b205209794ad1c585b7dfde7135d63db72ef6091
[oota-llvm.git] / docs / CommandGuide / opt.html
1 <html>
2 <title>LLVM: opt tool</title>
3
4 <body bgcolor=white>
5
6 <center><h1>LLVM: <tt>opt</tt> tool</h1></center>
7 <HR>
8
9 <h3>NAME</h3>
10 <tt>opt</tt>
11
12 <h3>SYNOPSIS</h3>
13 <tt>opt [options] [filename]</tt>
14
15 <h3>DESCRIPTION</h3>
16
17 The <tt>opt</tt> command is the modular LLVM optimizer.  It takes LLVM bytecode
18 as input, runs the specified optimizations on it, and then outputs the optimized
19 LLVM bytecode.
20 <p>
21
22 The optimizations available via <tt>opt</tt> depend upon what libraries were
23 linked into it as well as any additional libraries that have been loaded with
24 the <tt>-load</tt> option.  Use the <tt>-help</tt> option to determine what
25 optimizations you can use.
26 <p>
27
28 If no filename is specified on the command line, <tt>opt</tt> reads its input
29 from standard input.
30 <p>
31
32 If an output filename is not specified with the <tt>-o</tt> option, <tt>opt</tt>
33 writes its output to the standard output.
34
35
36 <h3>OPTIONS</h3>
37
38 <ul>
39         <li> -f
40         <br>
41         Force overwrite.  Normally, <tt>opt</tt> will refuse to overwrite an
42         output file that already exists.  With this option, <tt>opt</tt> will
43         overwrite the output file and replace it with new bytecode.
44         <p>
45
46         <li> -help
47         <br>
48         Print a summary of command line options.
49         <p>
50
51         <li> -o &lt;filename&gt;
52         <br>
53         Specify the output filename.
54         <p>
55
56         <li> -stats
57         <br>
58         Print statistics.
59         <p>
60
61         <li> -time-passes
62         <br>
63         Record the amount of time needed for each pass and print it to standard
64         error.
65         <p>
66
67         <li> -debug
68         <br>
69         If this is a debug build, this option will enable debug printouts from
70         passes which use the <tt>DEBUG</tt> macro.  See the <a
71         href="../ProgrammersManual.html#DEBUG">Programmer's Manual</a> for more
72         information.
73         <p>
74 <!--
75         <li> -internalize-public-api-file &lt;filename&gt;
76         <br>
77         Preserve the symbol names listed in the file filename.
78         <p>
79
80         <li> -internalize-public-api-list=&lt;list&gt;
81         <br>
82         Perserve the symbol names specified.
83         <p>
84 -->
85
86         <li> -q
87         <br>
88         Quiet mode.  Do not print messages on whether the program was modified.
89         <p>
90
91         <li> -load &lt;plugin.so&gt;
92         <br>
93         Load the dynamic object &lt;plugin.so&gt;.  This object should register new
94         optimization passes.  Once loaded, the object will add new command line
95         options to enable various optimizations.  To see the new complete list
96         of optimizations, use the -help and -load options together:
97         <p>
98         <tt>opt -load  &lt;plugin.so&gt; -help</tt>
99         <p>
100
101         <li> -p
102         <br>
103         Print module after each transformation.
104         <p>
105 </ul>
106
107 <h3>EXIT STATUS</h3>
108
109 If <tt>opt</tt> succeeds, it will exit with 0.  Otherwise, if an error occurs,
110 it will exit with a non-zero value.
111
112 <h3>SEE ALSO</h3>
113
114 <a href="analyze.html"><tt>analyze</tt></a>
115
116 <HR>
117 Maintained by the <a href="http://llvm.cs.uiuc.edu">LLVM Team</a>.
118 </body>
119 </html>
120