Man Linux: Main Page and Category List

NAME

       llvmc - The LLVM Compiler Driver (WIP)

SYNOPSIS

       llvmc [options] filenames...

DESCRIPTION

       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 gcc tool, it is very similar.
       Please note that llvmc is considered an experimental tool.

OPTIONS

   Built-in Options
       LLVMC has some built-in options that can't be overridden in the
       configuration libraries.

       -o filename
           Output file name.

       -x language
           Specify the language of the following input files until the next -x
           option.

       -load plugin_name
           Load the specified plugin DLL. Example:
           -load $LLVM_DIR/Release/lib/LLVMCSimple.so.

       -v or --verbose
           Enable verbose mode, i.e. print out all executed commands.

       --check-graph
           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.

       --view-graph
           Show a graphical representation of the compilation graph and exit.
           Requires that you have dot and gv programs installed. Hidden
           option, useful for debugging LLVMC plugins.

       --write-graph
           Write a compilation-graph.dot file in the current directory with
           the compilation graph description in Graphviz format (identical to
           the file used by the --view-graph option). The -o option can be
           used to set the output file name. Hidden option, useful for
           debugging LLVMC plugins.

       --save-temps
           Write temporary files to the current directory and do not delete
           them on exit. This option can also take an argument: the
           --save-temps=obj switch will write files into the directory
           specified with the -o option. The --save-temps=cwd and --save-temps
           switches are both synonyms for the default behaviour.

       --temp-dir directory
           Store temporary files in the given directory. This directory is
           deleted on exit unless --save-temps is specified. If
           --save-temps=obj is also specified, --temp-dir is given the
           precedence.

       -help
           Print a summary of command-line options and exit.

       -help-hidden
           Print a summary of command-line options and exit. Print help even
           for options intended for developers.

       --version
           Print version information and exit.

       @file
           Read command-line options from file. The options read are inserted
           in place of the original @file option. If file does not exist, or
           cannot be read, then the option will be treated literally, and not
           removed.

           Options in 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
           @file options; any such options will be processed recursively.

   Control Options
       By default, LLVMC is built with some standard configuration libraries
       that define the following options:

       -clang
           Use Clang instead of llvm-gcc.

       -opt
           Enable optimization passes with opt. To pass options to the opt
           program use the -Wo, option.

       -I directory
           Add a directory to the header file search path.

       -L directory
           Add directory to the library search path.

       -F directory
           Add directory to the framework search path.

       -lname
           Link in the library libname.[bc | a | so].  This library should be
           a bitcode library.

       -framework name
           Link in the library libname.[bc | a | so].  This library should be
           a bitcode library.

       -emit-llvm
           Output LLVM bitcode (with -c) or assembly (with -S) instead of
           native object (or assembly).  If -emit-llvm is given without either
           -c or -S it has no effect.

       -Wa Pass options to assembler.

       -Wl Pass options to linker.

       -Wo Pass options to opt.

       -Wllc
           Pass options to llc (code generator).

EXIT STATUS

       If 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
       llvmc will return the same result code as the failing compilation tool.

SEE ALSO

       llvm-gcc, llvm-g++, llvm-as, llvm-dis, llc, llvm-link

AUTHORS

       Maintained by the LLVM Team (<http://llvm.org>).