MMU .c/.h - Added a Clear Memory function
NDSSystem.c - Call Clear Memory every time you run a rom to make sure all the the memory is blank like it should be mc.c - Added basic saving backup ram to file (it slows saving down ALOT though)
This commit is contained in:
parent
52f564a0fe
commit
f19bb9cfce
|
@ -287,6 +287,28 @@ u32 rom_mask = 0;
|
||||||
u32 DMASrc[2][4] = {{0, 0, 0, 0}, {0, 0, 0, 0}};
|
u32 DMASrc[2][4] = {{0, 0, 0, 0}, {0, 0, 0, 0}};
|
||||||
u32 DMADst[2][4] = {{0, 0, 0, 0}, {0, 0, 0, 0}};
|
u32 DMADst[2][4] = {{0, 0, 0, 0}, {0, 0, 0, 0}};
|
||||||
|
|
||||||
|
void MMU_clearMem()
|
||||||
|
{
|
||||||
|
memset(ARM9Mem.ARM9_ABG, 0, 0x80000);
|
||||||
|
memset(ARM9Mem.ARM9_AOBJ, 0, 0x40000);
|
||||||
|
memset(ARM9Mem.ARM9_BBG, 0, 0x20000);
|
||||||
|
memset(ARM9Mem.ARM9_BOBJ, 0, 0x20000);
|
||||||
|
memset(ARM9Mem.ARM9_DTCM, 0, 0x4000);
|
||||||
|
memset(ARM9Mem.ARM9_ITCM, 0, 0x8000);
|
||||||
|
memset(ARM9Mem.ARM9_LCD, 0, 0xA4000);
|
||||||
|
memset(ARM9Mem.ARM9_OAM, 0, 0x800);
|
||||||
|
memset(ARM9Mem.ARM9_REG, 0, 0x1000000);
|
||||||
|
memset(ARM9Mem.ARM9_VMEM, 0, 0x800);
|
||||||
|
memset(ARM9Mem.ARM9_WRAM, 0, 0x1000000);
|
||||||
|
memset(ARM9Mem.MAIN_MEM, 0, 0x400000);
|
||||||
|
//memset(&ARM9, 0, sizeof(ARM9_struct));
|
||||||
|
|
||||||
|
memset(MMU.ARM7_ERAM, 0, 0x10000);
|
||||||
|
memset(MMU.ARM7_REG, 0, 0x10000);
|
||||||
|
|
||||||
|
MainScreen.offset = 192;
|
||||||
|
SubScreen.offset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
void MMU_setRom(u8 * rom, u32 mask)
|
void MMU_setRom(u8 * rom, u32 mask)
|
||||||
{
|
{
|
||||||
|
@ -1068,42 +1090,42 @@ void FASTCALL MMU_write16(u32 proc, u32 adr, u16 val)
|
||||||
GPU_setYH(SubScreen.gpu, 3, val);
|
GPU_setYH(SubScreen.gpu, 3, val);
|
||||||
return;
|
return;
|
||||||
case BG0_CR :
|
case BG0_CR :
|
||||||
GPULOG("MAIN BG0 SETPROP 16B %08X\r\n", val);
|
//GPULOG("MAIN BG0 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(MainScreen.gpu, 0, val);
|
GPU_setBGProp(MainScreen.gpu, 0, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x8, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x8, val);
|
||||||
return;
|
return;
|
||||||
case BG1_CR :
|
case BG1_CR :
|
||||||
GPULOG("MAIN BG1 SETPROP 16B %08X\r\n", val);
|
//GPULOG("MAIN BG1 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(MainScreen.gpu, 1, val);
|
GPU_setBGProp(MainScreen.gpu, 1, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xA, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xA, val);
|
||||||
return;
|
return;
|
||||||
case BG2_CR :
|
case BG2_CR :
|
||||||
GPULOG("MAIN BG2 SETPROP 16B %08X\r\n", val);
|
//GPULOG("MAIN BG2 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(MainScreen.gpu, 2, val);
|
GPU_setBGProp(MainScreen.gpu, 2, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xC, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xC, val);
|
||||||
return;
|
return;
|
||||||
case BG3_CR :
|
case BG3_CR :
|
||||||
GPULOG("MAIN BG3 SETPROP 16B %08X\r\n", val);
|
//GPULOG("MAIN BG3 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(MainScreen.gpu, 3, val);
|
GPU_setBGProp(MainScreen.gpu, 3, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xE, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0xE, val);
|
||||||
return;
|
return;
|
||||||
case SUB_BG0_CR :
|
case SUB_BG0_CR :
|
||||||
GPULOG("SUB BG0 SETPROP 16B %08X\r\n", val);
|
//GPULOG("SUB BG0 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(SubScreen.gpu, 0, val);
|
GPU_setBGProp(SubScreen.gpu, 0, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x1008, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x1008, val);
|
||||||
return;
|
return;
|
||||||
case SUB_BG1_CR :
|
case SUB_BG1_CR :
|
||||||
GPULOG("SUB BG1 SETPROP 16B %08X\r\n", val);
|
//GPULOG("SUB BG1 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(SubScreen.gpu, 1, val);
|
GPU_setBGProp(SubScreen.gpu, 1, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100A, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100A, val);
|
||||||
return;
|
return;
|
||||||
case SUB_BG2_CR :
|
case SUB_BG2_CR :
|
||||||
GPULOG("SUB BG2 SETPROP 16B %08X\r\n", val);
|
//GPULOG("SUB BG2 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(SubScreen.gpu, 2, val);
|
GPU_setBGProp(SubScreen.gpu, 2, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100C, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100C, val);
|
||||||
return;
|
return;
|
||||||
case SUB_BG3_CR :
|
case SUB_BG3_CR :
|
||||||
GPULOG("SUB BG3 SETPROP 16B %08X\r\n", val);
|
//GPULOG("SUB BG3 SETPROP 16B %08X\r\n", val);
|
||||||
GPU_setBGProp(SubScreen.gpu, 3, val);
|
GPU_setBGProp(SubScreen.gpu, 3, val);
|
||||||
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100E, val);
|
T1WriteWord(MMU.MMU_MEM[proc][0x40], 0x100E, val);
|
||||||
return;
|
return;
|
||||||
|
@ -1595,13 +1617,13 @@ void FASTCALL MMU_write32(u32 proc, u32 adr, u32 val)
|
||||||
case 0x04000000 :
|
case 0x04000000 :
|
||||||
GPU_setVideoProp(MainScreen.gpu, val);
|
GPU_setVideoProp(MainScreen.gpu, val);
|
||||||
|
|
||||||
GPULOG("MAIN INIT 32B %08X\r\n", val);
|
//GPULOG("MAIN INIT 32B %08X\r\n", val);
|
||||||
T1WriteLong(MMU.MMU_MEM[proc][0x40], 0, val);
|
T1WriteLong(MMU.MMU_MEM[proc][0x40], 0, val);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case 0x04001000 :
|
case 0x04001000 :
|
||||||
GPU_setVideoProp(SubScreen.gpu, val);
|
GPU_setVideoProp(SubScreen.gpu, val);
|
||||||
GPULOG("SUB INIT 32B %08X\r\n", val);
|
//GPULOG("SUB INIT 32B %08X\r\n", val);
|
||||||
T1WriteLong(MMU.MMU_MEM[proc][0x40], 0x1000, val);
|
T1WriteLong(MMU.MMU_MEM[proc][0x40], 0x1000, val);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -100,6 +100,8 @@ extern MMU_struct MMU;
|
||||||
void MMUInit(void);
|
void MMUInit(void);
|
||||||
void MMUDeInit(void);
|
void MMUDeInit(void);
|
||||||
|
|
||||||
|
void MMU_clearMem();
|
||||||
|
|
||||||
void MMU_setRom(u8 * rom, u32 mask);
|
void MMU_setRom(u8 * rom, u32 mask);
|
||||||
void MMU_unsetRom();
|
void MMU_unsetRom();
|
||||||
|
|
||||||
|
|
|
@ -87,6 +87,8 @@ BOOL NDS_SetROM(u8 * rom, u32 mask)
|
||||||
{
|
{
|
||||||
u32 i;
|
u32 i;
|
||||||
|
|
||||||
|
MMU_clearMem();
|
||||||
|
|
||||||
MMU_setRom(rom, mask);
|
MMU_setRom(rom, mask);
|
||||||
|
|
||||||
NDS_header * header = NDS_getROMHeader();
|
NDS_header * header = NDS_getROMHeader();
|
||||||
|
|
|
@ -83,6 +83,22 @@ void mc_reset_com(memory_chip_t *mc)
|
||||||
mc->com = 0;
|
mc->com = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mc_read_file(memory_chip_t *mc, char* filename)
|
||||||
|
{
|
||||||
|
FILE* file = fopen(filename, "rb");
|
||||||
|
if(file == NULL) return;
|
||||||
|
fread (mc->data, mc->size, 1, file);
|
||||||
|
fclose (file);
|
||||||
|
}
|
||||||
|
|
||||||
|
void mc_write_file(memory_chip_t *mc, char* filename)
|
||||||
|
{
|
||||||
|
FILE* file = fopen(filename, "wb");
|
||||||
|
if(file == NULL) return;
|
||||||
|
fwrite (mc->data, mc->size, 1, file);
|
||||||
|
fclose (file);
|
||||||
|
}
|
||||||
|
|
||||||
u8 fw_transfer(memory_chip_t *mc, u8 data)
|
u8 fw_transfer(memory_chip_t *mc, u8 data)
|
||||||
{
|
{
|
||||||
if(mc->com == FW_CMD_READ || mc->com == FW_CMD_PAGEWRITE) /* check if we are in a command that needs 3 bytes address */
|
if(mc->com == FW_CMD_READ || mc->com == FW_CMD_PAGEWRITE) /* check if we are in a command that needs 3 bytes address */
|
||||||
|
@ -164,6 +180,7 @@ u8 fw_transfer(memory_chip_t *mc, u8 data)
|
||||||
|
|
||||||
u8 bm_transfer(memory_chip_t *mc, u8 data)
|
u8 bm_transfer(memory_chip_t *mc, u8 data)
|
||||||
{
|
{
|
||||||
|
mc_read_file(mc,"test.sav");
|
||||||
if(mc->com == BM_CMD_READLOW || mc->com == BM_CMD_READHIGH ||
|
if(mc->com == BM_CMD_READLOW || mc->com == BM_CMD_READHIGH ||
|
||||||
mc->com == BM_CMD_WRITELOW || mc->com == BM_CMD_WRITEHIGH) /* check if we are in a command that needs multiple byte address */
|
mc->com == BM_CMD_WRITELOW || mc->com == BM_CMD_WRITEHIGH) /* check if we are in a command that needs multiple byte address */
|
||||||
{
|
{
|
||||||
|
@ -258,6 +275,7 @@ u8 bm_transfer(memory_chip_t *mc, u8 data)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mc_write_file(mc,"test.sav");
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue