[Soot-list] Hi All,
Bernhard Berger
berber at tzi.de
Sat Apr 27 13:44:31 EDT 2013
Hi,
when I was using paddle I just added the command line options -p cg.paddle enabled:true. Why do you call paddle by hand?
Regards,
Bernhard
Am 27.04.2013 um 19:40 schrieb ASHISH MISHRA <ashish123.mishragkp at gmail.com>:
> Hi Marc,
> Thanks for the response and sorry if I am spamming the list. Following the other thread and your earlier suggestion , I removed my custom Driver and started using soot.Main.main(), by creating stub main methods, Instantiating required Class and Calling the Entry Points explicitly from there.
> Something like this-
> public static void main(String[] args) {
>
> ContactManager cm = new ContactManager();
> Bundle savedins = new Bundle();
>
> cm.onCreate(savedins);
>
>
>
> }// Currently I am modifying the source for test purposes.
>
>
>
> Using this I instrument the Body of some of the methods, to get modified jimple, Which I wish to pass a Call Graph constructor like Paddle or Spark.
>
> For Paddle I do something like this
> String[] soot_options= new String[]{
> "-w",
> //"-full-resolver",
> "-p",
> "jb",
> "use-original-names:true",
> "-src-prec",
> "jimple",
> "-p",
> "cg",
> "enabled:true",
> "-cp",
> "./out", //OUT has the instrumented Jimple files from the earlier run of Soot jtp phase
> "-pp",
> "-main-class",
> args[0],
>
> // "--app",
> args[0],
>
> //"-f",
> //"jimple"
>
>
> };
>
> PackManager.v().getPack("wjtp").add(
> new Transform("wjtp.myTransform", new SceneTransformer() {
> protected void internalTransform(String phase, Map options) {
>
> // CallGraph cg = null;
> //set paddle options
> HashMap opt = new HashMap();
> opt.put("enabled","true");
> opt.put("verbose","true");
> opt.put("src-prec", "jimple");
> opt.put("bdd","true");
> opt.put("backend","buddy");
> opt.put("context","kcfa");
> opt.put("context-heap", "true");
> // opt.put("context-counts","true");
> opt.put("k","2");
> opt.put("propagator","auto");
> opt.put("conf","ofcg-aot");
> opt.put("order","32");
> opt.put("q","auto");
> opt.put("set-impl","double");
> opt.put("double-set-old","hybrid");
> opt.put("double-set-new","hybrid");
> opt.put("pre-jimplify","true");
> opt.put("whole-program", "true");
> PaddleTransformer pt = new PaddleTransformer();
> PaddleOptions paddle_opt = new PaddleOptions(opt);
> pt.setup(paddle_opt);
> pt.solve(paddle_opt);
> soot.jimple.paddle.Results.v().makeStandardSootResults();
>
> CallGraph cg= Scene.v().getCallGraph(); //return paddle call graph
>
> System.out.println("Call Graph" + cg.toString());
>
> }));
> soot.Main.main(soot_options);
>
>
> But still I get the same Exception- as follows
> Exception in thread "main" java.lang.RuntimeException: Exception reference used other than as the first statement of an exception handler.
> at soot.jimple.toolkits.typing.fast.AugEvalFunction.eval_(AugEvalFunction.java:162)
> at soot.jimple.toolkits.typing.fast.AugEvalFunction.eval(AugEvalFunction.java:41)
> at soot.jimple.toolkits.typing.fast.TypeResolver.applyAssignmentConstraints(TypeResolver.java:407)
> at soot.jimple.toolkits.typing.fast.TypeResolver.inferTypes(TypeResolver.java:113)
>
> Any Suggestions or help can be a great
> Thanks
>
>
>
>
> On Sat, Apr 27, 2013 at 6:38 AM, Marc-André Laverdière-Papineau <marc-andre.laverdiere-papineau at polymtl.ca> wrote:
> Hi,
>
> I think the other thread on non-static entry points sort of answers that
> question already. But since someone could look at this thread when
> searching the archives, I'm going to just point to Bodden's tutorial :)
>
> Sorry again for getting mixed up on the soot main thing.
> http://www.bodden.de/2012/07/26/soot-custom-entry-points/
>
> Marc-André Laverdière-Papineau
> Doctorant - PhD Candidate
>
> On 04/25/2013 12:04 PM, ASHISH MISHRA wrote:
> >
> > Thanks Marc-Andre for the reply,
> >
> > Sorry for posting the query without any subject.
> > using soot.Main.main(), is it possible to set *entryPoints*. If I set
> > entryPoints and then call soot.Main(options) ,
> > 1)I get a compiler death exception, due to duplicate parsing of the
> > options. do I need to change the main() [make changes to
> > *processCmdLine()*] or Is there some other workaround.
> >
> >
> >
> >
> > On Thu, Apr 25, 2013 at 8:18 PM, Marc-André Laverdière-Papineau
> > <marc-andre.laverdiere-papineau at polymtl.ca
> > <mailto:marc-andre.laverdiere-papineau at polymtl.ca>> wrote:
> >
> > Hello Ashish,
> >
> > My only suggestion would be to try with Soot main :)
> > Anybody got a better idea?
> >
> > Marc-André Laverdière-Papineau
> > Doctorant - PhD Candidate
> >
> > On 04/25/2013 09:46 AM, ASHISH MISHRA wrote:
> > > I am trying to use the Jimple files as input to Paddle Call graph
> > > construction, for this I am setting jimple as the "-src-prec"
> > option and
> > > change the soot-class path appropriately. When I run the soot as
> > > Pack.v().PackMnager(); I get the following exception.
> > >
> > > library
> > >
> > path/usr/share/jdk1.7.0_01/jre/lib/i386/server:/usr/share/jdk1.7.0_01/jre/lib/i386:/usr/share/jdk1.7.0_01/jre/../lib/i386:/usr/share/jdk1.6.0_35/jre/lib/i386/client:/usr/share/jdk1.6.0_35/jre/lib/i386::/usr/java/packages/lib/i386:/lib:/usr/lib
> > > [Call Graph] For information on where the call graph may be
> > incomplete,
> > > use the verbose option to the cg phase.
> > > */Exception in thread "main" java.lang.RuntimeException: Exception
> > > reference used other than as the first statement of an exception
> > handler./*
> > > */at
> > >
> > soot.jimple.toolkits.typing.fast.AugEvalFunction.eval_(AugEvalFunction.java:162)/*
> > > */at
> > >
> > soot.jimple.toolkits.typing.fast.AugEvalFunction.eval(AugEvalFunction.java:41)/*
> > > */at
> > >
> > soot.jimple.toolkits.typing.fast.TypeResolver.applyAssignmentConstraints(TypeResolver.java:407)/*
> > > */at
> > >
> > soot.jimple.toolkits.typing.fast.TypeResolver.inferTypes(TypeResolver.java:113)/*
> > > */at
> > >
> > soot.jimple.toolkits.typing.TypeAssigner.internalTransform(TypeAssigner.java:101)/*
> > > */at soot.BodyTransformer.transform(BodyTransformer.java:51)/*
> > > */at soot.Transform.apply(Transform.java:104)/*
> > > */at soot.JimpleBodyPack.applyPhaseOptions(JimpleBodyPack.java:66)/*
> > > */at soot.JimpleBodyPack.internalApply(JimpleBodyPack.java:89)/*
> > > */at soot.Pack.apply(Pack.java:124)/*
> > > */at
> > soot.jimple.JimpleMethodSource.getBody(JimpleMethodSource.java:49)/*
> > > */at soot.SootMethod.getBodyFromMethodSource(SootMethod.java:89)/*
> > > */at soot.SootMethod.retrieveActiveBody(SootMethod.java:322)/*
> > > */at
> > >
> > soot.jimple.toolkits.callgraph.OnFlyCallGraphBuilder.processNewMethod(OnFlyCallGraphBuilder.java:531)/*
> > > */at
> > >
> > soot.jimple.toolkits.callgraph.OnFlyCallGraphBuilder.processReachables(OnFlyCallGraphBuilder.java:426)/*
> > > */at
> > >
> > soot.jimple.toolkits.callgraph.CallGraphBuilder.build(CallGraphBuilder.java:84)/*
> > > */at
> > >
> > soot.jimple.toolkits.callgraph.CHATransformer.internalTransform(CHATransformer.java:43)/*
> > > */at soot.SceneTransformer.transform(SceneTransformer.java:39)/*
> > > */at soot.Transform.apply(Transform.java:89)/*
> > > */at soot.RadioScenePack.internalApply(RadioScenePack.java:57)/*
> > > */at
> > >
> > soot.jimple.toolkits.callgraph.CallGraphPack.internalApply(CallGraphPack.java:49)/*
> > > */at soot.Pack.apply(Pack.java:114)/*
> > > */at soot.PackManager.runWholeProgramPacks(PackManager.java:417)/*
> > > */at soot.PackManager.runPacks(PackManager.java:336)/*
> > > */at callgraph.PaddleTest.main(PaddleTest.java:290)/*
> > > */
> > > /*
> > > */
> > > /*
> > > After debugging a little further I find out that , No active Body is
> > > present for the Entry Method OnCreate(). This looks odd , as I
> > can see
> > > the body present in the JimpleMethodSource's mTree field, I am
> > sure the
> > > problem occurs during Walking this tree to get the Body, but I am not
> > > sure Whats the reason.
> > >
> > > NOTE - The problem exists only when I pass the Jimple Body as
> > Input, To
> > > validate the jimple body, I called validate() after any
> > instrumentation
> > > made to the Jimple earlier. and it returns fine.
> > >
> > > Please provide the probable cause of the problem.
> > >
> > >
> > >
> > >
> > >
> > >
> > >
> > >
> > > --
> > > Regards,
> > > Ashish Mishra
> > > Graduate Student,
> > > Computer Science and Automation Department,IISc
> > > Cell : +91-9611194714
> > > Mailto : ashishmishra at csa.iisc.ernet.in
> > <mailto:ashishmishra at csa.iisc.ernet.in>
> > > <mailto:ashishmishra at csa.iisc.ernet.in
> > <mailto:ashishmishra at csa.iisc.ernet.in>>
> > >
> > >
> > >
> > > _______________________________________________
> > > Soot-list mailing list
> > > Soot-list at sable.mcgill.ca <mailto:Soot-list at sable.mcgill.ca>
> > > http://mailman.cs.mcgill.ca/mailman/listinfo/soot-list
> > >
> > _______________________________________________
> > Soot-list mailing list
> > Soot-list at sable.mcgill.ca <mailto:Soot-list at sable.mcgill.ca>
> > http://mailman.cs.mcgill.ca/mailman/listinfo/soot-list
> >
> >
> >
> >
> > --
> > Regards,
> > Ashish Mishra
> > Graduate Student,
> > Computer Science and Automation Department,IISc
> > Cell : +91-9611194714
> > Mailto : ashishmishra at csa.iisc.ernet.in
> > <mailto:ashishmishra at csa.iisc.ernet.in>
> >
> _______________________________________________
> Soot-list mailing list
> Soot-list at sable.mcgill.ca
> http://mailman.cs.mcgill.ca/mailman/listinfo/soot-list
>
>
>
> --
> Regards,
> Ashish Mishra
> Graduate Student,
> Computer Science and Automation Department,IISc
> Cell : +91-9611194714
> Mailto : ashishmishra at csa.iisc.ernet.in
>
> _______________________________________________
> Soot-list mailing list
> Soot-list at sable.mcgill.ca
> http://mailman.cs.mcgill.ca/mailman/listinfo/soot-list
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mailman.cs.mcgill.ca/pipermail/soot-list/attachments/20130427/a6681a64/attachment-0001.html
More information about the Soot-list
mailing list