2020-10-03 15:22:44 +00:00
|
|
|
#include "global.h"
|
2020-03-17 04:31:30 +00:00
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
typedef struct {
|
2020-03-17 04:31:30 +00:00
|
|
|
/* 0x00 */ OSPiHandle piHandle;
|
|
|
|
/* 0x74 */ OSIoMesg ioMesg;
|
|
|
|
/* 0x8C */ OSMesgQueue mesgQ;
|
|
|
|
} struct_800A9D40;
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
struct_800A9D40 D_8012A690 = { 0 };
|
2020-03-17 04:31:30 +00:00
|
|
|
|
|
|
|
void func_800A9D40(u32 addr, u8 handleType, u8 handleDomain, u8 handleLatency, u8 handlePageSize, u8 handleRelDuration,
|
2020-03-22 21:19:43 +00:00
|
|
|
u8 handlePulse, u32 handleSpeed) {
|
2020-03-17 04:31:30 +00:00
|
|
|
u32 int_disabled;
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
OSPiHandle* handle = &D_8012A690.piHandle;
|
|
|
|
if ((u32)OS_PHYSICAL_TO_K1(addr) != (*handle).baseAddress) {
|
2020-03-17 04:31:30 +00:00
|
|
|
D_8012A690.piHandle.type = handleType;
|
|
|
|
(*handle).baseAddress = OS_PHYSICAL_TO_K1(addr);
|
|
|
|
D_8012A690.piHandle.latency = handleLatency;
|
|
|
|
D_8012A690.piHandle.pulse = handlePulse;
|
|
|
|
D_8012A690.piHandle.pageSize = handlePageSize;
|
|
|
|
D_8012A690.piHandle.relDuration = handleRelDuration;
|
|
|
|
D_8012A690.piHandle.domain = handleDomain;
|
|
|
|
D_8012A690.piHandle.speed = handleSpeed;
|
|
|
|
bzero(&D_8012A690.piHandle.transferInfo, sizeof(__OSTranxInfo));
|
|
|
|
int_disabled = __osDisableInt();
|
|
|
|
D_8012A690.piHandle.next = __osPiTable;
|
|
|
|
__osPiTable = &D_8012A690;
|
|
|
|
__osRestoreInt(int_disabled);
|
|
|
|
D_8012A690.ioMesg.hdr.pri = 0;
|
|
|
|
D_8012A690.ioMesg.hdr.retQueue = &D_8012A690.mesgQ;
|
|
|
|
D_8012A690.ioMesg.devAddr = addr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void func_800A9E14(UNK_PTR dramAddr, size_t size, UNK_TYPE arg2) {
|
2020-03-17 04:31:30 +00:00
|
|
|
OSMesg mesg;
|
|
|
|
|
|
|
|
osCreateMesgQueue(&D_8012A690.mesgQ, &mesg, 1);
|
|
|
|
D_8012A690.ioMesg.dramAddr = dramAddr;
|
|
|
|
D_8012A690.ioMesg.size = size;
|
|
|
|
osWritebackDCache(dramAddr, size);
|
|
|
|
osEPiStartDma(&D_8012A690, &D_8012A690.ioMesg, arg2);
|
|
|
|
osRecvMesg(&D_8012A690.mesgQ, &mesg, 1);
|
|
|
|
osInvalDCache(dramAddr, size);
|
|
|
|
}
|
|
|
|
|
2020-03-22 21:19:43 +00:00
|
|
|
void Sram_ReadWrite(UNK_TYPE arg0, UNK_PTR dramAddr, size_t size, UNK_TYPE arg3) {
|
2020-03-17 04:31:30 +00:00
|
|
|
osSyncPrintf("ssSRAMReadWrite:%08x %08x %08x %d\n", arg0, dramAddr, size, arg3);
|
|
|
|
func_800A9D40(arg0, 3, 1, 5, 0xd, 2, 0xc, 0);
|
|
|
|
func_800A9E14(dramAddr, size, arg3);
|
|
|
|
}
|