aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCesar Philippidis <cesar@codesourcery.com>2016-04-14 06:44:17 -0700
committerCesar Philippidis <cesar@gcc.gnu.org>2016-04-14 06:44:17 -0700
commite387fc6494396c13f68458c7e3ed94d492aca54f (patch)
treefd4a4a91473cffc90c7a2d4498805190de428f88
parente21401b6b11f87986ee08499619b861c6964286c (diff)
re PR middle-end/70643 (broken openacc reduction inside a fortran module)
PR middle-end/70643 gcc/ * omp-low.c (lower_oacc_reductions): Check for TREE_CONSTANT when building a mem ref for the incoming reduction variable. libgomp/ * testsuite/libgomp.oacc-fortran/pr70643.f90: New test. From-SVN: r234973
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/omp-low.c2
-rw-r--r--libgomp/ChangeLog5
-rw-r--r--libgomp/testsuite/libgomp.oacc-fortran/pr70643.f9051
4 files changed, 63 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 19575f0fc79..ca2a9a74600 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2016-04-14 Cesar Philippidis <cesar@codesourcery.com>
+
+ PR middle-end/70643
+ * omp-low.c (lower_oacc_reductions): Check for TREE_CONSTANT
+ when building a mem ref for the incoming reduction variable.
+
2016-04-14 Richard Biener <rguenther@suse.de>
PR tree-optimization/70614
diff --git a/gcc/omp-low.c b/gcc/omp-low.c
index 7335abc6396..aa3721edc9d 100644
--- a/gcc/omp-low.c
+++ b/gcc/omp-low.c
@@ -5691,7 +5691,7 @@ lower_oacc_reductions (location_t loc, tree clauses, tree level, bool inner,
v3 = build_simple_mem_ref (v3);
outgoing = build_simple_mem_ref (outgoing);
- if (TREE_CODE (incoming) != INTEGER_CST)
+ if (!TREE_CONSTANT (incoming))
incoming = build_simple_mem_ref (incoming);
}
else
diff --git a/libgomp/ChangeLog b/libgomp/ChangeLog
index d4411c0f557..89ee866ac4c 100644
--- a/libgomp/ChangeLog
+++ b/libgomp/ChangeLog
@@ -1,3 +1,8 @@
+2016-04-14 Cesar Philippidis <cesar@codesourcery.com>
+
+ PR middle-end/70643
+ * testsuite/libgomp.oacc-fortran/pr70643.f90: New test.
+
2016-04-13 Cesar Philippidis <cesar@codesourcery.com>
PR testsuite/68242
diff --git a/libgomp/testsuite/libgomp.oacc-fortran/pr70643.f90 b/libgomp/testsuite/libgomp.oacc-fortran/pr70643.f90
new file mode 100644
index 00000000000..7c2e5eef904
--- /dev/null
+++ b/libgomp/testsuite/libgomp.oacc-fortran/pr70643.f90
@@ -0,0 +1,51 @@
+MODULE reduction_test
+
+CONTAINS
+
+SUBROUTINE reduction_kernel(x_min,x_max,y_min,y_max,arr,sum)
+
+ IMPLICIT NONE
+
+ INTEGER :: x_min,x_max,y_min,y_max
+ REAL(KIND=8), DIMENSION(x_min-2:x_max+2,y_min-2:y_max+2) :: arr
+ REAL(KIND=8) :: sum
+
+ INTEGER :: j,k
+
+!$ACC DATA PRESENT(arr) COPY(sum)
+!$ACC PARALLEL LOOP REDUCTION(+ : sum)
+ DO k=y_min,y_max
+ DO j=x_min,x_max
+ sum=sum+arr(j,k)
+ ENDDO
+ ENDDO
+!$ACC END PARALLEL LOOP
+!$ACC END DATA
+END SUBROUTINE reduction_kernel
+
+END MODULE reduction_test
+
+program main
+ use reduction_test
+
+ integer :: x_min,x_max,y_min,y_max
+ real(kind=8), dimension(1:10,1:10) :: arr
+ real(kind=8) :: sum
+
+ x_min = 1
+ x_max = 2
+ y_min = 1
+ y_max = 2
+
+ arr(:,:) = 1.0
+
+ sum = 0.0
+
+ !$acc data copy(arr)
+
+ call reduction_kernel(x_min,x_max,y_min,y_max,arr,sum)
+
+ !$acc end data
+
+ if (sum .ne. 4.0) call abort
+end program