[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Transforms / InstCombine / vec_gep_scalar_arg.ll
blob33ed7cb6a7fde261119ca6d5a7758ba11b63d6ab
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -instcombine -S < %s | FileCheck %s
4 define <4 x i16*> @PR41270([4 x i16]* %x) {
5 ; CHECK-LABEL: @PR41270(
6 ; CHECK-NEXT:    [[TMP1:%.*]] = insertelement <4 x [4 x i16]*> undef, [4 x i16]* [[X:%.*]], i32 0
7 ; CHECK-NEXT:    [[TMP2:%.*]] = getelementptr inbounds [4 x i16], <4 x [4 x i16]*> [[TMP1]], i64 0, i64 3
8 ; CHECK-NEXT:    ret <4 x i16*> [[TMP2]]
10   %ins = insertelement <4 x [4 x i16]*> undef, [4 x i16]* %x, i32 0
11   %splat = shufflevector <4 x [4 x i16]*> %ins, <4 x [4 x i16]*> undef, <4 x i32> zeroinitializer
12   %t2 = getelementptr inbounds [4 x i16], <4 x [4 x i16]*> %splat, i32 0, i32 3
13   %t3 = extractelement <4 x i16*> %t2, i32 3
14   %ins2 = insertelement <4 x i16*> undef, i16* %t3, i32 0
15   ret <4 x i16*> %ins2