master_taskloop_simd_reduction_messages.cpp 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352
  1. // RUN: %clang_cc1 -verify -fopenmp -ferror-limit 150 -o - %s -Wuninitialized
  2. // RUN: %clang_cc1 -verify -fopenmp -std=c++98 -ferror-limit 150 -o - %s -Wuninitialized
  3. // RUN: %clang_cc1 -verify -fopenmp -std=c++11 -ferror-limit 150 -o - %s -Wuninitialized
  4. // RUN: %clang_cc1 -verify -fopenmp-simd -ferror-limit 150 -o - %s -Wuninitialized
  5. // RUN: %clang_cc1 -verify -fopenmp-simd -std=c++98 -ferror-limit 150 -o - %s -Wuninitialized
  6. // RUN: %clang_cc1 -verify -fopenmp-simd -std=c++11 -ferror-limit 150 -o - %s -Wuninitialized
  7. typedef void **omp_allocator_handle_t;
  8. extern const omp_allocator_handle_t omp_default_mem_alloc;
  9. extern const omp_allocator_handle_t omp_large_cap_mem_alloc;
  10. extern const omp_allocator_handle_t omp_const_mem_alloc;
  11. extern const omp_allocator_handle_t omp_high_bw_mem_alloc;
  12. extern const omp_allocator_handle_t omp_low_lat_mem_alloc;
  13. extern const omp_allocator_handle_t omp_cgroup_mem_alloc;
  14. extern const omp_allocator_handle_t omp_pteam_mem_alloc;
  15. extern const omp_allocator_handle_t omp_thread_mem_alloc;
  16. void xxx(int argc) {
  17. int fp; // expected-note {{initialize the variable 'fp' to silence this warning}}
  18. #pragma omp master taskloop simd reduction(+:fp) // expected-warning {{variable 'fp' is uninitialized when used here}}
  19. for (int i = 0; i < 10; ++i)
  20. ;
  21. }
  22. void foo() {
  23. }
  24. bool foobool(int argc) {
  25. return argc;
  26. }
  27. void foobar(int &ref) {
  28. #pragma omp master taskloop simd reduction(+:ref)
  29. for (int i = 0; i < 10; ++i)
  30. foo();
  31. }
  32. struct S1; // expected-note {{declared here}} expected-note 4 {{forward declaration of 'S1'}}
  33. extern S1 a;
  34. class S2 {
  35. mutable int a;
  36. S2 &operator+(const S2 &arg) { return (*this); } // expected-note 3 {{implicitly declared private here}}
  37. public:
  38. S2() : a(0) {}
  39. S2(S2 &s2) : a(s2.a) {}
  40. static float S2s; // expected-note 2 {{static data member is predetermined as shared}}
  41. static const float S2sc; // expected-note 2 {{'S2sc' declared here}}
  42. };
  43. const float S2::S2sc = 0;
  44. S2 b; // expected-note 3 {{'b' defined here}}
  45. const S2 ba[5]; // expected-note 2 {{'ba' defined here}}
  46. class S3 {
  47. int a;
  48. public:
  49. int b;
  50. S3() : a(0) {}
  51. S3(const S3 &s3) : a(s3.a) {}
  52. S3 operator+(const S3 &arg1) { return arg1; }
  53. };
  54. int operator+(const S3 &arg1, const S3 &arg2) { return 5; }
  55. S3 c; // expected-note 3 {{'c' defined here}}
  56. const S3 ca[5]; // expected-note 2 {{'ca' defined here}}
  57. extern const int f; // expected-note 4 {{'f' declared here}}
  58. class S4 {
  59. int a;
  60. S4(); // expected-note {{implicitly declared private here}}
  61. S4(const S4 &s4);
  62. S4 &operator+(const S4 &arg) { return (*this); }
  63. public:
  64. S4(int v) : a(v) {}
  65. };
  66. S4 &operator&=(S4 &arg1, S4 &arg2) { return arg1; }
  67. class S5 {
  68. int a;
  69. S5() : a(0) {} // expected-note {{implicitly declared private here}}
  70. S5(const S5 &s5) : a(s5.a) {}
  71. S5 &operator+(const S5 &arg);
  72. public:
  73. S5(int v) : a(v) {}
  74. };
  75. class S6 { // expected-note 3 {{candidate function (the implicit copy assignment operator) not viable: no known conversion from 'int' to 'const S6' for 1st argument}}
  76. #if __cplusplus >= 201103L // C++11 or later
  77. // expected-note@-2 3 {{candidate function (the implicit move assignment operator) not viable}}
  78. #endif
  79. int a;
  80. public:
  81. S6() : a(6) {}
  82. operator int() { return 6; }
  83. } o;
  84. struct S7 {
  85. int a: 32;
  86. S7() {
  87. #pragma omp taskloop reduction(+:a) // expected-error {{expected addressable reduction item for the task-based directives}}
  88. for (int i = 0; i < 10; ++i)
  89. ++a;
  90. }
  91. };
  92. S3 h, k;
  93. #pragma omp threadprivate(h) // expected-note 2 {{defined as threadprivate or thread local}}
  94. template <class T> // expected-note {{declared here}}
  95. T tmain(T argc) {
  96. const T d = T(); // expected-note 4 {{'d' defined here}}
  97. const T da[5] = {T()}; // expected-note 2 {{'da' defined here}}
  98. T qa[5] = {T()};
  99. T i, z;
  100. T &j = i; // expected-note 4 {{'j' defined here}}
  101. S3 &p = k; // expected-note 2 {{'p' defined here}}
  102. const T &r = da[(int)i]; // expected-note 2 {{'r' defined here}}
  103. T &q = qa[(int)i]; // expected-note 2 {{'q' defined here}}
  104. T fl;
  105. #pragma omp master taskloop simd reduction // expected-error {{expected '(' after 'reduction'}}
  106. for (int i = 0; i < 10; ++i)
  107. foo();
  108. #pragma omp master taskloop simd reduction + // expected-error {{expected '(' after 'reduction'}} expected-warning {{extra tokens at the end of '#pragma omp master taskloop simd' are ignored}}
  109. for (int i = 0; i < 10; ++i)
  110. foo();
  111. #pragma omp master taskloop simd reduction( // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected ')'}} expected-note {{to match this '('}}
  112. for (int i = 0; i < 10; ++i)
  113. foo();
  114. #pragma omp master taskloop simd reduction(- // expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
  115. for (int i = 0; i < 10; ++i)
  116. foo();
  117. #pragma omp master taskloop simd reduction() // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}}
  118. for (int i = 0; i < 10; ++i)
  119. foo();
  120. #pragma omp master taskloop simd reduction(*) // expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected expression}}
  121. for (int i = 0; i < 10; ++i)
  122. foo();
  123. #pragma omp master taskloop simd reduction(\) // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}}
  124. for (int i = 0; i < 10; ++i)
  125. foo();
  126. #pragma omp master taskloop simd reduction(& : argc // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{invalid operands to binary expression ('float' and 'float')}}
  127. for (int i = 0; i < 10; ++i)
  128. foo();
  129. #pragma omp master taskloop simd reduction(| : argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{invalid operands to binary expression ('float' and 'float')}}
  130. for (int i = 0; i < 10; ++i)
  131. foo();
  132. #pragma omp master taskloop simd reduction(|| : argc ? i : argc) // expected-error 2 {{expected variable name, array element or array section}}
  133. for (int i = 0; i < 10; ++i)
  134. foo();
  135. #pragma omp master taskloop simd reduction(foo : argc) //expected-error {{incorrect reduction identifier, expected one of '+', '-', '*', '&', '|', '^', '&&', '||', 'min' or 'max' or declare reduction for type 'float'}} expected-error {{incorrect reduction identifier, expected one of '+', '-', '*', '&', '|', '^', '&&', '||', 'min' or 'max' or declare reduction for type 'int'}}
  136. for (int i = 0; i < 10; ++i)
  137. foo();
  138. #pragma omp master taskloop simd reduction(&& : argc) allocate , allocate(, allocate(omp_default , allocate(omp_default_mem_alloc, allocate(omp_default_mem_alloc:, allocate(omp_default_mem_alloc: argc, allocate(omp_default_mem_alloc: argv), allocate(argv) // expected-error {{expected '(' after 'allocate'}} expected-error 2 {{expected expression}} expected-error 2 {{expected ')'}} expected-error {{use of undeclared identifier 'omp_default'}} expected-note 2 {{to match this '('}}
  139. for (int i = 0; i < 10; ++i)
  140. foo();
  141. #pragma omp master taskloop simd reduction(^ : T) // expected-error {{'T' does not refer to a value}}
  142. for (int i = 0; i < 10; ++i)
  143. foo();
  144. #pragma omp master taskloop simd reduction(+ : a, b, c, d, f) // expected-error {{a reduction list item with incomplete type 'S1'}} expected-error 3 {{const-qualified variable cannot be reduction}} expected-error 2 {{'operator+' is a private member of 'S2'}}
  145. for (int i = 0; i < 10; ++i)
  146. foo();
  147. #pragma omp master taskloop simd reduction(min : a, b, c, d, f) // expected-error {{a reduction list item with incomplete type 'S1'}} expected-error 4 {{arguments of OpenMP clause 'reduction' for 'min' or 'max' must be of arithmetic type}} expected-error 3 {{const-qualified variable cannot be reduction}}
  148. for (int i = 0; i < 10; ++i)
  149. foo();
  150. #pragma omp master taskloop simd reduction(max : h.b) // expected-error {{expected variable name, array element or array section}}
  151. for (int i = 0; i < 10; ++i)
  152. foo();
  153. #pragma omp master taskloop simd reduction(+ : ba) // expected-error {{const-qualified variable cannot be reduction}}
  154. for (int i = 0; i < 10; ++i)
  155. foo();
  156. #pragma omp master taskloop simd reduction(* : z, ca) // expected-error {{const-qualified variable cannot be reduction}}
  157. for (int i = 0; i < 10; ++i)
  158. foo();
  159. #pragma omp master taskloop simd reduction(- : da) // expected-error {{const-qualified variable cannot be reduction}} expected-error {{const-qualified variable cannot be reduction}}
  160. for (int i = 0; i < 10; ++i)
  161. foo();
  162. #pragma omp master taskloop simd reduction(^ : fl) // expected-error {{invalid operands to binary expression ('float' and 'float')}}
  163. for (int i = 0; i < 10; ++i)
  164. foo();
  165. #pragma omp master taskloop simd reduction(&& : S2::S2s) // expected-error {{shared variable cannot be reduction}}
  166. for (int i = 0; i < 10; ++i)
  167. foo();
  168. #pragma omp master taskloop simd reduction(&& : S2::S2sc) // expected-error {{const-qualified variable cannot be reduction}}
  169. for (int i = 0; i < 10; ++i)
  170. foo();
  171. #pragma omp master taskloop simd reduction(+ : h, k) // expected-error {{threadprivate or thread local variable cannot be reduction}}
  172. for (int i = 0; i < 10; ++i)
  173. foo();
  174. #pragma omp master taskloop simd reduction(+ : o) // expected-error 2 {{no viable overloaded '='}}
  175. for (int i = 0; i < 10; ++i)
  176. foo();
  177. #pragma omp master taskloop simd private(i), reduction(+ : j), reduction(+ : q) // expected-error 4 {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  178. for (int i = 0; i < 10; ++i)
  179. foo();
  180. #pragma omp parallel private(k)
  181. #pragma omp master taskloop simd reduction(+ : p), reduction(+ : p) // expected-error 2 {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  182. for (int i = 0; i < 10; ++i)
  183. foo();
  184. #pragma omp master taskloop simd reduction(+ : p), reduction(+ : p) // expected-error 2 {{variable can appear only once in OpenMP 'reduction' clause}} expected-note 2 {{previously referenced here}}
  185. for (int i = 0; i < 10; ++i)
  186. foo();
  187. #pragma omp master taskloop simd reduction(+ : r) // expected-error 2 {{const-qualified variable cannot be reduction}}
  188. for (int i = 0; i < 10; ++i)
  189. foo();
  190. #pragma omp parallel shared(i)
  191. #pragma omp parallel reduction(min : i)
  192. #pragma omp master taskloop simd reduction(max : j) // expected-error 2 {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  193. for (int i = 0; i < 10; ++i)
  194. foo();
  195. #pragma omp parallel private(fl)
  196. #pragma omp master taskloop simd reduction(+ : fl) allocate(omp_thread_mem_alloc: fl) // expected-warning 2 {{allocator with the 'thread' trait access has unspecified behavior on 'master taskloop simd' directive}}
  197. for (int i = 0; i < 10; ++i)
  198. foo();
  199. #pragma omp parallel reduction(* : fl)
  200. #pragma omp master taskloop simd reduction(+ : fl)
  201. for (int i = 0; i < 10; ++i)
  202. foo();
  203. return T();
  204. }
  205. namespace A {
  206. double x;
  207. #pragma omp threadprivate(x) // expected-note {{defined as threadprivate or thread local}}
  208. }
  209. namespace B {
  210. using A::x;
  211. }
  212. int main(int argc, char **argv) {
  213. const int d = 5; // expected-note 2 {{'d' defined here}}
  214. const int da[5] = {0}; // expected-note {{'da' defined here}}
  215. int qa[5] = {0};
  216. S4 e(4);
  217. S5 g(5);
  218. int i, z;
  219. int &j = i; // expected-note 2 {{'j' defined here}}
  220. S3 &p = k; // expected-note 2 {{'p' defined here}}
  221. const int &r = da[i]; // expected-note {{'r' defined here}}
  222. int &q = qa[i]; // expected-note {{'q' defined here}}
  223. float fl;
  224. #pragma omp master taskloop simd reduction // expected-error {{expected '(' after 'reduction'}}
  225. for (int i = 0; i < 10; ++i)
  226. foo();
  227. #pragma omp master taskloop simd reduction + // expected-error {{expected '(' after 'reduction'}} expected-warning {{extra tokens at the end of '#pragma omp master taskloop simd' are ignored}}
  228. for (int i = 0; i < 10; ++i)
  229. foo();
  230. #pragma omp master taskloop simd reduction( // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected ')'}} expected-note {{to match this '('}}
  231. for (int i = 0; i < 10; ++i)
  232. foo();
  233. #pragma omp master taskloop simd reduction(- // expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
  234. for (int i = 0; i < 10; ++i)
  235. foo();
  236. #pragma omp master taskloop simd reduction() // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}}
  237. for (int i = 0; i < 10; ++i)
  238. foo();
  239. #pragma omp master taskloop simd reduction(*) // expected-warning {{missing ':' after reduction identifier - ignoring}} expected-error {{expected expression}}
  240. for (int i = 0; i < 10; ++i)
  241. foo();
  242. #pragma omp master taskloop simd reduction(\) // expected-error {{expected unqualified-id}} expected-warning {{missing ':' after reduction identifier - ignoring}}
  243. for (int i = 0; i < 10; ++i)
  244. foo();
  245. #pragma omp master taskloop simd reduction(foo : argc // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{incorrect reduction identifier, expected one of '+', '-', '*', '&', '|', '^', '&&', '||', 'min' or 'max'}}
  246. for (int i = 0; i < 10; ++i)
  247. foo();
  248. #pragma omp master taskloop simd reduction(| : argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
  249. for (int i = 0; i < 10; ++i)
  250. foo();
  251. #pragma omp master taskloop simd reduction(|| : argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name, array element or array section}}
  252. for (int i = 0; i < 10; ++i)
  253. foo();
  254. #pragma omp master taskloop simd reduction(~ : argc) // expected-error {{expected unqualified-id}}
  255. for (int i = 0; i < 10; ++i)
  256. foo();
  257. #pragma omp master taskloop simd reduction(&& : argc, z)
  258. for (int i = 0; i < 10; ++i)
  259. foo();
  260. #pragma omp master taskloop simd reduction(^ : S1) // expected-error {{'S1' does not refer to a value}}
  261. for (int i = 0; i < 10; ++i)
  262. foo();
  263. #pragma omp master taskloop simd reduction(+ : a, b, c, d, f) // expected-error {{a reduction list item with incomplete type 'S1'}} expected-error 2 {{const-qualified variable cannot be reduction}} expected-error {{'operator+' is a private member of 'S2'}}
  264. for (int i = 0; i < 10; ++i)
  265. foo();
  266. #pragma omp master taskloop simd reduction(min : a, b, c, d, f) // expected-error {{a reduction list item with incomplete type 'S1'}} expected-error 2 {{arguments of OpenMP clause 'reduction' for 'min' or 'max' must be of arithmetic type}} expected-error 2 {{const-qualified variable cannot be reduction}}
  267. for (int i = 0; i < 10; ++i)
  268. foo();
  269. #pragma omp master taskloop simd reduction(max : h.b) // expected-error {{expected variable name, array element or array section}}
  270. for (int i = 0; i < 10; ++i)
  271. foo();
  272. #pragma omp master taskloop simd reduction(+ : ba) // expected-error {{const-qualified variable cannot be reduction}}
  273. for (int i = 0; i < 10; ++i)
  274. foo();
  275. #pragma omp master taskloop simd reduction(* : ca) // expected-error {{const-qualified variable cannot be reduction}}
  276. for (int i = 0; i < 10; ++i)
  277. foo();
  278. #pragma omp master taskloop simd reduction(- : da) // expected-error {{const-qualified variable cannot be reduction}}
  279. for (int i = 0; i < 10; ++i)
  280. foo();
  281. #pragma omp master taskloop simd reduction(^ : fl) // expected-error {{invalid operands to binary expression ('float' and 'float')}}
  282. for (int i = 0; i < 10; ++i)
  283. foo();
  284. #pragma omp master taskloop simd reduction(&& : S2::S2s) // expected-error {{shared variable cannot be reduction}}
  285. for (int i = 0; i < 10; ++i)
  286. foo();
  287. #pragma omp master taskloop simd reduction(&& : S2::S2sc) // expected-error {{const-qualified variable cannot be reduction}}
  288. for (int i = 0; i < 10; ++i)
  289. foo();
  290. #pragma omp master taskloop simd reduction(& : e, g) // expected-error {{calling a private constructor of class 'S4'}} expected-error {{invalid operands to binary expression ('S4' and 'S4')}} expected-error {{calling a private constructor of class 'S5'}} expected-error {{invalid operands to binary expression ('S5' and 'S5')}}
  291. for (int i = 0; i < 10; ++i)
  292. foo();
  293. #pragma omp master taskloop simd reduction(+ : h, k, B::x) // expected-error 2 {{threadprivate or thread local variable cannot be reduction}}
  294. for (int i = 0; i < 10; ++i)
  295. foo();
  296. #pragma omp master taskloop simd reduction(+ : o) // expected-error {{no viable overloaded '='}}
  297. for (int i = 0; i < 10; ++i)
  298. foo();
  299. #pragma omp master taskloop simd private(i), reduction(+ : j), reduction(+ : q) // expected-error 2 {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  300. for (int i = 0; i < 10; ++i)
  301. foo();
  302. #pragma omp parallel private(k)
  303. #pragma omp master taskloop simd reduction(+ : p), reduction(+ : p) // expected-error 2 {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  304. for (int i = 0; i < 10; ++i)
  305. foo();
  306. #pragma omp master taskloop simd reduction(+ : p), reduction(+ : p) // expected-error {{variable can appear only once in OpenMP 'reduction' clause}} expected-note {{previously referenced here}}
  307. for (int i = 0; i < 10; ++i)
  308. foo();
  309. #pragma omp master taskloop simd reduction(+ : r) // expected-error {{const-qualified variable cannot be reduction}}
  310. for (int i = 0; i < 10; ++i)
  311. foo();
  312. #pragma omp parallel shared(i)
  313. #pragma omp parallel reduction(min : i)
  314. #pragma omp master taskloop simd reduction(max : j) // expected-error {{argument of OpenMP clause 'reduction' must reference the same object in all threads}}
  315. for (int i = 0; i < 10; ++i)
  316. foo();
  317. #pragma omp parallel private(fl)
  318. #pragma omp master taskloop simd reduction(+ : fl)
  319. for (int i = 0; i < 10; ++i)
  320. foo();
  321. #pragma omp parallel reduction(* : fl)
  322. #pragma omp master taskloop simd reduction(+ : fl)
  323. for (int i = 0; i < 10; ++i)
  324. foo();
  325. static int m;
  326. #pragma omp master taskloop simd reduction(+ : m) // OK
  327. for (int i = 0; i < 10; ++i)
  328. m++;
  329. #pragma omp master taskloop simd reduction(+ : m) nogroup // expected-error {{'reduction' clause cannot be used with 'nogroup' clause}}
  330. for (int i = 0; i < 10; ++i)
  331. m++;
  332. return tmain(argc) + tmain(fl); // expected-note {{in instantiation of function template specialization 'tmain<int>' requested here}} expected-note {{in instantiation of function template specialization 'tmain<float>' requested here}}
  333. }