[Mesa-dev] [PATCH 5/5] glsl: add unit tests data vertex/expected outcome for unitialized warning

Ian Romanick idr at freedesktop.org
Thu May 12 21:21:33 UTC 2016


This is a good set, but, based on some of the previous issues, I think a
couple more tests would be good.

1. Verify this doesn't generate any warnings

void f(out float x);

out float y;

void main()
{
    float will_be_defined;

    f(will_be_defined);
    y = will_be_defined;
}

2. Verify this generates only one warning

void f(inout float x);

out float y;

void main()
{
    float will_be_defined;

    f(will_be_defined);
    y = will_be_defined;
}

There are probably some other variations of these that would be interesting.

I think this patch is

Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>

but I'd like to see a few more tests.

On 05/10/2016 12:13 AM, Alejandro PiƱeiro wrote:
> ---
>  .../glsl/tests/warnings/000-basic-test.vert        | 10 ++++++++
>  .../tests/warnings/000-basic-test.vert.expected    |  1 +
>  .../warnings/001-use-undefined-then-define.vert    | 12 ++++++++++
>  .../001-use-undefined-then-define.vert.expected    |  1 +
>  src/compiler/glsl/tests/warnings/002-loop.vert     | 23 ++++++++++++++++++
>  .../glsl/tests/warnings/002-loop.vert.expected     |  3 +++
>  src/compiler/glsl/tests/warnings/003-less.vert     | 17 +++++++++++++
>  .../glsl/tests/warnings/003-less.vert.expected     |  1 +
>  src/compiler/glsl/tests/warnings/004-greater.vert  | 17 +++++++++++++
>  .../glsl/tests/warnings/004-greater.vert.expected  |  1 +
>  src/compiler/glsl/tests/warnings/005-lequal.vert   | 17 +++++++++++++
>  .../glsl/tests/warnings/005-lequal.vert.expected   |  1 +
>  src/compiler/glsl/tests/warnings/006-gequal.vert   | 17 +++++++++++++
>  .../glsl/tests/warnings/006-gequal.vert.expected   |  1 +
>  src/compiler/glsl/tests/warnings/007-test-mod.vert | 25 +++++++++++++++++++
>  .../glsl/tests/warnings/007-test-mod.vert.expected |  3 +++
>  .../glsl/tests/warnings/008-mulassign.vert         | 12 ++++++++++
>  .../tests/warnings/008-mulassign.vert.expected     |  1 +
>  .../glsl/tests/warnings/009-div-assign.vert        | 12 ++++++++++
>  .../tests/warnings/009-div-assign.vert.expected    |  1 +
>  .../glsl/tests/warnings/010-add-assign.vert        | 12 ++++++++++
>  .../tests/warnings/010-add-assign.vert.expected    |  1 +
>  .../glsl/tests/warnings/011-sub-assign.vert        | 12 ++++++++++
>  .../tests/warnings/011-sub-assign.vert.expected    |  1 +
>  .../glsl/tests/warnings/012-modassign.vert         | 12 ++++++++++
>  .../tests/warnings/012-modassign.vert.expected     |  1 +
>  src/compiler/glsl/tests/warnings/013-lsassign.vert | 12 ++++++++++
>  .../glsl/tests/warnings/013-lsassign.vert.expected |  1 +
>  src/compiler/glsl/tests/warnings/014-rsassign.vert | 12 ++++++++++
>  .../glsl/tests/warnings/014-rsassign.vert.expected |  1 +
>  .../glsl/tests/warnings/015-andassign.vert         | 12 ++++++++++
>  .../tests/warnings/015-andassign.vert.expected     |  1 +
>  src/compiler/glsl/tests/warnings/016-orassign.vert | 12 ++++++++++
>  .../glsl/tests/warnings/016-orassign.vert.expected |  1 +
>  .../glsl/tests/warnings/017-xorassign.vert         | 12 ++++++++++
>  .../tests/warnings/017-xorassign.vert.expected     |  1 +
>  src/compiler/glsl/tests/warnings/018-bitand.vert   | 24 +++++++++++++++++++
>  .../glsl/tests/warnings/018-bitand.vert.expected   |  3 +++
>  src/compiler/glsl/tests/warnings/019-array.vert    | 23 ++++++++++++++++++
>  .../glsl/tests/warnings/019-array.vert.expected    |  5 ++++
>  .../glsl/tests/warnings/020-array-length.vert      | 12 ++++++++++
>  .../tests/warnings/020-array-length.vert.expected  |  0
>  src/compiler/glsl/tests/warnings/021-lshift.vert   | 25 +++++++++++++++++++
>  .../glsl/tests/warnings/021-lshift.vert.expected   |  3 +++
>  src/compiler/glsl/tests/warnings/022-rshift.vert   | 25 +++++++++++++++++++
>  .../glsl/tests/warnings/022-rshift.vert.expected   |  3 +++
>  src/compiler/glsl/tests/warnings/023-switch.vert   | 28 ++++++++++++++++++++++
>  .../glsl/tests/warnings/023-switch.vert.expected   |  3 +++
>  .../glsl/tests/warnings/024-shaderout.vert         | 19 +++++++++++++++
>  .../tests/warnings/024-shaderout.vert.expected     |  2 ++
>  .../025-out-inout-function-parameters.vert         | 16 +++++++++++++
>  ...025-out-inout-function-parameters.vert.expected |  1 +
>  .../glsl/tests/warnings/026-conditional.vert       | 17 +++++++++++++
>  .../tests/warnings/026-conditional.vert.expected   |  6 +++++
>  .../glsl/tests/warnings/027-fieldselection.vert    | 23 ++++++++++++++++++
>  .../warnings/027-fieldselection.vert.expected      |  1 +
>  56 files changed, 519 insertions(+)
>  create mode 100644 src/compiler/glsl/tests/warnings/000-basic-test.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/000-basic-test.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/002-loop.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/002-loop.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/003-less.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/003-less.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/004-greater.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/004-greater.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/005-lequal.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/005-lequal.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/006-gequal.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/006-gequal.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/007-test-mod.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/007-test-mod.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/008-mulassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/008-mulassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/009-div-assign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/009-div-assign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/010-add-assign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/010-add-assign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/011-sub-assign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/011-sub-assign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/012-modassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/012-modassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/013-lsassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/013-lsassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/014-rsassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/014-rsassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/015-andassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/015-andassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/016-orassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/016-orassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/017-xorassign.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/017-xorassign.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/018-bitand.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/018-bitand.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/019-array.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/019-array.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/020-array-length.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/020-array-length.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/021-lshift.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/021-lshift.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/022-rshift.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/022-rshift.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/023-switch.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/023-switch.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/024-shaderout.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/024-shaderout.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/026-conditional.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/026-conditional.vert.expected
>  create mode 100644 src/compiler/glsl/tests/warnings/027-fieldselection.vert
>  create mode 100644 src/compiler/glsl/tests/warnings/027-fieldselection.vert.expected
> 
> diff --git a/src/compiler/glsl/tests/warnings/000-basic-test.vert b/src/compiler/glsl/tests/warnings/000-basic-test.vert
> new file mode 100644
> index 0000000..266eed6
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/000-basic-test.vert
> @@ -0,0 +1,10 @@
> +#version 130
> +
> +void main()
> +{
> +  float foo;
> +  float undefined;
> +
> +  foo = undefined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/000-basic-test.vert.expected b/src/compiler/glsl/tests/warnings/000-basic-test.vert.expected
> new file mode 100644
> index 0000000..ed02a95
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/000-basic-test.vert.expected
> @@ -0,0 +1 @@
> +0:8(8): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert b/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert
> new file mode 100644
> index 0000000..2175afe
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  float foo;
> +  float undefinedThenDefined;
> +
> +  foo = undefinedThenDefined;
> +  undefinedThenDefined = 2.0;
> +  foo = undefinedThenDefined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert.expected b/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert.expected
> new file mode 100644
> index 0000000..a036d67
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/001-use-undefined-then-define.vert.expected
> @@ -0,0 +1 @@
> +0:8(8): warning: `undefinedThenDefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/002-loop.vert b/src/compiler/glsl/tests/warnings/002-loop.vert
> new file mode 100644
> index 0000000..de05d9c
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/002-loop.vert
> @@ -0,0 +1,23 @@
> +#version 130
> +
> +void main()
> +{
> +   int i;
> +   int undefined;
> +   int undefined2;
> +   int defined = 2;
> +   float fooFloat;
> +
> +   for (i = 0; i < undefined; i++) {
> +      fooFloat = 10.0;
> +   }
> +
> +   for (; undefined < undefined2; i++) {
> +      fooFloat = 10.0;
> +   }
> +
> +   for (i = 0; i < defined; i++) {
> +      fooFloat = 10.0;
> +   }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/002-loop.vert.expected b/src/compiler/glsl/tests/warnings/002-loop.vert.expected
> new file mode 100644
> index 0000000..7a51001
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/002-loop.vert.expected
> @@ -0,0 +1,3 @@
> +0:11(18): warning: `undefined' used uninitialized
> +0:15(9): warning: `undefined' used uninitialized
> +0:15(21): warning: `undefined2' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/003-less.vert b/src/compiler/glsl/tests/warnings/003-less.vert
> new file mode 100644
> index 0000000..bbab55a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/003-less.vert
> @@ -0,0 +1,17 @@
> +#version 130
> +
> +void main()
> +{
> +   int undefined;
> +   int defined = 2;
> +   float fooFloat;
> +
> +   if (undefined < 0) {
> +      fooFloat = 10.0;
> +   }
> +
> +   if (defined < 0) {
> +      fooFloat = 10.0;
> +   }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/003-less.vert.expected b/src/compiler/glsl/tests/warnings/003-less.vert.expected
> new file mode 100644
> index 0000000..93cd789
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/003-less.vert.expected
> @@ -0,0 +1 @@
> +0:9(6): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/004-greater.vert b/src/compiler/glsl/tests/warnings/004-greater.vert
> new file mode 100644
> index 0000000..c9842e5
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/004-greater.vert
> @@ -0,0 +1,17 @@
> +#version 130
> +
> +void main()
> +{
> +   int undefined;
> +   int defined = 2;
> +   float fooFloat;
> +
> +   if (undefined > 0) {
> +      fooFloat = 10.0;
> +   }
> +
> +   if (defined > 0) {
> +      fooFloat = 10.0;
> +   }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/004-greater.vert.expected b/src/compiler/glsl/tests/warnings/004-greater.vert.expected
> new file mode 100644
> index 0000000..93cd789
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/004-greater.vert.expected
> @@ -0,0 +1 @@
> +0:9(6): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/005-lequal.vert b/src/compiler/glsl/tests/warnings/005-lequal.vert
> new file mode 100644
> index 0000000..73e476a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/005-lequal.vert
> @@ -0,0 +1,17 @@
> +#version 130
> +
> +void main()
> +{
> +   int undefined;
> +   int defined = 2;
> +   float fooFloat;
> +
> +   if (undefined <= 0) {
> +      fooFloat = 10.0;
> +   }
> +
> +   if (defined <= 0) {
> +      fooFloat = 10.0;
> +   }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/005-lequal.vert.expected b/src/compiler/glsl/tests/warnings/005-lequal.vert.expected
> new file mode 100644
> index 0000000..93cd789
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/005-lequal.vert.expected
> @@ -0,0 +1 @@
> +0:9(6): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/006-gequal.vert b/src/compiler/glsl/tests/warnings/006-gequal.vert
> new file mode 100644
> index 0000000..f1694bd
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/006-gequal.vert
> @@ -0,0 +1,17 @@
> +#version 130
> +
> +void main()
> +{
> +   int undefined;
> +   int defined = 2;
> +   float fooFloat;
> +
> +   if (undefined >= 0) {
> +      fooFloat = 10.0;
> +   }
> +
> +   if (defined >= 0) {
> +      fooFloat = 10.0;
> +   }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/006-gequal.vert.expected b/src/compiler/glsl/tests/warnings/006-gequal.vert.expected
> new file mode 100644
> index 0000000..93cd789
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/006-gequal.vert.expected
> @@ -0,0 +1 @@
> +0:9(6): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/007-test-mod.vert b/src/compiler/glsl/tests/warnings/007-test-mod.vert
> new file mode 100644
> index 0000000..2881db8
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/007-test-mod.vert
> @@ -0,0 +1,25 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  float fooFloat;
> +
> +  if (undefined % 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined % 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (undefined % defined == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined % undefined == 0) {
> +    fooFloat = 10.0;
> +  }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/007-test-mod.vert.expected b/src/compiler/glsl/tests/warnings/007-test-mod.vert.expected
> new file mode 100644
> index 0000000..78613d5
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/007-test-mod.vert.expected
> @@ -0,0 +1,3 @@
> +0:9(6): warning: `undefined' used uninitialized
> +0:17(6): warning: `undefined' used uninitialized
> +0:21(16): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/008-mulassign.vert b/src/compiler/glsl/tests/warnings/008-mulassign.vert
> new file mode 100644
> index 0000000..0923891
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/008-mulassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt *= undefined;
> +  fooInt *= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/008-mulassign.vert.expected b/src/compiler/glsl/tests/warnings/008-mulassign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/008-mulassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/009-div-assign.vert b/src/compiler/glsl/tests/warnings/009-div-assign.vert
> new file mode 100644
> index 0000000..91440bf
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/009-div-assign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt /= undefined;
> +  fooInt /= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/009-div-assign.vert.expected b/src/compiler/glsl/tests/warnings/009-div-assign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/009-div-assign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/010-add-assign.vert b/src/compiler/glsl/tests/warnings/010-add-assign.vert
> new file mode 100644
> index 0000000..661219f
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/010-add-assign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt += undefined;
> +  fooInt += defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/010-add-assign.vert.expected b/src/compiler/glsl/tests/warnings/010-add-assign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/010-add-assign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/011-sub-assign.vert b/src/compiler/glsl/tests/warnings/011-sub-assign.vert
> new file mode 100644
> index 0000000..9839dec
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/011-sub-assign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt -= undefined;
> +  fooInt -= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/011-sub-assign.vert.expected b/src/compiler/glsl/tests/warnings/011-sub-assign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/011-sub-assign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/012-modassign.vert b/src/compiler/glsl/tests/warnings/012-modassign.vert
> new file mode 100644
> index 0000000..2f261a3
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/012-modassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int myInt;
> +
> +  myInt %= undefined;
> +  myInt %= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/012-modassign.vert.expected b/src/compiler/glsl/tests/warnings/012-modassign.vert.expected
> new file mode 100644
> index 0000000..637142e
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/012-modassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(11): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/013-lsassign.vert b/src/compiler/glsl/tests/warnings/013-lsassign.vert
> new file mode 100644
> index 0000000..f2b49e2
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/013-lsassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt >>= undefined;
> +  fooInt >>= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/013-lsassign.vert.expected b/src/compiler/glsl/tests/warnings/013-lsassign.vert.expected
> new file mode 100644
> index 0000000..b20d3c0
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/013-lsassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(13): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/014-rsassign.vert b/src/compiler/glsl/tests/warnings/014-rsassign.vert
> new file mode 100644
> index 0000000..798b6cc
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/014-rsassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt <<= undefined;
> +  fooInt <<= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/014-rsassign.vert.expected b/src/compiler/glsl/tests/warnings/014-rsassign.vert.expected
> new file mode 100644
> index 0000000..b20d3c0
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/014-rsassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(13): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/015-andassign.vert b/src/compiler/glsl/tests/warnings/015-andassign.vert
> new file mode 100644
> index 0000000..a86a8d8
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/015-andassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt &= undefined;
> +  fooInt &= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/015-andassign.vert.expected b/src/compiler/glsl/tests/warnings/015-andassign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/015-andassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/016-orassign.vert b/src/compiler/glsl/tests/warnings/016-orassign.vert
> new file mode 100644
> index 0000000..c04241a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/016-orassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt |= undefined;
> +  fooInt |= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/016-orassign.vert.expected b/src/compiler/glsl/tests/warnings/016-orassign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/016-orassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/017-xorassign.vert b/src/compiler/glsl/tests/warnings/017-xorassign.vert
> new file mode 100644
> index 0000000..ff649f7
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/017-xorassign.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  fooInt ^= undefined;
> +  fooInt ^= defined;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/017-xorassign.vert.expected b/src/compiler/glsl/tests/warnings/017-xorassign.vert.expected
> new file mode 100644
> index 0000000..8fbb408
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/017-xorassign.vert.expected
> @@ -0,0 +1 @@
> +0:9(12): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/018-bitand.vert b/src/compiler/glsl/tests/warnings/018-bitand.vert
> new file mode 100644
> index 0000000..7e879dc
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/018-bitand.vert
> @@ -0,0 +1,24 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  float fooFloat;
> +
> +  if ((undefined | 2) == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if ((defined | 2) == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if ((undefined | defined) == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if ((defined | undefined) == 0) {
> +    fooFloat = 10.0;
> +  }
> +}
> diff --git a/src/compiler/glsl/tests/warnings/018-bitand.vert.expected b/src/compiler/glsl/tests/warnings/018-bitand.vert.expected
> new file mode 100644
> index 0000000..c7e5c99
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/018-bitand.vert.expected
> @@ -0,0 +1,3 @@
> +0:9(7): warning: `undefined' used uninitialized
> +0:17(7): warning: `undefined' used uninitialized
> +0:21(17): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/019-array.vert b/src/compiler/glsl/tests/warnings/019-array.vert
> new file mode 100644
> index 0000000..43d7f4c
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/019-array.vert
> @@ -0,0 +1,23 @@
> +#version 130
> +
> +void main()
> +{
> +  int undefinedIndex;
> +  int undefinedIndex2;
> +  int definedIndex = 2;
> +  int definedIndex2 = 2;
> +  float array[4];
> +  float fooPos;
> +  int fooLength;
> +
> +  fooPos = array[undefinedIndex];
> +  fooPos = array[definedIndex];
> +
> +  fooPos = array[definedIndex+definedIndex2];
> +  fooPos = array[undefinedIndex+undefinedIndex2];
> +  array[0] = 10.0;
> +  fooPos = array[definedIndex];
> +
> +  array[undefinedIndex2] = array[undefinedIndex];
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/019-array.vert.expected b/src/compiler/glsl/tests/warnings/019-array.vert.expected
> new file mode 100644
> index 0000000..3d80306
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/019-array.vert.expected
> @@ -0,0 +1,5 @@
> +0:13(17): warning: `undefinedIndex' used uninitialized
> +0:17(17): warning: `undefinedIndex' used uninitialized
> +0:17(32): warning: `undefinedIndex2' used uninitialized
> +0:21(8): warning: `undefinedIndex2' used uninitialized
> +0:21(33): warning: `undefinedIndex' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/020-array-length.vert b/src/compiler/glsl/tests/warnings/020-array-length.vert
> new file mode 100644
> index 0000000..0fa57b2
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/020-array-length.vert
> @@ -0,0 +1,12 @@
> +#version 130
> +
> +void main()
> +{
> +  float array[4];
> +  int fooLength;
> +
> +  fooLength = array.length();
> +  array[0] = 2.0;
> +  fooLength = array.length();
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/020-array-length.vert.expected b/src/compiler/glsl/tests/warnings/020-array-length.vert.expected
> new file mode 100644
> index 0000000..e69de29
> diff --git a/src/compiler/glsl/tests/warnings/021-lshift.vert b/src/compiler/glsl/tests/warnings/021-lshift.vert
> new file mode 100644
> index 0000000..ed8c819
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/021-lshift.vert
> @@ -0,0 +1,25 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  float fooFloat;
> +
> +  if (undefined << 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined << 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (undefined << defined == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined << undefined == 0) {
> +    fooFloat = 10.0;
> +  }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/021-lshift.vert.expected b/src/compiler/glsl/tests/warnings/021-lshift.vert.expected
> new file mode 100644
> index 0000000..5813f12
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/021-lshift.vert.expected
> @@ -0,0 +1,3 @@
> +0:9(6): warning: `undefined' used uninitialized
> +0:17(6): warning: `undefined' used uninitialized
> +0:21(17): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/022-rshift.vert b/src/compiler/glsl/tests/warnings/022-rshift.vert
> new file mode 100644
> index 0000000..226d346
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/022-rshift.vert
> @@ -0,0 +1,25 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  float fooFloat;
> +
> +  if (undefined >> 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined >> 2 == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (undefined >> defined == 0) {
> +    fooFloat = 10.0;
> +  }
> +
> +  if (defined >> undefined == 0) {
> +    fooFloat = 10.0;
> +  }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/022-rshift.vert.expected b/src/compiler/glsl/tests/warnings/022-rshift.vert.expected
> new file mode 100644
> index 0000000..5813f12
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/022-rshift.vert.expected
> @@ -0,0 +1,3 @@
> +0:9(6): warning: `undefined' used uninitialized
> +0:17(6): warning: `undefined' used uninitialized
> +0:21(17): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/023-switch.vert b/src/compiler/glsl/tests/warnings/023-switch.vert
> new file mode 100644
> index 0000000..4527971
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/023-switch.vert
> @@ -0,0 +1,28 @@
> +#version 130
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  float fooFloat;
> +  int fooInt;
> +
> +  switch(undefined) {
> +  case 0:
> +    fooFloat = 0.0;
> +  case 1:
> +    fooFloat = 1.0;
> +  default:
> +    fooFloat = undefined;
> +  }
> +
> +  switch(defined) {
> +  case 0:
> +    fooFloat = 0.0;
> +  case 1:
> +    fooFloat = 1.0;
> +  default:
> +    fooFloat = undefined;
> +  }
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/023-switch.vert.expected b/src/compiler/glsl/tests/warnings/023-switch.vert.expected
> new file mode 100644
> index 0000000..201d0a2
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/023-switch.vert.expected
> @@ -0,0 +1,3 @@
> +0:10(9): warning: `undefined' used uninitialized
> +0:16(13): warning: `undefined' used uninitialized
> +0:25(13): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/024-shaderout.vert b/src/compiler/glsl/tests/warnings/024-shaderout.vert
> new file mode 100644
> index 0000000..00a7988
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/024-shaderout.vert
> @@ -0,0 +1,19 @@
> +#version 130
> +
> +out int fooOut;
> +
> +void main()
> +{
> +  int defined = 2;
> +  int undefined;
> +  int fooInt;
> +
> +  defined = fooOut;
> +  fooOut = undefined;
> +  /* Technically at this point fooOut is still undefined. But it was
> +   * initialized that is what the unitialized warning detects in any
> +   * case. "Real undefined" is beyond the scope of what mesa is/should
> +   * detect*/
> +  defined = fooOut;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/024-shaderout.vert.expected b/src/compiler/glsl/tests/warnings/024-shaderout.vert.expected
> new file mode 100644
> index 0000000..c85c55a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/024-shaderout.vert.expected
> @@ -0,0 +1,2 @@
> +0:11(12): warning: `fooOut' used uninitialized
> +0:12(11): warning: `undefined' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert b/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert
> new file mode 100644
> index 0000000..c6b2b16
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert
> @@ -0,0 +1,16 @@
> +#version 130
> +
> +void foo(float normalVar, out float outVar, inout float inoutVar)
> +{
> +  outVar = 1.0f;
> +}
> +
> +void main()
> +{
> +   float undefinedFloat;
> +   float noRaise;
> +   float noRaise2;
> +
> +   foo(undefinedFloat, noRaise, noRaise2);
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert.expected b/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert.expected
> new file mode 100644
> index 0000000..5e2c007
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/025-out-inout-function-parameters.vert.expected
> @@ -0,0 +1 @@
> +0:14(6): warning: `undefinedFloat' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/026-conditional.vert b/src/compiler/glsl/tests/warnings/026-conditional.vert
> new file mode 100644
> index 0000000..3447f05
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/026-conditional.vert
> @@ -0,0 +1,17 @@
> +#version 130
> +
> +void main()
> +{
> +  bool defined = false;
> +  bool undefined;
> +  int fooInt;
> +  int definedInt = 2;
> +  int undefinedInt;
> +
> +  fooInt = defined ? definedInt : undefinedInt;
> +  fooInt = defined ? undefinedInt : definedInt;
> +
> +  fooInt = undefined ? definedInt : undefinedInt;
> +  fooInt = undefined ? undefinedInt : definedInt;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/026-conditional.vert.expected b/src/compiler/glsl/tests/warnings/026-conditional.vert.expected
> new file mode 100644
> index 0000000..aaf5b7b
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/026-conditional.vert.expected
> @@ -0,0 +1,6 @@
> +0:11(34): warning: `undefinedInt' used uninitialized
> +0:12(21): warning: `undefinedInt' used uninitialized
> +0:14(11): warning: `undefined' used uninitialized
> +0:14(36): warning: `undefinedInt' used uninitialized
> +0:15(11): warning: `undefined' used uninitialized
> +0:15(23): warning: `undefinedInt' used uninitialized
> diff --git a/src/compiler/glsl/tests/warnings/027-fieldselection.vert b/src/compiler/glsl/tests/warnings/027-fieldselection.vert
> new file mode 100644
> index 0000000..cdec06a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/027-fieldselection.vert
> @@ -0,0 +1,23 @@
> +#version 130
> +
> +struct s {
> +  float c;
> +  float x;
> +};
> +
> +void main()
> +{
> +  float fooFloat;
> +  s fooStruct;
> +
> +  fooFloat = fooStruct.c;
> +  fooStruct.c = 10.0;
> +  fooFloat = fooStruct.c;
> +  fooStruct.c = 20.0;
> +
> +  /* Technically .x is also uninitialized, but detecting this is beyond
> +   * scope. FWIW, gcc doesn't detect this neither.
> +   */
> +  fooFloat = fooStruct.x;
> +}
> +
> diff --git a/src/compiler/glsl/tests/warnings/027-fieldselection.vert.expected b/src/compiler/glsl/tests/warnings/027-fieldselection.vert.expected
> new file mode 100644
> index 0000000..0a2c04a
> --- /dev/null
> +++ b/src/compiler/glsl/tests/warnings/027-fieldselection.vert.expected
> @@ -0,0 +1 @@
> +0:13(13): warning: `fooStruct' used uninitialized
> 



More information about the mesa-dev mailing list