This is the mail archive of the
gcc-patches@gcc.gnu.org
mailing list for the GCC project.
[testsuite, committed] Add goacc/uninit-if-clause.{c,f95}
- From: Tom de Vries <Tom_deVries at mentor dot com>
- To: GCC Patches <gcc-patches at gcc dot gnu dot org>
- Cc: Thomas Schwinge <thomas at codesourcery dot com>, Jakub Jelinek <jakub at redhat dot com>
- Date: Thu, 24 Mar 2016 13:11:21 +0100
- Subject: [testsuite, committed] Add goacc/uninit-if-clause.{c,f95}
- Authentication-results: sourceware.org; auth=none
Hi,
I've committed attached patch, which adds testcases that test the
-Wuninitialized warning for the if clause on various openacc directives.
I found an issue with line-numbers of the warning in C++, which I've
filed as PR70392 - '[openacc] inconsistent line numbers in uninitialised
warnings for if clause'.
Some of the warning scans are xfailed in C++ due to that PR.
Thanks,
- Tom
Add goacc/uninit-if-clause.{c,f95}
2016-03-24 Tom de Vries <tom@codesourcery.com>
* c-c++-common/goacc/uninit-if-clause.c: New test.
* gfortran.dg/goacc/uninit-if-clause.f95: New test.
---
.../c-c++-common/goacc/uninit-if-clause.c | 38 ++++++++++++++++++++++
.../gfortran.dg/goacc/uninit-if-clause.f95 | 20 ++++++++++++
2 files changed, 58 insertions(+)
diff --git a/gcc/testsuite/c-c++-common/goacc/uninit-if-clause.c b/gcc/testsuite/c-c++-common/goacc/uninit-if-clause.c
new file mode 100644
index 0000000..55caa4c
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/goacc/uninit-if-clause.c
@@ -0,0 +1,38 @@
+/* { dg-do compile } */
+/* { dg-additional-options "-Wuninitialized" } */
+/* { dg-excess-errors "PR70392" { xfail c++ } } */
+
+#include <stdbool.h>
+
+int
+main (void)
+{
+ int l, l2, l3, l4;
+ bool b, b2, b3, b4;
+ int i, i2;
+
+ #pragma acc parallel if(l) /* { dg-warning "is used uninitialized in this function" } */
+ ;
+
+ #pragma acc parallel if(b) /* { dg-warning "is used uninitialized in this function" "" { xfail c++ } } */
+ ;
+
+ #pragma acc kernels if(l2) /* { dg-warning "is used uninitialized in this function" } */
+ ;
+
+ #pragma acc kernels if(b2) /* { dg-warning "is used uninitialized in this function" "" { xfail c++ } } */
+ ;
+
+ #pragma acc data if(l3) /* { dg-warning "is used uninitialized in this function" } */
+ ;
+
+ #pragma acc data if(b3) /* { dg-warning "is used uninitialized in this function" "" { xfail c++ } } */
+ ;
+
+ #pragma acc update if(l4) self(i) /* { dg-warning "is used uninitialized in this function" } */
+ ;
+
+ #pragma acc update if(b4) self(i2) /* { dg-warning "is used uninitialized in this function" "" { xfail c++ } } */
+ ;
+
+}
diff --git a/gcc/testsuite/gfortran.dg/goacc/uninit-if-clause.f95 b/gcc/testsuite/gfortran.dg/goacc/uninit-if-clause.f95
new file mode 100644
index 0000000..60dc53e
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/goacc/uninit-if-clause.f95
@@ -0,0 +1,20 @@
+! { dg-do compile }
+! { dg-additional-options "-Wuninitialized" }
+
+program test
+ implicit none
+ logical :: b, b2, b3, b4
+ integer :: data, data2
+
+ !$acc parallel if(b) ! { dg-warning "is used uninitialized in this function" }
+ !$acc end parallel
+
+ !$acc kernels if(b2) ! { dg-warning "is used uninitialized in this function" }
+ !$acc end kernels
+
+ !$acc data if(b3) ! { dg-warning "is used uninitialized in this function" }
+ !$acc end data
+
+ !$acc update if(b4) self(data2) ! { dg-warning "is used uninitialized in this function" }
+
+end program test