mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-13 23:18:58 +00:00
a421ac689f
This can significantly reduce the size of the switch, allowing for more efficient lowering. I also worked with the idea of exploiting unreachable defaults by omitting the range check for jump tables, but always ended up with a non-neglible binary size increase. It might be worth looking into some more. SimplifyCFG currently does this transformation, but I'm working towards changing that so we can optimize harder based on unreachable defaults. Differential Revision: http://reviews.llvm.org/D6510 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@223566 91177308-0d34-0410-b5e6-96231b3b80d8
41 lines
1.3 KiB
LLVM
41 lines
1.3 KiB
LLVM
; RUN: llc -mtriple=x86_64-apple-darwin10 -O0 < %s | FileCheck %s
|
|
|
|
; test that we print a label that we use. We had a bug where
|
|
; we would print the jump, but not the label because it was considered
|
|
; a fall through.
|
|
|
|
; CHECK: jmp LBB0_9
|
|
; CHECK: LBB0_9: ## %cleanup
|
|
|
|
define void @foo() {
|
|
entry:
|
|
br i1 undef, label %land.lhs.true, label %if.end11
|
|
|
|
land.lhs.true: ; preds = %entry
|
|
br i1 undef, label %if.then, label %if.end11
|
|
|
|
if.then: ; preds = %land.lhs.true
|
|
br i1 undef, label %if.then9, label %if.end
|
|
|
|
if.then9: ; preds = %if.then
|
|
br label %cleanup
|
|
|
|
if.end: ; preds = %if.then
|
|
br label %cleanup
|
|
|
|
cleanup: ; preds = %if.end, %if.then9
|
|
switch i32 undef, label %default [
|
|
i32 0, label %cleanup.cont
|
|
i32 1, label %if.end11
|
|
]
|
|
|
|
cleanup.cont: ; preds = %cleanup
|
|
br label %if.end11
|
|
|
|
if.end11: ; preds = %cleanup.cont, %cleanup, %land.lhs.true, %entry
|
|
ret void
|
|
|
|
default: ; preds = %cleanup
|
|
br label %if.end11
|
|
}
|