1
- #include " ../../slang/ prelude/slang-cpp-prelude.h"
1
+ #include " ../../prelude/slang-cpp-prelude.h"
2
2
3
3
4
- // namespace { // anonymous
5
-
6
4
#ifdef SLANG_PRELUDE_NAMESPACE
7
5
using namespace SLANG_PRELUDE_NAMESPACE ;
8
6
#endif
9
7
10
- Vector<uint32_t , 3 > operator + (Vector<uint32_t , 3 > a, Vector<uint32_t , 3 > b)
8
+ Vector<uint32_t , 3 > operator * (Vector<uint32_t , 3 > a, Vector<uint32_t , 3 > b)
11
9
{
12
10
Vector<uint32_t , 3 > r;
13
- r.x = a.x + b.x ;
14
- r.y = a.y + b.y ;
15
- r.z = a.z + b.z ;
11
+ r.x = a.x * b.x ;
12
+ r.y = a.y * b.y ;
13
+ r.z = a.z * b.z ;
16
14
return r;
17
15
}
18
16
19
- Vector<uint32_t , 3 > operator * (Vector<uint32_t , 3 > a, Vector<uint32_t , 3 > b)
17
+ Vector<uint32_t , 3 > operator + (Vector<uint32_t , 3 > a, Vector<uint32_t , 3 > b)
20
18
{
21
19
Vector<uint32_t , 3 > r;
22
- r.x = a.x * b.x ;
23
- r.y = a.y * b.y ;
24
- r.z = a.z * b.z ;
20
+ r.x = a.x + b.x ;
21
+ r.y = a.y + b.y ;
22
+ r.z = a.z + b.z ;
25
23
return r;
26
24
}
27
25
@@ -30,20 +28,31 @@ Vector<uint32_t, 3> make_VecU3(uint32_t a, uint32_t b, uint32_t c)
30
28
return Vector<uint32_t , 3 >{ a, b, c};
31
29
}
32
30
33
- size_t __computeMainSize = 652 ;
34
- unsigned char __computeMain[] = {68, 88, 66, 67, 85, 217, 21, 44, 5, 208, 4, 46, 7, 254, 139, 84, 132, 65, 108, 79, 1, 0, 0, 0, 140, 2, 0, 0, 5, 0, 0, 0, 52, 0, 0, 0, 248, 0, 0, 0, 8, 1, 0, 0, 24, 1, 0, 0, 16, 2, 0, 0, 82, 68, 69, 70, 188, 0, 0, 0, 1, 0, 0, 0, 72, 0, 0, 0, 1, 0, 0, 0, 28, 0, 0, 0, 0, 4, 83, 67, 0, 9, 16, 0, 148, 0, 0, 0, 60, 0, 0, 0, 6, 0, 0, 0, 6, 0, 0, 0, 1, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 105, 111, 66, 117, 102, 102, 101, 114, 95, 48, 0, 171, 60, 0, 0, 0, 1, 0, 0, 0, 96, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 120, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 2, 0, 0, 0, 132, 0, 0, 0, 0, 0, 0, 0, 36, 69, 108, 101, 109, 101, 110, 116, 0, 171, 171, 171, 0, 0, 3, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 77, 105, 99, 114, 111, 115, 111, 102, 116, 32, 40, 82, 41, 32, 72, 76, 83, 76, 32, 83, 104, 97, 100, 101, 114, 32, 67, 111, 109, 112, 105, 108, 101, 114, 32, 49, 48, 46, 49, 0, 73, 83, 71, 78, 8, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 79, 83, 71, 78, 8, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 83, 72, 69, 88, 240, 0, 0, 0, 64, 0, 5, 0, 60, 0, 0, 0, 106, 8, 0, 1, 158, 0, 0, 4, 0, 224, 17, 0, 0, 0, 0, 0, 4, 0, 0, 0, 95, 0, 0, 2, 18, 0, 2, 0, 104, 0, 0, 2, 1, 0, 0, 0, 155, 0, 0, 4, 4, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 167, 0, 0, 8, 18, 0, 16, 0, 0, 0, 0, 0, 10, 0, 2, 0, 1, 64, 0, 0, 0, 0, 0, 0, 6, 224, 17, 0, 0, 0, 0, 0, 49, 0, 0, 7, 34, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 1, 64, 0, 0, 0, 0, 0, 63, 0, 0, 0, 7, 66, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 75, 0, 0, 5, 18, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 55, 0, 0, 9, 18, 0, 16, 0, 0, 0, 0, 0, 26, 0, 16, 0, 0, 0, 0, 0, 42, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 168, 0, 0, 8, 18, 224, 17, 0, 0, 0, 0, 0, 10, 0, 2, 0, 1, 64, 0, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 62, 0, 0, 1, 83, 84, 65, 84, 116, 0, 0, 0, 7, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
31
+ size_t __computeMainSize = 668 ;
32
+ unsigned char __computeMain[] = {68, 88, 66, 67, 87, 111, 81, 164, 2, 29, 72, 42, 151, 28, 13, 217, 55, 37, 7, 95, 1, 0, 0, 0, 156, 2, 0, 0, 5, 0, 0, 0, 52, 0, 0, 0, 8, 1, 0, 0, 24, 1, 0, 0, 40, 1, 0, 0, 32, 2, 0, 0, 82, 68, 69, 70, 204, 0, 0, 0, 1, 0, 0, 0, 88, 0, 0, 0, 1, 0, 0, 0, 28, 0, 0, 0, 0, 4, 83, 67, 0, 9, 16, 0, 164, 0, 0, 0, 60, 0, 0, 0, 6, 0, 0, 0, 6, 0, 0, 0, 1, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 101, 110, 116, 114, 121, 80, 111, 105, 110, 116, 80, 97, 114, 97, 109, 115, 95, 105, 111, 66, 117, 102, 102, 101, 114, 95, 48, 0, 60, 0, 0, 0, 1, 0, 0, 0, 112, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 136, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 2, 0, 0, 0, 148, 0, 0, 0, 0, 0, 0, 0, 36, 69, 108, 101, 109, 101, 110, 116, 0, 171, 171, 171, 0, 0, 3, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 77, 105, 99, 114, 111, 115, 111, 102, 116, 32, 40, 82, 41, 32, 72, 76, 83, 76, 32, 83, 104, 97, 100, 101, 114, 32, 67, 111, 109, 112, 105, 108, 101, 114, 32, 49, 48, 46, 49, 0, 73, 83, 71, 78, 8, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 79, 83, 71, 78, 8, 0, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 83, 72, 69, 88, 240, 0, 0, 0, 64, 0, 5, 0, 60, 0, 0, 0, 106, 8, 0, 1, 158, 0, 0, 4, 0, 224, 17, 0, 0, 0, 0, 0, 4, 0, 0, 0, 95, 0, 0, 2, 18, 0, 2, 0, 104, 0, 0, 2, 1, 0, 0, 0, 155, 0, 0, 4, 4, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 167, 0, 0, 8, 18, 0, 16, 0, 0, 0, 0, 0, 10, 0, 2, 0, 1, 64, 0, 0, 0, 0, 0, 0, 6, 224, 17, 0, 0, 0, 0, 0, 49, 0, 0, 7, 34, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 1, 64, 0, 0, 0, 0, 0, 63, 0, 0, 0, 7, 66, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 75, 0, 0, 5, 18, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 55, 0, 0, 9, 18, 0, 16, 0, 0, 0, 0, 0, 26, 0, 16, 0, 0, 0, 0, 0, 42, 0, 16, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 168, 0, 0, 8, 18, 224, 17, 0, 0, 0, 0, 0, 10, 0, 2, 0, 1, 64, 0, 0, 0, 0, 0, 0, 10, 0, 16, 0, 0, 0, 0, 0, 62, 0, 0, 1, 83, 84, 65, 84, 116, 0, 0, 0, 7, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
33
+ void computeMain_wrapper (gfx_Renderer_0* renderer, Vector<uint32_t , 3 > gridDims,
34
+ RWStructuredBuffer<float > buffer)
35
+ {
36
+ gfx_ShaderProgram_0* shaderProgram = loadShaderProgram_0 (renderer, __computeMain, __computeMainSize);
37
+ gfx_DescriptorSetLayout_0* setLayout = buildDescriptorSetLayout_0 (renderer);
38
+ gfx_PipelineLayout_0* pipelineLayout = buildPipeline_0 (renderer, setLayout);
39
+ gfx_DescriptorSet_0* descriptorSet = buildDescriptorSet_0 (renderer, setLayout, unconvertBuffer_0 (buffer));
40
+ gfx_PipelineState_0* pipelineState = buildPipelineState_0 (shaderProgram, renderer, pipelineLayout);
41
+ dispatchComputation_0 (renderer, pipelineState, pipelineLayout, descriptorSet, gridDims.x , gridDims.y , gridDims.z );
42
+ }
35
43
36
- #line 11 " shader.slang"
37
- struct GlobalParams_0
44
+ #line 7 "../../examples/heterogeneous-hello-world/ shader.slang"
45
+ struct EntryPointParams_0
38
46
{
39
47
RWStructuredBuffer<float > ioBuffer_0;
40
48
};
41
49
42
50
struct KernelContext_0
43
51
{
44
- GlobalParams_0* globalParams_0;
45
52
};
46
53
54
+
55
+ #line 21
47
56
struct gfx_Window_0
48
57
{
49
58
};
@@ -61,46 +70,16 @@ struct gfx_BufferResource_0
61
70
};
62
71
63
72
64
- struct gfx_ShaderProgram_0
65
- {
66
- };
67
-
68
-
69
- #line 26
70
- struct gfx_DescriptorSetLayout_0
71
- {
72
- };
73
-
74
-
75
- #line 24
76
- struct gfx_PipelineLayout_0
77
- {
78
- };
79
-
80
-
81
- #line 27
82
- struct gfx_DescriptorSet_0
83
- {
84
- };
85
-
86
-
87
- #line 25
88
- struct gfx_PipelineState_0
89
- {
90
- };
91
-
92
-
93
73
#line 7
94
74
void _computeMain (void * _S1, void * entryPointParams_0, void * _S2)
95
75
{
96
76
ComputeThreadVaryingInput* _S3 = ((ComputeThreadVaryingInput*)(_S1));
97
77
KernelContext_0 kernelContext_0;
98
- *(&(&kernelContext_0)->globalParams_0 ) = ((GlobalParams_0*)(_S2));
99
78
100
79
#line 9
101
80
uint32_t tid_0 = (*(&_S3->groupID ) * make_VecU3 (4U , 1U , 1U ) + *(&_S3->groupThreadID )).x ;
102
81
103
- float * _S4 = &(*(&(*(&(&kernelContext_0)-> globalParams_0 ))->ioBuffer_0 ))[tid_0];
82
+ float * _S4 = &(*(&((EntryPointParams_0*)(entryPointParams_0 ))->ioBuffer_0 ))[tid_0];
104
83
105
84
#line 11
106
85
float i_0 = *_S4;
@@ -115,7 +94,7 @@ void _computeMain(void* _S1, void* entryPointParams_0, void* _S2)
115
94
#line 12
116
95
float o_0 = _S5 ? _S6 : _S7;
117
96
118
- float * _S8 = &(*(&(*(&(&kernelContext_0)-> globalParams_0 ))->ioBuffer_0 ))[tid_0];
97
+ float * _S8 = &(*(&((EntryPointParams_0*)(entryPointParams_0 ))->ioBuffer_0 ))[tid_0];
119
98
120
99
#line 14
121
100
*_S8 = o_0;
@@ -137,36 +116,15 @@ gfx_Renderer_0* createRenderer_0(int32_t _0, int32_t _1, gfx_Window_0* _2);
137
116
gfx_BufferResource_0* createStructuredBuffer_0 (gfx_Renderer_0* _0, FixedArray<float , 4 > _1);
138
117
139
118
140
- #line 33
141
- gfx_ShaderProgram_0* loadShaderProgram_0 (gfx_Renderer_0 * _0);
119
+ #line 4
120
+ RWStructuredBuffer< float > convertBuffer_0 (gfx_BufferResource_0 * _0);
142
121
143
122
144
123
#line 40
145
- gfx_DescriptorSetLayout_0* buildDescriptorSetLayout_0 (gfx_Renderer_0* _0);
146
-
147
-
148
- #line 41
149
- gfx_PipelineLayout_0* buildPipeline_0 (gfx_Renderer_0* _0, gfx_DescriptorSetLayout_0* _1);
150
-
151
-
152
- #line 42
153
- gfx_DescriptorSet_0* buildDescriptorSet_0 (gfx_Renderer_0* _0, gfx_DescriptorSetLayout_0* _1, gfx_BufferResource_0* _2);
154
-
155
-
156
-
157
- gfx_PipelineState_0* buildPipelineState_0 (gfx_ShaderProgram_0* _0, gfx_Renderer_0* _1, gfx_PipelineLayout_0* _2);
158
-
159
-
160
-
161
124
void printInitialValues_0 (FixedArray<float , 4 > _0, int32_t _1);
162
125
163
126
164
- #line 51
165
- void dispatchComputation_0 (gfx_Renderer_0* _0, gfx_PipelineState_0* _1, gfx_PipelineLayout_0* _2, gfx_DescriptorSet_0* _3);
166
-
167
-
168
-
169
-
127
+ #line 41
170
128
void print_output_0 (gfx_Renderer_0* _0, gfx_BufferResource_0* _1, int32_t _2);
171
129
172
130
@@ -183,21 +141,19 @@ bool executeComputation_0()
183
141
gfx_Window_0* _S9 = createWindow_0 (int (1024 ), int (768 ));
184
142
gfx_Renderer_0* _S10 = createRenderer_0 (int (1024 ), int (768 ), _S9);
185
143
gfx_BufferResource_0* _S11 = createStructuredBuffer_0 (_S10, initialArray_0);
186
- gfx_ShaderProgram_0* _S12 = loadShaderProgram_0 (_S10);
187
- gfx_DescriptorSetLayout_0* _S13 = buildDescriptorSetLayout_0 (_S10);
188
- gfx_PipelineLayout_0* _S14 = buildPipeline_0 (_S10, _S13);
189
- gfx_DescriptorSet_0* _S15 = buildDescriptorSet_0 (_S10, _S13, _S11);
190
- gfx_PipelineState_0* _S16 = buildPipelineState_0 (_S12, _S10, _S14);
144
+ Vector<uint32_t , 3 > _S12 = make_VecU3 (uint32_t (int (4 )), uint32_t (int (1 )), uint32_t (int (1 )));
145
+ RWStructuredBuffer<float > _S13 = convertBuffer_0 (_S11);
146
+
147
+ #line 57
148
+ computeMain_wrapper (_S10, _S12, _S13);
149
+
191
150
printInitialValues_0 (initialArray_0, int (4 ));
192
- dispatchComputation_0 (_S10, _S16, _S14, _S15);
193
151
print_output_0 (_S10, _S11, int (4 ));
194
152
195
153
196
154
return true ;
197
155
}
198
156
199
- // } // anonymous
200
-
201
157
// [numthreads(4, 1, 1)]
202
158
SLANG_PRELUDE_EXPORT
203
159
void computeMain_Thread (ComputeThreadVaryingInput* varyingInput, void * entryPointParams, void * globalParams)
0 commit comments