mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-10 18:11:19 +00:00
dc5ce72afa
Recommit of r335084 after revert in r335516. ... instead of prepending it at the beginning (the original behavior since implemented in r122535 2010-12-23). This builds up an AttributeList in the the order in which the attributes appear in the source. The reverse order caused nodes for attributes in the AST (e.g. LoopHint) to be in the reverse order, and therefore printed in the wrong order in -ast-dump. Some TODO comments mention this. The order was explicitly reversed for enable_if attribute overload resolution and name mangling, which is not necessary anymore with this patch. The change unfortunately has some secondary effect, especially on diagnostic output. In the simplest cases, the CHECK lines or expected diagnostic were changed to the the new output. If the kind of error/warning changed, the attributes' order was changed instead. This unfortunately causes some 'previous occurrence here' hints to be textually after the main marker. This typically happens when attributes are merged, but are incompatible to each other. Interchanging the role of the the main and note SourceLocation will also cause the case where two different declaration's attributes (in contrast to multiple attributes of the same declaration) are merged to be reverse. There is no easy fix because sometimes previous attributes are merged into a new declaration's attribute list, sometimes new attributes are added to a previous declaration's attribute list. Since 'previous occurrence here' pointing to locations after the main marker is not rare, I left the markers as-is; it is only relevant when the attributes are declared in the same declaration anyway. Differential Revision: https://reviews.llvm.org/D48100 llvm-svn: 338800
115 lines
2.6 KiB
C++
115 lines
2.6 KiB
C++
// RUN: %clang_cc1 -emit-pch -o %t.a %s
|
|
// RUN: %clang_cc1 -include-pch %t.a %s -ast-print -o - | FileCheck %s
|
|
|
|
// CHECK: #pragma clang loop vectorize_width(4)
|
|
// CHECK: #pragma clang loop interleave_count(8)
|
|
// CHECK: #pragma clang loop unroll_count(16){{$}}
|
|
// CHECK: #pragma clang loop vectorize(enable)
|
|
// CHECK: #pragma clang loop interleave(disable)
|
|
// CHECK: #pragma clang loop unroll(disable)
|
|
// CHECK: #pragma clang loop distribute(enable)
|
|
// CHECK: #pragma clang loop vectorize(disable)
|
|
// CHECK: #pragma clang loop interleave(enable)
|
|
// CHECK: #pragma clang loop unroll(full)
|
|
// CHECK: #pragma clang loop distribute(disable)
|
|
// FIXME: "#pragma unroll (enable)" is invalid and is not the input source.
|
|
// CHECK: #pragma unroll (enable){{$}}
|
|
// CHECK: #pragma unroll (32){{$}}
|
|
// CHECK: #pragma nounroll{{$}}
|
|
// CHECK: #pragma clang loop vectorize_width(V)
|
|
// CHECK: #pragma clang loop interleave_count(I)
|
|
|
|
#ifndef HEADER
|
|
#define HEADER
|
|
|
|
class pragma_test {
|
|
public:
|
|
inline void run1(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma clang loop vectorize_width(4)
|
|
#pragma clang loop interleave_count(8)
|
|
#pragma clang loop unroll_count(16)
|
|
while (i < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
inline void run2(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma clang loop vectorize(enable)
|
|
#pragma clang loop interleave(disable)
|
|
#pragma clang loop unroll(disable)
|
|
#pragma clang loop distribute(enable)
|
|
while (i - 1 < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
inline void run3(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma clang loop vectorize(disable)
|
|
#pragma clang loop interleave(enable)
|
|
#pragma clang loop unroll(full)
|
|
#pragma clang loop distribute(disable)
|
|
while (i - 3 < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
inline void run4(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma unroll
|
|
while (i - 3 < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
inline void run5(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma unroll 32
|
|
while (i - 3 < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
inline void run6(int *List, int Length) {
|
|
int i = 0;
|
|
#pragma nounroll
|
|
while (i - 3 < Length) {
|
|
List[i] = i;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
template <int V, int I>
|
|
inline void run7(int *List, int Length) {
|
|
#pragma clang loop vectorize_width(V)
|
|
#pragma clang loop interleave_count(I)
|
|
for (int i = 0; i < Length; i++) {
|
|
List[i] = i;
|
|
}
|
|
}
|
|
};
|
|
#else
|
|
|
|
void test() {
|
|
int List[100];
|
|
|
|
pragma_test pt;
|
|
|
|
pt.run1(List, 100);
|
|
pt.run2(List, 100);
|
|
pt.run3(List, 100);
|
|
pt.run4(List, 100);
|
|
pt.run5(List, 100);
|
|
pt.run6(List, 100);
|
|
pt.run7<2, 4>(List, 100);
|
|
}
|
|
|
|
#endif
|