From: Valerio Proietti Date: Sun, 30 Jun 2019 08:24:43 +0000 (+0200) Subject: report correct geometry and update geometry when needed. X-Git-Tag: r24l~720^2~1 X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d3c41e5eabb5e49e457ae0413982c4c25350c170;p=pcsx_rearmed.git report correct geometry and update geometry when needed. --- diff --git a/frontend/libretro.c b/frontend/libretro.c index 3689297f..92cc9e65 100644 --- a/frontend/libretro.c +++ b/frontend/libretro.c @@ -180,6 +180,12 @@ static void vout_set_mode(int w, int h, int raw_w, int raw_h, int bpp) vout_width = w; vout_height = h; + SysPrintf("setting mode width: %d height %d\n", vout_width, vout_height); + + struct retro_system_av_info info; + retro_get_system_av_info(&info); + environ_cb(RETRO_ENVIRONMENT_SET_GEOMETRY, &info.geometry); + set_vout_fb(); } @@ -714,11 +720,15 @@ void retro_get_system_info(struct retro_system_info *info) void retro_get_system_av_info(struct retro_system_av_info *info) { + + unsigned geom_height = vout_height > 0 ? vout_height : 240; + unsigned geom_width = vout_width > 0 ? vout_width : 320; + memset(info, 0, sizeof(*info)); info->timing.fps = is_pal_mode ? 50 : 60; info->timing.sample_rate = 44100; - info->geometry.base_width = 320; - info->geometry.base_height = 240; + info->geometry.base_width = geom_width; + info->geometry.base_height = geom_height; info->geometry.max_width = VOUT_MAX_WIDTH; info->geometry.max_height = VOUT_MAX_HEIGHT; info->geometry.aspect_ratio = 4.0 / 3.0;