evdev.c 22.3 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10
/*
 * Event char devices, giving access to raw input device events.
 *
 * Copyright (c) 1999-2002 Vojtech Pavlik
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 as published by
 * the Free Software Foundation.
 */

J
Joe Perches 已提交
11 12
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt

L
Linus Torvalds 已提交
13 14
#define EVDEV_MINOR_BASE	64
#define EVDEV_MINORS		32
15 16
#define EVDEV_MIN_BUFFER_SIZE	64U
#define EVDEV_BUF_PACKETS	8
L
Linus Torvalds 已提交
17 18

#include <linux/poll.h>
19
#include <linux/sched.h>
L
Linus Torvalds 已提交
20 21 22 23 24 25
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/input.h>
#include <linux/major.h>
#include <linux/device.h>
26
#include "input-compat.h"
L
Linus Torvalds 已提交
27 28 29 30 31 32

struct evdev {
	int open;
	int minor;
	struct input_handle handle;
	wait_queue_head_t wait;
A
Arnd Bergmann 已提交
33
	struct evdev_client __rcu *grab;
34
	struct list_head client_list;
35 36
	spinlock_t client_lock; /* protects client_list */
	struct mutex mutex;
37
	struct device dev;
38
	bool exist;
L
Linus Torvalds 已提交
39 40
};

41
struct evdev_client {
42 43
	unsigned int head;
	unsigned int tail;
44
	spinlock_t buffer_lock; /* protects access to buffer, head and tail */
L
Linus Torvalds 已提交
45 46 47
	struct fasync_struct *fasync;
	struct evdev *evdev;
	struct list_head node;
48
	unsigned int bufsize;
49
	struct input_event buffer[];
L
Linus Torvalds 已提交
50 51 52
};

static struct evdev *evdev_table[EVDEV_MINORS];
53
static DEFINE_MUTEX(evdev_table_mutex);
L
Linus Torvalds 已提交
54

55 56 57
static void evdev_pass_event(struct evdev_client *client,
			     struct input_event *event)
{
58
	/* Interrupts are disabled, just acquire the lock. */
59
	spin_lock(&client->buffer_lock);
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76

	client->buffer[client->head++] = *event;
	client->head &= client->bufsize - 1;

	if (unlikely(client->head == client->tail)) {
		/*
		 * This effectively "drops" all unconsumed events, leaving
		 * EV_SYN/SYN_DROPPED plus the newest event in the queue.
		 */
		client->tail = (client->head - 2) & (client->bufsize - 1);

		client->buffer[client->tail].time = event->time;
		client->buffer[client->tail].type = EV_SYN;
		client->buffer[client->tail].code = SYN_DROPPED;
		client->buffer[client->tail].value = 0;
	}

77 78
	spin_unlock(&client->buffer_lock);

79 80
	if (event->type == EV_SYN)
		kill_fasync(&client->fasync, SIGIO, POLL_IN);
81 82 83
}

/*
D
Dmitry Torokhov 已提交
84
 * Pass incoming event to all connected clients.
85 86 87
 */
static void evdev_event(struct input_handle *handle,
			unsigned int type, unsigned int code, int value)
L
Linus Torvalds 已提交
88 89
{
	struct evdev *evdev = handle->private;
90
	struct evdev_client *client;
91
	struct input_event event;
L
Linus Torvalds 已提交
92

93 94 95 96
	do_gettimeofday(&event.time);
	event.type = type;
	event.code = code;
	event.value = value;
L
Linus Torvalds 已提交
97

D
Dmitry Torokhov 已提交
98 99
	rcu_read_lock();

100 101 102 103 104 105
	client = rcu_dereference(evdev->grab);
	if (client)
		evdev_pass_event(client, &event);
	else
		list_for_each_entry_rcu(client, &evdev->client_list, node)
			evdev_pass_event(client, &event);
L
Linus Torvalds 已提交
106

D
Dmitry Torokhov 已提交
107 108
	rcu_read_unlock();

L
Linus Torvalds 已提交
109 110 111 112 113
	wake_up_interruptible(&evdev->wait);
}

static int evdev_fasync(int fd, struct file *file, int on)
{
114
	struct evdev_client *client = file->private_data;
115

116
	return fasync_helper(fd, file, on, &client->fasync);
L
Linus Torvalds 已提交
117 118
}

