aboutsummaryrefslogtreecommitdiff
path: root/frontend/libretro.c
diff options
context:
space:
mode:
authorTwinaphex2014-11-29 15:45:02 +0100
committerTwinaphex2014-11-29 15:45:02 +0100
commitf563a4bfd576197a8e907f30fb77cd6db8e24f00 (patch)
tree11f25b84f46982367069df1f691e1171ba5f4de9 /frontend/libretro.c
parentde2a99184b5e478a39a2cb82872d8d5c4af0f3f6 (diff)
parent8d24cb85c2a67040aff70716f317fd6d37777dd5 (diff)
downloadpcsx_rearmed-f563a4bfd576197a8e907f30fb77cd6db8e24f00.tar.gz
pcsx_rearmed-f563a4bfd576197a8e907f30fb77cd6db8e24f00.tar.bz2
pcsx_rearmed-f563a4bfd576197a8e907f30fb77cd6db8e24f00.zip
Merge pull request #8 from ksv1986/master
libretro: Add rumble support
Diffstat (limited to 'frontend/libretro.c')
-rw-r--r--frontend/libretro.c35
1 files changed, 25 insertions, 10 deletions
diff --git a/frontend/libretro.c b/frontend/libretro.c
index e5496cb..3b8975f 100644
--- a/frontend/libretro.c
+++ b/frontend/libretro.c
@@ -32,6 +32,7 @@ static retro_input_poll_t input_poll_cb;
static retro_input_state_t input_state_cb;
static retro_environment_t environ_cb;
static retro_audio_sample_batch_t audio_batch_cb;
+static struct retro_rumble_interface rumble;
static void *vout_buf;
static int vout_width, vout_height;
@@ -51,7 +52,7 @@ extern char McdDisable[2];
int in_type1, in_type2;
int in_a1[2] = { 127, 127 }, in_a2[2] = { 127, 127 };
int in_keystate;
-int in_enable_vibration;
+int in_enable_vibration = 1;
/* PSX max resolution is 640x512, but with enhancement it's 1024x512 */
#define VOUT_MAX_WIDTH 1024
@@ -196,8 +197,10 @@ void pl_timing_prepare(int is_pal)
is_pal_mode = is_pal;
}
-void plat_trigger_vibrate(int is_strong)
+void plat_trigger_vibrate(int pad, uint32_t low, uint32_t high)
{
+ rumble.set_rumble_state(pad, RETRO_RUMBLE_STRONG, high << 8);
+ rumble.set_rumble_state(pad, RETRO_RUMBLE_WEAK, low ? 0xffff : 0x0);
}
void pl_update_gun(int *xn, int *yn, int *xres, int *yres, int *in)
@@ -241,11 +244,12 @@ void out_register_libretro(struct out_driver *drv)
void retro_set_environment(retro_environment_t cb)
{
static const struct retro_variable vars[] = {
- { "frameskip", "Frameskip; 0|1|2|3" },
- { "region", "Region; Auto|NTSC|PAL" },
- { "pad1type", "Pad 1 Type; standard|analog" },
+ { "pcsx_rearmed_frameskip", "Frameskip; 0|1|2|3" },
+ { "pcsx_rearmed_region", "Region; Auto|NTSC|PAL" },
+ { "pcsx_rearmed_pad1type", "Pad 1 Type; standard|analog" },
+ { "pcsx_rearmed_pad2type", "Pad 2 Type; standard|analog" },
#ifndef DRC_DISABLE
- { "rearmed_drc", "Dynamic recompiler; enabled|disabled" },
+ { "pcsx_rearmed_drc", "Dynamic recompiler; enabled|disabled" },
#endif
#if defined(__ARM_NEON__) || defined(NEON_PC)
{ "neon_interlace_enable", "Enable interlacing mode(s); disabled|enabled" },
@@ -773,13 +777,13 @@ static void update_variables(bool in_flight)
struct retro_variable var;
var.value = NULL;
- var.key = "frameskip";
+ var.key = "pcsx_rearmed_frameskip";
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) || var.value)
pl_rearmed_cbs.frameskip = atoi(var.value);
var.value = NULL;
- var.key = "region";
+ var.key = "pcsx_rearmed_region";
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) || var.value)
{
@@ -793,7 +797,7 @@ static void update_variables(bool in_flight)
}
var.value = NULL;
- var.key = "pad1type";
+ var.key = "pcsx_rearmed_pad1type";
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) || var.value)
{
@@ -802,6 +806,16 @@ static void update_variables(bool in_flight)
in_type1 = PSE_PAD_TYPE_ANALOGPAD;
}
+ var.value = NULL;
+ var.key = "pcsx_rearmed_pad2type";
+
+ if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) || var.value)
+ {
+ in_type2 = PSE_PAD_TYPE_STANDARD;
+ if (strcmp(var.value, "analog") == 0)
+ in_type2 = PSE_PAD_TYPE_ANALOGPAD;
+ }
+
#if defined(__ARM_NEON__) || defined(NEON_PC)
var.value = "NULL";
var.key = "neon_interlace_enable";
@@ -850,7 +864,7 @@ static void update_variables(bool in_flight)
#ifndef DRC_DISABLE
var.value = NULL;
- var.key = "rearmed_drc";
+ var.key = "pcsx_rearmed_drc";
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) || var.value)
{
@@ -1034,6 +1048,7 @@ void retro_init(void)
environ_cb(RETRO_ENVIRONMENT_GET_CAN_DUPE, &vout_can_dupe);
environ_cb(RETRO_ENVIRONMENT_SET_DISK_CONTROL_INTERFACE, &disk_control);
+ environ_cb(RETRO_ENVIRONMENT_GET_RUMBLE_INTERFACE, &rumble);
/* Set how much slower PSX CPU runs * 100 (so that 200 is 2 times)
* we have to do this because cache misses and some IO penalties