diff --git a/llvm/test/tools/llvm-nm/special-syms-riscv.test b/llvm/test/tools/llvm-nm/special-syms-riscv.test new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-nm/special-syms-riscv.test @@ -0,0 +1,29 @@ +## Test --special-syms flag. +# RUN: yaml2obj %s -o %t + +# RUN: llvm-nm %t | count 0 +# RUN: llvm-nm %t --special-syms | FileCheck %s + +!ELF +FileHeader: + Class: ELFCLASS64 + Data: ELFDATA2LSB + Type: ET_REL + Machine: EM_RISCV +Sections: + - Name: .text + Type: SHT_PROGBITS + Flags: [ SHF_ALLOC, SHF_EXECINSTR ] + Address: 0x1000 + - Name: .data + Type: SHT_PROGBITS + Flags: [ SHF_ALLOC, SHF_WRITE ] + Address: 0x2000 +Symbols: + - Name: $x.1 + Section: .text + - Name: $d.1 + Section: .data + +# CHECK: 2000 d $d.1 +# CHECK-NEXT: 1000 t $x.1 diff --git a/llvm/tools/llvm-nm/llvm-nm.cpp b/llvm/tools/llvm-nm/llvm-nm.cpp --- a/llvm/tools/llvm-nm/llvm-nm.cpp +++ b/llvm/tools/llvm-nm/llvm-nm.cpp @@ -1803,9 +1803,9 @@ // --special-syms option. auto *ELFObj = dyn_cast(&Obj); bool HasMappingSymbol = - ELFObj && - llvm::is_contained({ELF::EM_ARM, ELF::EM_AARCH64, ELF::EM_CSKY}, - ELFObj->getEMachine()); + ELFObj && llvm::is_contained({ELF::EM_ARM, ELF::EM_AARCH64, + ELF::EM_CSKY, ELF::EM_RISCV}, + ELFObj->getEMachine()); if (!HasMappingSymbol && !DebugSyms && (*SymFlagsOrErr & SymbolRef::SF_FormatSpecific)) continue;