X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2Fcd%2FPico.c;h=0577d3e7b865b6b7c15edc5a58d655dffc9354c0;hb=c060a9ab9c428e1ed9c4159b56529a2a36031e44;hp=9d028b495c329fae770a1a4439d78cc171ac8f63;hpb=d6114368e1ee2cc4e6f0eb2785a1fce626987897;p=picodrive.git diff --git a/Pico/cd/Pico.c b/Pico/cd/Pico.c index 9d028b4..0577d3e 100644 --- a/Pico/cd/Pico.c +++ b/Pico/cd/Pico.c @@ -2,7 +2,7 @@ #include "../PicoInt.h" - +#include "../sound/ym2612.h" extern unsigned char formatted_bram[4*0x10]; extern unsigned int s68k_poll_adclk; @@ -31,12 +31,10 @@ int (*PicoMCDcloseTray)(void) = NULL; } -PICO_INTERNAL int PicoInitMCD(void) +PICO_INTERNAL void PicoInitMCD(void) { SekInitS68k(); Init_CD_Driver(); - - return 0; } @@ -48,16 +46,18 @@ PICO_INTERNAL void PicoExitMCD(void) //dump_ram(Pico.ram, "ram.bin"); } -PICO_INTERNAL int PicoResetMCD(int hard) +PICO_INTERNAL void PicoPowerMCD(void) +{ + int fmt_size = sizeof(formatted_bram); + memset(Pico_mcd->prg_ram, 0, sizeof(Pico_mcd->prg_ram)); + memset(Pico_mcd->word_ram2M, 0, sizeof(Pico_mcd->word_ram2M)); + memset(Pico_mcd->pcm_ram, 0, sizeof(Pico_mcd->pcm_ram)); + memset(Pico_mcd->bram, 0, sizeof(Pico_mcd->bram)); + memcpy(Pico_mcd->bram + sizeof(Pico_mcd->bram) - fmt_size, formatted_bram, fmt_size); +} + +PICO_INTERNAL int PicoResetMCD(void) { - if (hard) { - int fmt_size = sizeof(formatted_bram); - memset(Pico_mcd->prg_ram, 0, sizeof(Pico_mcd->prg_ram)); - memset(Pico_mcd->word_ram2M, 0, sizeof(Pico_mcd->word_ram2M)); - memset(Pico_mcd->pcm_ram, 0, sizeof(Pico_mcd->pcm_ram)); - memset(Pico_mcd->bram, 0, sizeof(Pico_mcd->bram)); - memcpy(Pico_mcd->bram + sizeof(Pico_mcd->bram) - fmt_size, formatted_bram, fmt_size); - } memset(Pico_mcd->s68k_regs, 0, sizeof(Pico_mcd->s68k_regs)); memset(&Pico_mcd->pcm, 0, sizeof(Pico_mcd->pcm)); memset(&Pico_mcd->m, 0, sizeof(Pico_mcd->m)); @@ -75,7 +75,7 @@ PICO_INTERNAL int PicoResetMCD(int hard) #endif // use SRam.data for RAM cart - if (PicoOpt&0x8000) { + if (PicoOpt&POPT_EN_MCD_RAMCART) { if (SRam.data == NULL) SRam.data = calloc(1, 0x12000); } @@ -104,7 +104,7 @@ static __inline void SekRunM68k(int cyc) SekCycleCnt+=m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext=&PicoCpuFM68k; - SekCycleCnt+=fm68k_emulate(cyc_do, 0); + SekCycleCnt+=fm68k_emulate(cyc_do, 0, 0); #endif } @@ -124,7 +124,7 @@ static __inline void SekRunS68k(int cyc) SekCycleCntS68k+=m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext=&PicoCpuFS68k; - SekCycleCntS68k+=fm68k_emulate(cyc_do, 0); + SekCycleCntS68k+=fm68k_emulate(cyc_do, 0, 0); #endif } @@ -138,7 +138,7 @@ static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) { SekCycleAim+=cyc_m68k; SekCycleAimS68k+=cyc_s68k; - fm68k_emulate(0, 1); + fm68k_emulate(0, 1, 0); } #else static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) @@ -164,7 +164,7 @@ static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) SekCycleCnt += m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext = &PicoCpuFM68k; - SekCycleCnt += fm68k_emulate(cyc_do, 0); + SekCycleCnt += fm68k_emulate(cyc_do, 0, 0); #endif } if ((cyc_do = SekCycleAimS68k-SekCycleCntS68k-cycn_s68k) > 0) { @@ -177,7 +177,7 @@ static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) SekCycleCntS68k += m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext = &PicoCpuFS68k; - SekCycleCntS68k += fm68k_emulate(cyc_do, 0); + SekCycleCntS68k += fm68k_emulate(cyc_do, 0, 0); #endif } } @@ -262,14 +262,12 @@ static __inline void getSamples(int y) #include "../PicoFrameHints.c" -PICO_INTERNAL int PicoFrameMCD(void) +PICO_INTERNAL void PicoFrameMCD(void) { - if(!(PicoOpt&0x10)) + if (!(PicoOpt&POPT_ALT_RENDERER)) PicoFrameStart(); PicoFrameHints(); - - return 0; }