From: Saurabh Badhwar Date: Wed, 16 Jan 2019 14:38:22 +0000 (+0000) Subject: [llvm-nm] Allow --size-sort to print symbols with only Symbol size X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=93312b1fb7d2501df00aaf8644ab2ec5d9a179af;p=llvm [llvm-nm] Allow --size-sort to print symbols with only Symbol size Summary: When llvm-nm is passed only the --size-sort option for an object file, there is no output generated. The commit modifies the behavior to print the symbols sorted and their size which is also inline with the output of the GNU nm tool. Signed-off-by: Saurabh Badhwar Reviewers: enderby, rupprecht Reviewed By: rupprecht Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D56063 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@351347 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/tools/llvm-nm/X86/size-sort.test b/test/tools/llvm-nm/X86/size-sort.test new file mode 100644 index 00000000000..64ea99e35b1 --- /dev/null +++ b/test/tools/llvm-nm/X86/size-sort.test @@ -0,0 +1,12 @@ +# RUN: llvm-nm --size-sort %p/Inputs/hello.obj.elf-x86_64 | FileCheck --check-prefix=SIZE-SORT-NO-ADDR %s +# RUN: llvm-nm --size-sort -S %p/Inputs/hello.obj.elf-x86_64 | FileCheck --check-prefix=SIZE-SORT-PRINT-ADDR %s +# RUN: llvm-nm -S %p/Inputs/hello.obj.elf-x86_64 | FileCheck --check-prefix=NO-SIZE-SORT-PRINT-ADDR %s + +# SIZE-SORT-NO-ADDR: U puts +# SIZE-SORT-NO-ADDR: 0000000000000015 T main + +# SIZE-SORT-PRINT-ADDR: U puts +# SIZE-SORT-PRINT-ADDR: 0000000000000000 0000000000000015 T main + +# NO-SIZE-SORT-PRINT-ADDR: 0000000000000000 0000000000000015 T main +# NO-SIZE-SORT-PRINT-ADDR: U puts diff --git a/tools/llvm-nm/llvm-nm.cpp b/tools/llvm-nm/llvm-nm.cpp index 042e284e836..084e30540a1 100644 --- a/tools/llvm-nm/llvm-nm.cpp +++ b/tools/llvm-nm/llvm-nm.cpp @@ -798,8 +798,7 @@ static void sortAndPrintSymbolList(SymbolicFile &Obj, bool printName, bool Global = SymFlags & SymbolRef::SF_Global; bool Weak = SymFlags & SymbolRef::SF_Weak; if ((!Undefined && UndefinedOnly) || (Undefined && DefinedOnly) || - (!Global && ExternalOnly) || (SizeSort && !PrintAddress) || - (Weak && NoWeakSymbols)) + (!Global && ExternalOnly) || (Weak && NoWeakSymbols)) continue; if (PrintFileName) writeFileName(outs());