print physcial address with special format - preparations for 64-bit physical address emu

This commit is contained in:
Stanislav Shwartsman 2008-05-09 22:33:37 +00:00
parent 8e7cf2bf3a
commit 6ebae41ad7
9 changed files with 82 additions and 88 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: bochs.h,v 1.227 2008-04-19 13:21:21 sshwarts Exp $ // $Id: bochs.h,v 1.228 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -416,6 +416,9 @@ BOCHSAPI extern logfunc_t *genlog;
#define FMT_ADDRX FMT_ADDRX32 #define FMT_ADDRX FMT_ADDRX32
#endif #endif
#define FMT_PHY_ADDRX FMT_ADDRX32
#define FMT_LIN_ADDRX FMT_ADDRX
#if BX_GDBSTUB #if BX_GDBSTUB
// defines for GDB stub // defines for GDB stub
void bx_gdbstub_init(void); void bx_gdbstub_init(void);

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: dbg_main.cc,v 1.141 2008-05-03 21:32:01 sshwarts Exp $ // $Id: dbg_main.cc,v 1.142 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -519,7 +519,7 @@ void bx_dbg_lin_memory_access(unsigned cpu, bx_address lin, bx_phy_address phy,
if (! BX_CPU(dbg_cpu)->trace_mem) if (! BX_CPU(dbg_cpu)->trace_mem)
return; return;
dbg_printf("[CPU%d %s]: LIN 0x" FMT_ADDRX " PHY 0x%08x (len=%d, pl=%d)", dbg_printf("[CPU%d %s]: LIN 0x" FMT_ADDRX " PHY 0x" FMT_PHY_ADDRX " (len=%d, pl=%d)",
cpu, cpu,
(rw == BX_READ) ? "RD" : (rw == BX_WRITE) ? "WR" : "??", (rw == BX_READ) ? "RD" : (rw == BX_WRITE) ? "WR" : "??",
lin, phy, lin, phy,
@ -550,7 +550,7 @@ void bx_dbg_phy_memory_access(unsigned cpu, bx_phy_address phy, unsigned len, un
if (! BX_CPU(dbg_cpu)->trace_mem) if (! BX_CPU(dbg_cpu)->trace_mem)
return; return;
dbg_printf("[CPU%d %s]: PHY 0x%08x (len=%d)", dbg_printf("[CPU%d %s]: PHY 0x " FMT_PHY_ADDRX " (len=%d)",
cpu, cpu,
(rw == BX_READ) ? "RD" : (rw == BX_WRITE) ? "WR" : "??", (rw == BX_READ) ? "RD" : (rw == BX_WRITE) ? "WR" : "??",
phy, phy,
@ -660,7 +660,7 @@ void bx_dbg_info_control_regs_command(void)
{ {
Bit32u cr0 = SIM->get_param_num("CR0", dbg_cpu_list)->get(); Bit32u cr0 = SIM->get_param_num("CR0", dbg_cpu_list)->get();
bx_address cr2 = (bx_address) SIM->get_param_num("CR2", dbg_cpu_list)->get64(); bx_address cr2 = (bx_address) SIM->get_param_num("CR2", dbg_cpu_list)->get64();
bx_phy_address cr3 = (bx_phy_address) SIM->get_param_num("CR3", dbg_cpu_list)->get(); bx_phy_address cr3 = (bx_phy_address) SIM->get_param_num("CR3", dbg_cpu_list)->get64();
dbg_printf("CR0=0x%08x\n", cr0); dbg_printf("CR0=0x%08x\n", cr0);
dbg_printf(" PG=paging=%d\n", (cr0>>31) & 1); dbg_printf(" PG=paging=%d\n", (cr0>>31) & 1);
dbg_printf(" CD=cache disable=%d\n", (cr0>>30) & 1); dbg_printf(" CD=cache disable=%d\n", (cr0>>30) & 1);
@ -674,7 +674,7 @@ void bx_dbg_info_control_regs_command(void)
dbg_printf(" MP=monitor coprocessor=%d\n", (cr0>>1) & 1); dbg_printf(" MP=monitor coprocessor=%d\n", (cr0>>1) & 1);
dbg_printf(" PE=protection enable=%d\n", (cr0>>0) & 1); dbg_printf(" PE=protection enable=%d\n", (cr0>>0) & 1);
dbg_printf("CR2=page fault linear address=0x" FMT_ADDRX "\n", cr2); dbg_printf("CR2=page fault linear address=0x" FMT_ADDRX "\n", cr2);
dbg_printf("CR3=0x%08x\n", cr3); dbg_printf("CR3=0x " FMT_PHY_ADDRX "\n", cr3);
dbg_printf(" PCD=page-level cache disable=%d\n", (cr3>>4) & 1); dbg_printf(" PCD=page-level cache disable=%d\n", (cr3>>4) & 1);
dbg_printf(" PWT=page-level writes transparent=%d\n", (cr3>>3) & 1); dbg_printf(" PWT=page-level writes transparent=%d\n", (cr3>>3) & 1);
#if BX_CPU_LEVEL >= 4 #if BX_CPU_LEVEL >= 4
@ -1061,7 +1061,7 @@ next_page:
paddr_valid = BX_CPU(which_cpu)->dbg_xlate_linear2phy(laddr, &paddr); paddr_valid = BX_CPU(which_cpu)->dbg_xlate_linear2phy(laddr, &paddr);
if (paddr_valid) { if (paddr_valid) {
if (! BX_MEM(0)->dbg_fetch_mem(BX_CPU(which_cpu), paddr, read_len, buf)) { if (! BX_MEM(0)->dbg_fetch_mem(BX_CPU(which_cpu), paddr, read_len, buf)) {
dbg_printf("bx_dbg_read_linear: physical memory read error (phy=0x%08x, lin=0x" FMT_ADDRX ")\n", paddr, laddr); dbg_printf("bx_dbg_read_linear: physical memory read error (phy=0x" FMT_PHY_ADDRX ", lin=0x" FMT_ADDRX ")\n", paddr, laddr);
return 0; return 0;
} }
} }
@ -1173,7 +1173,7 @@ void bx_dbg_xlate_address(bx_lin_address laddr)
bx_bool paddr_valid = BX_CPU(dbg_cpu)->dbg_xlate_linear2phy(laddr, &paddr); bx_bool paddr_valid = BX_CPU(dbg_cpu)->dbg_xlate_linear2phy(laddr, &paddr);
if (paddr_valid) { if (paddr_valid) {
dbg_printf("linear page 0x" FMT_ADDRX " maps to physical page 0x%08x\n", laddr, paddr); dbg_printf("linear page 0x" FMT_ADDRX " maps to physical page 0x" FMT_PHY_ADDRX "\n", laddr, paddr);
} }
else { else {
dbg_printf("physical address not available for linear 0x" FMT_ADDRX "\n", laddr); dbg_printf("physical address not available for linear 0x" FMT_ADDRX "\n", laddr);
@ -1359,7 +1359,7 @@ int bx_dbg_show_symbolic(void)
} }
if(last_cr3 != BX_CPU(dbg_cpu)->cr3) if(last_cr3 != BX_CPU(dbg_cpu)->cr3)
dbg_printf(FMT_TICK ": address space switched. CR3: 0x%08x\n", dbg_printf(FMT_TICK ": address space switched. CR3: 0x" FMT_PHY_ADDRX "\n",
bx_pc_system.time_ticks(), BX_CPU(dbg_cpu)->cr3); bx_pc_system.time_ticks(), BX_CPU(dbg_cpu)->cr3);
} }
@ -1406,7 +1406,7 @@ int bx_dbg_show_symbolic(void)
BX_CPU(dbg_cpu)->guard_found.laddr); BX_CPU(dbg_cpu)->guard_found.laddr);
if (!valid) dbg_printf(" phys not valid"); if (!valid) dbg_printf(" phys not valid");
else { else {
dbg_printf(" (phy: 0x%08x) %s", phy, dbg_printf(" (phy: 0x" FMT_PHY_ADDRX ") %s", phy,
bx_dbg_symbolic_address(BX_CPU(dbg_cpu)->cr3, bx_dbg_symbolic_address(BX_CPU(dbg_cpu)->cr3,
BX_CPU(dbg_cpu)->guard_found.eip, BX_CPU(dbg_cpu)->guard_found.eip,
BX_CPU(dbg_cpu)->guard_found.laddr - BX_CPU(dbg_cpu)->guard_found.eip)); BX_CPU(dbg_cpu)->guard_found.laddr - BX_CPU(dbg_cpu)->guard_found.eip));
@ -1489,17 +1489,17 @@ void bx_dbg_watch(int read, bx_phy_address address)
for (i = 0; i < num_read_watchpoints; i++) { for (i = 0; i < num_read_watchpoints; i++) {
Bit8u buf[2]; Bit8u buf[2];
if (BX_MEM(0)->dbg_fetch_mem(BX_CPU(dbg_cpu), read_watchpoint[i], 2, buf)) if (BX_MEM(0)->dbg_fetch_mem(BX_CPU(dbg_cpu), read_watchpoint[i], 2, buf))
dbg_printf("read %08x (%04x)\n", dbg_printf("read 0x"FMT_PHY_ADDRX" (%04x)\n",
read_watchpoint[i], (int)buf[0] | ((int)buf[1] << 8)); read_watchpoint[i], (int)buf[0] | ((int)buf[1] << 8));
else else
dbg_printf("read %08x (read error)\n", read_watchpoint[i]); dbg_printf("read 0x"FMT_PHY_ADDRX" (read error)\n", read_watchpoint[i]);
} }
for (i = 0; i < num_write_watchpoints; i++) { for (i = 0; i < num_write_watchpoints; i++) {
Bit8u buf[2]; Bit8u buf[2];
if (BX_MEM(0)->dbg_fetch_mem(BX_CPU(dbg_cpu), write_watchpoint[i], 2, buf)) if (BX_MEM(0)->dbg_fetch_mem(BX_CPU(dbg_cpu), write_watchpoint[i], 2, buf))
dbg_printf("write %08x (%04x)\n", write_watchpoint[i], (int)buf[0] | ((int)buf[1] << 8)); dbg_printf("write 0x"FMT_PHY_ADDRX" (%04x)\n", write_watchpoint[i], (int)buf[0] | ((int)buf[1] << 8));
else else
dbg_printf("write %08x (read error)\n", write_watchpoint[i]); dbg_printf("write 0x"FMT_PHY_ADDRX" (read error)\n", write_watchpoint[i]);
} }
} else { } else {
if (read) { if (read) {
@ -1508,14 +1508,14 @@ void bx_dbg_watch(int read, bx_phy_address address)
return; return;
} }
read_watchpoint[num_read_watchpoints++] = address; read_watchpoint[num_read_watchpoints++] = address;
dbg_printf("Read watchpoint at 0x%08x inserted\n", address); dbg_printf("Read watchpoint at 0x" FMT_PHY_ADDRX " inserted\n", address);
} else { } else {
if (num_write_watchpoints == MAX_WRITE_WATCHPOINTS) { if (num_write_watchpoints == MAX_WRITE_WATCHPOINTS) {
dbg_printf("Too many write watchpoints\n"); dbg_printf("Too many write watchpoints\n");
return; return;
} }
write_watchpoint[num_write_watchpoints++] = address; write_watchpoint[num_write_watchpoints++] = address;
dbg_printf("Write watchpoint at 0x%08x inserted\n", address); dbg_printf("Write watchpoint at 0x" FMT_PHY_ADDRX " inserted\n", address);
} }
} }
} }
@ -1713,7 +1713,7 @@ void bx_dbg_disassemble_current(int which_cpu, int print_time)
dbg_printf("(%u) ", which_cpu); dbg_printf("(%u) ", which_cpu);
if (BX_CPU(which_cpu)->protected_mode()) { if (BX_CPU(which_cpu)->protected_mode()) {
dbg_printf("[0x%08x] %04x:" FMT_ADDRX " (%s): ", dbg_printf("[0x"FMT_PHY_ADDRX"] %04x:" FMT_ADDRX " (%s): ",
phy, BX_CPU(which_cpu)->guard_found.cs, phy, BX_CPU(which_cpu)->guard_found.cs,
BX_CPU(which_cpu)->guard_found.eip, BX_CPU(which_cpu)->guard_found.eip,
bx_dbg_symbolic_address((BX_CPU(which_cpu)->cr3) >> 12, bx_dbg_symbolic_address((BX_CPU(which_cpu)->cr3) >> 12,
@ -1721,7 +1721,7 @@ void bx_dbg_disassemble_current(int which_cpu, int print_time)
BX_CPU(which_cpu)->get_segment_base(BX_SEG_REG_CS))); BX_CPU(which_cpu)->get_segment_base(BX_SEG_REG_CS)));
} }
else { // Real & V86 mode else { // Real & V86 mode
dbg_printf("[0x%08x] %04x:%04x (%s): ", dbg_printf("[0x"FMT_PHY_ADDRX"] %04x:%04x (%s): ",
phy, BX_CPU(which_cpu)->guard_found.cs, phy, BX_CPU(which_cpu)->guard_found.cs,
(unsigned) BX_CPU(which_cpu)->guard_found.eip, (unsigned) BX_CPU(which_cpu)->guard_found.eip,
bx_dbg_symbolic_address_16bit(BX_CPU(which_cpu)->guard_found.eip, bx_dbg_symbolic_address_16bit(BX_CPU(which_cpu)->guard_found.eip,
@ -1779,10 +1779,10 @@ void bx_dbg_print_guard_results(void)
dbg_printf("(%u) Caught time breakpoint\n", cpu); dbg_printf("(%u) Caught time breakpoint\n", cpu);
break; break;
case STOP_READ_WATCH_POINT: case STOP_READ_WATCH_POINT:
dbg_printf("(%u) Caught read watch point at %08X\n", cpu, BX_CPU(cpu)->watchpoint); dbg_printf("(%u) Caught read watch point at 0x" FMT_PHY_ADDRX "\n", cpu, BX_CPU(cpu)->watchpoint);
break; break;
case STOP_WRITE_WATCH_POINT: case STOP_WRITE_WATCH_POINT:
dbg_printf("(%u) Caught write watch point at %08X\n", cpu, BX_CPU(cpu)->watchpoint); dbg_printf("(%u) Caught write watch point at 0x" FMT_PHY_ADDRX "\n", cpu, BX_CPU(cpu)->watchpoint);
break; break;
case STOP_MAGIC_BREAK_POINT: case STOP_MAGIC_BREAK_POINT:
dbg_printf("(%u) Magic breakpoint\n", cpu); dbg_printf("(%u) Magic breakpoint\n", cpu);
@ -1799,7 +1799,7 @@ void bx_dbg_print_guard_results(void)
if (bx_debugger.auto_disassemble) { if (bx_debugger.auto_disassemble) {
if (cpu==0) { if (cpu==0) {
// print this only once // print this only once
dbg_printf("Next at t=" FMT_LL "d\n", bx_pc_system.time_ticks ()); dbg_printf("Next at t=" FMT_LL "d\n", bx_pc_system.time_ticks());
} }
bx_dbg_disassemble_current(cpu, 0); // one cpu, don't print time bx_dbg_disassemble_current(cpu, 0); // one cpu, don't print time
} }
@ -2102,7 +2102,7 @@ void bx_dbg_info_bpoints_command(void)
dbg_printf("pbreakpoint "); dbg_printf("pbreakpoint ");
dbg_printf("keep "); dbg_printf("keep ");
dbg_printf(bx_guard.iaddr.phy[i].enabled?"y ":"n "); dbg_printf(bx_guard.iaddr.phy[i].enabled?"y ":"n ");
dbg_printf("0x%08x\n", bx_guard.iaddr.phy[i].addr); dbg_printf("0x"FMT_PHY_ADDRX"\n", bx_guard.iaddr.phy[i].addr);
} }
#endif #endif
} }
@ -2770,14 +2770,14 @@ void bx_dbg_print_descriptor(unsigned char desc[8], int verbose)
// 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, linearaddr=%08x, limit=%05x %s, %s%s%s, %d-bit\n", dbg_printf("Code segment, laddr=%08x, limit=%05x %s, %s%s%s, %d-bit\n",
base, limit, g ? "* 4Kbytes" : "bytes", base, limit, g ? "* 4Kbytes" : "bytes",
(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, linearaddr=%08x, limit=%05x %s, %s%s%s\n", dbg_printf("Data segment, laddr=%08x, limit=%05x %s, %s%s%s\n",
base, limit, g ? "* 4Kbytes" : "bytes", base, limit, g ? "* 4Kbytes" : "bytes",
(type&2)? "Read/Write" : "Read-Only", (type&2)? "Read/Write" : "Read-Only",
(type&4)? ", Expand-down" : "", (type&4)? ", Expand-down" : "",
@ -3272,7 +3272,7 @@ void bx_dbg_dump_table(void)
return; return;
} }
printf("cr3: 0x%08x\n", BX_CPU(dbg_cpu)->cr3); printf("cr3: 0x"FMT_PHY_ADDRX"\n", BX_CPU(dbg_cpu)->cr3);
lin = 0; lin = 0;
phy = 0; phy = 0;
@ -3284,14 +3284,14 @@ void bx_dbg_dump_table(void)
if(valid) { if(valid) {
if((lin - start_lin) != (phy - start_phy)) { if((lin - start_lin) != (phy - start_phy)) {
if(start_lin != 1) if(start_lin != 1)
dbg_printf("0x%08x-0x%08x -> 0x%08x-0x%08x\n", dbg_printf("0x%08x-0x%08x -> 0x"FMT_PHY_ADDRX"-0x"FMT_PHY_ADDRX"\n",
start_lin, lin - 1, start_phy, start_phy + (lin-1-start_lin)); start_lin, lin - 1, start_phy, start_phy + (lin-1-start_lin));
start_lin = lin; start_lin = lin;
start_phy = phy; start_phy = phy;
} }
} else { } else {
if(start_lin != 1) if(start_lin != 1)
dbg_printf("0x%08x-0x%08x -> 0x%08x-0x%08x\n", dbg_printf("0x%08x-0x%08x -> 0x"FMT_PHY_ADDRX"-0x"FMT_PHY_ADDRX"\n",
start_lin, lin - 1, start_phy, start_phy + (lin-1-start_lin)); start_lin, lin - 1, start_phy, start_phy + (lin-1-start_lin));
start_lin = 1; start_lin = 1;
start_phy = 2; start_phy = 2;
@ -3301,7 +3301,7 @@ void bx_dbg_dump_table(void)
lin += 0x1000; lin += 0x1000;
} }
if(start_lin != 1) if(start_lin != 1)
dbg_printf("0x%08x-0x%08x -> 0x%08x-0x%08x\n", dbg_printf("0x%08x-0x%08x -> 0x"FMT_PHY_ADDRX"-0x"FMT_PHY_ADDRX"\n",
start_lin, 0xffffffff, start_phy, start_phy + (0xffffffff-start_lin)); start_lin, 0xffffffff, start_phy, start_phy + (0xffffffff-start_lin));
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: apic.cc,v 1.107 2008-02-15 19:03:53 sshwarts Exp $ // $Id: apic.cc,v 1.108 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (c) 2002 Zwane Mwaikambo, Stanislav Shwartsman // Copyright (c) 2002 Zwane Mwaikambo, Stanislav Shwartsman
@ -179,7 +179,7 @@ void bx_generic_apic_c::set_base(bx_phy_address newbase)
newbase &= (~0xfff); newbase &= (~0xfff);
base_addr = newbase; base_addr = newbase;
if (id != APIC_UNKNOWN_ID) if (id != APIC_UNKNOWN_ID)
BX_INFO(("relocate APIC id=%d to 0x%08x", id, newbase)); BX_INFO(("relocate APIC id=%d to 0x" FMT_PHY_ADDRX, id, newbase));
} }
void bx_generic_apic_c::set_id(Bit8u newid) void bx_generic_apic_c::set_id(Bit8u newid)
@ -192,7 +192,7 @@ bx_bool bx_generic_apic_c::is_selected(bx_phy_address addr, unsigned len)
{ {
if((addr & ~0xfff) == get_base()) { if((addr & ~0xfff) == get_base()) {
if((addr & 0xf) != 0) if((addr & 0xf) != 0)
BX_INFO(("warning: misaligned APIC access. addr=0x%08x, len=%d", addr, len)); BX_INFO(("warning: misaligned APIC access. addr=0x" FMT_PHY_ADDRX ", len=%d", addr, len));
return 1; return 1;
} }
return 0; return 0;
@ -201,7 +201,7 @@ bx_bool bx_generic_apic_c::is_selected(bx_phy_address addr, unsigned len)
void bx_generic_apic_c::read(bx_phy_address addr, void *data, unsigned len) void bx_generic_apic_c::read(bx_phy_address addr, void *data, unsigned len)
{ {
if((addr & ~0x3) != ((addr+len-1) & ~0x3)) { if((addr & ~0x3) != ((addr+len-1) & ~0x3)) {
BX_PANIC(("APIC read at address 0x%08x spans 32-bit boundary !", addr)); BX_PANIC(("APIC read at address 0x" FMT_PHY_ADDRX " spans 32-bit boundary !", addr));
return; return;
} }
Bit32u value; Bit32u value;
@ -217,13 +217,13 @@ void bx_generic_apic_c::read(bx_phy_address addr, void *data, unsigned len)
else if (len == 2) else if (len == 2)
*((Bit16u *)data) = value & 0xffff; *((Bit16u *)data) = value & 0xffff;
else else
BX_PANIC(("Unsupported APIC read at address 0x%08x, len=%d", addr, len)); BX_PANIC(("Unsupported APIC read at address 0x" FMT_PHY_ADDRX ", len=%d", addr, len));
} }
void bx_generic_apic_c::write(bx_phy_address addr, void *data, unsigned len) void bx_generic_apic_c::write(bx_phy_address addr, void *data, unsigned len)
{ {
if((addr & ~0x3) != ((addr+len-1) & ~0x3)) { if((addr & ~0x3) != ((addr+len-1) & ~0x3)) {
BX_PANIC(("APIC write at address 0x%08x spans 32-bit boundary !", addr)); BX_PANIC(("APIC write at address 0x" FMT_PHY_ADDRX " spans 32-bit boundary !", addr));
return; return;
} }
bx_phy_address addr_aligned = addr & ~0x3; bx_phy_address addr_aligned = addr & ~0x3;
@ -246,7 +246,7 @@ void bx_generic_apic_c::write(bx_phy_address addr, void *data, unsigned len)
value |= (*((Bit16u *)data) << shift); value |= (*((Bit16u *)data) << shift);
} }
else { else {
BX_PANIC(("Unsupported APIC write at address 0x%08x, len=%d", addr, len)); BX_PANIC(("Unsupported APIC write at address 0x" FMT_PHY_ADDRX ", len=%d", addr, len));
} }
write_aligned(addr_aligned, &value); write_aligned(addr_aligned, &value);
} }
@ -335,11 +335,11 @@ void bx_local_apic_c::set_id(Bit8u newid)
// APIC write: 4 byte write to 16-byte aligned APIC address // APIC write: 4 byte write to 16-byte aligned APIC address
void bx_local_apic_c::write_aligned(bx_phy_address addr, Bit32u *data) void bx_local_apic_c::write_aligned(bx_phy_address addr, Bit32u *data)
{ {
BX_DEBUG(("%s: LAPIC write 0x%08x to address %08x", cpu->name, *data, addr)); BX_DEBUG(("%s: LAPIC write 0x" FMT_PHY_ADDRX " to address %08x", cpu->name, *data, addr));
BX_ASSERT((addr & 0xf) == 0); BX_ASSERT((addr & 0xf) == 0);
addr &= 0xff0; Bit32u apic_reg = addr & 0xff0;
Bit32u value = *data; Bit32u value = *data;
switch(addr) { switch(apic_reg) {
case 0x20: // local APIC id case 0x20: // local APIC id
id = (value>>24) & APIC_ID_MASK; id = (value>>24) & APIC_ID_MASK;
break; break;
@ -423,12 +423,12 @@ void bx_local_apic_c::write_aligned(bx_phy_address addr, Bit32u *data)
// current count for timer // current count for timer
case 0x390: case 0x390:
// all read-only registers should fall into this line // all read-only registers should fall into this line
BX_INFO(("warning: write to read-only APIC register 0x%02x", addr)); BX_INFO(("warning: write to read-only APIC register 0x%x", apic_reg));
break; break;
default: default:
shadow_error_status |= APIC_ERR_ILLEGAL_ADDR; shadow_error_status |= APIC_ERR_ILLEGAL_ADDR;
// but for now I want to know about it in case I missed some. // but for now I want to know about it in case I missed some.
BX_PANIC(("APIC register %08x not implemented", addr)); BX_PANIC(("APIC register %x not implemented", apic_reg));
} }
} }
@ -481,7 +481,7 @@ void bx_local_apic_c::send_ipi(void)
void bx_local_apic_c::write_spurious_interrupt_register(Bit32u value) void bx_local_apic_c::write_spurious_interrupt_register(Bit32u value)
{ {
BX_DEBUG(("write %08x to spurious interrupt register", value)); BX_DEBUG(("write of %08x to spurious interrupt register", value));
#ifdef BX_IMPLEMENT_XAPIC #ifdef BX_IMPLEMENT_XAPIC
spurious_vector = value & 0xff; spurious_vector = value & 0xff;
@ -529,7 +529,7 @@ void bx_local_apic_c::startup_msg(Bit32u vector)
cpu->gen_reg[BX_32BIT_REG_EIP].dword.erx = 0; cpu->gen_reg[BX_32BIT_REG_EIP].dword.erx = 0;
cpu->load_seg_reg(&cpu->sregs[BX_SEG_REG_CS], vector*0x100); cpu->load_seg_reg(&cpu->sregs[BX_SEG_REG_CS], vector*0x100);
BX_INFO(("%s started up at %04X:%08X by APIC", BX_INFO(("%s started up at %04X:%08X by APIC",
cpu->name, vector*0x100, cpu->gen_reg[BX_32BIT_REG_EIP].dword.erx)); cpu->name, vector*0x100, cpu->get_eip()));
} else { } else {
BX_INFO(("%s started up by APIC, but was not halted at the time", cpu->name)); BX_INFO(("%s started up by APIC, but was not halted at the time", cpu->name));
} }
@ -538,11 +538,11 @@ void bx_local_apic_c::startup_msg(Bit32u vector)
// APIC read: 4 byte read from 16-byte aligned APIC address // APIC read: 4 byte read from 16-byte aligned APIC address
void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data) void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
{ {
BX_DEBUG(("%s: LAPIC read from address %08x", cpu->name, addr)); BX_DEBUG(("%s: LAPIC read from address 0x" FMT_PHY_ADDRX, cpu->name, addr));
BX_ASSERT((addr & 0xf) == 0); BX_ASSERT((addr & 0xf) == 0);
*data = 0; // default value for unimplemented registers *data = 0; // default value for unimplemented registers
bx_phy_address addr2 = addr & 0xff0; bx_phy_address apic_reg = addr & 0xff0;
switch(addr2) { switch(apic_reg) {
case 0x20: // local APIC id case 0x20: // local APIC id
*data = (id) << 24; break; *data = (id) << 24; break;
case 0x30: // local APIC version case 0x30: // local APIC version
@ -577,7 +577,7 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
case 0x140: case 0x150: case 0x140: case 0x150:
case 0x160: case 0x170: case 0x160: case 0x170:
{ {
unsigned index = (addr2 - 0x100) << 1; unsigned index = (apic_reg - 0x100) << 1;
Bit32u value = 0, mask = 1; Bit32u value = 0, mask = 1;
for(int i=0;i<32;i++) { for(int i=0;i<32;i++) {
if(isr[index+i]) value |= mask; if(isr[index+i]) value |= mask;
@ -591,7 +591,7 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
case 0x1c0: case 0x1d0: case 0x1c0: case 0x1d0:
case 0x1e0: case 0x1f0: case 0x1e0: case 0x1f0:
{ {
unsigned index = (addr2 - 0x180) << 1; unsigned index = (apic_reg - 0x180) << 1;
Bit32u value = 0, mask = 1; Bit32u value = 0, mask = 1;
for(int i=0;i<32;i++) { for(int i=0;i<32;i++) {
if(tmr[index+i]) value |= mask; if(tmr[index+i]) value |= mask;
@ -605,7 +605,7 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
case 0x240: case 0x250: case 0x240: case 0x250:
case 0x260: case 0x270: case 0x260: case 0x270:
{ {
unsigned index = (addr2 - 0x200) << 1; unsigned index = (apic_reg - 0x200) << 1;
Bit32u value = 0, mask = 1; Bit32u value = 0, mask = 1;
for(int i=0;i<32;i++) { for(int i=0;i<32;i++) {
if(irr[index+i]) value |= mask; if(irr[index+i]) value |= mask;
@ -627,7 +627,7 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
case 0x360: // LVT Lint1 Reg case 0x360: // LVT Lint1 Reg
case 0x370: // LVT Error Reg case 0x370: // LVT Error Reg
{ {
int index = (addr2 - 0x320) >> 4; int index = (apic_reg - 0x320) >> 4;
*data = lvt[index]; *data = lvt[index];
break; break;
} }
@ -638,10 +638,8 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
if(timer_active==0) { if(timer_active==0) {
*data = timer_current; *data = timer_current;
} else { } else {
Bit64u delta64; Bit64u delta64 = (bx_pc_system.time_ticks() - ticksInitial) / timer_divide_factor;
Bit32u delta32; Bit32u delta32 = (Bit32u) delta64;
delta64 = (bx_pc_system.time_ticks() - ticksInitial) / timer_divide_factor;
delta32 = (Bit32u) delta64;
if(delta32 > timer_initial) if(delta32 > timer_initial)
BX_PANIC(("APIC: R(curr timer count): delta < initial")); BX_PANIC(("APIC: R(curr timer count): delta < initial"));
timer_current = timer_initial - delta32; timer_current = timer_initial - delta32;
@ -652,10 +650,10 @@ void bx_local_apic_c::read_aligned(bx_phy_address addr, Bit32u *data)
*data = timer_divconf; *data = timer_divconf;
break; break;
default: default:
BX_INFO(("APIC register %08x not implemented", addr)); BX_INFO(("APIC register %08x not implemented", apic_reg));
} }
BX_DEBUG(("%s: read from APIC address %08x = %08x", cpu->name, addr, *data)); BX_DEBUG(("%s: read from APIC address 0x" FMT_PHY_ADDRX " = %08x", cpu->name, addr, *data));
} }
int bx_local_apic_c::highest_priority_int(Bit8u *array) int bx_local_apic_c::highest_priority_int(Bit8u *array)

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: cpu.cc,v 1.227 2008-05-04 05:37:36 sshwarts Exp $ // $Id: cpu.cc,v 1.228 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -668,10 +668,10 @@ void BX_CPU_C::prefetch(void)
// Sanity checks // Sanity checks
if (! BX_CPU_THIS_PTR eipFetchPtr) { if (! BX_CPU_THIS_PTR eipFetchPtr) {
if (pAddr >= BX_MEM(0)->get_memory_len()) { if (pAddr >= BX_MEM(0)->get_memory_len()) {
BX_PANIC(("prefetch: running in bogus memory, pAddr=0x%08x", pAddr)); BX_PANIC(("prefetch: running in bogus memory, pAddr=0x" FMT_PHY_ADDRX, pAddr));
} }
else { else {
BX_PANIC(("prefetch: getHostMemAddr vetoed direct read, pAddr=0x%08x", pAddr)); BX_PANIC(("prefetch: getHostMemAddr vetoed direct read, pAddr=0x" FMT_PHY_ADDRX, pAddr));
} }
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: paging.cc,v 1.126 2008-05-02 22:47:07 sshwarts Exp $ // $Id: paging.cc,v 1.127 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -449,8 +449,8 @@ BX_CPU_C::pagingCR4Changed(Bit32u oldCR4, Bit32u newCR4)
BX_CPU_C::CR3_change(bx_phy_address value) BX_CPU_C::CR3_change(bx_phy_address value)
{ {
if (bx_dbg.paging) { if (bx_dbg.paging) {
BX_INFO(("CR3_change(): flush TLB cache")); BX_DEBUG(("CR3_change(): flush TLB cache"));
BX_INFO(("Page Directory Base %08x", (unsigned) value)); BX_DEBUG(("Page Directory Base: 0x" FMT_PHY_ADDRX, value));
} }
// flush TLB even if value does not change // flush TLB even if value does not change
@ -657,11 +657,7 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
// generate an exception if one is warranted. // generate an exception if one is warranted.
} }
#if BX_SUPPORT_X86_64 BX_DEBUG(("page walk for address 0x" FMT_LIN_ADDRX, laddr));
BX_DEBUG(("page walk for address 0x%08x:%08x", GET32H(laddr), GET32L(laddr)));
#else
BX_DEBUG(("page walk for address 0x%08x", laddr));
#endif
InstrTLB_Increment(tlbMisses); InstrTLB_Increment(tlbMisses);

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: proc_ctrl.cc,v 1.226 2008-05-09 08:28:00 sshwarts Exp $ // $Id: proc_ctrl.cc,v 1.227 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -618,11 +618,11 @@ void BX_CPP_AttrRegparmN(1) BX_CPU_C::MOV_CdRd(bxInstruction_c *i)
SetCR0(val_32); SetCR0(val_32);
break; break;
case 2: /* CR2 */ case 2: /* CR2 */
BX_DEBUG(("MOV_CdRd:CR2 = %08x", (unsigned) val_32)); BX_DEBUG(("MOV_CdRd:CR2 = %08x", val_32));
BX_CPU_THIS_PTR cr2 = val_32; BX_CPU_THIS_PTR cr2 = val_32;
break; break;
case 3: // CR3 case 3: // CR3
BX_DEBUG(("MOV_CdRd:CR3 = %08x", (unsigned) val_32)); BX_DEBUG(("MOV_CdRd:CR3 = %08x", val_32));
// Reserved bits take on value of MOV instruction // Reserved bits take on value of MOV instruction
CR3_change(val_32); CR3_change(val_32);
BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_MOV_CR3, val_32); BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_MOV_CR3, val_32);
@ -728,13 +728,11 @@ void BX_CPP_AttrRegparmN(1) BX_CPU_C::MOV_CqRq(bxInstruction_c *i)
SetCR0((Bit32u) val_64); SetCR0((Bit32u) val_64);
break; break;
case 2: /* CR2 */ case 2: /* CR2 */
BX_DEBUG(("MOV_CqRq: write to CR2 of %08x:%08x", BX_DEBUG(("MOV_CqRq: write to CR2 of %08x:%08x", GET32H(val_64), GET32L(val_64)));
(Bit32u)(val_64 >> 32), (Bit32u)(val_64 & 0xFFFFFFFF)));
BX_CPU_THIS_PTR cr2 = val_64; BX_CPU_THIS_PTR cr2 = val_64;
break; break;
case 3: // CR3 case 3: // CR3
BX_DEBUG(("MOV_CqRq: write to CR3 of %08x:%08x", BX_DEBUG(("MOV_CqRq: write to CR3 of %08x:%08x", GET32H(val_64), GET32L(val_64)));
(Bit32u)(val_64 >> 32), (Bit32u)(val_64 & 0xFFFFFFFF)));
if (val_64 & BX_CONST64(0xffffffff00000000)) { if (val_64 & BX_CONST64(0xffffffff00000000)) {
BX_PANIC(("CR3 write: Only 32 bit physical address space is emulated !")); BX_PANIC(("CR3 write: Only 32 bit physical address space is emulated !"));
} }
@ -745,8 +743,7 @@ void BX_CPP_AttrRegparmN(1) BX_CPU_C::MOV_CqRq(bxInstruction_c *i)
case 4: // CR4 case 4: // CR4
// Protected mode: #GP(0) if attempt to write a 1 to // Protected mode: #GP(0) if attempt to write a 1 to
// any reserved bit of CR4 // any reserved bit of CR4
BX_DEBUG(("MOV_CqRq: write to CR4 of %08x:%08x", BX_DEBUG(("MOV_CqRq: write to CR4 of %08x:%08x", GET32H(val_64), GET32L(val_64)));
(Bit32u)(val_64 >> 32), (Bit32u)(val_64 & 0xFFFFFFFF)));
if (! SetCR4(val_64)) if (! SetCR4(val_64))
exception(BX_GP_EXCEPTION, 0, 0); exception(BX_GP_EXCEPTION, 0, 0);
break; break;
@ -2023,7 +2020,7 @@ void BX_CPP_AttrRegparmN(1) BX_CPU_C::MWAIT(bxInstruction_c *i)
bx_pc_system.invlpg(BX_CPU_THIS_PTR monitor.monitor_begin); bx_pc_system.invlpg(BX_CPU_THIS_PTR monitor.monitor_begin);
if ((BX_CPU_THIS_PTR monitor.monitor_end & ~0xfff) != (BX_CPU_THIS_PTR monitor.monitor_begin & ~0xfff)) if ((BX_CPU_THIS_PTR monitor.monitor_end & ~0xfff) != (BX_CPU_THIS_PTR monitor.monitor_begin & ~0xfff))
bx_pc_system.invlpg(BX_CPU_THIS_PTR monitor.monitor_end); bx_pc_system.invlpg(BX_CPU_THIS_PTR monitor.monitor_end);
BX_DEBUG(("MWAIT for phys_addr=%08x", BX_CPU_THIS_PTR monitor.monitor_begin)); BX_DEBUG(("MWAIT for phys_addr=" FMT_PHY_ADDRX, BX_CPU_THIS_PTR monitor.monitor_begin));
BX_MEM(0)->set_monitor(BX_CPU_THIS_PTR bx_cpuid); BX_MEM(0)->set_monitor(BX_CPU_THIS_PTR bx_cpuid);
// stops instruction execution and places the processor in a optimized // stops instruction execution and places the processor in a optimized

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: tasking.cc,v 1.57 2008-04-28 18:14:50 sshwarts Exp $ // $Id: tasking.cc,v 1.58 2008-05-09 22:33:36 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -421,7 +421,7 @@ void BX_CPU_C::task_switch(bx_selector_t *tss_selector,
// change CR3 only if it actually modified // change CR3 only if it actually modified
if (newCR3 != BX_CPU_THIS_PTR cr3) { if (newCR3 != BX_CPU_THIS_PTR cr3) {
CR3_change(newCR3); // Tell paging unit about new cr3 value CR3_change(newCR3); // Tell paging unit about new cr3 value
BX_DEBUG (("task_switch changing CR3 to 0x%08x", newCR3)); BX_DEBUG (("task_switch changing CR3 to 0x" FMT_PHY_ADDRX, newCR3));
BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_TASKSWITCH, newCR3); BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_TASKSWITCH, newCR3);
} }
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: memory.cc,v 1.67 2008-05-02 23:18:51 sshwarts Exp $ // $Id: memory.cc,v 1.68 2008-05-09 22:33:37 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -52,7 +52,7 @@ void BX_MEM_C::writePhysicalPage(BX_CPU_C *cpu, bx_phy_address addr, unsigned le
// Note: accesses should always be contained within a single page now // Note: accesses should always be contained within a single page now
if ((addr>>12) != ((addr+len-1)>>12)) { if ((addr>>12) != ((addr+len-1)>>12)) {
BX_PANIC(("writePhysicalPage: cross page access at address 0x%08x, len=%d", addr, len)); BX_PANIC(("writePhysicalPage: cross page access at address 0x" FMT_PHY_ADDRX ", len=%d", addr, len));
} }
#if BX_SUPPORT_MONITOR_MWAIT #if BX_SUPPORT_MONITOR_MWAIT
@ -185,13 +185,13 @@ mem_write:
{ {
switch (DEV_pci_wr_memtype(a20addr)) { switch (DEV_pci_wr_memtype(a20addr)) {
case 0x1: // Writes to ShadowRAM case 0x1: // Writes to ShadowRAM
BX_DEBUG(("Writing to ShadowRAM: address %08x, data %02x", (unsigned) a20addr, *data_ptr)); BX_DEBUG(("Writing to ShadowRAM: address 0x" FMT_PHY_ADDRX ", data %02x", a20addr, *data_ptr));
*(BX_MEM_THIS get_vector(a20addr)) = *data_ptr; *(BX_MEM_THIS get_vector(a20addr)) = *data_ptr;
BX_DBG_DIRTY_PAGE(a20addr >> 12); BX_DBG_DIRTY_PAGE(a20addr >> 12);
break; break;
case 0x0: // Writes to ROM, Inhibit case 0x0: // Writes to ROM, Inhibit
BX_DEBUG(("Write to ROM ignored: address %08x, data %02x", (unsigned) a20addr, *data_ptr)); BX_DEBUG(("Write to ROM ignored: address 0x" FMT_PHY_ADDRX ", data %02x", a20addr, *data_ptr));
break; break;
default: default:
@ -212,7 +212,7 @@ inc_one:
} }
else { else {
// access outside limits of physical memory, ignore // access outside limits of physical memory, ignore
BX_DEBUG(("Write outside the limits of physical memory (0x%08x) (ignore)", a20addr)); BX_DEBUG(("Write outside the limits of physical memory (0x"FMT_PHY_ADDRX") (ignore)", a20addr));
} }
} }
@ -224,7 +224,7 @@ void BX_MEM_C::readPhysicalPage(BX_CPU_C *cpu, bx_phy_address addr, unsigned len
// Note: accesses should always be contained within a single page now // Note: accesses should always be contained within a single page now
if ((addr>>12) != ((addr+len-1)>>12)) { if ((addr>>12) != ((addr+len-1)>>12)) {
BX_PANIC(("readPhysicalPage: cross page access at address 0x%08x, len=%d", addr, len)); BX_PANIC(("readPhysicalPage: cross page access at address 0x" FMT_PHY_ADDRX ", len=%d", addr, len));
} }
if (cpu != NULL) { if (cpu != NULL) {

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: misc_mem.cc,v 1.113 2008-05-01 20:28:36 sshwarts Exp $ // $Id: misc_mem.cc,v 1.114 2008-05-09 22:33:37 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -76,7 +76,7 @@ void BX_MEM_C::init_memory(Bit32u memsize)
{ {
unsigned idx; unsigned idx;
BX_DEBUG(("Init $Id: misc_mem.cc,v 1.113 2008-05-01 20:28:36 sshwarts Exp $")); BX_DEBUG(("Init $Id: misc_mem.cc,v 1.114 2008-05-09 22:33:37 sshwarts Exp $"));
if (BX_MEM_THIS actual_vector != NULL) { if (BX_MEM_THIS actual_vector != NULL) {
BX_INFO (("freeing existing memory vector")); BX_INFO (("freeing existing memory vector"));
@ -637,7 +637,7 @@ BX_MEM_C::registerMemoryHandlers(void *param, memory_handler_t read_handler,
return 0; return 0;
if (!read_handler || !write_handler) if (!read_handler || !write_handler)
return 0; return 0;
BX_INFO(("Register memory access handlers: %08x-%08x", begin_addr, end_addr)); BX_INFO(("Register memory access handlers: 0x" FMT_PHY_ADDRX " - 0x" FMT_PHY_ADDRX, begin_addr, end_addr));
for (unsigned page_idx = begin_addr >> 20; page_idx <= end_addr >> 20; page_idx++) { for (unsigned page_idx = begin_addr >> 20; page_idx <= end_addr >> 20; page_idx++) {
struct memory_handler_struct *memory_handler = new struct memory_handler_struct; struct memory_handler_struct *memory_handler = new struct memory_handler_struct;
memory_handler->next = BX_MEM_THIS memory_handlers[page_idx]; memory_handler->next = BX_MEM_THIS memory_handlers[page_idx];
@ -656,7 +656,7 @@ BX_MEM_C::unregisterMemoryHandlers(memory_handler_t read_handler, memory_handler
bx_phy_address begin_addr, bx_phy_address end_addr) bx_phy_address begin_addr, bx_phy_address end_addr)
{ {
bx_bool ret = 1; bx_bool ret = 1;
BX_INFO(("Memory access handlers unregistered: %08x-%08x", begin_addr, end_addr)); BX_INFO(("Memory access handlers unregistered: 0x" FMT_PHY_ADDRX " - 0x" FMT_PHY_ADDRX, begin_addr, end_addr));
for (unsigned page_idx = begin_addr >> 20; page_idx <= end_addr >> 20; page_idx++) { for (unsigned page_idx = begin_addr >> 20; page_idx <= end_addr >> 20; page_idx++) {
struct memory_handler_struct *memory_handler = BX_MEM_THIS memory_handlers[page_idx]; struct memory_handler_struct *memory_handler = BX_MEM_THIS memory_handlers[page_idx];
struct memory_handler_struct *prev = NULL; struct memory_handler_struct *prev = NULL;