58 lines
1.5 KiB
Plaintext
58 lines
1.5 KiB
Plaintext
|
=pod
|
||
|
|
||
|
=head1 NAME
|
||
|
|
||
|
llvm-prof - print execution profile of LLVM program
|
||
|
|
||
|
=head1 SYNOPSIS
|
||
|
|
||
|
B<llvm-prof> [I<options>] [I<bitcode file>] [I<llvmprof.out>]
|
||
|
|
||
|
=head1 DESCRIPTION
|
||
|
|
||
|
The B<llvm-prof> tool reads in an F<llvmprof.out> file (which can
|
||
|
optionally use a specific file with the third program argument), a bitcode file
|
||
|
for the program, and produces a human readable report, suitable for determining
|
||
|
where the program hotspots are.
|
||
|
|
||
|
This program is often used in conjunction with the F<utils/profile.pl>
|
||
|
script. This script automatically instruments a program, runs it with the JIT,
|
||
|
then runs B<llvm-prof> to format a report. To get more information about
|
||
|
F<utils/profile.pl>, execute it with the B<-help> option.
|
||
|
|
||
|
=head1 OPTIONS
|
||
|
|
||
|
=over
|
||
|
|
||
|
=item B<--annotated-llvm> or B<-A>
|
||
|
|
||
|
In addition to the normal report printed, print out the code for the
|
||
|
program, annotated with 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.
|
||
|
|
||
|
=item B<--print-all-code>
|
||
|
|
||
|
Using this option enables the B<--annotated-llvm> option, but it
|
||
|
prints the entire module, instead of just the most commonly executed
|
||
|
functions.
|
||
|
|
||
|
=item B<--time-passes>
|
||
|
|
||
|
Record the amount of time needed for each pass and print it to standard
|
||
|
error.
|
||
|
|
||
|
=back
|
||
|
|
||
|
=head1 EXIT STATUS
|
||
|
|
||
|
B<llvm-prof> returns 1 if it cannot load the bitcode file or the profile
|
||
|
information. Otherwise, it exits with zero.
|
||
|
|
||
|
=head1 AUTHOR
|
||
|
|
||
|
B<llvm-prof> is maintained by the LLVM Team (L<http://llvm.org/>).
|
||
|
|
||
|
=cut
|