extern void abort (void); extern void exit (int); typedef short __v2hi __attribute ((vector_size(4))); typedef __v2hi fract2x16; typedef short fract16; #define GETVECT(HILO1,HILO2,IN1,IN2) \ __builtin_bfin_compose_2x16 ((HILO2) ? __builtin_bfin_extract_hi (IN1) : __builtin_bfin_extract_lo (IN1), \ (HILO1) ? __builtin_bfin_extract_hi (IN2) : __builtin_bfin_extract_lo (IN2)) #define DOTEST(IN1, IN2, HL1, HL2, HL3, HL4) \ __builtin_bfin_multr_fr2x16 (GETVECT (HL1, HL2, IN1, IN1), \ GETVECT (HL3, HL4, IN2, IN2)) #define FUNC(HL1, HL2, HL3, HL4) \ fract2x16 foo ## HL1 ## HL2 ## HL3 ## HL4 (fract2x16 a, fract2x16 b)\ { \ return DOTEST(a, b, HL1, HL2, HL3, HL4);\ } FUNC (0, 0, 0, 0) FUNC (1, 0, 0, 0) FUNC (0, 1, 0, 0) FUNC (1, 1, 0, 0) FUNC (0, 0, 1, 0) FUNC (1, 0, 1, 0) FUNC (0, 1, 1, 0) FUNC (1, 1, 1, 0) FUNC (0, 0, 0, 1) FUNC (1, 0, 0, 1) FUNC (0, 1, 0, 1) FUNC (1, 1, 0, 1) FUNC (0, 0, 1, 1) FUNC (1, 0, 1, 1) FUNC (0, 1, 1, 1) FUNC (1, 1, 1, 1) #define RES1 0x1400 #define RES2 0x1e00 #define RES3 0x1c00 #define RES4 0x2a00 int main () { fract2x16 a, b, c; fract16 t1, t2; a = __builtin_bfin_compose_2x16 (0x3000, 0x2000); b = __builtin_bfin_compose_2x16 (0x7000, 0x5000); c = foo0000 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES1 || t2 != RES1) abort (); c = foo1000 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES2 || t2 != RES1) abort (); c = foo0100 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES1 || t2 != RES2) abort (); c = foo1100 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES2 || t2 != RES2) abort (); c = foo0010 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES3 || t2 != RES1) abort (); c = foo1010 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES4 || t2 != RES1) abort (); c = foo0110 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES3 || t2 != RES2) abort (); c = foo1110 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES4 || t2 != RES2) abort (); c = foo0001 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES1 || t2 != RES3) abort (); c = foo1001 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES2 || t2 != RES3) abort (); c = foo0101 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES1 || t2 != RES4) abort (); c = foo1101 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES2 || t2 != RES4) abort (); c = foo0011 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES3 || t2 != RES3) abort (); c = foo1011 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES4 || t2 != RES3) abort (); c = foo0111 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES3 || t2 != RES4) abort (); c = foo1111 (a, b); t1 = __builtin_bfin_extract_lo (c); t2 = __builtin_bfin_extract_hi (c); if (t1 != RES4 || t2 != RES4) abort (); exit (0); }