evdev.c 22.0 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 {
L
Linus Torvalds 已提交
42 43
	int head;
	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 49
	int bufsize;
	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 58
static void evdev_pass_event(struct evdev_client *client,
			     struct input_event *event)
{
	/*
59 60 61
	 * Interrupts are disabled, just acquire the lock.
	 * Make sure we don't leave with the client buffer
	 * "empty" by having client->head == client->tail.
62 63
	 */
	spin_lock(&client->buffer_lock);
64 65 66 67
	do {
		client->buffer[client->head++] = *event;
		client->head &= client->bufsize - 1;
	} while (client->head == client->tail);
68 69
	spin_unlock(&client->buffer_lock);

70 71
	if (event->type == EV_SYN)
		kill_fasync(&client->fasync, SIGIO, POLL_IN);
72 73 74
}

/*
D
Dmitry Torokhov 已提交
75
 * Pass incoming event to all connected clients.
76 77 78
 */
static void evdev_event(struct input_handle *handle,
			unsigned int type, unsigned int code, int value)
L
Linus Torvalds 已提交
79 80
{
	struct evdev *evdev = handle->private;
81
	struct evdev_client *client;
82
	struct input_event event;
L
Linus Torvalds 已提交
83

84 85 86 87
	do_gettimeofday(&event.time);
	event.type = type;
	event.code = code;
	event.value = value;
L
Linus Torvalds 已提交
88

D
Dmitry Torokhov 已提交
89 90
	rcu_read_lock();

91 92 93 94 95 96
	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 已提交
97

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

L
Linus Torvalds 已提交
100 101 102 103 104
	wake_up_interruptible(&evdev->wait);
}

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

107
	return fasync_helper(fd, file, on, &client->fasync);
L
Linus Torvalds 已提交
108 109
}

110
static int evdev_flush(struct file *file, fl_owner_t id)
L
Linus Torvalds 已提交
111
{
112 113
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
114 115 116 117 118
	int retval;

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

120
	if (!evdev->exist)
121 122 123
		retval = -ENODEV;
	else
		retval = input_flush_device(&evdev->handle, file);
124

125 126
	mutex_unlock(&evdev->mutex);
	return retval;
L
Linus Torvalds 已提交
127 128
}

129
static void evdev_free(struct device *dev)
L
Linus Torvalds 已提交
130
{
131 132
	struct evdev *evdev = container_of(dev, struct evdev, dev);

133
	input_put_device(evdev->handle.dev);
L
Linus Torvalds 已提交
134 135 136
	kfree(evdev);
}

