aboutsummaryrefslogtreecommitdiff
path: root/test/CodeGen/hexagon-check-builtins.c
diff options
context:
space:
mode:
Diffstat (limited to 'test/CodeGen/hexagon-check-builtins.c')
-rw-r--r--test/CodeGen/hexagon-check-builtins.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/test/CodeGen/hexagon-check-builtins.c b/test/CodeGen/hexagon-check-builtins.c
new file mode 100644
index 000000000000..a9294362f6ba
--- /dev/null
+++ b/test/CodeGen/hexagon-check-builtins.c
@@ -0,0 +1,30 @@
+// REQUIRES: hexagon-registered-target
+// RUN: %clang_cc1 -fsyntax-only -triple hexagon-unknown-elf -verify %s
+
+int foo(int x) {
+ // expected-error-re@+2 {{argument value {{.*}} is outside the valid range}}
+ // expected-error-re@+1 {{argument value {{.*}} is outside the valid range}}
+ return __builtin_HEXAGON_S4_extract(x, 33, -1) +
+ // expected-error-re@+1 {{argument value {{.*}} is outside the valid range}}
+ __builtin_HEXAGON_S4_extract(x, 3, 91) +
+ // expected-error-re@+2 {{argument value {{.*}} is outside the valid range}}
+ // expected-error-re@+1 {{argument value {{.*}} is outside the valid range}}
+ __builtin_HEXAGON_S4_extract(x, -1, 35) +
+ __builtin_HEXAGON_S4_extract(x, 0, 31) +
+ __builtin_HEXAGON_S4_extract(x, 31, 0);
+}
+
+int bar(void *p, void *q, int x) {
+ // expected-error@+1 {{argument should be a multiple of 4}}
+ return __builtin_HEXAGON_L2_loadri_pci(p, -1, x, q) +
+ // expected-error-re@+2 {{argument value {{.*}} is outside the valid range}}
+ // expected-error@+1 {{argument should be a multiple of 4}}
+ __builtin_HEXAGON_L2_loadri_pci(p, -99, x, q) +
+ // expected-error-re@+1 {{argument value {{.*}} is outside the valid range}}
+ __builtin_HEXAGON_L2_loadri_pci(p, -132, x, q) +
+ __builtin_HEXAGON_L2_loadri_pci(p, 28, x, q) +
+ // expected-error-re@+2 {{argument value {{.*}} is outside the valid range}}
+ // expected-error@+1 {{argument should be a multiple of 4}}
+ __builtin_HEXAGON_L2_loadri_pci(p, 29, x, q);
+}
+