; RUN: opt -S -instcombine %s | FileCheck %s define <1 x i8> @test1(<8 x i8> %in) { ; CHECK-LABEL: @test1 ; CHECK: shufflevector <8 x i8> %in, <8 x i8> undef, <1 x i32> %val = extractelement <8 x i8> %in, i32 5 %vec = insertelement <1 x i8> undef, i8 %val, i32 0 ret <1 x i8> %vec } define <4 x i16> @test2(<8 x i16> %in, <8 x i16> %in2) { ; CHECK-LABEL: @test2 ; CHECK: shufflevector <8 x i16> %in2, <8 x i16> %in, <4 x i32> %elt0 = extractelement <8 x i16> %in, i32 3 %elt1 = extractelement <8 x i16> %in, i32 1 %elt2 = extractelement <8 x i16> %in2, i32 0 %elt3 = extractelement <8 x i16> %in, i32 2 %vec.0 = insertelement <4 x i16> undef, i16 %elt0, i32 0 %vec.1 = insertelement <4 x i16> %vec.0, i16 %elt1, i32 1 %vec.2 = insertelement <4 x i16> %vec.1, i16 %elt2, i32 2 %vec.3 = insertelement <4 x i16> %vec.2, i16 %elt3, i32 3 ret <4 x i16> %vec.3 } define <2 x i64> @test_vcopyq_lane_p64(<2 x i64> %a, <1 x i64> %b) #0 { ; CHECK-LABEL: @test_vcopyq_lane_p64 ; CHECK: extractelement ; CHECK: insertelement ; CHECK-NOT: shufflevector entry: %elt = extractelement <1 x i64> %b, i32 0 %res = insertelement <2 x i64> %a, i64 %elt, i32 1 ret <2 x i64> %res }