diff options
| author | Sanjay Patel <spatel@rotateright.com> | 2016-05-15 18:41:18 +0000 |
|---|---|---|
| committer | Sanjay Patel <spatel@rotateright.com> | 2016-05-15 18:41:18 +0000 |
| commit | 399780f0884b069b28d347923568a0cbe7e9682f (patch) | |
| tree | 8a6c7963d9ebb73167dfdb6592eb700b3e3cbb14 /llvm/test | |
| parent | 5b68a0df04d089c16d078b51a00ed0bf510698a0 (diff) | |
| download | bcm5719-llvm-399780f0884b069b28d347923568a0cbe7e9682f.tar.gz bcm5719-llvm-399780f0884b069b28d347923568a0cbe7e9682f.zip | |
add test to show missing optimization
llvm-svn: 269601
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/Transforms/SimplifyCFG/switch-masked-bits.ll | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/llvm/test/Transforms/SimplifyCFG/switch-masked-bits.ll b/llvm/test/Transforms/SimplifyCFG/switch-masked-bits.ll index ecd516519ab..284f7e3cb15 100644 --- a/llvm/test/Transforms/SimplifyCFG/switch-masked-bits.ll +++ b/llvm/test/Transforms/SimplifyCFG/switch-masked-bits.ll @@ -42,3 +42,40 @@ b: c: ret i32 5 } + +; We're sign extending an 8-bit value. +; The switch condition must be in the range [-128, 127], so any cases outside of that range must be dead. + +define i1 @repeated_signbits(i8 %condition) { +; CHECK-LABEL: @repeated_signbits( +; CHECK: switch i32 +; CHECK-DAG: i32 -2147483648, label %a +; CHECK-DAG: i32 -129, label %a +; CHECK-DAG: i32 -128, label %a +; CHECK-DAG: i32 -1, label %a +; CHECK-DAG: i32 0, label %a +; CHECK-DAG: i32 127, label %a +; CHECK-DAG: i32 128, label %a +; CHECK-DAG: i32 2147483647, label %a +; CHECK-NEXT: ] +; +entry: + %sext = sext i8 %condition to i32 + switch i32 %sext, label %default [ + i32 -2147483648, label %a + i32 -129, label %a + i32 -128, label %a + i32 -1, label %a + i32 0, label %a + i32 127, label %a + i32 128, label %a + i32 2147483647, label %a + ] + +a: + ret i1 1 + +default: + ret i1 0 +} + |

