|  | // { dg-do run } | 
|  |  | 
|  | extern "C" void abort (); | 
|  | int cnt; | 
|  |  | 
|  | int | 
|  | foo () | 
|  | { | 
|  | return cnt++; | 
|  | } | 
|  |  | 
|  | template <typename T> | 
|  | void | 
|  | bar () | 
|  | { | 
|  | extern T x; | 
|  | T v, *p; | 
|  | p = &x; | 
|  | #pragma omp atomic update | 
|  | p[foo (), 0] = 16 + 6 - p[foo (), 0]; | 
|  | #pragma omp atomic read | 
|  | v = x; | 
|  | if (cnt != 2 || v != 16) | 
|  | abort (); | 
|  | #pragma omp atomic capture | 
|  | v = p[foo () + foo (), 0] = p[foo () + foo (), 0] + 3; | 
|  | if (cnt != 6 || v != 19) | 
|  | abort (); | 
|  | #pragma omp atomic capture | 
|  | v = p[foo (), 0] = 12 * 1 / 2 + (foo (), 0) + p[foo (), 0]; | 
|  | if (cnt != 9 || v != 25) | 
|  | abort (); | 
|  | #pragma omp atomic capture | 
|  | { | 
|  | v = p[foo () & 0]; p[foo () & 0] = (foo (), 1) * 9 - p[foo () & 0]; | 
|  | } | 
|  | if (cnt != 13 || v != 25) | 
|  | abort (); | 
|  | #pragma omp atomic read | 
|  | v = x; | 
|  | if (v != -16) | 
|  | abort (); | 
|  | #pragma omp atomic capture | 
|  | { | 
|  | p[0 & foo ()] = 16 - 2 + 3 + p[0 & foo ()]; v = p[0 & foo ()]; | 
|  | } | 
|  | if (cnt != 16 || v != 1) | 
|  | abort (); | 
|  | #pragma omp atomic capture | 
|  | { | 
|  | v = p[foo (), 0]; p[foo (), 0] = (foo (), 7) ? 13 : foo () + 6; | 
|  | } | 
|  | if (cnt != 19 || v != 1) | 
|  | abort (); | 
|  | #pragma omp atomic read | 
|  | v = x; | 
|  | if (v != 13) | 
|  | abort (); | 
|  | } | 
|  |  | 
|  | int x = 6; | 
|  |  | 
|  | int | 
|  | main () | 
|  | { | 
|  | bar <int> (); | 
|  | return 0; | 
|  | } |