diff options
author | notaz | 2012-10-23 04:48:41 -0700 |
---|---|---|
committer | notaz | 2012-10-23 04:48:41 -0700 |
commit | 0e53ec55691229fee1cbb7c23b305be6a59431c4 (patch) | |
tree | 29799aaff96d243104b604c9ba7cc78f526c5c18 /frontend/libretro.c | |
parent | af044cbf908762f4e5d66384aa7dffeae58844aa (diff) | |
parent | 9f766dbe7543819bdf44bb326665998af45c102d (diff) | |
download | pcsx_rearmed-0e53ec55691229fee1cbb7c23b305be6a59431c4.tar.gz pcsx_rearmed-0e53ec55691229fee1cbb7c23b305be6a59431c4.tar.bz2 pcsx_rearmed-0e53ec55691229fee1cbb7c23b305be6a59431c4.zip |
Merge pull request #3 from libretro/master
RGB565 support
Diffstat (limited to 'frontend/libretro.c')
-rw-r--r-- | frontend/libretro.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/frontend/libretro.c b/frontend/libretro.c index 9bbea5b..4305aa7 100644 --- a/frontend/libretro.c +++ b/frontend/libretro.c @@ -29,6 +29,7 @@ static void *vout_buf; static int vout_width, vout_height; static int samples_sent, samples_to_send; static int plugins_opened; +static int native_rgb565; /* PCSX ReARMed core calls and stuff */ int in_type1, in_type2; @@ -62,7 +63,8 @@ static void convert(void *buf, size_t bytes) static void *vout_flip(void) { pl_rearmed_cbs.flip_cnt++; - convert(vout_buf, vout_width * vout_height * 2); + if (!native_rgb565) + convert(vout_buf, vout_width * vout_height * 2); video_cb(vout_buf, vout_width, vout_height, vout_width * 2); return vout_buf; @@ -197,6 +199,12 @@ void retro_cheat_set(unsigned index, bool enabled, const char *code) bool retro_load_game(const struct retro_game_info *info) { + enum retro_pixel_format fmt = RETRO_PIXEL_FORMAT_RGB565; + if (environ_cb(RETRO_ENVIRONMENT_SET_PIXEL_FORMAT, &fmt)) { + native_rgb565 = 1; + fprintf(stderr, "RGB565 supported, using it\n"); + } + if (plugins_opened) { ClosePlugins(); plugins_opened = 0; |