--- np2/i286c/i286c_sf.mcr 2003/11/30 12:38:15 1.6 +++ np2/i286c/i286c_sf.mcr 2003/12/11 04:03:35 1.8 @@ -39,11 +39,17 @@ I286_OV = (s) & 0x80; \ I286_FLAGL = (BYTE)(BYTESZPF(d) | A_FLAG | ((s) & 1)); +#if 1 #define BYTE_SAR1(d, s) \ - (d) = (BYTE)(((SINT8)s) >> 1); \ + (d) = ((s) & 0x80) + ((s) >> 1); \ I286_OV = 0; \ I286_FLAGL = (BYTE)(BYTESZPF(d) | A_FLAG | ((s) & 1)); - +#else // eVC3/4 compiler bug +#define BYTE_SAR1(d, s) \ + (d) = (BYTE)(((SINT8)(s)) >> 1); \ + I286_OV = 0; \ + I286_FLAGL = (BYTE)(BYTESZPF(d) | A_FLAG | ((s) & 1)); +#endif #define WORD_ROL1(d, s) { \ @@ -84,11 +90,17 @@ I286_OV = (s) & 0x8000; \ I286_FLAGL = (BYTE)(WORDSZPF(d) | A_FLAG | ((s) & 1)); +#if 1 #define WORD_SAR1(d, s) \ - (d) = (UINT16)(((SINT16)s) >> 1); \ + (d) = ((s) & 0x8000) + ((s) >> 1); \ I286_OV = 0; \ I286_FLAGL = (BYTE)(WORDSZPF(d) | A_FLAG | ((s) & 1)); - +#else // eVC3/4 compiler bug +#define WORD_SAR1(d, s) \ + (d) = (UINT16)(((SINT16)(s)) >> 1); \ + I286_OV = 0; \ + I286_FLAGL = (BYTE)(WORDSZPF(d) | A_FLAG | ((s) & 1)); +#endif @@ -297,6 +309,7 @@ } \ (d) = (s); +#if !defined(_WIN32_WCE) || (_WIN32_WCE < 300) #define WORD_SARCL(d, s, c) \ (c) &= 0x1f; \ if (c) { \ @@ -307,4 +320,18 @@ I286_FLAGL |= WORDSZPF(s); \ } \ (d) = (s); +#else // eVC¡Á +#define WORD_SARCL(d, s, c) \ + (c) &= 0x1f; \ + if (c) { \ + SINT32 tmp; \ + tmp = (s) << 16; \ + tmp = tmp >> (16 + (c) - 1); \ + I286_FLAGL = (BYTE)(tmp & 1); \ + (s) = (UINT16)(tmp >> 1); \ + I286_OV = 0; \ + I286_FLAGL |= WORDSZPF(s); \ + } \ + (d) = (s); +#endif