blob: 2243a6b75914a5cb63808b3e660f1e9eceb89f5a [file] [log] [blame]
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -03001======================================================
2UHID - User-space I/O driver support for HID subsystem
3======================================================
David Herrmannd99b8ba2012-06-10 15:16:26 +02004
David Herrmann76c7c492014-07-29 17:14:26 +02005UHID allows user-space to implement HID transport drivers. Please see
Randy Dunlap356006a2020-12-28 12:53:27 -08006hid-transport.rst for an introduction into HID transport drivers. This document
David Herrmann76c7c492014-07-29 17:14:26 +02007relies heavily on the definitions declared there.
David Herrmannd99b8ba2012-06-10 15:16:26 +02008
David Herrmann76c7c492014-07-29 17:14:26 +02009With UHID, a user-space transport driver can create kernel hid-devices for each
10device connected to the user-space controlled bus. The UHID API defines the I/O
11events provided from the kernel to user-space and vice versa.
David Herrmannd99b8ba2012-06-10 15:16:26 +020012
13There is an example user-space application in ./samples/uhid/uhid-example.c
14
15The UHID API
16------------
17
Randy Dunlap356006a2020-12-28 12:53:27 -080018UHID is accessed through a character misc-device. The minor number is allocated
David Herrmannd99b8ba2012-06-10 15:16:26 +020019dynamically so you need to rely on udev (or similar) to create the device node.
20This is /dev/uhid by default.
21
22If a new device is detected by your HID I/O Driver and you want to register this
23device with the HID subsystem, then you need to open /dev/uhid once for each
24device you want to register. All further communication is done by read()'ing or
25write()'ing "struct uhid_event" objects. Non-blocking operations are supported
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -030026by setting O_NONBLOCK::
David Herrmannd99b8ba2012-06-10 15:16:26 +020027
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -030028 struct uhid_event {
David Herrmannd99b8ba2012-06-10 15:16:26 +020029 __u32 type;
30 union {
David Herrmann76c7c492014-07-29 17:14:26 +020031 struct uhid_create2_req create2;
32 struct uhid_output_req output;
33 struct uhid_input2_req input2;
David Herrmannd99b8ba2012-06-10 15:16:26 +020034 ...
35 } u;
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -030036 };
David Herrmannd99b8ba2012-06-10 15:16:26 +020037
38The "type" field contains the ID of the event. Depending on the ID different
39payloads are sent. You must not split a single event across multiple read()'s or
40multiple write()'s. A single event must always be sent as a whole. Furthermore,
41only a single event can be sent per read() or write(). Pending data is ignored.
42If you want to handle multiple events in a single syscall, then use vectored
43I/O with readv()/writev().
David Herrmann76c7c492014-07-29 17:14:26 +020044The "type" field defines the payload. For each type, there is a
45payload-structure available in the union "u" (except for empty payloads). This
46payload contains management and/or device data.
David Herrmannd99b8ba2012-06-10 15:16:26 +020047
Randy Dunlap356006a2020-12-28 12:53:27 -080048The first thing you should do is send a UHID_CREATE2 event. This will
49register the device. UHID will respond with a UHID_START event. You can now
David Herrmannd99b8ba2012-06-10 15:16:26 +020050start sending data to and reading data from UHID. However, unless UHID sends the
51UHID_OPEN event, the internally attached HID Device Driver has no user attached.
52That is, you might put your device asleep unless you receive the UHID_OPEN
53event. If you receive the UHID_OPEN event, you should start I/O. If the last
Randy Dunlap356006a2020-12-28 12:53:27 -080054user closes the HID device, you will receive a UHID_CLOSE event. This may be
55followed by a UHID_OPEN event again and so on. There is no need to perform
David Herrmannd99b8ba2012-06-10 15:16:26 +020056reference-counting in user-space. That is, you will never receive multiple
Randy Dunlap356006a2020-12-28 12:53:27 -080057UHID_OPEN events without a UHID_CLOSE event. The HID subsystem performs
David Herrmannd99b8ba2012-06-10 15:16:26 +020058ref-counting for you.
59You may decide to ignore UHID_OPEN/UHID_CLOSE, though. I/O is allowed even
60though the device may have no users.
61
David Herrmann76c7c492014-07-29 17:14:26 +020062If you want to send data on the interrupt channel to the HID subsystem, you send
Randy Dunlap356006a2020-12-28 12:53:27 -080063a HID_INPUT2 event with your raw data payload. If the kernel wants to send data
64on the interrupt channel to the device, you will read a UHID_OUTPUT event.
David Herrmann76c7c492014-07-29 17:14:26 +020065Data requests on the control channel are currently limited to GET_REPORT and
66SET_REPORT (no other data reports on the control channel are defined so far).
67Those requests are always synchronous. That means, the kernel sends
68UHID_GET_REPORT and UHID_SET_REPORT events and requires you to forward them to
69the device on the control channel. Once the device responds, you must forward
70the response via UHID_GET_REPORT_REPLY and UHID_SET_REPORT_REPLY to the kernel.
71The kernel blocks internal driver-execution during such round-trips (times out
72after a hard-coded period).
David Herrmannd99b8ba2012-06-10 15:16:26 +020073
Randy Dunlap356006a2020-12-28 12:53:27 -080074If your device disconnects, you should send a UHID_DESTROY event. This will
David Herrmann76c7c492014-07-29 17:14:26 +020075unregister the device. You can now send UHID_CREATE2 again to register a new
David Herrmannd99b8ba2012-06-10 15:16:26 +020076device.
77If you close() the fd, the device is automatically unregistered and destroyed
78internally.
79
80write()
81-------
82write() allows you to modify the state of the device and feed input data into
David Herrmann76c7c492014-07-29 17:14:26 +020083the kernel. The kernel will parse the event immediately and if the event ID is
David Herrmannd99b8ba2012-06-10 15:16:26 +020084not supported, it will return -EOPNOTSUPP. If the payload is invalid, then
85-EINVAL is returned, otherwise, the amount of data that was read is returned and
David Herrmann76c7c492014-07-29 17:14:26 +020086the request was handled successfully. O_NONBLOCK does not affect write() as
87writes are always handled immediately in a non-blocking fashion. Future requests
88might make use of O_NONBLOCK, though.
David Herrmannd99b8ba2012-06-10 15:16:26 +020089
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -030090UHID_CREATE2:
David Herrmann76c7c492014-07-29 17:14:26 +020091 This creates the internal HID device. No I/O is possible until you send this
92 event to the kernel. The payload is of type struct uhid_create2_req and
93 contains information about your device. You can start I/O now.
Petri Gynther45226432014-03-24 13:50:01 -070094
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -030095UHID_DESTROY:
David Herrmannd99b8ba2012-06-10 15:16:26 +020096 This destroys the internal HID device. No further I/O will be accepted. There
97 may still be pending messages that you can receive with read() but no further
98 UHID_INPUT events can be sent to the kernel.
David Herrmann76c7c492014-07-29 17:14:26 +020099 You can create a new device by sending UHID_CREATE2 again. There is no need to
David Herrmannd99b8ba2012-06-10 15:16:26 +0200100 reopen the character device.
101
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300102UHID_INPUT2:
David Herrmann76c7c492014-07-29 17:14:26 +0200103 You must send UHID_CREATE2 before sending input to the kernel! This event
104 contains a data-payload. This is the raw data that you read from your device
105 on the interrupt channel. The kernel will parse the HID reports.
Petri Gynther45226432014-03-24 13:50:01 -0700106
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300107UHID_GET_REPORT_REPLY:
David Herrmann76c7c492014-07-29 17:14:26 +0200108 If you receive a UHID_GET_REPORT request you must answer with this request.
109 You must copy the "id" field from the request into the answer. Set the "err"
110 field to 0 if no error occurred or to EIO if an I/O error occurred.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200111 If "err" is 0 then you should fill the buffer of the answer with the results
David Herrmann76c7c492014-07-29 17:14:26 +0200112 of the GET_REPORT request and set "size" correspondingly.
113
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300114UHID_SET_REPORT_REPLY:
David Herrmann76c7c492014-07-29 17:14:26 +0200115 This is the SET_REPORT equivalent of UHID_GET_REPORT_REPLY. Unlike GET_REPORT,
116 SET_REPORT never returns a data buffer, therefore, it's sufficient to set the
117 "id" and "err" fields correctly.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200118
119read()
120------
David Herrmann76c7c492014-07-29 17:14:26 +0200121read() will return a queued output report. No reaction is required to any of
122them but you should handle them according to your needs.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200123
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300124UHID_START:
David Herrmannd99b8ba2012-06-10 15:16:26 +0200125 This is sent when the HID device is started. Consider this as an answer to
David Herrmann76c7c492014-07-29 17:14:26 +0200126 UHID_CREATE2. This is always the first event that is sent. Note that this
127 event might not be available immediately after write(UHID_CREATE2) returns.
Randy Dunlap356006a2020-12-28 12:53:27 -0800128 Device drivers might require delayed setups.
David Herrmann76c7c492014-07-29 17:14:26 +0200129 This event contains a payload of type uhid_start_req. The "dev_flags" field
130 describes special behaviors of a device. The following flags are defined:
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300131
132 - UHID_DEV_NUMBERED_FEATURE_REPORTS
133 - UHID_DEV_NUMBERED_OUTPUT_REPORTS
134 - UHID_DEV_NUMBERED_INPUT_REPORTS
135
David Herrmann76c7c492014-07-29 17:14:26 +0200136 Each of these flags defines whether a given report-type uses numbered
137 reports. If numbered reports are used for a type, all messages from
138 the kernel already have the report-number as prefix. Otherwise, no
139 prefix is added by the kernel.
140 For messages sent by user-space to the kernel, you must adjust the
141 prefixes according to these flags.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200142
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300143UHID_STOP:
David Herrmannd99b8ba2012-06-10 15:16:26 +0200144 This is sent when the HID device is stopped. Consider this as an answer to
145 UHID_DESTROY.
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300146
David Herrmann76c7c492014-07-29 17:14:26 +0200147 If you didn't destroy your device via UHID_DESTROY, but the kernel sends an
148 UHID_STOP event, this should usually be ignored. It means that the kernel
149 reloaded/changed the device driver loaded on your HID device (or some other
150 maintenance actions happened).
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300151
Randy Dunlap356006a2020-12-28 12:53:27 -0800152 You can usually ignore any UHID_STOP events safely.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200153
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300154UHID_OPEN:
David Herrmannd99b8ba2012-06-10 15:16:26 +0200155 This is sent when the HID device is opened. That is, the data that the HID
156 device provides is read by some other process. You may ignore this event but
157 it is useful for power-management. As long as you haven't received this event
158 there is actually no other process that reads your data so there is no need to
David Herrmann76c7c492014-07-29 17:14:26 +0200159 send UHID_INPUT2 events to the kernel.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200160
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300161UHID_CLOSE:
David Herrmannd99b8ba2012-06-10 15:16:26 +0200162 This is sent when there are no more processes which read the HID data. It is
163 the counterpart of UHID_OPEN and you may as well ignore this event.
164
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300165UHID_OUTPUT:
David Herrmannd99b8ba2012-06-10 15:16:26 +0200166 This is sent if the HID device driver wants to send raw data to the I/O
David Herrmann76c7c492014-07-29 17:14:26 +0200167 device on the interrupt channel. You should read the payload and forward it to
Peter Hutterer46b14ee2018-12-13 11:28:51 +1000168 the device. The payload is of type "struct uhid_output_req".
Randy Dunlap356006a2020-12-28 12:53:27 -0800169 This may be received even though you haven't received UHID_OPEN yet.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200170
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300171UHID_GET_REPORT:
David Herrmann76c7c492014-07-29 17:14:26 +0200172 This event is sent if the kernel driver wants to perform a GET_REPORT request
Randy Dunlap356006a2020-12-28 12:53:27 -0800173 on the control channel as described in the HID specs. The report-type and
David Herrmann76c7c492014-07-29 17:14:26 +0200174 report-number are available in the payload.
175 The kernel serializes GET_REPORT requests so there will never be two in
176 parallel. However, if you fail to respond with a UHID_GET_REPORT_REPLY, the
177 request might silently time out.
Randy Dunlap356006a2020-12-28 12:53:27 -0800178 Once you read a GET_REPORT request, you shall forward it to the HID device and
179 remember the "id" field in the payload. Once your HID device responds to the
David Herrmann76c7c492014-07-29 17:14:26 +0200180 GET_REPORT (or if it fails), you must send a UHID_GET_REPORT_REPLY to the
181 kernel with the exact same "id" as in the request. If the request already
182 timed out, the kernel will ignore the response silently. The "id" field is
183 never re-used, so conflicts cannot happen.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200184
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300185UHID_SET_REPORT:
David Herrmann76c7c492014-07-29 17:14:26 +0200186 This is the SET_REPORT equivalent of UHID_GET_REPORT. On receipt, you shall
Randy Dunlap356006a2020-12-28 12:53:27 -0800187 send a SET_REPORT request to your HID device. Once it replies, you must tell
David Herrmann76c7c492014-07-29 17:14:26 +0200188 the kernel about it via UHID_SET_REPORT_REPLY.
189 The same restrictions as for UHID_GET_REPORT apply.
David Herrmannd99b8ba2012-06-10 15:16:26 +0200190
David Herrmann76c7c492014-07-29 17:14:26 +0200191----------------------------------------------------
Mauro Carvalho Chehabcca47862019-06-28 09:19:59 -0300192
David Herrmann76c7c492014-07-29 17:14:26 +0200193Written 2012, David Herrmann <dh.herrmann@gmail.com>