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 | |
| parent | 5b68a0df04d089c16d078b51a00ed0bf510698a0 (diff) | |
| download | bcm5719-llvm-399780f0884b069b28d347923568a0cbe7e9682f.tar.gz bcm5719-llvm-399780f0884b069b28d347923568a0cbe7e9682f.zip  | |
add test to show missing optimization
llvm-svn: 269601
| -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 +} +  | 