119
static int evdev_flush(struct file *file, fl_owner_t id)
L
Linus Torvalds 已提交
120
{
121 122
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
123 124 125 126 127
	int retval;

	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;
128

129
	if (!evdev->exist)
130 131 132
		retval = -ENODEV;
	else
		retval = input_flush_device(&evdev->handle, file);
133

134 135
	mutex_unlock(&evdev->mutex);
	return retval;
L
Linus Torvalds 已提交
136 137
}

138
static void evdev_free(struct device *dev)
L
Linus Torvalds 已提交
139
{
140 141
	struct evdev *evdev = container_of(dev, struct evdev, dev);

142
	input_put_device(evdev->handle.dev);
L
Linus Torvalds 已提交
143 144 145
	kfree(evdev);
}

146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161
/*
 * Grabs an event device (along with underlying input device).
 * This function is called with evdev->mutex taken.
 */
static int evdev_grab(struct evdev *evdev, struct evdev_client *client)
{
	int error;

	if (evdev->grab)
		return -EBUSY;

	error = input_grab_device(&evdev->handle);
	if (error)
		return error;

	rcu_assign_pointer(evdev->grab, client);
D
Dmitry Torokhov 已提交
162
	synchronize_rcu();
163 164 165 166 167 168 169 170 171 172

	return 0;
}

static int evdev_ungrab(struct evdev *evdev, struct evdev_client *client)
{
	if (evdev->grab != client)
		return  -EINVAL;

	rcu_assign_pointer(evdev->grab, NULL);
D
Dmitry Torokhov 已提交
173
	synchronize_rcu();
174 175 176 177 178 179 180 181 182 183 184
	input_release_device(&evdev->handle);

	return 0;
}

static void evdev_attach_client(struct evdev *evdev,
				struct evdev_client *client)
{
	spin_lock(&evdev->client_lock);
	list_add_tail_rcu(&client->node, &evdev->client_list);
	spin_unlock(&evdev->client_lock);
D
Dmitry Torokhov 已提交
185
	synchronize_rcu();
186 187 188 189 190 191 192 193
}

static void evdev_detach_client(struct evdev *evdev,
				struct evdev_client *client)
{
	spin_lock(&evdev->client_lock);
	list_del_rcu(&client->node);
	spin_unlock(&evdev->client_lock);
D
Dmitry Torokhov 已提交
194
	synchronize_rcu();
195 196 197 198 199 200 201 202 203 204 205 206
}

static int evdev_open_device(struct evdev *evdev)
{
	int retval;

	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;

	if (!evdev->exist)
		retval = -ENODEV;
207
	else if (!evdev->open++) {
208
		retval = input_open_device(&evdev->handle);
209 210 211
		if (retval)
			evdev->open--;
	}
212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242

	mutex_unlock(&evdev->mutex);
	return retval;
}

static void evdev_close_device(struct evdev *evdev)
{
	mutex_lock(&evdev->mutex);

	if (evdev->exist && !--evdev->open)
		input_close_device(&evdev->handle);

	mutex_unlock(&evdev->mutex);
}

/*
 * Wake up users waiting for IO so they can disconnect from
 * dead device.
 */
static void evdev_hangup(struct evdev *evdev)
{
	struct evdev_client *client;

	spin_lock(&evdev->client_lock);
	list_for_each_entry(client, &evdev->client_list, node)
		kill_fasync(&client->fasync, SIGIO, POLL_HUP);
	spin_unlock(&evdev->client_lock);

	wake_up_interruptible(&evdev->wait);
}

243
static int evdev_release(struct inode *inode, struct file *file)
L
Linus Torvalds 已提交
244
{
245 246
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
247

248 249 250 251
	mutex_lock(&evdev->mutex);
	if (evdev->grab == client)
		evdev_ungrab(evdev, client);
	mutex_unlock(&evdev->mutex);
L
Linus Torvalds 已提交
252

253
	evdev_detach_client(evdev, client);
254
	kfree(client);
L
Linus Torvalds 已提交
255

256
	evdev_close_device(evdev);
257
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
258 259 260 261

	return 0;
}

