mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-27 04:52:05 +08:00
56262a931b
Currently, "print/x" will display a floating-point value by first casting it to an integer type. This yields weird results like: (gdb) print/x 1.5 $1 = 0x1 This has confused users multiple times -- see PR gdb/16242, where there are several dups. I've also seen some confusion from this internally at AdaCore. The manual says: 'x' Regard the bits of the value as an integer, and print the integer in hexadecimal. ... which seems more useful. So, perhaps what happened is that this was incorrectly implemented (or maybe correctly implemented and then regressed, as there don't seem to be any tests). This patch fixes the bug. There was a previous discussion where we agreed to preserve the old behavior: https://sourceware.org/legacy-ml/gdb-patches/2017-06/msg00314.html However, I think it makes more sense to follow the manual. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=16242
261 lines
9.6 KiB
C
261 lines
9.6 KiB
C
/* 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";
|
|
|
|
/* -- */
|
|
|
|
float f_var = 65.0f;
|
|
|
|
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);
|
|
}
|