``` // llvm-objdump -d output (before) 400000: e8 0b 00 00 00 callq 11 400005: e8 0b 00 00 00 callq 11 // llvm-objdump -d output (after) 400000: e8 0b 00 00 00 callq 0x400010 400005: e8 0b 00 00 00 callq 0x400015 // GNU objdump -d. The lack of 0x is not ideal because the result cannot be re-assembled 400000: e8 0b 00 00 00 callq 400010 400005: e8 0b 00 00 00 callq 400015 ``` In llvm-objdump, we pass the address of the next MCInst. Ideally we should just thread the address of the current address, unfortunately we cannot call X86MCCodeEmitter::encodeInstruction (X86MCCodeEmitter requires MCInstrInfo and MCContext) to get the length of the MCInst. MCInstPrinter::printInst has other callers (e.g llvm-mc -filetype=asm, llvm-mca) which set Address to 0. They leave MCInstPrinter::PrintBranchImmAsAddress as false and this change is a no-op for them. Reviewed By: jhenderson Differential Revision: https://reviews.llvm.org/D76580
39 lines
1.2 KiB
LLVM
39 lines
1.2 KiB
LLVM
; RUN: opt -module-summary %s -o %t1.o
|
|
; RUN: opt -module-summary -o %t2.o %S/Inputs/not-prevailing.ll
|
|
; RUN: llvm-lto2 run -o %t3.o %t1.o %t2.o -r %t1.o,foo,x -r %t1.o,zed,px -r %t1.o,bar,x \
|
|
; RUN: -r %t2.o,bar,x -save-temps
|
|
|
|
; Check that 'foo' and 'bar' were not inlined.
|
|
; CHECK: <zed>:
|
|
; CHECK-NEXT: {{.*}} pushq %rbx
|
|
; CHECK-NEXT: {{.*}} callq 0x6 <zed+0x6>
|
|
; CHECK-NEXT: {{.*}} movl %eax, %ebx
|
|
; CHECK-NEXT: {{.*}} callq 0xd <zed+0xd>
|
|
; CHECK-NEXT: {{.*}} movl %ebx, %eax
|
|
; CHECK-NEXT: {{.*}} popq %rbx
|
|
; CHECK-NEXT: {{.*}} retq
|
|
|
|
; RUN: llvm-objdump -d %t3.o.1 | FileCheck %s
|
|
; RUN: llvm-readelf --symbols %t3.o.1 | FileCheck %s --check-prefix=SYMBOLS
|
|
|
|
; Check that 'foo' and 'bar' produced as undefined.
|
|
; SYMBOLS: NOTYPE GLOBAL DEFAULT UND bar
|
|
; SYMBOLS: NOTYPE GLOBAL DEFAULT UND foo
|
|
; SYMBOLS: FUNC GLOBAL DEFAULT 2 zed
|
|
|
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
$foo = comdat any
|
|
define weak i32 @foo() comdat {
|
|
ret i32 65
|
|
}
|
|
|
|
declare void @bar()
|
|
|
|
define i32 @zed() {
|
|
%1 = tail call i32 @foo()
|
|
call void @bar()
|
|
ret i32 %1
|
|
}
|