blob: 857fbfc16458b8c10234bd7535fa7306fd8a341a [file] [log] [blame]
Chris Lattner10c91cc2003-10-28 22:11:31 +00001#!/usr/bin/perl -w
2#
3# Program: profile.pl
4#
5# Synopsis: Insert instrumentation code into a program, run it with the JIT,
6# then print out a profile report.
7#
8# Syntax: profile.pl [OPTIONS] bytecodefile <arguments>
9#
10# OPTIONS may include one or more of the following:
Chris Lattner2c14d2532003-10-28 22:52:05 +000011# -block - Enable basic block level profiling
Chris Lattner10c91cc2003-10-28 22:11:31 +000012#
Chris Lattner3538c9d2003-10-29 21:51:00 +000013# Any unrecognized options are passed into the invocation of llvm-prof
14#
Chris Lattner10c91cc2003-10-28 22:11:31 +000015
16my $ProfilePass = "-insert-function-profiling";
17
Chris Lattner3538c9d2003-10-29 21:51:00 +000018my $LLVMProfOpts = "";
19
Chris Lattner10c91cc2003-10-28 22:11:31 +000020# Parse arguments...
21while (scalar(@ARGV) and ($_ = $ARGV[0], /^[-+]/)) {
22 shift;
23 last if /^--$/; # Stop processing arguments on --
24
25 # List command line options here...
Chris Lattner5d8e5522003-11-02 05:17:32 +000026 if (/^-?-block$/) { $ProfilePass = "-insert-block-profiling"; next; }
27 if (/^-?-help$/) {
28 print "OVERVIEW: profile.pl - Instrumentation and profile printer.\n\n";
29 print "USAGE: profile.pl [options] program.bc <program args>\n\n";
30 print "OPTIONS:\n";
31 print " -block - Enable basic block level profiling\n";
32 print " -help - Print this usage information\n";
33 print "\nAll other options are passed into llvm-prof.\n";
34 exit 1;
35 }
Chris Lattner10c91cc2003-10-28 22:11:31 +000036
Chris Lattner3538c9d2003-10-29 21:51:00 +000037 # Otherwise, pass the option on to llvm-prof
38 $LLVMProfOpts .= " " . $_;
Chris Lattner10c91cc2003-10-28 22:11:31 +000039}
40
41die "Must specify LLVM bytecode file as first argument!" if (@ARGV == 0);
42
43my $BytecodeFile = $ARGV[0];
44
45shift @ARGV;
46
47my $LLIPath = `which lli`;
48$LLIPath = `dirname $LLIPath`;
49chomp $LLIPath;
50
51my $LibProfPath = $LLIPath . "/../../lib/Debug/libprofile_rt.so";
52
Chris Lattner5d8e5522003-11-02 05:17:32 +000053system "opt -q $ProfilePass < $BytecodeFile | lli -fake-argv0 '$BytecodeFile'" .
Chris Lattner2c14d2532003-10-28 22:52:05 +000054 " -load $LibProfPath - " . (join ' ', @ARGV);
Chris Lattner10c91cc2003-10-28 22:11:31 +000055
Chris Lattner3538c9d2003-10-29 21:51:00 +000056system "llvm-prof $LLVMProfOpts $BytecodeFile";