[llvm-commits] 	CVS: llvm-www/releases/1.4/docs/CommandGuide/html/.cvsignore	analyze.html bugpoint.html extract.html gccas.html gccld.html	llc.html lli.html llvm-ar.html llvm-as.html	llvm-bcanalyzer.html llvm-db.html llvm-dis.html llvm-ld.html	llvm-link.html llvm-nm.html llvm-prof.html llvm-ranlib.html	llvmc.html llvmgcc.html llvmgxx.html manpage.css opt.html	stkrc.html 
    John Criswell 
    criswell at cs.uiuc.edu
       
    Thu Dec  9 14:19:15 PST 2004
    
    
  
Changes in directory llvm-www/releases/1.4/docs/CommandGuide/html:
.cvsignore added (r1.1)
analyze.html added (r1.1)
bugpoint.html added (r1.1)
extract.html added (r1.1)
gccas.html added (r1.1)
gccld.html added (r1.1)
llc.html added (r1.1)
lli.html added (r1.1)
llvm-ar.html added (r1.1)
llvm-as.html added (r1.1)
llvm-bcanalyzer.html added (r1.1)
llvm-db.html added (r1.1)
llvm-dis.html added (r1.1)
llvm-ld.html added (r1.1)
llvm-link.html added (r1.1)
llvm-nm.html added (r1.1)
llvm-prof.html added (r1.1)
llvm-ranlib.html added (r1.1)
llvmc.html added (r1.1)
llvmgcc.html added (r1.1)
llvmgxx.html added (r1.1)
manpage.css added (r1.1)
opt.html added (r1.1)
stkrc.html added (r1.1)
---
Log message:
Adding in documentation for LLVM 1.4.
---
Diffs of the changes:  (+4521 -0)
Index: llvm-www/releases/1.4/docs/CommandGuide/html/.cvsignore
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/.cvsignore:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/.cvsignore	Thu Dec  9 16:19:03 2004
***************
*** 0 ****
--- 1 ----
+ *html
Index: llvm-www/releases/1.4/docs/CommandGuide/html/analyze.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/analyze.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/analyze.html	Thu Dec  9 16:19:03 2004
***************
*** 0 ****
--- 1,120 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>analyze</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>analyze - LLVM program analyzer</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>analyze</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>analyze</strong> command performs various analysis of LLVM assembly
+ code or bytecode.  It will usually print the results on standard
+ output, but in a few cases, it will print output to standard error
+ or generate a file with the analysis output, which is usually done
+ when the output is meant for another program.</p>
+ <p>If filename is omitted or is <em>-</em>, <strong>analyze</strong> reads its input from
+ standard input.  It first attempts to interpret its input as LLVM
+ bytecode.  If it encounters an error, it then attempts to parse the
+ input as LLVM assembly language.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dhelp"><strong>-help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dq"><strong>-q</strong></a></strong><br />
+ </dt>
+ <dd>
+ Quiet mode.  With this option, analysis pass names are not printed.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dload_plugin"><strong>-load</strong> <em>plugin</em></a></strong><br />
+ </dt>
+ <dd>
+ Load the specified dynamic object with name <em>plugin</em>.  This file
+ should contain additional analysis passes that register themselves
+ with the <strong>analyze</strong> program after being loaded.
+ </dd>
+ <dd>
+ <p>After being loaded, additional command line options are made
+ available for running the passes made available by <em>plugin</em>.  Use
+ <strong>analyze -load</strong> <em>plugin</em> <strong>-help</strong> to see the new list of available
+ analysis passes.</p>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dprofile_2dinfo_2dfile_filename"><strong>-profile-info-file</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the name of the file loaded by the -profile-loader option.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dstats"><strong>-stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>analyze</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././opt.html">opt</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/bugpoint.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/bugpoint.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/bugpoint.html	Thu Dec  9 16:19:03 2004
***************
*** 0 ****
--- 1,309 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>bugpoint</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#design_philosophy">Design Philosophy</a></li>
+ 		<li><a href="#automatic_debugger_selection">Automatic Debugger Selection</a></li>
+ 		<li><a href="#crash_debugger">Crash debugger</a></li>
+ 		<li><a href="#code_generator_debugger">Code generator debugger</a></li>
+ 		<li><a href="#miscompilation_debugger">Miscompilation debugger</a></li>
+ 		<li><a href="#advice_for_using_bugpoint">Advice for using bugpoint</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#author">AUTHOR</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>bugpoint - automatic test case reduction tool</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>bugpoint</strong> [<em>options</em>] [<em>input LLVM ll/bc files</em>] [<em>LLVM passes</em>] <strong>--args</strong>
+ <em>program arguments</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p><strong>bugpoint</strong> narrows down the source of problems in LLVM tools and passes.  It
+ can be used to debug three types of failures: optimizer crashes, miscompilations
+ by optimizers, or bad native code generation (including problems in the static
+ and JIT compilers).  It aims to reduce large test cases to small, useful ones.
+ For example, if <strong>gccas</strong> crashes while optimizing a file, it will identify the
+ optimization (or combination of optimizations) that causes the crash, and reduce
+ the file down to a small example which triggers the crash.</p>
+ <p>
+ </p>
+ <h2><a name="design_philosophy">Design Philosophy</a></h2>
+ <p><strong>bugpoint</strong> is designed to be a useful tool without requiring any hooks into the
+ LLVM infrastructure at all.  It works with any and all LLVM passes and code
+ generators, and does not need to ``know'' how they work.  Because of this, it may
+ appear to do stupid things or miss obvious simplifications.  <strong>bugpoint</strong> is also
+ designed to trade off programmer time for computer time in the
+ compiler-debugging process; consequently, it may take a long period of
+ (unattended) time to reduce a test case, but we feel it is still worth it. Note
+ that <strong>bugpoint</strong> is generally very quick unless debugging a miscompilation where
+ each test of the program (which requires executing it) takes a long time.</p>
+ <p>
+ </p>
+ <h2><a name="automatic_debugger_selection">Automatic Debugger Selection</a></h2>
+ <p><strong>bugpoint</strong> reads each <em>.bc</em> or <em>.ll</em> file specified on the command line and
+ links them together into a single module, called the test program.  If any LLVM
+ passes are specified on the command line, it runs these passes on the test
+ program.  If any of the passes crash, or if they produce malformed output (which
+ causes the verifier to abort), <strong>bugpoint</strong> starts the crash debugger.</p>
+ <p>Otherwise, if the <strong>-output</strong> option was not specified, <strong>bugpoint</strong> runs the test
+ program with the C backend (which is assumed to generate good code) to generate
+ a reference output.  Once <strong>bugpoint</strong> has a reference output for the test
+ program, it tries executing it with the selected code generator.  If the
+ selected code generator crashes, <strong>bugpoint</strong> starts the <a href="#crash_debugger">Crash debugger</a> on
+ the code generator.  Otherwise, if the resulting output differs from the
+ reference output, it assumes the difference resulted from a code generator
+ failure, and starts the <a href="#code_generator_debugger">Code generator debugger</a>.</p>
+ <p>Finally, if the output of the selected code generator matches the reference
+ output, <strong>bugpoint</strong> runs the test program after all of the LLVM passes have been
+ applied to it.  If its output differs from the reference output, it assumes the
+ difference resulted from a failure in one of the LLVM passes, and enters the
+ miscompilation debugger. Otherwise, there is no problem <strong>bugpoint</strong> can debug.</p>
+ <p>
+ </p>
+ <h2><a name="crash_debugger">Crash debugger</a></h2>
+ <p>If an optimizer or code generator crashes, <strong>bugpoint</strong> will try as hard as it
+ can to reduce the list of passes (for optimizer crashes) and the size of the
+ test program.  First, <strong>bugpoint</strong> figures out which combination of optimizer
+ passes triggers the bug. This is useful when debugging a problem exposed by
+ <strong>gccas</strong>, for example, because it runs over 38 passes.</p>
+ <p>Next, <strong>bugpoint</strong> tries removing functions from the test program, to reduce its
+ size.  Usually it is able to reduce a test program to a single function, when
+ debugging intraprocedural optimizations.  Once the number of functions has been
+ reduced, it attempts to delete various edges in the control flow graph, to
+ reduce the size of the function as much as possible.  Finally, <strong>bugpoint</strong>
+ deletes any individual LLVM instructions whose absence does not eliminate the
+ failure.  At the end, <strong>bugpoint</strong> should tell you what passes crash, give you a
+ bytecode file, and give you instructions on how to reproduce the failure with
+ <strong>opt</strong>, <strong>analyze</strong>, or <strong>llc</strong>.</p>
+ <p>
+ </p>
+ <h2><a name="code_generator_debugger">Code generator debugger</a></h2>
+ <p>The code generator debugger attempts to narrow down the amount of code that is
+ being miscompiled by the selected code generator.  To do this, it takes the test
+ program and partitions it into two pieces: one piece which it compiles with the
+ C backend (into a shared object), and one piece which it runs with either the
+ JIT or the static compiler (<strong>llc</strong>).  It uses several techniques to reduce the
+ amount of code pushed through the LLVM code generator, to reduce the potential
+ scope of the problem.  After it is finished, it emits two bytecode files (called
+ ``test'' [to be compiled with the code generator] and ``safe'' [to be compiled with
+ the C backend], respectively), and instructions for reproducing the problem.
+ The code generator debugger assumes that the C backend produces good code.</p>
+ <p>
+ </p>
+ <h2><a name="miscompilation_debugger">Miscompilation debugger</a></h2>
+ <p>The miscompilation debugger works similarly to the code generator debugger.  It
+ works by splitting the test program into two pieces, running the optimizations
+ specified on one piece, linking the two pieces back together, and then executing
+ the result.  It attempts to narrow down the list of passes to the one (or few)
+ which are causing the miscompilation, then reduce the portion of the test
+ program which is being miscompiled.  The miscompilation debugger assumes that
+ the selected code generator is working properly.</p>
+ <p>
+ </p>
+ <h2><a name="advice_for_using_bugpoint">Advice for using bugpoint</a></h2>
+ <p><strong>bugpoint</strong> can be a remarkably useful tool, but it sometimes works in
+ non-obvious ways.  Here are some hints and tips:</p>
+ <ul>
+ <li></li>
+ In the code generator and miscompilation debuggers, <strong>bugpoint</strong> only
+ works with programs that have deterministic output.  Thus, if the program
+ outputs <code>argv[0]</code>, the date, time, or any other ``random'' data, <strong>bugpoint</strong> may
+ misinterpret differences in these data, when output, as the result of a
+ miscompilation.  Programs should be temporarily modified to disable outputs that
+ are likely to vary from run to run.
+ <p></p>
+ <li></li>
+ In the code generator and miscompilation debuggers, debugging will go faster if
+ you manually modify the program or its inputs to reduce the runtime, but still
+ exhibit the problem.
+ <p></p>
+ <li></li>
+ <strong>bugpoint</strong> is extremely useful when working on a new optimization: it helps
+ track down regressions quickly.  To avoid having to relink <strong>bugpoint</strong> every
+ time you change your optimization, make <strong>bugpoint</strong> dynamically load
+ your optimization by using the <strong>-load</strong> option.
+ <p></p>
+ <li></li>
+ <strong>bugpoint</strong> can generate a lot of output and run for a long period of time.  It
+ is often useful to capture the output of the program to file.  For example, in
+ the C shell, you can type:
+ <pre>
+     bugpoint ... |& tee bugpoint.log</pre>
+ <p>to get a copy of <strong>bugpoint</strong>'s output in the file <em>bugpoint.log</em>, as well as on
+ your terminal.</p>
+ <p></p>
+ <li></li>
+ <strong>bugpoint</strong> cannot debug problems with the LLVM linker. If <strong>bugpoint</strong> crashes
+ before you see its <code>All input ok</code> message, you might try running <code>llvm-link
+ -v</code> on the same set of input files. If that also crashes, you may be
+ experiencing a linker bug.
+ <p></p>
+ <li></li>
+ If your program is supposed to crash, <strong>bugpoint</strong> will be confused. One way to
+ deal with this is to cause <strong>bugpoint</strong> to ignore the exit code from your
+ program, by giving it the <strong>-check-exit-code=false</strong> option.
+ <p></p></ul>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2d_2dadditional_2dso_library"><strong>--additional-so</strong> <em>library</em></a></strong><br />
+ </dt>
+ <dd>
+ Load the dynamic shared object <em>library</em> into the test program whenever it is
+ run.  This is useful if you are debugging programs which depend on non-LLVM
+ libraries (such as the X or curses libraries) to run.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dargs_program_args"><strong>--args</strong> <em>program args</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass all arguments specified after -args to the test program whenever it runs.
+ Note that if any of the <em>program args</em> start with a '-', you should use:
+ </dd>
+ <dd>
+ <pre>
+     bugpoint [bugpoint args] --args -- [program args]</pre>
+ </dd>
+ <dd>
+ <p>The ``--'' right after the <strong>--args</strong> option tells <strong>bugpoint</strong> to consider any
+ options starting with <code>-</code> to be part of the <strong>--args</strong> option, not as options to
+ <strong>bugpoint</strong> itself.</p>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtool_2dargs_tool_args"><strong>--tool-args</strong> <em>tool args</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass all arguments specified after --tool-args to the LLVM tool under test
+ (<strong>llc</strong>, <strong>lli</strong>, etc.) whenever it runs.  You should use this option in the
+ following way:
+ </dd>
+ <dd>
+ <pre>
+     bugpoint [bugpoint args] --tool-args -- [tool args]</pre>
+ </dd>
+ <dd>
+ <p>The ``--'' right after the <strong>--tool-args</strong> option tells <strong>bugpoint</strong> to consider any
+ options starting with <code>-</code> to be part of the <strong>--tool-args</strong> option, not as
+ options to <strong>bugpoint</strong> itself. (See <strong>--args</strong>, above.)</p>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dcheck_2dexit_2dcode_3d_7btrue_2cfalse_7d"><strong>--check-exit-code</strong>=<em>{true,false}</em></a></strong><br />
+ </dt>
+ <dd>
+ Assume a non-zero exit code or core dump from the test program is a failure.
+ Defaults to true.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2ddisable_2d_7bdce_2csimplifycfg_7d"><strong>--disable-{dce,simplifycfg}</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not run the specified passes to clean up and reduce the size of the test
+ program. By default, <strong>bugpoint</strong> uses these passes internally when attempting to
+ reduce test programs.  If you're trying to find a bug in one of these passes,
+ <strong>bugpoint</strong> may crash.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dinput_filename"><strong>--input</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Open <em>filename</em> and redirect the standard input of the test program, whenever
+ it runs, to come from that file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dload_plugin"><strong>--load</strong> <em>plugin</em></a></strong><br />
+ </dt>
+ <dd>
+ Load the dynamic object <em>plugin</em> into <strong>bugpoint</strong> itself.  This object should
+ register new optimization passes.  Once loaded, the object will add new command
+ line options to enable various optimizations.  To see the new complete list of
+ optimizations, use the <strong>--help</strong> and <strong>--load</strong> options together; for example:
+ </dd>
+ <dd>
+ <pre>
+     bugpoint --load myNewPass.so --help</pre>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2doutput_filename"><strong>--output</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Whenever the test program produces output on its standard output stream, it
+ should match the contents of <em>filename</em> (the ``reference output''). If you
+ do not use this option, <strong>bugpoint</strong> will attempt to generate a reference output
+ by compiling the program with the C backend and running it.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dprofile_2dinfo_2dfile_filename"><strong>--profile-info-file</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Profile file loaded by <strong>--profile-loader</strong>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2drun_2d_7bint_2cjit_2cllc_2ccbe_7d"><strong>--run-{int,jit,llc,cbe}</strong></a></strong><br />
+ </dt>
+ <dd>
+ Whenever the test program is compiled, <strong>bugpoint</strong> should generate code for it
+ using the specified code generator.  These options allow you to choose the
+ interpreter, the JIT compiler, the static native code compiler, or the C
+ backend, respectively.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>bugpoint</strong> succeeds in finding a problem, it will exit with 0.  Otherwise,
+ if an error occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././opt.html">opt</a>, <a href="././analyze.html">analyze</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="author">AUTHOR</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/extract.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/extract.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/extract.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,115 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>extract</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>extract - extract a function from an LLVM module</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>extract</strong> [<em>options</em>] <strong>--func</strong> <em>function-name</em> [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>extract</strong> command takes the name of a function and extracts it from
+ the specified LLVM bytecode file.  It is primarily used as a debugging tool to
+ reduce test cases from larger programs that are triggering a bug.</p>
+ <p>In addition to extracting the bytecode of the specified function,
+ <strong>extract</strong> will also remove unreachable global variables, prototypes, and
+ unused types.</p>
+ <p>The <strong>extract</strong> command reads its input from standard input if filename is
+ omitted or if filename is -.  The output is always written to standard output,
+ unless the <strong>-o</strong> option is specified (see below).</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Force overwrite.  Normally, <strong>extract</strong> will refuse to overwrite an
+ output file that already exists.  With this option, <strong>extract</strong>
+ will overwrite the output file and replace it with new bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dfunc_function_2dname"><strong>--func</strong> <em>function-name</em></a></strong><br />
+ </dt>
+ <dd>
+ Extract the function named <em>function-name</em> from the LLVM bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output filename.  If filename is ``-'' (the default), then
+ <strong>extract</strong> sends its output to standard output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dstats"><strong>--stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>extract</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././bugpoint.html">bugpoint</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/gccas.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/gccas.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/gccas.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,122 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>gccas</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>gccas - optimizing LLVM assembler</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>gccas</strong> [<em>options</em>] <em>filename</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>gccas</strong> utility takes an LLVM assembly file generated by the
+ <a href="././llvmgcc.html">llvmgcc</a> or <a href="././llvmgxx.html">llvmg++</a> front-ends and converts
+ it into an LLVM bytecode file.  It is primarily used by the GCC
+ front end, and as such, attempts to mimic the interface provided
+ by the default system assembler so that it can act as a ``drop-in''
+ replacement.</p>
+ <p><strong>gccas</strong> performs a number of optimizations on the input program,
+ including but not limited to: promotion of stack values to SSA
+ registers; elimination of dead globals, function arguments, code,
+ and types; tail-call elimination; loop-invariant code motion; global
+ common-subexpression elimination; and sparse conditional constant
+ propagation.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the name of the output file which will hold the assembled bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2ddisable_2dinlining"><strong>--disable-inlining</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable the inlining pass.  By default, it is enabled.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2ddisable_2dopt"><strong>--disable-opt</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable all assembler-time optimization passes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dstats"><strong>--stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dverify"><strong>--verify</strong></a></strong><br />
+ </dt>
+ <dd>
+ Verify each pass result.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>gccas</strong> succeeds, it will exit with an exit status of 0.
+ Otherwise, if an error occurs, it will exit with a non-zero exit
+ status.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-as.html">llvm-as</a>, <a href="././gccld.html">gccld</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/gccld.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/gccld.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/gccld.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,251 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>gccld</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#search_order">Search Order</a></li>
+ 		<li><a href="#link_order">Link order</a></li>
+ 		<li><a href="#library_linkage">Library Linkage</a></li>
+ 		<li><a href="#native_code_generation">Native code generation</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>gccld - optimizing LLVM linker</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>gccld</strong> [<em>options</em>] <em>filename ...</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>gccld</strong> utility takes a set of LLVM bytecode files and links them
+ together into a single LLVM bytecode file.  The output bytecode file can be
+ another bytecode library or an executable bytecode program.  Using additional
+ options, <strong>gccld</strong> is able to produce native code executables.</p>
+ <p>The <strong>gccld</strong> utility is primarily used by the <a href="././llvmgcc.html">the llvmgcc manpage</a> and
+ <a href="././llvmgxx.html">llvmg++</a> front-ends, and as such, attempts to mimic the interface
+ provided by the default system linker so that it can act as a ``drop-in''
+ replacement.</p>
+ <p>The <strong>gccld</strong> tool performs a small set of interprocedural, post-link
+ optimizations on the program.</p>
+ <p>
+ </p>
+ <h2><a name="search_order">Search Order</a></h2>
+ <p>When looking for objects specified on the command line, <strong>gccld</strong> will search for
+ the object first in the current directory and then in the directory specified by
+ the <strong>LLVM_LIB_SEARCH_PATH</strong> environment variable.  If it cannot find the object,
+ it fails.</p>
+ <p>When looking for a library specified with the <strong>-l</strong> option, <strong>gccld</strong> first
+ attempts to load a file with that name from the current directory.  If that
+ fails, it looks for lib<em>library</em>.bc, lib<em>library</em>.a, or lib<em>library</em>.<em>shared
+ library extension</em>, in that order, in each directory added to the library search
+ path with the <strong>-L</strong> option.  These directories are searched in the order they
+ were specified.  If the library cannot be located, then <strong>gccld</strong> looks in the
+ directory specified by the <strong>LLVM_LIB_SEARCH_PATH</strong> environment variable.  If it
+ does not find a library there, it fails.</p>
+ <p>The shared library extension may be <em>.so</em>, <em>.dyld</em>, <em>.dll</em>, or something
+ different, depending upon the system.</p>
+ <p>The <strong>-L</strong> option is global.  It does not matter where it is specified in the
+ list of command line arguments; the directory is simply added to the search path
+ and is applied to all libraries, preceding or succeeding, in the command line.</p>
+ <p>
+ </p>
+ <h2><a name="link_order">Link order</a></h2>
+ <p>All object files are linked first in the order they were specified on the
+ command line.  All library files are linked next.  Some libraries may not be
+ linked into the object program; see below.</p>
+ <p>
+ </p>
+ <h2><a name="library_linkage">Library Linkage</a></h2>
+ <p>Object files and static bytecode objects are always linked into the output
+ file.  Library archives (.a files) load only the objects within the archive
+ that define symbols needed by the output file.  Hence, libraries should be
+ listed after the object files and libraries which need them; otherwise, the
+ library may not be linked in, and the dependent library will not have its
+ undefined symbols defined.</p>
+ <p>
+ </p>
+ <h2><a name="native_code_generation">Native code generation</a></h2>
+ <p>The <strong>gccld</strong> program has limited support for native code generation, when
+ using the <strong>-native</strong> or <strong>-native-cbe</strong> options.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dhelp"><strong>-help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output filename which will hold the linked bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dstats"><strong>-stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dverify"><strong>-verify</strong></a></strong><br />
+ </dt>
+ <dd>
+ Verify each pass result.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dopt"><strong>-disable-opt</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable all link-time optimization passes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dinlining"><strong>-disable-inlining</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not run the inliner pass.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dldirectory"><strong>-L</strong><em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add directory to the list of directories to search when looking for
+ libraries.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dinternalize"><strong>-disable-internalize</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not mark all symbols as internal.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dinternalize_2dpublic_2dapi_2dfile_filename"><strong>-internalize-public-api-file</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Preserve the list of symbol names in the file filename.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dinternalize_2dpublic_2dapi_2dlist__26lt_3blist_"><strong>-internalize-public-api-list <list></strong></a></strong><br />
+ </dt>
+ <dd>
+ Preserve the symbol names in list.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dllibrary"><strong>-l</strong><em>library</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify libraries to include when linking the output file.  When linking,
+ <strong>gccld</strong> will first attempt to load a file with the pathname <strong>library</strong>.  If
+ that fails, it will then attempt to load lib<em>library</em>.bc, lib<em>library</em>.a, and
+ lib<em>library</em>.<em>shared library extension</em>, in that order.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlink_2das_2dlibrary"><strong>-link-as-library</strong></a></strong><br />
+ </dt>
+ <dd>
+ Link the .bc files together as a library, not an executable.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dnative"><strong>-native</strong></a></strong><br />
+ </dt>
+ <dd>
+ Generate a native machine code executable.
+ </dd>
+ <dd>
+ <p>When generating native executables, <strong>gccld</strong> first checks for a bytecode
+ version of the library and links it in, if necessary.  If the library is
+ missing, <strong>gccld</strong> skips it.  Then, <strong>gccld</strong> links in the same
+ libraries as native code.</p>
+ </dd>
+ <dd>
+ <p>In this way, <strong>gccld</strong> should be able to link in optimized bytecode
+ subsets of common libraries and then link in any part of the library that
+ hasn't been converted to bytecode.</p>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dnative_2dcbe"><strong>-native-cbe</strong></a></strong><br />
+ </dt>
+ <dd>
+ Generate a native machine code executable with the LLVM C backend.
+ 
+ </dd>
+ <dd>
+ <pre>
+ 
+ This option is identical to the B<-native> option, but uses the
+ C backend to generate code for the program instead of an LLVM native
+ code generator.</pre>
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds"><strong>-s</strong></a></strong><br />
+ </dt>
+ <dd>
+ Strip symbol information from the generated executable.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dv"><strong>-v</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print information about actions taken.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>gccld</strong> succeeds, it will exit with an exit status of 0.
+ Otherwise, if an error occurs, it will exit with a non-zero exit
+ status.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-link.html">llvm-link</a>, <a href="././gccas.html">gccas</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llc.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llc.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llc.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,242 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llc</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#intel_ia32specific_options">Intel IA-32-specific Options</a></li>
+ 		<li><a href="#sparcv9specific_options">SPARCV9-specific Options</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llc - LLVM static compiler</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llc</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llc</strong> command compiles LLVM bytecode into assembly language for a
+ specified architecture.  The assembly language output can then be passed through
+ a native assembler and linker to generate native code.</p>
+ <p>The choice of architecture for the output assembly code is automatically 
+ determined from the input bytecode file, unless a <strong>-m</strong> option is used to override
+ the default.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <p>If <em>filename</em> is - or omitted, <strong>llc</strong> reads LLVM bytecode from standard input.
+ Otherwise, it will read LLVM bytecode from <em>filename</em>.</p>
+ <p>If the <strong>-o</strong> option is omitted, then <strong>llc</strong> will send its output to standard
+ output if the input is from standard input.  If the <strong>-o</strong> option specifies -,
+ then the output will also be sent to standard output.</p>
+ <p>If no <strong>-o</strong> option is specified and an input file other than - is specified,
+ then <strong>llc</strong> creates the output filename by taking the input filename,
+ removing any existing <em>.bc</em> extension, and adding a <em>.s</em> suffix.</p>
+ <p>Other <strong>llc</strong> options are as follows:</p>
+ <dl>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Overwrite output files. By default, <strong>llc</strong> will refuse to overwrite
+ an output file which already exists.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dmarch_3darch"><strong>-march</strong>=<em>arch</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the architecture for which to generate assembly.  Valid
+ architectures are:
+ </dd>
+ <dl>
+ <dt><strong><a name="item_x86"><em>x86</em></a></strong><br />
+ </dt>
+ <dd>
+ Intel IA-32 (Pentium and above)
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_ppc32"><em>ppc32</em></a></strong><br />
+ </dt>
+ <dd>
+ 32-bit PowerPC (MacOS X, 32-bit ABI)
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_sparcv9"><em>sparcv9</em></a></strong><br />
+ </dt>
+ <dd>
+ 64-bit SPARC V9
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_c"><em>c</em></a></strong><br />
+ </dt>
+ <dd>
+ Emit C code, not assembly
+ </dd>
+ <p></p></dl>
+ <dt><strong><a name="item__2d_2ddisable_2dfp_2delim"><strong>--disable-fp-elim</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable frame pointer elimination optimization.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2denable_2dcorrect_2deh_2dsupport"><strong>--enable-correct-eh-support</strong></a></strong><br />
+ </dt>
+ <dd>
+ Instruct the <strong>lowerinvoke</strong> pass to insert code for correct exception handling
+ support.  This is expensive and is by default omitted for efficiency.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dstats"><strong>--stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics recorded by code-generation passes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print a report to standard
+ error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dprint_2dmachineinstrs"><strong>--print-machineinstrs</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print generated machine code between compilation phases (useful for debugging).
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dregalloc_3dallocator"><strong>--regalloc</strong>=<em>allocator</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the register allocator to use. The default <em>allocator</em> is <em>local</em>.
+ Valid register allocators are:
+ </dd>
+ <dl>
+ <dt><strong><a name="item_simple"><em>simple</em></a></strong><br />
+ </dt>
+ <dd>
+ Very simple ``always spill'' register allocator
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_local"><em>local</em></a></strong><br />
+ </dt>
+ <dd>
+ Local register allocator
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_linearscan"><em>linearscan</em></a></strong><br />
+ </dt>
+ <dd>
+ Linear scan global register allocator
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_iterativescan"><em>iterativescan</em></a></strong><br />
+ </dt>
+ <dd>
+ Iterative scan global register allocator
+ </dd>
+ <p></p></dl>
+ <dt><strong><a name="item__2d_2dspiller_3dspiller"><strong>--spiller</strong>=<em>spiller</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the spiller to use for register allocators that support it.  Currently
+ this option is used only by the linear scan register allocator. The default
+ <em>spiller</em> is <em>local</em>.  Valid spillers are:
+ </dd>
+ <dl>
+ <dt><strong><em>simple</em></strong><br />
+ </dt>
+ <dd>
+ Simple spiller
+ </dd>
+ <p></p>
+ <dt><strong><em>local</em></strong><br />
+ </dt>
+ <dd>
+ Local spiller
+ </dd>
+ <p></p></dl>
+ </dl>
+ <p>
+ </p>
+ <h2><a name="intel_ia32specific_options">Intel IA-32-specific Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2d_2dx86_2dasm_2dsyntax_3datt_7cintel"><strong>--x86-asm-syntax=att|intel</strong></a></strong><br />
+ </dt>
+ <dd>
+ Specify whether to emit assembly code in AT&T syntax (the default) or intel
+ syntax.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="sparcv9specific_options">SPARCV9-specific Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2d_2ddisable_2dpeephole"><strong>--disable-peephole</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable peephole optimization pass.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2ddisable_2dsched"><strong>--disable-sched</strong></a></strong><br />
+ </dt>
+ <dd>
+ Disable local scheduling pass.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llc</strong> succeeds, it will exit with 0.  Otherwise, if an error occurs,
+ it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././lli.html">lli</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/lli.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/lli.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/lli.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,119 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>lli</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#author">AUTHOR</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>lli - directly execute programs from LLVM bytecode</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>lli</strong> [<em>options</em>] [<em>filename</em>] [<em>program args</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p><strong>lli</strong> directly executes programs in LLVM bytecode format.  It takes a program
+ in LLVM bytecode format and executes it using a just-in-time compiler, if one is
+ available for the current architecture, or an interpreter.  <strong>lli</strong> takes all of
+ the same code generator options as <a href="././llc.html">llc</a>, but they are only effective when
+ <strong>lli</strong> is using the just-in-time compiler.</p>
+ <p>If <em>filename</em> is not specified, then <strong>lli</strong> reads the LLVM bytecode for the
+ program from standard input.</p>
+ <p>The optional <em>args</em> specified on the command line are passed to the program as
+ arguments.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dhelp"><strong>-help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dstats"><strong>-stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics from the code-generation passes. This is only meaningful for
+ the just-in-time compiler, at present.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each code-generation pass and print it to
+ standard error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dmarch_3darch"><strong>-march</strong>=<em>arch</em></a></strong><br />
+ </dt>
+ <dd>
+ Use the specified non-default architecture arch when selecting a code generator
+ for the just-in-time compiler. This may result in a crash if you pick an
+ architecture which is not compatible with the hardware you are running <strong>lli</strong> on.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dforce_2dinterpreter_3d_7bfalse_2ctrue_7d"><strong>-force-interpreter</strong>=<em>{false,true}</em></a></strong><br />
+ </dt>
+ <dd>
+ If set to true, use the interpreter even if a just-in-time compiler is available
+ for this architecture. Defaults to false.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2df_3dname"><strong>-f</strong>=<em>name</em></a></strong><br />
+ </dt>
+ <dd>
+ Call the function named <em>name</em> to start the program.  Note: The
+ function is assumed to have the C signature <code>int</code> <em>name</em> <code>(int,
+ char **, char **)</code>.  If you try to use this option to call a function of
+ incompatible type, undefined behavior may result. Defaults to <code>main</code>.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>lli</strong> fails to load the program, it will exit with an exit code of 1.
+ Otherwise, it will return the exit code of the program it executes.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llc.html">llc</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="author">AUTHOR</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ar.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ar.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ar.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,502 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-ar</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#operations">Operations</a></li>
+ 		<li><a href="#modifiers__operation_specific_">Modifiers (operation specific)</a></li>
+ 		<li><a href="#modifiers__generic_">Modifiers (generic)</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#standards">STANDARDS</a></li>
+ 	<li><a href="#file_format">FILE FORMAT</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-ar - LLVM archiver</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-ar</strong> [-]{dmpqrtx}[Rabfikouz] [relpos] [count] <archive> [files...]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-ar</strong> command is similar to the common Unix utility, <code>ar</code>. It 
+ archives several files together into a single file. The intent for this is
+ to produce archive libraries by LLVM bytecode that can be linked into an
+ LLVM program. However, the archive can contain any kind of file. By default,
+ <strong>llvm-ar</strong> generates a symbol table that makes linking faster because
+ only the symbol table needs to be consulted, not each individual file member
+ of the archive.</p>
+ <p>The <strong>llvm-ar</strong> command can be used to <em>read</em> both SVR4 and BSD style archive
+ files. However, it cannot be used to write them.  While the <strong>llvm-ar</strong> command 
+ produces files that are <em>almost</em> identical to the format used by other <code>ar</code> 
+ implementations, it has two significant departures in order to make the 
+ archive appropriate for LLVM. The first departure is that <strong>llvm-ar</strong> only
+ uses BSD4.4 style long path names (stored immediately after the header) and
+ never contains a string table for long names. The second departure is that the
+ symbol table is formated for efficient construction of an in-memory data
+ structure that permits rapid (red-black tree) lookups. Consequently, archives 
+ produced with <strong>llvm-ar</strong> usually won't be readable or editable with any
+ <code>ar</code> implementation or useful for linking.  Using the <code>f</code> modifier to flatten
+ file names will make the archive readable by other <code>ar</code> implementations
+ but not for linking because the symbol table format for LLVM is unique. If an
+ SVR4 or BSD style archive is used with the <code>r</code> (replace) or <code>q</code> (quick
+ update) operations, the archive will be reconstructed in LLVM format. This 
+ means that the string table will be dropped (in deference to BSD 4.4 long names)
+ and an LLVM symbol table will be added (by default). The system symbol table
+ will be retained.</p>
+ <p>Here's where <strong>llvm-ar</strong> departs from previous <code>ar</code> implementations:</p>
+ <dl>
+ <dt><strong><a name="item_symbol_table"><em>Symbol Table</em></a></strong><br />
+ </dt>
+ <dd>
+ Since <strong>llvm-ar</strong> is intended to archive bytecode files, the symbol table
+ won't make much sense to anything but LLVM. Consequently, the symbol table's
+ format has been simplified. It consists simply of a sequence of pairs
+ of a file member index number as an LSB 4byte integer and a null-terminated 
+ string.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_long_paths"><em>Long Paths</em></a></strong><br />
+ </dt>
+ <dd>
+ Some <code>ar</code> implementations (SVR4) use a separate file member to record long
+ path names (> 15 characters). <strong>llvm-ar</strong> takes the BSD 4.4 and Mac OS X 
+ approach which is to simply store the full path name immediately preceding
+ the data for the file. The path name is null terminated and may contain the
+ slash (/) character.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_compression"><em>Compression</em></a></strong><br />
+ </dt>
+ <dd>
+ <strong>llvm-ar</strong> can compress the members of an archive to save space. The 
+ compression used depends on what's available on the platform and what choices
+ the LLVM Compressor utility makes. It generally favors bzip2 but will select
+ between ``no compression'' or bzip2 depending on what makes sense for the
+ file's content.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_directory_recursion"><em>Directory Recursion</em></a></strong><br />
+ </dt>
+ <dd>
+ Most <code>ar</code> implementations do not recurse through directories but simply
+ ignore directories if they are presented to the program in the <em>files</em> 
+ option. <strong>llvm-ar</strong>, however, can recurse through directory structures and
+ add all the files under a directory, if requested.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_toc_verbose_output"><em>TOC Verbose Output</em></a></strong><br />
+ </dt>
+ <dd>
+ When <strong>llvm-ar</strong> prints out the verbose table of contents (<code>tv</code> option), it
+ precedes the usual output with a character indicating the basic kind of 
+ content in the file. A blank means the file is a regular file. A 'Z' means
+ the file is compressed. A 'B' means the file is an LLVM bytecode file. An
+ 'S' means the file is the symbol table.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <p>The options to <strong>llvm-ar</strong> are compatible with other <code>ar</code> implementations.
+ However, there are a few modifiers (<em>zR</em>) that are not found in other
+ <code>ar</code>s. The options to <strong>llvm-ar</strong> specify a single basic operation to 
+ perform on the archive, a variety of modifiers for that operation, the
+ name of the archive file, and an optional list of file names. These options
+ are used to determine how <strong>llvm-ar</strong> should process the archive file.</p>
+ <p>The Operations and Modifiers are explained in the sections below. The minimal
+ set of options is at least one operator and the name of the archive. Typically
+ archive files end with a <code>.a</code> suffix, but this is not required. Following
+ the <em>archive-name</em> comes a list of <em>files</em> that indicate the specific members
+ of the archive to operate on. If the <em>files</em> option is not specified, it
+ generally means either ``none'' or ``all'' members, depending on the operation.</p>
+ <p>
+ </p>
+ <h2><a name="operations">Operations</a></h2>
+ <dl>
+ <dt><strong><a name="item_d">d</a></strong><br />
+ </dt>
+ <dd>
+ Delete files from the archive. No modifiers are applicable to this operation.
+ The <em>files</em> options specify which members should be removed from the
+ archive. It is not an error if a specified file does not appear in the archive.
+ If no <em>files</em> are specified, the archive is not modified.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_m_5babi_5d">m[abi]</a></strong><br />
+ </dt>
+ <dd>
+ Move files from one location in the archive to another. The <em>a</em>, <em>b</em>, and 
+ <em>i</em> modifiers apply to this operation. The <em>files</em> will all be moved
+ to the location given by the modifiers. If no modifiers are used, the files
+ will be moved to the end of the archive. If no <em>files</em> are specified, the
+ archive is not modified.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_p_5bk_5d">p[k]</a></strong><br />
+ </dt>
+ <dd>
+ Print files to the standard output. The <em>k</em> modifier applies to this
+ operation. This operation simply prints the <em>files</em> indicated to the
+ standard output. If no <em>files</em> are specified, the entire archive is printed.
+ Printing bytecode files is ill-advised as they might confuse your terminal
+ settings. The <em>p</em> operation never modifies the archive.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_q_5brfz_5d">q[Rfz]</a></strong><br />
+ </dt>
+ <dd>
+ Quickly append files to the end of the archive. The <em>R</em>, <em>f</em>, and <em>z</em>
+ modifiers apply to this operation.  This operation quickly adds the 
+ <em>files</em> to the archive without checking for duplicates that should be 
+ removed first. If no <em>files</em> are specified, the archive is not modified. 
+ Because of the way that <strong>llvm-ar</strong> constructs the archive file, its dubious 
+ whether the <em>q</em> operation is any faster than the <em>r</em> operation.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_r_5brabfuz_5d">r[Rabfuz]</a></strong><br />
+ </dt>
+ <dd>
+ Replace or insert file members. The <em>R</em>, <em>a</em>, <em>b</em>, <em>f</em>, <em>u</em>, and <em>z</em>
+ modifiers apply to this operation. This operation will replace existing
+ <em>files</em> or insert them at the end of the archive if they do not exist. If no
+ <em>files</em> are specified, the archive is not modified.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_t_5bv_5d">t[v]</a></strong><br />
+ </dt>
+ <dd>
+ Print the table of contents. Without any modifiers, this operation just prints
+ the names of the members to the standard output. With the <em>v</em> modifier,
+ <strong>llvm-ar</strong> also prints out the file type (B=bytecode, Z=compressed, S=symbol
+ table, blank=regular file), the permission mode, the owner and group, the
+ size, and the date. If any <em>files</em> are specified, the listing is only for
+ those files. If no <em>files</em> are specified, the table of contents for the
+ whole archive is printed.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_x_5bop_5d">x[oP]</a></strong><br />
+ </dt>
+ <dd>
+ Extract archive members back to files. The <em>o</em> modifier applies to this
+ operation. This operation retrieves the indicated <em>files</em> from the archive 
+ and writes them back to the operating system's file system. If no 
+ <em>files</em> are specified, the entire archive is extract.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="modifiers__operation_specific_">Modifiers (operation specific)</a></h2>
+ <p>The modifiers below are specific to certain operations. See the Operations
+ section (above) to determine which modifiers are applicable to which operations.</p>
+ <dl>
+ <dt><strong><a name="item__5ba_5d">[a]</a></strong><br />
+ </dt>
+ <dd>
+ When inserting or moving member files, this option specifies the destination of
+ the new files as being <code>a</code>fter the <em>relpos</em> member. If <em>relpos</em> is not found,
+ the files are placed at the end of the archive.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bb_5d">[b]</a></strong><br />
+ </dt>
+ <dd>
+ When inserting or moving member files, this option specifies the destination of
+ the new files as being <code>b</code>efore the <em>relpos</em> member. If <em>relpos</em> is not 
+ found, the files are placed at the end of the archive. This modifier is 
+ identical to the the <em>i</em> modifier.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bf_5d">[f]</a></strong><br />
+ </dt>
+ <dd>
+ Normally, <strong>llvm-ar</strong> stores the full path name to a file as presented to it on
+ the command line. With this option, truncated (15 characters max) names are
+ used. This ensures name compatibility with older versions of <code>ar</code> but may also
+ thwart correct extraction of the files (duplicates may overwrite). If used with
+ the <em>R</em> option, the directory recursion will be performed but the file names
+ will all be <code>f</code>lattened to simple file names.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bi_5d">[i]</a></strong><br />
+ </dt>
+ <dd>
+ A synonym for the <em>b</em> option.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bk_5d">[k]</a></strong><br />
+ </dt>
+ <dd>
+ Normally, <strong>llvm-ar</strong> will not print the contents of bytecode files when the 
+ <em>p</em> operation is used. This modifier defeats the default and allows the 
+ bytecode members to be printed.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bn_5d">[N]</a></strong><br />
+ </dt>
+ <dd>
+ This option is ignored by <strong>llvm-ar</strong> but provided for compatibility.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bo_5d">[o]</a></strong><br />
+ </dt>
+ <dd>
+ When extracting files, this option will cause <strong>llvm-ar</strong> to preserve the
+ original modification times of the files it writes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bp_5d">[P]</a></strong><br />
+ </dt>
+ <dd>
+ use full path names when matching
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5br_5d">[R]</a></strong><br />
+ </dt>
+ <dd>
+ This modifier instructions the <em>r</em> option to recursively process directories.
+ Without <em>R</em>, directories are ignored and only those <em>files</em> that refer to
+ files will be added to the archive. When <em>R</em> is used, any directories specified
+ with <em>files</em> will be scanned (recursively) to find files to be added to the
+ archive. Any file whose name begins with a dot will not be added.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bu_5d">[u]</a></strong><br />
+ </dt>
+ <dd>
+ When replacing existing files in the archive, only replace those files that have
+ a time stamp than the time stamp of the member in the archive.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bz_5d">[z]</a></strong><br />
+ </dt>
+ <dd>
+ When inserting or replacing any file in the archive, compress the file first.
+ This
+ modifier is safe to use when (previously) compressed bytecode files are added to
+ the archive; the compressed bytecode files will not be doubly compressed.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="modifiers__generic_">Modifiers (generic)</a></h2>
+ <p>The modifiers below may be applied to any operation.</p>
+ <dl>
+ <dt><strong><a name="item__5bc_5d">[c]</a></strong><br />
+ </dt>
+ <dd>
+ For all operations, <strong>llvm-ar</strong> will always create the archive if it doesn't 
+ exist. Normally, <strong>llvm-ar</strong> will print a warning message indicating that the
+ archive is being created. Using this modifier turns off that warning.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bs_5d">[s]</a></strong><br />
+ </dt>
+ <dd>
+ This modifier requests that an archive index (or symbol table) be added to the
+ archive. This is the default mode of operation. The symbol table will contain
+ all the externally visible functions and global variables defined by all the
+ bytecode files in the archive. Using this modifier is more efficient that using
+ <a href="././llvm-ranlib.html">llvm-ranlib</a> which also creates the symbol table.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bs_5d">[S]</a></strong><br />
+ </dt>
+ <dd>
+ This modifier is the opposite of the <em>s</em> modifier. It instructs <strong>llvm-ar</strong> to
+ not build the symbol table. If both <em>s</em> and <em>S</em> are used, the last modifier to
+ occur in the options will prevail.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__5bv_5d">[v]</a></strong><br />
+ </dt>
+ <dd>
+ This modifier instructs <strong>llvm-ar</strong> to be verbose about what it is doing. Each
+ editing operation taken against the archive will produce a line of output saying
+ what is being done.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="standards">STANDARDS</a></h1>
+ <p>The <strong>llvm-ar</strong> utility is intended to provide a superset of the IEEE Std 1003.2
+ (POSIX.2) functionality for <code>ar</code>. <strong>llvm-ar</strong> can read both SVR4 and BSD4.4 (or
+ Mac OS X) archives. If the <code>f</code> modifier is given to the <code>x</code> or <code>r</code> operations
+ then <strong>llvm-ar</strong> will write SVR4 compatible archives. Without this modifier, 
+ <strong>llvm-ar</strong> will write BSD4.4 compatible archives that have long names
+ immediately after the header and indicated using the ``#1/ddd'' notation for the
+ name in the header.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="file_format">FILE FORMAT</a></h1>
+ <p>The file format for LLVM Archive files is similar to that of BSD 4.4 or Mac OSX
+ archive files. In fact, except for the symbol table, the <code>ar</code> commands on those
+ operating systems should be able to read LLVM archive files. The details of the
+ file format follow.</p>
+ <p>Each archive begins with the archive magic number which is the eight printable
+ characters ``!<arch>\n'' where \n represents the newline character (0x0A). 
+ Following the magic number, the file is composed of even length members that 
+ begin with an archive header and end with a \n padding character if necessary 
+ (to make the length even). Each file member is composed of a header (defined 
+ below), an optional newline-terminated ``long file name'' and the contents of 
+ the file.</p>
+ <p>The fields of the header are described in the items below. All fields of the
+ header contain only ASCII characters, are left justified and are right padded 
+ with space characters.</p>
+ <dl>
+ <dt><strong><a name="item_name__2d_char_5b16_5d">name - char[16]</a></strong><br />
+ </dt>
+ <dd>
+ This field of the header provides the name of the archive member. If the name is
+ longer than 15 characters or contains a slash (/) character, then this field
+ contains <code>#1/nnn</code> where <code>nnn</code> provides the length of the name and the <code>#1/</code>
+ is literal.  In this case, the actual name of the file is provided in the <code>nnn</code>
+ bytes immediately following the header. If the name is 15 characters or less, it
+ is contained directly in this field and terminated with a slash (/) character.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_date__2d_char_5b12_5d">date - char[12]</a></strong><br />
+ </dt>
+ <dd>
+ This field provides the date of modification of the file in the form of a
+ decimal encoded number that provides the number of seconds since the epoch 
+ (since 00:00:00 Jan 1, 1970) per Posix specifications.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_uid__2d_char_5b6_5d">uid - char[6]</a></strong><br />
+ </dt>
+ <dd>
+ This field provides the user id of the file encoded as a decimal ASCII string.
+ This field might not make much sense on non-Unix systems. On Unix, it is the
+ same value as the st_uid field of the stat structure returned by the <code>stat(2)</code>
+ operating system call.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_gid__2d_char_5b6_5d">gid - char[6]</a></strong><br />
+ </dt>
+ <dd>
+ This field provides the group id of the file encoded as a decimal ASCII string.
+ This field might not make much sense on non-Unix systems. On Unix, it is the
+ same value as the st_gid field of the stat structure returned by the <code>stat(2)</code>
+ operating system call.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_mode__2d_char_5b8_5d">mode - char[8]</a></strong><br />
+ </dt>
+ <dd>
+ This field provides the access mode of the file encoded as an octal ASCII 
+ string. This field might not make much sense on non-Unix systems. On Unix, it 
+ is the same value as the st_mode field of the stat structure returned by the 
+ <code>stat(2)</code> operating system call.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_size__2d_char_5b10_5d">size - char[10]</a></strong><br />
+ </dt>
+ <dd>
+ This field provides the size of the file, in bytes, encoded as a decimal ASCII
+ string. If the size field is negative (starts with a minus sign, 0x02D), then
+ the archive member is stored in compressed form. The first byte of the archive
+ member's data indicates the compression type used. A value of 0 (0x30) indicates
+ that no compression was used. A value of 2 (0x32) indicates that bzip2
+ compression was used.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_fmag__2d_char_5b2_5d">fmag - char[2]</a></strong><br />
+ </dt>
+ <dd>
+ This field is the archive file member magic number. Its content is always the
+ two characters back tick (0x60) and newline (0x0A). This provides some measure 
+ utility in identifying archive files that have been corrupted.
+ </dd>
+ <p></p></dl>
+ <p>The LLVM symbol table has the special name ``#_LLVM_SYM_TAB_#''. It is presumed
+ that no regular archive member file will want this name. The LLVM symbol table 
+ is simply composed of a sequence of triplets: byte offset, length of symbol, 
+ and the symbol itself. Symbols are not null or newline terminated. Here are 
+ the details on each of these items:</p>
+ <dl>
+ <dt><strong><a name="item_offset__2d_vbr_encoded_32_2dbit_integer">offset - vbr encoded 32-bit integer</a></strong><br />
+ </dt>
+ <dd>
+ The offset item provides the offset into the archive file where the bytecode
+ member is stored that is associated with the symbol. The offset value is 0
+ based at the start of the first ``normal'' file member. To derive the actual
+ file offset of the member, you must add the number of bytes occupied by the file
+ signature (8 bytes) and the symbol tables. The value of this item is encoded
+ using variable bit rate encoding to reduce the size of the symbol table.
+ Variable bit rate encoding uses the high bit (0x80) of each byte to indicate 
+ if there are more bytes to follow. The remaining 7 bits in each byte carry bits
+ from the value. The final byte does not have the high bit set.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_length__2d_vbr_encoded_32_2dbit_integer">length - vbr encoded 32-bit integer</a></strong><br />
+ </dt>
+ <dd>
+ The length item provides the length of the symbol that follows. Like this
+ <em>offset</em> item, the length is variable bit rate encoded.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_symbol__2d_character_array">symbol - character array</a></strong><br />
+ </dt>
+ <dd>
+ The symbol item provides the text of the symbol that is associated with the
+ <em>offset</em>. The symbol is not terminated by any character. Its length is provided
+ by the <em>length</em> field. Note that is allowed (but unwise) to use non-printing
+ characters (even 0x00) in the symbol. This allows for multiple encodings of 
+ symbol names.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-ar</strong> succeeds, it will exit with 0.  A usage error, results
+ in an exit code of 1. A hard (file system typically) error results in an
+ exit code of 2. Miscellaneous or unknown errors result in an
+ exit code of 3.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-ranlib.html">llvm-ranlib</a>, <em>ar(1)</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-as.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-as.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-as.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,121 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-as</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-as - LLVM assembler</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-as</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p><strong>llvm-as</strong> is the LLVM assembler.  It reads a file containing human-readable
+ LLVM assembly language, translates it to LLVM bytecode, and writes the result
+ into a file or to standard output.</p>
+ <p>If <em>filename</em> is omitted or is <code>-</code>, then <strong>llvm-as</strong> reads its input from
+ standard input.</p>
+ <p>If an output file is not specified with the <strong>-o</strong> option, then
+ <strong>llvm-as</strong> sends its output to a file or standard output by following
+ these rules:</p>
+ <ul>
+ <li></li>
+ If the input is standard input, then the output is standard output.
+ <p></p>
+ <li></li>
+ If the input is a file that ends with <code>.ll</code>, then the output file is of
+ the same name, except that the suffix is changed to <code>.bc</code>.
+ <p></p>
+ <li></li>
+ If the input is a file that does not end with the <code>.ll</code> suffix, then the
+ output file has the same name as the input file, except that the <code>.bc</code>
+ suffix is appended.
+ <p></p></ul>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Force overwrite.  Normally, <strong>llvm-as</strong> will refuse to overwrite an
+ output file that already exists.  With this option, <strong>llvm-as</strong>
+ will overwrite the output file and replace it with new bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file name.  If <em>filename</em> is <code>-</code>, then <strong>llvm-as</strong>
+ sends its output to standard output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dstats"><strong>--stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-as</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-dis.html">llvm-dis</a>, <a href="././gccas.html">gccas</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-bcanalyzer.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-bcanalyzer.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-bcanalyzer.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,451 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-bcanalyzer</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#summary_output_definitions">SUMMARY OUTPUT DEFINITIONS</a></li>
+ 	<li><a href="#detailed_output_definitions">DETAILED OUTPUT DEFINITIONS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-bcanalyzer - LLVM bytecode analyzer</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-bcanalyzer</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-bcanalyzer</strong> command is a small utility for analyzing bytecode files.
+ The tool reads a bytecode file (such as generated with the <strong>llvm-as</strong> tool) and
+ produces a statistical report on the contents of the byteocde file.  The tool
+ will also dump a low level but human readable version of the bytecode file. 
+ This tool is probably not of much interest or utility except for those working 
+ directly with the bytecode file format. Most LLVM users can just ignore
+ this tool.</p>
+ <p>If <em>filename</em> is omitted or is <code>-</code>, then <strong>llvm-bcanalyzer</strong> reads its input 
+ from standard input. This is useful for combining the tool into a pipeline.</p>
+ <p>Output is written to the standard output.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dnodetails"><strong>-nodetails</strong></a></strong><br />
+ </dt>
+ <dd>
+ Causes <strong>llvm-bcanalyzer</strong> to abbreviate its output by writing out only a module 
+ level summary. The details for individual functions are not displayed.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddump"><strong>-dump</strong></a></strong><br />
+ </dt>
+ <dd>
+ Causes <strong>llvm-bcanalyzer</strong> to dump the bytecode in a human readable format. This 
+ format is significantly different from LLVM assembly and provides details about 
+ the encoding of the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dverify"><strong>-verify</strong></a></strong><br />
+ </dt>
+ <dd>
+ Causes <strong>llvm-bcanalyzer</strong> to verify the module produced by by reading the 
+ bytecode. This ensures that the statistics generated are based on a consistent
+ module.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-bcanalyzer</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value, usually 1.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="summary_output_definitions">SUMMARY OUTPUT DEFINITIONS</a></h1>
+ <p>The following items are always printed by llvm-bcanalyzer. They comprize the
+ summary output.</p>
+ <dl>
+ <dt><strong><a name="item_bytecode_analysis_of_module"><strong>Bytecode Analysis Of Module</strong></a></strong><br />
+ </dt>
+ <dd>
+ This just provides the name of the module for which bytecode analysis is being
+ generated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytecode_version_number"><strong>Bytecode Version Number</strong></a></strong><br />
+ </dt>
+ <dd>
+ The bytecode version (not LLVM version) of the file read by the analyzer.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_file_size"><strong>File Size</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of the entire bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_module_bytes"><strong>Module Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of the module block. Percentage is relative to File Size.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_function_bytes"><strong>Function Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of all the function blocks. Percentage is relative to File
+ Size.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_global_types_bytes"><strong>Global Types Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of the Global Types Pool. Percentage is relative to File
+ Size. This is the size of the definitions of all types in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_constant_pool_bytes"><strong>Constant Pool Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of the Constant Pool Blocks Percentage is relative to File
+ Size.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_module_globals_bytes"><strong>Module Globals Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Ths size, in bytes, of the Global Variable Definitions and their initializers.
+ Percentage is relative to File Size.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_instruction_list_bytes"><strong>Instruction List Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of all the instruction lists in all the functions.
+ Percentage is relative to File Size. Note that this value is also included in
+ the Function Bytes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_compaction_table_bytes"><strong>Compaction Table Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of all the compaction tables in all the functions.
+ Percentage is relative to File Size. Note that this value is also included in
+ the Function Bytes.
+ </dd>
+ <p></p>
+ <dt><strong><strong>Compaction Table Bytes</strong></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of all the symbol tables in all the functions. Percentage is
+ relative to File Size. Note that this value is also included in the Function
+ Bytes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_dependent_libraries_bytes"><strong>Dependent Libraries Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The size, in bytes, of the list of dependent libraries in the module. Percentage
+ is relative to File Size. Note that this value is also included in the Module
+ Global Bytes.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_bytecode_blocks"><strong>Number Of Bytecode Blocks</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of blocks of any kind in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_functions"><strong>Number Of Functions</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of function definitions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_types"><strong>Number Of Types</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of types defined in the Global Types Pool.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_constants"><strong>Number Of Constants</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of constants (of any type) defined in the Constant Pool.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_basic_blocks"><strong>Number Of Basic Blocks</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of basic blocks defined in all functions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_instructions"><strong>Number Of Instructions</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of instructions defined in all functions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_long_instructions"><strong>Number Of Long Instructions</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of long instructions defined in all functions in the bytecode
+ file. Long instructions are those taking greater than 4 bytes. Typically long
+ instructions are GetElementPtr with several indices, PHI nodes, and calls to
+ functions with large numbers of arguments.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_operands"><strong>Number Of Operands</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of operands used in all instructions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_compaction_tables"><strong>Number Of Compaction Tables</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of compaction tables in all functions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_symbol_tables"><strong>Number Of Symbol Tables</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of symbol tables in all functions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_number_of_dependent_libs"><strong>Number Of Dependent Libs</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of dependent libraries found in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_total_instruction_size"><strong>Total Instruction Size</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total size of the instructions in all functions in the bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_average_instruction_size"><strong>Average Instruction Size</strong></a></strong><br />
+ </dt>
+ <dd>
+ The average number of bytes per instruction across all functions in the bytecode
+ file. This value is computed by dividing Total Instruction Size by Number Of
+ Instructions.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_maximum_type_slot_number"><strong>Maximum Type Slot Number</strong></a></strong><br />
+ </dt>
+ <dd>
+ The maximum value used for a type's slot number. Larger slot number values take 
+ more bytes to encode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_maximum_value_slot_number"><strong>Maximum Value Slot Number</strong></a></strong><br />
+ </dt>
+ <dd>
+ The maximum value used for a value's slot number. Larger slot number values take 
+ more bytes to encode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytes_per_value"><strong>Bytes Per Value</strong></a></strong><br />
+ </dt>
+ <dd>
+ The average size of a Value definition (of any type). This is computed by
+ dividing File Size by the total number of values of any type.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytes_per_global"><strong>Bytes Per Global</strong></a></strong><br />
+ </dt>
+ <dd>
+ The average size of a global definition (constants and global variables).
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytes_per_function"><strong>Bytes Per Function</strong></a></strong><br />
+ </dt>
+ <dd>
+ The average number of bytes per function definition. This is computed by
+ dividing Function Bytes by Number Of Functions.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__23_of_vbr_32_2dbit_integers"><strong># of VBR 32-bit Integers</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of 32-bit integers encoded using the Variable Bit Rate
+ encoding scheme.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__23_of_vbr_64_2dbit_integers"><strong># of VBR 64-bit Integers</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of 64-bit integers encoded using the Variable Bit Rate encoding
+ scheme.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__23_of_vbr_compressed_bytes"><strong># of VBR Compressed Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes consumed by the 32-bit and 64-bit integers that use
+ the Variable Bit Rate encoding scheme.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__23_of_vbr_expanded_bytes"><strong># of VBR Expanded Bytes</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes that would have been consumed by the 32-bit and 64-bit
+ integers had they not been compressed with the Variable Bit Rage encoding
+ scheme.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytes_saved_with_vbr"><strong>Bytes Saved With VBR</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes saved by using the Variable Bit Rate encoding scheme.
+ The percentage is relative to # of VBR Expanded Bytes.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="detailed_output_definitions">DETAILED OUTPUT DEFINITIONS</a></h1>
+ <p>The following definitions occur only if the -nodetails option was not given.
+ The detailed output provides additional information on a per-function basis.</p>
+ <dl>
+ <dt><strong><a name="item_type"><strong>Type</strong></a></strong><br />
+ </dt>
+ <dd>
+ The type signature of the function.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_byte_size"><strong>Byte Size</strong></a></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes in the function's block.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_basic_blocks"><strong>Basic Blocks</strong></a></strong><br />
+ </dt>
+ <dd>
+ The number of basic blocks defined by the function.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_instructions"><strong>Instructions</strong></a></strong><br />
+ </dt>
+ <dd>
+ The number of instructions defined by the function.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_long_instructions"><strong>Long Instructions</strong></a></strong><br />
+ </dt>
+ <dd>
+ The number of instructions using the long instruction format in the function.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_operands"><strong>Operands</strong></a></strong><br />
+ </dt>
+ <dd>
+ The number of operands used by all instructions in the function.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_instruction_size"><strong>Instruction Size</strong></a></strong><br />
+ </dt>
+ <dd>
+ The number of bytes consumed by instructions in the function.
+ </dd>
+ <p></p>
+ <dt><strong><strong>Average Instruction Size</strong></strong><br />
+ </dt>
+ <dd>
+ The average number of bytes consumed by the instructions in the funtion. This
+ value is computed by dividing Instruction Size by Instructions.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_bytes_per_instruction"><strong>Bytes Per Instruction</strong></a></strong><br />
+ </dt>
+ <dd>
+ The average number of bytes used by the function per instruction. This value is
+ computed by dividing Byte Size by Instructions. Note that this is not the same
+ as Average Instruction Size. It computes a number relative to the total function
+ size not just the size of the instruction list.
+ </dd>
+ <p></p>
+ <dt><strong><strong># of VBR 32-bit Integers</strong></strong><br />
+ </dt>
+ <dd>
+ The total number of 32-bit integers found in this function (for any use).
+ </dd>
+ <p></p>
+ <dt><strong><strong># of VBR 64-bit Integers</strong></strong><br />
+ </dt>
+ <dd>
+ The total number of 64-bit integers found in this function (for any use).
+ </dd>
+ <p></p>
+ <dt><strong><strong># of VBR Compressed Bytes</strong></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes in this function consumed by the 32-bit and 64-bit 
+ integers that use the Variable Bit Rate encoding scheme.
+ </dd>
+ <p></p>
+ <dt><strong><strong># of VBR Expanded Bytes</strong></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes in this function that would have been consumed by 
+ the 32-bit and 64-bit integers had they not been compressed with the Variable 
+ Bit Rate encoding scheme.
+ </dd>
+ <p></p>
+ <dt><strong><strong>Bytes Saved With VBR</strong></strong><br />
+ </dt>
+ <dd>
+ The total number of bytes saved in this function by using the Variable Bit 
+ Rate encoding scheme. The percentage is relative to # of VBR Expanded Bytes.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-dis.html">llvm-dis</a>, <a href="http://llvm.cs.uiuc.edu/docs/BytecodeFormat.html">http://llvm.cs.uiuc.edu/docs/BytecodeFormat.html</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-db.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-db.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-db.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,43 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-db</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-db - LLVM debugger (alpha)</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p>Details coming soon. Please see 
+ <a href="http://llvm.cs.uiuc.edu/docs/SourceLevelDebugging.html">http://llvm.cs.uiuc.edu/docs/SourceLevelDebugging.html</a> in the meantime.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-dis.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-dis.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-dis.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,104 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-dis</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-dis - LLVM disassembler</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-dis</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-dis</strong> command is the LLVM disassembler.  It takes an LLVM
+ bytecode file and converts it into human-readable LLVM assembly language.</p>
+ <p>If filename is omitted or specified as <code>-</code>, <strong>llvm-dis</strong> reads its
+ input from standard input.</p>
+ <p>If the input is being read from standard input, then <strong>llvm-dis</strong>
+ will send its output to standard output by default.  Otherwise, the
+ output will be written to a file named after the input file, with
+ a <code>.ll</code> suffix added (any existing <code>.bc</code> suffix will first be
+ removed).  You can override the choice of output file using the
+ <strong>-o</strong> option.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Force overwrite.  Normally, <strong>llvm-dis</strong> will refuse to overwrite
+ an output file that already exists.  With this option, <strong>llvm-dis</strong>
+ will overwrite the output file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file name.  If <em>filename</em> is -, then the output is sent
+ to standard output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-dis</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-as.html">llvm-as</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ld.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ld.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ld.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,256 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-ld</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#input_output_options">Input/Output Options</a></li>
+ 		<li><a href="#optimization_options">Optimization Options</a></li>
+ 		<li><a href="#miscellaneous_options">Miscellaneous Options</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#environment">ENVIRONMENT</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-ld - LLVM linker</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-ld</strong> <options> <files></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-ld</strong> command is similar to the common Unix utility, <code>ld</code>. It 
+ links together bytecode modules to produce an executable program.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <p>
+ </p>
+ <h2><a name="input_output_options">Input/Output Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ This overrides the default output file and specifies the name of the file that
+ should be generated by the linker. By default, <strong>llvm-ld</strong> generates a file named
+ <em>a.out</em> for compatibility with <strong>ld</strong>. The output will be written to
+ <em>filename</em>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlname"><strong>-l</strong><em>name</em></a></strong><br />
+ </dt>
+ <dd>
+ This option specifies the <em>name</em> of a library to search when resolving symbols
+ for the program. Only the base name should be specified as <em>name</em>, without a
+ <em>lib</em> prefix or any suffix.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlpath"><strong>-L</strong><em>Path</em></a></strong><br />
+ </dt>
+ <dd>
+ This option tells <strong>llvm-ld</strong> to look in <em>Path</em> to find any library subsequently
+ specified with the <strong>-l</strong> option. The paths will be searched in the order in
+ which they are specified on the command line. If the library is still not found,
+ a small set of system specific directories will also be searched. Note that
+ libraries specified with the <strong>-l</strong> option that occur <em>before</em> any <strong>-L</strong> options
+ will not search the paths given by the <strong>-L</strong> options following it.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlink_2das_2dlibrary"><strong>-link-as-library</strong></a></strong><br />
+ </dt>
+ <dd>
+ Link the bytecode files together as a library, not an executable. In this mode,
+ undefined symbols will be permitted.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dr"><strong>-r</strong></a></strong><br />
+ </dt>
+ <dd>
+ An alias for -link-as-library.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dmarch_3dtarget"><strong>-march=</strong><code>target</code></a></strong><br />
+ </dt>
+ <dd>
+ Specifies the kind of machine for which code or assembly should be generated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dnative"><strong>-native</strong></a></strong><br />
+ </dt>
+ <dd>
+ Generate a native binary instead of a shell script that runs the JIT from
+ bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dnative_2dcbe"><strong>-native-cbe</strong></a></strong><br />
+ </dt>
+ <dd>
+ Generate a native binary with the C back end and compilation with GCC.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dcompression"><strong>-disable-compression</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not compress bytecode files.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="optimization_options">Optimization Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2do0"><strong>-O0</strong></a></strong><br />
+ </dt>
+ <dd>
+ An alias for the -O1 option.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do1"><strong>-O1</strong></a></strong><br />
+ </dt>
+ <dd>
+ Optimize for linking speed, not execution speed. The optimizer will attempt to
+ reduce the size of the linked program to reduce I/O but will not otherwise
+ perform any link-time optimizations.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do2"><strong>-O2</strong></a></strong><br />
+ </dt>
+ <dd>
+ Perform only the minimal or required set of scalar optimizations.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d03"><strong>-03</strong></a></strong><br />
+ </dt>
+ <dd>
+ An alias for the -O2 option.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d04"><strong>-04</strong></a></strong><br />
+ </dt>
+ <dd>
+ Perform the standard link time inter-procedural optimizations. This will 
+ attempt to optimize the program taking the entire program into consideration.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do5"><strong>-O5</strong></a></strong><br />
+ </dt>
+ <dd>
+ Perform aggressive link time optimizations. This is the same as -O4 but works
+ more aggressively to optimize the program.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dinlining"><strong>-disable-inlining</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not run the inlining pass. Functions will not be inlined into other
+ functions.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dopt"><strong>-disable-opt</strong></a></strong><br />
+ </dt>
+ <dd>
+ Completely disable optimization. The various <strong>-On</strong> options will be ignored and
+ no link time optimization passes will be run.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddisable_2dinternalize"><strong>-disable-internalize</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not mark all symbols as internal.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dverify"><strong>-verify</strong></a></strong><br />
+ </dt>
+ <dd>
+ Run the verification pass after each of the passes to verify intermediate
+ results.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds"><strong>-s</strong></a></strong><br />
+ </dt>
+ <dd>
+ Strip symbol info from the executable to make it smaller.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dexport_2ddynamic"><strong>-export-dynamic</strong></a></strong><br />
+ </dt>
+ <dd>
+ An alias for -disable-internalize
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dload_module"><strong>-load</strong> <em>module</em></a></strong><br />
+ </dt>
+ <dd>
+ Load an optimization module, <em>module</em>, which is expected to be a dynamic
+ library that provides the function name <code>RunOptimizations</code>. This function will
+ be passed the PassManager, and the optimization level (values 0-5 based on the
+ <strong>-On</strong> option). This function may add passes to the PassManager that should be
+ run. This feature allows the optimization passes of <strong>llvm-ld</strong> to be extended.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="miscellaneous_options">Miscellaneous Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2dv"><strong>-v</strong></a></strong><br />
+ </dt>
+ <dd>
+ Specifies verbose mode. In this mode the linker will print additional
+ information about the actions it takes, programs it executes, etc.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-ld</strong> succeeds, it will exit with 0 return code.  If an error occurs,
+ it will exit with a non-zero return code.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="environment">ENVIRONMENT</a></h1>
+ <p>The <code>LLVM_LIB_SEARCH_PATH</code> environment variable is used to find bytecode
+ libraries. Any paths specified in this variable will be searched after the <code>-L</code>
+ options.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-ar.html">llvm-ar</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-link.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-link.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-link.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,118 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-link</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-link - LLVM linker</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-link</strong> [<em>options</em>] <em>filename ...</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p><strong>llvm-link</strong> takes several LLVM bytecode files and links them together into a
+ single LLVM bytecode file.  It writes the output file to standard output, unless
+ the <strong>-o</strong> option is used to specify a filename.</p>
+ <p><strong>llvm-link</strong> attempts to load the input files from the current directory.  If
+ that fails, it looks for each file in each of the directories specified by the
+ <strong>-L</strong> options on the command line.  The library search paths are global; each
+ one is searched for every input file if necessary.  The directories are searched
+ in the order they were specified on the command line.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dl_directory"><strong>-L</strong> <em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add the specified <em>directory</em> to the library search path.  When looking for
+ libraries, <strong>llvm-link</strong> will look in pathname for libraries.  This option can be
+ specified multiple times; <strong>llvm-link</strong> will search inside these directories in
+ the order in which they were specified on the command line.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Overwrite output files.  By default, <strong>llvm-link</strong> will not overwrite an output
+ file if it alreadys exists.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file name.  If <em>filename</em> is <code>-</code>, then <strong>llvm-link</strong> will
+ write its output to standard output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dd"><strong>-d</strong></a></strong><br />
+ </dt>
+ <dd>
+ If specified, <strong>llvm-link</strong> prints a human-readable version of the output
+ bytecode file to standard error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dv"><strong>-v</strong></a></strong><br />
+ </dt>
+ <dd>
+ Verbose mode.  Print information about what <strong>llvm-link</strong> is doing.  This
+ typically includes a message for each bytecode file linked in and for each
+ library found.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-link</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././gccld.html">gccld</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-nm.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-nm.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-nm.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,181 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-nm</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#bugs">BUGS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#author">AUTHOR</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-nm - list LLVM bytecode file's symbol table</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-nm</strong> [<em>options</em>] [<em>filenames...</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-nm</strong> utility lists the names of symbols from the LLVM bytecode files,
+ or <strong>ar</strong> archives containing LLVM bytecode files, named on the command line.
+ Each symbol is listed along with some simple information about its provenance.
+ If no filename is specified, or <em>-</em> is used as a filename, <strong>llvm-nm</strong> will
+ process a bytecode file on its standard input stream.</p>
+ <p><strong>llvm-nm</strong>'s default output format is the traditional BSD <strong>nm</strong> output format.
+ Each such output record consists of an (optional) 8-digit hexadecimal address,
+ followed by a type code character, followed by a name, for each symbol. One
+ record is printed per line; fields are separated by spaces. When the address is
+ omitted, it is replaced by 8 spaces.</p>
+ <p>Type code characters currently supported, and their meanings, are as follows:</p>
+ <dl>
+ <dt><strong><a name="item_u">U</a></strong><br />
+ </dt>
+ <dd>
+ Named object is referenced but undefined in this bytecode file
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_c">C</a></strong><br />
+ </dt>
+ <dd>
+ Common (multiple defs link together into one def)
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_w">W</a></strong><br />
+ </dt>
+ <dd>
+ Weak reference (multiple defs link together into zero or one defs)
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_t">t</a></strong><br />
+ </dt>
+ <dd>
+ Local function (text) object
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_t">T</a></strong><br />
+ </dt>
+ <dd>
+ Global function (text) object
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_d">d</a></strong><br />
+ </dt>
+ <dd>
+ Local data object
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_d">D</a></strong><br />
+ </dt>
+ <dd>
+ Global data object
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__3f">?</a></strong><br />
+ </dt>
+ <dd>
+ Something unrecognizable
+ </dd>
+ <p></p></dl>
+ <p>Because LLVM bytecode files typically contain objects that are not considered to
+ have addresses until they are linked into an executable image or dynamically
+ compiled ``just-in-time'', <strong>llvm-nm</strong> does not print an address for any symbol,
+ even symbols which are defined in the bytecode file.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2dp"><strong>-P</strong></a></strong><br />
+ </dt>
+ <dd>
+ Use POSIX.2 output format. Alias for <strong>--format=posix</strong>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_b"><strong>-B</strong>    (default)</a></strong><br />
+ </dt>
+ <dd>
+ Use BSD output format. Alias for <strong>--format=bsd</strong>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command-line options and their meanings.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2ddefined_2donly"><strong>--defined-only</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print only symbols defined in this bytecode file (as opposed to
+ symbols which may be referenced by objects in this file, but not
+ defined in this file.)
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dextern_2donly_2c__2dg"><strong>--extern-only</strong>, <strong>-g</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print only symbols whose definitions are external; that is, accessible
+ from other bytecode files.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dundefined_2donly_2c__2du"><strong>--undefined-only</strong>, <strong>-u</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print only symbols referenced but not defined in this bytecode file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dformat_3dfmt_2c__2df"><strong>--format=</strong><em>fmt</em>, <strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Select an output format; <em>fmt</em> may be <em>sysv</em>, <em>posix</em>, or <em>bsd</em>. The
+ default is <em>bsd</em>.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="bugs">BUGS</a></h1>
+ <p><strong>llvm-nm</strong> cannot demangle C++ mangled names, like GNU <strong>nm</strong> can.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p><strong>llvm-nm</strong> exits with an exit code of zero.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-dis.html">llvm-dis</a>, <em>ar(1)</em>, <em>nm(1)</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="author">AUTHOR</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-prof.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-prof.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-prof.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,93 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-prof</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#author">AUTHOR</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-prof - print execution profile of LLVM program</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-prof</strong> [<em>options</em>] [<em>bytecode file</em>] [<em>llvmprof.out</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-prof</strong> tool reads in an <em>llvmprof.out</em> 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>
+ <p>This program is often used in conjunction with the <em>utils/profile.pl</em>
+ script.  This script automatically instruments a program, runs it with the JIT,
+ then runs <strong>llvm-prof</strong> to format a report.  To get more information about
+ <em>utils/profile.pl</em>, execute it with the <strong>--help</strong> option.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2d_2dannotated_2dllvm_or__2da"><strong>--annotated-llvm</strong> or <strong>-A</strong></a></strong><br />
+ </dt>
+ <dd>
+ 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.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dprint_2dall_2dcode"><strong>--print-all-code</strong></a></strong><br />
+ </dt>
+ <dd>
+ Using this option enables the <strong>--annotated-llvm</strong> option, but it
+ prints the entire module, instead of just the most commonly executed
+ functions.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p><strong>llvm-prof</strong> returns 1 if it cannot load the bytecode file or the profile
+ information. Otherwise, it exits with zero.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="author">AUTHOR</a></h1>
+ <p><strong>llvm-prof</strong> is maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ranlib.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ranlib.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvm-ranlib.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,91 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvm-ranlib</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvm-ranlib - Generate index for LLVM archive</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvm-ranlib</strong> [--version] [--help] <archive-file></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvm-ranlib</strong> command is similar to the common Unix utility, <code>ranlib</code>. It
+ adds or updates the symbol table in an LLVM archive file. Note that using the
+ <strong>llvm-ar</strong> modifier <em>s</em> is usually more efficient than running <strong>llvm-ranlib</strong>
+ which is only provided only for completness and compatibility. Unlike other 
+ implementations of <code>ranlib</code>, <strong>llvm-ranlib</strong> indexes LLVM bytecode files, not
+ native object modules. You can list the contents of the symbol table with the
+ <code>llvm-nm -s</code> command.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item_archive_2dfile"><em>archive-file</em></a></strong><br />
+ </dt>
+ <dd>
+ Specifies the archive-file to which the symbol table is added or updated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dversion"><em>--version</em></a></strong><br />
+ </dt>
+ <dd>
+ Print the version of <strong>llvm-ranlib</strong> and exit without building a symbol table.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dhelp"><em>--help</em></a></strong><br />
+ </dt>
+ <dd>
+ Print usage help for <strong>llvm-ranlib</strong> and exit without building a symbol table.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvm-ranlib</strong> succeeds, it will exit with 0.  If an error occurs, a non-zero
+ exit code will be returned.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-ar.html">llvm-ar</a>, <em>ranlib(1)</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvmc.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvmc.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvmc.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,488 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvmc</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#basic_operation">Basic Operation</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<ul>
+ 
+ 		<li><a href="#control_options">Control Options</a></li>
+ 		<li><a href="#optimization_options">Optimization Options</a></li>
+ 		<li><a href="#input_options">Input Options</a></li>
+ 		<li><a href="#output_options">Output Options</a></li>
+ 		<li><a href="#information_options">Information Options</a></li>
+ 		<li><a href="#language_specific_options">Language Specific Options</a></li>
+ 		<ul>
+ 
+ 			<li><a href="#c_c___specific_options">C/C++ Specific Options</a></li>
+ 		</ul>
+ 
+ 		<li><a href="#miscellaneous_options">Miscellaneous Options</a></li>
+ 		<li><a href="#advanced_options">Advanced Options</a></li>
+ 	</ul>
+ 
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvmc - The LLVM Compiler Driver</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvmc</strong> [<em>options</em>] [<em>filenames</em>...]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvmc</strong> command is a configurable driver for invoking other 
+ LLVM (and non-LLVM) tools in order to compile, optimize and link software
+ for multiple languages. For those familiar with the GNU Compiler 
+ Collection's <strong>gcc</strong> tool, it is very similar. This tool has the
+ following main goals or purposes:</p>
+ <ul>
+ <li><strong><a name="item_a_single_point_of_access_to_the_llvm_tool_set_2e">A Single point of access to the LLVM tool set.</a></strong><br />
+ </li>
+ <li><strong><a name="item_hide_the_complexities_of_the_llvm_tools_through_a_">Hide the complexities of the LLVM tools through a single interface.</a></strong><br />
+ </li>
+ <li><strong><a name="item_make_integration_of_existing_non_2dllvm_tools_simp">Make integration of existing non-LLVM tools simple.</a></strong><br />
+ </li>
+ <li><strong><a name="item_extend_the_capabilities_of_minimal_front_ends_2e">Extend the capabilities of minimal front ends.</a></strong><br />
+ </li>
+ <li><strong><a name="item_make_the_interface_for_compiling_consistent_for_al">Make the interface for compiling consistent for all languages.</a></strong><br />
+ </li>
+ </ul>
+ <p>The tool itself does nothing with a user's program. It merely invokes other
+ tools to get the compilation tasks done.</p>
+ <p>The options supported by <strong>llvmc</strong> generalize the compilation process and
+ provide a consistent and simple interface for multiple programming languages.
+ This makes it easier for developers to get their software compiled with LLVM.
+ Without <strong>llvmc</strong>, developers would need to understand how to invoke the 
+ front-end compiler, optimizer, assembler, and linker in order to compile their 
+ programs. <strong>llvmc</strong>'s sole mission is to trivialize that process.</p>
+ <p>
+ </p>
+ <h2><a name="basic_operation">Basic Operation</a></h2>
+ <p><strong>llvmc</strong> always takes the following basic actions:</p>
+ <ul>
+ <li><strong><a name="item_command_line_options_and_filenames_are_collected_2">Command line options and filenames are collected.</a></strong><br />
+ </li>
+ The command line options provide the marching orders to <strong>llvmc</strong> on what actions
+ it should perform. This is the <em>request</em> the user is making of <strong>llvmc</strong> and it
+ is interpreted first.
+ <p></p>
+ <li><strong><a name="item_configuration_files_are_read_2e">Configuration files are read.</a></strong><br />
+ </li>
+ Based on the options and the suffixes of the filenames presented, a set of 
+ configuration files are read to configure the actions <strong>llvmc</strong> will take. 
+ Configuration files are provided by either LLVM or the front end compiler tools
+ that <strong>llvmc</strong> invokes. Users generally don't need to be concerned with the
+ contents of the configuration files.
+ <p></p>
+ <li><strong><a name="item_determine_actions_to_take_2e">Determine actions to take.</a></strong><br />
+ </li>
+ The tool chain needed to complete the task is determined. This is the primary 
+ work of <strong>llvmc</strong>. It breaks the request specified by the command line options 
+ into a set of basic actions to be done:
+ <ul>
+ <li><strong><a name="item_input">Pre-processing: gathering/filtering compiler input (optional).</a></strong><br />
+ </li>
+ <li><strong><a name="item_translation_3a_source_language_to_bytecode_convers">Translation: source language to bytecode conversion.</a></strong><br />
+ </li>
+ <li><strong><a name="item_assembly_3a_bytecode_to_native_code_conversion_2e">Assembly: bytecode to native code conversion.</a></strong><br />
+ </li>
+ <li><strong><a name="item_optimization_3a_conversion_of_bytecode_to_somethin">Optimization: conversion of bytecode to something that runs faster.</a></strong><br />
+ </li>
+ <li><strong><a name="item_linking_3a_combining_multiple_bytecodes_to_produce">Linking: combining multiple bytecodes to produce executable program.</a></strong><br />
+ </li>
+ </ul>
+ <li><strong><a name="item_execute_actions_2e">Execute actions.</a></strong><br />
+ </li>
+ The actions determined previously are executed sequentially and then
+ <strong>llvmc</strong> terminates.
+ <p></p></ul>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <p>
+ </p>
+ <h2><a name="control_options">Control Options</a></h2>
+ <p>Control options tell <strong>llvmc</strong> what to do at a high level. The 
+ following control options are defined:</p>
+ <dl>
+ <dt><strong><a name="item__2dc_or__2d_2dcompile"><strong>-c</strong> or <strong>--compile</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option specifies that the linking phase is not to be run. All
+ previous phases, if applicable will run. This is generally how a given
+ bytecode file is compiled and optimized for a source language module.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dk_or__2d_2dlink_or_default"><strong>-k</strong> or <strong>--link</strong> or default</a></strong><br />
+ </dt>
+ <dd>
+ This option (or the lack of any control option) specifies that all stages
+ of compilation, optimization, and linking should be attempted.  Source files
+ specified on the command line will be compiled and linked with objects and
+ libraries also specified.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds_or__2d_2dassemble"><strong>-S</strong> or <strong>--assemble</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option specifies that compilation should end in the creation of
+ an LLVM assembly file that can be later converted to an LLVM object
+ file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2de_or__2d_2dpreprocess"><strong>-E</strong> or <strong>--preprocess</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option specifies that no compilation or linking should be 
+ performed. Only pre-processing, if applicable to the language being
+ compiled, is performed. For languages that support it, this will
+ result in the output containing the raw input to the compiler.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="optimization_options">Optimization Options</a></h2>
+ <p>Optimization with <strong>llvmc</strong> is based on goals and specified with
+ the following -O options. The specific details of which
+ optimizations run is controlled by the configuration files because
+ each source language will have different needs.</p>
+ <dl>
+ <dt><strong><a name="item_o0"><strong>-O1</strong> or <strong>-O0</strong> (default, fast compilation)</a></strong><br />
+ </dt>
+ <dd>
+ Only those optimizations that will hasten the compilation (mostly by reducing
+ the output) are applied. In general these are extremely fast and simple 
+ optimizations that reduce emitted code size. The goal here is not to make the 
+ resulting program fast but to make the compilation fast.  If not specified, 
+ this is the default level of optimization.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o2"><strong>-O2</strong> (basic optimization)</a></strong><br />
+ </dt>
+ <dd>
+ This level of optimization specifies a balance between generating good code 
+ that will execute reasonably quickly and not spending too much time optimizing
+ the code to get there. For example, this level of optimization may include 
+ things like global common subexpression elimination, aggressive dead code 
+ elimination, and scalar replication.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o3"><strong>-O3</strong> (aggressive optimization)</a></strong><br />
+ </dt>
+ <dd>
+ This level of optimization aggressively optimizes each set of files compiled 
+ together. However, no link-time inter-procedural optimization is performed.
+ This level implies all the optimizations of the <strong>-O1</strong> and <strong>-O2</strong> optimization
+ levels, and should also provide loop optimizations and compile time 
+ inter-procedural optimizations. Essentially, this level tries to do as much
+ as it can with the input it is given but doesn't do any link time IPO.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o4"><strong>-O4</strong> (link time optimization)</a></strong><br />
+ </dt>
+ <dd>
+ In addition to the previous three levels of optimization, this level of 
+ optimization aggressively optimizes each program at link time. It employs
+ basic analysis and basic link-time inter-procedural optimizations, 
+ considering the program as a whole.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o5"><strong>-O5</strong> (aggressive link time optimization)</a></strong><br />
+ </dt>
+ <dd>
+ This is the same as <strong>-O4</strong> except it employs aggressive analyses and
+ aggressive inter-procedural optimization.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o6"><strong>-O6</strong> (profile guided optimization: not implemented)</a></strong><br />
+ </dt>
+ <dd>
+ This is the same as <strong>-O5</strong> except that it employs profile-guided
+ re-optimization of the program after it has executed. Note that this implies
+ a single level of re-optimization based on runtime profile analysis. Once
+ the re-optimization has completed, the profiling instrumentation is
+ removed and final optimizations are employed.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item_o7"><strong>-O7</strong> (lifelong optimization: not implemented)</a></strong><br />
+ </dt>
+ <dd>
+ This is the same as <strong>-O5</strong> and similar to <strong>-O6</strong> except that re-optimization
+ is performed through the life of the program. That is, each run will update
+ the profile by which future re-optimizations are directed.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="input_options">Input Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2dl_library"><strong>-l</strong> <em>LIBRARY</em></a></strong><br />
+ </dt>
+ <dd>
+ This option instructs <strong>llvmc</strong> to locate a library named <em>LIBRARY</em> and search
+ it for unresolved symbols when linking the program.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dl_path"><strong>-L</strong> <em>path</em></a></strong><br />
+ </dt>
+ <dd>
+ This option instructs <strong>llvmc</strong> to add <em>path</em> to the list of places in which
+ the linker will
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dx_language"><strong>-x</strong> <em>LANGUAGE</em></a></strong><br />
+ </dt>
+ <dd>
+ This option instructs <strong>llvmc</strong> to regard the following input files as 
+ containing programs in the language <em>LANGUAGE</em>. Normally, input file languages
+ are identified by their suffix but this option will override that default
+ behavior. The <strong>-x</strong> option stays in effect until the end of the options or
+ a new <strong>-x</strong> option is encountered.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="output_options">Output Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2dmarch"><strong>-m</strong><em>arch</em></a></strong><br />
+ </dt>
+ <dd>
+ This option selects the back end code generator to use. The <em>arch</em> portion
+ of the option names the back end to use.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dnative"><strong>--native</strong></a></strong><br />
+ </dt>
+ <dd>
+ Normally, <strong>llvmc</strong> produces bytecode files at most stages of compilation.
+ With this option, <strong>llvmc</strong> will arrange for native object files to be
+ generated with the <strong>-c</strong> option, native assembly files to be generated
+ with the <strong>-S</strong> option, and native executables to be generated with the
+ <strong>--link</strong> option. In the case of the <strong>-E</strong> option, the output will not
+ differ as there is no <em>native</em> version of pre-processed output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file name.  The contents of the file  depend on other 
+ options.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="information_options">Information Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2dn_or__2d_2dno_2dop"><strong>-n</strong> or <strong>--no-op</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option tells <strong>llvmc</strong> to do everything but actually execute the
+ resulting tools. In combination with the <strong>-v</strong> option, this causes <strong>llvmc</strong>
+ to merely print out what it would have done.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dv_or__2d_2dverbose"><strong>-v</strong> or <strong>--verbose</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option will cause <strong>llvmc</strong> to print out (on standard output) each of the 
+ actions it takes to accomplish the objective. The output will immediately
+ precede the invocation of other tools.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dstats"><strong>--stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print all statistics gathered during the compilation to the standard error. 
+ Note that this option is merely passed through to the sub-tools to do with 
+ as they please.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dpasses"><strong>--time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each optimization pass and print it 
+ to standard error. Like <strong>--stats</strong> this option is just passed through to
+ the sub-tools to do with as they please.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dtime_2dprograms"><strong>--time-programs</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time each program (compilation tool) takes and print
+ it to the standard error.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="language_specific_options">Language Specific Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2dt_2cpp_3doptions"><strong>-T,pp</strong>=<em>options</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass an arbitrary option to the pre-processor.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dt_2copt_3doptions"><strong>-T,opt</strong>=<em>options</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass an arbitrary option to the optimizer.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dt_2clink_3doptions"><strong>-T,link</strong>=<em>options</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass an arbitrary option to the linker.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dt_2casm_3doptions"><strong>-T,asm</strong>=<em>options</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass an arbitrary option to the code generator.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h3><a name="c_c___specific_options">C/C++ Specific Options</a></h3>
+ <dl>
+ <dt><strong><a name="item__2dipath"><strong>-I</strong><em>path</em></a></strong><br />
+ </dt>
+ <dd>
+ This option is just passed through to a C or C++ front end compiler to tell it
+ where include files can be found.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="miscellaneous_options">Miscellaneous Options</a></h2>
+ <dl>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dv_or__2d_2dversion"><strong>-V</strong> or <strong>--version</strong></a></strong><br />
+ </dt>
+ <dd>
+ This option will cause <strong>llvmc</strong> to print out its version number
+ and terminate.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <h2><a name="advanced_options">Advanced Options</a></h2>
+ <p>You better know what you're doing if you use these options. Improper use
+ of these options can produce drastically wrong results.</p>
+ <dl>
+ <dt><strong><a name="item__2d_2dshow_2dconfig__5bsuffixes_2e_2e_2e_5d"><strong>--show-config</strong> <em>[suffixes...]</em></a></strong><br />
+ </dt>
+ <dd>
+ When this option is given, the only action taken by <strong>llvmc</strong> is to show its
+ final configuration state in the form of a configuration file. No compilation
+ tasks will be conducted when this option is given; processing will stop once
+ the configuration has been printed. The optional (comma separated) list of 
+ suffixes controls what is printed. Without any suffixes, the configuration
+ for all languages is printed. With suffixes, only the languages pertaining
+ to those file suffixes will be printed. The configuration information is
+ printed after all command line options and configuration files have been
+ read and processed. This allows the user to verify that the correct
+ configuration data has been read by <strong>llvmc</strong>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dconfig__3asection_3aname_3dvalue"><strong>--config</strong> :<em>section</em>:<em>name</em>=<em>value</em></a></strong><br />
+ </dt>
+ <dd>
+ This option instructs <strong>llvmc</strong> to accept <em>value</em> as the value for configuration
+ item <em>name</em> in the section named <em>section</em>. This is a quick way to override
+ a configuration item on the command line without resorting to changing the
+ configuration files.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dconfig_2dfile_dirname"><strong>--config-file</strong> <em>dirname</em></a></strong><br />
+ </dt>
+ <dd>
+ This option tells <strong>llvmc</strong> to read configuration data from the <em>directory</em>
+ named <em>dirname</em>. Data from such directories will be read in the order
+ specified on the command line after all other standard configuration files have
+ been read. This allows users or groups of users to conveniently create 
+ their own configuration directories in addition to the standard ones to which 
+ they may not have write access.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2dconfig_2donly_2dfrom_dirname"><strong>--config-only-from</strong> <em>dirname</em></a></strong><br />
+ </dt>
+ <dd>
+ This option tells <strong>llvmc</strong> to skip the normal processing of configuration
+ files and only configure from the contents of the <em>dirname</em> directory. Multiple
+ <strong>--config-only-from</strong> options may be given in which case the directories are
+ read in the order given on the command line.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2d_2demit_2draw_2dcode"><strong>--emit-raw-code</strong></a></strong><br />
+ </dt>
+ <dd>
+ No optimization is done whatsoever. The compilers invoked by <strong>llvmc</strong> with 
+ this option given will be instructed to produce raw, unoptimized code.  This 
+ option is useful only to front end language developers and therefore does not 
+ participate in the list of <strong>-O</strong> options. This is distinctly different from
+ the <strong>-O0</strong> option (a synonym for <strong>-O1</strong>) because those optimizations will
+ reduce code size to make compilation faster. With <strong>--emit-raw-code</strong>, only
+ the full raw code produced by the compiler will be generated.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvmc</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value and no compilation actions
+ will be taken. If one of the compilation tools returns a non-zero 
+ status, pending actions will be discarded and <strong>llvmc</strong> will return the
+ same result code as the failing compilation tool.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././gccas.html">gccas</a>, <a href="././gccld.html">gccld</a>, <a href="././llvm-as.html">llvm-as</a>, <a href="././llvm-dis.html">llvm-dis</a>, 
+ <a href="././llc.html">llc</a>, <a href="././llvm-link.html">llvm-link</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvmgcc.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvmgcc.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvmgcc.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,133 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvmgcc</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvmgcc - LLVM C front-end</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvmgcc</strong> [<em>options</em>] <em>filename</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvmgcc</strong> command is the LLVM C front end.  It is a modified
+ version of gcc that takes C programs and compiles them into LLVM
+ bytecode or assembly language, depending upon the options.</p>
+ <p>Unless the <strong>-S</strong> option is specified, <strong>llvmgcc</strong> will use the
+ <a href="././gccas.html">gccas</a> program to perform some optimizations and create an
+ LLVM bytecode file. Unless the <strong>-c</strong> option is specified, <strong>llvmgcc</strong>
+ will also use the <a href="././gccld.html">gccld</a> program to perform further
+ optimizations and link the resulting bytecode <code>file(s)</code> with support
+ libraries to create an executable program.</p>
+ <p>Being derived from the GNU Compiler Collection, <strong>llvmgcc</strong> has many
+ of gcc's features and accepts most of gcc's options.  It handles a
+ number of gcc's extensions to the C programming language.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds"><strong>-S</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not generate an LLVM bytecode file.  Rather, compile the source
+ file into an LLVM assembly language file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dc"><strong>-c</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not generate a linked executable.  Rather, compile the source
+ file into an LLVM bytecode file.  This bytecode file can then be
+ linked with other bytecode files later on to generate a full LLVM
+ executable.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file to be <em>filename</em>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2di_directory"><strong>-I</strong> <em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add a directory to the header file search path.  This option can be
+ repeated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dl_directory"><strong>-L</strong> <em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add <em>directory</em> to the library search path.  This option can be
+ repeated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlname"><strong>-l</strong><em>name</em></a></strong><br />
+ </dt>
+ <dd>
+ Link in the library lib<em>name</em>.[bc | a | so].  This library should
+ be a bytecode library.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dwl_2coption"><strong>-Wl,</strong><em>option</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass <em>option</em> to the linker (usually gccld).
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvmgcc</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvmgxx.html">llvmg++</a>, <a href="././gccas.html">gccas</a>, <a href="././gccld.html">gccld</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/llvmgxx.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/llvmgxx.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/llvmgxx.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,133 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>llvmgxx</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>llvmg++ - LLVM C++ front-end</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>llvmg++</strong> [<em>options</em>] <em>filename</em></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>llvmg++</strong> command is the LLVM C++ front end.  It is a modified
+ version of g++ that takes C++ programs and compiles them into LLVM
+ bytecode or assembly language, depending upon the options.</p>
+ <p>Unless the <strong>-S</strong> option is specified, <strong>llvmg++</strong> will use the
+ <a href="././gccas.html">gccas</a> program to perform some optimizations and create an
+ LLVM bytecode file. Unless the <strong>-c</strong> option is specified, <strong>llvmg++</strong>
+ will also use the <a href="././gccld.html">gccld</a> program to perform further
+ optimizations and link the resulting bytecode <code>file(s)</code> with support
+ libraries to create an executable program.</p>
+ <p>Being derived from the GNU Compiler Collection, <strong>llvmg++</strong> has many
+ of g++'s features and accepts most of g++'s options.  It handles a
+ number of g++'s extensions to the C++ programming language.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2d_2dhelp"><strong>--help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds"><strong>-S</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not generate an LLVM bytecode file.  Rather, compile the source
+ file into an LLVM assembly language file.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dc"><strong>-c</strong></a></strong><br />
+ </dt>
+ <dd>
+ Do not generate a linked executable.  Rather, compile the source
+ file into an LLVM bytecode file.  This bytecode file can then be
+ linked with other bytecode files later on to generate a full LLVM
+ executable.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file to be <em>filename</em>.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2di_directory"><strong>-I</strong> <em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add a directory to the header file search path.  This option can be
+ repeated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dl_directory"><strong>-L</strong> <em>directory</em></a></strong><br />
+ </dt>
+ <dd>
+ Add <em>directory</em> to the library search path.  This option can be
+ repeated.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dlname"><strong>-l</strong><em>name</em></a></strong><br />
+ </dt>
+ <dd>
+ Link in the library lib<em>name</em>.[bc | a | so].  This library should
+ be a bytecode library.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dwl_2coption"><strong>-Wl,</strong><em>option</em></a></strong><br />
+ </dt>
+ <dd>
+ Pass <em>option</em> to the linker (usually gccld).
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>llvmg++</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvmgcc.html">the llvmgcc manpage</a>, <a href="././gccas.html">the gccas manpage</a>, <a href="././gccld.html">the gccld manpage</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/manpage.css
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/manpage.css:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/manpage.css	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,256 ----
+ /* Based on http://www.perldoc.com/css/perldoc.css */
+ 
+ @import url("../llvm.css");
+ 
+ body { font-family: Arial,Helvetica; }
+ 
+ blockquote { margin: 10pt;  }
+ 
+ h1, a { color: #336699; }
+ 
+ 
+ /*** Top menu style ****/
+ .mmenuon { 
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #ff6600; font-size: 10pt;
+  }
+ .mmenuoff { 
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #ffffff; font-size: 10pt;
+ }	  
+ .cpyright {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #ffffff; font-size: xx-small;
+ }
+ .cpyrightText {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #ffffff; font-size: xx-small;
+ }
+ .sections { 
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: 11pt;
+ }	 
+ .dsections { 
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: 12pt;
+ }	
+ .slink { 
+  font-family: Arial,Helvetica; font-weight: normal; text-decoration: none;
+  color: #000000; font-size: 9pt;
+ }	 
+ 
+ .slink2 { font-family: Arial,Helvetica; text-decoration: none; color: #336699; }	 
+ 
+ .maintitle { 
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: 18pt;
+ }	 
+ .dblArrow {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: small;
+ }
+ .menuSec {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: small;
+ }
+ 
+ .newstext {
+  font-family: Arial,Helvetica; font-size: small;
+ }
+ 
+ .linkmenu {
+  font-family: Arial,Helvetica; color: #000000; font-weight: bold;
+  text-decoration: none;
+ }
+ 
+ P {
+  font-family: Arial,Helvetica;
+ }
+ 
+ PRE {
+     font-size: 10pt;
+ }
+ .quote { 
+  font-family: Times; text-decoration: none;
+  color: #000000; font-size: 9pt; font-style: italic;
+ }	
+ .smstd { font-family: Arial,Helvetica; color: #000000; font-size: x-small; } 
+ .std { font-family: Arial,Helvetica; color: #000000; } 
+ .meerkatTitle { 
+  font-family: sans-serif; font-size: x-small;  color: black;    }
+ 
+ .meerkatDescription { font-family: sans-serif; font-size: 10pt; color: black }
+ .meerkatCategory { 
+  font-family: sans-serif; font-size: 9pt; font-weight: bold; font-style: italic; 
+  color: brown; }
+ .meerkatChannel { 
+  font-family: sans-serif; font-size: 9pt; font-style: italic; color: brown; }
+ .meerkatDate { font-family: sans-serif; font-size: xx-small; color: #336699; }
+ 
+ .tocTitle {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #333333; font-size: 10pt;
+ }
+ 
+ .toc-item {
+  font-family: Arial,Helvetica; font-weight: bold; 
+  color: #336699; font-size: 10pt; text-decoration: underline;
+ }
+ 
+ .perlVersion {
+  font-family: Arial,Helvetica; font-weight: bold; 
+  color: #336699; font-size: 10pt; text-decoration: none;
+ }
+ 
+ .podTitle {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #000000;
+ }
+ 
+ .docTitle {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #000000; font-size: 10pt;
+ }
+ .dotDot {
+  font-family: Arial,Helvetica; font-weight: bold; 
+  color: #000000; font-size: 9pt;
+ }
+ 
+ .docSec {
+  font-family: Arial,Helvetica; font-weight: normal; 
+  color: #333333; font-size: 9pt;
+ }
+ .docVersion {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: 10pt;
+ }
+ 
+ .docSecs-on {
+  font-family: Arial,Helvetica; font-weight: normal; text-decoration: none;
+  color: #ff0000; font-size: 10pt;
+ }
+ .docSecs-off {
+  font-family: Arial,Helvetica; font-weight: normal; text-decoration: none;
+  color: #333333; font-size: 10pt;
+ }
+ 
+ h2 {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: medium;
+ }
+ h1 {
+  font-family: Verdana,Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: large;
+ }
+ 
+ DL {
+  font-family: Arial,Helvetica; font-weight: normal; text-decoration: none;
+  color: #333333; font-size: 10pt;
+ }
+ 
+ UL > LI > A {
+  font-family: Arial,Helvetica; font-weight: bold;
+  color: #336699; font-size: 10pt;
+ }
+ 
+ .moduleInfo {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #333333; font-size: 11pt;
+ }
+ 
+ .moduleInfoSec {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none;
+  color: #336699; font-size: 10pt;
+ }
+ 
+ .moduleInfoVal {
+  font-family: Arial,Helvetica; font-weight: normal; text-decoration: underline;
+  color: #000000; font-size: 10pt;
+ }
+ 
+ .cpanNavTitle {
+  font-family: Arial,Helvetica; font-weight: bold; 
+  color: #ffffff; font-size: 10pt;
+ }
+ .cpanNavLetter {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none; 
+  color: #333333; font-size: 9pt;
+ }
+ .cpanCat {
+  font-family: Arial,Helvetica; font-weight: bold; text-decoration: none; 
+  color: #336699; font-size: 9pt;
+ }
+ 
+ .bttndrkblue-bkgd-top {
+ 	background-color: #225688;
+ 	background-image: url(/global/mvc_objects/images/bttndrkblue_bgtop.gif);
+ }
+ .bttndrkblue-bkgd-left {
+ 	background-color: #225688;
+ 	background-image: url(/global/mvc_objects/images/bttndrkblue_bgleft.gif);
+ }
+ .bttndrkblue-bkgd {
+ 	padding-top: 0px;
+ 	padding-bottom: 0px;
+ 	margin-bottom: 0px;
+ 	margin-top: 0px;
+ 	background-repeat: no-repeat;
+ 	background-color: #225688;
+ 	background-image: url(/global/mvc_objects/images/bttndrkblue_bgmiddle.gif);
+ 	vertical-align: top;
+ }
+ .bttndrkblue-bkgd-right {
+ 	background-color: #225688;
+ 	background-image: url(/global/mvc_objects/images/bttndrkblue_bgright.gif);
+ }
+ .bttndrkblue-bkgd-bottom {
+ 	background-color: #225688;
+ 	background-image: url(/global/mvc_objects/images/bttndrkblue_bgbottom.gif);
+ }
+ .bttndrkblue-text a {
+ 	color: #ffffff;
+ 	text-decoration: none;
+ }
+ a.bttndrkblue-text:hover {
+ 	color: #ffDD3C;
+ 	text-decoration: none;
+ }
+ .bg-ltblue {
+ 	background-color: #f0f5fa;
+ } 
+ 
+ .border-left-b {
+ 	background: #f0f5fa url(/i/corner-leftline.gif) repeat-y;
+ } 
+ 
+ .border-right-b {
+ 	background: #f0f5fa url(/i/corner-rightline.gif) repeat-y;
+ } 
+ 
+ .border-top-b {
+ 	background: #f0f5fa url(/i/corner-topline.gif) repeat-x;
+ } 
+ 
+ .border-bottom-b {
+ 	background: #f0f5fa url(/i/corner-botline.gif) repeat-x;
+ } 
+ 
+ .border-right-w {
+ 	background: #ffffff url(/i/corner-rightline.gif) repeat-y;
+ } 
+ 
+ .border-top-w {
+ 	background: #ffffff url(/i/corner-topline.gif) repeat-x;
+ } 
+ 
+ .border-bottom-w {
+ 	background: #ffffff url(/i/corner-botline.gif) repeat-x;
+ } 
+ 
+ .bg-white {
+ 	background-color: #ffffff;
+ } 
+ 
+ .border-left-w {
+ 	background: #ffffff url(/i/corner-leftline.gif) repeat-y;
+ } 
Index: llvm-www/releases/1.4/docs/CommandGuide/html/opt.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/opt.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/opt.html	Thu Dec  9 16:19:04 2004
***************
*** 0 ****
--- 1,139 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>opt</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>opt - LLVM optimizer</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>opt</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>opt</strong> command is the modular LLVM optimizer.  It takes LLVM
+ bytecode as input, runs the specified optimizations on it, and then
+ outputs the optimized LLVM bytecode.</p>
+ <p>The optimizations available via <strong>opt</strong> depend upon what libraries
+ were linked into it as well as any additional libraries that have
+ been loaded with the <strong>-load</strong> option.  Use the <strong>-help</strong> option to
+ determine what optimizations you can use.</p>
+ <p>If no filename is specified on the command line, <strong>opt</strong> reads its
+ input from standard input.</p>
+ <p>If an output filename is not specified with the <strong>-o</strong> option, <strong>opt</strong>
+ writes its output to the standard output.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Force overwrite.  Normally, <strong>opt</strong> will refuse to overwrite an
+ output file that already exists.  With this option, <strong>opt</strong> will
+ overwrite the output file and replace it with new bytecode.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dhelp"><strong>-help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output filename.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dprofile_2dinfo_2dfile_filename"><strong>-profile-info-file</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the name of the file loaded by the -profile-loader option.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dstats"><strong>-stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ddebug"><strong>-debug</strong></a></strong><br />
+ </dt>
+ <dd>
+ If this is a debug build, this option will enable debug printouts
+ from passes which use the <em>DEBUG()</em> macro.  See the <strong>LLVM Programmer's
+ Manual</strong>, section <em>#DEBUG</em> for more information.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dload_3dplugin"><strong>-load</strong>=<em>plugin</em></a></strong><br />
+ </dt>
+ <dd>
+ Load the dynamic object <em>plugin</em>.  This object should register new
+ optimization passes.  Once loaded, the object will add new command line
+ options to enable various optimizations.  To see the new complete list
+ of optimizations, use the <strong>-help</strong> and <strong>-load</strong> options together:
+ </dd>
+ <p><strong>opt -load</strong>=<em>plugin</em> <strong>-help</strong></p>
+ <dt><strong><a name="item__2dp"><strong>-p</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print module after each transformation.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>opt</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././analyze.html">analyze</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
Index: llvm-www/releases/1.4/docs/CommandGuide/html/stkrc.html
diff -c /dev/null llvm-www/releases/1.4/docs/CommandGuide/html/stkrc.html:1.1
*** /dev/null	Thu Dec  9 16:19:15 2004
--- llvm-www/releases/1.4/docs/CommandGuide/html/stkrc.html	Thu Dec  9 16:19:05 2004
***************
*** 0 ****
--- 1,133 ----
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+ <html xmlns="http://www.w3.org/1999/xhtml">
+ <head>
+ <title>stkrc</title>
+ <link rel="stylesheet" href="manpage.css" type="text/css" />
+ <link rev="made" href="mailto:criswell at choi.cs.uiuc.edu" />
+ </head>
+ 
+ <body>
+ 
+ <p><a name="__index__"></a></p>
+ <!-- INDEX BEGIN -->
+ <!--
+ 
+ <ul>
+ 
+ 	<li><a href="#name">NAME</a></li>
+ 	<li><a href="#synopsis">SYNOPSIS</a></li>
+ 	<li><a href="#description">DESCRIPTION</a></li>
+ 	<li><a href="#options">OPTIONS</a></li>
+ 	<li><a href="#exit_status">EXIT STATUS</a></li>
+ 	<li><a href="#see_also">SEE ALSO</a></li>
+ 	<li><a href="#authors">AUTHORS</a></li>
+ </ul>
+ -->
+ <!-- INDEX END -->
+ 
+ <p>
+ </p>
+ <hr />
+ <h1><a name="name">NAME</a></h1>
+ <p>stkrc - Stacker Compiler</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="synopsis">SYNOPSIS</a></h1>
+ <p><strong>stkrc</strong> [<em>options</em>] [<em>filename</em>]</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="description">DESCRIPTION</a></h1>
+ <p>The <strong>stkrc</strong> command is the compiler for the Stacker language. Stacker is a
+ simple stack based, Forth-like language that was written as a demonstration
+ language for LLVM. For details on the language, please see
+ <a href="http://llvm.cs.uiuc.edu/docs/Stacker.html">http://llvm.cs.uiuc.edu/docs/Stacker.html</a> . The <strong>stkrc</strong> compiler is fairly 
+ minimal. It compiles to bytecode only and doesn't perform any optimizations.
+ The output of stkrc (a bytecode file) can be piped through other LLVM tools
+ for optimization and linking.</p>
+ <p>If <em>filename</em> is omitted or is <code>-</code>, then <strong>stkrc</strong> reads its input 
+ from standard input. This is useful for combining the tool into a pipeline.</p>
+ <p>If an output file is not specified with the <strong>-o</strong> option, then
+ <strong>llvm-as</strong> sends its output to a file or standard output by following
+ these rules:</p>
+ <ul>
+ <li></li>
+ If the input is standard input, then the output is standard output.
+ <p></p>
+ <li></li>
+ If the input is a file that ends with <code>.st</code>, then the output file is of
+ the same name, except that the suffix is changed to <code>.bc</code>.
+ <p></p>
+ <li></li>
+ If the input is a file that does not end with the <code>.st</code> suffix, then the
+ output file has the same name as the input file, except that the <code>.bc</code>
+ suffix is appended.
+ <p></p></ul>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="options">OPTIONS</a></h1>
+ <dl>
+ <dt><strong><a name="item__2do_filename"><strong>-o</strong> <em>filename</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the output file name.  If <em>filename</em> is <code>-</code>, then <strong>llvm-as</strong>
+ sends its output to standard output.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dstats"><strong>-stats</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print statistics acquired during compilation.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dtime_2dpasses"><strong>-time-passes</strong></a></strong><br />
+ </dt>
+ <dd>
+ Record the amount of time needed for each pass and print it to standard
+ error.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2df"><strong>-f</strong></a></strong><br />
+ </dt>
+ <dd>
+ Force the output to be written. Normally, <strong>stkrc</strong> won't overwrite an existing
+ bytecode file. This option overrides that behavior.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2ds_stacksize"><strong>-s</strong> <em>stacksize</em></a></strong><br />
+ </dt>
+ <dd>
+ Specify the stack size for the program. The default stack size, 1024, should be
+ sufficient for most programs. For very large programs, especially those that 
+ recurse a lot, you might want to provide a larger value. Each unit of this
+ value consumes 8 bytes of memory.
+ </dd>
+ <p></p>
+ <dt><strong><a name="item__2dhelp"><strong>-help</strong></a></strong><br />
+ </dt>
+ <dd>
+ Print a summary of command line options.
+ </dd>
+ <p></p></dl>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="exit_status">EXIT STATUS</a></h1>
+ <p>If <strong>stkrc</strong> succeeds, it will exit with 0.  Otherwise, if an error
+ occurs, it will exit with a non-zero value, usually 1.</p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="see_also">SEE ALSO</a></h1>
+ <p><a href="././llvm-as.html">the llvm-as manpage</a>, <a href="http://llvm.cs.uiuc.edu/docs/Stacker.html">http://llvm.cs.uiuc.edu/docs/Stacker.html</a></p>
+ <p>
+ </p>
+ <hr />
+ <h1><a name="authors">AUTHORS</a></h1>
+ <p>Maintained by the LLVM Team (<a href="http://llvm.cs.uiuc.edu">http://llvm.cs.uiuc.edu</a>).</p>
+ 
+ </body>
+ 
+ </html>
    
    
More information about the llvm-commits
mailing list