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);