Changed push_32() and push_64() to issue SS(0) for a push outside of
stack limits. This is needed for EROS, and probably for L4, as both rely on this SS fault (and the corresponding GP fault) to trigger the switch from small address spaces to large address spaces. The push_16() code was already correct, and I find the inconsistency a bit odd. I'm not 100% sure about the push_64() change, so I made the change with a comment but left it a BX_PANIC() rather than switching it to BX_INFO. I'll ask Peter momentarily to have a look and let me know. While I was added, changed the push_16() BX_INFO message to be consistent with the others -- all now say 'push outside stack limits'.
This commit is contained in:
parent
b5b78258bf
commit
0aac231adb
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: stack_pro.cc,v 1.10 2002-10-25 11:44:35 bdenney Exp $
|
// $Id: stack_pro.cc,v 1.11 2002-11-07 14:02:47 shap Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2001 MandrakeSoft S.A.
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
||||||
@ -52,7 +52,7 @@ BailBigRSP("push_16");
|
|||||||
#endif
|
#endif
|
||||||
temp_ESP = SP;
|
temp_ESP = SP;
|
||||||
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, temp_ESP, 2)) {
|
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, temp_ESP, 2)) {
|
||||||
BX_PANIC(("push_16(): can't push on stack"));
|
BX_PANIC(("push_16(): push outside stack limits"));
|
||||||
exception(BX_SS_EXCEPTION, 0, 0);
|
exception(BX_SS_EXCEPTION, 0, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -97,8 +97,8 @@ BailBigRSP("push_32");
|
|||||||
/* 32bit stack size: pushes use SS:ESP */
|
/* 32bit stack size: pushes use SS:ESP */
|
||||||
if (protected_mode()) {
|
if (protected_mode()) {
|
||||||
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, ESP, 4)) {
|
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, ESP, 4)) {
|
||||||
BX_PANIC(("push_32(): push outside stack limits"));
|
BX_INFO(("push_32(): push outside stack limits"));
|
||||||
/* #SS(0) */
|
exception(BX_SS_EXCEPTION, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { /* real mode */
|
else { /* real mode */
|
||||||
@ -115,8 +115,8 @@ BailBigRSP("push_32");
|
|||||||
else { /* 16bit stack size: pushes use SS:SP */
|
else { /* 16bit stack size: pushes use SS:SP */
|
||||||
if (protected_mode()) {
|
if (protected_mode()) {
|
||||||
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, SP, 4)) {
|
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, SP, 4)) {
|
||||||
BX_PANIC(("push_32(): push outside stack limits"));
|
BX_INFO(("push_32(): push outside stack limits"));
|
||||||
/* #SS(0) */
|
exception(BX_SS_EXCEPTION, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { /* real mode */
|
else { /* real mode */
|
||||||
@ -138,8 +138,13 @@ BX_CPU_C::push_64(Bit64u value64)
|
|||||||
{
|
{
|
||||||
/* 64bit stack size: pushes use SS:RSP, assume protected mode */
|
/* 64bit stack size: pushes use SS:RSP, assume protected mode */
|
||||||
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, RSP, 8)) {
|
if (!can_push(&BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].cache, RSP, 8)) {
|
||||||
|
/* FIX: I (shap) think this should be an SS_EXCEPTION similar to
|
||||||
|
the 32bit case above, and it used to be commented #SS(0), but
|
||||||
|
until somebody who groks the hammer chip can double check this
|
||||||
|
I am leaving this as a BX_PANIC(). If this change is correct,
|
||||||
|
please change the BX_PANIC to a BX_INFO(). */
|
||||||
BX_PANIC(("push_64(): push outside stack limits"));
|
BX_PANIC(("push_64(): push outside stack limits"));
|
||||||
/* #SS(0) */
|
exception(BX_SS_EXCEPTION, 0, 0); /* #SS(0) */
|
||||||
}
|
}
|
||||||
|
|
||||||
write_virtual_qword(BX_SEG_REG_SS, RSP-8, &value64);
|
write_virtual_qword(BX_SEG_REG_SS, RSP-8, &value64);
|
||||||
|
Loading…
Reference in New Issue
Block a user