53 lines
1.4 KiB
C++
53 lines
1.4 KiB
C++
#include <stdint.h>
|
|
|
|
#include "smpc.h"
|
|
#include "scsp.h"
|
|
|
|
#include "../common/copy.hpp"
|
|
|
|
extern void * _m68k_start __asm("_binary_m68k_slot_bin_start");
|
|
extern void * _m68k_size __asm("_binary_m68k_slot_bin_size");
|
|
|
|
void main()
|
|
{
|
|
/* SEGA SATURN TECHNICAL BULLETIN # 51
|
|
|
|
The document suggests that Sound RAM is (somewhat) preserved
|
|
during SNDOFF.
|
|
*/
|
|
|
|
while ((smpc.reg.SF & 1) != 0);
|
|
smpc.reg.SF = 1;
|
|
smpc.reg.COMREG = COMREG__SNDOFF;
|
|
while (smpc.reg.OREG[31].val != OREG31__SNDOFF);
|
|
|
|
scsp.reg.ctrl.MIXER = MIXER__MEM4MB;
|
|
|
|
/*
|
|
The Saturn BIOS does not (un)initialize the DSP. Without zeroizing the DSP
|
|
program, the SCSP DSP appears to have a program that continuously writes to
|
|
0x30000 through 0x3ffff in sound RAM, which has the effect of destroying any
|
|
samples stored there.
|
|
*/
|
|
reg32 * dsp_steps = reinterpret_cast<reg32*>(&(scsp.reg.dsp.STEP[0].MPRO[0]));
|
|
fill<reg32>(dsp_steps, 0, (sizeof (scsp.reg.dsp.STEP)));
|
|
|
|
uint32_t * m68k_main_start = reinterpret_cast<uint32_t*>(&_m68k_start);
|
|
uint32_t m68k_main_size = reinterpret_cast<uint32_t>(&_m68k_size);
|
|
copy<uint32_t>(&scsp.ram.u32[0], m68k_main_start, m68k_main_size);
|
|
|
|
while ((smpc.reg.SF & 1) != 0);
|
|
smpc.reg.SF = 1;
|
|
smpc.reg.COMREG = COMREG__SNDON;
|
|
while (smpc.reg.OREG[31].val != OREG31__SNDON);
|
|
|
|
// do nothing while the sound CPU manipulates the SCSP
|
|
}
|
|
|
|
extern "C"
|
|
void start(void)
|
|
{
|
|
main();
|
|
while (1);
|
|
}
|