blob: e8e17176ac07e1787a50101759f22c424fb7eb4d (
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
|
/*
This test checks promotion of bitfields. Bitfields should be promoted
very much like chars and shorts:
Bitfields (signed or unsigned) should be promoted to signed int if their
value will fit in a signed int, otherwise to an unsigned int if their
value will fit in an unsigned int, otherwise we don't promote them (ANSI/ISO
does not specify the behavior of bitfields larger than an unsigned int).
We test the behavior by subtracting two from the promoted value: this will
result in a negitive value for signed types, a positive value for unsigned
types. This test (of course) assumes that the compiler is correctly
implementing signed and unsigned arithmetic.
*/
struct X {
unsigned int u3:3;
signed long int s31:31;
signed long int s32:32;
unsigned long int u31:31;
unsigned long int u32:32;
unsigned long long ull3 :3;
unsigned long long ull35:35;
unsigned u15:15;
};
struct X x;
main ()
{
if ((x.u3 - 2) >= 0) /* promoted value should be signed */
abort ();
if ((x.s31 - 2) >= 0) /* promoted value should be signed */
abort ();
if ((x.s32 - 2) >= 0) /* promoted value should be signed */
abort ();
if ((x.u15 - 2) >= 0) /* promoted value should be signed */
abort ();
/* Conditionalize check on whether integers are 4 bytes or larger, i.e.
larger than a 31 bit bitfield. */
if (sizeof (int) >= 4)
{
if ((x.u31 - 2) >= 0) /* promoted value should be signed */
abort ();
}
else
{
if ((x.u31 - 2) < 0) /* promoted value should be UNsigned */
abort ();
}
if ((x.u32 - 2) < 0) /* promoted value should be UNsigned */
abort ();
if ((x.ull3 - 2) >= 0) /* promoted value should be signed */
abort ();
if ((x.ull35 - 2) < 0) /* promoted value should be UNsigned */
abort ();
exit (0);
}
|