mirror of
https://github.com/TwilitRealm/dusklight
synced 2026-06-14 05:34:38 -04:00
Reorganize library code into libs/ (#3119)
* Reorganize files into libs/{dolphin,JSystem,PowerPC_EABI_Support,revolution,TRK_MINNOW_DOLPHIN}
* Update configure.py and project.py for new libs structure
* Refactor `#include <dolphin/x.h>` -> `<x.h>`
* Remove `__REVOLUTION_SDK__` forwards from dolphin
* Fix dolphin/ references in revolution
* Wrap `#include <dolphin.h>` in `!__REVOLUTION_SDK__`
* Always build TRK against dolphin headers
* Resolve revolution SDK header resolution issues
This commit is contained in:
@@ -0,0 +1,117 @@
|
||||
#include <dolphin/dolphin.h>
|
||||
#include <dolphin/os.h>
|
||||
|
||||
#include "__os.h"
|
||||
|
||||
static u8 DSPInitCode[128] = {
|
||||
0x02, 0x9F, 0x00, 0x10, 0x02, 0x9F, 0x00, 0x33, 0x02, 0x9F, 0x00, 0x34, 0x02, 0x9F, 0x00, 0x35,
|
||||
0x02, 0x9F, 0x00, 0x36, 0x02, 0x9F, 0x00, 0x37, 0x02, 0x9F, 0x00, 0x38, 0x02, 0x9F, 0x00, 0x39,
|
||||
0x12, 0x06, 0x12, 0x03, 0x12, 0x04, 0x12, 0x05, 0x00, 0x80, 0x80, 0x00, 0x00, 0x88, 0xFF, 0xFF,
|
||||
0x00, 0x84, 0x10, 0x00, 0x00, 0x64, 0x00, 0x1D, 0x02, 0x18, 0x00, 0x00, 0x81, 0x00, 0x1C, 0x1E,
|
||||
0x00, 0x44, 0x1B, 0x1E, 0x00, 0x84, 0x08, 0x00, 0x00, 0x64, 0x00, 0x27, 0x19, 0x1E, 0x00, 0x00,
|
||||
0x00, 0xDE, 0xFF, 0xFC, 0x02, 0xA0, 0x80, 0x00, 0x02, 0x9C, 0x00, 0x28, 0x16, 0xFC, 0x00, 0x54,
|
||||
0x16, 0xFD, 0x43, 0x48, 0x00, 0x21, 0x02, 0xFF, 0x02, 0xFF, 0x02, 0xFF, 0x02, 0xFF, 0x02, 0xFF,
|
||||
0x02, 0xFF, 0x02, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
};
|
||||
|
||||
#define __DSPWorkBuffer (void*)0x81000000
|
||||
|
||||
void __OSInitAudioSystem(void) {
|
||||
u8 errFlag;
|
||||
u16 reg16;
|
||||
u32 start_tick;
|
||||
|
||||
memcpy((void*)((u32)OSGetArenaHi() - 0x80), __DSPWorkBuffer, sizeof(DSPInitCode));
|
||||
memcpy(__DSPWorkBuffer, (void*)DSPInitCode, sizeof(DSPInitCode));
|
||||
DCFlushRange(__DSPWorkBuffer, sizeof(DSPInitCode));
|
||||
|
||||
__DSPRegs[9] = 0x43;
|
||||
ASSERTMSGLINE(113, !(__DSPRegs[5] & 0x200), "__OSInitAudioSystem(): ARAM DMA already in progress");
|
||||
ASSERTMSGLINE(117, !(__DSPRegs[5] & 0x400), "__OSInitAudioSystem(): DSP DMA already in progress");
|
||||
ASSERTMSGLINE(121, (__DSPRegs[5] & 0x004), "__OSInitAudioSystem(): DSP already working");
|
||||
|
||||
__DSPRegs[5] = 0x8AC;
|
||||
__DSPRegs[5] |= 1;
|
||||
|
||||
while (__DSPRegs[5] & 1);
|
||||
__DSPRegs[0] = 0;
|
||||
|
||||
while (((__DSPRegs[2] << 16) | __DSPRegs[3]) & 0x80000000);
|
||||
|
||||
*(u32*)&__DSPRegs[16] = 0x1000000;
|
||||
*(u32*)&__DSPRegs[18] = 0;
|
||||
*(u32*)&__DSPRegs[20] = 0x20;
|
||||
|
||||
reg16 = __DSPRegs[5];
|
||||
while (!(reg16 & 0x20))
|
||||
reg16 = __DSPRegs[5];
|
||||
|
||||
__DSPRegs[5] = reg16;
|
||||
|
||||
start_tick = OSGetTick();
|
||||
while ((s32)(OSGetTick() - start_tick) < 0x892);
|
||||
|
||||
*(u32*)&__DSPRegs[16] = 0x1000000;
|
||||
*(u32*)&__DSPRegs[18] = 0;
|
||||
*(u32*)&__DSPRegs[20] = 0x20;
|
||||
|
||||
reg16 = __DSPRegs[5];
|
||||
while (!(reg16 & 0x20)) {
|
||||
reg16 = __DSPRegs[5];
|
||||
}
|
||||
__DSPRegs[5] = reg16;
|
||||
|
||||
__DSPRegs[5] &= ~0x800;
|
||||
while ((__DSPRegs[5]) & 0x400);
|
||||
|
||||
__DSPRegs[5] &= ~4;
|
||||
errFlag = 0;
|
||||
|
||||
reg16 = __DSPRegs[2];
|
||||
|
||||
while (!(reg16 & 0x8000)) {
|
||||
reg16 = __DSPRegs[2];
|
||||
}
|
||||
|
||||
if(((u32)((reg16 << 16) | __DSPRegs[3]) + 0x7FAC0000U) != 0x4348) {
|
||||
ASSERTMSGLINE(193, 0, "__OSInitAudioSystem(): DSP returns invalid message");
|
||||
}
|
||||
|
||||
reg16 != 0x81800; // fake but fixes reg alloc on retail
|
||||
__DSPRegs[5] |= 4;
|
||||
__DSPRegs[5] = 0x8AC;
|
||||
__DSPRegs[5] |= 1;
|
||||
while (__DSPRegs[5] & 1);
|
||||
|
||||
memcpy(__DSPWorkBuffer, (void*)((u32)OSGetArenaHi() - 0x80), sizeof(DSPInitCode));
|
||||
}
|
||||
|
||||
void __OSStopAudioSystem(void) {
|
||||
u16 reg16;
|
||||
u32 start_tick;
|
||||
|
||||
#define waitUntil(load, mask) \
|
||||
reg16 = (load); \
|
||||
while (reg16 & (mask)) { \
|
||||
reg16 = (load); \
|
||||
}
|
||||
|
||||
__DSPRegs[5] = 0x804;
|
||||
reg16 = __DSPRegs[27];
|
||||
__DSPRegs[27] = reg16 & ~0x8000;
|
||||
waitUntil(__DSPRegs[5], 0x400);
|
||||
waitUntil(__DSPRegs[5], 0x200);
|
||||
__DSPRegs[5] = 0x8ac;
|
||||
__DSPRegs[0] = 0;
|
||||
|
||||
while (((__DSPRegs[2] << 16) | __DSPRegs[3]) & 0x80000000);
|
||||
|
||||
start_tick = OSGetTick();
|
||||
while ((s32)(OSGetTick() - start_tick) < 0x2c);
|
||||
|
||||
reg16 = __DSPRegs[5];
|
||||
__DSPRegs[5] = reg16 | 1;
|
||||
waitUntil(__DSPRegs[5], 0x001);
|
||||
|
||||
#undef waitUntil
|
||||
}
|
||||
Reference in New Issue
Block a user