evdev.c 23.1 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
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/init.h>
23
#include <linux/input/mt.h>
L
Linus Torvalds 已提交
24 25
#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
	unsigned int packet_head; /* [future] position of the first element of next packet */
45
	spinlock_t buffer_lock; /* protects access to buffer, head and tail */
L
Linus Torvalds 已提交
46 47 48
	struct fasync_struct *fasync;
	struct evdev *evdev;
	struct list_head node;
49
	unsigned int bufsize;
50
	struct input_event buffer[];
L
Linus Torvalds 已提交
51 52 53
};

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

56 57 58
static void evdev_pass_event(struct evdev_client *client,
			     struct input_event *event)
{
59
	/* Interrupts are disabled, just acquire the lock. */
60
	spin_lock(&client->buffer_lock);
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
		client->packet_head = client->tail;
	}
79

80 81
	if (event->type == EV_SYN && event->code == SYN_REPORT) {
		client->packet_head = client->head;
82
		kill_fasync(&client->fasync, SIGIO, POLL_IN);
83 84 85
	}

	spin_unlock(&client->buffer_lock);
86 87 88
}

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

98 99 100 101
	do_gettimeofday(&event.time);
	event.type = type;
	event.code = code;
	event.value = value;
L
Linus Torvalds 已提交
102

D
Dmitry Torokhov 已提交
103 104
	rcu_read_lock();

105 106 107 108 109 110
	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 已提交
111

D
Dmitry Torokhov 已提交
112 113
	rcu_read_unlock();

114 115
	if (type == EV_SYN && code == SYN_REPORT)
		wake_up_interruptible(&evdev->wait);
L
Linus Torvalds 已提交
116 117 118 119
}

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

122
	return fasync_helper(fd, file, on, &client->fasync);
L
Linus Torvalds 已提交
123 124
}

125
static int evdev_flush(struct file *file, fl_owner_t id)
L
Linus Torvalds 已提交
126
{
127 128
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
129 130 131 132 133
	int retval;

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

135
	if (!evdev->exist)
136 137 138
		retval = -ENODEV;
	else
		retval = input_flush_device(&evdev->handle, file);
139

140 141
	mutex_unlock(&evdev->mutex);
	return retval;
L
Linus Torvalds 已提交
142 143
}

144
static void evdev_free(struct device *dev)
L
Linus Torvalds 已提交
145
{
146 147
	struct evdev *evdev = container_of(dev, struct evdev, dev);

148
	input_put_device(evdev->handle.dev);
L
Linus Torvalds 已提交
149 150 151
	kfree(evdev);
}

