| /* This table is used as a source for every ascii character. |
| It is explicitly unsigned to avoid differences due to native characters |
| being either signed or unsigned. */ |
| #include <stdlib.h> |
| unsigned char ctable1[256] = { |
| 0000, 0001, 0002, 0003, 0004, 0005, 0006, 0007, |
| 0010, 0011, 0012, 0013, 0014, 0015, 0016, 0017, |
| 0020, 0021, 0022, 0023, 0024, 0025, 0026, 0027, |
| 0030, 0031, 0032, 0033, 0034, 0035, 0036, 0037, |
| 0040, 0041, 0042, 0043, 0044, 0045, 0046, 0047, |
| 0050, 0051, 0052, 0053, 0054, 0055, 0056, 0057, |
| 0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067, |
| 0070, 0071, 0072, 0073, 0074, 0075, 0076, 0077, |
| 0100, 0101, 0102, 0103, 0104, 0105, 0106, 0107, |
| 0110, 0111, 0112, 0113, 0114, 0115, 0116, 0117, |
| 0120, 0121, 0122, 0123, 0124, 0125, 0126, 0127, |
| 0130, 0131, 0132, 0133, 0134, 0135, 0136, 0137, |
| 0140, 0141, 0142, 0143, 0144, 0145, 0146, 0147, |
| 0150, 0151, 0152, 0153, 0154, 0155, 0156, 0157, |
| 0160, 0161, 0162, 0163, 0164, 0165, 0166, 0167, |
| 0170, 0171, 0172, 0173, 0174, 0175, 0176, 0177, |
| 0200, 0201, 0202, 0203, 0204, 0205, 0206, 0207, |
| 0210, 0211, 0212, 0213, 0214, 0215, 0216, 0217, |
| 0220, 0221, 0222, 0223, 0224, 0225, 0226, 0227, |
| 0230, 0231, 0232, 0233, 0234, 0235, 0236, 0237, |
| 0240, 0241, 0242, 0243, 0244, 0245, 0246, 0247, |
| 0250, 0251, 0252, 0253, 0254, 0255, 0256, 0257, |
| 0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267, |
| 0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277, |
| 0300, 0301, 0302, 0303, 0304, 0305, 0306, 0307, |
| 0310, 0311, 0312, 0313, 0314, 0315, 0316, 0317, |
| 0320, 0321, 0322, 0323, 0324, 0325, 0326, 0327, |
| 0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337, |
| 0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347, |
| 0350, 0351, 0352, 0353, 0354, 0355, 0356, 0357, |
| 0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367, |
| 0370, 0371, 0372, 0373, 0374, 0375, 0376, 0377 |
| }; |
| |
| unsigned char ctable2[] = { |
| 'a','X','X','X','X','X','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','X','X','X','X','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','X','X','X','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','X','X','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','X','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','X','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','X','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','X','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','X','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','X','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','X','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','a','X','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','a','a','X','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','X','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','X', |
| 'a','a','a','a','a','a','a','a','a','a','a','a','a','a','a','a', 0 |
| }; |
| |
| /* Single and multidimensional arrays to test access and printing of array |
| members. */ |
| |
| typedef int ArrayInt [10]; |
| ArrayInt a1 = {2,4,6,8,10,12,14,16,18,20}; |
| |
| typedef char ArrayChar [5]; |
| ArrayChar a2 = {'a','b','c','d','\0'}; |
| |
| int int1dim[12] = {0,1,2,3,4,5,6,7,8,9,10,11}; |
| int int2dim[3][4] = {{0,1,2,3},{4,5,6,7},{8,9,10,11}}; |
| int int3dim[2][3][2] = {{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}}; |
| int int4dim[1][2][3][2] = {{{{0,1},{2,3},{4,5}},{{6,7},{8,9},{10,11}}}}; |
| |
| char *teststring = (char*)"teststring contents"; |
| |
| typedef char *charptr; |
| charptr teststring2 = "more contents"; |
| |
| /* Test printing of a struct containing character arrays. */ |
| |
| struct some_arrays { |
| unsigned char array1[4]; |
| unsigned char array2[1]; |
| unsigned char array3[1]; |
| unsigned char array4[2]; |
| unsigned char array5[4]; |
| } arrays = { |
| {'a', 'b', 'c', '\0'}, |
| {'d'}, |
| {'e'}, |
| {'f', 'g' }, |
| {'h', 'i', 'j', '\0'} |
| }; |
| |
| struct some_arrays *parrays = &arrays; |
| |
| enum some_volatile_enum { enumvolval1, enumvolval2 }; |
| |
| /* A volatile enum variable whose name is the same as the enumeration |
| name. See PR11827. */ |
| volatile enum some_volatile_enum some_volatile_enum = enumvolval1; |
| |
| /* An enum considered as a "flag enum". */ |
| enum flag_enum |
| { |
| FE_NONE = 0x00, |
| FE_ONE = 0x01, |
| FE_TWO = 0x02, |
| FE_TWO_LEGACY = 0x02, |
| }; |
| |
| enum flag_enum three = (enum flag_enum) (FE_ONE | FE_TWO); |
| |
| /* Another enum considered as a "flag enum", but with no enumerator with value |
| 0. */ |
| enum flag_enum_without_zero |
| { |
| FEWZ_ONE = 0x01, |
| FEWZ_TWO = 0x02, |
| }; |
| |
| enum flag_enum_without_zero flag_enum_without_zero = (enum flag_enum_without_zero) 0; |
| |
| /* Not a flag enum, an enumerator value has multiple bits sets. */ |
| enum not_flag_enum |
| { |
| NFE_ONE = 0x01, |
| NFE_TWO = 0x02, |
| NFE_F0 = 0xf0, |
| }; |
| |
| enum not_flag_enum three_not_flag = (enum not_flag_enum) (NFE_ONE | NFE_TWO); |
| |
| /* A structure with an embedded array at an offset > 0. The array has |
| all elements with the same repeating value, which must not be the |
| same as the value of the preceding fields in the structure for the |
| test to be effective. This tests whether GDB uses the correct |
| element content offsets (relative to the complete `some_struct' |
| value) when counting value repetitions. */ |
| struct some_struct |
| { |
| int a; |
| int b; |
| unsigned char array[20]; |
| } some_struct = { |
| 0x12345678, |
| 0x87654321, |
| { |
| 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, |
| 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, |
| 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, |
| 0xaa, 0xaa, 0xaa, 0xaa, 0xaa |
| } |
| }; |
| |
| /* The following variables are used for testing byte repeat sequences. |
| The variable names are encoded: invalid_XYZ where: |
| X = start |
| Y = invalid |
| Z = end |
| |
| Each of X and Z can be "E" (empty), "S" (single), "L" (long single), |
| or "R" (repeat). |
| |
| Y can be either any of the above except "E" (otherwise there is nothing |
| to test). */ |
| char invalid_ESE[] = "\240"; |
| char invalid_SSE[] = "a\240"; |
| char invalid_LSE[] = "abaabbaaabbb\240"; |
| char invalid_RSE[] = "aaaaaaaaaaaaaaaaaaaa\240"; |
| char invalid_ESS[] = "\240c"; |
| char invalid_SSS[] = "a\240c"; |
| char invalid_LSS[] = "abaabbaaabbb\240c"; |
| char invalid_RSS[] = "aaaaaaaaaaaaaaaaaaaa\240c"; |
| char invalid_ESL[] = "\240cdccddcccddd"; |
| char invalid_SSL[] = "a\240cdccddcccddd"; |
| char invalid_LSL[] = "abaabbaaabbb\240cdccddcccddd"; |
| char invalid_RSL[] = "aaaaaaaaaaaaaaaaaaaa\240cdccddcccddd"; |
| char invalid_ESR[] = "\240cccccccccccccccccccc"; |
| char invalid_SSR[] = "a\240cccccccccccccccccccc"; |
| char invalid_LSR[] = "abaabbaaabbb\240cccccccccccccccccccc"; |
| char invalid_RSR[] = "aaaaaaaaaaaaaaaaaaaa\240cccccccccccccccccccc"; |
| char invalid_ELE[] = "\240\240\240\240"; |
| char invalid_SLE[] = "a\240\240\240\240"; |
| char invalid_LLE[] = "abaabbaaabbb\240\240\240\240"; |
| char invalid_RLE[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240"; |
| char invalid_ELS[] = "\240\240\240\240c"; |
| char invalid_SLS[] = "a\240\240\240\240c"; |
| char invalid_LLS[] = "abaabbaaabbb\240\240\240\240c"; |
| char invalid_RLS[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240c"; |
| char invalid_ELL[] = "\240\240\240\240cdccddcccddd"; |
| char invalid_SLL[] = "a\240\240\240\240cdccddcccddd"; |
| char invalid_LLL[] = "abaabbaaabbb\240\240\240\240cdccddcccddd"; |
| char invalid_RLL[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cdccddcccddd"; |
| char invalid_ELR[] = "\240\240\240\240cccccccccccccccccccc"; |
| char invalid_SLR[] = "a\240\240\240\240cccccccccccccccccccc"; |
| char invalid_LLR[] = "abaabbaaabbb\240\240\240\240cccccccccccccccccccc"; |
| char invalid_RLR[] = "aaaaaaaaaaaaaaaaaaaa\240\240\240\240cccccccccccccccccccc"; |
| char invalid_ERE[] = "" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240"; |
| char invalid_LRE[] = "abaabbaaabbb" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240"; |
| char invalid_RRE[] = "aaaaaaaaaaaaaaaaaaaa" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240"; |
| char invalid_ERS[] = "" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240c"; |
| char invalid_ERL[] = "" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; |
| char invalid_ERR[] = "" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; |
| char invalid_SRE[] = "a" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240"; |
| char invalid_SRS[] = "a" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240c"; |
| char invalid_SRL[] = "a" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; |
| char invalid_SRR[] = "a" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; |
| char invalid_LRS[] = "abaabbaaabbb" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240c"; |
| char invalid_LRL[] = "abaabbaaabbb" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; |
| char invalid_LRR[] = "abaabbaaabbb" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; |
| char invalid_RRS[] = "aaaaaaaaaaaaaaaaaaaa" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240c"; |
| char invalid_RRL[] = "aaaaaaaaaaaaaaaaaaaa" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cdccddcccddd"; |
| char invalid_RRR[] = "aaaaaaaaaaaaaaaaaaaa" |
| "\240\240\240\240\240\240\240\240\240\240" |
| "\240\240\240\240\240\240\240\240\240\240cccccccccccccccccccc"; |
| |
| /* -- */ |
| |
| int main () |
| { |
| void *p = malloc (1); |
| |
| /* Prevent AIX linker from removing variables. */ |
| return ctable1[0] + ctable2[0] + int1dim[0] + int2dim[0][0] |
| + int3dim[0][0][0] + int4dim[0][0][0][0] + teststring[0] + |
| *parrays -> array1 + a1[0] + a2[0]; |
| free (p); |
| } |