1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
|
// RUN: %clang_cc1 %s -fopenacc -verify
struct S {
int IntMem;
int *PtrMem;
operator int*();
};
void uses() {
int LocalInt;
int *LocalPtr;
int Array[5];
int *PtrArray[5];
struct S s;
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(LocalInt)
while (true);
#pragma acc parallel attach(LocalPtr)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int[5]'}}
#pragma acc parallel attach(Array)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(Array[0])
while (true);
// expected-error@+2{{OpenACC sub-array is not allowed here}}
// expected-note@+1{{expected variable of pointer type}}
#pragma acc parallel attach(Array[0:1])
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int *[5]'}}
#pragma acc parallel attach(PtrArray)
while (true);
#pragma acc parallel attach(PtrArray[0])
while (true);
// expected-error@+2{{OpenACC sub-array is not allowed here}}
// expected-note@+1{{expected variable of pointer type}}
#pragma acc parallel attach(PtrArray[0:1])
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'struct S'}}
#pragma acc parallel attach(s)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(s.IntMem)
while (true);
#pragma acc parallel attach(s.PtrMem)
while (true);
}
template<typename T, typename TPtr, typename TStruct, auto &R1>
void Templ() {
T SomeInt;
TPtr SomePtr;
T SomeIntArray[5];
TPtr SomeIntPtrArray[5];
TStruct SomeStruct;
// expected-error@+2{{expected pointer in 'attach' clause, type is 'int'}}
// expected-note@#INST{{in instantiation of function template specialization}}
#pragma acc parallel attach(SomeInt)
while (true);
#pragma acc parallel attach(SomePtr)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int[5]'}}
#pragma acc parallel attach(SomeIntArray)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(SomeIntArray[0])
while (true);
// expected-error@+2{{OpenACC sub-array is not allowed here}}
// expected-note@+1{{expected variable of pointer type}}
#pragma acc parallel attach(SomeIntArray[0:1])
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int *[5]'}}
#pragma acc parallel attach(SomeIntPtrArray)
while (true);
#pragma acc parallel attach(SomeIntPtrArray[0])
while (true);
// expected-error@+2{{OpenACC sub-array is not allowed here}}
// expected-note@+1{{expected variable of pointer type}}
#pragma acc parallel attach(SomeIntPtrArray[0:1])
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'S'}}
#pragma acc parallel attach(SomeStruct)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(SomeStruct.IntMem)
while (true);
#pragma acc parallel attach(SomeStruct.PtrMem)
while (true);
// expected-error@+1{{expected pointer in 'attach' clause, type is 'int'}}
#pragma acc parallel attach(R1)
while (true);
}
void inst() {
static constexpr int CEVar = 1;
Templ<int, int*, S, CEVar>(); // #INST
}
|