parallel_for_loop_messages.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631
  1. // RUN: %clang_cc1 -fsyntax-only -fopenmp -x c++ -std=c++11 -fexceptions -fcxx-exceptions -verify=expected,omp4 %s -Wuninitialized
  2. // RUN: %clang_cc1 -fsyntax-only -fopenmp -fopenmp-version=50 -x c++ -std=c++11 -fexceptions -fcxx-exceptions -verify=expected,omp5 %s -Wuninitialized
  3. // RUN: %clang_cc1 -fsyntax-only -fopenmp-simd -x c++ -std=c++11 -fexceptions -fcxx-exceptions -verify=expected,omp4 %s -Wuninitialized
  4. // RUN: %clang_cc1 -fsyntax-only -fopenmp-simd -fopenmp-version=50 -x c++ -std=c++11 -fexceptions -fcxx-exceptions -verify=expected,omp5 %s -Wuninitialized
  5. class S {
  6. int a;
  7. S() : a(0) {}
  8. public:
  9. S(int v) : a(v) {}
  10. S(const S &s) : a(s.a) {}
  11. };
  12. static int sii;
  13. // expected-note@+1 {{defined as threadprivate or thread local}}
  14. #pragma omp threadprivate(sii)
  15. static int globalii;
  16. int test_iteration_spaces() {
  17. const int N = 100;
  18. float a[N], b[N], c[N];
  19. int ii, jj, kk;
  20. float fii;
  21. double dii;
  22. #pragma omp parallel for
  23. for (int i = 0; i < 10; i += 1) {
  24. c[i] = a[i] + b[i];
  25. }
  26. #pragma omp parallel for
  27. for (char i = 0; i < 10; i++) {
  28. c[i] = a[i] + b[i];
  29. }
  30. #pragma omp parallel for
  31. for (char i = 0; i < 10; i += '\1') {
  32. c[i] = a[i] + b[i];
  33. }
  34. #pragma omp parallel for
  35. for (long long i = 0; i < 10; i++) {
  36. c[i] = a[i] + b[i];
  37. }
  38. // expected-error@+2 {{expression must have integral or unscoped enumeration type, not 'double'}}
  39. #pragma omp parallel for
  40. for (long long i = 0; i < 10; i += 1.5) {
  41. c[i] = a[i] + b[i];
  42. }
  43. #pragma omp parallel for
  44. for (long long i = 0; i < 'z'; i += 1u) {
  45. c[i] = a[i] + b[i];
  46. }
  47. // expected-error@+2 {{variable must be of integer or random access iterator type}}
  48. #pragma omp parallel for
  49. for (float fi = 0; fi < 10.0; fi++) {
  50. c[(int)fi] = a[(int)fi] + b[(int)fi];
  51. }
  52. // expected-error@+2 {{variable must be of integer or random access iterator type}}
  53. #pragma omp parallel for
  54. for (double fi = 0; fi < 10.0; fi++) {
  55. c[(int)fi] = a[(int)fi] + b[(int)fi];
  56. }
  57. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  58. #pragma omp parallel for
  59. for (int &ref = ii; ref < 10; ref++) {
  60. }
  61. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  62. #pragma omp parallel for
  63. for (int i; i < 10; i++)
  64. c[i] = a[i];
  65. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  66. #pragma omp parallel for
  67. for (int i = 0, j = 0; i < 10; ++i)
  68. c[i] = a[i];
  69. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  70. #pragma omp parallel for
  71. for (; ii < 10; ++ii)
  72. c[ii] = a[ii];
  73. // expected-warning@+3 {{expression result unused}}
  74. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  75. #pragma omp parallel for
  76. for (ii + 1; ii < 10; ++ii)
  77. c[ii] = a[ii];
  78. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  79. #pragma omp parallel for
  80. for (c[ii] = 0; ii < 10; ++ii)
  81. c[ii] = a[ii];
  82. // Ok to skip parenthesises.
  83. #pragma omp parallel for
  84. for (((ii)) = 0; ii < 10; ++ii)
  85. c[ii] = a[ii];
  86. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'i'}}
  87. #pragma omp parallel for
  88. for (int i = 0; i; i++)
  89. c[i] = a[i];
  90. // omp4-error@+3 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}} omp5-error@+3 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'i'}}
  91. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'i'}}
  92. #pragma omp parallel for
  93. for (int i = 0; jj < kk; ii++)
  94. c[i] = a[i];
  95. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'i'}}
  96. #pragma omp parallel for
  97. for (int i = 0; !!i; i++)
  98. c[i] = a[i];
  99. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}}
  100. #pragma omp parallel for
  101. for (int i = 0; i != 1; i++)
  102. c[i] = a[i];
  103. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'i'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'i'}}
  104. #pragma omp parallel for
  105. for (int i = 0;; i++)
  106. c[i] = a[i];
  107. // Ok.
  108. #pragma omp parallel for
  109. for (int i = 11; i > 10; i--)
  110. c[i] = a[i];
  111. // Ok.
  112. #pragma omp parallel for
  113. for (int i = 0; i < 10; ++i)
  114. c[i] = a[i];
  115. // Ok.
  116. #pragma omp parallel for
  117. for (ii = 0; ii < 10; ++ii)
  118. c[ii] = a[ii];
  119. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  120. #pragma omp parallel for
  121. for (ii = 0; ii < 10; ++jj)
  122. c[ii] = a[jj];
  123. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  124. #pragma omp parallel for
  125. for (ii = 0; ii < 10; ++++ii)
  126. c[ii] = a[ii];
  127. // Ok but undefined behavior (in general, cannot check that incr
  128. // is really loop-invariant).
  129. #pragma omp parallel for
  130. for (ii = 0; ii < 10; ii = ii + ii)
  131. c[ii] = a[ii];
  132. // expected-error@+2 {{expression must have integral or unscoped enumeration type, not 'float'}}
  133. #pragma omp parallel for
  134. for (ii = 0; ii < 10; ii = ii + 1.0f)
  135. c[ii] = a[ii];
  136. // Ok - step was converted to integer type.
  137. #pragma omp parallel for
  138. for (ii = 0; ii < 10; ii = ii + (int)1.1f)
  139. c[ii] = a[ii];
  140. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  141. #pragma omp parallel for
  142. for (ii = 0; ii < 10; jj = ii + 2)
  143. c[ii] = a[ii];
  144. // expected-warning@+3 {{relational comparison result unused}}
  145. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  146. #pragma omp parallel for
  147. for (ii = 0; ii<10; jj> kk + 2)
  148. c[ii] = a[ii];
  149. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  150. #pragma omp parallel for
  151. for (ii = 0; ii < 10;)
  152. c[ii] = a[ii];
  153. // expected-warning@+3 {{expression result unused}}
  154. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  155. #pragma omp parallel for
  156. for (ii = 0; ii < 10; !ii)
  157. c[ii] = a[ii];
  158. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  159. #pragma omp parallel for
  160. for (ii = 0; ii < 10; ii ? ++ii : ++jj)
  161. c[ii] = a[ii];
  162. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'ii'}}
  163. #pragma omp parallel for
  164. for (ii = 0; ii < 10; ii = ii < 10)
  165. c[ii] = a[ii];
  166. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  167. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  168. #pragma omp parallel for
  169. for (ii = 0; ii < 10; ii = ii + 0)
  170. c[ii] = a[ii];
  171. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  172. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  173. #pragma omp parallel for
  174. for (ii = 0; ii < 10; ii = ii + (int)(0.8 - 0.45))
  175. c[ii] = a[ii];
  176. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  177. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  178. #pragma omp parallel for
  179. for (ii = 0; (ii) < 10; ii -= 25)
  180. c[ii] = a[ii];
  181. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  182. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  183. #pragma omp parallel for
  184. for (ii = 0; (ii < 10); ii -= 0)
  185. c[ii] = a[ii];
  186. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  187. // expected-error@+2 {{increment expression must cause 'ii' to decrease on each iteration of OpenMP for loop}}
  188. #pragma omp parallel for
  189. for (ii = 0; ii > 10; (ii += 0))
  190. c[ii] = a[ii];
  191. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  192. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  193. #pragma omp parallel for
  194. for (ii = 0; ii < 10; (ii) = (1 - 1) + (ii))
  195. c[ii] = a[ii];
  196. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  197. // expected-error@+2 {{increment expression must cause 'ii' to decrease on each iteration of OpenMP for loop}}
  198. #pragma omp parallel for
  199. for ((ii = 0); ii > 10; (ii -= 0))
  200. c[ii] = a[ii];
  201. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  202. // expected-error@+2 {{increment expression must cause 'ii' to increase on each iteration of OpenMP for loop}}
  203. #pragma omp parallel for
  204. for (ii = 0; (ii < 10); (ii -= 0))
  205. c[ii] = a[ii];
  206. // expected-note@+2 {{defined as firstprivate}}
  207. // expected-error@+2 {{loop iteration variable in the associated loop of 'omp parallel for' directive may not be firstprivate, predetermined as private}}
  208. #pragma omp parallel for firstprivate(ii)
  209. for (ii = 0; ii < 10; ii++)
  210. c[ii] = a[ii];
  211. // expected-note@+2 {{defined as linear}}
  212. // expected-error@+2 {{loop iteration variable in the associated loop of 'omp parallel for' directive may not be linear, predetermined as private}}
  213. #pragma omp parallel for linear(ii)
  214. for (ii = 0; ii < 10; ii++)
  215. c[ii] = a[ii];
  216. #pragma omp parallel for private(ii)
  217. for (ii = 0; ii < 10; ii++)
  218. c[ii] = a[ii];
  219. #pragma omp parallel for lastprivate(ii)
  220. for (ii = 0; ii < 10; ii++)
  221. c[ii] = a[ii];
  222. {
  223. // expected-error@+2 {{loop iteration variable in the associated loop of 'omp parallel for' directive may not be threadprivate or thread local, predetermined as private}}
  224. #pragma omp parallel for
  225. for (sii = 0; sii < 10; sii += 1)
  226. c[sii] = a[sii];
  227. }
  228. {
  229. #pragma omp parallel for
  230. for (globalii = 0; globalii < 10; globalii += 1)
  231. c[globalii] = a[globalii];
  232. }
  233. {
  234. #pragma omp parallel for collapse(2)
  235. for (ii = 0; ii < 10; ii += 1)
  236. for (globalii = 0; globalii < 10; globalii += 1)
  237. c[globalii] += a[globalii] + ii;
  238. }
  239. // expected-error@+2 {{statement after '#pragma omp parallel for' must be a for loop}}
  240. #pragma omp parallel for
  241. for (auto &item : a) {
  242. item = item + 1;
  243. }
  244. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  245. // expected-error@+2 {{increment expression must cause 'i' to increase on each iteration of OpenMP for loop}}
  246. #pragma omp parallel for
  247. for (unsigned i = 9; i < 10; i--) {
  248. c[i] = a[i] + b[i];
  249. }
  250. int(*lb)[4] = nullptr;
  251. #pragma omp parallel for
  252. for (int(*p)[4] = lb; p < lb + 8; ++p) {
  253. }
  254. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  255. #pragma omp parallel for
  256. for (int a{0}; a < 10; ++a) {
  257. }
  258. return 0;
  259. }
  260. // Iterators allowed in openmp for-loops.
  261. namespace std {
  262. struct random_access_iterator_tag {};
  263. template <class Iter>
  264. struct iterator_traits {
  265. typedef typename Iter::difference_type difference_type;
  266. typedef typename Iter::iterator_category iterator_category;
  267. };
  268. template <class Iter>
  269. typename iterator_traits<Iter>::difference_type
  270. distance(Iter first, Iter last) { return first - last; }
  271. }
  272. class Iter0 {
  273. public:
  274. Iter0() {}
  275. Iter0(const Iter0 &) {}
  276. Iter0 operator++() { return *this; }
  277. Iter0 operator--() { return *this; }
  278. bool operator<(Iter0 a) { return true; }
  279. };
  280. // expected-note@+2 {{candidate function not viable: no known conversion from 'GoodIter' to 'Iter0' for 1st argument}}
  281. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter1' to 'Iter0' for 1st argument}}
  282. int operator-(Iter0 a, Iter0 b) { return 0; }
  283. class Iter1 {
  284. public:
  285. Iter1(float f = 0.0f, double d = 0.0) {}
  286. Iter1(const Iter1 &) {}
  287. Iter1 operator++() { return *this; }
  288. Iter1 operator--() { return *this; }
  289. bool operator<(Iter1 a) { return true; }
  290. bool operator>=(Iter1 a) { return false; }
  291. };
  292. class GoodIter {
  293. public:
  294. GoodIter() {}
  295. GoodIter(const GoodIter &) {}
  296. GoodIter(int fst, int snd) {}
  297. GoodIter &operator=(const GoodIter &that) { return *this; }
  298. GoodIter &operator=(const Iter0 &that) { return *this; }
  299. GoodIter &operator+=(int x) { return *this; }
  300. GoodIter &operator-=(int x) { return *this; }
  301. explicit GoodIter(void *) {}
  302. GoodIter operator++() { return *this; }
  303. GoodIter operator--() { return *this; }
  304. bool operator!() { return true; }
  305. bool operator<(GoodIter a) { return true; }
  306. bool operator<=(GoodIter a) { return true; }
  307. bool operator>=(GoodIter a) { return false; }
  308. typedef int difference_type;
  309. typedef std::random_access_iterator_tag iterator_category;
  310. };
  311. // expected-note@+2 {{candidate function not viable: no known conversion from 'const Iter0' to 'GoodIter' for 2nd argument}}
  312. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter1' to 'GoodIter' for 1st argument}}
  313. int operator-(GoodIter a, GoodIter b) { return 0; }
  314. // expected-note@+1 3 {{candidate function not viable: requires single argument 'a', but 2 arguments were provided}}
  315. GoodIter operator-(GoodIter a) { return a; }
  316. // expected-note@+2 {{candidate function not viable: no known conversion from 'const Iter0' to 'int' for 2nd argument}}
  317. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter1' to 'GoodIter' for 1st argument}}
  318. GoodIter operator-(GoodIter a, int v) { return GoodIter(); }
  319. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter0' to 'GoodIter' for 1st argument}}
  320. GoodIter operator+(GoodIter a, int v) { return GoodIter(); }
  321. // expected-note@+2 {{candidate function not viable: no known conversion from 'GoodIter' to 'int' for 1st argument}}
  322. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter1' to 'int' for 1st argument}}
  323. GoodIter operator-(int v, GoodIter a) { return GoodIter(); }
  324. // expected-note@+1 2 {{candidate function not viable: no known conversion from 'Iter0' to 'int' for 1st argument}}
  325. GoodIter operator+(int v, GoodIter a) { return GoodIter(); }
  326. int test_with_random_access_iterator() {
  327. GoodIter begin, end;
  328. Iter0 begin0, end0;
  329. #pragma omp parallel for
  330. for (GoodIter I = begin; I < end; ++I)
  331. ++I;
  332. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  333. #pragma omp parallel for
  334. for (GoodIter &I = begin; I < end; ++I)
  335. ++I;
  336. #pragma omp parallel for
  337. for (GoodIter I = begin; I >= end; --I)
  338. ++I;
  339. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  340. #pragma omp parallel for
  341. for (GoodIter I(begin); I < end; ++I)
  342. ++I;
  343. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  344. #pragma omp parallel for
  345. for (GoodIter I(nullptr); I < end; ++I)
  346. ++I;
  347. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  348. #pragma omp parallel for
  349. for (GoodIter I(0); I < end; ++I)
  350. ++I;
  351. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  352. #pragma omp parallel for
  353. for (GoodIter I(1, 2); I < end; ++I)
  354. ++I;
  355. #pragma omp parallel for
  356. for (begin = GoodIter(0); begin < end; ++begin)
  357. ++begin;
  358. // expected-error@+3 {{invalid operands to binary expression ('GoodIter' and 'const Iter0')}}
  359. // expected-error@+2 {{could not calculate number of iterations calling 'operator-' with upper and lower loop bounds}}
  360. #pragma omp parallel for
  361. for (begin = begin0; begin < end; ++begin)
  362. ++begin;
  363. // expected-error@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  364. #pragma omp parallel for
  365. for (++begin; begin < end; ++begin)
  366. ++begin;
  367. #pragma omp parallel for
  368. for (begin = end; begin < end; ++begin)
  369. ++begin;
  370. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'I'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'I'}}
  371. #pragma omp parallel for
  372. for (GoodIter I = begin; I - I; ++I)
  373. ++I;
  374. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'I'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'I'}}
  375. #pragma omp parallel for
  376. for (GoodIter I = begin; begin < end; ++I)
  377. ++I;
  378. // omp4-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', or '>=') of loop variable 'I'}} omp5-error@+2 {{condition of OpenMP for loop must be a relational comparison ('<', '<=', '>', '>=', or '!=') of loop variable 'I'}}
  379. #pragma omp parallel for
  380. for (GoodIter I = begin; !I; ++I)
  381. ++I;
  382. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  383. // expected-error@+2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  384. #pragma omp parallel for
  385. for (GoodIter I = begin; I >= end; I = I + 1)
  386. ++I;
  387. #pragma omp parallel for
  388. for (GoodIter I = begin; I >= end; I = I - 1)
  389. ++I;
  390. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'I'}}
  391. #pragma omp parallel for
  392. for (GoodIter I = begin; I >= end; I = -I)
  393. ++I;
  394. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  395. // expected-error@+2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  396. #pragma omp parallel for
  397. for (GoodIter I = begin; I >= end; I = 2 + I)
  398. ++I;
  399. // expected-error@+2 {{increment clause of OpenMP for loop must perform simple addition or subtraction on loop variable 'I'}}
  400. #pragma omp parallel for
  401. for (GoodIter I = begin; I >= end; I = 2 - I)
  402. ++I;
  403. // expected-error@+2 {{invalid operands to binary expression ('Iter0' and 'int')}}
  404. #pragma omp parallel for
  405. for (Iter0 I = begin0; I < end0; ++I)
  406. ++I;
  407. // Initializer is constructor without params.
  408. // expected-error@+3 {{invalid operands to binary expression ('Iter0' and 'int')}}
  409. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  410. #pragma omp parallel for
  411. for (Iter0 I; I < end0; ++I)
  412. ++I;
  413. Iter1 begin1, end1;
  414. // expected-error@+3 {{invalid operands to binary expression ('Iter1' and 'Iter1')}}
  415. // expected-error@+2 {{could not calculate number of iterations calling 'operator-' with upper and lower loop bounds}}
  416. #pragma omp parallel for
  417. for (Iter1 I = begin1; I < end1; ++I)
  418. ++I;
  419. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  420. // expected-error@+2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  421. #pragma omp parallel for
  422. for (Iter1 I = begin1; I >= end1; ++I)
  423. ++I;
  424. // expected-error@+5 {{invalid operands to binary expression ('Iter1' and 'float')}}
  425. // expected-error@+4 {{could not calculate number of iterations calling 'operator-' with upper and lower loop bounds}}
  426. // Initializer is constructor with all default params.
  427. // expected-warning@+2 {{initialization clause of OpenMP for loop is not in canonical form ('var = init' or 'T var = init')}}
  428. #pragma omp parallel for
  429. for (Iter1 I; I < end1; ++I) {
  430. }
  431. return 0;
  432. }
  433. template <typename IT, int ST>
  434. class TC {
  435. public:
  436. int dotest_lt(IT begin, IT end) {
  437. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  438. // expected-error@+2 {{increment expression must cause 'I' to increase on each iteration of OpenMP for loop}}
  439. #pragma omp parallel for
  440. for (IT I = begin; I < end; I = I + ST) {
  441. ++I;
  442. }
  443. // expected-note@+3 {{loop step is expected to be positive due to this condition}}
  444. // expected-error@+2 {{increment expression must cause 'I' to increase on each iteration of OpenMP for loop}}
  445. #pragma omp parallel for
  446. for (IT I = begin; I <= end; I += ST) {
  447. ++I;
  448. }
  449. #pragma omp parallel for
  450. for (IT I = begin; I < end; ++I) {
  451. ++I;
  452. }
  453. }
  454. static IT step() {
  455. return IT(ST);
  456. }
  457. };
  458. template <typename IT, int ST = 0>
  459. int dotest_gt(IT begin, IT end) {
  460. // expected-note@+3 2 {{loop step is expected to be negative due to this condition}}
  461. // expected-error@+2 2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  462. #pragma omp parallel for
  463. for (IT I = begin; I >= end; I = I + ST) {
  464. ++I;
  465. }
  466. // expected-note@+3 2 {{loop step is expected to be negative due to this condition}}
  467. // expected-error@+2 2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  468. #pragma omp parallel for
  469. for (IT I = begin; I >= end; I += ST) {
  470. ++I;
  471. }
  472. // expected-note@+3 {{loop step is expected to be negative due to this condition}}
  473. // expected-error@+2 {{increment expression must cause 'I' to decrease on each iteration of OpenMP for loop}}
  474. #pragma omp parallel for
  475. for (IT I = begin; I >= end; ++I) {
  476. ++I;
  477. }
  478. #pragma omp parallel for
  479. for (IT I = begin; I < end; I += TC<int, ST>::step()) {
  480. ++I;
  481. }
  482. }
  483. void test_with_template() {
  484. GoodIter begin, end;
  485. TC<GoodIter, 100> t1;
  486. TC<GoodIter, -100> t2;
  487. t1.dotest_lt(begin, end);
  488. t2.dotest_lt(begin, end); // expected-note {{in instantiation of member function 'TC<GoodIter, -100>::dotest_lt' requested here}}
  489. dotest_gt(begin, end); // expected-note {{in instantiation of function template specialization 'dotest_gt<GoodIter, 0>' requested here}}
  490. dotest_gt<unsigned, 10>(0, 100); // expected-note {{in instantiation of function template specialization 'dotest_gt<unsigned int, 10>' requested here}}
  491. }
  492. void test_loop_break() {
  493. const int N = 100;
  494. float a[N], b[N], c[N];
  495. #pragma omp parallel for
  496. for (int i = 0; i < 10; i++) {
  497. c[i] = a[i] + b[i];
  498. for (int j = 0; j < 10; ++j) {
  499. if (a[i] > b[j])
  500. break; // OK in nested loop
  501. }
  502. switch (i) {
  503. case 1:
  504. b[i]++;
  505. break;
  506. default:
  507. break;
  508. }
  509. if (c[i] > 10)
  510. break; // expected-error {{'break' statement cannot be used in OpenMP for loop}}
  511. if (c[i] > 11)
  512. break; // expected-error {{'break' statement cannot be used in OpenMP for loop}}
  513. }
  514. #pragma omp parallel for
  515. for (int i = 0; i < 10; i++) {
  516. for (int j = 0; j < 10; j++) {
  517. c[i] = a[i] + b[i];
  518. if (c[i] > 10) {
  519. if (c[i] < 20) {
  520. break; // OK
  521. }
  522. }
  523. }
  524. }
  525. }
  526. void test_loop_eh() {
  527. const int N = 100;
  528. float a[N], b[N], c[N];
  529. #pragma omp parallel for
  530. for (int i = 0; i < 10; i++) {
  531. c[i] = a[i] + b[i];
  532. try {
  533. for (int j = 0; j < 10; ++j) {
  534. if (a[i] > b[j])
  535. throw a[i];
  536. }
  537. throw a[i];
  538. } catch (float f) {
  539. if (f > 0.1)
  540. throw a[i];
  541. return; // expected-error {{cannot return from OpenMP region}}
  542. }
  543. switch (i) {
  544. case 1:
  545. b[i]++;
  546. break;
  547. default:
  548. break;
  549. }
  550. for (int j = 0; j < 10; j++) {
  551. if (c[i] > 10)
  552. throw c[i];
  553. }
  554. }
  555. if (c[9] > 10)
  556. throw c[9]; // OK
  557. #pragma omp parallel for
  558. for (int i = 0; i < 10; ++i) {
  559. struct S {
  560. void g() { throw 0; }
  561. };
  562. }
  563. }
  564. void test_loop_firstprivate_lastprivate() {
  565. S s(4);
  566. #pragma omp parallel for lastprivate(s) firstprivate(s)
  567. for (int i = 0; i < 16; ++i)
  568. ;
  569. }