2 * User-space I/O driver support for HID subsystem
3 * Copyright (c) 2012 David Herrmann
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the Free
9 * Software Foundation; either version 2 of the License, or (at your option)
13 #include <linux/atomic.h>
14 #include <linux/compat.h>
15 #include <linux/cred.h>
16 #include <linux/device.h>
18 #include <linux/hid.h>
19 #include <linux/input.h>
20 #include <linux/miscdevice.h>
21 #include <linux/module.h>
22 #include <linux/mutex.h>
23 #include <linux/poll.h>
24 #include <linux/sched.h>
25 #include <linux/spinlock.h>
26 #include <linux/uhid.h>
27 #include <linux/wait.h>
29 #define UHID_NAME "uhid"
30 #define UHID_BUFSIZE 32
39 struct hid_device
*hid
;
40 struct uhid_event input_buf
;
42 wait_queue_head_t waitq
;
46 struct uhid_event
*outq
[UHID_BUFSIZE
];
48 /* blocking GET_REPORT support; state changes protected by qlock */
49 struct mutex report_lock
;
50 wait_queue_head_t report_wait
;
54 struct uhid_event report_buf
;
55 struct work_struct worker
;
58 static struct miscdevice uhid_misc
;
60 static void uhid_device_add_worker(struct work_struct
*work
)
62 struct uhid_device
*uhid
= container_of(work
, struct uhid_device
, worker
);
65 ret
= hid_add_device(uhid
->hid
);
67 hid_err(uhid
->hid
, "Cannot register HID device: error %d\n", ret
);
69 hid_destroy_device(uhid
->hid
);
71 uhid
->running
= false;
75 static void uhid_queue(struct uhid_device
*uhid
, struct uhid_event
*ev
)
79 newhead
= (uhid
->head
+ 1) % UHID_BUFSIZE
;
81 if (newhead
!= uhid
->tail
) {
82 uhid
->outq
[uhid
->head
] = ev
;
84 wake_up_interruptible(&uhid
->waitq
);
86 hid_warn(uhid
->hid
, "Output queue is full\n");
91 static int uhid_queue_event(struct uhid_device
*uhid
, __u32 event
)
94 struct uhid_event
*ev
;
96 ev
= kzalloc(sizeof(*ev
), GFP_KERNEL
);
102 spin_lock_irqsave(&uhid
->qlock
, flags
);
103 uhid_queue(uhid
, ev
);
104 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
109 static int uhid_hid_start(struct hid_device
*hid
)
111 struct uhid_device
*uhid
= hid
->driver_data
;
112 struct uhid_event
*ev
;
115 ev
= kzalloc(sizeof(*ev
), GFP_KERNEL
);
119 ev
->type
= UHID_START
;
121 if (hid
->report_enum
[HID_FEATURE_REPORT
].numbered
)
122 ev
->u
.start
.dev_flags
|= UHID_DEV_NUMBERED_FEATURE_REPORTS
;
123 if (hid
->report_enum
[HID_OUTPUT_REPORT
].numbered
)
124 ev
->u
.start
.dev_flags
|= UHID_DEV_NUMBERED_OUTPUT_REPORTS
;
125 if (hid
->report_enum
[HID_INPUT_REPORT
].numbered
)
126 ev
->u
.start
.dev_flags
|= UHID_DEV_NUMBERED_INPUT_REPORTS
;
128 spin_lock_irqsave(&uhid
->qlock
, flags
);
129 uhid_queue(uhid
, ev
);
130 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
135 static void uhid_hid_stop(struct hid_device
*hid
)
137 struct uhid_device
*uhid
= hid
->driver_data
;
140 uhid_queue_event(uhid
, UHID_STOP
);
143 static int uhid_hid_open(struct hid_device
*hid
)
145 struct uhid_device
*uhid
= hid
->driver_data
;
147 return uhid_queue_event(uhid
, UHID_OPEN
);
150 static void uhid_hid_close(struct hid_device
*hid
)
152 struct uhid_device
*uhid
= hid
->driver_data
;
154 uhid_queue_event(uhid
, UHID_CLOSE
);
157 static int uhid_hid_parse(struct hid_device
*hid
)
159 struct uhid_device
*uhid
= hid
->driver_data
;
161 return hid_parse_report(hid
, uhid
->rd_data
, uhid
->rd_size
);
164 /* must be called with report_lock held */
165 static int __uhid_report_queue_and_wait(struct uhid_device
*uhid
,
166 struct uhid_event
*ev
,
172 spin_lock_irqsave(&uhid
->qlock
, flags
);
173 *report_id
= ++uhid
->report_id
;
174 uhid
->report_type
= ev
->type
+ 1;
175 uhid
->report_running
= true;
176 uhid_queue(uhid
, ev
);
177 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
179 ret
= wait_event_interruptible_timeout(uhid
->report_wait
,
180 !uhid
->report_running
|| !uhid
->running
,
182 if (!ret
|| !uhid
->running
|| uhid
->report_running
)
189 uhid
->report_running
= false;
194 static void uhid_report_wake_up(struct uhid_device
*uhid
, u32 id
,
195 const struct uhid_event
*ev
)
199 spin_lock_irqsave(&uhid
->qlock
, flags
);
201 /* id for old report; drop it silently */
202 if (uhid
->report_type
!= ev
->type
|| uhid
->report_id
!= id
)
204 if (!uhid
->report_running
)
207 memcpy(&uhid
->report_buf
, ev
, sizeof(*ev
));
208 uhid
->report_running
= false;
209 wake_up_interruptible(&uhid
->report_wait
);
212 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
215 static int uhid_hid_get_report(struct hid_device
*hid
, unsigned char rnum
,
216 u8
*buf
, size_t count
, u8 rtype
)
218 struct uhid_device
*uhid
= hid
->driver_data
;
219 struct uhid_get_report_reply_req
*req
;
220 struct uhid_event
*ev
;
226 ev
= kzalloc(sizeof(*ev
), GFP_KERNEL
);
230 ev
->type
= UHID_GET_REPORT
;
231 ev
->u
.get_report
.rnum
= rnum
;
232 ev
->u
.get_report
.rtype
= rtype
;
234 ret
= mutex_lock_interruptible(&uhid
->report_lock
);
240 /* this _always_ takes ownership of @ev */
241 ret
= __uhid_report_queue_and_wait(uhid
, ev
, &ev
->u
.get_report
.id
);
245 req
= &uhid
->report_buf
.u
.get_report_reply
;
249 ret
= min3(count
, (size_t)req
->size
, (size_t)UHID_DATA_MAX
);
250 memcpy(buf
, req
->data
, ret
);
254 mutex_unlock(&uhid
->report_lock
);
258 static int uhid_hid_set_report(struct hid_device
*hid
, unsigned char rnum
,
259 const u8
*buf
, size_t count
, u8 rtype
)
261 struct uhid_device
*uhid
= hid
->driver_data
;
262 struct uhid_event
*ev
;
265 if (!uhid
->running
|| count
> UHID_DATA_MAX
)
268 ev
= kzalloc(sizeof(*ev
), GFP_KERNEL
);
272 ev
->type
= UHID_SET_REPORT
;
273 ev
->u
.set_report
.rnum
= rnum
;
274 ev
->u
.set_report
.rtype
= rtype
;
275 ev
->u
.set_report
.size
= count
;
276 memcpy(ev
->u
.set_report
.data
, buf
, count
);
278 ret
= mutex_lock_interruptible(&uhid
->report_lock
);
284 /* this _always_ takes ownership of @ev */
285 ret
= __uhid_report_queue_and_wait(uhid
, ev
, &ev
->u
.set_report
.id
);
289 if (uhid
->report_buf
.u
.set_report_reply
.err
)
295 mutex_unlock(&uhid
->report_lock
);
299 static int uhid_hid_raw_request(struct hid_device
*hid
, unsigned char reportnum
,
300 __u8
*buf
, size_t len
, unsigned char rtype
,
306 case HID_FEATURE_REPORT
:
307 u_rtype
= UHID_FEATURE_REPORT
;
309 case HID_OUTPUT_REPORT
:
310 u_rtype
= UHID_OUTPUT_REPORT
;
312 case HID_INPUT_REPORT
:
313 u_rtype
= UHID_INPUT_REPORT
;
320 case HID_REQ_GET_REPORT
:
321 return uhid_hid_get_report(hid
, reportnum
, buf
, len
, u_rtype
);
322 case HID_REQ_SET_REPORT
:
323 return uhid_hid_set_report(hid
, reportnum
, buf
, len
, u_rtype
);
329 static int uhid_hid_output_raw(struct hid_device
*hid
, __u8
*buf
, size_t count
,
330 unsigned char report_type
)
332 struct uhid_device
*uhid
= hid
->driver_data
;
335 struct uhid_event
*ev
;
337 switch (report_type
) {
338 case HID_FEATURE_REPORT
:
339 rtype
= UHID_FEATURE_REPORT
;
341 case HID_OUTPUT_REPORT
:
342 rtype
= UHID_OUTPUT_REPORT
;
348 if (count
< 1 || count
> UHID_DATA_MAX
)
351 ev
= kzalloc(sizeof(*ev
), GFP_KERNEL
);
355 ev
->type
= UHID_OUTPUT
;
356 ev
->u
.output
.size
= count
;
357 ev
->u
.output
.rtype
= rtype
;
358 memcpy(ev
->u
.output
.data
, buf
, count
);
360 spin_lock_irqsave(&uhid
->qlock
, flags
);
361 uhid_queue(uhid
, ev
);
362 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
367 static int uhid_hid_output_report(struct hid_device
*hid
, __u8
*buf
,
370 return uhid_hid_output_raw(hid
, buf
, count
, HID_OUTPUT_REPORT
);
373 struct hid_ll_driver uhid_hid_driver
= {
374 .start
= uhid_hid_start
,
375 .stop
= uhid_hid_stop
,
376 .open
= uhid_hid_open
,
377 .close
= uhid_hid_close
,
378 .parse
= uhid_hid_parse
,
379 .raw_request
= uhid_hid_raw_request
,
380 .output_report
= uhid_hid_output_report
,
382 EXPORT_SYMBOL_GPL(uhid_hid_driver
);
386 /* Apparently we haven't stepped on these rakes enough times yet. */
387 struct uhid_create_req_compat
{
392 compat_uptr_t rd_data
;
400 } __attribute__((__packed__
));
402 static int uhid_event_from_user(const char __user
*buffer
, size_t len
,
403 struct uhid_event
*event
)
405 if (in_compat_syscall()) {
408 if (get_user(type
, buffer
))
411 if (type
== UHID_CREATE
) {
413 * This is our messed up request with compat pointer.
414 * It is largish (more than 256 bytes) so we better
415 * allocate it from the heap.
417 struct uhid_create_req_compat
*compat
;
419 compat
= kzalloc(sizeof(*compat
), GFP_KERNEL
);
423 buffer
+= sizeof(type
);
425 if (copy_from_user(compat
, buffer
,
426 min(len
, sizeof(*compat
)))) {
431 /* Shuffle the data over to proper structure */
434 memcpy(event
->u
.create
.name
, compat
->name
,
435 sizeof(compat
->name
));
436 memcpy(event
->u
.create
.phys
, compat
->phys
,
437 sizeof(compat
->phys
));
438 memcpy(event
->u
.create
.uniq
, compat
->uniq
,
439 sizeof(compat
->uniq
));
441 event
->u
.create
.rd_data
= compat_ptr(compat
->rd_data
);
442 event
->u
.create
.rd_size
= compat
->rd_size
;
444 event
->u
.create
.bus
= compat
->bus
;
445 event
->u
.create
.vendor
= compat
->vendor
;
446 event
->u
.create
.product
= compat
->product
;
447 event
->u
.create
.version
= compat
->version
;
448 event
->u
.create
.country
= compat
->country
;
453 /* All others can be copied directly */
456 if (copy_from_user(event
, buffer
, min(len
, sizeof(*event
))))
462 static int uhid_event_from_user(const char __user
*buffer
, size_t len
,
463 struct uhid_event
*event
)
465 if (copy_from_user(event
, buffer
, min(len
, sizeof(*event
))))
472 static int uhid_dev_create2(struct uhid_device
*uhid
,
473 const struct uhid_event
*ev
)
475 struct hid_device
*hid
;
483 rd_size
= ev
->u
.create2
.rd_size
;
484 if (rd_size
<= 0 || rd_size
> HID_MAX_DESCRIPTOR_SIZE
)
487 rd_data
= kmemdup(ev
->u
.create2
.rd_data
, rd_size
, GFP_KERNEL
);
491 uhid
->rd_size
= rd_size
;
492 uhid
->rd_data
= rd_data
;
494 hid
= hid_allocate_device();
500 /* @hid is zero-initialized, strncpy() is correct, strlcpy() not */
501 len
= min(sizeof(hid
->name
), sizeof(ev
->u
.create2
.name
)) - 1;
502 strncpy(hid
->name
, ev
->u
.create2
.name
, len
);
503 len
= min(sizeof(hid
->phys
), sizeof(ev
->u
.create2
.phys
)) - 1;
504 strncpy(hid
->phys
, ev
->u
.create2
.phys
, len
);
505 len
= min(sizeof(hid
->uniq
), sizeof(ev
->u
.create2
.uniq
)) - 1;
506 strncpy(hid
->uniq
, ev
->u
.create2
.uniq
, len
);
508 hid
->ll_driver
= &uhid_hid_driver
;
509 hid
->bus
= ev
->u
.create2
.bus
;
510 hid
->vendor
= ev
->u
.create2
.vendor
;
511 hid
->product
= ev
->u
.create2
.product
;
512 hid
->version
= ev
->u
.create2
.version
;
513 hid
->country
= ev
->u
.create2
.country
;
514 hid
->driver_data
= uhid
;
515 hid
->dev
.parent
= uhid_misc
.this_device
;
518 uhid
->running
= true;
520 /* Adding of a HID device is done through a worker, to allow HID drivers
521 * which use feature requests during .probe to work, without they would
522 * be blocked on devlock, which is held by uhid_char_write.
524 schedule_work(&uhid
->worker
);
529 kfree(uhid
->rd_data
);
530 uhid
->rd_data
= NULL
;
535 static int uhid_dev_create(struct uhid_device
*uhid
,
536 struct uhid_event
*ev
)
538 struct uhid_create_req orig
;
542 if (orig
.rd_size
<= 0 || orig
.rd_size
> HID_MAX_DESCRIPTOR_SIZE
)
544 if (copy_from_user(&ev
->u
.create2
.rd_data
, orig
.rd_data
, orig
.rd_size
))
547 memcpy(ev
->u
.create2
.name
, orig
.name
, sizeof(orig
.name
));
548 memcpy(ev
->u
.create2
.phys
, orig
.phys
, sizeof(orig
.phys
));
549 memcpy(ev
->u
.create2
.uniq
, orig
.uniq
, sizeof(orig
.uniq
));
550 ev
->u
.create2
.rd_size
= orig
.rd_size
;
551 ev
->u
.create2
.bus
= orig
.bus
;
552 ev
->u
.create2
.vendor
= orig
.vendor
;
553 ev
->u
.create2
.product
= orig
.product
;
554 ev
->u
.create2
.version
= orig
.version
;
555 ev
->u
.create2
.country
= orig
.country
;
557 return uhid_dev_create2(uhid
, ev
);
560 static int uhid_dev_destroy(struct uhid_device
*uhid
)
565 uhid
->running
= false;
566 wake_up_interruptible(&uhid
->report_wait
);
568 cancel_work_sync(&uhid
->worker
);
570 hid_destroy_device(uhid
->hid
);
571 kfree(uhid
->rd_data
);
576 static int uhid_dev_input(struct uhid_device
*uhid
, struct uhid_event
*ev
)
581 hid_input_report(uhid
->hid
, HID_INPUT_REPORT
, ev
->u
.input
.data
,
582 min_t(size_t, ev
->u
.input
.size
, UHID_DATA_MAX
), 0);
587 static int uhid_dev_input2(struct uhid_device
*uhid
, struct uhid_event
*ev
)
592 hid_input_report(uhid
->hid
, HID_INPUT_REPORT
, ev
->u
.input2
.data
,
593 min_t(size_t, ev
->u
.input2
.size
, UHID_DATA_MAX
), 0);
598 static int uhid_dev_get_report_reply(struct uhid_device
*uhid
,
599 struct uhid_event
*ev
)
604 uhid_report_wake_up(uhid
, ev
->u
.get_report_reply
.id
, ev
);
608 static int uhid_dev_set_report_reply(struct uhid_device
*uhid
,
609 struct uhid_event
*ev
)
614 uhid_report_wake_up(uhid
, ev
->u
.set_report_reply
.id
, ev
);
618 static int uhid_char_open(struct inode
*inode
, struct file
*file
)
620 struct uhid_device
*uhid
;
622 uhid
= kzalloc(sizeof(*uhid
), GFP_KERNEL
);
626 mutex_init(&uhid
->devlock
);
627 mutex_init(&uhid
->report_lock
);
628 spin_lock_init(&uhid
->qlock
);
629 init_waitqueue_head(&uhid
->waitq
);
630 init_waitqueue_head(&uhid
->report_wait
);
631 uhid
->running
= false;
632 INIT_WORK(&uhid
->worker
, uhid_device_add_worker
);
634 file
->private_data
= uhid
;
635 nonseekable_open(inode
, file
);
640 static int uhid_char_release(struct inode
*inode
, struct file
*file
)
642 struct uhid_device
*uhid
= file
->private_data
;
645 uhid_dev_destroy(uhid
);
647 for (i
= 0; i
< UHID_BUFSIZE
; ++i
)
648 kfree(uhid
->outq
[i
]);
655 static ssize_t
uhid_char_read(struct file
*file
, char __user
*buffer
,
656 size_t count
, loff_t
*ppos
)
658 struct uhid_device
*uhid
= file
->private_data
;
663 /* they need at least the "type" member of uhid_event */
664 if (count
< sizeof(__u32
))
668 if (file
->f_flags
& O_NONBLOCK
) {
669 if (uhid
->head
== uhid
->tail
)
672 ret
= wait_event_interruptible(uhid
->waitq
,
673 uhid
->head
!= uhid
->tail
);
678 ret
= mutex_lock_interruptible(&uhid
->devlock
);
682 if (uhid
->head
== uhid
->tail
) {
683 mutex_unlock(&uhid
->devlock
);
686 len
= min(count
, sizeof(**uhid
->outq
));
687 if (copy_to_user(buffer
, uhid
->outq
[uhid
->tail
], len
)) {
690 kfree(uhid
->outq
[uhid
->tail
]);
691 uhid
->outq
[uhid
->tail
] = NULL
;
693 spin_lock_irqsave(&uhid
->qlock
, flags
);
694 uhid
->tail
= (uhid
->tail
+ 1) % UHID_BUFSIZE
;
695 spin_unlock_irqrestore(&uhid
->qlock
, flags
);
699 mutex_unlock(&uhid
->devlock
);
700 return ret
? ret
: len
;
703 static ssize_t
uhid_char_write(struct file
*file
, const char __user
*buffer
,
704 size_t count
, loff_t
*ppos
)
706 struct uhid_device
*uhid
= file
->private_data
;
710 /* we need at least the "type" member of uhid_event */
711 if (count
< sizeof(__u32
))
714 ret
= mutex_lock_interruptible(&uhid
->devlock
);
718 memset(&uhid
->input_buf
, 0, sizeof(uhid
->input_buf
));
719 len
= min(count
, sizeof(uhid
->input_buf
));
721 ret
= uhid_event_from_user(buffer
, len
, &uhid
->input_buf
);
725 switch (uhid
->input_buf
.type
) {
728 * 'struct uhid_create_req' contains a __user pointer which is
729 * copied from, so it's unsafe to allow this with elevated
730 * privileges (e.g. from a setuid binary) or via kernel_write().
732 if (file
->f_cred
!= current_cred() || uaccess_kernel()) {
733 pr_err_once("UHID_CREATE from different security context by process %d (%s), this is not allowed.\n",
734 task_tgid_vnr(current
), current
->comm
);
738 ret
= uhid_dev_create(uhid
, &uhid
->input_buf
);
741 ret
= uhid_dev_create2(uhid
, &uhid
->input_buf
);
744 ret
= uhid_dev_destroy(uhid
);
747 ret
= uhid_dev_input(uhid
, &uhid
->input_buf
);
750 ret
= uhid_dev_input2(uhid
, &uhid
->input_buf
);
752 case UHID_GET_REPORT_REPLY
:
753 ret
= uhid_dev_get_report_reply(uhid
, &uhid
->input_buf
);
755 case UHID_SET_REPORT_REPLY
:
756 ret
= uhid_dev_set_report_reply(uhid
, &uhid
->input_buf
);
763 mutex_unlock(&uhid
->devlock
);
765 /* return "count" not "len" to not confuse the caller */
766 return ret
? ret
: count
;
769 static __poll_t
uhid_char_poll(struct file
*file
, poll_table
*wait
)
771 struct uhid_device
*uhid
= file
->private_data
;
772 __poll_t mask
= EPOLLOUT
| EPOLLWRNORM
; /* uhid is always writable */
774 poll_wait(file
, &uhid
->waitq
, wait
);
776 if (uhid
->head
!= uhid
->tail
)
777 mask
|= EPOLLIN
| EPOLLRDNORM
;
782 static const struct file_operations uhid_fops
= {
783 .owner
= THIS_MODULE
,
784 .open
= uhid_char_open
,
785 .release
= uhid_char_release
,
786 .read
= uhid_char_read
,
787 .write
= uhid_char_write
,
788 .poll
= uhid_char_poll
,
792 static struct miscdevice uhid_misc
= {
797 module_misc_device(uhid_misc
);
799 MODULE_LICENSE("GPL");
800 MODULE_AUTHOR("David Herrmann <dh.herrmann@gmail.com>");
801 MODULE_DESCRIPTION("User-space I/O driver support for HID subsystem");
802 MODULE_ALIAS_MISCDEV(UHID_MINOR
);
803 MODULE_ALIAS("devname:" UHID_NAME
);