; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -march=hexagon < %s | FileCheck %s define <128 x i8> @test_00(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_00: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v0,v0,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_01(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_01: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_02(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_02: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v1,v0,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_03(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_03: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r0 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: q0 = vsetq(r0) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = vmux(q0,v0,v1) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_04(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_04: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = valign(v0,v0,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_05(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_05: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v0,v0,r7) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = v1 ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_06(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_06: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = valign(v1,v0,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_07(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_07: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v1,v0,r7) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = v1 ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_08(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_08: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v0,v1,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_09(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_09: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r0 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: q0 = vsetq(r0) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = vmux(q0,v1,v0) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_10(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_10: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v1,v1,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_11(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_11: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: v0 = v1 ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_12(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_12: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = valign(v0,v1,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_13(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_13: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v0,v1,r7) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = v1 ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_14(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_14: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = valign(v1,v1,r7) ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } define <128 x i8> @test_15(<128 x i8> %a0, <128 x i8> %a1) #0 { ; CHECK-LABEL: test_15: ; CHECK: // %bb.0: ; CHECK-NEXT: { ; CHECK-NEXT: r7 = #64 ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v1:0 = vshuff(v1,v1,r7) ; CHECK-NEXT: } ; CHECK-NEXT: { ; CHECK-NEXT: v0 = v1 ; CHECK-NEXT: jumpr r31 ; CHECK-NEXT: } %v0 = shufflevector <128 x i8> %a0, <128 x i8> %a1, <128 x i32> ret <128 x i8> %v0 } attributes #0 = { nounwind readnone "target-features"="+hvx,+hvx-length128b" }