1/* This table is used as a source for every ascii character. 2 It is explicitly unsigned to avoid differences due to native characters 3 being either signed or unsigned. */ 4#include <stdlib.h> 5unsigned char ctable1[256] = { 6 0000, 0001, 0002, 0003, 0004, 0005, 0006, 0007, 7 0010, 0011, 0012, 0013, 0014, 0015, 0016, 0017, 8 0020, 0021, 0022, 0023, 0024, 0025, 0026, 0027, 9 0030, 0031, 0032, 0033, 0034, 0035, 0036, 0037, 10 0040, 0041, 0042, 0043, 0044, 0045, 0046, 0047, 11 0050, 0051, 0052, 0053, 0054, 0055, 0056, 0057, 12 0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067, 13 0070, 0071, 0072, 0073, 0074, 0075, 0076, 0077, 14 0100, 0101, 0102, 0103, 0104, 0105, 0106, 0107, 15 0110, 0111, 0112, 0113, 0114, 0115, 0116, 0117, 16 0120, 0121, 0122, 0123, 0124, 0125, 0126, 0127, 17 0130, 0131, 0132, 0133, 0134, 0135, 0136, 0137, 18 0140, 0141, 0142, 0143, 0144, 0145, 0146, 0147, 19 0150, 0151, 0152, 0153, 0154, 0155, 0156, 0157, 20 0160, 0161, 0162, 0163, 0164, 0165, 0166, 0167, 21 0170, 0171, 0172, 0173, 0174, 0175, 0176, 0177, 22 0200, 0201, 0202, 0203, 0204, 0205, 0206, 0207, 23 0210, 0211, 0212, 0213, 0214, 0215, 0216, 0217, 24 0220, 0221, 0222, 0223, 0224, 0225, 0226, 0227, 25 0230, 0231, 0232, 0233, 0234, 0235, 0236, 0237, 26 0240, 0241, 0242, 0243, 0244, 0245, 0246, 0247, 27 0250, 0251, 0252, 0253, 0254, 0255, 0256, 0257, 28 0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267, 29 0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277, 30 0300, 0301, 0302, 0303, 0304, 0305, 0306, 0307, 31 0310, 0311, 0312, 0313, 0314, 0315, 0316, 0317, 32 0320, 0321, 0322, 0323, 0324, 0325, 0326, 0327, 33 0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337, 34 0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347, 35 0350, 0351, 0352, 0353, 0354, 0355, 0356, 0357, 36 0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367, 37 0370, 0371, 0372, 0373, 0374, 0375, 0376, 0377 38}; 39 40unsigned char ctable2[] = { 41 'a','X','X','X','X','X','X','X','X','X','X','X','X','X','X','X', 42 'a','a','X','X','X','X','X','X','X','X','X','X','X','X','X','X', 43 'a','a','a','X','X','X','X','X','X','X','X','X','X','X','X','X', 44 'a','a','a','a','X','X','X','X','X','X','X','X','X','X','X','X', 45 'a','a','a','a','a','X','X','X','X','X','X','X','X','X','X','X', 46 'a','a','a','a','a','a','X','X','X','X','X','X','X','X','X','X', 47 'a','a','a','a','a','a','a','X','X','X','X','X','X','X','X','X', 48 'a','a','a','a','a','a','a','a','X','X','X','X','X','X','X','X', 49 'a','a','a','a','a','a','a','a','a','X','X','X','X','X','X','X', 50 'a','a','a','a','a','a','a','a','a','a','X','X','X','X','X','X', 51 'a','a','a','a','a','a','a','a','a','a','a','X','X','X','X','X', 52 'a','a','a','a','a','a','a','a','a','a','a','a','X','X','X','X', 53 'a','a','a','a','a','a','a','a','a','a','a','a','a','X','X','X', 54 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','X','X', 55 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','X', 56 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a', 0 57}; 58 59/* Single and multidimensional arrays to test access and printing of array 60 members. */ 61 62typedef int ArrayInt [10]; 63ArrayInt a1 = {2,4,6,8,10,12,14,16,18,20}; 64 65typedef char ArrayChar [5]; 66ArrayChar a2 = {'a','b','c','d','\0'}; 67 68int int1dim[12] = {0,1,2,3,4,5,6,7,8,9,10,11}; 69int int2dim[3][4] = {{0,1,2,3},{4,5,6,7},{8,9,10,11}}; 70int int3dim[2][3][2] = {{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}}; 71int int4dim[1][2][3][2] = {{{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}}}; 72 73char *teststring = (char*)"teststring contents"; 74 75typedef char *charptr; 76charptr teststring2 = "more contents"; 77 78/* Test printing of a struct containing character arrays. */ 79 80struct some_arrays { 81 unsigned char array1[4]; 82 unsigned char array2[1]; 83 unsigned char array3[1]; 84 unsigned char array4[2]; 85 unsigned char array5[4]; 86} arrays = { 87 {'a', 'b', 'c', '\0'}, 88 {'d'}, 89 {'e'}, 90 {'f', 'g' }, 91 {'h', 'i', 'j', '\0'} 92}; 93 94struct some_arrays *parrays = &arrays; 95 96enum some_volatile_enum { enumvolval1, enumvolval2 }; 97 98/* A volatile enum variable whose name is the same as the enumeration 99 name. See PR11827. */ 100volatile enum some_volatile_enum some_volatile_enum = enumvolval1; 101 102/* An enum considered as a "flag enum". */ 103enum flag_enum 104{ 105 FE_NONE = 0x00, 106 FE_ONE = 0x01, 107 FE_TWO = 0x02, 108 FE_TWO_LEGACY = 0x02, 109}; 110 111enum flag_enum three = FE_ONE | FE_TWO; 112 113/* Another enum considered as a "flag enum", but with no enumerator with value 114 0. */ 115enum flag_enum_without_zero 116{ 117 FEWZ_ONE = 0x01, 118 FEWZ_TWO = 0x02, 119}; 120 121enum flag_enum_without_zero flag_enum_without_zero = 0; 122 123/* Not a flag enum, an enumerator value has multiple bits sets. */ 124enum not_flag_enum 125{ 126 NFE_ONE = 0x01, 127 NFE_TWO = 0x02, 128 NFE_F0 = 0xf0, 129}; 130 131enum not_flag_enum three_not_flag = NFE_ONE | NFE_TWO; 132 133/* A structure with an embedded array at an offset > 0. The array has 134 all elements with the same repeating value, which must not be the 135 same as the value of the preceding fields in the structure for the 136 test to be effective. This tests whether GDB uses the correct 137 element content offsets (relative to the complete `some_struct' 138 value) when counting value repetitions. */ 139struct some_struct 140{ 141 int a; 142 int b; 143 unsigned char array[20]; 144} some_struct = { 145 0x12345678, 146 0x87654321, 147 { 148 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 149 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 150 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 151 0xaa, 0xaa, 0xaa, 0xaa, 0xaa 152 } 153}; 154 155/* The following variables are used for testing byte repeat sequences. 156 The variable names are encoded: invalid_XYZ where: 157 X = start 158 Y = invalid 159 Z = end 160 161 Each of X and Z can be "E" (empty), "S" (single), "L" (long single), 162 or "R" (repeat). 163 164 Y can be either any of the above except "E" (otherwise there is nothing 165 to test). */ 166char invalid_ESE[] = "\240"; 167char invalid_SSE[] = "a\240"; 168char invalid_LSE[] = "abaabbaaabbb\240"; 169char invalid_RSE[] = "aaaaaaaaaaaaaaaaaaaa\240"; 170char invalid_ESS[] = "\240c"; 171char invalid_SSS[] = "a\240c"; 172char invalid_LSS[] = "abaabbaaabbb\240c"; 173char invalid_RSS[] = "aaaaaaaaaaaaaaaaaaaa\240c"; 174char invalid_ESL[] = "\240cdccddcccddd"; 175char invalid_SSL[] = "a\240cdccddcccddd"; 176char invalid_LSL[] = "abaabbaaabbb\240cdccddcccddd"; 177char invalid_RSL[] = "aaaaaaaaaaaaaaaaaaaa\240cdccddcccddd"; 178char invalid_ESR[] = "\240cccccccccccccccccccc"; 179char invalid_SSR[] = "a\240cccccccccccccccccccc"; 180char invalid_LSR[] = "abaabbaaabbb\240cccccccccccccccccccc"; 181char invalid_RSR[] = "aaaaaaaaaaaaaaaaaaaa\240cccccccccccccccccccc"; 182char invalid_ELE[] = "\240\240\240\240"; 183char invalid_SLE[] = "a\240\240\240\240"; 184char invalid_LLE[] = "abaabbaaabbb\240\240\240\240"; 185char invalid_RLE[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240"; 186char invalid_ELS[] = "\240\240\240\240c"; 187char invalid_SLS[] = "a\240\240\240\240c"; 188char invalid_LLS[] = "abaabbaaabbb\240\240\240\240c"; 189char invalid_RLS[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240c"; 190char invalid_ELL[] = "\240\240\240\240cdccddcccddd"; 191char invalid_SLL[] = "a\240\240\240\240cdccddcccddd"; 192char invalid_LLL[] = "abaabbaaabbb\240\240\240\240cdccddcccddd"; 193char invalid_RLL[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cdccddcccddd"; 194char invalid_ELR[] = "\240\240\240\240cccccccccccccccccccc"; 195char invalid_SLR[] = "a\240\240\240\240cccccccccccccccccccc"; 196char invalid_LLR[] = "abaabbaaabbb\240\240\240\240cccccccccccccccccccc"; 197char invalid_RLR[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cccccccccccccccccccc"; 198char invalid_ERE[] = "" 199 "\240\240\240\240\240\240\240\240\240\240" 200 "\240\240\240\240\240\240\240\240\240\240"; 201char invalid_LRE[] = "abaabbaaabbb" 202 "\240\240\240\240\240\240\240\240\240\240" 203 "\240\240\240\240\240\240\240\240\240\240"; 204char invalid_RRE[] = "aaaaaaaaaaaaaaaaaaaa" 205 "\240\240\240\240\240\240\240\240\240\240" 206 "\240\240\240\240\240\240\240\240\240\240"; 207char invalid_ERS[] = "" 208 "\240\240\240\240\240\240\240\240\240\240" 209 "\240\240\240\240\240\240\240\240\240\240c"; 210char invalid_ERL[] = "" 211 "\240\240\240\240\240\240\240\240\240\240" 212 "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; 213char invalid_ERR[] = "" 214 "\240\240\240\240\240\240\240\240\240\240" 215 "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; 216char invalid_SRE[] = "a" 217 "\240\240\240\240\240\240\240\240\240\240" 218 "\240\240\240\240\240\240\240\240\240\240"; 219char invalid_SRS[] = "a" 220 "\240\240\240\240\240\240\240\240\240\240" 221 "\240\240\240\240\240\240\240\240\240\240c"; 222char invalid_SRL[] = "a" 223 "\240\240\240\240\240\240\240\240\240\240" 224 "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; 225char invalid_SRR[] = "a" 226 "\240\240\240\240\240\240\240\240\240\240" 227 "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; 228char invalid_LRS[] = "abaabbaaabbb" 229 "\240\240\240\240\240\240\240\240\240\240" 230 "\240\240\240\240\240\240\240\240\240\240c"; 231char invalid_LRL[] = "abaabbaaabbb" 232 "\240\240\240\240\240\240\240\240\240\240" 233 "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; 234char invalid_LRR[] = "abaabbaaabbb" 235 "\240\240\240\240\240\240\240\240\240\240" 236 "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; 237char invalid_RRS[] = "aaaaaaaaaaaaaaaaaaaa" 238 "\240\240\240\240\240\240\240\240\240\240" 239 "\240\240\240\240\240\240\240\240\240\240c"; 240char invalid_RRL[] = "aaaaaaaaaaaaaaaaaaaa" 241 "\240\240\240\240\240\240\240\240\240\240" 242 "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; 243char invalid_RRR[] = "aaaaaaaaaaaaaaaaaaaa" 244 "\240\240\240\240\240\240\240\240\240\240" 245 "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; 246 247/* -- */ 248 249int main () 250{ 251 void *p = malloc (1); 252 253 /* Prevent AIX linker from removing variables. */ 254 return ctable1[0] + ctable2[0] + int1dim[0] + int2dim[0][0] 255 + int3dim[0][0][0] + int4dim[0][0][0][0] + teststring[0] + 256 *parrays -> array1 + a1[0] + a2[0]; 257 free (p); 258} 259