137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152
/*
 * 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 已提交
153
	synchronize_rcu();
154 155 156 157 158 159 160 161 162 163

	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 已提交
164
	synchronize_rcu();
165 166 167 168 169 170 171 172 173 174 175
	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 已提交
176
	synchronize_rcu();
177 178 179 180 181 182 183 184
}

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

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;
198
	else if (!evdev->open++) {
199
		retval = input_open_device(&evdev->handle);
200 201 202
		if (retval)
			evdev->open--;
	}
203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233

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

234
static int evdev_release(struct inode *inode, struct file *file)
L
Linus Torvalds 已提交
235
{
236 237
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
238

239 240 241 242
	mutex_lock(&evdev->mutex);
	if (evdev->grab == client)
		evdev_ungrab(evdev, client);
	mutex_unlock(&evdev->mutex);
L
Linus Torvalds 已提交
243

244
	evdev_detach_client(evdev, client);
245
	kfree(client);
L
Linus Torvalds 已提交
246

247
	evdev_close_device(evdev);
248
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
249 250 251 252

	return 0;
}

253 254
static unsigned int evdev_compute_buffer_size(struct input_dev *dev)
{
255 256 257 258 259
	unsigned int n_events =
		max(dev->hint_events_per_packet * EVDEV_BUF_PACKETS,
		    EVDEV_MIN_BUFFER_SIZE);

	return roundup_pow_of_two(n_events);
260 261
}

262
static int evdev_open(struct inode *inode, struct file *file)
L
Linus Torvalds 已提交
263
{
264
	struct evdev *evdev;
265
	struct evdev_client *client;
L
Linus Torvalds 已提交
266
	int i = iminor(inode) - EVDEV_MINOR_BASE;
267
	unsigned int bufsize;
268
	int error;
L
Linus Torvalds 已提交
269

270
	if (i >= EVDEV_MINORS)
L
Linus Torvalds 已提交
271 272
		return -ENODEV;

273 274 275
	error = mutex_lock_interruptible(&evdev_table_mutex);
	if (error)
		return error;
276
	evdev = evdev_table[i];
277 278 279
	if (evdev)
		get_device(&evdev->dev);
	mutex_unlock(&evdev_table_mutex);
280

281
	if (!evdev)
L
Linus Torvalds 已提交
282 283
		return -ENODEV;

284 285 286 287 288
	bufsize = evdev_compute_buffer_size(evdev->handle.dev);

	client = kzalloc(sizeof(struct evdev_client) +
				bufsize * sizeof(struct input_event),
			 GFP_KERNEL);
289 290 291 292
	if (!client) {
		error = -ENOMEM;
		goto err_put_evdev;
	}
L
Linus Torvalds 已提交
293

294
	client->bufsize = bufsize;
295
	spin_lock_init(&client->buffer_lock);
296
	client->evdev = evdev;
297
	evdev_attach_client(evdev, client);
L
Linus Torvalds 已提交
298

299 300 301
	error = evdev_open_device(evdev);
	if (error)
		goto err_free_client;
L
Linus Torvalds 已提交
302

303
	file->private_data = client;
304 305
	nonseekable_open(inode, file);

L
Linus Torvalds 已提交
306
	return 0;
307 308

 err_free_client:
309
	evdev_detach_client(evdev, client);
310 311 312 313
	kfree(client);
 err_put_evdev:
	put_device(&evdev->dev);
	return error;
L
Linus Torvalds 已提交
314 315
}

316 317
static ssize_t evdev_write(struct file *file, const char __user *buffer,
			   size_t count, loff_t *ppos)
318
{
319 320
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
321
	struct input_event event;
322
	int retval;
323

324 325 326
	if (count < input_event_size())
		return -EINVAL;

327 328 329 330 331 332 333 334
	retval = mutex_lock_interruptible(&evdev->mutex);
	if (retval)
		return retval;

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

336
	do {
337
		if (input_event_from_user(buffer + retval, &event)) {
338 339 340
			retval = -EFAULT;
			goto out;
		}
341
		retval += input_event_size();
342 343 344

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

347 348
 out:
	mutex_unlock(&evdev->mutex);
349 350 351
	return retval;
}

352 353 354 355 356 357 358 359 360 361
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++];
362
		client->tail &= client->bufsize - 1;
363 364 365 366 367 368 369 370 371
	}

	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 已提交
372
{
373 374
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
375
	struct input_event event;
L
Linus Torvalds 已提交
376 377
	int retval;

378
	if (count < input_event_size())
L
Linus Torvalds 已提交
379 380
		return -EINVAL;

381 382
	if (client->head == client->tail && evdev->exist &&
	    (file->f_flags & O_NONBLOCK))
L
Linus Torvalds 已提交
383 384
		return -EAGAIN;

385 386
	retval = wait_event_interruptible(evdev->wait,
		client->head != client->tail || !evdev->exist);
L
Linus Torvalds 已提交
387 388 389
	if (retval)
		return retval;

390
	if (!evdev->exist)
L
Linus Torvalds 已提交
391 392
		return -ENODEV;

393
	while (retval + input_event_size() <= count &&
394
	       evdev_fetch_next_event(client, &event)) {
395

396
		if (input_event_to_user(buffer + retval, &event))
397 398
			return -EFAULT;

399
		retval += input_event_size();
L
Linus Torvalds 已提交
400 401 402 403 404 405 406 407
	}

	return retval;
}

/* No kernel lock - fine */
static unsigned int evdev_poll(struct file *file, poll_table *wait)
{
408 409
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
410
	unsigned int mask;
411

412
	poll_wait(file, &evdev->wait, wait);
413 414 415 416 417 418

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

	return mask;
L
Linus Torvalds 已提交
419 420
}

421 422 423
#ifdef CONFIG_COMPAT

#define BITS_PER_LONG_COMPAT (sizeof(compat_long_t) * 8)
424
#define BITS_TO_LONGS_COMPAT(x) ((((x) - 1) / BITS_PER_LONG_COMPAT) + 1)
425 426 427 428 429 430 431 432

