mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-25 03:30:37 +00:00
Previously, they were forced to immediately follow the actual branch instruction. This was usually OK (the LEAs actually accessing them got emitted nearby, and weren't usually separated much afterwards). Unfortunately, a sufficiently nasty phi elimination dumps many instructions right before the basic block terminator, and this can increase the range too much. This patch frees them up to be placed as usual by the constant islands pass, and consequently has to slightly modify the form of TBB/TBH tables to refer to a PC-relative label at the final jump. The other jump table formats were already position-independent. rdar://20813304 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@237590 91177308-0d34-0410-b5e6-96231b3b80d8
34 lines
1021 B
LLVM
34 lines
1021 B
LLVM
; RUN: llc < %s -mtriple thumbv6-apple-macosx10.6.0 | FileCheck %s
|
|
|
|
; test that we print the label of a bb that is only used in a jump table.
|
|
|
|
; CHECK: .long [[JUMPTABLE_DEST:LBB[0-9]+_[0-9]+]]
|
|
; CHECK: [[JUMPTABLE_DEST]]:
|
|
|
|
define i32 @calculate() {
|
|
entry:
|
|
switch i32 undef, label %return [
|
|
i32 1, label %sw.bb
|
|
i32 2, label %sw.bb6
|
|
i32 3, label %sw.bb13
|
|
i32 4, label %sw.bb20
|
|
]
|
|
|
|
sw.bb: ; preds = %entry
|
|
br label %return
|
|
|
|
sw.bb6: ; preds = %entry
|
|
br label %return
|
|
|
|
sw.bb13: ; preds = %entry
|
|
br label %return
|
|
|
|
sw.bb20: ; preds = %entry
|
|
%div = sdiv i32 undef, undef
|
|
br label %return
|
|
|
|
return: ; preds = %sw.bb20, %sw.bb13, %sw.bb6, %sw.bb, %entry
|
|
%retval.0 = phi i32 [ %div, %sw.bb20 ], [ undef, %sw.bb13 ], [ undef, %sw.bb6 ], [ undef, %sw.bb ], [ 0, %entry ]
|
|
ret i32 %retval.0
|
|
}
|