X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=platform%2Fpsp%2Fmain.c;h=a2e99aa647e8c8c4f8f6696a0c6d0c43bb8b7369;hb=2b02d6e533b114456785f39a356476eb97306fcf;hp=bad56a9a8cfddaf0a3bd2ba865639542f2a14ce7;hpb=8b99ab90aa519639a87c302c9a26fef526febde9;p=picodrive.git diff --git a/platform/psp/main.c b/platform/psp/main.c index bad56a9..a2e99aa 100644 --- a/platform/psp/main.c +++ b/platform/psp/main.c @@ -10,17 +10,14 @@ #include "mp3.h" #include "../common/menu.h" #include "../common/emu.h" +#include "../common/config.h" #include "../common/lprintf.h" -#include "version.h" -#define GPROF 0 -#define GCOV 0 - -#if GPROF +#ifdef GPROF #include #endif -#if GCOV +#ifdef GCOV #include #include @@ -32,11 +29,14 @@ void dummy(void) } #endif -int main() +int pico_main(void) { - lprintf("\nPicoDrive v" VERSION " " __DATE__ " " __TIME__ "\n"); psp_init(); + + emu_prepareDefaultConfig(); emu_ReadConfig(0, 0); + config_readlrom(PicoConfigFile); + emu_Init(); menu_init(); // moved to emu_Loop(), after CPU clock change.. @@ -49,10 +49,10 @@ int main() switch (engineState) { case PGS_Menu: -#if !GPROF +#ifndef GPROF menu_loop(); #else - strcpy(romFileName, currentConfig.lastRomFile); + strcpy(romFileName, lastRomFile); engineState = PGS_ReloadRom; #endif break; @@ -68,12 +68,30 @@ int main() } break; + case PGS_Suspending: + while (engineState == PGS_Suspending) + psp_wait_suspend(); + break; + + case PGS_SuspendWake: + psp_unhandled_suspend = 0; + psp_resume_suspend(); + emu_HandleResume(); + engineState = engineStateSuspend; + break; + case PGS_RestartRun: engineState = PGS_Running; case PGS_Running: + if (psp_unhandled_suspend) { + psp_unhandled_suspend = 0; + psp_resume_suspend(); + emu_HandleResume(); + break; + } emu_Loop(); -#if GPROF +#ifdef GPROF goto endloop; #endif break; @@ -91,10 +109,10 @@ int main() mp3_deinit(); emu_Deinit(); -#if GPROF +#ifdef GPROF gprof_cleanup(); #endif -#if !GCOV +#ifndef GCOV psp_finish(); #endif