; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 ; RUN: opt < %s -mtriple=riscv64 -mattr=+v -p interleaved-access -S | FileCheck %s ; Ensure we don't crash with non-zero address spaces. define void @load_factor2(ptr addrspace(1) %ptr) { ; CHECK-LABEL: define void @load_factor2( ; CHECK-SAME: ptr addrspace(1) [[PTR:%.*]]) #[[ATTR0:[0-9]+]] { ; CHECK-NEXT: [[TMP1:%.*]] = call { <8 x i32>, <8 x i32> } @llvm.riscv.seg2.load.mask.v8i32.p1.i64(ptr addrspace(1) [[PTR]], <8 x i1> splat (i1 true), i64 8) ; CHECK-NEXT: [[TMP2:%.*]] = extractvalue { <8 x i32>, <8 x i32> } [[TMP1]], 1 ; CHECK-NEXT: [[TMP3:%.*]] = extractvalue { <8 x i32>, <8 x i32> } [[TMP1]], 0 ; CHECK-NEXT: ret void ; %interleaved.vec = load <16 x i32>, ptr addrspace(1) %ptr %v0 = shufflevector <16 x i32> %interleaved.vec, <16 x i32> poison, <8 x i32> %v1 = shufflevector <16 x i32> %interleaved.vec, <16 x i32> poison, <8 x i32> ret void } define void @load_factor2_vscale(ptr addrspace(1) %ptr) { ; CHECK-LABEL: define void @load_factor2_vscale( ; CHECK-SAME: ptr addrspace(1) [[PTR:%.*]]) #[[ATTR0]] { ; CHECK-NEXT: [[TMP1:%.*]] = call target("riscv.vector.tuple", , 2) @llvm.riscv.vlseg2.mask.triscv.vector.tuple_nxv32i8_2t.p1.nxv8i1.i64(target("riscv.vector.tuple", , 2) poison, ptr addrspace(1) [[PTR]], splat (i1 true), i64 -1, i64 3, i64 5) ; CHECK-NEXT: [[TMP2:%.*]] = call @llvm.riscv.tuple.extract.nxv8i32.triscv.vector.tuple_nxv32i8_2t(target("riscv.vector.tuple", , 2) [[TMP1]], i32 0) ; CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 ; CHECK-NEXT: [[TMP4:%.*]] = call @llvm.riscv.tuple.extract.nxv8i32.triscv.vector.tuple_nxv32i8_2t(target("riscv.vector.tuple", , 2) [[TMP1]], i32 1) ; CHECK-NEXT: [[V:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 ; CHECK-NEXT: [[T0:%.*]] = extractvalue { , } [[V]], 0 ; CHECK-NEXT: [[T1:%.*]] = extractvalue { , } [[V]], 1 ; CHECK-NEXT: ret void ; %interleaved.vec = load , ptr addrspace(1) %ptr %v = call { , } @llvm.vector.deinterleave2.nxv16i32( %interleaved.vec) %t0 = extractvalue { , } %v, 0 %t1 = extractvalue { , } %v, 1 ret void }