Imroved sgre command
This commit is contained in:
parent
7dd6c7e595
commit
38c1f41df7
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: dbg_main.cc,v 1.206 2009-10-01 19:10:13 sshwarts Exp $
|
// $Id: dbg_main.cc,v 1.207 2009-10-02 10:16:04 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -57,6 +57,9 @@ bx_list_c *dbg_cpu_list = 0;
|
|||||||
extern const char* cpu_mode_string(unsigned cpu_mode);
|
extern const char* cpu_mode_string(unsigned cpu_mode);
|
||||||
extern void bx_sr_after_restore_state(void);
|
extern void bx_sr_after_restore_state(void);
|
||||||
|
|
||||||
|
void bx_dbg_print_descriptor(Bit32u lo, Bit32u hi);
|
||||||
|
void bx_dbg_print_descriptor64(Bit32u lo1, Bit32u hi1, Bit32u lo2, Bit32u hi2);
|
||||||
|
|
||||||
static bx_param_bool_c *sim_running = NULL;
|
static bx_param_bool_c *sim_running = NULL;
|
||||||
|
|
||||||
static char tmp_buf[512];
|
static char tmp_buf[512];
|
||||||
@ -806,46 +809,29 @@ void bx_dbg_info_control_regs_command(void)
|
|||||||
|
|
||||||
void bx_dbg_info_segment_regs_command(void)
|
void bx_dbg_info_segment_regs_command(void)
|
||||||
{
|
{
|
||||||
|
static const char *segname[] = { "es", "cs", "ss", "ds", "fs", "gs" };
|
||||||
|
|
||||||
bx_dbg_sreg_t sreg;
|
bx_dbg_sreg_t sreg;
|
||||||
bx_dbg_global_sreg_t global_sreg;
|
bx_dbg_global_sreg_t global_sreg;
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_CS);
|
for(int s=0;s<6;s++) {
|
||||||
dbg_printf("cs:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, s);
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
dbg_printf("%s:0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n", segname[s],
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
||||||
|
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_DS);
|
if (sreg.valid) {
|
||||||
dbg_printf("ds:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
dbg_printf("\t");
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
bx_dbg_print_descriptor(sreg.des_l, sreg.des_h);
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
}
|
||||||
|
}
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_SS);
|
|
||||||
dbg_printf("ss:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_ES);
|
|
||||||
dbg_printf("es:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_FS);
|
|
||||||
dbg_printf("fs:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_sreg(&sreg, BX_DBG_SREG_GS);
|
|
||||||
dbg_printf("gs:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_ldtr(&sreg);
|
BX_CPU(dbg_cpu)->dbg_get_ldtr(&sreg);
|
||||||
dbg_printf("ldtr:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
dbg_printf("ldtr:0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
||||||
|
|
||||||
BX_CPU(dbg_cpu)->dbg_get_tr(&sreg);
|
BX_CPU(dbg_cpu)->dbg_get_tr(&sreg);
|
||||||
dbg_printf("tr:s=0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
dbg_printf("tr:0x%04x, dh=0x%08x, dl=0x%08x, valid=%u\n",
|
||||||
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
(unsigned) sreg.sel, (unsigned) sreg.des_h,
|
||||||
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
(unsigned) sreg.des_l, (unsigned) sreg.valid);
|
||||||
|
|
||||||
@ -2766,10 +2752,8 @@ void bx_dbg_info_dirty_command(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void bx_dbg_print_descriptor(Bit8u *desc)
|
void bx_dbg_print_descriptor(Bit32u lo, Bit32u hi)
|
||||||
{
|
{
|
||||||
Bit32u lo = (desc[3] << 24) | (desc[2] << 16) | (desc[1] << 8) | (desc[0]);
|
|
||||||
Bit32u hi = (desc[7] << 24) | (desc[6] << 16) | (desc[5] << 8) | (desc[4]);
|
|
||||||
Bit32u base = ((lo >> 16) & 0xffff)
|
Bit32u base = ((lo >> 16) & 0xffff)
|
||||||
| ((hi << 16) & 0xff0000)
|
| ((hi << 16) & 0xff0000)
|
||||||
| (hi & 0xff000000);
|
| (hi & 0xff000000);
|
||||||
@ -2788,14 +2772,14 @@ void bx_dbg_print_descriptor(Bit8u *desc)
|
|||||||
// either a code or a data segment. bit 11 (type file MSB) then says
|
// either a code or a data segment. bit 11 (type file MSB) then says
|
||||||
// 0=data segment, 1=code seg
|
// 0=data segment, 1=code seg
|
||||||
if (type&8) {
|
if (type&8) {
|
||||||
dbg_printf("Code segment, laddr=0x%08x, limit=0x%08x, %s%s%s, %d-bit\n",
|
dbg_printf("Code segment, base=0x%08x, limit=0x%08x, %s%s%s, %d-bit\n",
|
||||||
base, g ? (limit * 4096 + 4095) : limit,
|
base, g ? (limit * 4096 + 4095) : limit,
|
||||||
(type&2)? "Execute/Read" : "Execute-Only",
|
(type&2)? "Execute/Read" : "Execute-Only",
|
||||||
(type&4)? ", Conforming" : "",
|
(type&4)? ", Conforming" : "",
|
||||||
(type&1)? ", Accessed" : "",
|
(type&1)? ", Accessed" : "",
|
||||||
d_b ? 32 : 16);
|
d_b ? 32 : 16);
|
||||||
} else {
|
} else {
|
||||||
dbg_printf("Data segment, laddr=0x%08x, limit=0x%08x, %s%s%s\n",
|
dbg_printf("Data segment, base=0x%08x, limit=0x%08x, %s%s%s\n",
|
||||||
base, g ? (limit * 4096 + 4095) : limit,
|
base, g ? (limit * 4096 + 4095) : limit,
|
||||||
(type&2)? "Read/Write" : "Read-Only",
|
(type&2)? "Read/Write" : "Read-Only",
|
||||||
(type&4)? ", Expand-down" : "",
|
(type&4)? ", Expand-down" : "",
|
||||||
@ -2853,12 +2837,8 @@ void bx_dbg_print_descriptor(Bit8u *desc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if BX_SUPPORT_X86_64
|
#if BX_SUPPORT_X86_64
|
||||||
void bx_dbg_print_descriptor64(Bit8u *desc)
|
void bx_dbg_print_descriptor64(Bit32u lo1, Bit32u hi1, Bit32u lo2, Bit32u hi2)
|
||||||
{
|
{
|
||||||
Bit32u lo1 = (desc[3] << 24) | (desc[2] << 16) | (desc[1] << 8) | (desc[0]);
|
|
||||||
Bit32u hi1 = (desc[7] << 24) | (desc[6] << 16) | (desc[5] << 8) | (desc[4]);
|
|
||||||
Bit32u lo2 = (desc[11] << 24) | (desc[10] << 16) | (desc[9] << 8) | (desc[8]);
|
|
||||||
Bit32u hi2 = (desc[15] << 24) | (desc[14] << 16) | (desc[13] << 8) | (desc[12]);
|
|
||||||
Bit32u segment = (lo1 >> 16) & 0xffff;
|
Bit32u segment = (lo1 >> 16) & 0xffff;
|
||||||
Bit64u offset = (lo1 & 0xffff) | (hi1 & 0xffff0000) | ((Bit64u)(lo2) << 32);
|
Bit64u offset = (lo1 & 0xffff) | (hi1 & 0xffff0000) | ((Bit64u)(lo2) << 32);
|
||||||
unsigned type = (hi1 >> 8) & 0xf;
|
unsigned type = (hi1 >> 8) & 0xf;
|
||||||
@ -2948,7 +2928,13 @@ void bx_dbg_info_idt_command(unsigned from, unsigned to)
|
|||||||
if (16*n + 15 > idtr.limit) break;
|
if (16*n + 15 > idtr.limit) break;
|
||||||
if (bx_dbg_read_linear(dbg_cpu, idtr.base + 16*n, 16, entry)) {
|
if (bx_dbg_read_linear(dbg_cpu, idtr.base + 16*n, 16, entry)) {
|
||||||
dbg_printf("IDT[0x%02x]=", n);
|
dbg_printf("IDT[0x%02x]=", n);
|
||||||
bx_dbg_print_descriptor64(entry);
|
|
||||||
|
Bit32u lo1 = (entry[3] << 24) | (entry[2] << 16) | (entry[1] << 8) | (entry[0]);
|
||||||
|
Bit32u hi1 = (entry[7] << 24) | (entry[6] << 16) | (entry[5] << 8) | (entry[4]);
|
||||||
|
Bit32u lo2 = (entry[11] << 24) | (entry[10] << 16) | (entry[9] << 8) | (entry[8]);
|
||||||
|
Bit32u hi2 = (entry[15] << 24) | (entry[14] << 16) | (entry[13] << 8) | (entry[12]);
|
||||||
|
|
||||||
|
bx_dbg_print_descriptor64(lo1, hi1, lo2, hi2);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
dbg_printf("error: IDTR+16*%d points to invalid linear address 0x" FMT_ADDRX "\n", n, idtr.base);
|
dbg_printf("error: IDTR+16*%d points to invalid linear address 0x" FMT_ADDRX "\n", n, idtr.base);
|
||||||
@ -2964,7 +2950,11 @@ void bx_dbg_info_idt_command(unsigned from, unsigned to)
|
|||||||
if (8*n + 7 > idtr.limit) break;
|
if (8*n + 7 > idtr.limit) break;
|
||||||
if (bx_dbg_read_linear(dbg_cpu, idtr.base + 8*n, 8, entry)) {
|
if (bx_dbg_read_linear(dbg_cpu, idtr.base + 8*n, 8, entry)) {
|
||||||
dbg_printf("IDT[0x%02x]=", n);
|
dbg_printf("IDT[0x%02x]=", n);
|
||||||
bx_dbg_print_descriptor(entry);
|
|
||||||
|
Bit32u lo = (entry[3] << 24) | (entry[2] << 16) | (entry[1] << 8) | (entry[0]);
|
||||||
|
Bit32u hi = (entry[7] << 24) | (entry[6] << 16) | (entry[5] << 8) | (entry[4]);
|
||||||
|
|
||||||
|
bx_dbg_print_descriptor(lo, hi);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
dbg_printf("error: IDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n", n, idtr.base);
|
dbg_printf("error: IDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n", n, idtr.base);
|
||||||
@ -3002,7 +2992,11 @@ void bx_dbg_info_gdt_command(unsigned from, unsigned to)
|
|||||||
if (8*n + 7 > gdtr.limit) break;
|
if (8*n + 7 > gdtr.limit) break;
|
||||||
if (bx_dbg_read_linear(dbg_cpu, gdtr.base + 8*n, 8, entry)) {
|
if (bx_dbg_read_linear(dbg_cpu, gdtr.base + 8*n, 8, entry)) {
|
||||||
dbg_printf("GDT[0x%02x]=", n);
|
dbg_printf("GDT[0x%02x]=", n);
|
||||||
bx_dbg_print_descriptor(entry);
|
|
||||||
|
Bit32u lo = (entry[3] << 24) | (entry[2] << 16) | (entry[1] << 8) | (entry[0]);
|
||||||
|
Bit32u hi = (entry[7] << 24) | (entry[6] << 16) | (entry[5] << 8) | (entry[4]);
|
||||||
|
|
||||||
|
bx_dbg_print_descriptor(lo, hi);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
dbg_printf("error: GDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n",
|
dbg_printf("error: GDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n",
|
||||||
@ -3040,7 +3034,11 @@ void bx_dbg_info_ldt_command(unsigned from, unsigned to)
|
|||||||
if (8*n + 7 > ldtr_limit) break;
|
if (8*n + 7 > ldtr_limit) break;
|
||||||
if (bx_dbg_read_linear(dbg_cpu, ldtr_base + 8*n, 8, entry)) {
|
if (bx_dbg_read_linear(dbg_cpu, ldtr_base + 8*n, 8, entry)) {
|
||||||
dbg_printf("LDT[0x%02x]=", n);
|
dbg_printf("LDT[0x%02x]=", n);
|
||||||
bx_dbg_print_descriptor(entry);
|
|
||||||
|
Bit32u lo = (entry[3] << 24) | (entry[2] << 16) | (entry[1] << 8) | (entry[0]);
|
||||||
|
Bit32u hi = (entry[7] << 24) | (entry[6] << 16) | (entry[5] << 8) | (entry[4]);
|
||||||
|
|
||||||
|
bx_dbg_print_descriptor(lo, hi);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
dbg_printf("error: LDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n",
|
dbg_printf("error: LDTR+8*%d points to invalid linear address 0x" FMT_ADDRX "\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user