summaryrefslogtreecommitdiffstats
path: root/test/CodeGen/hexagon-check-builtins.c
blob: a9294362f6bab142738530a682abdb69174eaffa (plain)
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
// 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);
}