|
|
| version 1.1, 2003/12/08 00:55:31 | version 1.10, 2007/02/06 14:20:57 |
|---|---|
| Line 1 | Line 1 |
| /* $Id$ */ | /* $Id$ */ |
| /* | /* |
| * Copyright (c) 2002-2003 NONAKA Kimihiro | * Copyright (c) 2002-2004 NONAKA Kimihiro |
| * All rights reserved. | * All rights reserved. |
| * | * |
| * Redistribution and use in source and binary forms, with or without | * Redistribution and use in source and binary forms, with or without |
| 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 30 | Line 28 |
| #ifndef IA32_CPU_CPU_MEM_H__ | #ifndef IA32_CPU_CPU_MEM_H__ |
| #define IA32_CPU_CPU_MEM_H__ | #define IA32_CPU_CPU_MEM_H__ |
| #include "memory.h" | |
| #include "segments.h" | #include "segments.h" |
| #ifdef __cplusplus | #ifdef __cplusplus |
| extern "C" { | extern "C" { |
| #endif | #endif |
| extern BYTE *cpumem; | |
| extern BYTE protectmem_size; | |
| extern DWORD extmem_size; | |
| int init_cpumem(BYTE usemem); | |
| /* | /* |
| * memory access check | * memory access check |
| */ | */ |
| void cpu_memoryread_check(descriptor_t* sd, DWORD madr, DWORD length, int e); | void cpu_memoryread_check(descriptor_t *sd, UINT32 madr, UINT length, int e); |
| void cpu_memorywrite_check(descriptor_t* sd, DWORD madr, DWORD length, int e); | void cpu_memorywrite_check(descriptor_t *sd, UINT32 madr, UINT length, int e); |
| BOOL cpu_stack_push_check(descriptor_t* sd, DWORD madr, DWORD length); | void cpu_stack_push_check(UINT16 s, descriptor_t *sd, UINT32 madr, UINT length); |
| BOOL cpu_stack_pop_check(descriptor_t* sd, DWORD madr, DWORD length); | void cpu_stack_pop_check(UINT16 s, descriptor_t *sd, UINT32 madr, UINT length); |
| #define CHECK_STACK_PUSH(sdp, addr, n) cpu_stack_push_check(sdp, addr, n) | #define STACK_PUSH_CHECK(s, sd, addr, n) cpu_stack_push_check(s, sd, addr, n) |
| #define CHECK_STACK_POP(sdp, addr, n) cpu_stack_pop_check(sdp, addr, n) | #define STACK_POP_CHECK(s, sd, addr, n) cpu_stack_pop_check(s, sd, addr, n) |
| /* | /* |
| * physcal address function | * virtual address function |
| */ | */ |
| void MEMCALL cpu_memorywrite(DWORD address, BYTE value); | void MEMCALL cpu_vmemorywrite_b(int idx, UINT32 offset, UINT8 value); |
| void MEMCALL cpu_memorywrite_w(DWORD address, WORD value); | void MEMCALL cpu_vmemorywrite_w(int idx, UINT32 offset, UINT16 value); |
| void MEMCALL cpu_memorywrite_d(DWORD address, DWORD value); | void MEMCALL cpu_vmemorywrite_d(int idx, UINT32 offset, UINT32 value); |
| BYTE MEMCALL cpu_memoryread(DWORD address); | void MEMCALL cpu_vmemorywrite_q(int idx, UINT32 offset, UINT64 value); |
| WORD MEMCALL cpu_memoryread_w(DWORD address); | void MEMCALL cpu_vmemorywrite_f(int idx, UINT32 offset, const REG80 *value); |
| DWORD MEMCALL cpu_memoryread_d(DWORD address); | UINT8 MEMCALL cpu_vmemoryread_b(int idx, UINT32 offset); |
| UINT16 MEMCALL cpu_vmemoryread_w(int idx, UINT32 offset); | |
| UINT32 MEMCALL cpu_vmemoryread_d(int idx, UINT32 offset); | |
| UINT64 MEMCALL cpu_vmemoryread_q(int idx, UINT32 offset); | |
| REG80 MEMCALL cpu_vmemoryread_f(int idx, UINT32 offset); | |
| UINT32 MEMCALL cpu_memory_access_va_RMW_b(int idx, UINT32 offset, UINT32 (*func)(UINT32, void *), void *arg); | |
| UINT32 MEMCALL cpu_memory_access_va_RMW_w(int idx, UINT32 offset, UINT32 (*func)(UINT32, void *), void *arg); | |
| UINT32 MEMCALL cpu_memory_access_va_RMW_d(int idx, UINT32 offset, UINT32 (*func)(UINT32, void *), void *arg); | |
| #define cpu_vmemorywrite(i,o,v) cpu_vmemorywrite_b(i,o,v) | |
| #define cpu_vmemoryread(i,o) cpu_vmemoryread_b(i,o) | |
| #define cpu_memory_access_va_RMW(i,o,f,a) cpu_memory_access_va_RMW_b(i,o,f,a) | |
| /* | /* |
| * virtual address function | * code fetch |
| */ | */ |
| void MEMCALL cpu_vmemorywrite(int idx, DWORD address, BYTE value); | UINT8 MEMCALL cpu_codefetch(UINT32 madr); |
| void MEMCALL cpu_vmemorywrite_w(int idx, DWORD address, WORD value); | UINT16 MEMCALL cpu_codefetch_w(UINT32 madr); |
| void MEMCALL cpu_vmemorywrite_d(int idx, DWORD address, DWORD value); | UINT32 MEMCALL cpu_codefetch_d(UINT32 madr); |
| BYTE MEMCALL cpu_vmemoryread(int idx, DWORD address); | |
| WORD MEMCALL cpu_vmemoryread_w(int idx, DWORD address); | |
| DWORD MEMCALL cpu_vmemoryread_d(int idx, DWORD address); | |
| /* | /* |
| * code fetch | * additional physical address function |
| */ | */ |
| BYTE MEMCALL cpu_codefetch(DWORD madr); | UINT64 MEMCALL cpu_memoryread_q(UINT32 address); |
| WORD MEMCALL cpu_codefetch_w(DWORD madr); | REG80 MEMCALL cpu_memoryread_f(UINT32 address); |
| DWORD MEMCALL cpu_codefetch_d(DWORD madr); | void MEMCALL cpu_memorywrite_q(UINT32 address, UINT64 value); |
| void MEMCALL cpu_memorywrite_f(UINT32 address, const REG80 *value); | |
| #ifdef __cplusplus | #ifdef __cplusplus |
| } | } |