| // 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); |
| } |
| |