X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=inline;f=platform%2Fpsp%2Fpsp.c;h=e740f2158a48966ca9595feb98fedddc71982bb1;hb=70357ce52578dee0dd3b3663902cf872c3d34258;hp=4bc1020b96e769dbabbd9af0e616068c567b9be8;hpb=1820b5a7a18fc8c37dddb2ab88159e513ceb3b16;p=picodrive.git diff --git a/platform/psp/psp.c b/platform/psp/psp.c index 4bc1020..e740f21 100644 --- a/platform/psp/psp.c +++ b/platform/psp/psp.c @@ -1,5 +1,11 @@ +#include +#include +#include + #include +#include #include +#include #include #include "psp.h" @@ -10,6 +16,7 @@ PSP_MODULE_INFO("PicoDrive", 0, 1, 34); void *psp_screen = PSP_VRAM_BASE0; static int current_screen = 0; /* front bufer */ +static SceUID logfd = -1; /* Exit callback */ static int exit_callback(int arg1, int arg2, void *common) @@ -67,11 +74,18 @@ void psp_finish(void) sceKernelExitGame(); } -void psp_video_flip(void) +void psp_video_flip(int wait_vsync) { - sceDisplaySetFrameBuf(psp_screen, 512, PSP_DISPLAY_PIXEL_FORMAT_565, PSP_DISPLAY_SETBUF_NEXTFRAME); + if (wait_vsync) sceDisplayWaitVblankStart(); + sceDisplaySetFrameBuf(psp_screen, 512, PSP_DISPLAY_PIXEL_FORMAT_565, + wait_vsync ? PSP_DISPLAY_SETBUF_IMMEDIATE : PSP_DISPLAY_SETBUF_NEXTFRAME); current_screen ^= 1; - psp_screen = current_screen ? PSP_VRAM_BASE1 : PSP_VRAM_BASE0; + psp_screen = current_screen ? PSP_VRAM_BASE0 : PSP_VRAM_BASE1; +} + +void *psp_video_get_active_fb(void) +{ + return current_screen ? PSP_VRAM_BASE1 : PSP_VRAM_BASE0; } void psp_video_switch_to_single(void) @@ -86,11 +100,52 @@ void psp_msleep(int ms) sceKernelDelayThread(ms * 1000); } -unsigned int psp_pad_read(void) +unsigned int psp_pad_read(int blocking) { SceCtrlData pad; - sceCtrlReadBufferPositive(&pad, 1); + if (blocking) + sceCtrlReadBufferPositive(&pad, 1); + else sceCtrlPeekBufferPositive(&pad, 1); return pad.Buttons; } +int psp_get_cpu_clock(void) +{ + return scePowerGetCpuClockFrequencyInt(); +} + +int psp_set_cpu_clock(int clock) +{ + int ret = scePowerSetClockFrequency(clock, clock, clock/2); + if (ret != 0) lprintf("failed to set clock: %i\n", ret); + + return ret; +} + +/* alt logging */ +#define LOG_FILE "log.log" + +void lprintf_f(const char *fmt, ...) +{ + va_list vl; + char buff[256]; + + if (logfd < 0) + { + logfd = sceIoOpen(LOG_FILE, PSP_O_WRONLY|PSP_O_APPEND, 0777); + if (logfd < 0) + return; + } + + va_start(vl, fmt); + vsnprintf(buff, sizeof(buff), fmt, vl); + va_end(vl); + + sceIoWrite(logfd, buff, strlen(buff)); +//sceKernelDelayThread(200 * 1000); +sceIoClose(logfd); +logfd = -1; +} + +