mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-08 21:10:35 +00:00
Compute the correct jump table entries on 32 bit windows.
On 32 bit windows we use label differences and .set does not suppress rolocations, a combination that was not used before r220256. This fixes PR21497. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221456 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f0f66a254d
commit
eed959015b
@ -1247,8 +1247,9 @@ void AsmPrinter::EmitJumpTableEntry(const MachineJumpTableInfo *MJTI,
|
||||
break;
|
||||
}
|
||||
Value = MCSymbolRefExpr::Create(MBB->getSymbol(), OutContext);
|
||||
const MCExpr *JTI = MCSymbolRefExpr::Create(GetJTISymbol(UID), OutContext);
|
||||
Value = MCBinaryExpr::CreateSub(Value, JTI, OutContext);
|
||||
const TargetLowering *TLI = TM.getSubtargetImpl()->getTargetLowering();
|
||||
const MCExpr *Base = TLI->getPICJumpTableRelocBaseExpr(MF, UID, OutContext);
|
||||
Value = MCBinaryExpr::CreateSub(Value, Base, OutContext);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
36
test/CodeGen/X86/win32-pic-jumptable.ll
Normal file
36
test/CodeGen/X86/win32-pic-jumptable.ll
Normal file
@ -0,0 +1,36 @@
|
||||
; RUN: llc < %s -relocation-model=pic | FileCheck %s
|
||||
|
||||
; CHECK: calll L0$pb
|
||||
; CHECK-NEXT: L0$pb:
|
||||
; CHECK-NEXT: popl %eax
|
||||
; CHECK-NEXT: addl LJTI0_0(,%ecx,4), %eax
|
||||
; CHECK-NEXT: jmpl *%eax
|
||||
|
||||
; CHECK: LJTI0_0:
|
||||
; CHECK-NEXT: .long LBB0_4-L0$pb
|
||||
; CHECK-NEXT: .long LBB0_5-L0$pb
|
||||
; CHECK-NEXT: .long LBB0_6-L0$pb
|
||||
; CHECK-NEXT: .long LBB0_7-L0$pb
|
||||
|
||||
|
||||
target triple = "i686--windows-itanium"
|
||||
define i32 @f(i64 %x) {
|
||||
bb0:
|
||||
switch i64 %x, label %bb5 [
|
||||
i64 1, label %bb1
|
||||
i64 2, label %bb2
|
||||
i64 3, label %bb3
|
||||
i64 4, label %bb4
|
||||
]
|
||||
bb1:
|
||||
br label %bb5
|
||||
bb2:
|
||||
br label %bb5
|
||||
bb3:
|
||||
br label %bb5
|
||||
bb4:
|
||||
br label %bb5
|
||||
bb5:
|
||||
%y = phi i32 [ 0, %bb0 ], [ 1, %bb1 ], [ 2, %bb2 ], [ 3, %bb3 ], [ 4, %bb4 ]
|
||||
ret i32 %y
|
||||
}
|
Loading…
Reference in New Issue
Block a user