summaryrefslogtreecommitdiffstats
path: root/clang/test/OpenMP/atomic_messages.c
diff options
context:
space:
mode:
authorAlexey Bataev <a.bataev@hotmail.com>2019-07-11 14:54:17 +0000
committerAlexey Bataev <a.bataev@hotmail.com>2019-07-11 14:54:17 +0000
commitc2c21ef9d2b37da6a8cc6322e4cd13fff3fe10b3 (patch)
tree1a076924f9da09097dad43e9caa807bc8250b594 /clang/test/OpenMP/atomic_messages.c
parentd0307f93a7658e6d0eef1ffd0b0ed4f1506bfc13 (diff)
downloadbcm5719-llvm-c2c21ef9d2b37da6a8cc6322e4cd13fff3fe10b3.tar.gz
bcm5719-llvm-c2c21ef9d2b37da6a8cc6322e4cd13fff3fe10b3.zip
[OPENMP]Initial fix PR42392: Improve -Wuninitialized warnings for OpenMP programs.
Summary: Some OpenMP clauses rely on the values of the variables. If the variable is not initialized and used in OpenMP clauses that depend on the variables values, it should be reported that the uninitialized variable is used in the OpenMP clause expression. This patch adds initial processing for uninitialized variables in OpenMP constructs. Currently, it checks for use of the uninitialized variables in the structured blocks. Reviewers: NoQ, Szelethus, dcoughlin, xazax.hun, a.sidorin, george.karpenkov, szepet Subscribers: rnkovacs, guansong, jfb, jdoerfert, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D64356 llvm-svn: 365786
Diffstat (limited to 'clang/test/OpenMP/atomic_messages.c')
-rw-r--r--clang/test/OpenMP/atomic_messages.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/clang/test/OpenMP/atomic_messages.c b/clang/test/OpenMP/atomic_messages.c
index bace18aba9e..abc703d578d 100644
--- a/clang/test/OpenMP/atomic_messages.c
+++ b/clang/test/OpenMP/atomic_messages.c
@@ -2,6 +2,12 @@
// RUN: %clang_cc1 -verify -fopenmp-simd -ferror-limit 100 %s -Wuninitialized
+void xxx(int argc) {
+ int x; // expected-note {{initialize the variable 'x' to silence this warning}}
+#pragma omp atomic read
+ argc = x; // expected-warning {{variable 'x' is uninitialized when used here}}
+}
+
int foo() {
L1:
foo();
OpenPOWER on IntegriCloud