--- np2/i386c/ia32/instructions/bit_byte.c 2004/02/20 16:09:05 1.6 +++ np2/i386c/ia32/instructions/bit_byte.c 2004/03/23 15:29:34 1.9 @@ -1,4 +1,4 @@ -/* $Id: bit_byte.c,v 1.6 2004/02/20 16:09:05 monaka Exp $ */ +/* $Id: bit_byte.c,v 1.9 2004/03/23 15:29:34 monaka Exp $ */ /* * Copyright (c) 2002-2003 NONAKA Kimihiro @@ -33,11 +33,11 @@ #include "bit_byte.h" -#define BIT_OFFSET16(v) (2 * (((SINT16)(v)) / 16)) +#define BIT_OFFSET16(v) (2 * (((SINT16)(v)) >> 4)) #define BIT_INDEX16(v) ((v) & 0xf) #define BIT_MAKEBIT16(v) (1 << BIT_INDEX16(v)) -#define BIT_OFFSET32(v) (4 * (((SINT32)(v)) / 32)) +#define BIT_OFFSET32(v) (4 * (((SINT32)(v)) >> 5)) #define BIT_INDEX32(v) ((v) & 0x1f) #define BIT_MAKEBIT32(v) (1 << BIT_INDEX32(v)) @@ -653,7 +653,7 @@ void SETO_Eb(void) { UINT32 op, madr; - UINT8 v = CPU_OV ? 1 : 0; + UINT8 v = CC_O?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -670,7 +670,7 @@ void SETNO_Eb(void) { UINT32 op, madr; - UINT8 v = CPU_OV ? 0 : 1; + UINT8 v = CC_NO?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -687,7 +687,7 @@ void SETC_Eb(void) { UINT32 op, madr; - UINT8 v = (UINT8)(CPU_FLAGL & C_FLAG); + UINT8 v = CC_C?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -704,7 +704,7 @@ void SETNC_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & C_FLAG) ? 0 : 1; + UINT8 v = CC_NC?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -721,7 +721,7 @@ void SETZ_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & Z_FLAG) ? 1 : 0; + UINT8 v = CC_Z?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -738,7 +738,7 @@ void SETNZ_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & Z_FLAG) ? 0 : 1; + UINT8 v = CC_NZ?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -755,7 +755,7 @@ void SETA_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & (Z_FLAG|C_FLAG)) ? 0 : 1; + UINT8 v = CC_A?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -772,7 +772,7 @@ void SETNA_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & (Z_FLAG|C_FLAG)) ? 1 : 0; + UINT8 v = CC_NA?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -789,7 +789,7 @@ void SETS_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & S_FLAG) ? 1 : 0; + UINT8 v = CC_S?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -806,7 +806,7 @@ void SETNS_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & S_FLAG) ? 0 : 1; + UINT8 v = CC_NS?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -823,7 +823,7 @@ void SETP_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & P_FLAG) ? 1 : 0; + UINT8 v = CC_P?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -840,7 +840,7 @@ void SETNP_Eb(void) { UINT32 op, madr; - UINT8 v = (CPU_FLAGL & P_FLAG) ? 0 : 1; + UINT8 v = CC_NP?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -857,7 +857,7 @@ void SETL_Eb(void) { UINT32 op, madr; - UINT8 v = (!CPU_OV == !(CPU_FLAGL & S_FLAG)) ? 1 : 0; + UINT8 v = CC_L?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -874,7 +874,7 @@ void SETNL_Eb(void) { UINT32 op, madr; - UINT8 v = (!CPU_OV == !(CPU_FLAGL & S_FLAG)) ? 0 : 1; + UINT8 v = CC_NL?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -891,7 +891,7 @@ void SETLE_Eb(void) { UINT32 op, madr; - UINT8 v = ((CPU_FLAGL & Z_FLAG) || (!CPU_OV == !(CPU_FLAGL & S_FLAG))) ? 1 : 0; + UINT8 v = CC_LE?1:0; GET_PCBYTE(op); if (op >= 0xc0) { @@ -908,7 +908,7 @@ void SETNLE_Eb(void) { UINT32 op, madr; - UINT8 v = ((CPU_FLAGL & Z_FLAG) || (!CPU_OV == !(CPU_FLAGL & S_FLAG))) ? 0 : 1; + UINT8 v = CC_NLE?1:0; GET_PCBYTE(op); if (op >= 0xc0) {