From ef0ad4176d8fb333a1d4a4288e03d66cb8203c4c Mon Sep 17 00:00:00 2001
From: Misha Brukman
Date: Mon, 6 Oct 2003 19:23:34 +0000
Subject: [PATCH] * Alphabetized order of tools * Added blurb about `bugpoint'
* Fixed some grammar issues * Added blurb about `llvm-link' * Took out the
part about the `lli debugger' which disappeared
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8900 91177308-0d34-0410-b5e6-96231b3b80d8
---
docs/GettingStarted.html | 60 +++++++++++++++++++++++++---------------
1 file changed, 37 insertions(+), 23 deletions(-)
diff --git a/docs/GettingStarted.html b/docs/GettingStarted.html
index f6905d65751..0f77b2275d1 100644
--- a/docs/GettingStarted.html
+++ b/docs/GettingStarted.html
@@ -815,26 +815,47 @@
following is a brief introduction to the most important tools.
+ -
+
+
- analyze
- analyze is used to run a specific
+ analysis on an input LLVM bytecode file and print out the results. It is
+ primarily useful for debugging analyses, or familiarizing yourself with
+ what an analysis does.
+
+
- bugpoint
- bugpoint is used to debug
+ optimization passes or code generation backends by narrowing down the
+ given test case to the minimum number of passes and/or instructions that
+ still cause a problem, whether it is a crash or miscompilation. See HowToSubmitABug.html for more information
+ on using bugpoint.
+
+
- llvm-ar
- The archiver produces an archive containing
+ the given LLVM bytecode files, optionally with an index for faster
+ lookup.
+
- llvm-as
- The assembler transforms the human readable
LLVM assembly to LLVM bytecode.
- llvm-dis
- The disassembler transforms the LLVM
- bytecode to human readable LLVM assembly. Additionally it can convert
+ bytecode to human readable LLVM assembly. Additionally, it can convert
LLVM bytecode to C, which is enabled with the -c option.
+
- llvm-link
- llvm-link, not surprisingly,
+ links multiple LLVM modules into a single program.
+
- lli
- lli is the LLVM interpreter, which
can directly execute LLVM bytecode (although very slowly...). In addition
- to a simple interpreter, lli is also has debugger and tracing
- modes (entered by specifying -debug or -trace on the
- command line, respectively). Finally, for architectures that support it
- (currently only x86 and Sparc), by default, lli will function as
- a Just-In-Time compiler (if the functionality was compiled in), and will
- execute the code much faster than the interpreter.
+ to a simple interpreter, lli also has a tracing mode (entered by
+ specifying -trace on the command line). Finally, for
+ architectures that support it (currently only x86 and Sparc), by default,
+ lli will function as a Just-In-Time compiler (if the
+ functionality was compiled in), and will execute the code much
+ faster than the interpreter.
- llc
- llc is the LLVM backend compiler,
which translates LLVM bytecode to a SPARC or x86 assembly file.
-
- llvmgcc
- llvmgcc is a GCC based C frontend
+
- llvmgcc
- llvmgcc is a GCC-based C frontend
that has been retargeted to emit LLVM code as the machine code output. It
works just like any other GCC compiler, taking the typical -c, -S, -E,
-o options that are typically used. The source code for the
@@ -845,15 +866,14 @@
- gccas
- This tool is invoked by the
llvmgcc frontend as the "assembler" part of the compiler. This
tool actually assembles LLVM assembly to LLVM bytecode,
- performs a variety of optimizations,
- and outputs LLVM bytecode. Thus when you invoke llvmgcc -c x.c -o
- x.o, you are causing gccas to be run, which writes the
- x.o file (which is an LLVM bytecode file that can be
- disassembled or manipulated just like any other bytecode file). The
- command line interface to gccas is designed to be as close as
- possible to the system `as' utility so that the gcc
- frontend itself did not have to be modified to interface to a "weird"
- assembler.
+ performs a variety of optimizations, and outputs LLVM bytecode. Thus
+ when you invoke llvmgcc -c x.c -o x.o, you are causing
+ gccas to be run, which writes the x.o file (which is
+ an LLVM bytecode file that can be disassembled or manipulated just like
+ any other bytecode file). The command line interface to gccas
+ is designed to be as close as possible to the system
+ `as' utility so that the gcc frontend itself did not have to be
+ modified to interface to a "weird" assembler.
- gccld
- gccld links together several LLVM
bytecode files into one bytecode file and does some optimization. It is
@@ -869,12 +889,6 @@
command is a good way to get a list of the program transformations
available in LLVM.
-
-
- analyze
- analyze is used to run a specific
- analysis on an input LLVM bytecode file and print out the results. It is
- primarily useful for debugging analyses, or familiarizing yourself with
- what an analysis does.
-