aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.7/gcc/testsuite/gcc.target/avr/torture/builtin_insert_bits-1.c
blob: fe20c916315d5071a15addff7ad549ba2ad9a645 (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/* { dg-do run } */

#include <stdlib.h>

#define MASK_F(M)                                       \
  (0                                                    \
   | ((0xf == (0xf & ((M) >> (4*0)))) ? (1 << 0) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*1)))) ? (1 << 1) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*2)))) ? (1 << 2) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*3)))) ? (1 << 3) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*4)))) ? (1 << 4) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*5)))) ? (1 << 5) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*6)))) ? (1 << 6) : 0)   \
   | ((0xf == (0xf & ((M) >> (4*7)))) ? (1 << 7) : 0)   \
   | 0)

#define MASK_0_7(M)                                     \
  (0                                                    \
   | ((8 > (0xf & ((M) >> (4*0)))) ? (1 << 0) : 0)      \
   | ((8 > (0xf & ((M) >> (4*1)))) ? (1 << 1) : 0)      \
   | ((8 > (0xf & ((M) >> (4*2)))) ? (1 << 2) : 0)      \
   | ((8 > (0xf & ((M) >> (4*3)))) ? (1 << 3) : 0)      \
   | ((8 > (0xf & ((M) >> (4*4)))) ? (1 << 4) : 0)      \
   | ((8 > (0xf & ((M) >> (4*5)))) ? (1 << 5) : 0)      \
   | ((8 > (0xf & ((M) >> (4*6)))) ? (1 << 6) : 0)      \
   | ((8 > (0xf & ((M) >> (4*7)))) ? (1 << 7) : 0)      \
   | 0)

#define INSERT_BITS(M,B,V)                                              \
  (__extension__({                                                      \
      unsigned char _n, _r = 0;                                         \
      _n = 0xf & (M >> (4*0)); if (_n<8) _r |= (!!(B & (1 << _n))) << 0; \
      _n = 0xf & (M >> (4*1)); if (_n<8) _r |= (!!(B & (1 << _n))) << 1; \
      _n = 0xf & (M >> (4*2)); if (_n<8) _r |= (!!(B & (1 << _n))) << 2; \
      _n = 0xf & (M >> (4*3)); if (_n<8) _r |= (!!(B & (1 << _n))) << 3; \
      _n = 0xf & (M >> (4*4)); if (_n<8) _r |= (!!(B & (1 << _n))) << 4; \
      _n = 0xf & (M >> (4*5)); if (_n<8) _r |= (!!(B & (1 << _n))) << 5; \
      _n = 0xf & (M >> (4*6)); if (_n<8) _r |= (!!(B & (1 << _n))) << 6; \
      _n = 0xf & (M >> (4*7)); if (_n<8) _r |= (!!(B & (1 << _n))) << 7; \
      (unsigned char) ((V) & MASK_F(M)) | _r;                           \
    }))

#define MASK_USED(M) (MASK_F(M) | MASK_0_7(M))

#define TEST2(M,B,V)                                    \
  do {                                                  \
    __asm volatile (";" #M);                            \
    r1 = MASK_USED (M)                                  \
      & __builtin_avr_insert_bits (M,B,V);              \
    r2 = INSERT_BITS (M,B,V);                           \
    if (r1 != r2)                                       \
      abort ();                                         \
  } while(0)

#define TEST1(M,X)                                      \
  do {                                                  \
    TEST2 (M,X,0x00); TEST2 (M,0x00,X);                 \
    TEST2 (M,X,0xff); TEST2 (M,0xff,X);                 \
    TEST2 (M,X,0xaa); TEST2 (M,0xaa,X);                 \
    TEST2 (M,X,0xcc); TEST2 (M,0xcc,X);                 \
    TEST2 (M,X,0x96); TEST2 (M,0x96,X);                 \
  } while(0)



void test8 (void)
{
  unsigned char r1, r2;
  unsigned char ib;

  static const unsigned char V[] =
    {
      0, 0xaa, 0xcc, 0xf0, 0xff, 0x5b, 0x4d
    };

  for (ib = 0; ib < sizeof (V) / sizeof (*V); ib++)
    {
      unsigned char b = V[ib];
      
      TEST1 (0x76543210, b);
      TEST1 (0x3210ffff, b);
      TEST1 (0x67452301, b);
      TEST1 (0xf0f1f2f3, b);
      TEST1 (0xff10ff54, b);
      TEST1 (0x01234567, b);
      TEST1 (0xff765f32, b);
    }
}

/****************************************************************/

int main()
{
  test8();
  
  exit(0);
}