166 lines
3.6 KiB
HLSL
166 lines
3.6 KiB
HLSL
|
SKIP: FAILED
|
||
|
|
||
|
struct QuicksortObject {
|
||
|
int numbers[10];
|
||
|
};
|
||
|
|
||
|
static QuicksortObject obj = (QuicksortObject)0;
|
||
|
static float4 x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
|
||
|
cbuffer cbuffer_x_30 : register(b0, space0) {
|
||
|
uint4 x_30[1];
|
||
|
};
|
||
|
|
||
|
void swap_i1_i1_(inout int i, inout int j) {
|
||
|
int temp = 0;
|
||
|
const int x_92 = i;
|
||
|
const int x_94 = obj.numbers[x_92];
|
||
|
temp = x_94;
|
||
|
const int x_95 = i;
|
||
|
const int x_96 = j;
|
||
|
const int x_98 = obj.numbers[x_96];
|
||
|
obj.numbers[x_95] = x_98;
|
||
|
const int x_100 = j;
|
||
|
obj.numbers[x_100] = temp;
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
int performPartition_i1_i1_(inout int l, inout int h) {
|
||
|
int pivot = 0;
|
||
|
int i_1 = 0;
|
||
|
int j_1 = 0;
|
||
|
int param = 0;
|
||
|
int param_1 = 0;
|
||
|
int param_2 = 0;
|
||
|
int param_3 = 0;
|
||
|
const int x_104 = h;
|
||
|
const int x_106 = obj.numbers[x_104];
|
||
|
pivot = x_106;
|
||
|
const int x_107 = l;
|
||
|
i_1 = (x_107 - 1);
|
||
|
const int x_109 = l;
|
||
|
j_1 = x_109;
|
||
|
[loop] while (true) {
|
||
|
const int x_114 = j_1;
|
||
|
const int x_115 = h;
|
||
|
if ((x_114 <= (x_115 - 1))) {
|
||
|
} else {
|
||
|
break;
|
||
|
}
|
||
|
const int x_121 = obj.numbers[j_1];
|
||
|
if ((x_121 <= pivot)) {
|
||
|
i_1 = (i_1 + 1);
|
||
|
param = i_1;
|
||
|
param_1 = j_1;
|
||
|
swap_i1_i1_(param, param_1);
|
||
|
}
|
||
|
{
|
||
|
j_1 = (j_1 + 1);
|
||
|
}
|
||
|
}
|
||
|
param_2 = (i_1 + 1);
|
||
|
const int x_135 = h;
|
||
|
param_3 = x_135;
|
||
|
swap_i1_i1_(param_2, param_3);
|
||
|
return (i_1 + 1);
|
||
|
}
|
||
|
|
||
|
void quicksort_() {
|
||
|
int l_1 = 0;
|
||
|
int h_1 = 0;
|
||
|
int top = 0;
|
||
|
int stack[10] = (int[10])0;
|
||
|
int p = 0;
|
||
|
int param_4 = 0;
|
||
|
int param_5 = 0;
|
||
|
l_1 = 0;
|
||
|
h_1 = 9;
|
||
|
top = -1;
|
||
|
const int x_141 = (top + 1);
|
||
|
top = x_141;
|
||
|
stack[x_141] = l_1;
|
||
|
const int x_145 = (top + 1);
|
||
|
top = x_145;
|
||
|
stack[x_145] = h_1;
|
||
|
[loop] while (true) {
|
||
|
if ((top >= 0)) {
|
||
|
} else {
|
||
|
break;
|
||
|
}
|
||
|
const int x_155 = top;
|
||
|
top = (x_155 - 1);
|
||
|
const int x_158 = stack[x_155];
|
||
|
h_1 = x_158;
|
||
|
const int x_159 = top;
|
||
|
top = (x_159 - 1);
|
||
|
const int x_162 = stack[x_159];
|
||
|
l_1 = x_162;
|
||
|
param_4 = l_1;
|
||
|
param_5 = h_1;
|
||
|
const int x_165 = performPartition_i1_i1_(param_4, param_5);
|
||
|
p = x_165;
|
||
|
if (((p - 1) > l_1)) {
|
||
|
const int x_173 = (top + 1);
|
||
|
top = x_173;
|
||
|
stack[x_173] = l_1;
|
||
|
const int x_177 = (top + 1);
|
||
|
top = x_177;
|
||
|
stack[x_177] = (p - 1);
|
||
|
}
|
||
|
if (((p + 1) < h_1)) {
|
||
|
const int x_188 = (top + 1);
|
||
|
top = x_188;
|
||
|
stack[x_188] = (p + 1);
|
||
|
const int x_193 = (top + 1);
|
||
|
top = x_193;
|
||
|
stack[x_193] = h_1;
|
||
|
}
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
void main_1() {
|
||
|
int i_2 = 0;
|
||
|
i_2 = 0;
|
||
|
{
|
||
|
[loop] for(; (i_2 < 10); i_2 = (i_2 + 1)) {
|
||
|
obj.numbers[i_2] = (10 - i_2);
|
||
|
const int x_71 = i_2;
|
||
|
const int x_74 = obj.numbers[i_2];
|
||
|
const int x_77 = obj.numbers[i_2];
|
||
|
obj.numbers[x_71] = (x_74 * x_77);
|
||
|
}
|
||
|
}
|
||
|
quicksort_();
|
||
|
const int x_84 = obj.numbers[0];
|
||
|
const int x_86 = obj.numbers[4];
|
||
|
if ((x_84 < x_86)) {
|
||
|
x_GLF_color = float4(1.0f, 0.0f, 0.0f, 1.0f);
|
||
|
} else {
|
||
|
x_GLF_color = float4(0.0f, 1.0f, 0.0f, 1.0f);
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
struct main_out {
|
||
|
float4 x_GLF_color_1;
|
||
|
};
|
||
|
struct tint_symbol {
|
||
|
float4 x_GLF_color_1 : SV_Target0;
|
||
|
};
|
||
|
|
||
|
main_out main_inner() {
|
||
|
main_1();
|
||
|
const main_out tint_symbol_1 = {x_GLF_color};
|
||
|
return tint_symbol_1;
|
||
|
}
|
||
|
|
||
|
tint_symbol main() {
|
||
|
const main_out inner_result = main_inner();
|
||
|
tint_symbol wrapper_result = (tint_symbol)0;
|
||
|
wrapper_result.x_GLF_color_1 = inner_result.x_GLF_color_1;
|
||
|
return wrapper_result;
|
||
|
}
|
||
|
C:\src\tint\test\Shader@0x000001BEDA24CD50(124,7-22): warning X3550: array reference cannot be used as an l-value; not natively addressable, forcing loop to unroll
|
||
|
C:\src\tint\test\Shader@0x000001BEDA24CD50(123,12-45): error X3531: can't unroll loops marked with loop attribute
|
||
|
|