<html>
  <head>
    <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    <div class="moz-cite-prefix">Dear Simon,<br>
      <br>
      Kevin is correct; as far as I can tell, there is no method of
      getting the functions calling a given function.  Instead, you have
      to start at the main() function and search for the function using
      a depth-first or breadth-first search.<br>
      <br>
      What may make sense is to build a new data structure that has
      nodes that point from callees to callers once and then use that
      for your queries.  That way, you're not researching the CallGraph
      all the time.<br>
      <br>
      One important note is that the CallGraph has an "external node"
      which represents all unresolved calls (e.g., indirect function
      calls).  Technically, you need to start searching from this node
      as well as the main() node (as a program can call out to external
      code which then calls back into the program; think of qsort() as
      an example).<br>
      <br>
      Regards,<br>
      <br>
      John Criswell<br>
      <br>
      On 2/26/15 10:13 PM, Kevin Hu wrote:<br>
    </div>
    <blockquote
cite="mid:CAH_2Da3uMT7_N_R_TnmUYw2kieGcKYAiqBaA5ZAwqBP+yna9TQ@mail.gmail.com"
      type="cite">
      <meta http-equiv="Context-Type" content="text/html; charset=UTF-8">
      <div dir="ltr"><img moz-do-not-send="true" height="1" width="1">
        <div class="gmail_extra">
          <div class="gmail_quote">
            <div>Hi Simon,</div>
            <div> <br>
            </div>
            <blockquote class="gmail_quote">
              From: Simone Atzeni <<a moz-do-not-send="true"
                href="mailto:simone.at@gmail.com">simone.at@gmail.com</a>><br>
              To: John Criswell <<a moz-do-not-send="true"
                href="mailto:jtcriswel@gmail.com">jtcriswel@gmail.com</a>><br>
              Cc: <a moz-do-not-send="true"
                href="mailto:llvmdev@cs.uiuc.edu">llvmdev@cs.uiuc.edu</a><br>
              Subject: Re: [LLVMdev] Walking thru CallGraph bottom up<br>
              Message-ID: <<a moz-do-not-send="true"
                href="mailto:318EBA41-2040-4EFE-B330-5813C817C2A2@gmail.com">318EBA41-2040-4EFE-B330-5813C817C2A2@gmail.com</a>><br>
              Content-Type: text/plain; charset="windows-1252"<br>
              <br>
              I think I got it and the example is pretty, however for
              what I understand, I can get the CallGraphNode for a given
              function F that has a list that represents all the
              functions that F is calling, but how can I get the list of
              the functions that are calling F? There is not a sort a
              similar list?<br>
            </blockquote>
            <div><br>
            </div>
            <div>After doing a simple search inside the LLVM documents,
              I found no so such data structures or methods for finding
              the callers of a CallGraphNode.</div>
            <div><br>
            </div>
            <div>However, since your problem is to find the path from
              main to the target function in the CallGraph, I think a
              depth-first-search from the main node might work.
              Following is the algorithm I have in mind.</div>
            <div><br>
            </div>
            <div>1. You can keep a list of functions in your search
              path, pushing to the list each time you visit a new node.</div>
            <div>2. If you find the one you currently have is a wrong
              path (you reach a leaf or a visited node), you pop out all
              the functions in the wrong path from your list.</div>
            <div>3. Search in another path, until you hit the node
              you're looking for. </div>
            <div>4. And then you can have a call path from main to your
              function in the list.</div>
            <div><br>
            </div>
            <div>Note that you may need a DFS on the entire CallGraph if
              you want all possible call paths from main to your
              function.</div>
            <div><br>
            </div>
            <div>IMHO, by getting a list of callers of a target function
              doesn't actually help simplify the problem a lot. You
              still need a  DFS or BFS from the node to find the main
              function node.</div>
            <div><br>
            </div>
            <div>Hope this helps a little.</div>
            <div><br>
            </div>
            <div>Apologies if you find any format, layout or etiquette
              problems in my mail. This is the first time I write to a
              mailing list.</div>
            <div><br>
            </div>
            <div>Thanks.</div>
            <div><br>
            </div>
            <div>---</div>
            <div>Regards,</div>
            <div>Kevin Hu</div>
            <div><a moz-do-not-send="true"
                href="mailto:hxy9243@gmail.com">hxy9243@gmail.com</a></div>
            <div> </div>
            <blockquote class="gmail_quote">
              Thanks.<br>
              Simone<br>
              <br>
              > On Feb 25, 2015, at 09:01, John Criswell <<a
                moz-do-not-send="true" href="mailto:jtcriswel@gmail.com">jtcriswel@gmail.com</a>>
              wrote:<br>
              ><br>
              > On 2/25/15 10:51 AM, Simone Atzeni wrote:<br>
              >> Thanks John.<br>
              >><br>
              >> I guess I will use a ModulePass, so when I am
              implementing the ?runOnModule? function,<br>
              >> do I have to loop through all the functions, for
              each functions all the BasicBlocks and for each BasicBlock
              all the instructions<br>
              ><br>
              > If you know the Instruction, you can get it's basic
              block using Instruction::getParent(), and then get its
              enclosing function using BasicBlock::getParent().<br>
              ><br>
              > Once you know the enclosing function, you can use the
              CallGraph pass to find which functions call it, and then
              repeat the procedures for functions calling that function,
              etc.<br>
              ><br>
              >> or given the Module I have to call the CallGraph
              directly?<br>
              >> Is there an example out there? I can?t find
              anything.<br>
              ><br>
              > It uses the DSA CallGraph pass, but <a
                moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/safecode/branches/release_32/lib/InsertPoolChecks/CFIChecks.cpp?revision=189030&view=markup"
                target="_blank">http://llvm.org/viewvc/llvm-project/safecode/branches/release_32/lib/InsertPoolChecks/CFIChecks.cpp?revision=189030&view=markup</a>
              <<a moz-do-not-send="true"
