aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.8.1/gcc/testsuite/gcc.target/bfin/builtins/cpmlx_mul_fr2x16-2.c
blob: d31fc15676a60c35aa5cb8c1ee3d8c27ea49ee35 (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, b, t;
  fract16 t1, t2;

  a = __builtin_bfin_compose_2x16 (0xa000, 0x8000);
  b = __builtin_bfin_compose_2x16 (0xb000, 0xe000);

  t = __builtin_bfin_cmplx_mul (a, b);
  t1 = __builtin_bfin_extract_hi (t);
  t2 = __builtin_bfin_extract_lo (t);
  if (t1 != 0x6800 || t2 != 0xffffe400)
    abort ();
  return 0;
}