#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) {
433
		len = BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t);
434
		if (len > maxlen)
435 436 437 438 439 440 441 442 443
			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 {
444
		len = BITS_TO_LONGS(maxbit) * sizeof(long);
445 446 447 448 449 450 451 452 453 454 455 456 457 458
		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 ?
459 460
			BITS_TO_LONGS_COMPAT(maxbit) * sizeof(compat_long_t) :
			BITS_TO_LONGS(maxbit) * sizeof(long);
461 462 463 464 465 466 467 468 469 470 471 472 473

	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)
{
474
	int len = BITS_TO_LONGS(maxbit) * sizeof(long);
475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497

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

498
#define OLD_KEY_MAX	0x1ff
499 500 501
static int handle_eviocgbit(struct input_dev *dev,
			    unsigned int type, unsigned int size,
			    void __user *p, int compat_mode)
502
{
503
	static unsigned long keymax_warn_time;
504 505 506
	unsigned long *bits;
	int len;

507
	switch (type) {
508 509 510 511 512 513 514 515 516 517 518 519

	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;
	}
520 521 522 523 524 525

	/*
	 * 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.
	 */
526
	if (type == EV_KEY && size == OLD_KEY_MAX) {
527 528
		len = OLD_KEY_MAX;
		if (printk_timed_ratelimit(&keymax_warn_time, 10 * 1000))
J
Joe Perches 已提交
529 530 531 532 533
			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));
534 535
	}

536
	return bits_to_user(bits, len, size, p, compat_mode);
537
}
538
#undef OLD_KEY_MAX
539

540
static int evdev_handle_get_keycode(struct input_dev *dev, void __user *p)
541
{
542 543 544 545 546
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
547 548
	int error;

549 550 551
	/* legacy case */
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
552

553 554 555
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
556

557 558
	if (put_user(ke.keycode, ip + 1))
		return -EFAULT;
559

560 561
	return 0;
}
562

563 564 565 566
static int evdev_handle_get_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
	int error;
567

568 569
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
570

571 572 573
	error = input_get_keycode(dev, &ke);
	if (error)
		return error;
574

575 576
	if (copy_to_user(p, &ke, sizeof(ke)))
		return -EFAULT;
577 578 579 580

	return 0;
}

581
static int evdev_handle_set_keycode(struct input_dev *dev, void __user *p)
582
{
583 584 585 586 587
	struct input_keymap_entry ke = {
		.len	= sizeof(unsigned int),
		.flags	= 0,
	};
	int __user *ip = (int __user *)p;
588

589 590
	if (copy_from_user(ke.scancode, p, sizeof(unsigned int)))
		return -EFAULT;
591

592 593
	if (get_user(ke.keycode, ip + 1))
		return -EFAULT;
594

595 596
	return input_set_keycode(dev, &ke);
}
597

598 599 600
static int evdev_handle_set_keycode_v2(struct input_dev *dev, void __user *p)
{
	struct input_keymap_entry ke;
601

602 603
	if (copy_from_user(&ke, p, sizeof(ke)))
		return -EFAULT;
604

605 606
	if (ke.len > sizeof(ke.scancode))
		return -EINVAL;
607 608 609 610

	return input_set_keycode(dev, &ke);
}

611 612
static long evdev_do_ioctl(struct file *file, unsigned int cmd,
			   void __user *p, int compat_mode)