262 263
static unsigned int evdev_compute_buffer_size(struct input_dev *dev)
{
264 265 266 267 268
	unsigned int n_events =
		max(dev->hint_events_per_packet * EVDEV_BUF_PACKETS,
		    EVDEV_MIN_BUFFER_SIZE);

	return roundup_pow_of_two(n_events);
269 270
}

271
static int evdev_open(struct inode *inode, struct file *file)
L
Linus Torvalds 已提交
272
{
273
	struct evdev *evdev;
274
	struct evdev_client *client;
L
Linus Torvalds 已提交
275
	int i = iminor(inode) - EVDEV_MINOR_BASE;
276
	unsigned int bufsize;
277
	int error;
L
Linus Torvalds 已提交
278

279
	if (i >= EVDEV_MINORS)
L
Linus Torvalds 已提交
280 281
		return -ENODEV;

282 283 284
	error = mutex_lock_interruptible(&evdev_table_mutex);
	if (error)
		return error;
285
	evdev = evdev_table[i];
286 287 288
	if (evdev)
		get_device(&evdev->dev);
	mutex_unlock(&evdev_table_mutex);
289

290
	if (!evdev)
L
Linus Torvalds 已提交
291 292
		return -ENODEV;

293 294 295 296 297
	bufsize = evdev_compute_buffer_size(evdev->handle.dev);

	client = kzalloc(sizeof(struct evdev_client) +
				bufsize * sizeof(struct input_event),
			 GFP_KERNEL);
298 299 300 301
	if (!client) {
		error = -ENOMEM;
		goto err_put_evdev;
	}
L
Linus Torvalds 已提交
302

303
	client->bufsize = bufsize;
304
	spin_lock_init(&client->buffer_lock);
305
	client->evdev = evdev;
306
	evdev_attach_client(evdev, client);
L
Linus Torvalds 已提交
307

308 309 310
	error = evdev_open_device(evdev);
	if (error)
		goto err_free_client;
L
Linus Torvalds 已提交
311

312
	file->private_data = client;
313 314
	nonseekable_open(inode, file);

L
Linus Torvalds 已提交
315
	return 0;
316 317

 err_free_client:
318
	evdev_detach_client(evdev, client);
319 320 321 322
	kfree(client);
 err_put_evdev:
	put_device(&evdev->dev);
	return error;
L
Linus Torvalds 已提交
323 324
}

325 326
static ssize_t evdev_write(struct file *file, const char __user *buffer,
			   size_t count, loff_t *ppos)
327
{
328 329
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
330
	struct input_event event;
331
	int retval;
332

333 334 335
	if (count < input_event_size())
		return -EINVAL;

336 337 338 339 340 341 342 343
	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;

	if (!evdev->exist) {
		retval = -ENODEV;
		goto out;
	}
344

345
	do {
346
		if (input_event_from_user(buffer + retval, &event)) {
347 348 349
			retval = -EFAULT;
			goto out;
		}
350
		retval += input_event_size();
351 352 353

		input_inject_event(&evdev->handle,
				   event.type, event.code, event.value);
354
	} while (retval + input_event_size() <= count);
355

356 357
 out:
	mutex_unlock(&evdev->mutex);
358 359 360
	return retval;
}

361 362 363 364 365 366 367 368 369 370
static int evdev_fetch_next_event(struct evdev_client *client,
				  struct input_event *event)
{
	int have_event;

	spin_lock_irq(&client->buffer_lock);

	have_event = client->head != client->tail;
	if (have_event) {
		*event = client->buffer[client->tail++];
371
		client->tail &= client->bufsize - 1;
372 373 374 375 376 377 378 379 380
	}

	spin_unlock_irq(&client->buffer_lock);

	return have_event;
}

static ssize_t evdev_read(struct file *file, char __user *buffer,
			  size_t count, loff_t *ppos)