href="http://llvm.org/viewvc/llvm-project/safecode/branches/release_32/lib/InsertPoolChecks/CFIChecks.cpp?revision=189030&view=markup"
                target="_blank">http://llvm.org/viewvc/llvm-project/safecode/branches/release_32/lib/InsertPoolChecks/CFIChecks.cpp?revision=189030&view=markup</a>>
              might provide a decent example.<br>
              ><br>
              > Regards,<br>
              ><br>
              > John Criswell<br>
              ><br>
              >><br>
              >> Thanks.<br>
              >> Simone<br>
              >><br>
              >>> On Feb 24, 2015, at 13:29, John Criswell <<a
                moz-do-not-send="true" href="mailto:jtcriswel@gmail.com">jtcriswel@gmail.com</a>>
              wrote:<br>
              >>><br>
              >>> On 2/24/15 2:27 PM, Simone Atzeni wrote:<br>
              >>>> Hi all,<br>
              >>>><br>
              >>>> I would like to create a Pass that given
              an IR instruction walks starting from that instruction up
              to the main function<br>
              >>>> to identify all the functions call that
              have been made to call that instruction.<br>
              >>>><br>
              >>>> Is it possible? What kind of Pass should
              I create?<br>
              >>> Yes, it is possible.  I think a ModulePass
              would be most appropriate, though a FunctionPass may be
              alright.<br>
              >>><br>
              >>> To get the call graph, you can use LLVM's
              CallGraph analysis.  If you need to handle function
              pointers more accurately than LLVM's internal CallGraph
              analysis does, you can use DSA's CallGraph analysis (which
              has the same interface but may only work with LLVM 3.2 and
              earlier LLVM releases).<br>
              >>><br>
              >>> -- John T.<br>
              >>><br>
              >>>> Thanks<br>
              >>>> Best,<br>
              >>>> Simone<br>
              >>>><br>
              >>>> Simone Atzeni<br>
              >>>> <a moz-do-not-send="true"
                href="mailto:simone.at@gmail.com">simone.at@gmail.com</a><br>
              >>>> <a moz-do-not-send="true"
                href="tel:%2B1%20%28801%29%20696-8373"
                value="+18016968373">+1 (801) 696-8373</a><br>
              >>>><br>
              >>>><br>
              >>>>
              _______________________________________________<br>
              >>>> LLVM Developers mailing list<br>
              >>>> <a moz-do-not-send="true"
                href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a> 
                     <a moz-do-not-send="true"
                href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
              >>>> <a moz-do-not-send="true"
                href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev"
                target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
              >>><br>
              >>> --<br>
              >>> John Criswell<br>
              >>> Assistant Professor<br>
              >>> Department of Computer Science, University of
              Rochester<br>
              >>> <a moz-do-not-send="true"
                href="http://www.cs.rochester.edu/u/criswell"
                target="_blank">http://www.cs.rochester.edu/u/criswell</a><br>
              >>><br>
              ><br>
              ><br>
              > --<br>
              > John Criswell<br>
              > Assistant Professor<br>
              > Department of Computer Science, University of
              Rochester<br>
              > <a moz-do-not-send="true"
                href="http://www.cs.rochester.edu/u/criswell"
                target="_blank">http://www.cs.rochester.edu/u/criswell</a>
              <<a moz-do-not-send="true"
                href="http://www.cs.rochester.edu/u/criswell"
                target="_blank">http://www.cs.rochester.edu/u/criswell</a>><br>
              -------------- next part --------------<br>
              An HTML attachment was scrubbed...<br>
              URL: <<a moz-do-not-send="true"
href="http://lists.cs.uiuc.edu/pipermail/llvmdev/attachments/20150226/51760124/attachment-0001.html"
                target="_blank">http://lists.cs.uiuc.edu/pipermail/llvmdev/attachments/20150226/51760124/attachment-0001.html</a>><br>
              d of LLVMdev Digest, Vol 128, Issue 111<br>
              *****************************************<br>
            </blockquote>
          </div>
          <br>
          <br>
          <div><br>
          </div>
          <div class="gmail_signature">
            <div dir="ltr">Yours,
              <div>Kevin Hu</div>
            </div>
          </div>
        </div>
      </div>
    </blockquote>
    <br>
    <br>
    <pre class="moz-signature" cols="72">-- 
John Criswell
Assistant Professor
Department of Computer Science, University of Rochester
<a class="moz-txt-link-freetext" href="http://www.cs.rochester.edu/u/criswell">http://www.cs.rochester.edu/u/criswell</a></pre>
  </body>
</html>