152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
/*
 * 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);

	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 已提交
178
	synchronize_rcu();
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197
	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);
}

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 已提交
198
	synchronize_rcu();
199 200 201 202 203 204 205 206 207 208 209 210
}

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;
211
	else if (!evdev->open++) {
212
		retval = input_open_device(&evdev->handle);
213 214 215
		if (retval)
			evdev->open--;
	}
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 243 244 245 246

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

247
static int evdev_release(struct inode *inode, struct file *file)
L
Linus Torvalds 已提交
248
{
249 250
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
251

252 253 254 255
	mutex_lock(&evdev->mutex);
	if (evdev->grab == client)
		evdev_ungrab(evdev, client);
	mutex_unlock(&evdev->mutex);
L
Linus Torvalds 已提交
256

257
	evdev_detach_client(evdev, client);
258
	kfree(client);
L
Linus Torvalds 已提交
259

260
	evdev_close_device(evdev);
261
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
262 263 264 265

	return 0;
}

266 267
static unsigned int evdev_compute_buffer_size(struct input_dev *dev)
{
268 269 270 271 272
	unsigned int n_events =
		max(dev->hint_events_per_packet * EVDEV_BUF_PACKETS,
		    EVDEV_MIN_BUFFER_SIZE);

	return roundup_pow_of_two(n_events);
273 274
}

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

283
	if (i >= EVDEV_MINORS)
L
Linus Torvalds 已提交
284 285
		return -ENODEV;

286 287 288
	error = mutex_lock_interruptible(&evdev_table_mutex);
	if (error)
		return error;
289
	evdev = evdev_table[i];
290 291 292
	if (evdev)
		get_device(&evdev->dev);
	mutex_unlock(&evdev_table_mutex);
293

294
	if (!evdev)
L
Linus Torvalds 已提交
295 296
		return -ENODEV;

297 298 299 300 301
	bufsize = evdev_compute_buffer_size(evdev->handle.dev);

	client = kzalloc(sizeof(struct evdev_client) +
				bufsize * sizeof(struct input_event),
			 GFP_KERNEL);
302 303 304 305
	if (!client) {
		error = -ENOMEM;
		goto err_put_evdev;
	}
L
Linus Torvalds 已提交
306

307
	client->bufsize = bufsize;
308
	spin_lock_init(&client->buffer_lock);
309
	client->evdev = evdev;
310
	evdev_attach_client(evdev, client);
L
Linus Torvalds 已提交
311

312 313 314
	error = evdev_open_device(evdev);
	if (error)
		goto err_free_client;
L
Linus Torvalds 已提交
315

316
	file->private_data = client;
317 318
	nonseekable_open(inode, file);

L
Linus Torvalds 已提交
319
	return 0;
320 321

 err_free_client:
322
	evdev_detach_client(evdev, client);
323 324 325 326
	kfree(client);
 err_put_evdev:
	put_device(&evdev->dev);
	return error;
L
Linus Torvalds 已提交
327 328
}

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

337 338 339
	if (count < input_event_size())
		return -EINVAL;

340 341 342 343 344 345 346 347
	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;

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

349
	do {
350
		if (input_event_from_user(buffer + retval, &event)) {
351 352 353
			retval = -EFAULT;
			goto out;
		}
354
		retval += input_event_size();
355 356 357

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

360 361
 out:
	mutex_unlock(&evdev->mutex);
362 363 364
	return retval;
}

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

	spin_lock_irq(&client->buffer_lock);

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

	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 已提交
385
{
386 387
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
388
	struct input_event event;
L
Linus Torvalds 已提交
389 390
	int retval;

391
	if (count < input_event_size())
L
Linus Torvalds 已提交
392 393
		return -EINVAL;

394 395 396 397 398 399 400
	if (!(file->f_flags & O_NONBLOCK)) {
		retval = wait_event_interruptible(evdev->wait,
				client->packet_head != client->tail ||
				!evdev->exist);
		if (retval)
			return retval;
	}
L
Linus Torvalds 已提交
401

402
	if (!evdev->exist)
L
Linus Torvalds 已提交
403 404
		return -ENODEV;

405
	while (retval + input_event_size() <= count &&
406
	       evdev_fetch_next_event(client, &event)) {
407

408
		if (input_event_to_user(buffer + retval, &event))
409 410
			return -EFAULT;

411
		retval += input_event_size();
L
Linus Torvalds 已提交
412 413
	}

414 415 416
	if (retval == 0 && (file->f_flags & O_NONBLOCK))
		return -EAGAIN;

L
Linus Torvalds 已提交
417 418 419 420 421 422
	return retval;
}

/* No kernel lock - fine */
static unsigned int evdev_poll(struct file *file, poll_table *wait)
{
423 424
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
425
	unsigned int mask;
426

427
	poll_wait(file, &evdev->wait, wait);
428 429

	mask = evdev->exist ? POLLOUT | POLLWRNORM : POLLHUP | POLLERR;
430
	if (client->packet_head != client->tail)
431 432 433
		mask |= POLLIN | POLLRDNORM;

	return mask;
L
Linus Torvalds 已提交
434 435
}

436 437 438
#ifdef CONFIG_COMPAT

#define BITS_PER_LONG_COMPAT (sizeof(compat_long_t) * 8)
439
#define BITS_TO_LONGS_COMPAT(x) ((((x) - 1) / BITS_PER_LONG_COMPAT) + 1)
440 441 442 443 444 445 446 447

#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) {
448
		len = BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t);
449
		if (len > maxlen)
450 451 452 453 454 455 456 457 458
			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 {
459
		len = BITS_TO_LONGS(maxbit) * sizeof(long);
460 461 462 463 464 465 466 467 468 469 470 471 472 473
		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 ?
474 475
			BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t) :
			BITS_TO_LONGS(maxbit) * sizeof(long);
