readability/writeability bit should not be checked in 64-bit mode

This commit is contained in:
Stanislav Shwartsman 2007-09-26 19:09:10 +00:00
parent dcb0335ae9
commit 44a04a5fa3
2 changed files with 10 additions and 7 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: descriptor.h,v 1.17 2006-08-31 18:18:15 sshwarts Exp $ // $Id: descriptor.h,v 1.18 2007-09-26 19:09:10 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -169,9 +169,12 @@ union {
#define IS_CODE_SEGMENT(type) (((type) >> 3) & 0x1) #define IS_CODE_SEGMENT(type) (((type) >> 3) & 0x1)
#define IS_CODE_SEGMENT_CONFORMING(type) (((type) >> 2) & 0x1) #define IS_CODE_SEGMENT_CONFORMING(type) (((type) >> 2) & 0x1)
#define IS_DATA_SEGMENT_EXPAND_DOWN(type) (((type) >> 2) & 0x1) #define IS_DATA_SEGMENT_EXPAND_DOWN(type) (((type) >> 2) & 0x1)
#define IS_CODE_SEGMENT_READABLE(type) (((type) >> 1) & 0x1)
#define IS_DATA_SEGMENT_WRITEABLE(type) (((type) >> 1) & 0x1) // readable/writeable bit is ignored when in 64-bit mode
#define IS_SEGMENT_ACCESSED(type) ( (type) & 0x1) #define IS_CODE_SEGMENT_READABLE(type) (Is64BitMode() || (((type) >> 1) & 0x1))
#define IS_DATA_SEGMENT_WRITEABLE(type) (Is64BitMode() || (((type) >> 1) & 0x1))
#define IS_SEGMENT_ACCESSED(type) ((type) & 0x1)
#define BX_SEGMENT_CODE (0x8) #define BX_SEGMENT_CODE (0x8)
#define BX_SEGMENT_DATA_EXPAND_DOWN (0x4) #define BX_SEGMENT_DATA_EXPAND_DOWN (0x4)

View File

@ -1,5 +1,5 @@
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
// $Id: iret.cc,v 1.19 2007-09-10 20:47:08 sshwarts Exp $ // $Id: iret.cc,v 1.20 2007-09-26 19:09:10 sshwarts Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -279,7 +279,7 @@ BX_CPU_C::iret_protected(bxInstruction_c *i)
IS_CODE_SEGMENT(ss_descriptor.type) || IS_CODE_SEGMENT(ss_descriptor.type) ||
!IS_DATA_SEGMENT_WRITEABLE(ss_descriptor.type)) !IS_DATA_SEGMENT_WRITEABLE(ss_descriptor.type))
{ {
BX_ERROR(("iret: SS AR byte not writable code segment")); BX_ERROR(("iret: SS AR byte not writable or code segment"));
exception(BX_GP_EXCEPTION, raw_ss_selector & 0xfffc, 0); exception(BX_GP_EXCEPTION, raw_ss_selector & 0xfffc, 0);
} }
@ -540,7 +540,7 @@ BX_CPU_C::long_iret(bxInstruction_c *i)
IS_CODE_SEGMENT(ss_descriptor.type) || IS_CODE_SEGMENT(ss_descriptor.type) ||
!IS_DATA_SEGMENT_WRITEABLE(ss_descriptor.type)) !IS_DATA_SEGMENT_WRITEABLE(ss_descriptor.type))
{ {
BX_ERROR(("iret64: SS AR byte not writable code segment")); BX_ERROR(("iret64: SS AR byte not writable or code segment: %d", ss_descriptor.type));
exception(BX_GP_EXCEPTION, raw_ss_selector & 0xfffc, 0); exception(BX_GP_EXCEPTION, raw_ss_selector & 0xfffc, 0);
} }