2 * Joystick device driver for the input driver suite.
4 * Copyright (c) 1999-2002 Vojtech Pavlik
5 * Copyright (c) 1999 Colin Van Dyke
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
14 #include <asm/system.h>
15 #include <linux/delay.h>
16 #include <linux/errno.h>
17 #include <linux/joystick.h>
18 #include <linux/input.h>
19 #include <linux/kernel.h>
20 #include <linux/major.h>
21 #include <linux/slab.h>
23 #include <linux/miscdevice.h>
24 #include <linux/module.h>
25 #include <linux/poll.h>
26 #include <linux/init.h>
27 #include <linux/device.h>
29 MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
30 MODULE_DESCRIPTION("Joystick device interfaces");
31 MODULE_SUPPORTED_DEVICE("input/js");
32 MODULE_LICENSE("GPL");
34 #define JOYDEV_MINOR_BASE 0
35 #define JOYDEV_MINORS 16
36 #define JOYDEV_BUFFER_SIZE 64
43 struct input_handle handle
;
44 wait_queue_head_t wait
;
45 struct list_head client_list
;
48 struct js_corr corr
[ABS_MAX
+ 1];
49 struct JS_DATA_SAVE_TYPE glue
;
52 __u16 keymap
[KEY_MAX
- BTN_MISC
+ 1];
53 __u16 keypam
[KEY_MAX
- BTN_MISC
+ 1];
54 __u8 absmap
[ABS_MAX
+ 1];
55 __u8 abspam
[ABS_MAX
+ 1];
56 __s16 abs
[ABS_MAX
+ 1];
59 struct joydev_client
{
60 struct js_event buffer
[JOYDEV_BUFFER_SIZE
];
64 struct fasync_struct
*fasync
;
65 struct joydev
*joydev
;
66 struct list_head node
;
69 static struct joydev
*joydev_table
[JOYDEV_MINORS
];
71 static int joydev_correct(int value
, struct js_corr
*corr
)
77 value
= value
> corr
->coef
[0] ? (value
< corr
->coef
[1] ? 0 :
78 ((corr
->coef
[3] * (value
- corr
->coef
[1])) >> 14)) :
79 ((corr
->coef
[2] * (value
- corr
->coef
[0])) >> 14);
85 return value
< -32767 ? -32767 : (value
> 32767 ? 32767 : value
);
88 static void joydev_event(struct input_handle
*handle
, unsigned int type
, unsigned int code
, int value
)
90 struct joydev
*joydev
= handle
->private;
91 struct joydev_client
*client
;
92 struct js_event event
;
97 if (code
< BTN_MISC
|| value
== 2)
99 event
.type
= JS_EVENT_BUTTON
;
100 event
.number
= joydev
->keymap
[code
- BTN_MISC
];
105 event
.type
= JS_EVENT_AXIS
;
106 event
.number
= joydev
->absmap
[code
];
107 event
.value
= joydev_correct(value
, joydev
->corr
+ event
.number
);
108 if (event
.value
== joydev
->abs
[event
.number
])
110 joydev
->abs
[event
.number
] = event
.value
;
117 event
.time
= jiffies_to_msecs(jiffies
);
119 list_for_each_entry(client
, &joydev
->client_list
, node
) {
121 memcpy(client
->buffer
+ client
->head
, &event
, sizeof(struct js_event
));
123 if (client
->startup
== joydev
->nabs
+ joydev
->nkey
)
124 if (client
->tail
== (client
->head
= (client
->head
+ 1) & (JOYDEV_BUFFER_SIZE
- 1)))
127 kill_fasync(&client
->fasync
, SIGIO
, POLL_IN
);
130 wake_up_interruptible(&joydev
->wait
);
133 static int joydev_fasync(int fd
, struct file
*file
, int on
)
136 struct joydev_client
*client
= file
->private_data
;
138 retval
= fasync_helper(fd
, file
, on
, &client
->fasync
);
140 return retval
< 0 ? retval
: 0;
143 static void joydev_free(struct device
*dev
)
145 struct joydev
*joydev
= container_of(dev
, struct joydev
, dev
);
147 joydev_table
[joydev
->minor
] = NULL
;
151 static int joydev_release(struct inode
*inode
, struct file
*file
)
153 struct joydev_client
*client
= file
->private_data
;
154 struct joydev
*joydev
= client
->joydev
;
156 joydev_fasync(-1, file
, 0);
158 list_del(&client
->node
);
161 if (!--joydev
->open
&& joydev
->exist
)
162 input_close_device(&joydev
->handle
);
164 put_device(&joydev
->dev
);
169 static int joydev_open(struct inode
*inode
, struct file
*file
)
171 struct joydev_client
*client
;
172 struct joydev
*joydev
;
173 int i
= iminor(inode
) - JOYDEV_MINOR_BASE
;
176 if (i
>= JOYDEV_MINORS
)
179 joydev
= joydev_table
[i
];
180 if (!joydev
|| !joydev
->exist
)
183 get_device(&joydev
->dev
);
185 client
= kzalloc(sizeof(struct joydev_client
), GFP_KERNEL
);
191 client
->joydev
= joydev
;
192 list_add_tail(&client
->node
, &joydev
->client_list
);
194 if (!joydev
->open
++ && joydev
->exist
) {
195 error
= input_open_device(&joydev
->handle
);
197 goto err_free_client
;
200 file
->private_data
= client
;
204 list_del(&client
->node
);
207 put_device(&joydev
->dev
);
211 static ssize_t
joydev_write(struct file
*file
, const char __user
*buffer
, size_t count
, loff_t
*ppos
)
216 static ssize_t
joydev_read(struct file
*file
, char __user
*buf
, size_t count
, loff_t
*ppos
)
218 struct joydev_client
*client
= file
->private_data
;
219 struct joydev
*joydev
= client
->joydev
;
220 struct input_dev
*input
= joydev
->handle
.dev
;
226 if (count
< sizeof(struct js_event
))
229 if (count
== sizeof(struct JS_DATA_TYPE
)) {
231 struct JS_DATA_TYPE data
;
234 for (data
.buttons
= i
= 0; i
< 32 && i
< joydev
->nkey
; i
++)
235 data
.buttons
|= test_bit(joydev
->keypam
[i
], input
->key
) ? (1 << i
) : 0;
236 data
.x
= (joydev
->abs
[0] / 256 + 128) >> joydev
->glue
.JS_CORR
.x
;
237 data
.y
= (joydev
->abs
[1] / 256 + 128) >> joydev
->glue
.JS_CORR
.y
;
239 if (copy_to_user(buf
, &data
, sizeof(struct JS_DATA_TYPE
)))
243 client
->tail
= client
->head
;
245 return sizeof(struct JS_DATA_TYPE
);
248 if (client
->startup
== joydev
->nabs
+ joydev
->nkey
&&
249 client
->head
== client
->tail
&& (file
->f_flags
& O_NONBLOCK
))
252 retval
= wait_event_interruptible(joydev
->wait
,
254 client
->startup
< joydev
->nabs
+ joydev
->nkey
||
255 client
->head
!= client
->tail
);
262 while (client
->startup
< joydev
->nabs
+ joydev
->nkey
&& retval
+ sizeof(struct js_event
) <= count
) {
264 struct js_event event
;
266 event
.time
= jiffies_to_msecs(jiffies
);
268 if (client
->startup
< joydev
->nkey
) {
269 event
.type
= JS_EVENT_BUTTON
| JS_EVENT_INIT
;
270 event
.number
= client
->startup
;
271 event
.value
= !!test_bit(joydev
->keypam
[event
.number
], input
->key
);
273 event
.type
= JS_EVENT_AXIS
| JS_EVENT_INIT
;
274 event
.number
= client
->startup
- joydev
->nkey
;
275 event
.value
= joydev
->abs
[event
.number
];
278 if (copy_to_user(buf
+ retval
, &event
, sizeof(struct js_event
)))
282 retval
+= sizeof(struct js_event
);
285 while (client
->head
!= client
->tail
&& retval
+ sizeof(struct js_event
) <= count
) {
287 if (copy_to_user(buf
+ retval
, client
->buffer
+ client
->tail
, sizeof(struct js_event
)))
290 client
->tail
= (client
->tail
+ 1) & (JOYDEV_BUFFER_SIZE
- 1);
291 retval
+= sizeof(struct js_event
);
297 /* No kernel lock - fine */
298 static unsigned int joydev_poll(struct file
*file
, poll_table
*wait
)
300 struct joydev_client
*client
= file
->private_data
;
301 struct joydev
*joydev
= client
->joydev
;
303 poll_wait(file
, &joydev
->wait
, wait
);
304 return ((client
->head
!= client
->tail
|| client
->startup
< joydev
->nabs
+ joydev
->nkey
) ?
305 (POLLIN
| POLLRDNORM
) : 0) | (joydev
->exist
? 0 : (POLLHUP
| POLLERR
));
308 static int joydev_ioctl_common(struct joydev
*joydev
, unsigned int cmd
, void __user
*argp
)
310 struct input_dev
*dev
= joydev
->handle
.dev
;
316 return copy_from_user(&joydev
->glue
.JS_CORR
, argp
,
317 sizeof(joydev
->glue
.JS_CORR
)) ? -EFAULT
: 0;
320 return copy_to_user(argp
, &joydev
->glue
.JS_CORR
,
321 sizeof(joydev
->glue
.JS_CORR
)) ? -EFAULT
: 0;
324 return get_user(joydev
->glue
.JS_TIMEOUT
, (s32 __user
*) argp
);
327 return put_user(joydev
->glue
.JS_TIMEOUT
, (s32 __user
*) argp
);
330 return put_user(JS_VERSION
, (__u32 __user
*) argp
);
333 return put_user(joydev
->nabs
, (__u8 __user
*) argp
);
336 return put_user(joydev
->nkey
, (__u8 __user
*) argp
);
339 if (copy_from_user(joydev
->corr
, argp
,
340 sizeof(joydev
->corr
[0]) * joydev
->nabs
))
342 for (i
= 0; i
< joydev
->nabs
; i
++) {
343 j
= joydev
->abspam
[i
];
344 joydev
->abs
[i
] = joydev_correct(dev
->abs
[j
], joydev
->corr
+ i
);
349 return copy_to_user(argp
, joydev
->corr
,
350 sizeof(joydev
->corr
[0]) * joydev
->nabs
) ? -EFAULT
: 0;
353 if (copy_from_user(joydev
->abspam
, argp
, sizeof(__u8
) * (ABS_MAX
+ 1)))
355 for (i
= 0; i
< joydev
->nabs
; i
++) {
356 if (joydev
->abspam
[i
] > ABS_MAX
)
358 joydev
->absmap
[joydev
->abspam
[i
]] = i
;
363 return copy_to_user(argp
, joydev
->abspam
,
364 sizeof(__u8
) * (ABS_MAX
+ 1)) ? -EFAULT
: 0;
367 if (copy_from_user(joydev
->keypam
, argp
, sizeof(__u16
) * (KEY_MAX
- BTN_MISC
+ 1)))
369 for (i
= 0; i
< joydev
->nkey
; i
++) {
370 if (joydev
->keypam
[i
] > KEY_MAX
|| joydev
->keypam
[i
] < BTN_MISC
)
372 joydev
->keymap
[joydev
->keypam
[i
] - BTN_MISC
] = i
;
377 return copy_to_user(argp
, joydev
->keypam
,
378 sizeof(__u16
) * (KEY_MAX
- BTN_MISC
+ 1)) ? -EFAULT
: 0;
381 if ((cmd
& ~(_IOC_SIZEMASK
<< _IOC_SIZESHIFT
)) == JSIOCGNAME(0)) {
385 len
= strlen(dev
->name
) + 1;
386 if (len
> _IOC_SIZE(cmd
))
387 len
= _IOC_SIZE(cmd
);
388 if (copy_to_user(argp
, dev
->name
, len
))
397 static long joydev_compat_ioctl(struct file
*file
, unsigned int cmd
, unsigned long arg
)
399 struct joydev_client
*client
= file
->private_data
;
400 struct joydev
*joydev
= client
->joydev
;
401 void __user
*argp
= (void __user
*)arg
;
403 struct JS_DATA_SAVE_TYPE_32 ds32
;
410 case JS_SET_TIMELIMIT
:
411 err
= get_user(tmp32
, (s32 __user
*) arg
);
413 joydev
->glue
.JS_TIMELIMIT
= tmp32
;
415 case JS_GET_TIMELIMIT
:
416 tmp32
= joydev
->glue
.JS_TIMELIMIT
;
417 err
= put_user(tmp32
, (s32 __user
*) arg
);
421 err
= copy_from_user(&ds32
, argp
,
422 sizeof(ds32
)) ? -EFAULT
: 0;
424 joydev
->glue
.JS_TIMEOUT
= ds32
.JS_TIMEOUT
;
425 joydev
->glue
.BUSY
= ds32
.BUSY
;
426 joydev
->glue
.JS_EXPIRETIME
= ds32
.JS_EXPIRETIME
;
427 joydev
->glue
.JS_TIMELIMIT
= ds32
.JS_TIMELIMIT
;
428 joydev
->glue
.JS_SAVE
= ds32
.JS_SAVE
;
429 joydev
->glue
.JS_CORR
= ds32
.JS_CORR
;
434 ds32
.JS_TIMEOUT
= joydev
->glue
.JS_TIMEOUT
;
435 ds32
.BUSY
= joydev
->glue
.BUSY
;
436 ds32
.JS_EXPIRETIME
= joydev
->glue
.JS_EXPIRETIME
;
437 ds32
.JS_TIMELIMIT
= joydev
->glue
.JS_TIMELIMIT
;
438 ds32
.JS_SAVE
= joydev
->glue
.JS_SAVE
;
439 ds32
.JS_CORR
= joydev
->glue
.JS_CORR
;
441 err
= copy_to_user(argp
, &ds32
, sizeof(ds32
)) ? -EFAULT
: 0;
445 err
= joydev_ioctl_common(joydev
, cmd
, argp
);
449 #endif /* CONFIG_COMPAT */
451 static int joydev_ioctl(struct inode
*inode
, struct file
*file
, unsigned int cmd
, unsigned long arg
)
453 struct joydev_client
*client
= file
->private_data
;
454 struct joydev
*joydev
= client
->joydev
;
455 void __user
*argp
= (void __user
*)arg
;
461 case JS_SET_TIMELIMIT
:
462 return get_user(joydev
->glue
.JS_TIMELIMIT
, (long __user
*) arg
);
463 case JS_GET_TIMELIMIT
:
464 return put_user(joydev
->glue
.JS_TIMELIMIT
, (long __user
*) arg
);
466 return copy_from_user(&joydev
->glue
, argp
,
467 sizeof(joydev
->glue
)) ? -EFAULT
: 0;
469 return copy_to_user(argp
, &joydev
->glue
,
470 sizeof(joydev
->glue
)) ? -EFAULT
: 0;
472 return joydev_ioctl_common(joydev
, cmd
, argp
);
476 static const struct file_operations joydev_fops
= {
477 .owner
= THIS_MODULE
,
479 .write
= joydev_write
,
482 .release
= joydev_release
,
483 .ioctl
= joydev_ioctl
,
485 .compat_ioctl
= joydev_compat_ioctl
,
487 .fasync
= joydev_fasync
,
490 static int joydev_connect(struct input_handler
*handler
, struct input_dev
*dev
,
491 const struct input_device_id
*id
)
493 struct joydev
*joydev
;
497 for (minor
= 0; minor
< JOYDEV_MINORS
&& joydev_table
[minor
]; minor
++);
498 if (minor
== JOYDEV_MINORS
) {
499 printk(KERN_ERR
"joydev: no more free joydev devices\n");
503 joydev
= kzalloc(sizeof(struct joydev
), GFP_KERNEL
);
507 INIT_LIST_HEAD(&joydev
->client_list
);
508 init_waitqueue_head(&joydev
->wait
);
510 joydev
->minor
= minor
;
512 joydev
->handle
.dev
= dev
;
513 joydev
->handle
.name
= joydev
->name
;
514 joydev
->handle
.handler
= handler
;
515 joydev
->handle
.private = joydev
;
516 snprintf(joydev
->name
, sizeof(joydev
->name
), "js%d", minor
);
518 for (i
= 0; i
< ABS_MAX
+ 1; i
++)
519 if (test_bit(i
, dev
->absbit
)) {
520 joydev
->absmap
[i
] = joydev
->nabs
;
521 joydev
->abspam
[joydev
->nabs
] = i
;
525 for (i
= BTN_JOYSTICK
- BTN_MISC
; i
< KEY_MAX
- BTN_MISC
+ 1; i
++)
526 if (test_bit(i
+ BTN_MISC
, dev
->keybit
)) {
527 joydev
->keymap
[i
] = joydev
->nkey
;
528 joydev
->keypam
[joydev
->nkey
] = i
+ BTN_MISC
;
532 for (i
= 0; i
< BTN_JOYSTICK
- BTN_MISC
; i
++)
533 if (test_bit(i
+ BTN_MISC
, dev
->keybit
)) {
534 joydev
->keymap
[i
] = joydev
->nkey
;
535 joydev
->keypam
[joydev
->nkey
] = i
+ BTN_MISC
;
539 for (i
= 0; i
< joydev
->nabs
; i
++) {
540 j
= joydev
->abspam
[i
];
541 if (dev
->absmax
[j
] == dev
->absmin
[j
]) {
542 joydev
->corr
[i
].type
= JS_CORR_NONE
;
543 joydev
->abs
[i
] = dev
->abs
[j
];
546 joydev
->corr
[i
].type
= JS_CORR_BROKEN
;
547 joydev
->corr
[i
].prec
= dev
->absfuzz
[j
];
548 joydev
->corr
[i
].coef
[0] = (dev
->absmax
[j
] + dev
->absmin
[j
]) / 2 - dev
->absflat
[j
];
549 joydev
->corr
[i
].coef
[1] = (dev
->absmax
[j
] + dev
->absmin
[j
]) / 2 + dev
->absflat
[j
];
550 if (!(t
= ((dev
->absmax
[j
] - dev
->absmin
[j
]) / 2 - 2 * dev
->absflat
[j
])))
552 joydev
->corr
[i
].coef
[2] = (1 << 29) / t
;
553 joydev
->corr
[i
].coef
[3] = (1 << 29) / t
;
555 joydev
->abs
[i
] = joydev_correct(dev
->abs
[j
], joydev
->corr
+ i
);
558 snprintf(joydev
->dev
.bus_id
, sizeof(joydev
->dev
.bus_id
),
560 joydev
->dev
.class = &input_class
;
561 joydev
->dev
.parent
= &dev
->dev
;
562 joydev
->dev
.devt
= MKDEV(INPUT_MAJOR
, JOYDEV_MINOR_BASE
+ minor
);
563 joydev
->dev
.release
= joydev_free
;
564 device_initialize(&joydev
->dev
);
566 joydev_table
[minor
] = joydev
;
568 error
= device_add(&joydev
->dev
);
570 goto err_free_joydev
;
572 error
= input_register_handle(&joydev
->handle
);
574 goto err_delete_joydev
;
579 device_del(&joydev
->dev
);
581 put_device(&joydev
->dev
);
586 static void joydev_disconnect(struct input_handle
*handle
)
588 struct joydev
*joydev
= handle
->private;
589 struct joydev_client
*client
;
591 input_unregister_handle(handle
);
592 device_del(&joydev
->dev
);
597 input_close_device(handle
);
598 list_for_each_entry(client
, &joydev
->client_list
, node
)
599 kill_fasync(&client
->fasync
, SIGIO
, POLL_HUP
);
600 wake_up_interruptible(&joydev
->wait
);
603 put_device(&joydev
->dev
);
606 static const struct input_device_id joydev_blacklist
[] = {
608 .flags
= INPUT_DEVICE_ID_MATCH_EVBIT
| INPUT_DEVICE_ID_MATCH_KEYBIT
,
609 .evbit
= { BIT(EV_KEY
) },
610 .keybit
= { [LONG(BTN_TOUCH
)] = BIT(BTN_TOUCH
) },
611 }, /* Avoid itouchpads, touchscreens and tablets */
612 { } /* Terminating entry */
615 static const struct input_device_id joydev_ids
[] = {
617 .flags
= INPUT_DEVICE_ID_MATCH_EVBIT
| INPUT_DEVICE_ID_MATCH_ABSBIT
,
618 .evbit
= { BIT(EV_ABS
) },
619 .absbit
= { BIT(ABS_X
) },
622 .flags
= INPUT_DEVICE_ID_MATCH_EVBIT
| INPUT_DEVICE_ID_MATCH_ABSBIT
,
623 .evbit
= { BIT(EV_ABS
) },
624 .absbit
= { BIT(ABS_WHEEL
) },
627 .flags
= INPUT_DEVICE_ID_MATCH_EVBIT
| INPUT_DEVICE_ID_MATCH_ABSBIT
,
628 .evbit
= { BIT(EV_ABS
) },
629 .absbit
= { BIT(ABS_THROTTLE
) },
631 { } /* Terminating entry */
634 MODULE_DEVICE_TABLE(input
, joydev_ids
);
636 static struct input_handler joydev_handler
= {
637 .event
= joydev_event
,
638 .connect
= joydev_connect
,
639 .disconnect
= joydev_disconnect
,
640 .fops
= &joydev_fops
,
641 .minor
= JOYDEV_MINOR_BASE
,
643 .id_table
= joydev_ids
,
644 .blacklist
= joydev_blacklist
,
647 static int __init
joydev_init(void)
649 return input_register_handler(&joydev_handler
);
652 static void __exit
joydev_exit(void)
654 input_unregister_handler(&joydev_handler
);
657 module_init(joydev_init
);
658 module_exit(joydev_exit
);