476 477 478 479 480 481 482 483 484 485 486 487 488

	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)
{
489
	int len = BITS_TO_LONGS(maxbit) * sizeof(long);
490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512

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

513
#define OLD_KEY_MAX	0x1ff
514 515 516
static int handle_eviocgbit(struct input_dev *dev,
			    unsigned int type, unsigned int size,
			    void __user *p, int compat_mode)
517
{
518
	static unsigned long keymax_warn_time;
519 520 521
	unsigned long *bits;
	int len;

522
	switch (type) {
523 524 525 526 527 528 529 530 531 532 533 534

	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;
	}
535 536 537 538 539 540

	/*
	 * 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.
	 */
541
	if (type == EV_KEY && size == OLD_KEY_MAX) {
542 543
		len = OLD_KEY_MAX;
		if (printk_timed_ratelimit(&keymax_warn_time, 10 * 1000))
J
Joe Perches 已提交
544 545 546 547 548
			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));
549 550
	}

551
	return bits_to_user(bits, len, size, p, compat_mode);
552
}
553
#undef OLD_KEY_MAX
554

555
static int evdev_handle_get_keycode(struct input_dev *dev, void __user *p)
556
{
557 558 559 560 561
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
562 563
	int error;

564 565 566
	/* legacy case */
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
567

568 569 570
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
571

572 573
	if (put_user(ke.keycode, ip + 1))
		return -EFAULT;
574

575 576
	return 0;
}
577

578 579 580 581
static int evdev_handle_get_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
	int error;
582

583 584
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
585

586 587 588
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
589

590 591
	if (copy_to_user(p, &ke, sizeof(ke)))
		return -EFAULT;
592 593 594 595

	return 0;
}

596
static int evdev_handle_set_keycode(struct input_dev *dev, void __user *p)
597
{
598 599 600 601 602
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
603

604 605
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
606

607 608
	if (get_user(ke.keycode, ip + 1))
		return -EFAULT;
609

610 611
	return input_set_keycode(dev, &ke);
}
612

613 614 615
static int evdev_handle_set_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
616

617 618
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
619

620 621
	if (ke.len > sizeof(ke.scancode))
		return -EINVAL;
622 623 624 625

	return input_set_keycode(dev, &ke);
}

626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647
static int evdev_handle_mt_request(struct input_dev *dev,
				   unsigned int size,
				   int __user *ip)
{
	const struct input_mt_slot *mt = dev->mt;
	unsigned int code;
	int max_slots;
	int i;

	if (get_user(code, &ip[0]))
		return -EFAULT;
	if (!input_is_mt_value(code))
		return -EINVAL;

	max_slots = (size - sizeof(__u32)) / sizeof(__s32);
	for (i = 0; i < dev->mtsize && i < max_slots; i++)
		if (put_user(input_mt_get_value(&mt[i], code), &ip[1 + i]))
			return -EFAULT;

	return 0;
}

648 649
static long evdev_do_ioctl(struct file *file, unsigned int cmd,
			   void __user *p, int compat_mode)
L
Linus Torvalds 已提交
650
{
651 652
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
653 654
	struct input_dev *dev = evdev->handle.dev;
	struct input_absinfo abs;
655
	struct ff_effect effect;
656
	int __user *ip = (int __user *)p;
657
	unsigned int i, t, u, v;
658
	unsigned int size;
659
	int error;
L
Linus Torvalds 已提交
660

661
	/* First we check for fixed-length commands */
L
Linus Torvalds 已提交
662 663
	switch (cmd) {

664 665
	case EVIOCGVERSION:
		return put_user(EV_VERSION, ip);
L
Linus Torvalds 已提交
666

667 668 669 670
	case EVIOCGID:
		if (copy_to_user(p, &dev->id, sizeof(struct input_id)))
			return -EFAULT;
		return 0;
671

672 673 674 675 676 677 678 679
	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;
680

681 682 683 684 685 686 687
	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;
688

689 690
		input_inject_event(&evdev->handle, EV_REP, REP_DELAY, u);
		input_inject_event(&evdev->handle, EV_REP, REP_PERIOD, v);
691

692
		return 0;
L
Linus Torvalds 已提交
693

694 695
	case EVIOCRMFF:
		return input_ff_erase(dev, (int)(unsigned long) p, file);
L
Linus Torvalds 已提交
696

697 698 699 700 701 702 703 704 705 706 707 708
	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);
709 710 711 712 713 714 715 716 717 718 719 720

	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);
