mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-24 20:29:53 +00:00
3f978ba958
As discussed by Andrea on PR30486, we have an unsafe cast to an Instruction type in the select combine which doesn't take into account that it could be a ConstantExpr instead. Differential Revision: https://reviews.llvm.org/D25466 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@284000 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
953 B
LLVM
45 lines
953 B
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt < %s -instcombine -S | FileCheck %s
|
|
|
|
@g = global i32 0
|
|
|
|
; PR30486
|
|
define i32 @single_case() {
|
|
; CHECK-LABEL: @single_case(
|
|
; CHECK-NEXT: switch i32 ptrtoint (i32* @g to i32), label %x [
|
|
; CHECK-NEXT: ]
|
|
; CHECK: x:
|
|
; CHECK-NEXT: ret i32 0
|
|
;
|
|
switch i32 add (i32 ptrtoint (i32* @g to i32), i32 -1), label %x []
|
|
x:
|
|
ret i32 0
|
|
}
|
|
|
|
define i32 @multiple_cases() {
|
|
; CHECK-LABEL: @multiple_cases(
|
|
; CHECK-NEXT: switch i32 ptrtoint (i32* @g to i32), label %x [
|
|
; CHECK-NEXT: i32 2, label %one
|
|
; CHECK-NEXT: i32 3, label %two
|
|
; CHECK-NEXT: ]
|
|
; CHECK: x:
|
|
; CHECK-NEXT: ret i32 0
|
|
; CHECK: one:
|
|
; CHECK-NEXT: ret i32 1
|
|
; CHECK: two:
|
|
; CHECK-NEXT: ret i32 2
|
|
;
|
|
switch i32 add (i32 ptrtoint (i32* @g to i32), i32 -1), label %x [
|
|
i32 1, label %one
|
|
i32 2, label %two
|
|
]
|
|
x:
|
|
ret i32 0
|
|
|
|
one:
|
|
ret i32 1
|
|
|
|
two:
|
|
ret i32 2
|
|
}
|