X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=gp2x%2Femu.c;h=32450758ee014cc713586453f6d7e50fa6805280;hb=f71361b521c9c64351ea99ed97627a606c642008;hp=acc3881aa31f7aece65f4375d6dd9075d9c53ca3;hpb=dd59a74b2061298e73c13ddf1be7287cca3ebc74;p=libpicofe.git diff --git a/gp2x/emu.c b/gp2x/emu.c index acc3881..3245075 100644 --- a/gp2x/emu.c +++ b/gp2x/emu.c @@ -756,6 +756,9 @@ void pemu_loop_prep(void) { static int gp2x_old_clock = -1, EmuOpt_old = 0, pal_old = 0; static int gp2x_old_gamma = 100; + gp2x_soc_t soc; + + soc = soc_detect(); if ((EmuOpt_old ^ currentConfig.EmuOpt) & EOPT_RAM_TIMINGS) { if (currentConfig.EmuOpt & EOPT_RAM_TIMINGS) @@ -773,16 +776,16 @@ void pemu_loop_prep(void) printf(" done\n"); } - if (gp2x_old_gamma != currentConfig.gamma || (EmuOpt_old&0x1000) != (currentConfig.EmuOpt&0x1000)) { - set_lcd_gamma(currentConfig.gamma, !!(currentConfig.EmuOpt&0x1000)); + if (gp2x_old_gamma != currentConfig.gamma || ((EmuOpt_old ^ currentConfig.EmuOpt) & EOPT_A_SN_GAMMA)) { + set_lcd_gamma(currentConfig.gamma, !!(currentConfig.EmuOpt & EOPT_A_SN_GAMMA)); gp2x_old_gamma = currentConfig.gamma; printf("updated gamma to %i, A_SN's curve: %i\n", currentConfig.gamma, !!(currentConfig.EmuOpt&0x1000)); } - if (((EmuOpt_old ^ currentConfig.EmuOpt) & EOPT_PSYNC) || Pico.m.pal != pal_old) { - if (currentConfig.EmuOpt & EOPT_PSYNC) + if (((EmuOpt_old ^ currentConfig.EmuOpt) & EOPT_VSYNC) || Pico.m.pal != pal_old) { + if ((currentConfig.EmuOpt & EOPT_VSYNC) || soc == SOCID_POLLUX) set_lcd_custom_rate(Pico.m.pal); - else + else if (EmuOpt_old & EOPT_VSYNC) unset_lcd_custom_rate(); }