llvm-nm - list LLVM bitcode and object file's symbol table ========================================================== SYNOPSIS -------- :program:`llvm-nm` [*options*] [*filenames...*] DESCRIPTION ----------- The :program:`llvm-nm` utility lists the names of symbols from the LLVM bitcode files, object files, or :program:`ar` archives containing them, named on the command line. Each symbol is listed along with some simple information about its provenance. If no file name is specified, or *-* is used as a file name, :program:`llvm-nm` will process a file on its standard input stream. :program:`llvm-nm`'s default output format is the traditional BSD :program:`nm` 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. Type code characters currently supported, and their meanings, are as follows: U Named object is referenced but undefined in this bitcode file C Common (multiple definitions link together into one def) W Weak reference (multiple definitions link together into zero or one definitions) t Local function (text) object T Global function (text) object d Local data object D Global data object ? Something unrecognizable Because LLVM bitcode 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", :program:`llvm-nm` does not print an address for any symbol in an LLVM bitcode file, even symbols which are defined in the bitcode file. OPTIONS ------- .. program:: llvm-nm .. option:: -B (default) Use BSD output format. Alias for `--format=bsd`. .. option:: -P Use POSIX.2 output format. Alias for `--format=posix`. .. option:: --debug-syms, -a Show all symbols, even debugger only. .. option:: --defined-only Print only symbols defined in this file (as opposed to symbols which may be referenced by objects in this file, but not defined in this file.) .. option:: --dynamic, -D Display dynamic symbols instead of normal symbols. .. option:: --extern-only, -g Print only symbols whose definitions are external; that is, accessible from other files. .. option:: --format=format, -f format Select an output format; *format* may be *sysv*, *posix*, or *bsd*. The default is *bsd*. .. option:: -help Print a summary of command-line options and their meanings. .. option:: --no-sort, -p Shows symbols in order encountered. .. option:: --numeric-sort, -n, -v Sort symbols by address. .. option:: --print-file-name, -A, -o Precede each symbol with the file it came from. .. option:: --print-size, -S Show symbol size instead of address. .. option:: --size-sort Sort symbols by size. .. option:: --undefined-only, -u Print only symbols referenced but not defined in this file. .. option:: --radix=RADIX, -t Specify the radix of the symbol address(es). Values accepted d(decimal), x(hexadecomal) and o(octal). BUGS ---- * :program:`llvm-nm` cannot demangle C++ mangled names, like GNU :program:`nm` can. * :program:`llvm-nm` does not support the full set of arguments that GNU :program:`nm` does. EXIT STATUS ----------- :program:`llvm-nm` exits with an exit code of zero. SEE ALSO -------- llvm-dis, ar(1), nm(1)