diff options
Diffstat (limited to 'drivers/input/joystick/grip.c')
-rw-r--r-- | drivers/input/joystick/grip.c | 78 |
1 files changed, 44 insertions, 34 deletions
diff --git a/drivers/input/joystick/grip.c b/drivers/input/joystick/grip.c index 9d3f910dd568..a936e7aedb10 100644 --- a/drivers/input/joystick/grip.c +++ b/drivers/input/joystick/grip.c | |||
@@ -34,6 +34,7 @@ | |||
34 | #include <linux/slab.h> | 34 | #include <linux/slab.h> |
35 | #include <linux/gameport.h> | 35 | #include <linux/gameport.h> |
36 | #include <linux/input.h> | 36 | #include <linux/input.h> |
37 | #include <linux/jiffies.h> | ||
37 | 38 | ||
38 | #define DRIVER_DESC "Gravis GrIP protocol joystick driver" | 39 | #define DRIVER_DESC "Gravis GrIP protocol joystick driver" |
39 | 40 | ||
@@ -55,7 +56,7 @@ MODULE_LICENSE("GPL"); | |||
55 | 56 | ||
56 | struct grip { | 57 | struct grip { |
57 | struct gameport *gameport; | 58 | struct gameport *gameport; |
58 | struct input_dev dev[2]; | 59 | struct input_dev *dev[2]; |
59 | unsigned char mode[2]; | 60 | unsigned char mode[2]; |
60 | int reads; | 61 | int reads; |
61 | int bads; | 62 | int bads; |
@@ -190,7 +191,7 @@ static void grip_poll(struct gameport *gameport) | |||
190 | 191 | ||
191 | for (i = 0; i < 2; i++) { | 192 | for (i = 0; i < 2; i++) { |
192 | 193 | ||
193 | dev = grip->dev + i; | 194 | dev = grip->dev[i]; |
194 | grip->reads++; | 195 | grip->reads++; |
195 | 196 | ||
196 | switch (grip->mode[i]) { | 197 | switch (grip->mode[i]) { |
@@ -297,6 +298,7 @@ static void grip_close(struct input_dev *dev) | |||
297 | static int grip_connect(struct gameport *gameport, struct gameport_driver *drv) | 298 | static int grip_connect(struct gameport *gameport, struct gameport_driver *drv) |
298 | { | 299 | { |
299 | struct grip *grip; | 300 | struct grip *grip; |
301 | struct input_dev *input_dev; | ||
300 | unsigned int data[GRIP_LENGTH_XT]; | 302 | unsigned int data[GRIP_LENGTH_XT]; |
301 | int i, j, t; | 303 | int i, j, t; |
302 | int err; | 304 | int err; |
@@ -339,48 +341,56 @@ static int grip_connect(struct gameport *gameport, struct gameport_driver *drv) | |||
339 | gameport_set_poll_handler(gameport, grip_poll); | 341 | gameport_set_poll_handler(gameport, grip_poll); |
340 | gameport_set_poll_interval(gameport, 20); | 342 | gameport_set_poll_interval(gameport, 20); |
341 | 343 | ||
342 | for (i = 0; i < 2; i++) | 344 | for (i = 0; i < 2; i++) { |
343 | if (grip->mode[i]) { | 345 | if (!grip->mode[i]) |
346 | continue; | ||
344 | 347 | ||
345 | sprintf(grip->phys[i], "%s/input%d", gameport->phys, i); | 348 | grip->dev[i] = input_dev = input_allocate_device(); |
349 | if (!input_dev) { | ||
350 | err = -ENOMEM; | ||
351 | goto fail3; | ||
352 | } | ||
346 | 353 | ||
347 | grip->dev[i].private = grip; | 354 | sprintf(grip->phys[i], "%s/input%d", gameport->phys, i); |
348 | 355 | ||
349 | grip->dev[i].open = grip_open; | 356 | input_dev->name = grip_name[grip->mode[i]]; |
350 | grip->dev[i].close = grip_close; | 357 | input_dev->phys = grip->phys[i]; |
358 | input_dev->id.bustype = BUS_GAMEPORT; | ||
359 | input_dev->id.vendor = GAMEPORT_ID_VENDOR_GRAVIS; | ||
360 | input_dev->id.product = grip->mode[i]; | ||
361 | input_dev->id.version = 0x0100; | ||
362 | input_dev->cdev.dev = &gameport->dev; | ||
363 | input_dev->private = grip; | ||
351 | 364 | ||
352 | grip->dev[i].name = grip_name[grip->mode[i]]; | 365 | input_dev->open = grip_open; |
353 | grip->dev[i].phys = grip->phys[i]; | 366 | input_dev->close = grip_close; |
354 | grip->dev[i].id.bustype = BUS_GAMEPORT; | ||
355 | grip->dev[i].id.vendor = GAMEPORT_ID_VENDOR_GRAVIS; | ||
356 | grip->dev[i].id.product = grip->mode[i]; | ||
357 | grip->dev[i].id.version = 0x0100; | ||
358 | 367 | ||
359 | grip->dev[i].evbit[0] = BIT(EV_KEY) | BIT(EV_ABS); | 368 | input_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_ABS); |
360 | 369 | ||
361 | for (j = 0; (t = grip_abs[grip->mode[i]][j]) >= 0; j++) { | 370 | for (j = 0; (t = grip_abs[grip->mode[i]][j]) >= 0; j++) { |
362 | 371 | ||
363 | if (j < grip_cen[grip->mode[i]]) | 372 | if (j < grip_cen[grip->mode[i]]) |
364 | input_set_abs_params(&grip->dev[i], t, 14, 52, 1, 2); | 373 | input_set_abs_params(input_dev, t, 14, 52, 1, 2); |
365 | else if (j < grip_anx[grip->mode[i]]) | 374 | else if (j < grip_anx[grip->mode[i]]) |
366 | input_set_abs_params(&grip->dev[i], t, 3, 57, 1, 0); | 375 | input_set_abs_params(input_dev, t, 3, 57, 1, 0); |
367 | else | 376 | else |
368 | input_set_abs_params(&grip->dev[i], t, -1, 1, 0, 0); | 377 | input_set_abs_params(input_dev, t, -1, 1, 0, 0); |
369 | } | 378 | } |
370 | 379 | ||
371 | for (j = 0; (t = grip_btn[grip->mode[i]][j]) >= 0; j++) | 380 | for (j = 0; (t = grip_btn[grip->mode[i]][j]) >= 0; j++) |
372 | if (t > 0) | 381 | if (t > 0) |
373 | set_bit(t, grip->dev[i].keybit); | 382 | set_bit(t, input_dev->keybit); |
374 | 383 | ||
375 | printk(KERN_INFO "input: %s on %s\n", | 384 | input_register_device(grip->dev[i]); |
376 | grip_name[grip->mode[i]], gameport->phys); | 385 | } |
377 | input_register_device(grip->dev + i); | ||
378 | } | ||
379 | 386 | ||
380 | return 0; | 387 | return 0; |
381 | 388 | ||
382 | fail2: gameport_close(gameport); | 389 | fail3: for (i = 0; i < 2; i++) |
383 | fail1: gameport_set_drvdata(gameport, NULL); | 390 | if (grip->dev[i]) |
391 | input_unregister_device(grip->dev[i]); | ||
392 | fail2: gameport_close(gameport); | ||
393 | fail1: gameport_set_drvdata(gameport, NULL); | ||
384 | kfree(grip); | 394 | kfree(grip); |
385 | return err; | 395 | return err; |
386 | } | 396 | } |
@@ -391,8 +401,8 @@ static void grip_disconnect(struct gameport *gameport) | |||
391 | int i; | 401 | int i; |
392 | 402 | ||
393 | for (i = 0; i < 2; i++) | 403 | for (i = 0; i < 2; i++) |
394 | if (grip->mode[i]) | 404 | if (grip->dev[i]) |
395 | input_unregister_device(grip->dev + i); | 405 | input_unregister_device(grip->dev[i]); |
396 | gameport_close(gameport); | 406 | gameport_close(gameport); |
397 | gameport_set_drvdata(gameport, NULL); | 407 | gameport_set_drvdata(gameport, NULL); |
398 | kfree(grip); | 408 | kfree(grip); |