1 group if "If Statements" 2 3 case single_statement 4 values 5 { 6 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 7 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 8 } 9 10 both "" 11 precision mediump float; 12 ${DECLARATIONS} 13 void main() 14 { 15 out0 = 0.0; 16 if (in0 >= 1.0) 17 out0 = 1.0; 18 ${OUTPUT} 19 } 20 "" 21 end 22 23 case compound_statement 24 values 25 { 26 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 27 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 28 output float out1 = [ 1.0 | 0.0 | 0.0 ]; 29 } 30 31 both "" 32 precision mediump float; 33 ${DECLARATIONS} 34 void main() 35 { 36 out0 = 0.0; 37 out1 = 1.0; 38 if (in0 >= 1.0) 39 { 40 out0 = 1.0; 41 out1 = 0.0; 42 } 43 ${OUTPUT} 44 } 45 "" 46 end 47 48 case sequence_statements 49 values 50 { 51 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 52 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 53 output float out1 = [ 1.0 | 0.0 | 0.0 ]; 54 } 55 56 both "" 57 precision mediump float; 58 ${DECLARATIONS} 59 void main() 60 { 61 out0 = 0.0; 62 out1 = 1.0; 63 if (in0 >= 1.0) 64 out0 = 1.0, out1 = 0.0; 65 ${OUTPUT} 66 } 67 "" 68 end 69 70 case sequence_condition 71 values 72 { 73 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 74 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 75 output float out1 = [ 1.0 | 0.0 | 0.0 ]; 76 } 77 78 both "" 79 precision mediump float; 80 ${DECLARATIONS} 81 void main() 82 { 83 out0 = 0.0; 84 out1 = 1.0; 85 if (false, in0 >= 1.0) 86 out0 = 1.0, out1 = 0.0; 87 ${OUTPUT} 88 } 89 "" 90 end 91 92 case complex_condition 93 values 94 { 95 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 96 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 97 output float out1 = [ 1.0 | 0.0 | 0.0 ]; 98 } 99 100 both "" 101 precision mediump float; 102 ${DECLARATIONS} 103 void main() 104 { 105 out0 = 0.0; 106 out1 = 1.0; 107 if (false || (in0 >= 1.0) && (in0 - 2.0*in0 < 0.0)) 108 out0 = 1.0, out1 = 0.0; 109 ${OUTPUT} 110 } 111 "" 112 end 113 114 case if_else 115 values 116 { 117 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 118 output float out0 = [ 0.0 | 1.0 | 1.0 ]; 119 } 120 121 both "" 122 precision mediump float; 123 ${DECLARATIONS} 124 void main() 125 { 126 if (in0 >= 1.0) 127 out0 = 1.0; 128 else 129 out0 = 0.0; 130 ${OUTPUT} 131 } 132 "" 133 end 134 135 case if_elseif 136 values 137 { 138 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 139 output float out0 = [ 0.0 | 1.0 | 2.0 ]; 140 } 141 142 both "" 143 precision mediump float; 144 ${DECLARATIONS} 145 void main() 146 { 147 out0 = 0.0; 148 if (in0 >= 2.0) 149 out0 = 2.0; 150 else if (in0 >= 1.0) 151 out0 = 1.0; 152 ${OUTPUT} 153 } 154 "" 155 end 156 157 case if_elseif_else 158 values 159 { 160 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 161 output float out0 = [ 0.0 | 1.0 | 2.0 ]; 162 } 163 164 both "" 165 precision mediump float; 166 ${DECLARATIONS} 167 void main() 168 { 169 if (in0 >= 2.0) 170 out0 = 2.0; 171 else if (in0 >= 1.0) 172 out0 = 1.0; 173 else 174 out0 = 0.0; 175 ${OUTPUT} 176 } 177 "" 178 end 179 180 case mixed_if_elseif_else 181 values 182 { 183 input float in0 = [ 0.0 | 1.0 | 2.0 ]; 184 output float out0 = [ 0.0 | 1.0 | 2.0 ]; 185 } 186 187 both "" 188 precision mediump float; 189 ${DECLARATIONS} 190 void main() 191 { 192 if (in0 >= 2.0) 193 { 194 out0 = 2.0; 195 } 196 else if (in0 >= 1.0) 197 out0 = 2.0, out0 = 1.0; 198 else 199 out0 = 0.0; 200 ${OUTPUT} 201 } 202 "" 203 end 204 205 case constant_conditional_assignment_to_matrix 206 vertex "" 207 // This variant doesn't provoke the crash seen in the versions below. 208 ${VERTEX_DECLARATIONS} 209 varying mediump float FragVarying; 210 const float in0 = 0.0; 211 void main() 212 { 213 mat2 projectionMatrix = mat2(0.0, 0.0, 0.0, 0.0); 214 if (in0 == 1.0) 215 { 216 projectionMatrix[0][0] = 1.0; 217 } 218 219 FragVarying = 1.0; 220 gl_Position = dEQP_Position + vec4(projectionMatrix[1][0], 0.0, 0.0, 0.0); 221 } 222 "" 223 fragment "" 224 precision mediump float; 225 varying float FragVarying; 226 void main() 227 { 228 gl_FragColor = vec4(FragVarying, 1.0, 1.0, 1.0); 229 } 230 "" 231 end 232 233 case input_conditional_assignment_to_matrix 234 values 235 { 236 input float in0 = [ 0.0 ]; 237 } 238 vertex "" 239 ${VERTEX_DECLARATIONS} 240 varying mediump float FragVarying; // Necessary to reproduce. 241 void main() 242 { 243 // Crashes with mat4 as well. Does not crash with vectors. 244 mat2 projectionMatrix = mat2(0.0, 0.0, 0.0, 0.0); 245 // Testing a non-constant variable is necessary. 246 if (in0 == 1.0) 247 { 248 // Using the matrix variable appears necessary. 249 projectionMatrix[0][0] = 1.0; 250 } 251 252 FragVarying = 1.0; 253 // Referencing the matrix is necessary though clearly the compiler 254 // doesn't realize the assignment is useless. 255 gl_Position = dEQP_Position + vec4(projectionMatrix[1][0], 0.0, 0.0, 0.0); 256 } 257 "" 258 fragment "" 259 precision mediump float; 260 varying float FragVarying; 261 void main() 262 { 263 gl_FragColor = vec4(FragVarying, 1.0, 1.0, 1.0); 264 } 265 "" 266 end 267 268 case uniform_conditional_assignment_to_matrix 269 values 270 { 271 uniform float uni0 = [ 0.0 ]; 272 } 273 vertex "" 274 ${VERTEX_DECLARATIONS} 275 varying mediump float FragVarying; // Necessary to reproduce. 276 void main() 277 { 278 // Crashes with mat4 as well. Does not crash with vectors. 279 mat2 projectionMatrix = mat2(0.0, 0.0, 0.0, 0.0); 280 // Testing a non-constant variable is necessary. 281 if (uni0 == 1.0) 282 { 283 // Using the matrix variable appears necessary. 284 projectionMatrix[0][0] = 1.0; 285 } 286 287 FragVarying = 1.0; 288 // Referencing the matrix is necessary though clearly the compiler 289 // doesn't realize the assignment is useless. 290 gl_Position = dEQP_Position + vec4(projectionMatrix[1][0], 0.0, 0.0, 0.0); 291 } 292 "" 293 fragment "" 294 precision mediump float; 295 varying float FragVarying; 296 void main() 297 { 298 gl_FragColor = vec4(FragVarying, 1.0, 1.0, 1.0); 299 } 300 "" 301 end 302 303 end # if 304 305 group invalid_if "Invalid If Conditionals" 306 307 case missing_parenthesis 308 expect compile_fail 309 both "" 310 precision mediump float; 311 void main() 312 { 313 if true 314 ${POSITION_FRAG_COLOR} = vec4(1.0); 315 } 316 "" 317 end 318 319 case unclosed_parenthesis 320 expect compile_fail 321 both "" 322 precision mediump float; 323 void main() 324 { 325 if (true 326 ${POSITION_FRAG_COLOR} = vec4(1.0); 327 } 328 "" 329 end 330 331 case int_condition 332 expect compile_fail 333 both "" 334 precision mediump float; 335 void main() 336 { 337 if (5) 338 ${POSITION_FRAG_COLOR} = vec4(1.0); 339 } 340 "" 341 end 342 343 case int_zero_condition 344 expect compile_fail 345 both "" 346 precision mediump float; 347 void main() 348 { 349 if (0) 350 ${POSITION_FRAG_COLOR} = vec4(1.0); 351 } 352 "" 353 end 354 355 case int_one_condition 356 expect compile_fail 357 both "" 358 precision mediump float; 359 void main() 360 { 361 if (1) 362 ${POSITION_FRAG_COLOR} = vec4(1.0); 363 } 364 "" 365 end 366 367 case int_uniform_condition 368 expect compile_fail 369 370 both "" 371 precision mediump float; 372 precision mediump int; 373 uniform int u0; 374 void main() 375 { 376 if (u0) 377 ${POSITION_FRAG_COLOR} = vec4(1.0); 378 } 379 "" 380 end 381 382 case float_condition 383 expect compile_fail 384 both "" 385 precision mediump float; 386 void main() 387 { 388 if (5.0) 389 ${POSITION_FRAG_COLOR} = vec4(1.0); 390 } 391 "" 392 end 393 394 case float_zero_condition 395 expect compile_fail 396 both "" 397 precision mediump float; 398 void main() 399 { 400 if (0.0) 401 ${POSITION_FRAG_COLOR} = vec4(1.0); 402 } 403 "" 404 end 405 406 case float_one_condition 407 expect compile_fail 408 both "" 409 precision mediump float; 410 void main() 411 { 412 if (1.0) 413 ${POSITION_FRAG_COLOR} = vec4(1.0); 414 } 415 "" 416 end 417 418 case sampler_condition 419 expect compile_fail 420 both "" 421 precision mediump float; 422 uniform sampler2D s0; 423 void main() 424 { 425 if (s0) 426 ${POSITION_FRAG_COLOR} = vec4(1.0); 427 } 428 "" 429 end 430 431 end # invalid_if 432