aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran
diff options
context:
space:
mode:
authorTobias Burnus <tobias@codesourcery.com>2020-06-16 20:18:31 +0200
committerTobias Burnus <tobias@codesourcery.com>2020-06-16 20:23:58 +0200
commit12df77ab6df4b91d4770240bcc4ab443e4bb18b9 (patch)
treebc813b527747e25caf6648269c40345834fe047f /gcc/fortran
parent244ed2adaa3d349d381ca6ce090c2fa69b6e8d8b (diff)
downloadgcc-12df77ab6df4b91d4770240bcc4ab443e4bb18b9.zip
gcc-12df77ab6df4b91d4770240bcc4ab443e4bb18b9.tar.gz
gcc-12df77ab6df4b91d4770240bcc4ab443e4bb18b9.tar.bz2
OpenACC/Fortran: permit 'routine' inside PURE
gcc/fortran/ChangeLog * parse.c (decode_oacc_directive): Permit 'acc routine' also inside pure procedures. * openmp.c (gfc_match_oacc_routine): Inside pure procedures do not permit gang, worker or vector clauses. libgomp/ChangeLog: * testsuite/libgomp.oacc-fortran/routine-10.f90: New test. gcc/testsuite/ChangeLog: * gfortran.dg/goacc/pure-elemental-procedures-2.f90: New test. Reviewed-by: Thomas Schwinge <thomas@codesourcery.com>
Diffstat (limited to 'gcc/fortran')
-rw-r--r--gcc/fortran/openmp.c8
-rw-r--r--gcc/fortran/parse.c28
2 files changed, 23 insertions, 13 deletions
diff --git a/gcc/fortran/openmp.c b/gcc/fortran/openmp.c
index b246308..94522d1 100644
--- a/gcc/fortran/openmp.c
+++ b/gcc/fortran/openmp.c
@@ -2525,6 +2525,14 @@ gfc_match_oacc_routine (void)
/* Something has gone wrong, possibly a syntax error. */
goto cleanup;
+ if (gfc_pure (NULL) && c && (c->gang || c->worker || c->vector))
+ {
+ gfc_error ("!$ACC ROUTINE with GANG, WORKER, or VECTOR clause is not "
+ "permitted in PURE procedure at %C");
+ goto cleanup;
+ }
+
+
if (n)
n->clauses = c;
else if (gfc_current_ns->oacc_routine)
diff --git a/gcc/fortran/parse.c b/gcc/fortran/parse.c
index 46e1e1b..3671513 100644
--- a/gcc/fortran/parse.c
+++ b/gcc/fortran/parse.c
@@ -639,20 +639,10 @@ decode_oacc_directive (void)
gfc_matching_function = false;
- if (gfc_pure (NULL))
- {
- gfc_error_now ("OpenACC directives at %C may not appear in PURE "
- "procedures");
- gfc_error_recovery ();
- return ST_NONE;
- }
-
if (gfc_current_state () == COMP_FUNCTION
&& gfc_current_block ()->result->ts.kind == -1)
spec_only = true;
- gfc_unset_implicit_pure (NULL);
-
old_locus = gfc_current_locus;
/* General OpenACC directive matching: Instead of testing every possible
@@ -663,6 +653,21 @@ decode_oacc_directive (void)
switch (c)
{
+ case 'r':
+ matcha ("routine", gfc_match_oacc_routine, ST_OACC_ROUTINE);
+ break;
+ }
+
+ gfc_unset_implicit_pure (NULL);
+ if (gfc_pure (NULL))
+ {
+ gfc_error_now ("OpenACC directives other than ROUTINE may not appear in PURE "
+ "procedures at %C");
+ goto error_handling;
+ }
+
+ switch (c)
+ {
case 'a':
matcha ("atomic", gfc_match_oacc_atomic, ST_OACC_ATOMIC);
break;
@@ -705,9 +710,6 @@ decode_oacc_directive (void)
case 'l':
matcha ("loop", gfc_match_oacc_loop, ST_OACC_LOOP);
break;
- case 'r':
- match ("routine", gfc_match_oacc_routine, ST_OACC_ROUTINE);
- break;
case 's':
matcha ("serial loop", gfc_match_oacc_serial_loop, ST_OACC_SERIAL_LOOP);
matcha ("serial", gfc_match_oacc_serial, ST_OACC_SERIAL);