summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/bfin/builtins/lshl_fr2x16-2.c
blob: c2f13d57e074d08ab8b1734e18d1ea7567738784 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
extern void abort (void);

typedef short  __v2hi __attribute ((vector_size(4)));
typedef __v2hi fract2x16;
typedef short  fract16;

int main ()
{
  fract2x16 a, t;
  fract16 t1, t2;

  a = __builtin_bfin_compose_2x16 (0xcfff, 0xffff);

  t = __builtin_bfin_lshl_fr2x16 (a, -4);
  t1 = __builtin_bfin_extract_hi (t);
  t2 = __builtin_bfin_extract_lo (t);
  if (t1 != 0x0cff || t2 != 0x0fff)
    abort ();

  return 0;
}