* add TSC shito

* fix possible modcrypt shittiness
This commit is contained in:
Arisotura 2021-08-30 21:42:35 +02:00
parent e7f0923623
commit e1f3fc75ea
3 changed files with 19 additions and 4 deletions

View File

@ -26,6 +26,7 @@
#include "GPU.h" #include "GPU.h"
#include "NDSCart.h" #include "NDSCart.h"
#include "SPI.h" #include "SPI.h"
#include "DSi_SPI_TSC.h"
#include "Platform.h" #include "Platform.h"
#ifdef JIT_ENABLED #ifdef JIT_ENABLED
@ -89,6 +90,9 @@ u8 ITCMInit[0x8000];
u8 ARM7Init[0x3C00]; u8 ARM7Init[0x3C00];
void Set_SCFG_Clock9(u16 val);
bool Init() bool Init()
{ {
#ifndef JIT_ENABLED #ifndef JIT_ENABLED
@ -230,13 +234,14 @@ void DecryptModcryptArea(u32 offset, u32 size, u8* iv)
// find a matching binary area // find a matching binary area
u32 binaryaddr, binarysize; u32 binaryaddr, binarysize;
u32 roundedsize = (size + 0xF) & ~0xF;
// CHECKME: GBAtek says the modcrypt area should be the same size, or bigger, // CHECKME: GBAtek says the modcrypt area should be the same size, or bigger,
// than the binary area being considered // than the binary area being considered
// but I have seen modcrypt areas smaller than the ARM9i binary // but I have seen modcrypt areas smaller than the ARM9i binary
#define BINARY_GOOD(name) \ #define BINARY_GOOD(name) \
((offset >= NDSCart::Header.name##ROMOffset) && \ ((offset >= NDSCart::Header.name##ROMOffset) && \
(offset+size) <= (NDSCart::Header.name##ROMOffset+NDSCart::Header.name##Size)) (offset+roundedsize) <= (NDSCart::Header.name##ROMOffset + ((NDSCart::Header.name##Size + 0xF) & ~0xF)))
if (BINARY_GOOD(ARM9)) if (BINARY_GOOD(ARM9))
{ {
@ -314,7 +319,8 @@ void SetupDirectBoot()
NDS::MapSharedWRAM(3); NDS::MapSharedWRAM(3);
// TODO: clock speed! DSi_SPI_TSC::SetMode(0x00);
Set_SCFG_Clock9(0x0000);
} }
else else
{ {
@ -363,6 +369,9 @@ void SetupDirectBoot()
MBK[1][8] = mbk[11] & 0x00FFFF0F; MBK[1][8] = mbk[11] & 0x00FFFF0F;
NDS::MapSharedWRAM(mbk[11] >> 24); NDS::MapSharedWRAM(mbk[11] >> 24);
if (!(NDSCart::Header.AppFlags & (1<<0)))
DSi_SPI_TSC::SetMode(0x00);
} }
u32 arm9start = 0; u32 arm9start = 0;
@ -489,8 +498,6 @@ void SetupDirectBoot()
NDS::ARM7BIOSProt = 0x20; NDS::ARM7BIOSProt = 0x20;
// TODO: SCFG setup, permissions, etc
SPI_Firmware::SetupDirectBoot(true); SPI_Firmware::SetupDirectBoot(true);
} }

View File

@ -81,6 +81,11 @@ void DoSavestate(Savestate* file)
// TODO!! // TODO!!
} }
void SetMode(u8 mode)
{
TSCMode = mode;
}
void SetTouchCoords(u16 x, u16 y) void SetTouchCoords(u16 x, u16 y)
{ {
if (TSCMode == 0x00) if (TSCMode == 0x00)

View File

@ -29,6 +29,9 @@ void DeInit();
void Reset(); void Reset();
void DoSavestate(Savestate* file); void DoSavestate(Savestate* file);
// 00=DS-mode 01=normal
void SetMode(u8 mode);
void SetTouchCoords(u16 x, u16 y); void SetTouchCoords(u16 x, u16 y);
void MicInputFrame(s16* data, int samples); void MicInputFrame(s16* data, int samples);