2008-11-25 21:38:38 +00:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
llvmc - The LLVM Compiler Driver (WIP)
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
B<llvmc> [I<options>] I<filenames...>
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
B<llvmc> 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 FSF's B<gcc> tool, it is very similar. Please note that
|
|
|
|
B<llvmc> is considered an experimental tool.
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
=head2 Built-in Options
|
|
|
|
|
|
|
|
LLVMC has some built-in options that can't be overridden in the
|
|
|
|
configuration libraries.
|
|
|
|
|
2008-11-25 21:38:38 +00:00
|
|
|
=over
|
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
=item B<-o> I<filename>
|
|
|
|
|
|
|
|
Output file name.
|
|
|
|
|
|
|
|
=item B<-x> I<language>
|
|
|
|
|
|
|
|
Specify the language of the following input files until the next B<-x>
|
|
|
|
option.
|
|
|
|
|
|
|
|
=item B<-load> I<plugin_name>
|
|
|
|
|
|
|
|
Load the specified plugin DLL. Example:
|
|
|
|
S<-load $LLVM_DIR/Release/lib/LLVMCSimple.so>.
|
|
|
|
|
|
|
|
=item B<-v> or B<--verbose>
|
|
|
|
|
|
|
|
Enable verbose mode, i.e. print out all executed commands.
|
|
|
|
|
|
|
|
=item B<--view-graph>
|
|
|
|
|
|
|
|
Show a graphical representation of the compilation graph. Requires
|
|
|
|
that you have I<dot> and I<gv> programs installed. Hidden option,
|
|
|
|
useful for debugging.
|
|
|
|
|
|
|
|
=item B<--write-graph>
|
|
|
|
|
|
|
|
Write a I<compilation-graph.dot> file in the current directory with
|
|
|
|
the compilation graph description in the Graphviz format. Hidden
|
|
|
|
option, useful for debugging.
|
|
|
|
|
|
|
|
=item B<--save-temps>
|
|
|
|
|
|
|
|
Write temporary files to the current directory and do not delete them
|
|
|
|
on exit. Hidden option, useful for debugging.
|
|
|
|
|
2008-11-25 21:38:38 +00:00
|
|
|
=item B<--help>
|
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
Print a summary of command-line options and exit.
|
2008-11-25 21:38:38 +00:00
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
=item B<--help-hidden>
|
|
|
|
|
|
|
|
Print a summary of command-line options and exit. Print help even for
|
|
|
|
options intended for developers.
|
|
|
|
|
|
|
|
=item B<--version>
|
2008-11-25 21:38:38 +00:00
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
Print version information and exit.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head2 Control Options
|
|
|
|
|
|
|
|
By default, LLVMC is built with some standard configuration libraries
|
|
|
|
that define the following options:
|
|
|
|
|
|
|
|
=over
|
2008-11-25 21:38:38 +00:00
|
|
|
|
2008-12-07 16:48:07 +00:00
|
|
|
=item B<-clang>
|
|
|
|
|
|
|
|
Use Clang instead of llvm-gcc.
|
|
|
|
|
2008-12-12 02:34:56 +00:00
|
|
|
=item B<-opt>
|
|
|
|
|
|
|
|
Enable optimization with B<opt>.
|
|
|
|
|
2008-11-25 21:38:38 +00:00
|
|
|
=item B<-I> I<directory>
|
|
|
|
|
|
|
|
Add a directory to the header file search path. This option can be
|
|
|
|
repeated.
|
|
|
|
|
|
|
|
=item B<-L> I<directory>
|
|
|
|
|
|
|
|
Add I<directory> to the library search path. This option can be
|
|
|
|
repeated.
|
|
|
|
|
|
|
|
=item B<-l>I<name>
|
|
|
|
|
|
|
|
Link in the library libI<name>.[bc | a | so]. This library should
|
|
|
|
be a bitcode library.
|
|
|
|
|
|
|
|
=item B<-emit-llvm>
|
|
|
|
|
2008-12-09 14:41:00 +00:00
|
|
|
Make the output be LLVM bitcode (with B<-c>) or assembly (with B<-S>) instead
|
2008-11-25 21:38:38 +00:00
|
|
|
of native object (or assembly). If B<-emit-llvm> is given without either B<-c>
|
|
|
|
or B<-S> it has no effect.
|
|
|
|
|
2008-12-07 16:48:07 +00:00
|
|
|
=item B<-Wa>
|
|
|
|
|
|
|
|
Pass options to assembler.
|
|
|
|
|
|
|
|
=item B<-Wl>
|
|
|
|
|
|
|
|
Pass options to linker.
|
|
|
|
|
2008-12-12 02:34:56 +00:00
|
|
|
=item B<-Wo>
|
|
|
|
|
|
|
|
Pass options to opt.
|
|
|
|
|
2008-11-25 21:38:38 +00:00
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 EXIT STATUS
|
|
|
|
|
2008-11-26 13:40:08 +00:00
|
|
|
If B<llvmc> succeeds, it will exit with code 0. Otherwise, if an
|
|
|
|
error occurs, it will exit with a non-zero value. If one of the
|
|
|
|
compilation tools returns a non-zero status, pending actions will be
|
|
|
|
discarded and B<llvmc> will return the same result code as the failing
|
|
|
|
compilation tool.
|
2008-11-25 21:38:38 +00:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
|
|
|
L<llvm-gcc|llvmgcc>, L<llvm-g++|llvmgxx>, L<llvm-as|llvm-as>,
|
|
|
|
L<llvm-dis|llvm-dis>, L<llc|llc>, L<llvm-link|llvm-link>
|
|
|
|
|
|
|
|
=head1 AUTHORS
|
|
|
|
|
|
|
|
Maintained by the LLVM Team (L<http://llvm.org>).
|
|
|
|
|
|
|
|
=cut
|