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 @@ -12,7 +12,7 @@ # CHECK-NEXT:0000000000000000 *UND* 0000000000000000 undef # CHECK-NEXT:0000000000000000 g *ABS* 0000000000000000 abs # CHECK-NEXT:0000000000000000 *COM* 0000000000000000 common -# CHECK-NEXT:0000000000000000 g .text 0000000000000000 ifunc +# CHECK-NEXT:0000000000000000 g i .text 0000000000000000 ifunc # CHECK-NEXT:0000000000000000 g O .data 0000000000000000 gnu_unique --- !ELF 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 @@ -1896,6 +1896,10 @@ bool Absolute = Flags & SymbolRef::SF_Absolute; bool Common = Flags & SymbolRef::SF_Common; bool Hidden = Flags & SymbolRef::SF_Hidden; + char Indirect = ' '; + if (auto *ELF = dyn_cast(O)) + if (ELFSymbolRef(*I).getELFType() == ELF::STT_GNU_IFUNC) + Indirect = 'i'; char GlobLoc = ' '; if ((Section != O->section_end() || Absolute) && !Weak) @@ -1918,7 +1922,7 @@ << (Weak ? 'w' : ' ') // Weak? << ' ' // Constructor. Not supported yet. << ' ' // Warning. Not supported yet. - << ' ' // Indirect reference to another symbol. + << Indirect // Indirect reference to another symbol. << Debug // Debugging (d) or dynamic (D) symbol. << FileFunc // Name of function (F), file (f) or object (O). << ' ';