L
Linus Torvalds 已提交
613
{
614 615
	struct evdev_client *client = file->private_data;
	struct evdev *evdev = client->evdev;
L
Linus Torvalds 已提交
616 617
	struct input_dev *dev = evdev->handle.dev;
	struct input_absinfo abs;
618
	struct ff_effect effect;
619
	int __user *ip = (int __user *)p;
620
	unsigned int i, t, u, v;
621
	unsigned int size;
622
	int error;
L
Linus Torvalds 已提交
623

624
	/* First we check for fixed-length commands */
L
Linus Torvalds 已提交
625 626
	switch (cmd) {

627 628
	case EVIOCGVERSION:
		return put_user(EV_VERSION, ip);
L
Linus Torvalds 已提交
629

630 631 632 633
	case EVIOCGID:
		if (copy_to_user(p, &dev->id, sizeof(struct input_id)))
			return -EFAULT;
		return 0;
634

635 636 637 638 639 640 641 642
	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;
643

644 645 646 647 648 649 650
	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;
651

652 653
		input_inject_event(&evdev->handle, EV_REP, REP_DELAY, u);
		input_inject_event(&evdev->handle, EV_REP, REP_PERIOD, v);
654

655
		return 0;
L
Linus Torvalds 已提交
656

657 658
	case EVIOCRMFF:
		return input_ff_erase(dev, (int)(unsigned long) p, file);
L
Linus Torvalds 已提交
659

660 661 662 663 664 665 666 667 668 669 670 671
	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);
672 673 674 675 676 677 678 679 680 681 682 683

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

686
	size = _IOC_SIZE(cmd);
L
Linus Torvalds 已提交
687

688 689 690
	/* Now check variable-length commands */
#define EVIOC_MASK_SIZE(nr)	((nr) & ~(_IOC_SIZEMASK << _IOC_SIZESHIFT))
	switch (EVIOC_MASK_SIZE(cmd)) {
691

692 693 694 695
	case EVIOCGPROP(0):
		return bits_to_user(dev->propbit, INPUT_PROP_MAX,
				    size, p, compat_mode);

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

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

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

705 706
	case EVIOCGSW(0):
		return bits_to_user(dev->sw, SW_MAX, size, p, compat_mode);
707

708 709
	case EVIOCGNAME(0):
		return str_to_user(dev->name, size, p);
L
Linus Torvalds 已提交
710

711 712
	case EVIOCGPHYS(0):
		return str_to_user(dev->phys, size, p);
L
Linus Torvalds 已提交
713

714 715
	case EVIOCGUNIQ(0):
		return str_to_user(dev->uniq, size, p);
L
Linus Torvalds 已提交
716

717 718 719
	case EVIOC_MASK_SIZE(EVIOCSFF):
		if (input_ff_effect_from_user(p, size, &effect))
			return -EFAULT;
L
Linus Torvalds 已提交
720

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

723 724
		if (put_user(effect.id, &(((struct ff_effect __user *)p)->id)))
			return -EFAULT;
725

726 727
		return error;
	}
L
Linus Torvalds 已提交
728

729 730 731
	/* Multi-number variable-length handlers */
	if (_IOC_TYPE(cmd) != 'E')
		return -EINVAL;
L
Linus Torvalds 已提交
732

733
	if (_IOC_DIR(cmd) == _IOC_READ) {
734

735 736 737 738
		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 已提交
739

740
		if ((_IOC_NR(cmd) & ~ABS_MAX) == _IOC_NR(EVIOCGABS(0))) {
741

742 743 744
			if (!dev->absinfo)
				return -EINVAL;

745 746
			t = _IOC_NR(cmd) & ABS_MAX;
			abs = dev->absinfo[t];
747

748 749 750
			if (copy_to_user(p, &abs, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
751

752 753 754
			return 0;
		}
	}
755

756
	if (_IOC_DIR(cmd) == _IOC_WRITE) {
757

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

760 761 762
			if (!dev->absinfo)
				return -EINVAL;

763
			t = _IOC_NR(cmd) & ABS_MAX;
764

765 766 767
			if (copy_from_user(&abs, p, min_t(size_t,
					size, sizeof(struct input_absinfo))))
				return -EFAULT;
L
Linus Torvalds 已提交
768

769 770
			if (size < sizeof(struct input_absinfo))
				abs.resolution = 0;
771

772 773 774
			/* We can't change number of reserved MT slots */
			if (t == ABS_MT_SLOT)
				return -EINVAL;
H
Henrik Rydberg 已提交
775

776 777 778 779 780 781 782 783
			/*
			 * 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);
784

785
			return 0;
786
		}
L
Linus Torvalds 已提交
787
	}
788

L
Linus Torvalds 已提交
789 790 791
	return -EINVAL;
}

792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814
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;
}

815 816 817 818
static long evdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
{
	return evdev_ioctl_handler(file, cmd, (void __user *)arg, 0);
}
819

820
#ifdef CONFIG_COMPAT
821 822
static long evdev_ioctl_compat(struct file *file,
				unsigned int cmd, unsigned long arg)
823
{
824
	return evdev_ioctl_handler(file, cmd, compat_ptr(arg), 1);
L
Linus Torvalds 已提交
825
}
826
#endif
L
Linus Torvalds 已提交
827

D
Dmitry Torokhov 已提交
828
static const struct file_operations evdev_fops = {
829 830 831 832 833 834 835
	.owner		= THIS_MODULE,
	.read		= evdev_read,
	.write		= evdev_write,
	.poll		= evdev_poll,
	.open		= evdev_open,
	.release	= evdev_release,
	.unlocked_ioctl	= evdev_ioctl,
836
#ifdef CONFIG_COMPAT
837
	.compat_ioctl	= evdev_ioctl_compat,
838
#endif
839
	.fasync		= evdev_fasync,
840 841
	.flush		= evdev_flush,
	.llseek		= no_llseek,
L
Linus Torvalds 已提交
842 843
};

844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871
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);
872
	evdev->exist = false;
873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894
	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.
 */
895 896
static int evdev_connect(struct input_handler *handler, struct input_dev *dev,
			 const struct input_device_id *id)
L
Linus Torvalds 已提交
897 898 899
{
	struct evdev *evdev;
	int minor;
900
	int error;
L
Linus Torvalds 已提交
901

902 903 904 905
	for (minor = 0; minor < EVDEV_MINORS; minor++)
		if (!evdev_table[minor])
			break;

L
Linus Torvalds 已提交
906
	if (minor == EVDEV_MINORS) {
J
Joe Perches 已提交
907
		pr_err("no more free evdev devices\n");
908
		return -ENFILE;
L
Linus Torvalds 已提交
909 910
	}

911 912 913
	evdev = kzalloc(sizeof(struct evdev), GFP_KERNEL);
	if (!evdev)
		return -ENOMEM;
L
Linus Torvalds 已提交
914

915
	INIT_LIST_HEAD(&evdev->client_list);
916 917
	spin_lock_init(&evdev->client_lock);
	mutex_init(&evdev->mutex);
L
Linus Torvalds 已提交
918 919
	init_waitqueue_head(&evdev->wait);

920
	dev_set_name(&evdev->dev, "event%d", minor);
921
	evdev->exist = true;
L
Linus Torvalds 已提交
922
	evdev->minor = minor;
923

924
	evdev->handle.dev = input_get_device(dev);
925
	evdev->handle.name = dev_name(&evdev->dev);
L
Linus Torvalds 已提交
926 927 928
	evdev->handle.handler = handler;
	evdev->handle.private = evdev;

929
	evdev->dev.devt = MKDEV(INPUT_MAJOR, EVDEV_MINOR_BASE + minor);
930 931 932 933
	evdev->dev.class = &input_class;
	evdev->dev.parent = &dev->dev;
	evdev->dev.release = evdev_free;
	device_initialize(&evdev->dev);
934

935
	error = input_register_handle(&evdev->handle);
936
	if (error)
937
		goto err_free_evdev;
938

939 940 941 942 943
	error = evdev_install_chrdev(evdev);
	if (error)
		goto err_unregister_handle;

	error = device_add(&evdev->dev);
944
	if (error)
945
		goto err_cleanup_evdev;
L
Linus Torvalds 已提交
946

947
	return 0;
L
Linus Torvalds 已提交
948

949 950 951 952
 err_cleanup_evdev:
	evdev_cleanup(evdev);
 err_unregister_handle:
	input_unregister_handle(&evdev->handle);
953
 err_free_evdev:
954
	put_device(&evdev->dev);
955
	return error;
L
Linus Torvalds 已提交
956 957 958 959 960 961
}

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

962
	device_del(&evdev->dev);
963 964
	evdev_cleanup(evdev);
	input_unregister_handle(handle);
965
	put_device(&evdev->dev);
L
Linus Torvalds 已提交
966 967
}

D
Dmitry Torokhov 已提交
968
static const struct input_device_id evdev_ids[] = {
L
Linus Torvalds 已提交
969 970 971 972 973 974 975
	{ .driver_info = 1 },	/* Matches all devices */
	{ },			/* Terminating zero entry */
};

MODULE_DEVICE_TABLE(input, evdev_ids);

static struct input_handler evdev_handler = {
976 977 978 979 980 981 982
	.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 已提交
983 984 985 986
};

static int __init evdev_init(void)
{
987
	return input_register_handler(&evdev_handler);
L
Linus Torvalds 已提交
988 989 990 991 992 993 994 995 996 997 998 999 1000
}

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