721
	}
L
Linus Torvalds 已提交
722

723
	size = _IOC_SIZE(cmd);
L
Linus Torvalds 已提交
724

725 726 727
	/* Now check variable-length commands */
#define EVIOC_MASK_SIZE(nr)	((nr) & ~(_IOC_SIZEMASK << _IOC_SIZESHIFT))
	switch (EVIOC_MASK_SIZE(cmd)) {
728

729 730 731 732
	case EVIOCGPROP(0):
		return bits_to_user(dev->propbit, INPUT_PROP_MAX,
				    size, p, compat_mode);

733 734 735
	case EVIOCGMTSLOTS(0):
		return evdev_handle_mt_request(dev, size, ip);

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

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

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

745 746
	case EVIOCGSW(0):
		return bits_to_user(dev->sw, SW_MAX, size, p, compat_mode);
747

748 749
	case EVIOCGNAME(0):
		return str_to_user(dev->name, size, p);
L
Linus Torvalds 已提交
750

751 752
	case EVIOCGPHYS(0):
		return str_to_user(dev->phys, size, p);
L
Linus Torvalds 已提交
753

754 755
	case EVIOCGUNIQ(0):
		return str_to_user(dev->uniq, size, p);
L
Linus Torvalds 已提交
756

757 758 759
	case EVIOC_MASK_SIZE(EVIOCSFF):
		if (input_ff_effect_from_user(p, size, &effect))
			return -EFAULT;
L
Linus Torvalds 已提交
760

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

763 764
		if (put_user(effect.id, &(((struct ff_effect __user *)p)->id)))
			return -EFAULT;
765

766 767
		return error;
	}
L
Linus Torvalds 已提交
768

769 770 771
	/* Multi-number variable-length handlers */
	if (_IOC_TYPE(cmd) != 'E')
		return -EINVAL;
L
Linus Torvalds 已提交
772

