Fixing V2008 warnings - they found a bug in sse_pfp.cc !
This commit is contained in:
parent
948d85c24b
commit
838fb2a048
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: config.cc,v 1.125 2007-12-06 22:21:40 sshwarts Exp $
|
// $Id: config.cc,v 1.126 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2002 MandrakeSoft S.A.
|
// Copyright (C) 2002 MandrakeSoft S.A.
|
||||||
@ -1736,7 +1736,7 @@ static int parse_bochsrc(const char *rcfile)
|
|||||||
do {
|
do {
|
||||||
ret = fgets(line, sizeof(line)-1, fd);
|
ret = fgets(line, sizeof(line)-1, fd);
|
||||||
line[sizeof(line) - 1] = '\0';
|
line[sizeof(line) - 1] = '\0';
|
||||||
int len = strlen(line);
|
size_t len = strlen(line);
|
||||||
if ((len>0) && (line[len-1] < ' '))
|
if ((len>0) && (line[len-1] < ' '))
|
||||||
line[len-1] = '\0';
|
line[len-1] = '\0';
|
||||||
if ((ret != NULL) && strlen(line)) {
|
if ((ret != NULL) && strlen(line)) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: arith16.cc,v 1.60 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: arith16.cc,v 1.61 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -538,7 +538,7 @@ void BX_CPU_C::NEG_EwM(bxInstruction_c *i)
|
|||||||
Bit16u op1_16;
|
Bit16u op1_16;
|
||||||
|
|
||||||
op1_16 = read_RMW_virtual_word(i->seg(), RMAddr(i));
|
op1_16 = read_RMW_virtual_word(i->seg(), RMAddr(i));
|
||||||
op1_16 = -op1_16;
|
op1_16 = (Bit16u) -op1_16;
|
||||||
write_RMW_virtual_word(op1_16);
|
write_RMW_virtual_word(op1_16);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_16(op1_16, BX_INSTR_NEG16);
|
SET_FLAGS_OSZAPC_RESULT_16(op1_16, BX_INSTR_NEG16);
|
||||||
@ -547,7 +547,7 @@ void BX_CPU_C::NEG_EwM(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::NEG_EwR(bxInstruction_c *i)
|
void BX_CPU_C::NEG_EwR(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
Bit16u op1_16 = BX_READ_16BIT_REG(i->rm());
|
Bit16u op1_16 = BX_READ_16BIT_REG(i->rm());
|
||||||
op1_16 = -op1_16;
|
op1_16 = (Bit16u) -op1_16;
|
||||||
BX_WRITE_16BIT_REG(i->rm(), op1_16);
|
BX_WRITE_16BIT_REG(i->rm(), op1_16);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_16(op1_16, BX_INSTR_NEG16);
|
SET_FLAGS_OSZAPC_RESULT_16(op1_16, BX_INSTR_NEG16);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: arith32.cc,v 1.69 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: arith32.cc,v 1.70 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -592,7 +592,7 @@ void BX_CPU_C::NEG_EdM(bxInstruction_c *i)
|
|||||||
Bit32u op1_32;
|
Bit32u op1_32;
|
||||||
|
|
||||||
op1_32 = read_RMW_virtual_dword(i->seg(), RMAddr(i));
|
op1_32 = read_RMW_virtual_dword(i->seg(), RMAddr(i));
|
||||||
op1_32 = -op1_32;
|
op1_32 = (Bit32u) -op1_32;
|
||||||
write_RMW_virtual_dword(op1_32);
|
write_RMW_virtual_dword(op1_32);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_32(op1_32, BX_INSTR_NEG32);
|
SET_FLAGS_OSZAPC_RESULT_32(op1_32, BX_INSTR_NEG32);
|
||||||
@ -601,7 +601,7 @@ void BX_CPU_C::NEG_EdM(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::NEG_EdR(bxInstruction_c *i)
|
void BX_CPU_C::NEG_EdR(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
Bit32u op1_32 = BX_READ_32BIT_REG(i->rm());
|
Bit32u op1_32 = BX_READ_32BIT_REG(i->rm());
|
||||||
op1_32 = -op1_32;
|
op1_32 = (Bit32u) -op1_32;
|
||||||
BX_WRITE_32BIT_REGZ(i->rm(), op1_32);
|
BX_WRITE_32BIT_REGZ(i->rm(), op1_32);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_32(op1_32, BX_INSTR_NEG32);
|
SET_FLAGS_OSZAPC_RESULT_32(op1_32, BX_INSTR_NEG32);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: arith64.cc,v 1.45 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: arith64.cc,v 1.46 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -571,7 +571,7 @@ void BX_CPU_C::NEG_EqM(bxInstruction_c *i)
|
|||||||
|
|
||||||
/* pointer, segment address pair */
|
/* pointer, segment address pair */
|
||||||
op1_64 = read_RMW_virtual_qword(i->seg(), RMAddr(i));
|
op1_64 = read_RMW_virtual_qword(i->seg(), RMAddr(i));
|
||||||
op1_64 = -op1_64;
|
op1_64 = (Bit64u) -op1_64;
|
||||||
write_RMW_virtual_qword(op1_64);
|
write_RMW_virtual_qword(op1_64);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_64(op1_64, BX_INSTR_NEG64);
|
SET_FLAGS_OSZAPC_RESULT_64(op1_64, BX_INSTR_NEG64);
|
||||||
@ -580,7 +580,7 @@ void BX_CPU_C::NEG_EqM(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::NEG_EqR(bxInstruction_c *i)
|
void BX_CPU_C::NEG_EqR(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
Bit64u op1_64 = BX_READ_64BIT_REG(i->rm());
|
Bit64u op1_64 = BX_READ_64BIT_REG(i->rm());
|
||||||
op1_64 = -op1_64;
|
op1_64 = (Bit64u) -op1_64;
|
||||||
BX_WRITE_64BIT_REG(i->rm(), op1_64);
|
BX_WRITE_64BIT_REG(i->rm(), op1_64);
|
||||||
|
|
||||||
SET_FLAGS_OSZAPC_RESULT_64(op1_64, BX_INSTR_NEG64);
|
SET_FLAGS_OSZAPC_RESULT_64(op1_64, BX_INSTR_NEG64);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: bit16.cc,v 1.2 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: bit16.cc,v 1.3 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -126,8 +126,9 @@ void BX_CPU_C::BT_EwGwR(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::BTS_EwGwM(bxInstruction_c *i)
|
void BX_CPU_C::BTS_EwGwM(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
bx_address op1_addr;
|
bx_address op1_addr;
|
||||||
Bit16u op1_16, op2_16, bit_i, index;
|
Bit16u op1_16, op2_16, index;
|
||||||
Bit32s displacement32;
|
Bit32s displacement32;
|
||||||
|
bx_bool bit_i;
|
||||||
|
|
||||||
op2_16 = BX_READ_16BIT_REG(i->nnn());
|
op2_16 = BX_READ_16BIT_REG(i->nnn());
|
||||||
index = op2_16 & 0x0f;
|
index = op2_16 & 0x0f;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: bit32.cc,v 1.2 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: bit32.cc,v 1.3 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -130,8 +130,9 @@ void BX_CPU_C::BT_EdGdR(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::BTS_EdGdM(bxInstruction_c *i)
|
void BX_CPU_C::BTS_EdGdM(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
bx_address op1_addr;
|
bx_address op1_addr;
|
||||||
Bit32u op1_32, op2_32, bit_i, index;
|
Bit32u op1_32, op2_32, index;
|
||||||
Bit32s displacement32;
|
Bit32s displacement32;
|
||||||
|
bx_bool bit_i;
|
||||||
|
|
||||||
op2_32 = BX_READ_32BIT_REG(i->nnn());
|
op2_32 = BX_READ_32BIT_REG(i->nnn());
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: bit64.cc,v 1.2 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: bit64.cc,v 1.3 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -130,7 +130,7 @@ void BX_CPU_C::BTS_EqGqM(bxInstruction_c *i)
|
|||||||
bx_address op1_addr;
|
bx_address op1_addr;
|
||||||
Bit64u op1_64, op2_64, index;
|
Bit64u op1_64, op2_64, index;
|
||||||
Bit64s displacement64;
|
Bit64s displacement64;
|
||||||
Bit64u bit_i;
|
bx_bool bit_i;
|
||||||
|
|
||||||
op2_64 = BX_READ_64BIT_REG(i->nnn());
|
op2_64 = BX_READ_64BIT_REG(i->nnn());
|
||||||
index = op2_64 & 0x3f;
|
index = op2_64 & 0x3f;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: cpu.cc,v 1.193 2007-12-22 17:17:40 sshwarts Exp $
|
// $Id: cpu.cc,v 1.194 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -102,7 +102,7 @@ static Bit32u iCacheTraceLengh[BX_MAX_TRACE_LENGTH];
|
|||||||
|
|
||||||
bxICacheEntry_c* BX_CPU_C::fetchInstructionTrace(bxInstruction_c *iStorage, bx_address eipBiased)
|
bxICacheEntry_c* BX_CPU_C::fetchInstructionTrace(bxInstruction_c *iStorage, bx_address eipBiased)
|
||||||
{
|
{
|
||||||
bx_phy_address pAddr = BX_CPU_THIS_PTR pAddrA20Page + eipBiased;
|
bx_phy_address pAddr = (bx_phy_address)(BX_CPU_THIS_PTR pAddrA20Page + eipBiased);
|
||||||
unsigned iCacheHash = BX_CPU_THIS_PTR iCache.hash(pAddr);
|
unsigned iCacheHash = BX_CPU_THIS_PTR iCache.hash(pAddr);
|
||||||
bxICacheEntry_c *trace = &(BX_CPU_THIS_PTR iCache.entry[iCacheHash]);
|
bxICacheEntry_c *trace = &(BX_CPU_THIS_PTR iCache.entry[iCacheHash]);
|
||||||
Bit32u pageWriteStamp = *(BX_CPU_THIS_PTR currPageWriteStampPtr);
|
Bit32u pageWriteStamp = *(BX_CPU_THIS_PTR currPageWriteStampPtr);
|
||||||
@ -839,7 +839,7 @@ void BX_CPU_C::prefetch(void)
|
|||||||
|
|
||||||
// Calculate RIP at the beginning of the page.
|
// Calculate RIP at the beginning of the page.
|
||||||
bx_address eipPageOffset0 = RIP - (laddr & 0xfff);
|
bx_address eipPageOffset0 = RIP - (laddr & 0xfff);
|
||||||
BX_CPU_THIS_PTR eipPageBias = -eipPageOffset0;
|
BX_CPU_THIS_PTR eipPageBias = (bx_address) -eipPageOffset0;
|
||||||
BX_CPU_THIS_PTR eipPageWindowSize = 4096;
|
BX_CPU_THIS_PTR eipPageWindowSize = 4096;
|
||||||
|
|
||||||
if (! Is64BitMode()) {
|
if (! Is64BitMode()) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: iret.cc,v 1.24 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: iret.cc,v 1.25 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2005 Stanislav Shwartsman
|
// Copyright (c) 2005 Stanislav Shwartsman
|
||||||
@ -60,7 +60,7 @@ BX_CPU_C::iret_protected(bxInstruction_c *i)
|
|||||||
|
|
||||||
if (BX_CPU_THIS_PTR tr.cache.valid==0)
|
if (BX_CPU_THIS_PTR tr.cache.valid==0)
|
||||||
BX_PANIC(("IRET: TR not valid"));
|
BX_PANIC(("IRET: TR not valid"));
|
||||||
Bit32u base32 = BX_CPU_THIS_PTR tr.cache.u.system.base;
|
Bit32u base32 = (Bit32u) BX_CPU_THIS_PTR tr.cache.u.system.base;
|
||||||
|
|
||||||
// examine back link selector in TSS addressed by current TR:
|
// examine back link selector in TSS addressed by current TR:
|
||||||
access_linear(base32, 2, 0, BX_READ, &raw_link_selector);
|
access_linear(base32, 2, 0, BX_READ, &raw_link_selector);
|
||||||
@ -377,13 +377,10 @@ BX_CPU_C::long_iret(bxInstruction_c *i)
|
|||||||
unsigned top_nbytes_same = 0; /* stop compiler warnings */
|
unsigned top_nbytes_same = 0; /* stop compiler warnings */
|
||||||
|
|
||||||
if (i->os64L()) {
|
if (i->os64L()) {
|
||||||
Bit64u new_rflags = 0;
|
|
||||||
|
|
||||||
raw_cs_selector = read_virtual_word (BX_SEG_REG_SS, temp_RSP + 8);
|
raw_cs_selector = read_virtual_word (BX_SEG_REG_SS, temp_RSP + 8);
|
||||||
new_rip = read_virtual_qword(BX_SEG_REG_SS, temp_RSP + 0);
|
new_rip = read_virtual_qword(BX_SEG_REG_SS, temp_RSP + 0);
|
||||||
new_rflags = read_virtual_qword(BX_SEG_REG_SS, temp_RSP + 16);
|
new_eflags = (Bit32u) read_virtual_qword(BX_SEG_REG_SS, temp_RSP + 16);
|
||||||
|
|
||||||
new_eflags = (Bit32u) new_rflags;
|
|
||||||
top_nbytes_outer = 40;
|
top_nbytes_outer = 40;
|
||||||
ss_offset = 32;
|
ss_offset = 32;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: mmx.cc,v 1.68 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: mmx.cc,v 1.69 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2002 Stanislav Shwartsman
|
// Copyright (c) 2002 Stanislav Shwartsman
|
||||||
@ -40,7 +40,7 @@ Bit8s BX_CPP_AttrRegparmN(1) SaturateWordSToByteS(Bit16s value)
|
|||||||
*/
|
*/
|
||||||
if(value < -128) return -128;
|
if(value < -128) return -128;
|
||||||
if(value > 127) return 127;
|
if(value > 127) return 127;
|
||||||
return value;
|
return (Bit8s) value;
|
||||||
}
|
}
|
||||||
|
|
||||||
Bit16s BX_CPP_AttrRegparmN(1) SaturateDwordSToWordS(Bit32s value)
|
Bit16s BX_CPP_AttrRegparmN(1) SaturateDwordSToWordS(Bit32s value)
|
||||||
@ -54,7 +54,7 @@ Bit16s BX_CPP_AttrRegparmN(1) SaturateDwordSToWordS(Bit32s value)
|
|||||||
*/
|
*/
|
||||||
if(value < -32768) return -32768;
|
if(value < -32768) return -32768;
|
||||||
if(value > 32767) return 32767;
|
if(value > 32767) return 32767;
|
||||||
return value;
|
return (Bit16s) value;
|
||||||
}
|
}
|
||||||
|
|
||||||
Bit8u BX_CPP_AttrRegparmN(1) SaturateWordSToByteU(Bit16s value)
|
Bit8u BX_CPP_AttrRegparmN(1) SaturateWordSToByteU(Bit16s value)
|
||||||
@ -67,7 +67,7 @@ Bit8u BX_CPP_AttrRegparmN(1) SaturateWordSToByteU(Bit16s value)
|
|||||||
*/
|
*/
|
||||||
if(value < 0) return 0;
|
if(value < 0) return 0;
|
||||||
if(value > 255) return 255;
|
if(value > 255) return 255;
|
||||||
return value;
|
return (Bit8u) value;
|
||||||
}
|
}
|
||||||
|
|
||||||
Bit16u BX_CPP_AttrRegparmN(1) SaturateDwordSToWordU(Bit32s value)
|
Bit16u BX_CPP_AttrRegparmN(1) SaturateDwordSToWordU(Bit32s value)
|
||||||
@ -81,7 +81,7 @@ Bit16u BX_CPP_AttrRegparmN(1) SaturateDwordSToWordU(Bit32s value)
|
|||||||
*/
|
*/
|
||||||
if(value < 0) return 0;
|
if(value < 0) return 0;
|
||||||
if(value > 65535) return 65535;
|
if(value > 65535) return 65535;
|
||||||
return value;
|
return (Bit16u) value;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BX_CPU_C::print_state_MMX(void)
|
void BX_CPU_C::print_state_MMX(void)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: mult64.cc,v 1.22 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: mult64.cc,v 1.23 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -74,7 +74,7 @@ void long_mul(Bit128u *product, Bit64u op1, Bit64u op2)
|
|||||||
void long_neg(Bit128s *n)
|
void long_neg(Bit128s *n)
|
||||||
{
|
{
|
||||||
Bit64u t = n->lo;
|
Bit64u t = n->lo;
|
||||||
n->lo = -n->lo;
|
n->lo = (Bit64u) -n->lo;
|
||||||
if (t - 1 > t) --n->hi;
|
if (t - 1 > t) --n->hi;
|
||||||
n->hi = ~n->hi;
|
n->hi = ~n->hi;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: paging.cc,v 1.101 2007-12-21 10:33:39 sshwarts Exp $
|
// $Id: paging.cc,v 1.102 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -671,8 +671,8 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
if (long_mode())
|
if (long_mode())
|
||||||
{
|
{
|
||||||
// Get PML4 entry
|
// Get PML4 entry
|
||||||
bx_phy_address pml4_addr = BX_CPU_THIS_PTR cr3_masked |
|
bx_phy_address pml4_addr = (bx_phy_address)(BX_CPU_THIS_PTR cr3_masked |
|
||||||
((laddr & BX_CONST64(0x0000ff8000000000)) >> 36);
|
((laddr & BX_CONST64(0x0000ff8000000000)) >> 36));
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pml4_addr, 8, &pml4);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pml4_addr, 8, &pml4);
|
||||||
|
|
||||||
if (!(pml4 & 0x01)) {
|
if (!(pml4 & 0x01)) {
|
||||||
@ -702,13 +702,13 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, pml4_addr, 8, &pml4);
|
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, pml4_addr, 8, &pml4);
|
||||||
}
|
}
|
||||||
|
|
||||||
pdpe_addr = (pml4 & BX_CONST64(0x000ffffffffff000)) |
|
pdpe_addr = (bx_phy_address)((pml4 & BX_CONST64(0x000ffffffffff000)) |
|
||||||
((laddr & BX_CONST64(0x0000007fc0000000)) >> 27);
|
((laddr & BX_CONST64(0x0000007fc0000000)) >> 27));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
pdpe_addr = BX_CPU_THIS_PTR cr3_masked | ((laddr & 0xc0000000) >> 27);
|
pdpe_addr = (bx_phy_address) (BX_CPU_THIS_PTR cr3_masked | ((laddr & 0xc0000000) >> 27));
|
||||||
}
|
}
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pdpe_addr, 8, &pdpe);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pdpe_addr, 8, &pdpe);
|
||||||
@ -737,8 +737,8 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
BX_PANIC(("PAE PDPE: Only 32 bit physical address space is emulated !"));
|
BX_PANIC(("PAE PDPE: Only 32 bit physical address space is emulated !"));
|
||||||
}
|
}
|
||||||
|
|
||||||
bx_phy_address pde_addr = (pdpe & BX_CONST64(0x000ffffffffff000))
|
bx_phy_address pde_addr = (bx_phy_address)((pdpe & BX_CONST64(0x000ffffffffff000))
|
||||||
| ((laddr & 0x3fe00000) >> 18);
|
| ((laddr & 0x3fe00000) >> 18));
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pde_addr, 8, &pde);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pde_addr, 8, &pde);
|
||||||
|
|
||||||
@ -773,7 +773,7 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Make up the physical page frame address.
|
// Make up the physical page frame address.
|
||||||
ppf = (pde & BX_CONST64(0x000fffffffe00000)) | (laddr & 0x001ff000);
|
ppf = (bx_phy_address)((pde & BX_CONST64(0x000fffffffe00000)) | (laddr & 0x001ff000));
|
||||||
|
|
||||||
#if BX_SUPPORT_GLOBAL_PAGES
|
#if BX_SUPPORT_GLOBAL_PAGES
|
||||||
if (BX_CPU_THIS_PTR cr4.get_PGE())
|
if (BX_CPU_THIS_PTR cr4.get_PGE())
|
||||||
@ -805,8 +805,8 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// 4k pages, Get page table entry
|
// 4k pages, Get page table entry
|
||||||
bx_phy_address pte_addr = (pde & BX_CONST64(0x000ffffffffff000)) |
|
bx_phy_address pte_addr = (bx_phy_address)((pde & BX_CONST64(0x000ffffffffff000)) |
|
||||||
((laddr & 0x001ff000) >> 9);
|
((laddr & 0x001ff000) >> 9));
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pte_addr, 8, &pte);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pte_addr, 8, &pte);
|
||||||
|
|
||||||
@ -838,7 +838,7 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Make up the physical page frame address.
|
// Make up the physical page frame address.
|
||||||
ppf = pte & BX_CONST64(0x000ffffffffff000);
|
ppf = (bx_phy_address)(pte & BX_CONST64(0x000ffffffffff000));
|
||||||
|
|
||||||
#if BX_SUPPORT_GLOBAL_PAGES
|
#if BX_SUPPORT_GLOBAL_PAGES
|
||||||
if (BX_CPU_THIS_PTR cr4.get_PGE())
|
if (BX_CPU_THIS_PTR cr4.get_PGE())
|
||||||
@ -881,7 +881,8 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
// CR4.PAE==0 (and EFER.LMA==0)
|
// CR4.PAE==0 (and EFER.LMA==0)
|
||||||
Bit32u pde, pte;
|
Bit32u pde, pte;
|
||||||
|
|
||||||
bx_phy_address pde_addr = BX_CPU_THIS_PTR cr3_masked | ((laddr & 0xffc00000) >> 20);
|
bx_phy_address pde_addr = (bx_phy_address) (BX_CPU_THIS_PTR cr3_masked |
|
||||||
|
((laddr & 0xffc00000) >> 20));
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pde_addr, 4, &pde);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pde_addr, 4, &pde);
|
||||||
|
|
||||||
@ -927,7 +928,7 @@ bx_phy_address BX_CPU_C::translate_linear(bx_address laddr, unsigned curr_pl, un
|
|||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
// Get page table entry
|
// Get page table entry
|
||||||
bx_phy_address pte_addr = (pde & 0xfffff000) | ((laddr & 0x003ff000) >> 10);
|
bx_phy_address pte_addr = (bx_phy_address)((pde & 0xfffff000) | ((laddr & 0x003ff000) >> 10));
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pte_addr, 4, &pte);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, pte_addr, 4, &pte);
|
||||||
|
|
||||||
@ -1045,7 +1046,7 @@ bx_bool BX_CPU_C::dbg_xlate_linear2phy(bx_address laddr, bx_phy_address *phy)
|
|||||||
}
|
}
|
||||||
|
|
||||||
bx_address lpf = LPFOf(laddr); // linear page frame
|
bx_address lpf = LPFOf(laddr); // linear page frame
|
||||||
bx_address poffset = laddr & 0x00000fff; // physical offset
|
bx_phy_address poffset = (bx_phy_address)(laddr & 0x00000fff); // physical offset
|
||||||
bx_phy_address paddress;
|
bx_phy_address paddress;
|
||||||
|
|
||||||
// see if page is in the TLB first
|
// see if page is in the TLB first
|
||||||
@ -1082,7 +1083,7 @@ bx_bool BX_CPU_C::dbg_xlate_linear2phy(bx_address laddr, bx_phy_address *phy)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
paddress = pt_address + (laddr & offset_mask);
|
paddress = pt_address + (bx_phy_address)(laddr & offset_mask);
|
||||||
}
|
}
|
||||||
else // not PAE
|
else // not PAE
|
||||||
#endif
|
#endif
|
||||||
@ -1099,7 +1100,7 @@ bx_bool BX_CPU_C::dbg_xlate_linear2phy(bx_address laddr, bx_phy_address *phy)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
paddress = pt_address + (laddr & offset_mask);
|
paddress = pt_address + (bx_phy_address)(laddr & offset_mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
*phy = paddress;
|
*phy = paddress;
|
||||||
@ -1217,7 +1218,7 @@ void BX_CPU_C::access_linear(bx_address laddr, unsigned len, unsigned curr_pl, u
|
|||||||
// Paging off.
|
// Paging off.
|
||||||
if ( (pageOffset + len) <= 4096 ) {
|
if ( (pageOffset + len) <= 4096 ) {
|
||||||
// Access within single page.
|
// Access within single page.
|
||||||
BX_CPU_THIS_PTR address_xlation.paddress1 = laddr;
|
BX_CPU_THIS_PTR address_xlation.paddress1 = (bx_phy_address) laddr;
|
||||||
BX_CPU_THIS_PTR address_xlation.pages = 1;
|
BX_CPU_THIS_PTR address_xlation.pages = 1;
|
||||||
if (rw == BX_READ) {
|
if (rw == BX_READ) {
|
||||||
BX_INSTR_LIN_ACCESS(BX_CPU_ID, laddr, laddr, len, xlate_rw);
|
BX_INSTR_LIN_ACCESS(BX_CPU_ID, laddr, laddr, len, xlate_rw);
|
||||||
@ -1227,13 +1228,13 @@ void BX_CPU_C::access_linear(bx_address laddr, unsigned len, unsigned curr_pl, u
|
|||||||
bx_address lpf = LPFOf(laddr);
|
bx_address lpf = LPFOf(laddr);
|
||||||
|
|
||||||
if (tlbEntry->lpf == lpf) {
|
if (tlbEntry->lpf == lpf) {
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, laddr, len, data);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, (bx_phy_address) laddr, len, data);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// We haven't seen this page, or it's been bumped before.
|
// We haven't seen this page, or it's been bumped before.
|
||||||
|
|
||||||
tlbEntry->lpf = lpf;
|
tlbEntry->lpf = lpf;
|
||||||
tlbEntry->ppf = lpf;
|
tlbEntry->ppf = (bx_phy_address) lpf;
|
||||||
// Request a direct write pointer so we can do either R or W.
|
// Request a direct write pointer so we can do either R or W.
|
||||||
tlbEntry->hostPageAddr = (bx_hostpageaddr_t)
|
tlbEntry->hostPageAddr = (bx_hostpageaddr_t)
|
||||||
BX_CPU_THIS_PTR mem->getHostMemAddr(BX_CPU_THIS, A20ADDR(lpf), BX_WRITE, DATA_ACCESS);
|
BX_CPU_THIS_PTR mem->getHostMemAddr(BX_CPU_THIS, A20ADDR(lpf), BX_WRITE, DATA_ACCESS);
|
||||||
@ -1258,7 +1259,7 @@ void BX_CPU_C::access_linear(bx_address laddr, unsigned len, unsigned curr_pl, u
|
|||||||
#endif // BX_SupportGuest2HostTLB
|
#endif // BX_SupportGuest2HostTLB
|
||||||
|
|
||||||
// Let access fall through to the following for this iteration.
|
// Let access fall through to the following for this iteration.
|
||||||
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, laddr, len, data);
|
BX_CPU_THIS_PTR mem->readPhysicalPage(BX_CPU_THIS, (bx_phy_address) laddr, len, data);
|
||||||
}
|
}
|
||||||
else { // Write
|
else { // Write
|
||||||
BX_INSTR_LIN_ACCESS(BX_CPU_ID, laddr, laddr, len, xlate_rw);
|
BX_INSTR_LIN_ACCESS(BX_CPU_ID, laddr, laddr, len, xlate_rw);
|
||||||
@ -1268,12 +1269,13 @@ void BX_CPU_C::access_linear(bx_address laddr, unsigned len, unsigned curr_pl, u
|
|||||||
bx_address lpf = LPFOf(laddr);
|
bx_address lpf = LPFOf(laddr);
|
||||||
|
|
||||||
if (tlbEntry->lpf == lpf) {
|
if (tlbEntry->lpf == lpf) {
|
||||||
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, laddr, len, data);
|
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, (bx_phy_address) laddr, len, data);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// We haven't seen this page, or it's been bumped before.
|
// We haven't seen this page, or it's been bumped before.
|
||||||
|
|
||||||
tlbEntry->lpf = tlbEntry->ppf = lpf;
|
tlbEntry->lpf = lpf;
|
||||||
|
tlbEntry->ppf = (bx_phy_address) lpf;
|
||||||
// TLB.entry[tlbIndex].ppf field not used for PG==0.
|
// TLB.entry[tlbIndex].ppf field not used for PG==0.
|
||||||
// Request a direct write pointer so we can do either R or W.
|
// Request a direct write pointer so we can do either R or W.
|
||||||
tlbEntry->hostPageAddr = (bx_hostpageaddr_t)
|
tlbEntry->hostPageAddr = (bx_hostpageaddr_t)
|
||||||
@ -1288,18 +1290,18 @@ void BX_CPU_C::access_linear(bx_address laddr, unsigned len, unsigned curr_pl, u
|
|||||||
tlbEntry->accessBits = 0;
|
tlbEntry->accessBits = 0;
|
||||||
#endif // BX_SupportGuest2HostTLB
|
#endif // BX_SupportGuest2HostTLB
|
||||||
|
|
||||||
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, laddr, len, data);
|
BX_CPU_THIS_PTR mem->writePhysicalPage(BX_CPU_THIS, (bx_phy_address) laddr, len, data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Access spans two pages.
|
// Access spans two pages.
|
||||||
BX_CPU_THIS_PTR address_xlation.paddress1 = laddr;
|
BX_CPU_THIS_PTR address_xlation.paddress1 = (bx_phy_address) laddr;
|
||||||
BX_CPU_THIS_PTR address_xlation.len1 = 4096 - pageOffset;
|
BX_CPU_THIS_PTR address_xlation.len1 = 4096 - pageOffset;
|
||||||
BX_CPU_THIS_PTR address_xlation.len2 = len -
|
BX_CPU_THIS_PTR address_xlation.len2 = len -
|
||||||
BX_CPU_THIS_PTR address_xlation.len1;
|
BX_CPU_THIS_PTR address_xlation.len1;
|
||||||
BX_CPU_THIS_PTR address_xlation.pages = 2;
|
BX_CPU_THIS_PTR address_xlation.pages = 2;
|
||||||
BX_CPU_THIS_PTR address_xlation.paddress2 = laddr +
|
BX_CPU_THIS_PTR address_xlation.paddress2 = (bx_phy_address) (laddr +
|
||||||
BX_CPU_THIS_PTR address_xlation.len1;
|
BX_CPU_THIS_PTR address_xlation.len1);
|
||||||
|
|
||||||
#ifdef BX_LITTLE_ENDIAN
|
#ifdef BX_LITTLE_ENDIAN
|
||||||
if (rw == BX_READ) {
|
if (rw == BX_READ) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: proc_ctrl.cc,v 1.192 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: proc_ctrl.cc,v 1.193 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -335,16 +335,16 @@ void BX_CPU_C::MOV_RdDd(bxInstruction_c *i)
|
|||||||
|
|
||||||
switch (i->nnn()) {
|
switch (i->nnn()) {
|
||||||
case 0: // DR0
|
case 0: // DR0
|
||||||
val_32 = BX_CPU_THIS_PTR dr0;
|
val_32 = (Bit32u) BX_CPU_THIS_PTR dr0;
|
||||||
break;
|
break;
|
||||||
case 1: // DR1
|
case 1: // DR1
|
||||||
val_32 = BX_CPU_THIS_PTR dr1;
|
val_32 = (Bit32u) BX_CPU_THIS_PTR dr1;
|
||||||
break;
|
break;
|
||||||
case 2: // DR2
|
case 2: // DR2
|
||||||
val_32 = BX_CPU_THIS_PTR dr2;
|
val_32 = (Bit32u) BX_CPU_THIS_PTR dr2;
|
||||||
break;
|
break;
|
||||||
case 3: // DR3
|
case 3: // DR3
|
||||||
val_32 = BX_CPU_THIS_PTR dr3;
|
val_32 = (Bit32u) BX_CPU_THIS_PTR dr3;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4: // DR4
|
case 4: // DR4
|
||||||
@ -594,9 +594,6 @@ void BX_CPU_C::MOV_CdRd(bxInstruction_c *i)
|
|||||||
case 0: // CR0 (MSW)
|
case 0: // CR0 (MSW)
|
||||||
SetCR0(val_32);
|
SetCR0(val_32);
|
||||||
break;
|
break;
|
||||||
case 1: /* CR1 */
|
|
||||||
BX_PANIC(("MOV_CdRd:CR1 not implemented yet"));
|
|
||||||
break;
|
|
||||||
case 2: /* CR2 */
|
case 2: /* CR2 */
|
||||||
BX_DEBUG(("MOV_CdRd:CR2 = %08x", (unsigned) val_32));
|
BX_DEBUG(("MOV_CdRd:CR2 = %08x", (unsigned) val_32));
|
||||||
BX_CPU_THIS_PTR cr2 = val_32;
|
BX_CPU_THIS_PTR cr2 = val_32;
|
||||||
@ -650,13 +647,9 @@ void BX_CPU_C::MOV_RdCd(bxInstruction_c *i)
|
|||||||
case 0: // CR0 (MSW)
|
case 0: // CR0 (MSW)
|
||||||
val_32 = BX_CPU_THIS_PTR cr0.val32;
|
val_32 = BX_CPU_THIS_PTR cr0.val32;
|
||||||
break;
|
break;
|
||||||
case 1: /* CR1 */
|
|
||||||
BX_PANIC(("MOV_RdCd: CR1 not implemented yet"));
|
|
||||||
val_32 = 0;
|
|
||||||
break;
|
|
||||||
case 2: /* CR2 */
|
case 2: /* CR2 */
|
||||||
BX_DEBUG(("MOV_RdCd: reading CR2"));
|
BX_DEBUG(("MOV_RdCd: reading CR2"));
|
||||||
val_32 = BX_CPU_THIS_PTR cr2;
|
val_32 = (Bit32u) BX_CPU_THIS_PTR cr2;
|
||||||
break;
|
break;
|
||||||
case 3: // CR3
|
case 3: // CR3
|
||||||
BX_DEBUG(("MOV_RdCd: reading CR3"));
|
BX_DEBUG(("MOV_RdCd: reading CR3"));
|
||||||
@ -709,10 +702,7 @@ void BX_CPU_C::MOV_CqRq(bxInstruction_c *i)
|
|||||||
|
|
||||||
switch (i->nnn()) {
|
switch (i->nnn()) {
|
||||||
case 0: // CR0 (MSW)
|
case 0: // CR0 (MSW)
|
||||||
SetCR0(val_64);
|
SetCR0((Bit32u) val_64);
|
||||||
break;
|
|
||||||
case 1: /* CR1 */
|
|
||||||
BX_PANIC(("MOV_CqRq: CR1 not implemented yet"));
|
|
||||||
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",
|
||||||
@ -726,7 +716,7 @@ void BX_CPU_C::MOV_CqRq(bxInstruction_c *i)
|
|||||||
BX_PANIC(("CR3 write: Only 32 bit physical address space is emulated !"));
|
BX_PANIC(("CR3 write: Only 32 bit physical address space is emulated !"));
|
||||||
}
|
}
|
||||||
// Reserved bits take on value of MOV instruction
|
// Reserved bits take on value of MOV instruction
|
||||||
CR3_change(val_64);
|
CR3_change((bx_phy_address) val_64);
|
||||||
BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_MOV_CR3, val_64);
|
BX_INSTR_TLB_CNTRL(BX_CPU_ID, BX_INSTR_MOV_CR3, val_64);
|
||||||
break;
|
break;
|
||||||
case 4: // CR4
|
case 4: // CR4
|
||||||
@ -734,7 +724,7 @@ void BX_CPU_C::MOV_CqRq(bxInstruction_c *i)
|
|||||||
// 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",
|
||||||
(Bit32u)(val_64 >> 32), (Bit32u)(val_64 & 0xFFFFFFFF)));
|
(Bit32u)(val_64 >> 32), (Bit32u)(val_64 & 0xFFFFFFFF)));
|
||||||
if (! SetCR4(val_64))
|
if (! SetCR4((Bit32u) val_64))
|
||||||
exception(BX_GP_EXCEPTION, 0, 0);
|
exception(BX_GP_EXCEPTION, 0, 0);
|
||||||
break;
|
break;
|
||||||
#if BX_SUPPORT_APIC
|
#if BX_SUPPORT_APIC
|
||||||
@ -782,10 +772,6 @@ void BX_CPU_C::MOV_RqCq(bxInstruction_c *i)
|
|||||||
case 0: // CR0 (MSW)
|
case 0: // CR0 (MSW)
|
||||||
val_64 = BX_CPU_THIS_PTR cr0.val32;
|
val_64 = BX_CPU_THIS_PTR cr0.val32;
|
||||||
break;
|
break;
|
||||||
case 1: /* CR1 */
|
|
||||||
BX_PANIC(("MOV_RqCq: CR1 not implemented yet"));
|
|
||||||
val_64 = 0;
|
|
||||||
break;
|
|
||||||
case 2: /* CR2 */
|
case 2: /* CR2 */
|
||||||
BX_DEBUG(("MOV_RqCq: read of CR2"));
|
BX_DEBUG(("MOV_RqCq: read of CR2"));
|
||||||
val_64 = BX_CPU_THIS_PTR cr2;
|
val_64 = BX_CPU_THIS_PTR cr2;
|
||||||
@ -2346,7 +2332,7 @@ void BX_CPU_C::SYSRET(bxInstruction_c *i)
|
|||||||
BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache.segment = 1; /* data/code segment */
|
BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache.segment = 1; /* data/code segment */
|
||||||
BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache.type = BX_DATA_READ_WRITE_ACCESSED;
|
BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache.type = BX_DATA_READ_WRITE_ACCESSED;
|
||||||
|
|
||||||
writeEFlags(R11, EFlagsValidMask);
|
writeEFlags((Bit32u) R11, EFlagsValidMask);
|
||||||
|
|
||||||
RIP = temp_RIP;
|
RIP = temp_RIP;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: protect_ctrl.cc,v 1.69 2007-12-21 17:30:49 sshwarts Exp $
|
// $Id: protect_ctrl.cc,v 1.70 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -627,7 +627,7 @@ void BX_CPU_C::VERW_Ew(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::SGDT_Ms(bxInstruction_c *i)
|
void BX_CPU_C::SGDT_Ms(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
Bit16u limit_16 = BX_CPU_THIS_PTR gdtr.limit;
|
Bit16u limit_16 = BX_CPU_THIS_PTR gdtr.limit;
|
||||||
Bit32u base_32 = BX_CPU_THIS_PTR gdtr.base;
|
Bit32u base_32 = (Bit32u) BX_CPU_THIS_PTR gdtr.base;
|
||||||
|
|
||||||
write_virtual_word(i->seg(), RMAddr(i), limit_16);
|
write_virtual_word(i->seg(), RMAddr(i), limit_16);
|
||||||
write_virtual_dword(i->seg(), RMAddr(i)+2, base_32);
|
write_virtual_dword(i->seg(), RMAddr(i)+2, base_32);
|
||||||
@ -636,7 +636,7 @@ void BX_CPU_C::SGDT_Ms(bxInstruction_c *i)
|
|||||||
void BX_CPU_C::SIDT_Ms(bxInstruction_c *i)
|
void BX_CPU_C::SIDT_Ms(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
Bit16u limit_16 = BX_CPU_THIS_PTR idtr.limit;
|
Bit16u limit_16 = BX_CPU_THIS_PTR idtr.limit;
|
||||||
Bit32u base_32 = BX_CPU_THIS_PTR idtr.base;
|
Bit32u base_32 = (Bit32u) BX_CPU_THIS_PTR idtr.base;
|
||||||
|
|
||||||
write_virtual_word(i->seg(), RMAddr(i), limit_16);
|
write_virtual_word(i->seg(), RMAddr(i), limit_16);
|
||||||
write_virtual_dword(i->seg(), RMAddr(i)+2, base_32);
|
write_virtual_dword(i->seg(), RMAddr(i)+2, base_32);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: sse_pfp.cc,v 1.38 2007-12-20 20:58:37 sshwarts Exp $
|
// $Id: sse_pfp.cc,v 1.39 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2003 Stanislav Shwartsman
|
// Copyright (c) 2003 Stanislav Shwartsman
|
||||||
@ -676,8 +676,8 @@ void BX_CPU_C::CVTPS2PD_VpsWps(bxInstruction_c *i)
|
|||||||
r1 = handleDAZ(r1);
|
r1 = handleDAZ(r1);
|
||||||
}
|
}
|
||||||
|
|
||||||
result.xmm32u(0) = float32_to_float64(r0, status_word);
|
result.xmm64u(0) = float32_to_float64(r0, status_word);
|
||||||
result.xmm32u(1) = float32_to_float64(r1, status_word);
|
result.xmm64u(1) = float32_to_float64(r1, status_word);
|
||||||
|
|
||||||
BX_CPU_THIS_PTR check_exceptionsSSE(status_word.float_exception_flags);
|
BX_CPU_THIS_PTR check_exceptionsSSE(status_word.float_exception_flags);
|
||||||
BX_WRITE_XMM_REG(i->nnn(), result);
|
BX_WRITE_XMM_REG(i->nnn(), result);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: tasking.cc,v 1.43 2007-12-13 23:17:50 sshwarts Exp $
|
// $Id: tasking.cc,v 1.44 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -176,9 +176,9 @@ void BX_CPU_C::task_switch(bx_selector_t *tss_selector,
|
|||||||
new_TSS_max = 103;
|
new_TSS_max = 103;
|
||||||
}
|
}
|
||||||
|
|
||||||
obase32 = BX_CPU_THIS_PTR tr.cache.u.system.base; // old TSS.base
|
obase32 = (Bit32u) BX_CPU_THIS_PTR tr.cache.u.system.base; // old TSS.base
|
||||||
old_TSS_limit = BX_CPU_THIS_PTR tr.cache.u.system.limit_scaled;
|
old_TSS_limit = BX_CPU_THIS_PTR tr.cache.u.system.limit_scaled;
|
||||||
nbase32 = tss_descriptor->u.system.base; // new TSS.base
|
nbase32 = (Bit32u) tss_descriptor->u.system.base; // new TSS.base
|
||||||
new_TSS_limit = tss_descriptor->u.system.limit_scaled;
|
new_TSS_limit = tss_descriptor->u.system.limit_scaled;
|
||||||
|
|
||||||
// TSS must have valid limit, else #TS(TSS selector)
|
// TSS must have valid limit, else #TS(TSS selector)
|
||||||
@ -359,7 +359,7 @@ void BX_CPU_C::task_switch(bx_selector_t *tss_selector,
|
|||||||
if (source == BX_TASK_FROM_JUMP || source == BX_TASK_FROM_CALL_OR_INT)
|
if (source == BX_TASK_FROM_JUMP || source == BX_TASK_FROM_CALL_OR_INT)
|
||||||
{
|
{
|
||||||
// set the new task's busy bit
|
// set the new task's busy bit
|
||||||
Bit32u laddr = BX_CPU_THIS_PTR gdtr.base + (tss_selector->index<<3) + 4;
|
bx_address laddr = BX_CPU_THIS_PTR gdtr.base + (tss_selector->index<<3) + 4;
|
||||||
access_linear(laddr, 4, 0, BX_READ, &dword2);
|
access_linear(laddr, 4, 0, BX_READ, &dword2);
|
||||||
dword2 |= 0x00000200;
|
dword2 |= 0x00000200;
|
||||||
access_linear(laddr, 4, 0, BX_WRITE, &dword2);
|
access_linear(laddr, 4, 0, BX_WRITE, &dword2);
|
||||||
@ -371,7 +371,7 @@ void BX_CPU_C::task_switch(bx_selector_t *tss_selector,
|
|||||||
// effect on Busy bit of old task
|
// effect on Busy bit of old task
|
||||||
if (source == BX_TASK_FROM_JUMP || source == BX_TASK_FROM_IRET) {
|
if (source == BX_TASK_FROM_JUMP || source == BX_TASK_FROM_IRET) {
|
||||||
// Bit is cleared
|
// Bit is cleared
|
||||||
Bit32u laddr = BX_CPU_THIS_PTR gdtr.base +
|
bx_address laddr = BX_CPU_THIS_PTR gdtr.base +
|
||||||
(BX_CPU_THIS_PTR tr.selector.index<<3) + 4;
|
(BX_CPU_THIS_PTR tr.selector.index<<3) + 4;
|
||||||
access_linear(laddr, 4, 0, BX_READ, &temp32);
|
access_linear(laddr, 4, 0, BX_READ, &temp32);
|
||||||
temp32 &= ~0x00000200;
|
temp32 &= ~0x00000200;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: vm8086.cc,v 1.35 2007-12-21 21:14:48 sshwarts Exp $
|
// $Id: vm8086.cc,v 1.36 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -50,7 +50,8 @@
|
|||||||
void BX_CPU_C::stack_return_to_v86(Bit32u new_eip, Bit32u raw_cs_selector,
|
void BX_CPU_C::stack_return_to_v86(Bit32u new_eip, Bit32u raw_cs_selector,
|
||||||
Bit32u flags32)
|
Bit32u flags32)
|
||||||
{
|
{
|
||||||
Bit32u temp_ESP, new_esp, esp_laddr;
|
Bit32u temp_ESP, new_esp;
|
||||||
|
bx_address esp_laddr;
|
||||||
Bit16u raw_es_selector, raw_ds_selector, raw_fs_selector,
|
Bit16u raw_es_selector, raw_ds_selector, raw_fs_selector,
|
||||||
raw_gs_selector, raw_ss_selector;
|
raw_gs_selector, raw_ss_selector;
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: fpu.cc,v 1.29 2007-12-20 20:58:38 sshwarts Exp $
|
// $Id: fpu.cc,v 1.30 2007-12-23 17:21:27 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (c) 2003 Stanislav Shwartsman
|
// Copyright (c) 2003 Stanislav Shwartsman
|
||||||
@ -132,9 +132,9 @@ int BX_CPU_C::fpu_save_environment(bxInstruction_c *i)
|
|||||||
else /* Real or V86 Mode */
|
else /* Real or V86 Mode */
|
||||||
{
|
{
|
||||||
Bit32u fp_ip = ((Bit32u)(BX_CPU_THIS_PTR the_i387.fcs) << 4) +
|
Bit32u fp_ip = ((Bit32u)(BX_CPU_THIS_PTR the_i387.fcs) << 4) +
|
||||||
(BX_CPU_THIS_PTR the_i387.fip);
|
(Bit32u)(BX_CPU_THIS_PTR the_i387.fip);
|
||||||
Bit32u fp_dp = ((Bit32u)(BX_CPU_THIS_PTR the_i387.fds) << 4) +
|
Bit32u fp_dp = ((Bit32u)(BX_CPU_THIS_PTR the_i387.fds) << 4) +
|
||||||
(BX_CPU_THIS_PTR the_i387.fdp);
|
(Bit32u)(BX_CPU_THIS_PTR the_i387.fdp);
|
||||||
|
|
||||||
if (i->os32L() || i->os64L())
|
if (i->os32L() || i->os64L())
|
||||||
{
|
{
|
||||||
|
@ -85,7 +85,7 @@ Bit32s roundAndPackInt32(int zSign, Bit64u absZ, float_status_t &status)
|
|||||||
int roundBits = absZ & 0x7F;
|
int roundBits = absZ & 0x7F;
|
||||||
absZ = (absZ + roundIncrement)>>7;
|
absZ = (absZ + roundIncrement)>>7;
|
||||||
absZ &= ~(((roundBits ^ 0x40) == 0) & roundNearestEven);
|
absZ &= ~(((roundBits ^ 0x40) == 0) & roundNearestEven);
|
||||||
Bit32s z = absZ;
|
Bit32s z = (Bit32s) absZ;
|
||||||
if (zSign) z = -z;
|
if (zSign) z = -z;
|
||||||
if ((absZ>>32) || (z && ((z < 0) ^ zSign))) {
|
if ((absZ>>32) || (z && ((z < 0) ^ zSign))) {
|
||||||
float_raise(status, float_flag_invalid);
|
float_raise(status, float_flag_invalid);
|
||||||
|
@ -608,7 +608,7 @@ float32 float32_mul(float32 a, float32 b, float_status_t &status)
|
|||||||
aSig = (aSig | 0x00800000)<<7;
|
aSig = (aSig | 0x00800000)<<7;
|
||||||
bSig = (bSig | 0x00800000)<<8;
|
bSig = (bSig | 0x00800000)<<8;
|
||||||
shift64RightJamming(((Bit64u) aSig) * bSig, 32, &zSig64);
|
shift64RightJamming(((Bit64u) aSig) * bSig, 32, &zSig64);
|
||||||
zSig = zSig64;
|
zSig = (Bit32u) zSig64;
|
||||||
if (0 <= (Bit32s) (zSig<<1)) {
|
if (0 <= (Bit32s) (zSig<<1)) {
|
||||||
zSig <<= 1;
|
zSig <<= 1;
|
||||||
--zExp;
|
--zExp;
|
||||||
@ -1083,7 +1083,7 @@ Bit32s float64_to_int32_round_to_zero(float64 a, float_status_t &status)
|
|||||||
shiftCount = 0x433 - aExp;
|
shiftCount = 0x433 - aExp;
|
||||||
savedASig = aSig;
|
savedASig = aSig;
|
||||||
aSig >>= shiftCount;
|
aSig >>= shiftCount;
|
||||||
z = aSig;
|
z = (Bit32s) aSig;
|
||||||
if (aSign) z = -z;
|
if (aSign) z = -z;
|
||||||
if ((z < 0) ^ aSign) {
|
if ((z < 0) ^ aSign) {
|
||||||
invalid:
|
invalid:
|
||||||
@ -1201,7 +1201,7 @@ float32 float64_to_float32(float64 a, float_status_t &status)
|
|||||||
float_raise(status, float_flag_denormal);
|
float_raise(status, float_flag_denormal);
|
||||||
}
|
}
|
||||||
shift64RightJamming(aSig, 22, &aSig);
|
shift64RightJamming(aSig, 22, &aSig);
|
||||||
zSig = aSig;
|
zSig = (Bit32u) aSig;
|
||||||
if (aExp || zSig) {
|
if (aExp || zSig) {
|
||||||
zSig |= 0x40000000;
|
zSig |= 0x40000000;
|
||||||
aExp -= 0x381;
|
aExp -= 0x381;
|
||||||
@ -2107,7 +2107,7 @@ Bit32s floatx80_to_int32_round_to_zero(floatx80 a, float_status_t &status)
|
|||||||
shiftCount = 0x403E - aExp;
|
shiftCount = 0x403E - aExp;
|
||||||
savedASig = aSig;
|
savedASig = aSig;
|
||||||
aSig >>= shiftCount;
|
aSig >>= shiftCount;
|
||||||
z = aSig;
|
z = (Bit32s) aSig;
|
||||||
if (aSign) z = -z;
|
if (aSign) z = -z;
|
||||||
if ((z < 0) ^ aSign) {
|
if ((z < 0) ^ aSign) {
|
||||||
invalid:
|
invalid:
|
||||||
@ -2237,7 +2237,7 @@ float32 floatx80_to_float32(floatx80 a, float_status_t &status)
|
|||||||
}
|
}
|
||||||
shift64RightJamming(aSig, 33, &aSig);
|
shift64RightJamming(aSig, 33, &aSig);
|
||||||
if (aExp || aSig) aExp -= 0x3F81;
|
if (aExp || aSig) aExp -= 0x3F81;
|
||||||
return roundAndPackFloat32(aSign, aExp, aSig, status);
|
return roundAndPackFloat32(aSign, aExp, (Bit32u) aSig, status);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------------------
|
/*----------------------------------------------------------------------------
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: misc_mem.cc,v 1.106 2007-12-10 19:05:07 sshwarts Exp $
|
// $Id: misc_mem.cc,v 1.107 2007-12-23 17:21:28 sshwarts Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2002 MandrakeSoft S.A.
|
// Copyright (C) 2002 MandrakeSoft S.A.
|
||||||
@ -90,7 +90,7 @@ void BX_MEM_C::init_memory(Bit32u memsize)
|
|||||||
{
|
{
|
||||||
unsigned idx;
|
unsigned idx;
|
||||||
|
|
||||||
BX_DEBUG(("Init $Id: misc_mem.cc,v 1.106 2007-12-10 19:05:07 sshwarts Exp $"));
|
BX_DEBUG(("Init $Id: misc_mem.cc,v 1.107 2007-12-23 17:21:28 sshwarts Exp $"));
|
||||||
|
|
||||||
alloc_vector_aligned(memsize+ BIOSROMSZ + EXROMSIZE + 4096, BX_MEM_VECTOR_ALIGN);
|
alloc_vector_aligned(memsize+ BIOSROMSZ + EXROMSIZE + 4096, BX_MEM_VECTOR_ALIGN);
|
||||||
BX_MEM_THIS len = memsize;
|
BX_MEM_THIS len = memsize;
|
||||||
@ -243,7 +243,7 @@ void BX_MEM_C::load_ROM(const char *path, bx_phy_address romaddress, Bit8u type)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
romaddress = (bx_phy_address)-size;
|
romaddress = (bx_phy_address)(-size);
|
||||||
}
|
}
|
||||||
offset = romaddress & BIOS_MASK;
|
offset = romaddress & BIOS_MASK;
|
||||||
if ((romaddress & 0xf0000) < 0xf0000) {
|
if ((romaddress & 0xf0000) < 0xf0000) {
|
||||||
|
Loading…
Reference in New Issue
Block a user