L
Linus Torvalds 已提交
381
{
382 383
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
384
	struct input_event event;
L
Linus Torvalds 已提交
385 386
	int retval;

387
	if (count < input_event_size())
L
Linus Torvalds 已提交
388 389
		return -EINVAL;

390 391
	if (client->head == client->tail && evdev->exist &&
	    (file->f_flags & O_NONBLOCK))
L
Linus Torvalds 已提交
392 393
		return -EAGAIN;

394 395
	retval = wait_event_interruptible(evdev->wait,
		client->head != client->tail || !evdev->exist);
L
Linus Torvalds 已提交
396 397 398
	if (retval)
		return retval;

399
	if (!evdev->exist)
L
Linus Torvalds 已提交
400 401
		return -ENODEV;

402
	while (retval + input_event_size() <= count &&
403
	       evdev_fetch_next_event(client, &event)) {
404

405
		if (input_event_to_user(buffer + retval, &event))
406 407
			return -EFAULT;

408
		retval += input_event_size();
L
Linus Torvalds 已提交
409 410 411 412 413 414 415 416
	}

	return retval;
}

/* No kernel lock - fine */
static unsigned int evdev_poll(struct file *file, poll_table *wait)
{
417 418
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
419
	unsigned int mask;
420

421
	poll_wait(file, &evdev->wait, wait);
422 423 424 425 426 427

	mask = evdev->exist ? POLLOUT | POLLWRNORM : POLLHUP | POLLERR;
	if (client->head != client->tail)
		mask |= POLLIN | POLLRDNORM;

	return mask;
L
Linus Torvalds 已提交
428 429
}

430 431 432
#ifdef CONFIG_COMPAT

#define BITS_PER_LONG_COMPAT (sizeof(compat_long_t) * 8)
433
#define BITS_TO_LONGS_COMPAT(x) ((((x) - 1) / BITS_PER_LONG_COMPAT) + 1)
434 435 436 437 438 439 440 441

#ifdef __BIG_ENDIAN
static int bits_to_user(unsigned long *bits, unsigned int maxbit,
			unsigned int maxlen, void __user *p, int compat)
{
	int len, i;

	if (compat) {
442
		len = BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t);
443
		if (len > maxlen)
444 445 446 447 448 449 450 451 452
			len = maxlen;

		for (i = 0; i < len / sizeof(compat_long_t); i++)
			if (copy_to_user((compat_long_t __user *) p + i,
					 (compat_long_t *) bits +
						i + 1 - ((i % 2) << 1),
					 sizeof(compat_long_t)))
				return -EFAULT;
	} else {
453
		len = BITS_TO_LONGS(maxbit) * sizeof(long);
454 455 456 457 458 459 460 461 462 463 464 465 466 467
		if (len > maxlen)
			len = maxlen;

		if (copy_to_user(p, bits, len))
			return -EFAULT;
	}

	return len;
}
#else
static int bits_to_user(unsigned long *bits, unsigned int maxbit,
			unsigned int maxlen, void __user *p, int compat)
{
	int len = compat ?
468 469
			BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t) :
			BITS_TO_LONGS(maxbit) * sizeof(long);
470 471 472 473 474 475 476 477 478 479 480 481 482

	if (len > maxlen)
		len = maxlen;

	return copy_to_user(p, bits, len) ? -EFAULT : len;
}
#endif /* __BIG_ENDIAN */

#else

static int bits_to_user(unsigned long *bits, unsigned int maxbit,
			unsigned int maxlen, void __user *p, int compat)
{
483
	int len = BITS_TO_LONGS(maxbit) * sizeof(long);
484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506

	if (len > maxlen)
		len = maxlen;

	return copy_to_user(p, bits, len) ? -EFAULT : len;
}

#endif /* CONFIG_COMPAT */

static int str_to_user(const char *str, unsigned int maxlen, void __user *p)
{
	int len;

	if (!str)
		return -ENOENT;

	len = strlen(str) + 1;
	if (len > maxlen)
		len = maxlen;

	return copy_to_user(p, str, len) ? -EFAULT : len;
}

507
#define OLD_KEY_MAX	0x1ff
508 509 510
static int handle_eviocgbit(struct input_dev *dev,
			    unsigned int type, unsigned int size,
			    void __user *p, int compat_mode)
