print physcial address with special format - preparations for 64-bit physical address emu
This commit is contained in:
parent
8e7cf2bf3a
commit
6ebae41ad7
@ -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);
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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) {
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user