From 5846b949460ea036e548e9a9fd72ae4c10993ce9 Mon Sep 17 00:00:00 2001 From: jakub Date: Mon, 1 Dec 2008 15:10:25 +0000 Subject: [PATCH] PR c++/38348 * c-omp.c (c_finish_omp_for): Only transform pointer ++ or -- into MODIFY_EXPR if second argument is non-NULL. * g++.dg/gomp/for-19.C: New test. * testsuite/libgomp.c++/for-6.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@142318 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 4 ++ gcc/c-omp.c | 3 +- gcc/testsuite/ChangeLog | 3 + gcc/testsuite/g++.dg/gomp/for-19.C | 41 +++++++++++++ libgomp/ChangeLog | 5 ++ libgomp/testsuite/libgomp.c++/for-6.C | 109 ++++++++++++++++++++++++++++++++++ 6 files changed, 164 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/gomp/for-19.C create mode 100644 libgomp/testsuite/libgomp.c++/for-6.C diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 05b970b7f46..5d7f4f03b7c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2008-12-01 Jakub Jelinek + PR c++/38348 + * c-omp.c (c_finish_omp_for): Only transform pointer + ++ or -- into MODIFY_EXPR if second argument is non-NULL. + PR rtl-optimization/38245 * tree-vrp.c (abs_extent_range): New function. (extract_range_from_binary_expr): Compute range diff --git a/gcc/c-omp.c b/gcc/c-omp.c index b06c83039b9..3be3729a32c 100644 --- a/gcc/c-omp.c +++ b/gcc/c-omp.c @@ -357,7 +357,8 @@ c_finish_omp_for (location_t locus, tree declv, tree initv, tree condv, break; incr_ok = true; - if (POINTER_TYPE_P (TREE_TYPE (decl))) + if (POINTER_TYPE_P (TREE_TYPE (decl)) + && TREE_OPERAND (incr, 1)) { tree t = fold_convert (sizetype, TREE_OPERAND (incr, 1)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 88adf43bda1..1bc5714a64c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2008-12-01 Jakub Jelinek + PR c++/38348 + * g++.dg/gomp/for-19.C: New test. + PR rtl-optimization/38245 * gcc.dg/pr38245-1.c: New test. * gcc.dg/pr38245-2.c: New test. diff --git a/gcc/testsuite/g++.dg/gomp/for-19.C b/gcc/testsuite/g++.dg/gomp/for-19.C new file mode 100644 index 00000000000..1929e45f884 --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/for-19.C @@ -0,0 +1,41 @@ +// PR c++/38348 +// { dg-do compile } +// { dg-options "-fopenmp" } + +const char *p = "abcde"; + +template +void +f1 (void) +{ +#pragma omp for // { dg-error "forbids incrementing a pointer of type" } + for (void *q = (void *)p; q < (void *) (p + 4); q++) // { dg-error "forbids incrementing a pointer of type" } + ; +} + +template +void +f2 (void) +{ +#pragma omp for + for (const char *q = p; q < p + 4; q++) + ; +} + +template +void +f3 (void) +{ +#pragma omp for // { dg-error "forbids incrementing a pointer of type" } + for (T q = T (p); q < T (p + 4); q++) + ; +} + +int +main (void) +{ + f1 (); // { dg-message "instantiated from here" } + f2 (); + f3 (); + f3 (); // { dg-message "instantiated from here" } +} diff --git a/libgomp/ChangeLog b/libgomp/ChangeLog index 0cdfba6d83f..5576af2049c 100644 --- a/libgomp/ChangeLog +++ b/libgomp/ChangeLog @@ -1,3 +1,8 @@ +2008-12-01 Jakub Jelinek + + PR c++/38348 + * testsuite/libgomp.c++/for-6.C: New test. + 2008-11-26 Janis Johnson PR testsuite/28870 diff --git a/libgomp/testsuite/libgomp.c++/for-6.C b/libgomp/testsuite/libgomp.c++/for-6.C new file mode 100644 index 00000000000..0da21ce2fe5 --- /dev/null +++ b/libgomp/testsuite/libgomp.c++/for-6.C @@ -0,0 +1,109 @@ +// PR c++/38348 +// { dg-do run } + +extern "C" void abort (); +int cnt; + +template +void +f0 (T, int) +{ + abort (); +} + +template <> +void +f0 (int, int type) +{ + if (type != 0) + abort (); +#pragma omp atomic + cnt++; +} + +template <> +void +f0 (const char *, int type) +{ + if (type != 1) + abort (); +#pragma omp atomic + cnt++; +} + +template +void +f1 () +{ +#pragma omp parallel for + for (int i = 0; i < 10; i++) + f0 (i, 0); +} + +template +void +f2 () +{ +#pragma omp parallel for + for (T i = T (0); i < T (10); i += T (1)) + f0 (i, 0); +} + +void +f3 () +{ +#pragma omp parallel for + for (int i = 0; i < 10; i++) + f0 (i, 0); +} + +const char *p = "abcdefghij"; + +template +void +f4 () +{ +#pragma omp parallel for + for (const char *i = p; i < p + 10; i += 1) + f0 (i, 1); +} + +template +void +f5 () +{ +#pragma omp parallel for + for (T i = T (p); i < T (p + 10); i += 1) + f0 (i, 1); +} + +void +f6 () +{ +#pragma omp parallel for + for (const char *i = p; i < p + 10; i++) + f0 (i, 1); +} + +int +main () +{ + f1 (); + if (cnt != 10) + abort (); + f2 (); + if (cnt != 20) + abort (); + f3 (); + if (cnt != 30) + abort (); + f4 (); + if (cnt != 40) + abort (); + f5 (); + if (cnt != 50) + abort (); + f6 (); + if (cnt != 60) + abort (); +} -- 2.11.0