diff options
| author | Sanjay Patel <spatel@rotateright.com> | 2018-07-09 17:20:20 +0000 | 
|---|---|---|
| committer | Sanjay Patel <spatel@rotateright.com> | 2018-07-09 17:20:20 +0000 | 
| commit | 7cd32419ab0ac5ff9609fcff12657b1ac6554e76 (patch) | |
| tree | 56d090e39bf7627154375a53a7f308c09195c41f /llvm/test/Transforms | |
| parent | 82dee6aca8755abb3cd2383ce9b46db722d52b21 (diff) | |
| download | bcm5719-llvm-7cd32419ab0ac5ff9609fcff12657b1ac6554e76.tar.gz bcm5719-llvm-7cd32419ab0ac5ff9609fcff12657b1ac6554e76.zip | |
[InstCombine] avoid extra poison when moving shift above shuffle
As discussed in D49047 / D48987, shift-by-undef produces poison,
so we can't use undef vector elements in that case..
Note that we need to extend this for poison-generating flags,
and there's a proposal to create poison from FMF in D47963,
llvm-svn: 336562
Diffstat (limited to 'llvm/test/Transforms')
| -rw-r--r-- | llvm/test/Transforms/InstCombine/vec_shuffle.ll | 6 | 
1 files changed, 3 insertions, 3 deletions
| diff --git a/llvm/test/Transforms/InstCombine/vec_shuffle.ll b/llvm/test/Transforms/InstCombine/vec_shuffle.ll index 7e863fd2813..d1a42882eaa 100644 --- a/llvm/test/Transforms/InstCombine/vec_shuffle.ll +++ b/llvm/test/Transforms/InstCombine/vec_shuffle.ll @@ -654,7 +654,7 @@ define <2 x i32> @shl_splat_constant0(<2 x i32> %x) {  define <2 x i32> @shl_splat_constant1(<2 x i32> %x) {  ; CHECK-LABEL: @shl_splat_constant1( -; CHECK-NEXT:    [[TMP1:%.*]] = shl <2 x i32> [[X:%.*]], <i32 5, i32 undef> +; CHECK-NEXT:    [[TMP1:%.*]] = shl <2 x i32> [[X:%.*]], <i32 5, i32 0>  ; CHECK-NEXT:    [[R:%.*]] = shufflevector <2 x i32> [[TMP1]], <2 x i32> undef, <2 x i32> zeroinitializer  ; CHECK-NEXT:    ret <2 x i32> [[R]]  ; @@ -676,7 +676,7 @@ define <2 x i32> @ashr_splat_constant0(<2 x i32> %x) {  define <2 x i32> @ashr_splat_constant1(<2 x i32> %x) {  ; CHECK-LABEL: @ashr_splat_constant1( -; CHECK-NEXT:    [[TMP1:%.*]] = ashr <2 x i32> [[X:%.*]], <i32 5, i32 undef> +; CHECK-NEXT:    [[TMP1:%.*]] = ashr <2 x i32> [[X:%.*]], <i32 5, i32 0>  ; CHECK-NEXT:    [[R:%.*]] = shufflevector <2 x i32> [[TMP1]], <2 x i32> undef, <2 x i32> zeroinitializer  ; CHECK-NEXT:    ret <2 x i32> [[R]]  ; @@ -698,7 +698,7 @@ define <2 x i32> @lshr_splat_constant0(<2 x i32> %x) {  define <2 x i32> @lshr_splat_constant1(<2 x i32> %x) {  ; CHECK-LABEL: @lshr_splat_constant1( -; CHECK-NEXT:    [[TMP1:%.*]] = lshr <2 x i32> [[X:%.*]], <i32 5, i32 undef> +; CHECK-NEXT:    [[TMP1:%.*]] = lshr <2 x i32> [[X:%.*]], <i32 5, i32 0>  ; CHECK-NEXT:    [[R:%.*]] = shufflevector <2 x i32> [[TMP1]], <2 x i32> undef, <2 x i32> zeroinitializer  ; CHECK-NEXT:    ret <2 x i32> [[R]]  ; | 

