X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2Fcd%2FPico.c;h=0847f291db5b42f4b444e0a4a81edecb2bebfda9;hb=017512f2823405ea2d02fa04b4c0754d7c4cba65;hp=92dfe8522bb3e360c1d722c1b152ecda0dfc0818;hpb=3ec29f016cdeb3100dbb433dd9041e81542765bd;p=picodrive.git diff --git a/Pico/cd/Pico.c b/Pico/cd/Pico.c index 92dfe85..0847f29 100644 --- a/Pico/cd/Pico.c +++ b/Pico/cd/Pico.c @@ -79,6 +79,7 @@ PICO_INTERNAL int PicoResetMCD(int hard) SRam.data = NULL; if (PicoOpt&0x8000) SRam.data = calloc(1, 0x12000); + SRam.start = SRam.end = 0; // unused return 0; } @@ -88,7 +89,9 @@ static __inline void SekRunM68k(int cyc) int cyc_do; SekCycleAim+=cyc; if ((cyc_do=SekCycleAim-SekCycleCnt) <= 0) return; -#if defined(EMU_C68K) +#if defined(EMU_CORE_DEBUG) + SekCycleCnt+=CM_compareRun(cyc_do, 0); +#elif defined(EMU_C68K) PicoCpuCM68k.cycles=cyc_do; CycloneRun(&PicoCpuCM68k); SekCycleCnt+=cyc_do-PicoCpuCM68k.cycles; @@ -97,7 +100,7 @@ static __inline void SekRunM68k(int cyc) SekCycleCnt+=m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext=&PicoCpuFM68k; - SekCycleCnt+=fm68k_emulate(cyc_do); + SekCycleCnt+=fm68k_emulate(cyc_do, 0); #endif } @@ -106,7 +109,9 @@ static __inline void SekRunS68k(int cyc) int cyc_do; SekCycleAimS68k+=cyc; if ((cyc_do=SekCycleAimS68k-SekCycleCntS68k) <= 0) return; -#if defined(EMU_C68K) +#if defined(EMU_CORE_DEBUG) + SekCycleCntS68k+=CM_compareRun(cyc_do, 1); +#elif defined(EMU_C68K) PicoCpuCS68k.cycles=cyc_do; CycloneRun(&PicoCpuCS68k); SekCycleCntS68k+=cyc_do-PicoCpuCS68k.cycles; @@ -115,15 +120,22 @@ static __inline void SekRunS68k(int cyc) SekCycleCntS68k+=m68k_execute(cyc_do); #elif defined(EMU_F68K) g_m68kcontext=&PicoCpuFS68k; - SekCycleCntS68k+=fm68k_emulate(cyc_do); + SekCycleCntS68k+=fm68k_emulate(cyc_do, 0); #endif } #define PS_STEP_M68K ((488<<16)/20) // ~24 //#define PS_STEP_S68K 13 -#ifdef _ASM_CD_PICO_C -void SekRunPS(int cyc_m68k, int cyc_s68k); +#if defined(_ASM_CD_PICO_C) +extern void SekRunPS(int cyc_m68k, int cyc_s68k); +#elif defined(EMU_F68K) +static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) +{ + SekCycleAim+=cyc_m68k; + SekCycleAimS68k+=cyc_s68k; + fm68k_emulate(0, 1); +} #else static __inline void SekRunPS(int cyc_m68k, int cyc_s68k) { @@ -148,7 +160,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); + SekCycleCnt += fm68k_emulate(cyc_do, 0); #endif } if ((cyc_do = SekCycleAimS68k-SekCycleCntS68k-cycn_s68k) > 0) { @@ -161,7 +173,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); + SekCycleCntS68k += fm68k_emulate(cyc_do, 0); #endif } }