]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
openmp: Handle rest of EXEC_OACC_* in oacc_code_to_statement [PR93463]
authorJakub Jelinek <jakub@redhat.com>
Wed, 29 Jan 2020 08:39:16 +0000 (09:39 +0100)
committerJakub Jelinek <jakub@redhat.com>
Thu, 13 Feb 2020 20:29:47 +0000 (21:29 +0100)
As the testcase shows, some EXEC_OACC_* codes weren't handled in
oacc_code_to_statement.  Fixed thusly.

2020-01-29  Jakub Jelinek  <jakub@redhat.com>

PR fortran/93463
* openmp.c (oacc_code_to_statement): Handle
EXEC_OACC_{ROUTINE,UPDATE,WAIT,CACHE,{ENTER,EXIT}_DATA,DECLARE}.

* gfortran.dg/goacc/pr93463.f90: New test.

gcc/fortran/ChangeLog
gcc/fortran/openmp.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/goacc/pr93463.f90 [new file with mode: 0644]

index 0f5b7e60a5046e578b70315adf953dfd4154c1fe..f31e052b10acb468c3e37157defdaf8046a42a4b 100644 (file)
@@ -1,3 +1,12 @@
+2020-02-13  Jakub Jelinek  <jakub@redhat.com>
+
+       Backported from mainline
+       2020-01-29  Jakub Jelinek  <jakub@redhat.com>
+
+       PR fortran/93463
+       * openmp.c (oacc_code_to_statement): Handle
+       EXEC_OACC_{ROUTINE,UPDATE,WAIT,CACHE,{ENTER,EXIT}_DATA,DECLARE}.
+
 2020-02-03  Tobias Burnus  <tobias@codesourcery.com>
 
        Backported from mainline
index 716dd5ec3e2d292e197b85a32be9eaff9080b8a5..83b1c4487de7cd4702007815c8792ef6023d8417 100644 (file)
@@ -5858,6 +5858,20 @@ oacc_code_to_statement (gfc_code *code)
       return ST_OACC_LOOP;
     case EXEC_OACC_ATOMIC:
       return ST_OACC_ATOMIC;
+    case EXEC_OACC_ROUTINE:
+      return ST_OACC_ROUTINE;
+    case EXEC_OACC_UPDATE:
+      return ST_OACC_UPDATE;
+    case EXEC_OACC_WAIT:
+      return ST_OACC_WAIT;
+    case EXEC_OACC_CACHE:
+      return ST_OACC_CACHE;
+    case EXEC_OACC_ENTER_DATA:
+      return ST_OACC_ENTER_DATA;
+    case EXEC_OACC_EXIT_DATA:
+      return ST_OACC_EXIT_DATA;
+    case EXEC_OACC_DECLARE:
+      return ST_OACC_DECLARE;
     default:
       gcc_unreachable ();
     }
index 532f8dbef6ccbe7ac7fd389e006fb6fae24dc269..b5165efbc350e9a817339b06d6fef4f53883ae68 100644 (file)
@@ -1,6 +1,11 @@
 2020-02-13  Jakub Jelinek  <jakub@redhat.com>
 
        Backported from mainline
+       2020-01-29  Jakub Jelinek  <jakub@redhat.com>
+
+       PR fortran/93463
+       * gfortran.dg/goacc/pr93463.f90: New test.
+
        2020-01-28  Jakub Jelinek  <jakub@redhat.com>
 
        PR target/93418
diff --git a/gcc/testsuite/gfortran.dg/goacc/pr93463.f90 b/gcc/testsuite/gfortran.dg/goacc/pr93463.f90
new file mode 100644 (file)
index 0000000..920892f
--- /dev/null
@@ -0,0 +1,15 @@
+! PR fortran/93463
+! { dg-do compile { target fopenmp } }
+! { dg-additional-options "-fopenmp" }
+
+program pr93463
+   integer :: i, x, y, z
+   !$omp parallel do
+   do i = 1, 4
+      !$acc enter data create(x)       ! { dg-error "ACC ENTER DATA directive cannot be specified within" }
+      !$acc exit data copyout(x)       ! { dg-error "ACC EXIT DATA directive cannot be specified within" }
+      !$acc cache(y)                   ! { dg-error "ACC CACHE directive cannot be specified within" }
+      !$acc wait(1)                    ! { dg-error "ACC WAIT directive cannot be specified within" }
+      !$acc update self(z)             ! { dg-error "ACC UPDATE directive cannot be specified within" }
+   end do
+end