GLSL: Fix Khronos private Bugzilla 15973: local sizes can't be 0.
diff --git a/Test/310.comp b/Test/310.comp
index 9575b6f..9ca8eaa 100644
--- a/Test/310.comp
+++ b/Test/310.comp
@@ -4,7 +4,7 @@
layout(local_size_x = 16) in; // ERROR, changing
layout(local_size_z = 4096) in; // ERROR, too large
layout(local_size_x = 2) in;
-
+layout(local_size_y = 0) in; // ERROR, 0 not allowed
const int total = gl_MaxComputeWorkGroupCount.y
+ gl_MaxComputeUniformComponents
+ gl_MaxComputeTextureImageUnits
diff --git a/Test/450.comp b/Test/450.comp
index 7f723ec..b6d974e 100644
--- a/Test/450.comp
+++ b/Test/450.comp
@@ -1 +1,2 @@
#version 450 core
+layout(local_size_x = 0) in; // ERROR, 0 not allowed
\ No newline at end of file
diff --git a/Test/baseResults/310.comp.out b/Test/baseResults/310.comp.out
index e97571a..85bb3d7 100644
--- a/Test/baseResults/310.comp.out
+++ b/Test/baseResults/310.comp.out
@@ -1,6 +1,7 @@
310.comp
ERROR: 0:4: 'local_size' : cannot change previously set size
ERROR: 0:5: 'local_size' : too large; see gl_MaxComputeWorkGroupSize
+ERROR: 0:7: 'local_size_y' : must be at least 1
ERROR: 0:23: '' : array size required
ERROR: 0:39: 'in' : global storage input qualifier cannot be used in a compute shader
ERROR: 0:39: 'location qualifier on input' : not supported in this stage: compute
@@ -83,7 +84,7 @@
ERROR: 0:244: 'gl_DeviceIndex' : required extension not requested: GL_EXT_device_group
ERROR: 0:245: 'gl_ViewIndex' : undeclared identifier
ERROR: 0:255: 'gl_ViewIndex' : undeclared identifier
-ERROR: 82 compilation errors. No code generated.
+ERROR: 83 compilation errors. No code generated.
Shader version: 310
diff --git a/Test/baseResults/450.comp.out b/Test/baseResults/450.comp.out
index 4d3ff7d..0e4ab32 100644
--- a/Test/baseResults/450.comp.out
+++ b/Test/baseResults/450.comp.out
@@ -1,7 +1,11 @@
450.comp
+ERROR: 0:2: 'local_size_x' : must be at least 1
+ERROR: 1 compilation errors. No code generated.
+
+
Shader version: 450
local_size = (1, 1, 1)
-0:? Sequence
+ERROR: node is still EOpNull!
0:? Linker Objects
@@ -11,6 +15,6 @@
Shader version: 450
local_size = (1, 1, 1)
-0:? Sequence
+ERROR: node is still EOpNull!
0:? Linker Objects
diff --git a/glslang/MachineIndependent/ParseHelper.cpp b/glslang/MachineIndependent/ParseHelper.cpp
index 0208224..4aa6f4e 100644
--- a/glslang/MachineIndependent/ParseHelper.cpp
+++ b/glslang/MachineIndependent/ParseHelper.cpp
@@ -4260,6 +4260,10 @@
if (id.compare(0, 11, "local_size_") == 0) {
profileRequires(loc, EEsProfile, 310, 0, "gl_WorkGroupSize");
profileRequires(loc, ~EEsProfile, 430, E_GL_ARB_compute_shader, "gl_WorkGroupSize");
+ if (id.size() == 12 && value == 0) {
+ error(loc, "must be at least 1", id.c_str(), "");
+ return;
+ }
if (id == "local_size_x") {
publicType.shaderQualifiers.localSize[0] = value;
return;