aboutsummaryrefslogtreecommitdiffstats
path: root/docs/CommandGuide/llvm-prof.html
blob: 5f1c48dcc1ebd5bb289b0b33e3dd5d1fef7855fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<html>
<title>LLVM: llvm-prof tool</title>

<body bgcolor=white>

<center><h1>LLVM: <tt>llvm-prof</tt> tool</h1></center>
<HR>

<h3>NAME</h3>
<tt>llvm-prof</tt>

<h3>SYNOPSIS</h3>
<tt>llvm-prof [options] [bytecode file] [llvmprof.out]</tt>

<h3>DESCRIPTION</h3>

The <tt>llvm-prof</tt> tool reads in an '<tt>llvmprof.out</tt>' file (which can
optionally use a specific file with the third program argument), a bytecode file
for the program, and produces a human readable report, suitable for determining
where the program hotspots are.<p>

This program is often used in conjunction with the <tt>utils/profile.pl</tt>
script.  This script automatically instruments a program, runs it with the JIT,
then runs <tt>llvm-prof</tt> to format a report.  To get more information about
<tt>utils/profile.pl</tt>, execute it with the <tt>--help</tt> option.<p>

<h3>OPTIONS</h3>

<ul>
	<li><tt>--annotated-llvm</tt> or <tt>-A</tt><br>

        In addition to the normal report printed, print out the code for the
        program, annotated we execution frequency information. This can be
        particularly useful when trying to visualize how frequently basic blocks
        are executed.  This is most useful with basic block profiling
        information or better.<p>

	<li><tt>--print-all-code</tt><br>

        Using this option enables the <tt>--annotated-llvm</tt> option, but it
        prints the entire module, instead of just the most commonly executed
        functions.<p>
</ul>

<h3>EXIT STATUS</h3>

<tt>llvm-prof</tt> returns 1 if it cannot load the bytecode file or the profile
information, otherwise it exits with zero.

<HR>
Maintained by the <a href="http://llvm.cs.uiuc.edu">LLVM Team</a>.
</body>
</html>