aboutsummaryrefslogtreecommitdiff
path: root/frontend/plat_pandora.c
diff options
context:
space:
mode:
authornotaz2011-12-10 01:57:29 +0200
committernotaz2011-12-11 01:38:49 +0200
commit1b0c513996d57548fc5df8726e21a68e5ace4f99 (patch)
treef3ac4dd1c09b467fd9e85d5e9a6f60c4ce01f101 /frontend/plat_pandora.c
parentb944a30eda75c36c94ef71e7768497801887612b (diff)
downloadpcsx_rearmed-1b0c513996d57548fc5df8726e21a68e5ace4f99.tar.gz
pcsx_rearmed-1b0c513996d57548fc5df8726e21a68e5ace4f99.tar.bz2
pcsx_rearmed-1b0c513996d57548fc5df8726e21a68e5ace4f99.zip
frontend: make analogs configurable
Diffstat (limited to 'frontend/plat_pandora.c')
-rw-r--r--frontend/plat_pandora.c92
1 files changed, 2 insertions, 90 deletions
diff --git a/frontend/plat_pandora.c b/frontend/plat_pandora.c
index d0cca89..d869d24 100644
--- a/frontend/plat_pandora.c
+++ b/frontend/plat_pandora.c
@@ -21,9 +21,6 @@
#include "plat.h"
#include "main.h"
-static int fdnub[2];
-static int analog_init_done;
-
static const char * const pandora_gpio_keys[KEY_MAX + 1] = {
[0 ... KEY_MAX] = NULL,
[KEY_UP] = "Up",
@@ -66,98 +63,13 @@ struct in_default_bind in_evdev_defbinds[] = {
{ 0, 0, 0 }
};
-static void analog_init(void)
-{
- int i, nub;
-
- fdnub[0] = fdnub[1] = -1;
-
- for (i = nub = 0; nub < 2; i++)
- {
- long absbits[(ABS_MAX+1) / sizeof(long) / 8];
- int ret, fd, support = 0;
- char name[64];
-
- snprintf(name, sizeof(name), "/dev/input/event%d", i);
- fd = open(name, O_RDONLY|O_NONBLOCK);
- if (fd == -1) {
- if (errno == EACCES)
- continue; /* maybe we can access next one */
- break;
- }
-
- /* check supported events */
- ret = ioctl(fd, EVIOCGBIT(0, sizeof(support)), &support);
- if (ret == -1) {
- printf("pandora: ioctl failed on %s\n", name);
- goto skip;
- }
-
- if (!(support & (1 << EV_ABS)))
- goto skip;
-
- ret = ioctl(fd, EVIOCGNAME(sizeof(name)), name);
- if (ret == -1 || strncmp(name, "nub", 3) != 0)
- goto skip;
-
- ret = ioctl(fd, EVIOCGBIT(EV_ABS, sizeof(absbits)), absbits);
- if (ret == -1)
- goto skip;
- if ((absbits[0] & ((1 << ABS_X)|(1 << ABS_Y))) != ((1 << ABS_X)|(1 << ABS_Y)))
- goto skip;
-
- printf("pandora: found analog #%d \"%s\"\n", nub, name);
- fdnub[nub++] = fd;
- continue;
-
-skip:
- close(fd);
- }
-
- if (nub != 2)
- printf("pandora: warning: not all nubs found: %d\n", nub);
-
- analog_init_done = 1;
-}
-
-void in_update_analogs(void)
-{
- int *nubp[2] = { in_a1, in_a2 };
- struct input_absinfo ainfo;
- int i, fd, v, ret;
-
- if (!analog_init_done)
- analog_init();
-
- for (i = 0; i < 2; i++) {
- fd = fdnub[i];
- if (fd < 0)
- continue;
-
- ret = ioctl(fd, EVIOCGABS(ABS_X), &ainfo);
- if (ret == -1) {
- perror("ioctl");
- continue;
- }
- v = ainfo.value / 2 + 127;
- nubp[i][0] = v < 0 ? 0 : v;
-
- ret = ioctl(fd, EVIOCGABS(ABS_Y), &ainfo);
- if (ret == -1) {
- perror("ioctl");
- continue;
- }
- v = ainfo.value / 2 + 127;
- nubp[i][1] = v < 0 ? 0 : v;
- }
- //printf("%4d %4d %4d %4d\n", in_a1[0], in_a1[1], in_a2[0], in_a2[1]);
-}
-
int plat_pandora_init(void)
{
in_probe();
in_set_config(in_name_to_id("evdev:gpio-keys"), IN_CFG_KEY_NAMES,
pandora_gpio_keys, sizeof(pandora_gpio_keys));
+ in_adev[0] = in_name_to_id("evdev:nub0");
+ in_adev[1] = in_name_to_id("evdev:nub1");
return 0;
}