1481bce01Sjoaosaffran; RUN: opt -passes='function(scalarizer)' -S -mtriple=dxil-pc-shadermodel6.3-library %s | FileCheck %s --check-prefixes=CHECK,NOLOWER 2481bce01Sjoaosaffran; RUN: opt -passes='function(scalarizer),module(dxil-op-lower)' -S -mtriple=dxil-pc-shadermodel6.3-library %s | FileCheck %s --check-prefixes=CHECK,WITHLOWER 3481bce01Sjoaosaffran 4481bce01Sjoaosaffrandefine i32 @test_scalar(double noundef %D) { 5481bce01Sjoaosaffran; CHECK-LABEL: define i32 @test_scalar( 6481bce01Sjoaosaffran; CHECK-SAME: double noundef [[D:%.*]]) { 7481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D]]) 8*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D]]) #[[#ATTR:]] 9481bce01Sjoaosaffran; NOLOWER-NEXT: [[EV1:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I0]], 0 10481bce01Sjoaosaffran; NOLOWER-NEXT: [[EV2:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I0]], 1 11481bce01Sjoaosaffran; WITHLOWER-NEXT: [[EV1:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I0]], 0 12481bce01Sjoaosaffran; WITHLOWER-NEXT: [[EV2:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I0]], 1 13481bce01Sjoaosaffran; CHECK-NEXT: [[ADD:%.*]] = add i32 [[EV1]], [[EV2]] 14481bce01Sjoaosaffran; CHECK-NEXT: ret i32 [[ADD]] 15481bce01Sjoaosaffran; 16481bce01Sjoaosaffran %hlsl.splitdouble = call { i32, i32 } @llvm.dx.splitdouble.i32(double %D) 17481bce01Sjoaosaffran %1 = extractvalue { i32, i32 } %hlsl.splitdouble, 0 18481bce01Sjoaosaffran %2 = extractvalue { i32, i32 } %hlsl.splitdouble, 1 19481bce01Sjoaosaffran %add = add i32 %1, %2 20481bce01Sjoaosaffran ret i32 %add 21481bce01Sjoaosaffran} 22481bce01Sjoaosaffran 23481bce01Sjoaosaffran 24481bce01Sjoaosaffrandefine void @test_vector_double_split_void(<2 x double> noundef %d) { 25481bce01Sjoaosaffran; CHECK-LABEL: define void @test_vector_double_split_void( 26481bce01Sjoaosaffran; CHECK-SAME: <2 x double> noundef [[D:%.*]]) { 27481bce01Sjoaosaffran; CHECK-NEXT: [[D_I0:%.*]] = extractelement <2 x double> [[D]], i64 0 28481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D_I0]]) 29*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D_I0]]) #[[#ATTR]] 30481bce01Sjoaosaffran; CHECK-NEXT: [[D_I1:%.*]] = extractelement <2 x double> [[D]], i64 1 31481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I1:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D_I1]]) 32*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I1:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D_I1]]) #[[#ATTR]] 33481bce01Sjoaosaffran; CHECK-NEXT: ret void 34481bce01Sjoaosaffran; 35481bce01Sjoaosaffran %hlsl.asuint = call { <2 x i32>, <2 x i32> } @llvm.dx.splitdouble.v2i32(<2 x double> %d) 36481bce01Sjoaosaffran ret void 37481bce01Sjoaosaffran} 38481bce01Sjoaosaffran 39481bce01Sjoaosaffrandefine noundef <3 x i32> @test_vector_double_split(<3 x double> noundef %d) { 40481bce01Sjoaosaffran; CHECK-LABEL: define noundef <3 x i32> @test_vector_double_split( 41481bce01Sjoaosaffran; CHECK-SAME: <3 x double> noundef [[D:%.*]]) { 42481bce01Sjoaosaffran; CHECK-NEXT: [[D_I0:%.*]] = extractelement <3 x double> [[D]], i64 0 43481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D_I0]]) 44*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I0:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D_I0]]) #[[#ATTR]] 45481bce01Sjoaosaffran; CHECK-NEXT: [[D_I1:%.*]] = extractelement <3 x double> [[D]], i64 1 46481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I1:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D_I1]]) 47*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I1:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D_I1]]) #[[#ATTR]] 48481bce01Sjoaosaffran; CHECK-NEXT: [[D_I2:%.*]] = extractelement <3 x double> [[D]], i64 2 49481bce01Sjoaosaffran; NOLOWER-NEXT: [[HLSL_ASUINT_I2:%.*]] = call { i32, i32 } @llvm.dx.splitdouble.i32(double [[D_I2]]) 50*011b6186SFinn Plummer; WITHLOWER-NEXT: [[HLSL_ASUINT_I2:%.*]] = call %dx.types.splitdouble @dx.op.splitDouble.f64(i32 102, double [[D_I2]]) #[[#ATTR]] 51481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM0:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I0]], 0 52481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM0:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I0]], 0 53481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM01:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I1]], 0 54481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM01:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I1]], 0 55481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM02:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I2]], 0 56481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM02:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I2]], 0 57481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM1:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I0]], 1 58481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM1:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I0]], 1 59481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM13:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I1]], 1 60481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM13:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I1]], 1 61481bce01Sjoaosaffran; NOLOWER-NEXT: [[DOTELEM14:%.*]] = extractvalue { i32, i32 } [[HLSL_ASUINT_I2]], 1 62481bce01Sjoaosaffran; WITHLOWER-NEXT: [[DOTELEM14:%.*]] = extractvalue %dx.types.splitdouble [[HLSL_ASUINT_I2]], 1 63481bce01Sjoaosaffran; CHECK-NEXT: [[DOTI0:%.*]] = add i32 [[DOTELEM0]], [[DOTELEM1]] 64481bce01Sjoaosaffran; CHECK-NEXT: [[DOTI1:%.*]] = add i32 [[DOTELEM01]], [[DOTELEM13]] 65481bce01Sjoaosaffran; CHECK-NEXT: [[DOTI2:%.*]] = add i32 [[DOTELEM02]], [[DOTELEM14]] 66481bce01Sjoaosaffran; CHECK-NEXT: [[DOTUPTO015:%.*]] = insertelement <3 x i32> poison, i32 [[DOTI0]], i64 0 67481bce01Sjoaosaffran; CHECK-NEXT: [[DOTUPTO116:%.*]] = insertelement <3 x i32> [[DOTUPTO015]], i32 [[DOTI1]], i64 1 68481bce01Sjoaosaffran; CHECK-NEXT: [[TMP1:%.*]] = insertelement <3 x i32> [[DOTUPTO116]], i32 [[DOTI2]], i64 2 69481bce01Sjoaosaffran; CHECK-NEXT: ret <3 x i32> [[TMP1]] 70481bce01Sjoaosaffran; 71481bce01Sjoaosaffran %hlsl.asuint = call { <3 x i32>, <3 x i32> } @llvm.dx.splitdouble.v3i32(<3 x double> %d) 72481bce01Sjoaosaffran %1 = extractvalue { <3 x i32>, <3 x i32> } %hlsl.asuint, 0 73481bce01Sjoaosaffran %2 = extractvalue { <3 x i32>, <3 x i32> } %hlsl.asuint, 1 74481bce01Sjoaosaffran %3 = add <3 x i32> %1, %2 75481bce01Sjoaosaffran ret <3 x i32> %3 76481bce01Sjoaosaffran} 77*011b6186SFinn Plummer 78*011b6186SFinn Plummer; WITHLOWER: attributes #[[#ATTR]] = {{{.*}} memory(none) {{.*}}} 79