xref: /llvm-project/llvm/test/CodeGen/DirectX/splitdouble.ll (revision 011b618644113996e2c0a8e57db40f89d20878e3)
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