aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorValerio Proietti2019-06-30 10:24:43 +0200
committerValerio Proietti2019-06-30 10:24:43 +0200
commitd3c41e5eabb5e49e457ae0413982c4c25350c170 (patch)
treeb55dc85e2506c89e4afd0f02130d826783402468
parenta3c2efcd073d986f17a4a81617acaf68e07447e1 (diff)
downloadpcsx_rearmed-d3c41e5eabb5e49e457ae0413982c4c25350c170.tar.gz
pcsx_rearmed-d3c41e5eabb5e49e457ae0413982c4c25350c170.tar.bz2
pcsx_rearmed-d3c41e5eabb5e49e457ae0413982c4c25350c170.zip
report correct geometry and update geometry when needed.
-rw-r--r--frontend/libretro.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/frontend/libretro.c b/frontend/libretro.c
index 3689297..92cc9e6 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;