511
{
512
	static unsigned long keymax_warn_time;
513 514 515
	unsigned long *bits;
	int len;

516
	switch (type) {
517 518 519 520 521 522 523 524 525 526 527 528

	case      0: bits = dev->evbit;  len = EV_MAX;  break;
	case EV_KEY: bits = dev->keybit; len = KEY_MAX; break;
	case EV_REL: bits = dev->relbit; len = REL_MAX; break;
	case EV_ABS: bits = dev->absbit; len = ABS_MAX; break;
	case EV_MSC: bits = dev->mscbit; len = MSC_MAX; break;
	case EV_LED: bits = dev->ledbit; len = LED_MAX; break;
	case EV_SND: bits = dev->sndbit; len = SND_MAX; break;
	case EV_FF:  bits = dev->ffbit;  len = FF_MAX;  break;
	case EV_SW:  bits = dev->swbit;  len = SW_MAX;  break;
	default: return -EINVAL;
	}
529 530 531 532 533 534

	/*
	 * Work around bugs in userspace programs that like to do
	 * EVIOCGBIT(EV_KEY, KEY_MAX) and not realize that 'len'
	 * should be in bytes, not in bits.
	 */
535
	if (type == EV_KEY && size == OLD_KEY_MAX) {
536 537
		len = OLD_KEY_MAX;
		if (printk_timed_ratelimit(&keymax_warn_time, 10 * 1000))
J
Joe Perches 已提交
538 539 540 541 542
			pr_warning("(EVIOCGBIT): Suspicious buffer size %u, "
				   "limiting output to %zu bytes. See "
				   "http://userweb.kernel.org/~dtor/eviocgbit-bug.html\n",
				   OLD_KEY_MAX,
				   BITS_TO_LONGS(OLD_KEY_MAX) * sizeof(long));
543 544
	}

545
	return bits_to_user(bits, len, size, p, compat_mode);
546
}
547
#undef OLD_KEY_MAX
548

549
static int evdev_handle_get_keycode(struct input_dev *dev, void __user *p)
550
{
551 552 553 554 555
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
556 557
	int error;

558 559 560
	/* legacy case */
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
561

562 563 564
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
565

566 567
	if (put_user(ke.keycode, ip + 1))
		return -EFAULT;
568

569 570
	return 0;
}
571

572 573 574 575
static int evdev_handle_get_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
	int error;
576

577 578
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
579

580 581 582
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
583

584 585
	if (copy_to_user(p, &ke, sizeof(ke)))
		return -EFAULT;
586 587 588 589

	return 0;
}

590
static int evdev_handle_set_keycode(struct input_dev *dev, void __user *p)
591
{
592 593 594 595 596
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
597

598 599
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
600

601 602
	if (get_user(ke.keycode, ip + 1))
		return -EFAULT;
603

604 605
	return input_set_keycode(dev, &ke);
}
606

607 608 609
static int evdev_handle_set_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
610

611 612
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
613

614 615
	if (ke.len > sizeof(ke.scancode))
		return -EINVAL;
616 617 618 619

	return input_set_keycode(dev, &ke);
}

620 621
static long evdev_do_ioctl(struct file *file, unsigned int cmd,
			   void __user *p, int compat_mode)
