mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-03 14:08:57 +00:00
af7ae9d689
Switch instructions were crashing the StructurizeCFG pass, and it's probably easier anyway if we don't need to handle them in this pass. Reviewed-by: Christian König <christian.koenig@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@191841 91177308-0d34-0410-b5e6-96231b3b80d8
24 lines
564 B
LLVM
24 lines
564 B
LLVM
; RUN: opt -S -structurizecfg %s -o - | FileCheck %s
|
|
|
|
; The structurizecfg pass cannot handle switch instructions, so we need to
|
|
; make sure the lower switch pass is always run before structurizecfg.
|
|
|
|
; CHECK-LABEL: @switch
|
|
define void @switch(i32 addrspace(1)* %out, i32 %cond) nounwind {
|
|
entry:
|
|
; CHECK: icmp
|
|
switch i32 %cond, label %done [ i32 0, label %zero]
|
|
|
|
; CHECK: zero:
|
|
zero:
|
|
; CHECK: store i32 7, i32 addrspace(1)* %out
|
|
store i32 7, i32 addrspace(1)* %out
|
|
; CHECK: br label %done
|
|
br label %done
|
|
|
|
; CHECK: done:
|
|
done:
|
|
; CHECK: ret void
|
|
ret void
|
|
}
|