X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=gp2x%2Fplat.c;h=aa60412328872e237b8da70d6418d306cd9e8b51;hb=053bef765a5dba9d5a050c0944676e96412e293d;hp=a2b839449d7daad44c099b792d6439f11d1214e3;hpb=e31266dd116b6bea59ce3f2036feeb6725c45a72;p=libpicofe.git diff --git a/gp2x/plat.c b/gp2x/plat.c index a2b8394..aa60412 100644 --- a/gp2x/plat.c +++ b/gp2x/plat.c @@ -1,11 +1,71 @@ +#include +#include #include +#include -#include "gp2x.h" +#include "plat_gp2x.h" +#include "soc.h" +#include "warm.h" #include "../common/plat.h" #include "../common/readpng.h" #include "../common/menu.h" #include "../common/emu.h" +#include "../linux/sndout_oss.h" +#include + +/* GP2X local */ +int default_cpu_clock; +void *gp2x_screens[4]; + +void gp2x_video_changemode(int bpp) +{ + gp2x_video_changemode_ll(bpp); + + gp2x_memset_all_buffers(0, 0, 320*240*2); + gp2x_video_flip(); +} + +static void gp2x_memcpy_buffers(int buffers, void *data, int offset, int len) +{ + char *dst; + if (buffers & (1<<0)) { dst = (char *)gp2x_screens[0] + offset; if (dst != data) memcpy(dst, data, len); } + if (buffers & (1<<1)) { dst = (char *)gp2x_screens[1] + offset; if (dst != data) memcpy(dst, data, len); } + if (buffers & (1<<2)) { dst = (char *)gp2x_screens[2] + offset; if (dst != data) memcpy(dst, data, len); } + if (buffers & (1<<3)) { dst = (char *)gp2x_screens[3] + offset; if (dst != data) memcpy(dst, data, len); } +} + +void gp2x_memcpy_all_buffers(void *data, int offset, int len) +{ + gp2x_memcpy_buffers(0xf, data, offset, len); +} + +void gp2x_memset_all_buffers(int offset, int byte, int len) +{ + memset((char *)gp2x_screens[0] + offset, byte, len); + memset((char *)gp2x_screens[1] + offset, byte, len); + memset((char *)gp2x_screens[2] + offset, byte, len); + memset((char *)gp2x_screens[3] + offset, byte, len); +} + +void gp2x_make_fb_bufferable(int yes) +{ + int ret = 0; + + yes = yes ? 1 : 0; + ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[0], 320*240*2); + ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[1], 320*240*2); + ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[2], 320*240*2); + ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[3], 320*240*2); + + if (ret) + fprintf(stderr, "could not make fb buferable.\n"); + else + printf("made fb buferable.\n"); +} + +/* common */ +char cpu_clk_name[16] = "GP2X CPU clocks"; void plat_video_menu_enter(int is_rom_loaded) { @@ -18,27 +78,131 @@ void plat_video_menu_enter(int is_rom_loaded) } else { + char buff[256]; + // should really only happen once, on startup.. - readpng(g_screen_ptr, "skin/background.png", READPNG_BG); + emu_make_path(buff, "skin/background.png", sizeof(buff)); + if (readpng(g_screen_ptr, buff, READPNG_BG) < 0) + memset(g_screen_ptr, 0, 320*240*2); } - // copy to buffer2 + // copy to buffer2, switch to black gp2x_memcpy_buffers((1<<2), g_screen_ptr, 0, 320*240*2); + /* try to switch nicely avoiding tearing on Wiz */ + gp2x_video_wait_vsync(); + memset(gp2x_screens[0], 0, 320*240*2); + memset(gp2x_screens[1], 0, 320*240*2); + gp2x_video_flip2(); + gp2x_video_wait_vsync(); + gp2x_video_wait_vsync(); + // switch to 16bpp - gp2x_video_changemode2(16); + gp2x_video_changemode_ll(16); gp2x_video_RGB_setscaling(0, 320, 240); - gp2x_video_flip2(); } void plat_video_menu_begin(void) { - gp2x_pd_clone_buffer2(); + memcpy(g_screen_ptr, gp2x_screens[2], 320*240*2); } void plat_video_menu_end(void) { - gp2x_video_flush_cache(); + // FIXME + // gp2x_video_flush_cache(); gp2x_video_flip2(); } +void plat_validate_config(void) +{ + gp2x_soc_t soc; + + soc = soc_detect(); + if (soc != SOCID_MMSP2) + PicoOpt &= ~POPT_EXT_FM; + if (soc != SOCID_POLLUX) + currentConfig.EmuOpt &= ~EOPT_WIZ_TEAR_FIX; + + if (currentConfig.gamma < 10 || currentConfig.gamma > 300) + currentConfig.gamma = 100; + + if (currentConfig.CPUclock < 10 || currentConfig.CPUclock > 1024) + currentConfig.CPUclock = default_cpu_clock; +} + +void plat_early_init(void) +{ + gp2x_soc_t soc; + + soc = soc_detect(); + switch (soc) + { + case SOCID_MMSP2: + default_cpu_clock = 200; + break; + case SOCID_POLLUX: + strcpy(cpu_clk_name, "Wiz CPU clock"); + default_cpu_clock = 533; + break; + default: + fprintf(stderr, "could not recognize SoC, bailing out.\n"); + exit(1); + } +} + +void plat_init(void) +{ + gp2x_soc_t soc; + + soc = soc_detect(); + switch (soc) + { + case SOCID_MMSP2: + mmsp2_init(); + break; + case SOCID_POLLUX: + pollux_init(); + menu_plat_setup(1); + break; + default: + break; + } + + warm_init(); + + gp2x_memset_all_buffers(0, 0, 320*240*2); + + // snd + sndout_oss_init(); +} + +void plat_finish(void) +{ + gp2x_soc_t soc; + + warm_finish(); + + soc = soc_detect(); + switch (soc) + { + case SOCID_MMSP2: + mmsp2_finish(); + break; + case SOCID_POLLUX: + pollux_finish(); + break; + } + + sndout_oss_exit(); +} + +void lprintf(const char *fmt, ...) +{ + va_list vl; + + va_start(vl, fmt); + vprintf(fmt, vl); + va_end(vl); +} +