3 storage: idata, xdata, code,
6 #define STORAGE {storage}
11 typedef unsigned int size_t;
12 #define offsetof(s,m) (size_t)&(((s *)0)->m)
14 #if defined(PORT_HOST) || defined(SDCC_z80) || defined(SDCC_gbz80)
20 char array[5] = {'a', 'b', 'c'};
46 struct x STORAGE teststruct[5] = {
47 { 10, { 1, 2, 3, 4, 5} },
52 struct y STORAGE incompletestruct = {
56 struct z STORAGE nestedstruct = {
64 ASSERT(array[2] == 'c');
65 ASSERT(array[4] == 0);
67 ASSERT(g[1].a == 'y');
69 ASSERT(g[2].a == 'z');
72 ASSERT(teststruct[0].b[1] == 2);
73 ASSERT(teststruct[0].b[5] == 0);
74 ASSERT(teststruct[1].b[0] == 11);
75 ASSERT(teststruct[4].b[9] == 0);
77 ASSERT(sizeof(teststruct[2].a) == 2);
78 ASSERT(sizeof(teststruct[1].b) == 10);
79 ASSERT(sizeof(teststruct[1]) == 12);
80 ASSERT(sizeof(teststruct) == 60);
82 ASSERT(incompletestruct.a == 10);
83 ASSERT(incompletestruct.b[0] == 1);
84 ASSERT(incompletestruct.b[4] == 5);
86 ASSERT(sizeof(incompletestruct) == sizeof(struct y));
87 ASSERT(sizeof(incompletestruct) == offsetof(struct y, b));
88 ASSERT(sizeof(incompletestruct) == offsetof(struct x, b));
90 ASSERT(nestedstruct.c == 16);
91 ASSERT(nestedstruct.s.a == 20);
92 ASSERT(nestedstruct.s.b[2] == 8);