2008-11-25 22:38:38 +01: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 14:40:08 +01:00
|
|
|
=head2 Built-in Options
|
|
|
|
|
|
|
|
LLVMC has some built-in options that can't be overridden in the
|
|
|
|
configuration libraries.
|
|
|
|
|
2008-11-25 22:38:38 +01:00
|
|
|
=over
|
|
|
|
|
2008-11-26 14:40:08 +01: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.
|
|
|
|
|
2009-01-09 17:16:27 +01:00
|
|
|
=item B<--check-graph>
|
|
|
|
|
2009-03-27 13:58:29 +01:00
|
|
|
Check the compilation for common errors like mismatched output/input language
|
|
|
|
names, multiple default edges and cycles. Because of plugins, these checks can't
|
|
|
|
be performed at compile-time. Exit with code zero if no errors were found, and
|
|
|
|
return the number of found errors otherwise. Hidden option, useful for debugging
|
|
|
|
LLVMC plugins.
|
2009-01-09 17:16:27 +01:00
|
|
|
|
2008-11-26 14:40:08 +01:00
|
|
|
=item B<--view-graph>
|
|
|
|
|
2009-03-27 13:58:29 +01:00
|
|
|
Show a graphical representation of the compilation graph and exit. Requires that
|
|
|
|
you have I<dot> and I<gv> programs installed. Hidden option, useful for
|
|
|
|
debugging LLVMC plugins.
|
2008-11-26 14:40:08 +01:00
|
|
|
|
|
|
|
=item B<--write-graph>
|
|
|
|
|
2009-03-27 13:58:29 +01:00
|
|
|
Write a I<compilation-graph.dot> file in the current directory with the
|
|
|
|
compilation graph description in Graphviz format (identical to the file used by
|
|
|
|
the B<--view-graph> option). The B<-o> option can be used to set the output file
|
|
|
|
name. Hidden option, useful for debugging LLVMC plugins.
|
2008-11-26 14:40:08 +01:00
|
|
|
|
|
|
|
=item B<--save-temps>
|
|
|
|
|
2009-06-25 20:20:44 +02:00
|
|
|
Write temporary files to the current directory and do not delete them on
|
|
|
|
exit. This option can also take an argument: the I<--save-temps=obj> switch will
|
|
|
|
write files into the directory specified with the I<-o> option. The
|
|
|
|
I<--save-temps=cwd> and I<--save-temps> switches are both synonyms for the
|
|
|
|
default behaviour.
|
2008-11-26 14:40:08 +01:00
|
|
|
|
2009-07-09 21:39:16 +02:00
|
|
|
=item B<--temp-dir> I<directory>
|
|
|
|
|
2009-07-11 21:27:40 +02:00
|
|
|
Store temporary files in the given directory. This directory is deleted on exit
|
|
|
|
unless I<--save-temps> is specified. If I<--save-temps=obj> is also specified,
|
|
|
|
I<--temp-dir> is given the precedence.
|
2009-07-09 21:39:16 +02:00
|
|
|
|
2010-02-18 15:08:13 +01:00
|
|
|
=item B<-help>
|
2008-11-25 22:38:38 +01:00
|
|
|
|
2008-11-26 14:40:08 +01:00
|
|
|
Print a summary of command-line options and exit.
|
2008-11-25 22:38:38 +01:00
|
|
|
|
2010-02-18 15:08:13 +01:00
|
|
|
=item B<-help-hidden>
|
2008-11-26 14:40:08 +01:00
|
|
|
|
|
|
|
Print a summary of command-line options and exit. Print help even for
|
|
|
|
options intended for developers.
|
|
|
|
|
|
|
|
=item B<--version>
|
2008-11-25 22:38:38 +01:00
|
|
|
|
2008-11-26 14:40:08 +01:00
|
|
|
Print version information and exit.
|
|
|
|
|
2009-01-21 14:14:02 +01:00
|
|
|
=item B<@>I<file>
|
|
|
|
|
|
|
|
Read command-line options from I<file>. The options read are inserted
|
|
|
|
in place of the original @I<file> option. If I<file> does not exist, or
|
|
|
|
cannot be read, then the option will be treated literally, and not
|
|
|
|
removed.
|
|
|
|
|
|
|
|
Options in I<file> are separated by whitespace. A whitespace character
|
|
|
|
may be included in an option by surrounding the entire option in
|
|
|
|
either single or double quotes. Any character (including a backslash)
|
|
|
|
may be included by prefixing the character to be included with a
|
|
|
|
backslash. The file may itself contain additional @I<file> options;
|
|
|
|
any such options will be processed recursively.
|
|
|
|
|
|
|
|
|
2008-11-26 14:40:08 +01:00
|
|
|
=back
|
|
|
|
|
2009-01-21 14:14:02 +01:00
|
|
|
|
2008-11-26 14:40:08 +01:00
|
|
|
=head2 Control Options
|
|
|
|
|
|
|
|
By default, LLVMC is built with some standard configuration libraries
|
|
|
|
that define the following options:
|
|
|
|
|
|
|
|
=over
|
2008-11-25 22:38:38 +01:00
|
|
|
|
2008-12-07 17:48:07 +01:00
|
|
|
=item B<-clang>
|
|
|
|
|
|
|
|
Use Clang instead of llvm-gcc.
|
|
|
|
|
2008-12-12 03:34:56 +01:00
|
|
|
=item B<-opt>
|
|
|
|
|
2009-03-27 13:58:29 +01:00
|
|
|
Enable optimization passes with B<opt>. To pass options to the B<opt> program
|
|
|
|
use the B<-Wo,> option.
|
2008-12-12 03:34:56 +01:00
|
|
|
|
2008-11-25 22:38:38 +01:00
|
|
|
=item B<-I> I<directory>
|
|
|
|
|
2009-12-01 06:59:55 +01:00
|
|
|
Add a directory to the header file search path.
|
2008-11-25 22:38:38 +01:00
|
|
|
|
|
|
|
=item B<-L> I<directory>
|
|
|
|
|
2009-12-01 06:59:55 +01:00
|
|
|
Add I<directory> to the library search path.
|
|
|
|
|
|
|
|
=item B<-F> I<directory>
|
|
|
|
|
|
|
|
Add I<directory> to the framework search path.
|
2008-11-25 22:38:38 +01:00
|
|
|
|
|
|
|
=item B<-l>I<name>
|
|
|
|
|
|
|
|
Link in the library libI<name>.[bc | a | so]. This library should
|
|
|
|
be a bitcode library.
|
|
|
|
|
2009-12-01 06:59:55 +01:00
|
|
|
=item B<-framework> I<name>
|
|
|
|
|
|
|
|
Link in the library libI<name>.[bc | a | so]. This library should
|
|
|
|
be a bitcode library.
|
|
|
|
|
2008-11-25 22:38:38 +01:00
|
|
|
=item B<-emit-llvm>
|
|
|
|
|
2009-12-01 06:59:55 +01:00
|
|
|
Output LLVM bitcode (with B<-c>) or assembly (with B<-S>) instead of native
|
|
|
|
object (or assembly). If B<-emit-llvm> is given without either B<-c> or B<-S>
|
|
|
|
it has no effect.
|
2008-11-25 22:38:38 +01:00
|
|
|
|
2008-12-07 17:48:07 +01:00
|
|
|
=item B<-Wa>
|
|
|
|
|
|
|
|
Pass options to assembler.
|
|
|
|
|
|
|
|
=item B<-Wl>
|
|
|
|
|
|
|
|
Pass options to linker.
|
|
|
|
|
2008-12-12 03:34:56 +01:00
|
|
|
=item B<-Wo>
|
|
|
|
|
|
|
|
Pass options to opt.
|
|
|
|
|
2009-12-01 06:59:55 +01:00
|
|
|
=item B<-Wllc>
|
|
|
|
|
|
|
|
Pass options to llc (code generator).
|
|
|
|
|
2008-11-25 22:38:38 +01:00
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 EXIT STATUS
|
|
|
|
|
2008-11-26 14:40:08 +01: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 22:38:38 +01: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
|