773
	if (_IOC_DIR(cmd) == _IOC_READ) {
774

775 776 777 778
		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 已提交
779

780
		if ((_IOC_NR(cmd) & ~ABS_MAX) == _IOC_NR(EVIOCGABS(0))) {
781

782 783 784
			if (!dev->absinfo)
				return -EINVAL;

785 786
			t = _IOC_NR(cmd) & ABS_MAX;
			abs = dev->absinfo[t];
787

788 789 790
			if (copy_to_user(p, &abs, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
791

792 793 794
			return 0;
		}
	}
795

796
	if (_IOC_DIR(cmd) == _IOC_WRITE) {
797

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

800 801 802
			if (!dev->absinfo)
				return -EINVAL;

803
			t = _IOC_NR(cmd) & ABS_MAX;
804

805 806 807
			if (copy_from_user(&abs, p, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
L
Linus Torvalds 已提交
808

809 810
			if (size < sizeof(struct input_absinfo))
				abs.resolution = 0;
811

812 813 814
			/* We can't change number of reserved MT slots */
			if (t == ABS_MT_SLOT)
				return -EINVAL;
H
Henrik Rydberg 已提交
815

816 817 818 819 820 821 822 823
			/*
			 * 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);
824

825
			return 0;
826
		}
L
Linus Torvalds 已提交
827
	}
828

L
Linus Torvalds 已提交
829 830 831
	return -EINVAL;
}

832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854
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;
}

855 856 857 858
static long evdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
{
	return evdev_ioctl_handler(file, cmd, (void __user *)arg, 0);
}
859

860
#ifdef CONFIG_COMPAT
861 862
static long evdev_ioctl_compat(struct file *file,
				unsigned int cmd, unsigned long arg)
863
{
864
	return evdev_ioctl_handler(file, cmd, compat_ptr(arg), 1);
L
Linus Torvalds 已提交
865
}
866
#endif
L
Linus Torvalds 已提交
867

D
Dmitry Torokhov 已提交
868
static const struct file_operations evdev_fops = {
869 870 871 872 873 874 875
	.owner		= THIS_MODULE,
	.read		= evdev_read,
	.write		= evdev_write,
	.poll		= evdev_poll,
	.open		= evdev_open,
	.release	= evdev_release,
	.unlocked_ioctl	= evdev_ioctl,
876
#ifdef CONFIG_COMPAT
877
	.compat_ioctl	= evdev_ioctl_compat,
878
#endif
879
	.fasync		= evdev_fasync,
880 881
	.flush		= evdev_flush,
	.llseek		= no_llseek,
L
Linus Torvalds 已提交
882 883
};

884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911
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);
912
	evdev->exist = false;
913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934
	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.
 */
935 936
static int evdev_connect(struct input_handler *handler, struct input_dev *dev,
			 const struct input_device_id *id)
L
Linus Torvalds 已提交
937 938 939
{
	struct evdev *evdev;
	int minor;
940
	int error;
L
Linus Torvalds 已提交
941

942 943 944 945
	for (minor = 0; minor < EVDEV_MINORS; minor++)
		if (!evdev_table[minor])
			break;

L
Linus Torvalds 已提交
946
	if (minor == EVDEV_MINORS) {
J
Joe Perches 已提交
947
		pr_err("no more free evdev devices\n");
948
		return -ENFILE;
L
Linus Torvalds 已提交
949 950
	}

951 952 953
	evdev = kzalloc(sizeof(struct evdev), GFP_KERNEL);
	if (!evdev)
		return -ENOMEM;
L
Linus Torvalds 已提交
954

955
	INIT_LIST_HEAD(&evdev->client_list);
956 957
	spin_lock_init(&evdev->client_lock);
	mutex_init(&evdev->mutex);
L
Linus Torvalds 已提交
958 959
	init_waitqueue_head(&evdev->wait);

960
	dev_set_name(&evdev->dev, "event%d", minor);
961
	evdev->exist = true;
L
Linus Torvalds 已提交
962
	evdev->minor = minor;
963

964
	evdev->handle.dev = input_get_device(dev);
965
	evdev->handle.name = dev_name(&evdev->dev);
L
Linus Torvalds 已提交
966 967 968
	evdev->handle.handler = handler;
	evdev->handle.private = evdev;

969
	evdev->dev.devt = MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor);
970 971 972 973
	evdev->dev.class = &input_class;
	evdev->dev.parent = &dev->dev;
	evdev->dev.release = evdev_free;
	device_initialize(&evdev->dev);
974

975
	error = input_register_handle(&evdev->handle);
976
	if (error)
977
		goto err_free_evdev;
978

979 980 981 982 983
	error = evdev_install_chrdev(evdev);
	if (error)
		goto err_unregister_handle;

	error = device_add(&evdev->dev);
984
	if (error)
985
		goto err_cleanup_evdev;
L
Linus Torvalds 已提交
986

987
	return 0;
L
Linus Torvalds 已提交
988

989 990 991 992
 err_cleanup_evdev:
	evdev_cleanup(evdev);
 err_unregister_handle:
	input_unregister_handle(&evdev->handle);
993
 err_free_evdev:
994
	put_device(&evdev->dev);
995
	return error;
L
Linus Torvalds 已提交
996 997 998 999 1000 1001
}

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

1002
	device_del(&evdev->dev);
1003 1004
	evdev_cleanup(evdev);
	input_unregister_handle(handle);
1005
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
1006 1007
}

D
Dmitry Torokhov 已提交
1008
static const struct input_device_id evdev_ids[] = {
L
Linus Torvalds 已提交
1009 1010 1011 1012 1013 1014 1015
	{ .driver_info = 1 },	/* Matches all devices */
	{ },			/* Terminating zero entry */
};

MODULE_DEVICE_TABLE(input, evdev_ids);

static struct input_handler evdev_handler = {
1016 1017 1018 1019 1020 1021 1022
	.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 已提交
1023 1024 1025 1026
};

static int __init evdev_init(void)
{
1027
	return input_register_handler(&evdev_handler);
L
Linus Torvalds 已提交
1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040
}

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