[Soot-list] Callgraphs, CHATransformer

Eric Bodden eric.bodden at mail.mcgill.ca
Thu Mar 12 10:35:43 EDT 2009


> Maybe this helps for you.

Not really. A VM just exiting without calling System.exit(..)
certainly looks like a VM bug to me. I don't see what else could cause
this...

Eric

>
>
> Greetings,
> Marco.
>
>
> Eric Bodden schrieb am 2009-02-18 18:45:
>>
>> To me this seems to be a bug in Sun's JVM. There is no call to
>> System.exit(..). Yet, as you wrote, the call to
>> CallGraphBuilder.build() never returns.
>>
>> I have seen such behavior on Sun JVMs before. Could you try another
>> VM, e.g. IBM's J9?
>>
>> Eric
>>
>> 2009/2/18 Marco Bakera <marco.bakera at tu-dortmund.de>:
>>>
>>> Hi Eric,
>>>
>>> thank you for the fast answer. I tried the following code but again Soot
>>> exits
>>> when invoking the main method. Further, I was not able to see the scene
>>> transformer's internalTransform method being invoked.
>>>
>>> Could you please tell me what is the problem with my simple
>>> implementation?
>>>
>>>
>>> public class CallGraphGenerationTest {
>>>
>>>       @Test
>>>       public void testCallGraphGeneration() throws Exception {
>>>               G.reset();
>>>
>>>               CallGraphFetcher callGraphFetcher = new CallGraphFetcher();
>>>               PackManager.v().getPack("wjtp").add(new
>>> Transform("wjtp.cgfetcher",
>>> callGraphFetcher));
>>>
>>>               String args = "-w " + OmgClass.class.getName();
>>>
>>> System.out.println("CallGraphGenerationTest.testCallGraphGeneration()
>>> invoking soot with "+args);
>>>               Main.main(args.split(" "));
>>>       }
>>>
>>>       private static class CallGraphFetcher extends SceneTransformer {
>>>
>>>               private CallGraph callGraph;
>>>
>>>               @Override
>>>               protected void internalTransform(String phaseName, Map
>>> options) {
>>>
>>> System.out.println("CallGraphFetcher.internalTransform() fetching call
>>> graph from scene");
>>>                       this.callGraph = Scene.v().getCallGraph();
>>>               }
>>>
>>>               public CallGraph getCallGraph() {
>>>                       return callGraph;
>>>               }
>>>       }
>>>
>>>       private static class OmgClass {
>>>
>>>               private int a;
>>>               private int b;
>>>               @SuppressWarnings("unused")
>>>               private int stop;
>>>
>>>               public OmgClass(int a, int b) {
>>>                       this.a = a;
>>>                       this.b = b;
>>>               }
>>>
>>>               public void omfg(int c) {
>>>                       for (int i=a; i<c; i++) {
>>>                               System.out.println(c+b);
>>>                               omfg(--c);
>>>                       }
>>>               }
>>>
>>>               public static void main(String[] args){
>>>                       OmgClass it = new OmgClass(1, 10);
>>>                       it.omfg(6);
>>>               }
>>>       }
>>> }
>>>
>>>
>>> Best regards,
>>> Marco.
>>>
>>> On Wednesday 18 February 2009 15:21:03 Eric Bodden wrote:
>>>>
>>>> Hi.
>>>>
>>>> At the point at which you call transform(), nothing at all has been
>>>> initialized. You should put your call to transform() into a
>>>> SceneTransformer, preferably within the wjtp pack. Then you have to
>>>> call Soot's main method. This will automatically take care of parsing
>>>> the command line, initializing Soot accordingly and then calling your
>>>> transformer.
>>>>
>>>> You may want to look at our tutorials, especially into this one here
>>>> that explains the various packs and also how to insert a transform:
>>>> http://www.bodden.de/2008/11/26/soot-packs/
>>>>
>>>> Eric
>>>>
>>>> 2009/2/18 André Lobitz <andre-lobitz at gmx.de>:
>>>>>
>>>>> I am trying to create callgraphs using soot. Therefore i've added the
>>>>> Soot-classes.jar to my library list and written a small class (see
>>>>> below). I am only getting the error message
>>>>>    [Call Graph] For information on where the call graph may be
>>>>> incomplete, use the verbose option to the cg phase.
>>>>> and a NullPointerException. It seems to be the call
>>>>>    CHATransformer.v().transform();
>>>>> throwing the Exception. Can anyone help me?
>>>>>
>>>>> Thanx,
>>>>> André
>>>>>
>>>>>
>>>>> -------------------------------------------------------------------------
>>>>>
>>>>> --------------------------------------------------------------------------
>>>>> -----------------
>>>>>
>>>>> package diplom.main;
>>>>>
>>>>> import soot.jimple.toolkits.callgraph.*;
>>>>> import java.util.Iterator;
>>>>> import soot.Scene;
>>>>> import soot.SootClass;
>>>>> import soot.SootMethod;
>>>>> import soot.options.Options;
>>>>>
>>>>> public class SootTest {
>>>>>
>>>>>    public static void main(String[] args) {
>>>>>        CHATransformer.v().transform();
>>>>>
>>>>>        Options.v().set_whole_program(true);
>>>>>        SootClass mainClass =
>>>>> Scene.v().loadClassAndSupport("diplom.testers.omg");
>>>>>        mainClass.setApplicationClass();
>>>>>        Scene.v().setMainClass(mainClass);
>>>>>
>>>>>        SootMethod src = mainClass.getMethodByName("main");
>>>>>        CallGraph cg = Scene.v().getCallGraph();
>>>>>        Iterator targets = new Targets(cg.edgesOutOf(src));
>>>>>        while (targets.hasNext()) {
>>>>>            SootMethod tgt = (SootMethod) targets.next();
>>>>>            System.out.println(src + " may call " + tgt);
>>>>>        }
>>>>>    }
>>>>> }
>>>>>
>>>>> -------------------------------------------------------------------------
>>>>>
>>>>> --------------------------------------------------------------------------
>>>>> -----------------
>>>>>
>>>>> package diplom.testers;
>>>>>
>>>>> public class omg {
>>>>>
>>>>>    int a;
>>>>>    int b;
>>>>>    int stop;
>>>>>
>>>>>    public omg(int a, int b){
>>>>>        this.a = a;
>>>>>        this.b = b;
>>>>>    }
>>>>>
>>>>>    public void omfg(int c){
>>>>>        for (int i=a; i<c; i++){
>>>>>            System.out.println(c+b);
>>>>>            omfg(--c);
>>>>>        }
>>>>>    }
>>>>>
>>>>>    public static void main(String[] args){
>>>>>        omg it = new omg(1, 10);
>>>>>        it.omfg(6);
>>>>>    }
>>>>>
>>>>> }
>>>>>
>



-- 
Eric Bodden
Sable Research Group, McGill University
Montréal, Québec, Canada


More information about the Soot-list mailing list