Index: docs/CommandGuide/llvm-nm.rst =================================================================== --- docs/CommandGuide/llvm-nm.rst +++ docs/CommandGuide/llvm-nm.rst @@ -93,6 +93,10 @@ Print only symbols whose definitions are external; that is, accessible from other files. +.. option:: --no-weak, -W + + Don't print any weak symbols in the output. + .. option:: --format=format, -f format Select an output format; *format* may be *sysv*, *posix*, or *bsd*. The default Index: test/tools/llvm-nm/X86/weak.test =================================================================== --- test/tools/llvm-nm/X86/weak.test +++ test/tools/llvm-nm/X86/weak.test @@ -1,4 +1,5 @@ # RUN: llvm-nm -B -S %p/Inputs/weak.obj.elf-x86_64 | FileCheck --match-full-lines %s +# RUN: llvm-nm -W -B -S %p/Inputs/weak.obj.elf-x86_64 | count 0 CHECK: w weak_extern_func CHECK: w weak_extern_var Index: tools/llvm-nm/llvm-nm.cpp =================================================================== --- tools/llvm-nm/llvm-nm.cpp +++ tools/llvm-nm/llvm-nm.cpp @@ -81,6 +81,11 @@ cl::aliasopt(ExternalOnly), cl::Grouping, cl::ZeroOrMore); +cl::opt NoWeakSymbols("no-weak", + cl::desc("Show only non-weak symbols")); +cl::alias NoWeakSymbols2("W", cl::desc("Alias for --no-weak"), + cl::aliasopt(NoWeakSymbols), cl::Grouping); + cl::opt BSDFormat("B", cl::desc("Alias for --format=bsd"), cl::Grouping); cl::opt POSIXFormat("P", cl::desc("Alias for --format=posix"), @@ -768,8 +773,10 @@ bool Undefined = SymFlags & SymbolRef::SF_Undefined; bool Global = SymFlags & SymbolRef::SF_Global; + bool Weak = SymFlags & SymbolRef::SF_Weak; if ((!Undefined && UndefinedOnly) || (Undefined && DefinedOnly) || - (!Global && ExternalOnly) || (SizeSort && !PrintAddress)) + (!Global && ExternalOnly) || (SizeSort && !PrintAddress) || + (Weak && NoWeakSymbols)) continue; if (PrintFileName) { if (!ArchitectureName.empty())