X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=psp%2Femu.c;h=b0504191a99b8e0fa6fd4a129e4ac68ba96092ef;hb=5d239ae7a46330845af01f9e5f429e78a099fbd9;hp=d6bc20c92b593609d9fcee3d3034cb708f4c3a43;hpb=6589c840ca686751d15ebb127367af1378dd7de2;p=libpicofe.git diff --git a/psp/emu.c b/psp/emu.c index d6bc20c..b050419 100644 --- a/psp/emu.c +++ b/psp/emu.c @@ -22,6 +22,7 @@ #include "../common/config.h" #include "../common/lprintf.h" #include "../../Pico/PicoInt.h" +#include "../../Pico/cd/cue.h" #define OSD_FPS_X 432 @@ -34,7 +35,7 @@ int sceAudioOutput2GetRestSample(); char romFileName[PATH_MAX]; unsigned char *PicoDraw2FB = (unsigned char *)VRAM_CACHED_STUFF + 8; // +8 to be able to skip border with 1 quadword.. -int engineState = PGS_Menu; +int engineState = PGS_Menu, engineStateSuspend; static unsigned int noticeMsgTime = 0; int reset_timing = 0; // do we need this? @@ -273,7 +274,7 @@ static void do_pal_update(int allow_sh, int allow_as) } else if (allow_as && (rendstatus & PDRAW_ACC_SPRITES)) { - memcpy32((int *)(void *)(localPal+0x80), (void *)localPal, 0x40/2); + memcpy32((int *)dpal+0x80/2, (void *)localPal, 0x40*2/4); } } @@ -295,6 +296,7 @@ static void EmuScanPrepare(void) if (dynamic_palette > 0) dynamic_palette--; + if (Pico.m.dirtyPal) do_pal_update(1, 1); if ((rendstatus & PDRAW_ACC_SPRITES) && !(Pico.video.reg[0xC]&8)) @@ -321,7 +323,7 @@ static int EmuScanSlowEnd(unsigned int num) do_slowmode_lines(num); dynamic_palette = 3; // last for 2 more frames } - do_pal_update(1, 0); + do_pal_update(1, 1); } if (dynamic_palette) { @@ -533,6 +535,11 @@ static void vidResetMode(void) sceGuSync(0,0); } +void emu_platformDebugCat(char *str) +{ + strcat(str, blit_16bit_mode ? "soft clut\n" : "hard clut\n"); +} + /* sound stuff */ #define SOUND_BLOCK_SIZE_NTSC (1470*2) // 1024 // 1152 @@ -1118,15 +1125,31 @@ void emu_HandleResume(void) { if (!(PicoAHW & PAHW_MCD)) return; - // reopen files.. + // reopen first CD track if (Pico_mcd->TOC.Tracks[0].F != NULL) { - lprintf("emu_HandleResume: reopen %s\n", romFileName); + char *fname = romFileName; + int len = strlen(romFileName); + cue_data_t *cue_data = NULL; + + if (len > 4 && strcasecmp(fname + len - 4, ".cue") == 0) + { + cue_data = cue_parse(romFileName); + if (cue_data != NULL) + fname = cue_data->tracks[1].fname; + } + + lprintf("emu_HandleResume: reopen %s\n", fname); pm_close(Pico_mcd->TOC.Tracks[0].F); - Pico_mcd->TOC.Tracks[0].F = pm_open(romFileName); + Pico_mcd->TOC.Tracks[0].F = pm_open(fname); lprintf("reopen %s\n", Pico_mcd->TOC.Tracks[0].F != NULL ? "ok" : "failed"); + + if (cue_data != NULL) cue_destroy(cue_data); } mp3_reopen_file(); + + if (!(Pico_mcd->s68k_regs[0x36] & 1) && (Pico_mcd->scd.Status_CDC & 1)) + cdda_start_play(); }