X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2Fcd%2FPico.c;h=9d028b495c329fae770a1a4439d78cc171ac8f63;hb=1b13dae0c45a068382ce2422b1d407ff47374039;hp=def0a418392384f4c1ffc3796d295574b36e9ee2;hpb=9d917eea21607c7c239d4b0cd850d660c0c8e4c5;p=picodrive.git diff --git a/Pico/cd/Pico.c b/Pico/cd/Pico.c index def0a41..9d028b4 100644 --- a/Pico/cd/Pico.c +++ b/Pico/cd/Pico.c @@ -75,10 +75,15 @@ PICO_INTERNAL int PicoResetMCD(int hard) #endif // use SRam.data for RAM cart - if (SRam.data) free(SRam.data); - SRam.data = NULL; - if (PicoOpt&0x8000) - SRam.data = calloc(1, 0x12000); + if (PicoOpt&0x8000) { + if (SRam.data == NULL) + SRam.data = calloc(1, 0x12000); + } + else if (SRam.data != NULL) { + free(SRam.data); + SRam.data = NULL; + } + SRam.start = SRam.end = 0; // unused return 0; } @@ -87,8 +92,10 @@ static __inline void SekRunM68k(int cyc) { int cyc_do; SekCycleAim+=cyc; - if((cyc_do=SekCycleAim-SekCycleCnt) < 0) return; -#if defined(EMU_C68K) + if ((cyc_do=SekCycleAim-SekCycleCnt) <= 0) return; +#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 +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); + SekCycleCnt+=fm68k_emulate(cyc_do, 0); #endif } @@ -105,8 +112,10 @@ static __inline void SekRunS68k(int cyc) { int cyc_do; SekCycleAimS68k+=cyc; - if((cyc_do=SekCycleAimS68k-SekCycleCntS68k) < 0) return; -#if defined(EMU_C68K) + if ((cyc_do=SekCycleAimS68k-SekCycleCntS68k) <= 0) return; +#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 +124,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 +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); + SekCycleCnt += fm68k_emulate(cyc_do, 0); #endif } if ((cyc_do = SekCycleAimS68k-SekCycleCntS68k-cycn_s68k) > 0) { @@ -161,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); + SekCycleCntS68k += fm68k_emulate(cyc_do, 0); #endif } }