17b9bf80aSAlexey Bataev; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2 27b9bf80aSAlexey Bataev; RUN: opt -S --passes=slp-vectorizer -slp-threshold=-50 -mtriple=riscv64-unknown-linux-gnu -mattr=+v < %s| FileCheck %s 37b9bf80aSAlexey Bataev 47b9bf80aSAlexey Bataev%class.A = type { i32, i32 } 57b9bf80aSAlexey Bataev 67b9bf80aSAlexey Bataevdefine void @test() { 77b9bf80aSAlexey Bataev; CHECK-LABEL: define void @test 87b9bf80aSAlexey Bataev; CHECK-SAME: () #[[ATTR0:[0-9]+]] { 97b9bf80aSAlexey Bataev; CHECK-NEXT: entry: 10b10ecfa9SAlexey Bataev; CHECK-NEXT: [[SUB4_I_I65_US:%.*]] = or i64 0, 1 117b9bf80aSAlexey Bataev; CHECK-NEXT: br label [[BODY:%.*]] 127b9bf80aSAlexey Bataev; CHECK: body: 137b9bf80aSAlexey Bataev; CHECK-NEXT: [[ADD_I_I62_US:%.*]] = shl i64 0, 0 147b9bf80aSAlexey Bataev; CHECK-NEXT: [[TMP0:%.*]] = insertelement <2 x i64> <i64 poison, i64 1>, i64 [[ADD_I_I62_US]], i32 0 157b9bf80aSAlexey Bataev; CHECK-NEXT: [[TMP1:%.*]] = or <2 x i64> zeroinitializer, [[TMP0]] 167b9bf80aSAlexey Bataev; CHECK-NEXT: [[TMP2:%.*]] = getelementptr [[CLASS_A:%.*]], <2 x ptr> zeroinitializer, <2 x i64> [[TMP1]] 17*38fffa63SPaul Walker; CHECK-NEXT: [[TMP3:%.*]] = call <2 x i32> @llvm.masked.gather.v2i32.v2p0(<2 x ptr> [[TMP2]], i32 4, <2 x i1> splat (i1 true), <2 x i32> poison) 187b9bf80aSAlexey Bataev; CHECK-NEXT: [[TMP4:%.*]] = extractelement <2 x i32> [[TMP3]], i32 0 197b9bf80aSAlexey Bataev; CHECK-NEXT: [[TMP5:%.*]] = extractelement <2 x i32> [[TMP3]], i32 1 207b9bf80aSAlexey Bataev; CHECK-NEXT: [[CMP_I_I_I_I67_US:%.*]] = icmp slt i32 [[TMP4]], [[TMP5]] 21b10ecfa9SAlexey Bataev; CHECK-NEXT: [[SPEC_SELECT_I_I68_US:%.*]] = select i1 false, i64 [[SUB4_I_I65_US]], i64 0 227b9bf80aSAlexey Bataev; CHECK-NEXT: br label [[BODY]] 237b9bf80aSAlexey Bataev; 247b9bf80aSAlexey Bataeventry: 257b9bf80aSAlexey Bataev br label %body 267b9bf80aSAlexey Bataev 277b9bf80aSAlexey Bataevbody: 287b9bf80aSAlexey Bataev %add.i.i62.us = shl i64 0, 0 297b9bf80aSAlexey Bataev %mul.i.i63.us = or i64 %add.i.i62.us, 0 307b9bf80aSAlexey Bataev %add.ptr.i.i.i64.us = getelementptr %class.A, ptr null, i64 %mul.i.i63.us 317b9bf80aSAlexey Bataev %sub4.i.i65.us = or i64 0, 1 327b9bf80aSAlexey Bataev %add.ptr.i63.i.i66.us = getelementptr %class.A, ptr null, i64 %sub4.i.i65.us 337b9bf80aSAlexey Bataev %0 = load i32, ptr %add.ptr.i.i.i64.us, align 4 347b9bf80aSAlexey Bataev %1 = load i32, ptr %add.ptr.i63.i.i66.us, align 4 357b9bf80aSAlexey Bataev %cmp.i.i.i.i67.us = icmp slt i32 %0, %1 367b9bf80aSAlexey Bataev %spec.select.i.i68.us = select i1 false, i64 %sub4.i.i65.us, i64 0 377b9bf80aSAlexey Bataev br label %body 387b9bf80aSAlexey Bataev} 397b9bf80aSAlexey Bataev 40