L
Linus Torvalds 已提交
622
{
623 624
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
625 626
	struct input_dev *dev = evdev->handle.dev;
	struct input_absinfo abs;
627
	struct ff_effect effect;
628
	int __user *ip = (int __user *)p;
629
	unsigned int i, t, u, v;
630
	unsigned int size;
631
	int error;
L
Linus Torvalds 已提交
632

633
	/* First we check for fixed-length commands */
L
Linus Torvalds 已提交
634 635
	switch (cmd) {

636 637
	case EVIOCGVERSION:
		return put_user(EV_VERSION, ip);
L
Linus Torvalds 已提交
638

639 640 641 642
	case EVIOCGID:
		if (copy_to_user(p, &dev->id, sizeof(struct input_id)))
			return -EFAULT;
		return 0;
643

644 645 646 647 648 649 650 651
	case EVIOCGREP:
		if (!test_bit(EV_REP, dev->evbit))
			return -ENOSYS;
		if (put_user(dev->rep[REP_DELAY], ip))
			return -EFAULT;
		if (put_user(dev->rep[REP_PERIOD], ip + 1))
			return -EFAULT;
		return 0;
652

653 654 655 656 657 658 659
	case EVIOCSREP:
		if (!test_bit(EV_REP, dev->evbit))
			return -ENOSYS;
		if (get_user(u, ip))
			return -EFAULT;
		if (get_user(v, ip + 1))
			return -EFAULT;
660

661 662
		input_inject_event(&evdev->handle, EV_REP, REP_DELAY, u);
		input_inject_event(&evdev->handle, EV_REP, REP_PERIOD, v);
663

664
		return 0;
L
Linus Torvalds 已提交
665

666 667
	case EVIOCRMFF:
		return input_ff_erase(dev, (int)(unsigned long) p, file);
L
Linus Torvalds 已提交
668

669 670 671 672 673 674 675 676 677 678 679 680
	case EVIOCGEFFECTS:
		i = test_bit(EV_FF, dev->evbit) ?
				dev->ff->max_effects : 0;
		if (put_user(i, ip))
			return -EFAULT;
		return 0;

	case EVIOCGRAB:
		if (p)
			return evdev_grab(evdev, client);
		else
			return evdev_ungrab(evdev, client);
681 682 683 684 685 686 687 688 689 690 691 692

	case EVIOCGKEYCODE:
		return evdev_handle_get_keycode(dev, p);

	case EVIOCSKEYCODE:
		return evdev_handle_set_keycode(dev, p);

	case EVIOCGKEYCODE_V2:
		return evdev_handle_get_keycode_v2(dev, p);

	case EVIOCSKEYCODE_V2:
		return evdev_handle_set_keycode_v2(dev, p);
693
	}
L
Linus Torvalds 已提交
694

695
	size = _IOC_SIZE(cmd);
L
Linus Torvalds 已提交
696

697 698 699
	/* Now check variable-length commands */
#define EVIOC_MASK_SIZE(nr)	((nr) & ~(_IOC_SIZEMASK << _IOC_SIZESHIFT))
	switch (EVIOC_MASK_SIZE(cmd)) {
700

701 702 703 704
	case EVIOCGPROP(0):
		return bits_to_user(dev->propbit, INPUT_PROP_MAX,
				    size, p, compat_mode);

705 706
	case EVIOCGKEY(0):
		return bits_to_user(dev->key, KEY_MAX, size, p, compat_mode);
L
Linus Torvalds 已提交
707

708 709
	case EVIOCGLED(0):
		return bits_to_user(dev->led, LED_MAX, size, p, compat_mode);
L
Linus Torvalds 已提交
710

711 712
	case EVIOCGSND(0):
		return bits_to_user(dev->snd, SND_MAX, size, p, compat_mode);
L
Linus Torvalds 已提交
713

714 715
	case EVIOCGSW(0):
		return bits_to_user(dev->sw, SW_MAX, size, p, compat_mode);
716

717 718
	case EVIOCGNAME(0):
		return str_to_user(dev->name, size, p);
L
Linus Torvalds 已提交
719

720 721
	case EVIOCGPHYS(0):
		return str_to_user(dev->phys, size, p);
L
Linus Torvalds 已提交
722

723 724
	case EVIOCGUNIQ(0):
		return str_to_user(dev->uniq, size, p);
L
Linus Torvalds 已提交
725

726 727 728
	case EVIOC_MASK_SIZE(EVIOCSFF):
		if (input_ff_effect_from_user(p, size, &effect))
			return -EFAULT;
L
Linus Torvalds 已提交
729

730
		error = input_ff_upload(dev, &effect, file);
L
Linus Torvalds 已提交
731

732 733
		if (put_user(effect.id, &(((struct ff_effect __user *)p)->id)))
			return -EFAULT;
734

735 736
		return error;
	}
L
Linus Torvalds 已提交
737

738 739 740
	/* Multi-number variable-length handlers */
	if (_IOC_TYPE(cmd) != 'E')
		return -EINVAL;
L
Linus Torvalds 已提交
741

742
	if (_IOC_DIR(cmd) == _IOC_READ) {
743

744 745 746 747
		if ((_IOC_NR(cmd) & ~EV_MAX) == _IOC_NR(EVIOCGBIT(0, 0)))
			return handle_eviocgbit(dev,
						_IOC_NR(cmd) & EV_MAX, size,
						p, compat_mode);
L
Linus Torvalds 已提交
748

749
		if ((_IOC_NR(cmd) & ~ABS_MAX) == _IOC_NR(EVIOCGABS(0))) {
750

751 752 753
			if (!dev->absinfo)
				return -EINVAL;

754 755
			t = _IOC_NR(cmd) & ABS_MAX;
			abs = dev->absinfo[t];
756

757 758 759
			if (copy_to_user(p, &abs, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
760

761 762 763
			return 0;
		}
	}
764

765
	if (_IOC_DIR(cmd) == _IOC_WRITE) {
766

767
		if ((_IOC_NR(cmd) & ~ABS_MAX) == _IOC_NR(EVIOCSABS(0))) {
L
Linus Torvalds 已提交
768

769 770 771
			if (!dev->absinfo)
				return -EINVAL;

772
			t = _IOC_NR(cmd) & ABS_MAX;
773

774 775 776
			if (copy_from_user(&abs, p, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
L
Linus Torvalds 已提交
777

778 779
			if (size < sizeof(struct input_absinfo))
				abs.resolution = 0;
780

781 782 783
			/* We can't change number of reserved MT slots */
			if (t == ABS_MT_SLOT)
				return -EINVAL;
H
Henrik Rydberg 已提交
784

785 786 787 788 789 790 791 792
			/*
			 * Take event lock to ensure that we are not
			 * changing device parameters in the middle
			 * of event.
			 */
			spin_lock_irq(&dev->event_lock);
			dev->absinfo[t] = abs;
			spin_unlock_irq(&dev->event_lock);
793

794
			return 0;
795
		}
L
Linus Torvalds 已提交
796
	}
797

L
Linus Torvalds 已提交
798 799 800
	return -EINVAL;
}

801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823
static long evdev_ioctl_handler(struct file *file, unsigned int cmd,
				void __user *p, int compat_mode)
{
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
	int retval;

	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;

	if (!evdev->exist) {
		retval = -ENODEV;
		goto out;
	}

	retval = evdev_do_ioctl(file, cmd, p, compat_mode);

 out:
	mutex_unlock(&evdev->mutex);
	return retval;
}

824 825 826 827
static long evdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
{
	return evdev_ioctl_handler(file, cmd, (void __user *)arg, 0);
}
828

829
#ifdef CONFIG_COMPAT
830 831
static long evdev_ioctl_compat(struct file *file,
				unsigned int cmd, unsigned long arg)
832
{
833
	return evdev_ioctl_handler(file, cmd, compat_ptr(arg), 1);
L
Linus Torvalds 已提交
834
}
835
#endif
L
Linus Torvalds 已提交
836

D
Dmitry Torokhov 已提交
837
static const struct file_operations evdev_fops = {
838 839 840 841 842 843 844
	.owner		= THIS_MODULE,
	.read		= evdev_read,
	.write		= evdev_write,
	.poll		= evdev_poll,
	.open		= evdev_open,
	.release	= evdev_release,
	.unlocked_ioctl	= evdev_ioctl,
845
#ifdef CONFIG_COMPAT
846
	.compat_ioctl	= evdev_ioctl_compat,
847
#endif
848
	.fasync		= evdev_fasync,
849 850
	.flush		= evdev_flush,
	.llseek		= no_llseek,
L
Linus Torvalds 已提交
851 852
};

853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880
static int evdev_install_chrdev(struct evdev *evdev)
{
	/*
	 * No need to do any locking here as calls to connect and
	 * disconnect are serialized by the input core
	 */
	evdev_table[evdev->minor] = evdev;
	return 0;
}

static void evdev_remove_chrdev(struct evdev *evdev)
{
	/*
	 * Lock evdev table to prevent race with evdev_open()
	 */
	mutex_lock(&evdev_table_mutex);
	evdev_table[evdev->minor] = NULL;
	mutex_unlock(&evdev_table_mutex);
}

/*
 * Mark device non-existent. This disables writes, ioctls and
 * prevents new users from opening the device. Already posted
 * blocking reads will stay, however new ones will fail.
 */
static void evdev_mark_dead(struct evdev *evdev)
{
	mutex_lock(&evdev->mutex);
881
	evdev->exist = false;
882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903
	mutex_unlock(&evdev->mutex);
}

static void evdev_cleanup(struct evdev *evdev)
{
	struct input_handle *handle = &evdev->handle;

	evdev_mark_dead(evdev);
	evdev_hangup(evdev);
	evdev_remove_chrdev(evdev);

	/* evdev is marked dead so no one else accesses evdev->open */
	if (evdev->open) {
		input_flush_device(handle, NULL);
		input_close_device(handle);
	}
}

/*
 * Create new evdev device. Note that input core serializes calls
 * to connect and disconnect so we don't need to lock evdev_table here.
 */
904 905
static int evdev_connect(struct input_handler *handler, struct input_dev *dev,
			 const struct input_device_id *id)
L
Linus Torvalds 已提交
906 907 908
{
	struct evdev *evdev;
	int minor;
909
	int error;
L
Linus Torvalds 已提交
910

911 912 913 914
	for (minor = 0; minor < EVDEV_MINORS; minor++)
		if (!evdev_table[minor])
			break;

L
Linus Torvalds 已提交
915
	if (minor == EVDEV_MINORS) {
J
Joe Perches 已提交
916
		pr_err("no more free evdev devices\n");
917
		return -ENFILE;
L
Linus Torvalds 已提交
918 919
	}

920 921 922
	evdev = kzalloc(sizeof(struct evdev), GFP_KERNEL);
	if (!evdev)
		return -ENOMEM;
L
Linus Torvalds 已提交
923

924
	INIT_LIST_HEAD(&evdev->client_list);
925 926
	spin_lock_init(&evdev->client_lock);
	mutex_init(&evdev->mutex);
L
Linus Torvalds 已提交
927 928
	init_waitqueue_head(&evdev->wait);

929
	dev_set_name(&evdev->dev, "event%d", minor);
930
	evdev->exist = true;
L
Linus Torvalds 已提交
931
	evdev->minor = minor;
932

933
	evdev->handle.dev = input_get_device(dev);
934
	evdev->handle.name = dev_name(&evdev->dev);
L
Linus Torvalds 已提交
935 936 937
	evdev->handle.handler = handler;
	evdev->handle.private = evdev;

938
	evdev->dev.devt = MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor);
939 940 941 942
	evdev->dev.class = &input_class;
	evdev->dev.parent = &dev->dev;
	evdev->dev.release = evdev_free;
	device_initialize(&evdev->dev);
943

944
	error = input_register_handle(&evdev->handle);
945
	if (error)
946
		goto err_free_evdev;
947

948 949 950 951 952
	error = evdev_install_chrdev(evdev);
	if (error)
		goto err_unregister_handle;

	error = device_add(&evdev->dev);
953
	if (error)
954
		goto err_cleanup_evdev;
L
Linus Torvalds 已提交
955

956
	return 0;
L
Linus Torvalds 已提交
957

958 959 960 961
 err_cleanup_evdev:
	evdev_cleanup(evdev);
 err_unregister_handle:
	input_unregister_handle(&evdev->handle);
962
 err_free_evdev:
963
	put_device(&evdev->dev);
964
	return error;
L
Linus Torvalds 已提交
965 966 967 968 969 970
}

static void evdev_disconnect(struct input_handle *handle)
{
	struct evdev *evdev = handle->private;

971
	device_del(&evdev->dev);
972 973
	evdev_cleanup(evdev);
	input_unregister_handle(handle);
974
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
975 976
}

D
Dmitry Torokhov 已提交
977
static const struct input_device_id evdev_ids[] = {
L
Linus Torvalds 已提交
978 979 980 981 982 983 984
	{ .driver_info = 1 },	/* Matches all devices */
	{ },			/* Terminating zero entry */
};

MODULE_DEVICE_TABLE(input, evdev_ids);

static struct input_handler evdev_handler = {
985 986 987 988 989 990 991
	.event		= evdev_event,
	.connect	= evdev_connect,
	.disconnect	= evdev_disconnect,
	.fops		= &evdev_fops,
	.minor		= EVDEV_MINOR_BASE,
	.name		= "evdev",
	.id_table	= evdev_ids,
L
Linus Torvalds 已提交
992 993 994 995
};

static int __init evdev_init(void)
{
996
	return input_register_handler(&evdev_handler);
L
Linus Torvalds 已提交
997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009
}

static void __exit evdev_exit(void)
{
	input_unregister_handler(&evdev_handler);
}

module_init(evdev_init);
module_exit(evdev_exit);

MODULE_AUTHOR("Vojtech Pavlik <vojtech@ucw.cz>");
MODULE_DESCRIPTION("Input driver event char devices");
MODULE_LICENSE("GPL");