2014-03-29 18:53:07 -07:00
|
|
|
/* armvirt.c -- ARMulator virtual memory interace: ARM6 Instruction Emulator.
|
|
|
|
Copyright (C) 1994 Advanced RISC Machines Ltd.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
|
|
|
|
|
|
|
/* This file contains a complete ARMulator memory model, modelling a
|
|
|
|
"virtual memory" system. A much simpler model can be found in armfast.c,
|
|
|
|
and that model goes faster too, but has a fixed amount of memory. This
|
|
|
|
model's memory has 64K pages, allocated on demand from a 64K entry page
|
|
|
|
table. The routines PutWord and GetWord implement this. Pages are never
|
|
|
|
freed as they might be needed again. A single area of memory may be
|
|
|
|
defined to generate aborts. */
|
|
|
|
|
2014-09-10 18:27:14 -07:00
|
|
|
#include "core/arm/skyeye_common/armdefs.h"
|
2014-10-07 15:56:40 -07:00
|
|
|
#include "core/arm/skyeye_common/armemu.h"
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
#include "core/mem_map.h"
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
#define dumpstack 1
|
|
|
|
#define dumpstacksize 0x10
|
|
|
|
#define maxdmupaddr 0x0033a850
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
/*ARMword ARMul_GetCPSR (ARMul_State * state) {
|
|
|
|
return 0;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_GetSPSR (ARMul_State * state, ARMword mode) {
|
|
|
|
return 0;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_SetCPSR (ARMul_State * state, ARMword value) {
|
2014-03-29 18:53:07 -07:00
|
|
|
|
|
|
|
}
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_SetSPSR (ARMul_State * state, ARMword mode, ARMword value) {
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
}*/
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_Icycles(ARMul_State * state, unsigned number, ARMword address) {
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_Ccycles(ARMul_State * state, unsigned number, ARMword address) {
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadInstrS(ARMul_State * state, ARMword address, ARMword isize) {
|
|
|
|
state->NumScycles++;
|
2014-03-29 18:53:07 -07:00
|
|
|
|
|
|
|
#ifdef HOURGLASS
|
2014-10-07 15:56:40 -07:00
|
|
|
if ((state->NumScycles & HOURGLASS_RATE) == 0) {
|
|
|
|
HOURGLASS;
|
|
|
|
}
|
2014-03-29 18:53:07 -07:00
|
|
|
#endif
|
2014-10-07 15:56:40 -07:00
|
|
|
if (isize == 2)
|
|
|
|
return (u16)Memory::Read16(address);
|
|
|
|
else
|
|
|
|
return (u32)Memory::Read32(address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadInstrN(ARMul_State * state, ARMword address, ARMword isize) {
|
|
|
|
state->NumNcycles++;
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
if (isize == 2)
|
|
|
|
return (u16)Memory::Read16(address);
|
|
|
|
else
|
|
|
|
return (u32)Memory::Read32(address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_ReLoadInstr(ARMul_State * state, ARMword address, ARMword isize) {
|
|
|
|
ARMword data;
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
if ((isize == 2) && (address & 0x2)) {
|
|
|
|
ARMword lo;
|
|
|
|
lo = (u16)Memory::Read16(address);
|
|
|
|
return lo;
|
|
|
|
}
|
2014-03-29 18:53:07 -07:00
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
data = (u32)Memory::Read32(address);
|
|
|
|
return data;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_ReadWord(ARMul_State * state, ARMword address) {
|
|
|
|
ARMword data;
|
|
|
|
data = Memory::Read32(address);
|
|
|
|
return data;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadWordS(ARMul_State * state, ARMword address) {
|
|
|
|
state->NumScycles++;
|
|
|
|
return ARMul_ReadWord(state, address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadWordN(ARMul_State * state, ARMword address) {
|
|
|
|
state->NumNcycles++;
|
|
|
|
return ARMul_ReadWord(state, address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadHalfWord(ARMul_State * state, ARMword address) {
|
|
|
|
state->NumNcycles++;
|
|
|
|
return (u16)Memory::Read16(address);;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_ReadByte(ARMul_State * state, ARMword address) {
|
|
|
|
return (u8)Memory::Read8(address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_LoadByte(ARMul_State * state, ARMword address) {
|
|
|
|
state->NumNcycles++;
|
|
|
|
return ARMul_ReadByte(state, address);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_StoreHalfWord(ARMul_State * state, ARMword address, ARMword data) {
|
|
|
|
state->NumNcycles++;
|
|
|
|
Memory::Write16(address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_StoreByte(ARMul_State * state, ARMword address, ARMword data) {
|
|
|
|
state->NumNcycles++;
|
|
|
|
ARMul_WriteByte(state, address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_SwapWord(ARMul_State * state, ARMword address, ARMword data) {
|
|
|
|
ARMword temp;
|
|
|
|
state->NumNcycles++;
|
|
|
|
temp = ARMul_ReadWord(state, address);
|
|
|
|
state->NumNcycles++;
|
|
|
|
Memory::Write32(address, data);
|
|
|
|
return temp;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
ARMword ARMul_SwapByte(ARMul_State * state, ARMword address, ARMword data) {
|
|
|
|
ARMword temp;
|
|
|
|
temp = ARMul_LoadByte(state, address);
|
|
|
|
Memory::Write8(address, data);
|
|
|
|
return temp;
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_WriteWord(ARMul_State * state, ARMword address, ARMword data) {
|
|
|
|
Memory::Write32(address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_WriteByte(ARMul_State * state, ARMword address, ARMword data)
|
2014-03-29 18:53:07 -07:00
|
|
|
{
|
2014-10-07 15:56:40 -07:00
|
|
|
Memory::Write8(address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_StoreWordS(ARMul_State * state, ARMword address, ARMword data)
|
2014-03-29 18:53:07 -07:00
|
|
|
{
|
2014-10-07 15:56:40 -07:00
|
|
|
state->NumScycles++;
|
|
|
|
ARMul_WriteWord(state, address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|
|
|
|
|
2014-10-07 15:56:40 -07:00
|
|
|
void ARMul_StoreWordN(ARMul_State * state, ARMword address, ARMword data)
|
2014-03-29 18:53:07 -07:00
|
|
|
{
|
2014-10-07 15:56:40 -07:00
|
|
|
state->NumNcycles++;
|
|
|
|
ARMul_WriteWord(state, address, data);
|
2014-03-29 18:53:07 -07:00
|
|
|
}
|