diff --git a/llvm/test/tools/llvm-objdump/X86/elf-bbaddrmap-disassemble-symbolize-operands.yaml b/llvm/test/tools/llvm-objdump/X86/elf-bbaddrmap-disassemble-symbolize-operands.yaml --- a/llvm/test/tools/llvm-objdump/X86/elf-bbaddrmap-disassemble-symbolize-operands.yaml +++ b/llvm/test/tools/llvm-objdump/X86/elf-bbaddrmap-disassemble-symbolize-operands.yaml @@ -20,15 +20,15 @@ ## Expect to find the branch and basic block labels and global variable name. # ATT: : -# ATT-NEXT: : +# ATT-NEXT: : # ATT-NEXT: pushq %rax -# ATT-NEXT: : +# ATT-NEXT: : # ATT-NEXT: cmpl , %eax <[[SYM]]> # ATT-NEXT: nop # ATT-NEXT: : -# ATT-NEXT: jge -# ATT-NEXT: jmp -# ATT-NEXT: : +# ATT-NEXT: jge +# ATT-NEXT: jmp +# ATT-NEXT: : # ATT-NEXT: retq # ATT: : # ATT-NEXT: : @@ -42,15 +42,15 @@ # ATT-NEXT: retq # INTEL: : -# INTEL-NEXT: : +# INTEL-NEXT: : # INTEL-NEXT: push rax -# INTEL-NEXT: : +# INTEL-NEXT: : # INTEL-NEXT: cmp eax, dword ptr <[[SYM]]> # INTEL-NEXT: nop # INTEL-NEXT: : -# INTEL-NEXT: jge -# INTEL-NEXT: jmp -# INTEL-NEXT: : +# INTEL-NEXT: jge +# INTEL-NEXT: jmp +# INTEL-NEXT: : # INTEL-NEXT: ret # INTEL: : # INTEL-NEXT: : @@ -92,19 +92,23 @@ Type: SHT_LLVM_BB_ADDR_MAP Link: .text.foo Entries: - - Version: 1 + - Version: 2 Address: [[FOO_ADDR]] BBEntries: - - AddressOffset: 0x0 + - ID: 4 + AddressOffset: 0x0 Size: 0x1 Metadata: 0x1 - - AddressOffset: 0x0 + - ID: 3 + AddressOffset: 0x0 Size: 0x6 Metadata: 0x0 - - AddressOffset: 0x1 + - ID: 2 + AddressOffset: 0x1 Size: 0x4 Metadata: 0x0 - - AddressOffset: 0x0 + - ID: 1 + AddressOffset: 0x0 Size: 0x1 Metadata: 0x2 - Name: .llvm_bb_addr_map.bar @@ -162,19 +166,23 @@ Type: SHT_LLVM_BB_ADDR_MAP Link: .text.foo Entries: - - Version: 1 + - Version: 2 Address: 0x4000 BBEntries: - - AddressOffset: 0x0 + - ID: 4 + AddressOffset: 0x0 Size: 0x1 Metadata: 0x1 - - AddressOffset: 0x0 + - ID: 3 + AddressOffset: 0x0 Size: 0x6 Metadata: 0x0 - - AddressOffset: 0x1 + - ID: 2 + AddressOffset: 0x1 Size: 0x4 Metadata: 0x0 - - AddressOffset: 0x0 + - ID: 1 + AddressOffset: 0x0 Size: 0x1 Metadata: 0x2 - Version: 1 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 @@ -1156,11 +1156,11 @@ auto Iter = AddrToBBAddrMap.find(StartAddress); if (Iter == AddrToBBAddrMap.end()) return; - for (unsigned I = 0, Size = Iter->second.BBEntries.size(); I < Size; ++I) { - uint64_t BBAddress = Iter->second.BBEntries[I].Offset + Iter->second.Addr; + for (const BBAddrMap::BBEntry &BBEntry : Iter->second.BBEntries) { + uint64_t BBAddress = BBEntry.Offset + Iter->second.Addr; if (BBAddress >= EndAddress) continue; - Labels[BBAddress].push_back(("BB" + Twine(I)).str()); + Labels[BBAddress].push_back(("BB" + Twine(BBEntry.ID)).str()); } }