|
|
| version 1.18, 2004/03/23 15:29:34 | version 1.24, 2008/01/25 18:07:30 |
|---|---|
| Line 12 | Line 12 |
| * 2. Redistributions in binary form must reproduce the above copyright | * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the | * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. | * documentation and/or other materials provided with the distribution. |
| * 3. The name of the author may not be used to endorse or promote products | |
| * derived from this software without specific prior written permission. | |
| * | * |
| * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR |
| * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES |
| Line 37 | Line 35 |
| #define __CBD(src) ((UINT32)((SINT8)(src))) | #define __CBD(src) ((UINT32)((SINT8)(src))) |
| #define __CWDE(src) ((SINT16)(src)) | #define __CWDE(src) ((SINT16)(src)) |
| #define PTR_TO_UINT32(p) ((UINT32)(unsigned long)(p)) | #ifndef PTR_TO_UINT32 |
| #define UINT32_TO_PTR(v) ((void *)(unsigned long)(v)) | #define PTR_TO_UINT32(p) ((UINT32)((unsigned long)(p))) |
| #endif | |
| #ifndef UINT32_TO_PTR | |
| #define UINT32_TO_PTR(v) ((void *)((unsigned long)(UINT32)(v))) | |
| #endif | |
| #define SWAP_BYTE(p, q) \ | #define SWAP_BYTE(p, q) \ |
| do { \ | do { \ |
| Line 95 do { \ | Line 97 do { \ |
| EXCEPTION(GP_EXCEPTION, 0); \ | EXCEPTION(GP_EXCEPTION, 0); \ |
| } \ | } \ |
| CPU_EIP = __new_ip; \ | CPU_EIP = __new_ip; \ |
| CPU_PREFETCH_CLEAR(); \ | |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define ADD_EIP(v) \ | #define ADD_EIP(v) \ |
| Line 104 do { \ | Line 105 do { \ |
| if (!CPU_STATSAVE.cpu_inst_default.op_32) { \ | if (!CPU_STATSAVE.cpu_inst_default.op_32) { \ |
| __tmp_ip &= 0xffff; \ | __tmp_ip &= 0xffff; \ |
| } \ | } \ |
| CPU_EIP = __tmp_ip; \ | SET_EIP(__tmp_ip); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define _ADD_EIP(v) \ | |
| do { \ | |
| UINT32 __tmp_ip = CPU_EIP + (v); \ | |
| if (!CPU_STATSAVE.cpu_inst_default.op_32) { \ | |
| __tmp_ip &= 0xffff; \ | |
| } \ | |
| CPU_EIP = __tmp_ip; \ | |
| } while (/*CONSTCOND*/ 0) | |
| #define GET_PCBYTE(v) \ | #define GET_PCBYTE(v) \ |
| do { \ | do { \ |
| (v) = cpu_codefetch(CPU_EIP); \ | (v) = cpu_codefetch(CPU_EIP); \ |
| ADD_EIP(1); \ | _ADD_EIP(1); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define GET_PCBYTES(v) \ | #define GET_PCBYTES(v) \ |
| do { \ | do { \ |
| (v) = __CBW(cpu_codefetch(CPU_EIP)); \ | (v) = __CBW(cpu_codefetch(CPU_EIP)); \ |
| ADD_EIP(1); \ | _ADD_EIP(1); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define GET_PCBYTESD(v) \ | #define GET_PCBYTESD(v) \ |
| do { \ | do { \ |
| (v) = __CBD(cpu_codefetch(CPU_EIP)); \ | (v) = __CBD(cpu_codefetch(CPU_EIP)); \ |
| ADD_EIP(1); \ | _ADD_EIP(1); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define GET_PCWORD(v) \ | #define GET_PCWORD(v) \ |
| do { \ | do { \ |
| (v) = cpu_codefetch_w(CPU_EIP); \ | (v) = cpu_codefetch_w(CPU_EIP); \ |
| ADD_EIP(2); \ | _ADD_EIP(2); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define GET_PCWORDS(v) \ | #define GET_PCWORDS(v) \ |
| do { \ | do { \ |
| (v) = __CWDE(cpu_codefetch_w(CPU_EIP)); \ | (v) = __CWDE(cpu_codefetch_w(CPU_EIP)); \ |
| ADD_EIP(2); \ | _ADD_EIP(2); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define GET_PCDWORD(v) \ | #define GET_PCDWORD(v) \ |
| do { \ | do { \ |
| (v) = cpu_codefetch_d(CPU_EIP); \ | (v) = cpu_codefetch_d(CPU_EIP); \ |
| ADD_EIP(4); \ | _ADD_EIP(4); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define PREPART_EA_REG8(b, d_s) \ | #define PREPART_EA_REG8(b, d_s) \ |
| Line 886 do { \ | Line 895 do { \ |
| do { \ | do { \ |
| UINT32 __ip; \ | UINT32 __ip; \ |
| CPU_WORKCLOCK(clock); \ | CPU_WORKCLOCK(clock); \ |
| __ip = __CBD(cpu_codefetch(CPU_EIP)); \ | GET_PCBYTESD(__ip); \ |
| __ip++; \ | |
| ADD_EIP(__ip); \ | ADD_EIP(__ip); \ |
| CPU_PREFETCH_CLEAR(); \ | |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define JMPNEAR(clock) \ | #define JMPNEAR(clock) \ |
| do { \ | do { \ |
| UINT32 __ip; \ | UINT32 __ip; \ |
| CPU_WORKCLOCK(clock); \ | CPU_WORKCLOCK(clock); \ |
| __ip = __CWDE(cpu_codefetch_w(CPU_EIP)); \ | GET_PCWORDS(__ip); \ |
| __ip += 2; \ | |
| ADD_EIP(__ip); \ | ADD_EIP(__ip); \ |
| CPU_PREFETCH_CLEAR(); \ | |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #define JMPNEAR_4(clock) \ | #define JMPNEAR_4(clock) \ |
| do { \ | do { \ |
| UINT32 __ip; \ | UINT32 __ip; \ |
| CPU_WORKCLOCK(clock); \ | CPU_WORKCLOCK(clock); \ |
| __ip = cpu_codefetch_d(CPU_EIP); \ | GET_PCDWORD(__ip); \ |
| __ip += 4; \ | |
| ADD_EIP(__ip); \ | ADD_EIP(__ip); \ |
| CPU_PREFETCH_CLEAR(); \ | |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #if !defined(IA32_SUPPORT_PREFETCH_QUEUE) | |
| #define JMPNOP(clock, d) \ | |
| do { \ | |
| CPU_WORKCLOCK(clock); \ | |
| ADD_EIP((d)); \ | |
| } while (/*CONSTCOND*/ 0) | |
| #else | |
| #define JMPNOP(clock, d) \ | #define JMPNOP(clock, d) \ |
| do { \ | do { \ |
| CPU_WORKCLOCK(clock); \ | CPU_WORKCLOCK(clock); \ |
| CPU_PREFETCHQ_REMAIN -= (d); \ | |
| ADD_EIP((d)); \ | ADD_EIP((d)); \ |
| } while (/*CONSTCOND*/ 0) | } while (/*CONSTCOND*/ 0) |
| #endif | |
| /* | /* |