2012-04-21 21:13:50 +00:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2013-01-01 00:37:37 +00:00
|
|
|
* Copyright (C) 2010-2013 - Hans-Kristian Arntzen
|
|
|
|
* Copyright (C) 2011-2013 - Daniel De Matteis
|
2012-07-26 21:07:47 +00:00
|
|
|
* Copyright (C) 2012 - Michael Lelli
|
2011-12-14 12:20:22 +00:00
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
2011-12-14 12:20:22 +00:00
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
2011-12-14 12:20:22 +00:00
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
2012-04-21 21:31:57 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
2011-12-14 12:20:22 +00:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <gccore.h>
|
|
|
|
#include <ogc/pad.h>
|
2012-04-11 02:25:55 +00:00
|
|
|
#ifdef HW_RVL
|
2012-01-03 11:11:02 +00:00
|
|
|
#include <wiiuse/wpad.h>
|
2012-04-11 02:25:55 +00:00
|
|
|
#endif
|
2012-01-03 11:11:02 +00:00
|
|
|
#include <string.h>
|
2012-07-26 05:28:57 +00:00
|
|
|
#include <math.h>
|
2011-12-14 12:20:22 +00:00
|
|
|
|
2012-07-26 05:28:57 +00:00
|
|
|
#ifndef M_PI
|
|
|
|
#define M_PI 3.14159265358979323846264338327
|
|
|
|
#endif
|
|
|
|
|
2012-07-26 21:11:52 +00:00
|
|
|
#include "gx_input.h"
|
2011-12-14 12:20:22 +00:00
|
|
|
#include "../driver.h"
|
2012-04-09 23:00:25 +00:00
|
|
|
#include "../libretro.h"
|
2011-12-14 12:20:22 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
#define GC_JOYSTICK_THRESHOLD (48 * 256)
|
|
|
|
#define WII_JOYSTICK_THRESHOLD (40 * 256)
|
2012-04-11 02:22:41 +00:00
|
|
|
|
2013-03-16 16:51:45 +00:00
|
|
|
#define MAX_PADS 4
|
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
typedef struct gx_input
|
|
|
|
{
|
|
|
|
uint32_t pad_connect[MAX_PADS];
|
|
|
|
uint32_t pad_type[MAX_PADS];
|
|
|
|
uint32_t pad_detect_pending[MAX_PADS];
|
|
|
|
uint64_t pad_state[MAX_PADS];
|
|
|
|
int16_t analog_state[MAX_PADS][2][2];
|
|
|
|
} gx_input_t;
|
2012-04-11 02:22:41 +00:00
|
|
|
|
2012-07-25 17:35:21 +00:00
|
|
|
const struct platform_bind platform_keys[] = {
|
2012-08-06 20:00:35 +00:00
|
|
|
{ GX_GC_A, "GC A button" },
|
|
|
|
{ GX_GC_B, "GC B button" },
|
|
|
|
{ GX_GC_X, "GC X button" },
|
|
|
|
{ GX_GC_Y, "GC Y button" },
|
|
|
|
{ GX_GC_UP, "GC D-Pad Up" },
|
|
|
|
{ GX_GC_DOWN, "GC D-Pad Down" },
|
|
|
|
{ GX_GC_LEFT, "GC D-Pad Left" },
|
|
|
|
{ GX_GC_RIGHT, "GC D-Pad Right" },
|
|
|
|
{ GX_GC_Z_TRIGGER, "GC Z Trigger" },
|
|
|
|
{ GX_GC_START, "GC Start button" },
|
|
|
|
{ GX_GC_L_TRIGGER, "GC Left Trigger" },
|
|
|
|
{ GX_GC_R_TRIGGER, "GC Right Trigger" },
|
2012-07-26 07:20:28 +00:00
|
|
|
|
2012-07-25 17:35:21 +00:00
|
|
|
#ifdef HW_RVL
|
2012-07-26 07:20:28 +00:00
|
|
|
// CLASSIC CONTROLLER
|
2012-08-06 20:00:35 +00:00
|
|
|
{ GX_CLASSIC_A, "Classic A button" },
|
|
|
|
{ GX_CLASSIC_B, "Classic B button" },
|
|
|
|
{ GX_CLASSIC_X, "Classic X button" },
|
|
|
|
{ GX_CLASSIC_Y, "Classic Y button" },
|
|
|
|
{ GX_CLASSIC_UP, "Classic D-Pad Up" },
|
|
|
|
{ GX_CLASSIC_DOWN, "Classic D-Pad Down" },
|
|
|
|
{ GX_CLASSIC_LEFT, "Classic D-Pad Left" },
|
|
|
|
{ GX_CLASSIC_RIGHT, "Classic D-Pad Right" },
|
|
|
|
{ GX_CLASSIC_PLUS, "Classic Plus button" },
|
|
|
|
{ GX_CLASSIC_MINUS, "Classic Minus button" },
|
|
|
|
{ GX_CLASSIC_HOME, "Classic Home button" },
|
|
|
|
{ GX_CLASSIC_L_TRIGGER, "Classic L Trigger" },
|
|
|
|
{ GX_CLASSIC_R_TRIGGER, "Classic R Trigger" },
|
|
|
|
{ GX_CLASSIC_ZL_TRIGGER, "Classic ZL Trigger" },
|
|
|
|
{ GX_CLASSIC_ZR_TRIGGER, "Classic ZR Trigger" },
|
2012-07-26 07:20:28 +00:00
|
|
|
|
|
|
|
// WIIMOTE (PLUS OPTIONAL NUNCHUK)
|
2012-08-06 20:00:35 +00:00
|
|
|
{ GX_WIIMOTE_A, "Wiimote A button" },
|
|
|
|
{ GX_WIIMOTE_B, "Wiimote B button" },
|
|
|
|
{ GX_WIIMOTE_1, "Wiimote 1 button" },
|
|
|
|
{ GX_WIIMOTE_2, "Wiimote 2 button" },
|
|
|
|
{ GX_WIIMOTE_UP, "Wiimote D-Pad Up" },
|
|
|
|
{ GX_WIIMOTE_DOWN, "Wiimote D-Pad Down" },
|
|
|
|
{ GX_WIIMOTE_LEFT, "Wiimote D-Pad Left" },
|
|
|
|
{ GX_WIIMOTE_RIGHT, "Wiimote D-Pad Right" },
|
|
|
|
{ GX_WIIMOTE_PLUS, "Wiimote Plus button" },
|
|
|
|
{ GX_WIIMOTE_MINUS, "Wiimote Minus button" },
|
|
|
|
{ GX_WIIMOTE_HOME, "Wiimote Home button" },
|
|
|
|
{ GX_NUNCHUK_Z, "Nunchuk Z button" },
|
|
|
|
{ GX_NUNCHUK_C, "Nunchuk C button" },
|
|
|
|
{ GX_NUNCHUK_LEFT, "Nunchuk Stick Left" },
|
|
|
|
{ GX_NUNCHUK_RIGHT, "Nunchuk Stick Right" },
|
|
|
|
{ GX_NUNCHUK_UP, "Nunchuk Stick Up" },
|
|
|
|
{ GX_NUNCHUK_DOWN, "Nunchuk Stick Down" },
|
2012-07-25 17:35:21 +00:00
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
2012-08-29 02:58:21 +00:00
|
|
|
static bool g_menu;
|
2013-05-21 22:29:48 +00:00
|
|
|
|
|
|
|
#ifdef HW_RVL
|
2011-12-14 12:20:22 +00:00
|
|
|
static bool g_quit;
|
2013-05-21 22:29:48 +00:00
|
|
|
#endif
|
2011-12-14 12:20:22 +00:00
|
|
|
|
2012-08-09 01:54:27 +00:00
|
|
|
static int16_t gx_input_state(void *data, const struct retro_keybind **binds,
|
2012-04-09 23:00:25 +00:00
|
|
|
unsigned port, unsigned device,
|
2011-12-14 12:20:22 +00:00
|
|
|
unsigned index, unsigned id)
|
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
gx_input_t *gx = (gx_input_t*)data;
|
2011-12-14 12:20:22 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
if (port >= MAX_PADS)
|
2012-07-26 05:28:57 +00:00
|
|
|
return 0;
|
2011-12-14 12:20:22 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
switch (device)
|
|
|
|
{
|
|
|
|
case RETRO_DEVICE_JOYPAD:
|
2013-11-01 15:33:32 +00:00
|
|
|
return (binds[port][id].joykey & gx->pad_state[port]) ? 1 : 0;
|
2013-07-04 18:52:53 +00:00
|
|
|
case RETRO_DEVICE_ANALOG:
|
2013-11-01 15:33:32 +00:00
|
|
|
return gx->analog_state[port][index][id];
|
2013-07-04 18:52:53 +00:00
|
|
|
default:
|
|
|
|
return 0;
|
|
|
|
}
|
2011-12-14 12:20:22 +00:00
|
|
|
}
|
|
|
|
|
2012-11-27 00:23:10 +00:00
|
|
|
static void gx_input_free_input(void *data)
|
2011-12-14 12:20:22 +00:00
|
|
|
{
|
|
|
|
(void)data;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void reset_callback(void)
|
2012-08-29 02:58:21 +00:00
|
|
|
{
|
|
|
|
g_menu = true;
|
|
|
|
}
|
|
|
|
|
2012-08-29 19:15:24 +00:00
|
|
|
#ifdef HW_RVL
|
2012-08-29 02:58:21 +00:00
|
|
|
static void power_callback(void)
|
2011-12-14 12:20:22 +00:00
|
|
|
{
|
|
|
|
g_quit = true;
|
|
|
|
}
|
2012-08-29 19:15:24 +00:00
|
|
|
#endif
|
2011-12-14 12:20:22 +00:00
|
|
|
|
2013-03-14 01:24:57 +00:00
|
|
|
static void gx_input_set_keybinds(void *data, unsigned device, unsigned port,
|
|
|
|
unsigned id, unsigned keybind_action)
|
2012-07-26 05:28:57 +00:00
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
gx_input_t *gx = (gx_input_t*)data;
|
2013-03-14 14:01:36 +00:00
|
|
|
uint64_t *key = &g_settings.input.binds[port][id].joykey;
|
2013-03-14 20:55:10 +00:00
|
|
|
size_t arr_size = sizeof(platform_keys) / sizeof(platform_keys[0]);
|
2013-03-14 14:01:36 +00:00
|
|
|
|
|
|
|
(void)device;
|
|
|
|
|
|
|
|
if (keybind_action & (1ULL << KEYBINDS_ACTION_SET_DEFAULT_BIND))
|
|
|
|
*key = g_settings.input.binds[port][id].def_joykey;
|
2013-03-14 01:24:57 +00:00
|
|
|
|
|
|
|
if (keybind_action & (1ULL << KEYBINDS_ACTION_SET_DEFAULT_BINDS))
|
2012-07-27 19:13:24 +00:00
|
|
|
{
|
2013-03-14 01:24:57 +00:00
|
|
|
switch (device)
|
|
|
|
{
|
2012-08-06 20:00:35 +00:00
|
|
|
#ifdef HW_RVL
|
2013-03-15 00:22:52 +00:00
|
|
|
case DEVICE_WIIMOTE:
|
|
|
|
g_settings.input.device[port] = device;
|
|
|
|
strlcpy(g_settings.input.device_names[port], "Wiimote", sizeof(g_settings.input.device_names[port]));
|
2013-03-14 01:24:57 +00:00
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_B].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_1].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_Y].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_A].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_SELECT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_MINUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_START].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_PLUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_UP].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_UP].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_DOWN].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_DOWN].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_LEFT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_LEFT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_RIGHT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_RIGHT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_A].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_2].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_X].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_B].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L3].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R3].def_joykey = NO_BTN;
|
|
|
|
break;
|
2013-03-15 00:22:52 +00:00
|
|
|
case DEVICE_NUNCHUK:
|
|
|
|
g_settings.input.device[port] = device;
|
|
|
|
strlcpy(g_settings.input.device_names[port], "Wiimote + Nunchuk", sizeof(g_settings.input.device_names[port]));
|
2013-03-14 01:24:57 +00:00
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_B].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_B].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_Y].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_2].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_SELECT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_MINUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_START].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_PLUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_UP].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_UP].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_DOWN].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_DOWN].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_LEFT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_LEFT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_RIGHT].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_RIGHT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_A].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_A].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_X].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_1].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_Z].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R].def_joykey = platform_keys[GX_DEVICE_WIIMOTE_ID_JOYPAD_C].joykey;;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L3].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R3].def_joykey = NO_BTN; break;
|
2013-03-15 00:22:52 +00:00
|
|
|
case DEVICE_CLASSIC:
|
|
|
|
g_settings.input.device[port] = device;
|
|
|
|
strlcpy(g_settings.input.device_names[port], "Classic Controller", sizeof(g_settings.input.device_names[port]));
|
2013-03-14 01:24:57 +00:00
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_B].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_B].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_Y].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_Y].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_SELECT].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_MINUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_START].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_PLUS].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_UP].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_UP].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_DOWN].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_DOWN].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_LEFT].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_LEFT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_RIGHT].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_RIGHT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_A].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_A].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_X].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_X].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_L_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_R_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L2].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_ZL_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R2].def_joykey = platform_keys[GX_DEVICE_CLASSIC_ID_JOYPAD_ZR_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L3].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R3].def_joykey = NO_BTN;
|
|
|
|
break;
|
2012-08-06 20:00:35 +00:00
|
|
|
#endif
|
2013-03-15 00:22:52 +00:00
|
|
|
case DEVICE_GAMECUBE:
|
|
|
|
g_settings.input.device[port] = device;
|
|
|
|
strlcpy(g_settings.input.device_names[port], "Gamecube Controller", sizeof(g_settings.input.device_names[port]));
|
2013-03-14 01:24:57 +00:00
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_B].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_B].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_Y].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_Y].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_SELECT].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_Z_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_START].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_START].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_UP].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_UP].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_DOWN].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_DOWN].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_LEFT].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_LEFT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_RIGHT].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_RIGHT].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_A].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_A].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_X].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_X].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_L_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R].def_joykey = platform_keys[GX_DEVICE_GC_ID_JOYPAD_R_TRIGGER].joykey;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R2].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_L3].def_joykey = NO_BTN;
|
|
|
|
g_settings.input.binds[port][RETRO_DEVICE_ID_JOYPAD_R3].def_joykey = NO_BTN;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2012-07-26 05:28:57 +00:00
|
|
|
|
2013-03-14 01:24:57 +00:00
|
|
|
for (unsigned i = 0; i < RARCH_CUSTOM_BIND_LIST_END; i++)
|
|
|
|
{
|
|
|
|
g_settings.input.binds[port][i].id = i;
|
|
|
|
g_settings.input.binds[port][i].joykey = g_settings.input.binds[port][i].def_joykey;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-14 17:02:19 +00:00
|
|
|
if (keybind_action & (1ULL << KEYBINDS_ACTION_GET_BIND_LABEL))
|
|
|
|
{
|
|
|
|
struct platform_bind *ret = (struct platform_bind*)data;
|
|
|
|
|
|
|
|
if (ret->joykey == NO_BTN)
|
|
|
|
strlcpy(ret->desc, "No button", sizeof(ret->desc));
|
|
|
|
else
|
|
|
|
{
|
|
|
|
for (size_t i = 0; i < arr_size; i++)
|
|
|
|
{
|
2013-03-14 17:04:16 +00:00
|
|
|
if (platform_keys[i].joykey == ret->joykey)
|
2013-03-14 17:02:19 +00:00
|
|
|
{
|
|
|
|
strlcpy(ret->desc, platform_keys[i].desc, sizeof(ret->desc));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
strlcpy(ret->desc, "Unknown", sizeof(ret->desc));
|
|
|
|
}
|
|
|
|
}
|
2013-07-28 17:11:22 +00:00
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->pad_detect_pending[port] = 1;
|
2013-03-12 23:14:28 +00:00
|
|
|
}
|
|
|
|
|
2013-03-12 23:34:46 +00:00
|
|
|
static void *gx_input_init(void)
|
2012-07-27 13:46:15 +00:00
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
gx_input_t *gx = (gx_input_t*)calloc(1, sizeof(*gx));
|
|
|
|
if (!gx)
|
|
|
|
return NULL;
|
|
|
|
|
2013-07-28 17:11:22 +00:00
|
|
|
for (unsigned i = 0; i < MAX_PADS; i++)
|
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->pad_connect[i] = 0;
|
|
|
|
gx->pad_type[i] = 0;
|
|
|
|
gx->pad_detect_pending[i] = 1;
|
2013-07-28 17:11:22 +00:00
|
|
|
}
|
|
|
|
|
2013-03-12 23:34:46 +00:00
|
|
|
PAD_Init();
|
|
|
|
#ifdef HW_RVL
|
|
|
|
WPAD_Init();
|
|
|
|
#endif
|
|
|
|
SYS_SetResetCallback(reset_callback);
|
|
|
|
#ifdef HW_RVL
|
|
|
|
SYS_SetPowerCallback(power_callback);
|
|
|
|
#endif
|
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
return gx;
|
2012-07-27 13:46:15 +00:00
|
|
|
}
|
|
|
|
|
2012-08-09 01:54:27 +00:00
|
|
|
static void gx_input_poll(void *data)
|
2012-07-26 05:28:57 +00:00
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
gx_input_t *gx = (gx_input_t*)data;
|
2012-12-15 04:46:49 +00:00
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->pad_state[0] = 0;
|
|
|
|
gx->pad_state[1] = 0;
|
|
|
|
gx->pad_state[2] = 0;
|
|
|
|
gx->pad_state[3] = 0;
|
|
|
|
gx->analog_state[0][0][0] = gx->analog_state[0][0][1] = gx->analog_state[0][1][0] = gx->analog_state[0][1][1] = 0;
|
|
|
|
gx->analog_state[1][0][0] = gx->analog_state[1][0][1] = gx->analog_state[1][1][0] = gx->analog_state[1][1][1] = 0;
|
|
|
|
gx->analog_state[2][0][0] = gx->analog_state[2][0][1] = gx->analog_state[2][1][0] = gx->analog_state[2][1][1] = 0;
|
|
|
|
gx->analog_state[3][0][0] = gx->analog_state[3][0][1] = gx->analog_state[3][1][0] = gx->analog_state[3][1][1] = 0;
|
2013-01-06 19:17:05 +00:00
|
|
|
|
2013-01-07 00:48:56 +00:00
|
|
|
PAD_ScanPads();
|
|
|
|
|
2012-08-09 01:54:27 +00:00
|
|
|
#ifdef HW_RVL
|
2013-01-06 18:40:54 +00:00
|
|
|
WPAD_ReadPending(WPAD_CHAN_ALL, NULL);
|
2013-01-07 00:51:29 +00:00
|
|
|
#endif
|
2012-07-26 05:28:57 +00:00
|
|
|
|
2013-03-16 16:51:45 +00:00
|
|
|
for (unsigned port = 0; port < MAX_PADS; port++)
|
2012-01-03 11:11:02 +00:00
|
|
|
{
|
2013-01-07 00:51:29 +00:00
|
|
|
uint32_t down = 0;
|
2013-11-01 15:33:32 +00:00
|
|
|
uint64_t *state_cur = &gx->pad_state[port];
|
2013-01-06 18:40:54 +00:00
|
|
|
|
2013-01-07 00:51:29 +00:00
|
|
|
#ifdef HW_RVL
|
2013-11-01 15:33:32 +00:00
|
|
|
if (gx->pad_detect_pending[port])
|
2013-07-28 17:11:22 +00:00
|
|
|
{
|
2013-11-01 15:33:32 +00:00
|
|
|
uint32_t *ptype = &gx->pad_type[port];
|
|
|
|
gx->pad_connect[port] = WPAD_Probe(port, ptype);
|
|
|
|
gx->pad_detect_pending[port] = 0;
|
2013-07-28 17:11:22 +00:00
|
|
|
}
|
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
uint32_t connected = gx->pad_connect[port];
|
|
|
|
uint32_t type = gx->pad_type[port];
|
2013-01-09 04:08:08 +00:00
|
|
|
|
2013-07-28 17:11:22 +00:00
|
|
|
if (connected == WPAD_ERR_NONE)
|
2013-01-06 19:17:05 +00:00
|
|
|
{
|
2013-01-08 04:48:21 +00:00
|
|
|
WPADData *wpaddata = WPAD_Data(port);
|
|
|
|
|
|
|
|
down = wpaddata->btns_h;
|
|
|
|
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_A) ? GX_WIIMOTE_A : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_B) ? GX_WIIMOTE_B : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_1) ? GX_WIIMOTE_1 : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_2) ? GX_WIIMOTE_2 : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_PLUS) ? GX_WIIMOTE_PLUS : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_MINUS) ? GX_WIIMOTE_MINUS : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_HOME) ? GX_WIIMOTE_HOME : 0;
|
|
|
|
// rotated d-pad on Wiimote
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_UP) ? GX_WIIMOTE_LEFT : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_DOWN) ? GX_WIIMOTE_RIGHT : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_LEFT) ? GX_WIIMOTE_DOWN : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_RIGHT) ? GX_WIIMOTE_UP : 0;
|
|
|
|
|
|
|
|
expansion_t *exp = &wpaddata->exp;
|
|
|
|
|
|
|
|
if (type == WPAD_EXP_CLASSIC)
|
|
|
|
{
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_A) ? GX_CLASSIC_A : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_B) ? GX_CLASSIC_B : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_X) ? GX_CLASSIC_X : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_Y) ? GX_CLASSIC_Y : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_UP) ? GX_CLASSIC_UP : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_DOWN) ? GX_CLASSIC_DOWN : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_LEFT) ? GX_CLASSIC_LEFT : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_RIGHT) ? GX_CLASSIC_RIGHT : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_PLUS) ? GX_CLASSIC_PLUS : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_MINUS) ? GX_CLASSIC_MINUS : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_HOME) ? GX_CLASSIC_HOME : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_FULL_L) ? GX_CLASSIC_L_TRIGGER : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_FULL_R) ? GX_CLASSIC_R_TRIGGER : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_ZL) ? GX_CLASSIC_ZL_TRIGGER : 0;
|
|
|
|
*state_cur |= (down & WPAD_CLASSIC_BUTTON_ZR) ? GX_CLASSIC_ZR_TRIGGER : 0;
|
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
float ljs_mag = exp->classic.ljs.mag;
|
|
|
|
float ljs_ang = exp->classic.ljs.ang;
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
float rjs_mag = exp->classic.rjs.mag;
|
|
|
|
float rjs_ang = exp->classic.rjs.ang;
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
if (ljs_mag > 1.0f)
|
|
|
|
ljs_mag = 1.0f;
|
|
|
|
else if (ljs_mag < -1.0f)
|
|
|
|
ljs_mag = -1.0f;
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
if (rjs_mag > 1.0f)
|
|
|
|
rjs_mag = 1.0f;
|
|
|
|
else if (rjs_mag < -1.0f)
|
|
|
|
rjs_mag = -1.0f;
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
double ljs_val_x = ljs_mag * sin(M_PI * ljs_ang / 180.0);
|
|
|
|
double ljs_val_y = -ljs_mag * cos(M_PI * ljs_ang / 180.0);
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
double rjs_val_x = rjs_mag * sin(M_PI * rjs_ang / 180.0);
|
|
|
|
double rjs_val_y = -rjs_mag * cos(M_PI * rjs_ang / 180.0);
|
2013-01-18 18:43:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
int16_t ls_x = (int16_t)(ljs_val_x * 32767.0f);
|
|
|
|
int16_t ls_y = (int16_t)(ljs_val_y * 32767.0f);
|
2013-01-18 13:24:46 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
int16_t rs_x = (int16_t)(rjs_val_x * 32767.0f);
|
|
|
|
int16_t rs_y = (int16_t)(rjs_val_y * 32767.0f);
|
2013-01-18 13:24:46 +00:00
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_X] = ls_x;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_Y] = ls_y;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_RIGHT][RETRO_DEVICE_ID_ANALOG_X] = rs_x;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_RIGHT][RETRO_DEVICE_ID_ANALOG_Y] = rs_y;
|
2013-01-08 04:48:21 +00:00
|
|
|
}
|
|
|
|
else if (type == WPAD_EXP_NUNCHUK)
|
2013-01-06 19:17:05 +00:00
|
|
|
{
|
2013-01-08 04:48:21 +00:00
|
|
|
// wiimote is held upright with nunchuk, do not change d-pad orientation
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_UP) ? GX_WIIMOTE_UP : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_DOWN) ? GX_WIIMOTE_DOWN : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_LEFT) ? GX_WIIMOTE_LEFT : 0;
|
|
|
|
*state_cur |= (down & WPAD_BUTTON_RIGHT) ? GX_WIIMOTE_RIGHT : 0;
|
2012-07-26 21:07:47 +00:00
|
|
|
|
2013-01-08 04:48:21 +00:00
|
|
|
*state_cur |= (down & WPAD_NUNCHUK_BUTTON_Z) ? GX_NUNCHUK_Z : 0;
|
|
|
|
*state_cur |= (down & WPAD_NUNCHUK_BUTTON_C) ? GX_NUNCHUK_C : 0;
|
2012-08-08 04:56:56 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
float js_mag = exp->nunchuk.js.mag;
|
|
|
|
float js_ang = exp->nunchuk.js.ang;
|
2013-01-19 19:43:18 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
if (js_mag > 1.0f)
|
|
|
|
js_mag = 1.0f;
|
|
|
|
else if (js_mag < -1.0f)
|
|
|
|
js_mag = -1.0f;
|
2013-01-19 19:43:18 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
double js_val_x = js_mag * sin(M_PI * js_ang / 180.0);
|
|
|
|
double js_val_y = -js_mag * cos(M_PI * js_ang / 180.0);
|
2013-01-19 19:43:18 +00:00
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
int16_t x = (int16_t)(js_val_x * 32767.0f);
|
|
|
|
int16_t y = (int16_t)(js_val_y * 32767.0f);
|
2012-12-16 06:28:01 +00:00
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_X] = x;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_Y] = y;
|
2012-07-26 05:28:57 +00:00
|
|
|
}
|
|
|
|
}
|
2013-01-08 04:48:21 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
if (SI_GetType(port) & SI_TYPE_GC)
|
2013-01-06 19:17:05 +00:00
|
|
|
{
|
2013-01-08 04:48:21 +00:00
|
|
|
down = PAD_ButtonsHeld(port);
|
|
|
|
|
|
|
|
*state_cur |= (down & PAD_BUTTON_A) ? GX_GC_A : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_B) ? GX_GC_B : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_X) ? GX_GC_X : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_Y) ? GX_GC_Y : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_UP) ? GX_GC_UP : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_DOWN) ? GX_GC_DOWN : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_LEFT) ? GX_GC_LEFT : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_RIGHT) ? GX_GC_RIGHT : 0;
|
|
|
|
*state_cur |= (down & PAD_BUTTON_START) ? GX_GC_START : 0;
|
|
|
|
*state_cur |= (down & PAD_TRIGGER_Z) ? GX_GC_Z_TRIGGER : 0;
|
|
|
|
*state_cur |= ((down & PAD_TRIGGER_L) || PAD_TriggerL(port) > 127) ? GX_GC_L_TRIGGER : 0;
|
|
|
|
*state_cur |= ((down & PAD_TRIGGER_R) || PAD_TriggerR(port) > 127) ? GX_GC_R_TRIGGER : 0;
|
|
|
|
|
2013-07-04 18:52:53 +00:00
|
|
|
int16_t ls_x = (int16_t)PAD_StickX(port) * 256;
|
|
|
|
int16_t ls_y = (int16_t)PAD_StickY(port) * -256;
|
|
|
|
int16_t rs_x = (int16_t)PAD_SubStickX(port) * 256;
|
|
|
|
int16_t rs_y = (int16_t)PAD_SubStickY(port) * -256;
|
2012-07-26 05:28:57 +00:00
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_X] = ls_x;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_LEFT][RETRO_DEVICE_ID_ANALOG_Y] = ls_y;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_RIGHT][RETRO_DEVICE_ID_ANALOG_X] = rs_x;
|
|
|
|
gx->analog_state[port][RETRO_DEVICE_INDEX_ANALOG_RIGHT][RETRO_DEVICE_ID_ANALOG_Y] = rs_y;
|
2012-07-26 05:28:57 +00:00
|
|
|
|
2013-10-07 14:19:32 +00:00
|
|
|
if ((*state_cur & (GX_GC_START | GX_GC_Z_TRIGGER | GX_GC_L_TRIGGER | GX_GC_R_TRIGGER)) == (GX_GC_START | GX_GC_Z_TRIGGER | GX_GC_L_TRIGGER | GX_GC_R_TRIGGER))
|
2013-01-08 04:48:21 +00:00
|
|
|
*state_cur |= GX_WIIMOTE_HOME;
|
|
|
|
}
|
2012-07-26 05:28:57 +00:00
|
|
|
}
|
|
|
|
|
2013-11-01 15:33:32 +00:00
|
|
|
uint64_t *state_p1 = &gx->pad_state[0];
|
2013-01-07 01:09:19 +00:00
|
|
|
uint64_t *lifecycle_state = &g_extern.lifecycle_state;
|
|
|
|
|
2013-01-18 14:07:11 +00:00
|
|
|
*lifecycle_state &= ~(
|
|
|
|
(1ULL << RARCH_FAST_FORWARD_HOLD_KEY) |
|
|
|
|
(1ULL << RARCH_LOAD_STATE_KEY) |
|
|
|
|
(1ULL << RARCH_SAVE_STATE_KEY) |
|
|
|
|
(1ULL << RARCH_STATE_SLOT_PLUS) |
|
|
|
|
(1ULL << RARCH_STATE_SLOT_MINUS) |
|
|
|
|
(1ULL << RARCH_REWIND) |
|
|
|
|
(1ULL << RARCH_QUIT_KEY) |
|
2013-03-30 06:19:42 +00:00
|
|
|
(1ULL << RARCH_MENU_TOGGLE));
|
2013-01-18 14:07:11 +00:00
|
|
|
|
2012-08-29 02:58:21 +00:00
|
|
|
if (g_menu)
|
2012-07-26 05:28:57 +00:00
|
|
|
{
|
2013-01-18 14:07:11 +00:00
|
|
|
*state_p1 |= GX_WIIMOTE_HOME;
|
2012-08-29 02:58:21 +00:00
|
|
|
g_menu = false;
|
|
|
|
}
|
|
|
|
|
2013-04-27 19:27:41 +00:00
|
|
|
if (*state_p1 & (GX_WIIMOTE_HOME
|
2012-08-09 01:54:27 +00:00
|
|
|
#ifdef HW_RVL
|
2013-04-27 19:27:41 +00:00
|
|
|
| GX_CLASSIC_HOME
|
2012-08-09 01:54:27 +00:00
|
|
|
#endif
|
2013-04-27 19:27:41 +00:00
|
|
|
))
|
|
|
|
*lifecycle_state |= (1ULL << RARCH_MENU_TOGGLE);
|
2011-12-14 12:20:22 +00:00
|
|
|
}
|
|
|
|
|
2013-01-06 22:45:09 +00:00
|
|
|
static bool gx_input_key_pressed(void *data, int key)
|
|
|
|
{
|
|
|
|
return (g_extern.lifecycle_state & (1ULL << key));
|
|
|
|
}
|
|
|
|
|
2013-11-02 20:16:57 +00:00
|
|
|
static uint64_t gx_input_get_capabilities(void *data)
|
|
|
|
{
|
|
|
|
uint64_t caps = 0;
|
|
|
|
|
|
|
|
caps |= (1 << RETRO_DEVICE_JOYPAD);
|
|
|
|
caps |= (1 << RETRO_DEVICE_ANALOG);
|
|
|
|
|
|
|
|
return caps;
|
|
|
|
}
|
|
|
|
|
2012-07-25 19:02:01 +00:00
|
|
|
|
2012-08-09 01:54:27 +00:00
|
|
|
const input_driver_t input_gx = {
|
2013-11-02 20:16:57 +00:00
|
|
|
gx_input_init,
|
|
|
|
gx_input_poll,
|
|
|
|
gx_input_state,
|
|
|
|
gx_input_key_pressed,
|
|
|
|
gx_input_free_input,
|
|
|
|
gx_input_set_keybinds,
|
2013-11-02 23:27:58 +00:00
|
|
|
NULL,
|
2013-11-02 20:16:57 +00:00
|
|
|
gx_input_get_capabilities,
|
|
|
|
"gx",
|
2011-12-14 12:20:22 +00:00
|
|
|
};
|