diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-11-02 05:03:24 +0000 |
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-11-02 05:03:24 +0000 |
| commit | a135632af0f0a108f882954200052a95c2cd873b (patch) | |
| tree | d0586ae9a34b299ce6d756f03a4e0c645e04d3ed | |
| parent | 329211bbb7f6f3145a65494624e57d422048923f (diff) | |
| download | bcm5719-llvm-a135632af0f0a108f882954200052a95c2cd873b.tar.gz bcm5719-llvm-a135632af0f0a108f882954200052a95c2cd873b.zip | |
Fix llvm-nm to mach OS X's nm on some tests.
There is still a long way to go for llvm-nm, but at least we now match
nm's letter output in the cases we test for.
llvm-svn: 193912
| -rw-r--r-- | llvm/lib/Object/MachOObjectFile.cpp | 23 | ||||
| -rw-r--r-- | llvm/test/Object/Inputs/weak-global-symbol.macho-i386 | bin | 0 -> 344 bytes | |||
| -rw-r--r-- | llvm/test/Object/nm-trivial-object.test | 8 | ||||
| -rw-r--r-- | llvm/test/Object/nm-weak-global-macho.test | 3 |
4 files changed, 24 insertions, 10 deletions
diff --git a/llvm/lib/Object/MachOObjectFile.cpp b/llvm/lib/Object/MachOObjectFile.cpp index 3040094f14b..f48bb8a7fe0 100644 --- a/llvm/lib/Object/MachOObjectFile.cpp +++ b/llvm/lib/Object/MachOObjectFile.cpp @@ -594,24 +594,35 @@ error_code MachOObjectFile::getSymbolType(DataRefImpl Symb, error_code MachOObjectFile::getSymbolNMTypeChar(DataRefImpl Symb, char &Res) const { nlist_base Entry = getSymbolTableEntryBase(this, Symb); - uint8_t Type = Entry.n_type; - uint16_t Flags = Entry.n_desc; + uint8_t NType = Entry.n_type; char Char; - switch (Type & MachO::N_TYPE) { + switch (NType & MachO::N_TYPE) { case MachO::N_UNDF: Char = 'u'; break; case MachO::N_ABS: - case MachO::N_SECT: Char = 's'; break; + case MachO::N_SECT: { + section_iterator Sec = end_sections(); + getSymbolSection(Symb, Sec); + DataRefImpl Ref = Sec->getRawDataRefImpl(); + StringRef SectionName; + getSectionName(Ref, SectionName); + StringRef SegmentName = getSectionFinalSegmentName(Ref); + if (SegmentName == "__TEXT" && SectionName == "__text") + Char = 't'; + else + Char = 's'; + } + break; default: Char = '?'; break; } - if (Flags & (MachO::N_EXT | MachO::N_PEXT)) + if (NType & (MachO::N_EXT | MachO::N_PEXT)) Char = toupper(static_cast<unsigned char>(Char)); Res = Char; return object_error::success; @@ -630,7 +641,7 @@ error_code MachOObjectFile::getSymbolFlags(DataRefImpl DRI, if ((MachOType & MachO::N_TYPE) == MachO::N_UNDF) Result |= SymbolRef::SF_Undefined; - if (MachOFlags & MachO::N_STAB) + if (MachOType & MachO::N_STAB) Result |= SymbolRef::SF_FormatSpecific; if (MachOType & MachO::N_EXT) { diff --git a/llvm/test/Object/Inputs/weak-global-symbol.macho-i386 b/llvm/test/Object/Inputs/weak-global-symbol.macho-i386 Binary files differnew file mode 100644 index 00000000000..a9c8e0cde15 --- /dev/null +++ b/llvm/test/Object/Inputs/weak-global-symbol.macho-i386 diff --git a/llvm/test/Object/nm-trivial-object.test b/llvm/test/Object/nm-trivial-object.test index d5177457a8d..748d6f20d51 100644 --- a/llvm/test/Object/nm-trivial-object.test +++ b/llvm/test/Object/nm-trivial-object.test @@ -25,10 +25,10 @@ ELF: U puts macho: 00000000 U _SomeOtherFunction -macho: 00000000 s _main +macho: 00000000 T _main macho: 00000000 U _puts macho64: 00000028 s L_.str -macho64: 00000000 u _SomeOtherFunction -macho64: 00000000 s _main -macho64: 00000000 u _puts +macho64: 00000000 U _SomeOtherFunction +macho64: 00000000 T _main +macho64: 00000000 U _puts diff --git a/llvm/test/Object/nm-weak-global-macho.test b/llvm/test/Object/nm-weak-global-macho.test new file mode 100644 index 00000000000..ede26090f95 --- /dev/null +++ b/llvm/test/Object/nm-weak-global-macho.test @@ -0,0 +1,3 @@ +RUN: llvm-nm %p/Inputs/weak-global-symbol.macho-i386 | FileCheck %s + +CHECK: 00000000 S _a |

