Update OpArrayLengthTests to use WGSL
Bug: dawn:572 Change-Id: Iba92adda4758fc91294f7c6d8b0be3065c786f71 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/33773 Commit-Queue: Austin Eng <enga@chromium.org> Reviewed-by: Corentin Wallez <cwallez@chromium.org>
This commit is contained in:
parent
04e3078a64
commit
33bf309c1d
|
@ -56,23 +56,33 @@ class OpArrayLengthTest : public DawnTest {
|
||||||
// Common shader code to use these buffers in shaders, assuming they are in bindgroup index
|
// Common shader code to use these buffers in shaders, assuming they are in bindgroup index
|
||||||
// 0.
|
// 0.
|
||||||
mShaderInterface = R"(
|
mShaderInterface = R"(
|
||||||
// The length should be 1 because the buffer is 4-byte long.
|
# TODO(crbug.com/tint/386): Use the same struct.
|
||||||
layout(std430, set = 0, binding = 0) readonly buffer Buffer1 {
|
[[block]] struct DataBuffer1 {
|
||||||
float data[];
|
[[offset(0)]] data : [[stride(4)]] array<f32>;
|
||||||
} buffer1;
|
};
|
||||||
|
|
||||||
// The length should be 64 because the buffer is 256 bytes long.
|
[[block]] struct DataBuffer2 {
|
||||||
layout(std430, set = 0, binding = 1) readonly buffer Buffer2 {
|
[[offset(0)]] data : [[stride(4)]] array<f32>;
|
||||||
float data[];
|
};
|
||||||
} buffer2;
|
|
||||||
|
|
||||||
// The length should be (512 - 16*4) / 8 = 56 because the buffer is 512 bytes long
|
# The length should be 1 because the buffer is 4-byte long.
|
||||||
// and the structure is 8 bytes big.
|
[[set(0), binding(0)]] var<storage_buffer> buffer1 : [[access(read)]] DataBuffer1;
|
||||||
struct Buffer3Data {float a; int b;};
|
|
||||||
layout(std430, set = 0, binding = 2) readonly buffer Buffer3 {
|
# The length should be 64 because the buffer is 256 bytes long.
|
||||||
mat4 garbage;
|
[[set(0), binding(1)]] var<storage_buffer> buffer2 : [[access(read)]] DataBuffer2;
|
||||||
Buffer3Data data[];
|
|
||||||
} buffer3;
|
# The length should be (512 - 16*4) / 8 = 56 because the buffer is 512 bytes long
|
||||||
|
# and the structure is 8 bytes big.
|
||||||
|
struct Buffer3Data {
|
||||||
|
[[offset(0)]] a : f32;
|
||||||
|
[[offset(4)]] b : i32;
|
||||||
|
};
|
||||||
|
|
||||||
|
[[block]] struct Buffer3 {
|
||||||
|
[[offset(0)]] garbage : mat4x4<f32>;
|
||||||
|
[[offset(64)]] data : [[stride(8)]] array<Buffer3Data>;
|
||||||
|
};
|
||||||
|
[[set(0), binding(2)]] var<storage_buffer> buffer3 : [[access(read)]] Buffer3;
|
||||||
)";
|
)";
|
||||||
|
|
||||||
// See comments in the shader for an explanation of these values
|
// See comments in the shader for an explanation of these values
|
||||||
|
@ -118,17 +128,16 @@ TEST_P(OpArrayLengthTest, Compute) {
|
||||||
wgpu::ComputePipelineDescriptor pipelineDesc;
|
wgpu::ComputePipelineDescriptor pipelineDesc;
|
||||||
pipelineDesc.layout = pl;
|
pipelineDesc.layout = pl;
|
||||||
pipelineDesc.computeStage.entryPoint = "main";
|
pipelineDesc.computeStage.entryPoint = "main";
|
||||||
pipelineDesc.computeStage.module =
|
pipelineDesc.computeStage.module = utils::CreateShaderModuleFromWGSL(device, (R"(
|
||||||
utils::CreateShaderModule(device, utils::SingleShaderStage::Compute,
|
[[block]] struct ResultBuffer {
|
||||||
(R"(#version 450
|
[[offset(0)]] data : [[stride(4)]] array<u32, 3>;
|
||||||
layout(std430, set = 1, binding = 0) buffer ResultBuffer {
|
|
||||||
uint result[3];
|
|
||||||
};
|
};
|
||||||
|
[[set(1), binding(0)]] var<storage_buffer> result : [[access(read_write)]] ResultBuffer;
|
||||||
)" + mShaderInterface + R"(
|
)" + mShaderInterface + R"(
|
||||||
void main() {
|
[[stage(compute)]] fn main() -> void {
|
||||||
result[0] = buffer1.data.length();
|
result.data[0] = arrayLength(buffer1.data);
|
||||||
result[1] = buffer2.data.length();
|
result.data[1] = arrayLength(buffer2.data);
|
||||||
result[2] = buffer3.data.length();
|
result.data[2] = arrayLength(buffer3.data);
|
||||||
})")
|
})")
|
||||||
.c_str());
|
.c_str());
|
||||||
wgpu::ComputePipeline pipeline = device.CreateComputePipeline(&pipelineDesc);
|
wgpu::ComputePipeline pipeline = device.CreateComputePipeline(&pipelineDesc);
|
||||||
|
@ -159,25 +168,19 @@ TEST_P(OpArrayLengthTest, Fragment) {
|
||||||
|
|
||||||
// Create the pipeline that computes the length of the buffers and writes it to the only render
|
// Create the pipeline that computes the length of the buffers and writes it to the only render
|
||||||
// pass pixel.
|
// pass pixel.
|
||||||
wgpu::ShaderModule vsModule =
|
wgpu::ShaderModule vsModule = utils::CreateShaderModuleFromWGSL(device, R"(
|
||||||
utils::CreateShaderModule(device, utils::SingleShaderStage::Vertex, R"(
|
[[builtin(position)]] var<out> Position : vec4<f32>;
|
||||||
#version 450
|
[[stage(vertex)]] fn main() -> void {
|
||||||
void main() {
|
Position = vec4<f32>(0.0, 0.0, 0.0, 1.0);
|
||||||
gl_Position = vec4(0.0f, 0.0f, 0.0f, 1.0f);
|
|
||||||
gl_PointSize = 1.0;
|
|
||||||
})");
|
})");
|
||||||
|
|
||||||
wgpu::ShaderModule fsModule =
|
wgpu::ShaderModule fsModule = utils::CreateShaderModuleFromWGSL(device, (mShaderInterface + R"(
|
||||||
utils::CreateShaderModule(device, utils::SingleShaderStage::Fragment,
|
[[location(0)]] var<out> fragColor : vec4<f32>;
|
||||||
(R"(
|
[[stage(fragment)]] fn main() -> void {
|
||||||
#version 450
|
fragColor.r = f32(arrayLength(buffer1.data)) / 255.0;
|
||||||
)" + mShaderInterface + R"(
|
fragColor.g = f32(arrayLength(buffer2.data)) / 255.0;
|
||||||
layout(location = 0) out vec4 fragColor;
|
fragColor.b = f32(arrayLength(buffer3.data)) / 255.0;
|
||||||
void main() {
|
fragColor.a = 0.0;
|
||||||
fragColor.r = buffer1.data.length() / 255.0f;
|
|
||||||
fragColor.g = buffer2.data.length() / 255.0f;
|
|
||||||
fragColor.b = buffer3.data.length() / 255.0f;
|
|
||||||
fragColor.a = 0.0f;
|
|
||||||
})")
|
})")
|
||||||
.c_str());
|
.c_str());
|
||||||
|
|
||||||
|
@ -217,29 +220,23 @@ TEST_P(OpArrayLengthTest, Vertex) {
|
||||||
|
|
||||||
// Create the pipeline that computes the length of the buffers and writes it to the only render
|
// Create the pipeline that computes the length of the buffers and writes it to the only render
|
||||||
// pass pixel.
|
// pass pixel.
|
||||||
wgpu::ShaderModule vsModule =
|
wgpu::ShaderModule vsModule = utils::CreateShaderModuleFromWGSL(device, (mShaderInterface + R"(
|
||||||
utils::CreateShaderModule(device, utils::SingleShaderStage::Vertex,
|
[[location(0)]] var<out> pointColor : vec4<f32>;
|
||||||
(R"(
|
[[builtin(position)]] var<out> Position : vec4<f32>;
|
||||||
#version 450
|
[[stage(vertex)]] fn main() -> void {
|
||||||
)" + mShaderInterface + R"(
|
pointColor.r = f32(arrayLength(buffer1.data)) / 255.0;
|
||||||
layout(location = 0) out vec4 pointColor;
|
pointColor.g = f32(arrayLength(buffer2.data)) / 255.0;
|
||||||
void main() {
|
pointColor.b = f32(arrayLength(buffer3.data)) / 255.0;
|
||||||
pointColor.r = buffer1.data.length() / 255.0f;
|
pointColor.a = 0.0;
|
||||||
pointColor.g = buffer2.data.length() / 255.0f;
|
|
||||||
pointColor.b = buffer3.data.length() / 255.0f;
|
|
||||||
pointColor.a = 0.0f;
|
|
||||||
|
|
||||||
gl_Position = vec4(0.0f, 0.0f, 0.0f, 1.0f);
|
Position = vec4<f32>(0.0, 0.0, 0.0, 1.0);
|
||||||
gl_PointSize = 1.0;
|
|
||||||
})")
|
})")
|
||||||
.c_str());
|
.c_str());
|
||||||
|
|
||||||
wgpu::ShaderModule fsModule =
|
wgpu::ShaderModule fsModule = utils::CreateShaderModuleFromWGSL(device, R"(
|
||||||
utils::CreateShaderModule(device, utils::SingleShaderStage::Fragment, R"(
|
[[location(0)]] var<out> fragColor : vec4<f32>;
|
||||||
#version 450
|
[[location(0)]] var<in> pointColor : vec4<f32>;
|
||||||
layout(location = 0) out vec4 fragColor;
|
[[stage(fragment)]] fn main() -> void {
|
||||||
layout(location = 0) in vec4 pointColor;
|
|
||||||
void main() {
|
|
||||||
fragColor = pointColor;
|
fragColor = pointColor;
|
||||||
})");
|
})");
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue