--- ./gdb-7.2/gdb/i387-tdep.c 2010-05-05 21:30:36.000000000 +0200 +++ ./gdb-7.2.2/gdb/i387-tdep.c 2011-04-14 16:23:54.647948001 +0200 @@ -36,6 +36,52 @@ #include "i387-tdep.h" #include "i386-xstate.h" +struct +{ + char *tag; + char *description; +} + +static const npx_exception_flags[6] = + +{ + {"IE", "invalid operation"}, + {"DE", "denormalized operand"}, + {"ZE", "zero divide"}, + {"OE", "overflow"}, + {"UE", "underflow"}, + {"PE", "precision"} +}; + +// print the numeric coprocessor extension (npx) status word +void print_npx_status_word(uint16_t npx_status_word, struct ui_file *file) +{ + fprintf_filtered(file, "status word : 0x%04X\n", npx_status_word); + + fprintf_filtered(file, " exception flags : "); + + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0005) & 0x0001) ? npx_exception_flags[5].tag : " "); // precision + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0004) & 0x0001) ? npx_exception_flags[4].tag : " "); // underflow + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0003) & 0x0001) ? npx_exception_flags[3].tag : " "); // overflow + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0002) & 0x0001) ? npx_exception_flags[2].tag : " "); // zero divide + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0001) & 0x0001) ? npx_exception_flags[1].tag : " "); // denormalized operand + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0000) & 0x0001) ? npx_exception_flags[0].tag : " "); // invalid operation + fprintf_filtered(file, "\n"); + + fprintf_filtered(file, " stack fault : %u\n", ((npx_status_word >> 0x0006) & 0x0001)); + fprintf_filtered(file, " error summary status : %u\n", ((npx_status_word >> 0x0007) & 0x0001)); + fprintf_filtered(file, " busy : %u\n", ((npx_status_word >> 0x000F) & 0x0001)); + fprintf_filtered(file, " top of stack pointer : %u\n", ((npx_status_word >> 0x000B) & 0x0007)); + + fprintf_filtered(file, " condition code : "); + + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x000E) & 0x0001) ? "C3" : " "); + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x000A) & 0x0001) ? "C2" : " "); + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0009) & 0x0001) ? "C1" : " "); + fprintf_filtered(file, "%s ", ((npx_status_word >> 0x0008) & 0x0001) ? "C0" : " "); + fprintf_filtered(file, "\n"); +} + /* Print the floating point number specified by RAW. */ static void @@ -114,36 +160,6 @@ print_i387_ext (struct gdbarch *gdbarch, fputs_filtered (" Unsupported", file); } -/* Print the status word STATUS. */ - -static void -print_i387_status_word (unsigned int status, struct ui_file *file) -{ - fprintf_filtered (file, "Status Word: %s", - hex_string_custom (status, 4)); - fputs_filtered (" ", file); - fprintf_filtered (file, " %s", (status & 0x0001) ? "IE" : " "); - fprintf_filtered (file, " %s", (status & 0x0002) ? "DE" : " "); - fprintf_filtered (file, " %s", (status & 0x0004) ? "ZE" : " "); - fprintf_filtered (file, " %s", (status & 0x0008) ? "OE" : " "); - fprintf_filtered (file, " %s", (status & 0x0010) ? "UE" : " "); - fprintf_filtered (file, " %s", (status & 0x0020) ? "PE" : " "); - fputs_filtered (" ", file); - fprintf_filtered (file, " %s", (status & 0x0080) ? "ES" : " "); - fputs_filtered (" ", file); - fprintf_filtered (file, " %s", (status & 0x0040) ? "SF" : " "); - fputs_filtered (" ", file); - fprintf_filtered (file, " %s", (status & 0x0100) ? "C0" : " "); - fprintf_filtered (file, " %s", (status & 0x0200) ? "C1" : " "); - fprintf_filtered (file, " %s", (status & 0x0400) ? "C2" : " "); - fprintf_filtered (file, " %s", (status & 0x4000) ? "C3" : " "); - - fputs_filtered ("\n", file); - - fprintf_filtered (file, - " TOP: %d\n", ((status >> 11) & 7)); -} - /* Print the control word CONTROL. */ static void @@ -268,7 +284,9 @@ i387_print_float_info (struct gdbarch *g fputs_filtered ("\n", file); - print_i387_status_word (fstat, file); + print_npx_status_word(fstat, file); + fprintf_filtered(file, "\n"); + print_i387_control_word (fctrl, file); fprintf_filtered (file, "Tag Word: %s\n", hex_string_custom (ftag, 4));