[Soot-list] Exceptions in IFDS Analysis

Henddher Pedroza hpedro2 at uic.edu
Fri Apr 5 16:44:40 EDT 2013


I was getting strange exceptions also, and after letting it run pass the exceptions, it ended up with OOE. 
I bumped up the heap size to 4000M and it seems to be ok now.

-Xmx4000m

I am actually running IDE Main + IFDSUninitializedVariables on a dummy stand-alone java app with 5 classes (~5K uncompressed)

But, I don't know :(

On Apr 5, 2013, at 3:35 PM, Marc-André Laverdière-Papineau <marc-andre.laverdiere-papineau at polymtl.ca> wrote:

> Hello,
> 
> I have been getting this problem only recently, and I am not sure what I 
> am doing wrong.
> 
> I am getting exceptions like these:
> 
> Exception in thread "pool-2-thread-1" java.lang.NullPointerException
> 	at 
> com.google.common.base.Preconditions.checkNotNull(Preconditions.java:191)
> 	at com.google.common.cache.LocalCache.get(LocalCache.java:3989)
> 	at com.google.common.cache.LocalCache.getOrLoad(LocalCache.java:3994)
> 	at 
> com.google.common.cache.LocalCache$LocalLoadingCache.get(LocalCache.java:4878)
> 	at 
> com.google.common.cache.LocalCache$LocalLoadingCache.getUnchecked(LocalCache.java:4884)
> 	at 
> soot.jimple.toolkits.ide.icfg.JimpleBasedInterproceduralCFG.getOrCreateUnitGraph(JimpleBasedInterproceduralCFG.java:174)
> 	at 
> soot.jimple.toolkits.ide.icfg.JimpleBasedInterproceduralCFG.isExitStmt(JimpleBasedInterproceduralCFG.java:199)
> 
> and
> 
> Exception in thread "main" java.lang.NullPointerException
> 	at 
> soot.jimple.toolkits.ide.icfg.JimpleBasedInterproceduralCFG.getMethodOf(JimpleBasedInterproceduralCFG.java:163)
> 	at 
> soot.jimple.toolkits.ide.icfg.JimpleBasedInterproceduralCFG.getMethodOf(JimpleBasedInterproceduralCFG.java:65)
> 	at heros.solver.IDESolver.setVal(IDESolver.java:576)
> 
> Digging a bit, I am seeing that unitToOwner returns null in this chunk 
> of code, when u is an IdentityStmt.
> 
> 	@Override
> 	public boolean isExitStmt(Unit u) {
> 		Body body = unitToOwner.get(u);
> 		DirectedGraph<Unit> unitGraph = getOrCreateUnitGraph(body);
> 		return unitGraph.getTails().contains(u);
> 	}
> 
> Even when I breakpoint and look down in the trace, I am unable to 
> determine where it is coming from, or why is it that a given method is 
> analyzed or not. You can say that troubleshooting is hard :(
> 
> Has anybody else ever dealt with this? How did you fix it?
> 
> P.S. I am running with some exclusions and -no-bodies-for-excluded
> P.P.S I tried feeding all the units in the application classes in 
> unitToOwner and I'm still hitting this problem.
> 
> Regards,
> 
> -- 
> Marc-André Laverdière-Papineau
> Doctorant - PhD Candidate
> _______________________________________________
> Soot-list mailing list
> Soot-list at sable.mcgill.ca
> http://mailman.cs.mcgill.ca/mailman/listinfo/soot-list



More information about the Soot-list mailing list