diff --git a/llvm/test/tools/llvm-objdump/ELF/symbol-table.test b/llvm/test/tools/llvm-objdump/ELF/symbol-table.test --- a/llvm/test/tools/llvm-objdump/ELF/symbol-table.test +++ b/llvm/test/tools/llvm-objdump/ELF/symbol-table.test @@ -15,7 +15,7 @@ # CHECK-NEXT:0000000000000000 g F .text 000000000000000f func # CHECK-NEXT:0000000000000000 g O *COM* 0000000000000000 common # CHECK-NEXT:0000000000000000 g O .data 0000000000000000 tls -# CHECK-NEXT:0000000000000000 g .text 0000000000000000 ifunc +# CHECK-NEXT:0000000000000000 g i .text 0000000000000000 ifunc # CHECK-NEXT:0000000000000000 g .text 0000000000000000 invalid_type # CHECK-NEXT:0000000000000000 g .text 0000000000000000 STT_HIOS # CHECK-NEXT:0000000000000000 g .text 0000000000000000 STT_LOPROC diff --git a/llvm/tools/llvm-objdump/llvm-objdump.cpp b/llvm/tools/llvm-objdump/llvm-objdump.cpp --- a/llvm/tools/llvm-objdump/llvm-objdump.cpp +++ b/llvm/tools/llvm-objdump/llvm-objdump.cpp @@ -1899,6 +1899,11 @@ char GlobLoc = ' '; if ((Section != O->section_end() || Absolute) && !Weak) GlobLoc = Global ? 'g' : 'l'; + char IFunc = ' '; + if (auto *ELF = dyn_cast(O)) { + if (ELFSymbolRef(*I).getELFType() == ELF::STT_GNU_IFUNC) + IFunc = 'i'; + } char Debug = (Type == SymbolRef::ST_Debug || Type == SymbolRef::ST_File) ? 'd' : ' '; char FileFunc = ' '; @@ -1917,7 +1922,7 @@ << (Weak ? 'w' : ' ') // Weak? << ' ' // Constructor. Not supported yet. << ' ' // Warning. Not supported yet. - << ' ' // Indirect reference to another symbol. + << IFunc << Debug // Debugging (d) or dynamic (D) symbol. << FileFunc // Name of function (F), file (f) or object (O). << ' ';