blob: 69586b31640940d1ea58cf20aff50697a4abca52 [file] [log] [blame]
Jiri Slabybd28ce02008-06-25 23:47:04 +02001/*
Frank Praznik077147a2014-09-14 11:56:39 -04002 * HID driver for Sony / PS2 / PS3 / PS4 BD devices.
Jiri Slabybd28ce02008-06-25 23:47:04 +02003 *
4 * Copyright (c) 1999 Andreas Gal
5 * Copyright (c) 2000-2005 Vojtech Pavlik <vojtech@suse.cz>
6 * Copyright (c) 2005 Michael Haboustak <mike-@cinci.rr.com> for Concept2, Inc
Jiri Slabybd28ce02008-06-25 23:47:04 +02007 * Copyright (c) 2008 Jiri Slaby
Jiri Kosina078328d2013-06-13 12:03:49 +02008 * Copyright (c) 2012 David Dillow <dave@thedillows.org>
9 * Copyright (c) 2006-2013 Jiri Kosina
Colin Leitnerf04d5142013-05-27 23:41:05 +020010 * Copyright (c) 2013 Colin Leitner <colin.leitner@gmail.com>
Frank Praznik077147a2014-09-14 11:56:39 -040011 * Copyright (c) 2014 Frank Praznik <frank.praznik@gmail.com>
Jiri Slabybd28ce02008-06-25 23:47:04 +020012 */
13
14/*
15 * This program is free software; you can redistribute it and/or modify it
16 * under the terms of the GNU General Public License as published by the Free
17 * Software Foundation; either version 2 of the License, or (at your option)
18 * any later version.
19 */
20
Frank Praznikad142b92014-02-20 11:36:00 -050021/*
22 * NOTE: in order for the Sony PS3 BD Remote Control to be found by
Jiri Kosina078328d2013-06-13 12:03:49 +020023 * a Bluetooth host, the key combination Start+Enter has to be kept pressed
24 * for about 7 seconds with the Bluetooth Host Controller in discovering mode.
25 *
26 * There will be no PIN request from the device.
27 */
28
Jiri Slabybd28ce02008-06-25 23:47:04 +020029#include <linux/device.h>
30#include <linux/hid.h>
31#include <linux/module.h>
Tejun Heo5a0e3ad2010-03-24 17:04:11 +090032#include <linux/slab.h>
Jiri Kosina40e32ee2013-05-28 11:22:09 +020033#include <linux/leds.h>
Frank Praznikd902f472014-01-27 10:17:36 -050034#include <linux/power_supply.h>
35#include <linux/spinlock.h>
Frank Praznikd2d782f2014-02-20 11:36:03 -050036#include <linux/list.h>
Frank Praznik80250872014-04-14 10:11:35 -040037#include <linux/idr.h>
Frank Praznike5606232014-01-27 10:17:37 -050038#include <linux/input/mt.h>
Jiri Slabybd28ce02008-06-25 23:47:04 +020039
40#include "hid-ids.h"
41
Frank Praznik6c79c182014-01-16 21:43:03 -050042#define VAIO_RDESC_CONSTANT BIT(0)
43#define SIXAXIS_CONTROLLER_USB BIT(1)
44#define SIXAXIS_CONTROLLER_BT BIT(2)
45#define BUZZ_CONTROLLER BIT(3)
46#define PS3REMOTE BIT(4)
Frank Praznik8ab16762014-01-16 21:42:31 -050047#define DUALSHOCK4_CONTROLLER_USB BIT(5)
48#define DUALSHOCK4_CONTROLLER_BT BIT(6)
Simon Woodb3bca322015-06-09 21:27:04 -060049#define MOTION_CONTROLLER_USB BIT(7)
50#define MOTION_CONTROLLER_BT BIT(8)
Simon Wood4545ee02015-06-17 00:08:52 -060051#define NAVIGATION_CONTROLLER_USB BIT(9)
52#define NAVIGATION_CONTROLLER_BT BIT(10)
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +020053
Frank Praznikfee4e2d2014-02-18 17:22:01 -050054#define SIXAXIS_CONTROLLER (SIXAXIS_CONTROLLER_USB | SIXAXIS_CONTROLLER_BT)
Simon Woodb3bca322015-06-09 21:27:04 -060055#define MOTION_CONTROLLER (MOTION_CONTROLLER_USB | MOTION_CONTROLLER_BT)
Simon Wood4545ee02015-06-17 00:08:52 -060056#define NAVIGATION_CONTROLLER (NAVIGATION_CONTROLLER_USB |\
57 NAVIGATION_CONTROLLER_BT)
Frank Praznik68330d82014-02-05 20:03:49 -050058#define DUALSHOCK4_CONTROLLER (DUALSHOCK4_CONTROLLER_USB |\
59 DUALSHOCK4_CONTROLLER_BT)
Frank Praznikfee4e2d2014-02-18 17:22:01 -050060#define SONY_LED_SUPPORT (SIXAXIS_CONTROLLER | BUZZ_CONTROLLER |\
Simon Wood4545ee02015-06-17 00:08:52 -060061 DUALSHOCK4_CONTROLLER | MOTION_CONTROLLER |\
62 NAVIGATION_CONTROLLER)
Simon Wood12e9a6d72015-06-09 21:27:05 -060063#define SONY_BATTERY_SUPPORT (SIXAXIS_CONTROLLER | DUALSHOCK4_CONTROLLER |\
Simon Wood4545ee02015-06-17 00:08:52 -060064 MOTION_CONTROLLER_BT | NAVIGATION_CONTROLLER)
Frank Praznikc5e0c1c2015-05-05 20:47:30 -040065#define SONY_FF_SUPPORT (SIXAXIS_CONTROLLER | DUALSHOCK4_CONTROLLER |\
66 MOTION_CONTROLLER)
Frank Praznik60781cf2014-01-11 15:13:15 -050067
68#define MAX_LEDS 4
Sven Eckelmann0a286ef2013-11-19 20:26:32 +010069
Frank Praznik4c3e8292015-05-05 20:47:33 -040070/*
71 * The Sixaxis reports both digital and analog values for each button on the
72 * controller except for Start, Select and the PS button. The controller ends
73 * up reporting 27 axes which causes them to spill over into the multi-touch
74 * axis values. Additionally, the controller only has 20 actual, physical axes
75 * so there are several unused axes in between the used ones.
76 */
Antonio Ospitec607fb82014-06-24 13:28:41 +020077static __u8 sixaxis_rdesc[] = {
Antonio Ospitefb705a62014-06-24 13:28:42 +020078 0x05, 0x01, /* Usage Page (Desktop), */
Frank Praznik4c3e8292015-05-05 20:47:33 -040079 0x09, 0x04, /* Usage (Joystick), */
Antonio Ospitefb705a62014-06-24 13:28:42 +020080 0xA1, 0x01, /* Collection (Application), */
81 0xA1, 0x02, /* Collection (Logical), */
82 0x85, 0x01, /* Report ID (1), */
83 0x75, 0x08, /* Report Size (8), */
84 0x95, 0x01, /* Report Count (1), */
85 0x15, 0x00, /* Logical Minimum (0), */
86 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
87 0x81, 0x03, /* Input (Constant, Variable), */
88 0x75, 0x01, /* Report Size (1), */
89 0x95, 0x13, /* Report Count (19), */
90 0x15, 0x00, /* Logical Minimum (0), */
91 0x25, 0x01, /* Logical Maximum (1), */
92 0x35, 0x00, /* Physical Minimum (0), */
93 0x45, 0x01, /* Physical Maximum (1), */
94 0x05, 0x09, /* Usage Page (Button), */
95 0x19, 0x01, /* Usage Minimum (01h), */
96 0x29, 0x13, /* Usage Maximum (13h), */
97 0x81, 0x02, /* Input (Variable), */
98 0x75, 0x01, /* Report Size (1), */
99 0x95, 0x0D, /* Report Count (13), */
100 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
101 0x81, 0x03, /* Input (Constant, Variable), */
102 0x15, 0x00, /* Logical Minimum (0), */
103 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
104 0x05, 0x01, /* Usage Page (Desktop), */
105 0x09, 0x01, /* Usage (Pointer), */
106 0xA1, 0x00, /* Collection (Physical), */
107 0x75, 0x08, /* Report Size (8), */
108 0x95, 0x04, /* Report Count (4), */
109 0x35, 0x00, /* Physical Minimum (0), */
110 0x46, 0xFF, 0x00, /* Physical Maximum (255), */
111 0x09, 0x30, /* Usage (X), */
112 0x09, 0x31, /* Usage (Y), */
113 0x09, 0x32, /* Usage (Z), */
114 0x09, 0x35, /* Usage (Rz), */
115 0x81, 0x02, /* Input (Variable), */
116 0xC0, /* End Collection, */
117 0x05, 0x01, /* Usage Page (Desktop), */
118 0x95, 0x13, /* Report Count (19), */
119 0x09, 0x01, /* Usage (Pointer), */
120 0x81, 0x02, /* Input (Variable), */
121 0x95, 0x0C, /* Report Count (12), */
122 0x81, 0x01, /* Input (Constant), */
123 0x75, 0x10, /* Report Size (16), */
124 0x95, 0x04, /* Report Count (4), */
125 0x26, 0xFF, 0x03, /* Logical Maximum (1023), */
126 0x46, 0xFF, 0x03, /* Physical Maximum (1023), */
127 0x09, 0x01, /* Usage (Pointer), */
128 0x81, 0x02, /* Input (Variable), */
129 0xC0, /* End Collection, */
130 0xA1, 0x02, /* Collection (Logical), */
131 0x85, 0x02, /* Report ID (2), */
132 0x75, 0x08, /* Report Size (8), */
133 0x95, 0x30, /* Report Count (48), */
134 0x09, 0x01, /* Usage (Pointer), */
135 0xB1, 0x02, /* Feature (Variable), */
136 0xC0, /* End Collection, */
137 0xA1, 0x02, /* Collection (Logical), */
138 0x85, 0xEE, /* Report ID (238), */
139 0x75, 0x08, /* Report Size (8), */
140 0x95, 0x30, /* Report Count (48), */
141 0x09, 0x01, /* Usage (Pointer), */
142 0xB1, 0x02, /* Feature (Variable), */
143 0xC0, /* End Collection, */
144 0xA1, 0x02, /* Collection (Logical), */
145 0x85, 0xEF, /* Report ID (239), */
146 0x75, 0x08, /* Report Size (8), */
147 0x95, 0x30, /* Report Count (48), */
148 0x09, 0x01, /* Usage (Pointer), */
149 0xB1, 0x02, /* Feature (Variable), */
150 0xC0, /* End Collection, */
151 0xC0 /* End Collection */
Mauro Carvalho Chehabe57a67d2012-12-14 20:57:34 -0200152};
153
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400154/* PS/3 Motion controller */
155static __u8 motion_rdesc[] = {
156 0x05, 0x01, /* Usage Page (Desktop), */
157 0x09, 0x04, /* Usage (Joystick), */
158 0xA1, 0x01, /* Collection (Application), */
159 0xA1, 0x02, /* Collection (Logical), */
160 0x85, 0x01, /* Report ID (1), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400161 0x75, 0x01, /* Report Size (1), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600162 0x95, 0x15, /* Report Count (21), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400163 0x15, 0x00, /* Logical Minimum (0), */
164 0x25, 0x01, /* Logical Maximum (1), */
165 0x35, 0x00, /* Physical Minimum (0), */
166 0x45, 0x01, /* Physical Maximum (1), */
167 0x05, 0x09, /* Usage Page (Button), */
168 0x19, 0x01, /* Usage Minimum (01h), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600169 0x29, 0x15, /* Usage Maximum (15h), */
170 0x81, 0x02, /* Input (Variable), * Buttons */
171 0x95, 0x0B, /* Report Count (11), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400172 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600173 0x81, 0x03, /* Input (Constant, Variable), * Padding */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400174 0x15, 0x00, /* Logical Minimum (0), */
175 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
176 0x05, 0x01, /* Usage Page (Desktop), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400177 0xA1, 0x00, /* Collection (Physical), */
178 0x75, 0x08, /* Report Size (8), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600179 0x95, 0x01, /* Report Count (1), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400180 0x35, 0x00, /* Physical Minimum (0), */
181 0x46, 0xFF, 0x00, /* Physical Maximum (255), */
182 0x09, 0x30, /* Usage (X), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600183 0x81, 0x02, /* Input (Variable), * Trigger */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400184 0xC0, /* End Collection, */
Simon Wood8b2513c2015-06-09 21:27:07 -0600185 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
186 0x75, 0x08, /* Report Size (8), */
187 0x95, 0x07, /* Report Count (7), * skip 7 bytes */
188 0x81, 0x02, /* Input (Variable), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400189 0x05, 0x01, /* Usage Page (Desktop), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400190 0x75, 0x10, /* Report Size (16), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600191 0x46, 0xFF, 0xFF, /* Physical Maximum (65535), */
192 0x27, 0xFF, 0xFF, 0x00, 0x00, /* Logical Maximum (65535), */
193 0x95, 0x03, /* Report Count (3), * 3x Accels */
194 0x09, 0x33, /* Usage (rX), */
195 0x09, 0x34, /* Usage (rY), */
196 0x09, 0x35, /* Usage (rZ), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400197 0x81, 0x02, /* Input (Variable), */
Simon Wood8b2513c2015-06-09 21:27:07 -0600198 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
199 0x95, 0x03, /* Report Count (3), * Skip Accels 2nd frame */
200 0x81, 0x02, /* Input (Variable), */
201 0x05, 0x01, /* Usage Page (Desktop), */
202 0x09, 0x01, /* Usage (Pointer), */
203 0x95, 0x03, /* Report Count (3), * 3x Gyros */
204 0x81, 0x02, /* Input (Variable), */
205 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
206 0x95, 0x03, /* Report Count (3), * Skip Gyros 2nd frame */
207 0x81, 0x02, /* Input (Variable), */
208 0x75, 0x0C, /* Report Size (12), */
209 0x46, 0xFF, 0x0F, /* Physical Maximum (4095), */
210 0x26, 0xFF, 0x0F, /* Logical Maximum (4095), */
211 0x95, 0x04, /* Report Count (4), * Skip Temp and Magnetometers */
212 0x81, 0x02, /* Input (Variable), */
213 0x75, 0x08, /* Report Size (8), */
214 0x46, 0xFF, 0x00, /* Physical Maximum (255), */
215 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
216 0x95, 0x06, /* Report Count (6), * Skip Timestamp and Extension Bytes */
217 0x81, 0x02, /* Input (Variable), */
218 0x75, 0x08, /* Report Size (8), */
219 0x95, 0x30, /* Report Count (48), */
220 0x09, 0x01, /* Usage (Pointer), */
221 0x91, 0x02, /* Output (Variable), */
222 0x75, 0x08, /* Report Size (8), */
223 0x95, 0x30, /* Report Count (48), */
224 0x09, 0x01, /* Usage (Pointer), */
225 0xB1, 0x02, /* Feature (Variable), */
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400226 0xC0, /* End Collection, */
227 0xA1, 0x02, /* Collection (Logical), */
228 0x85, 0x02, /* Report ID (2), */
229 0x75, 0x08, /* Report Size (8), */
230 0x95, 0x30, /* Report Count (48), */
231 0x09, 0x01, /* Usage (Pointer), */
232 0xB1, 0x02, /* Feature (Variable), */
233 0xC0, /* End Collection, */
234 0xA1, 0x02, /* Collection (Logical), */
235 0x85, 0xEE, /* Report ID (238), */
236 0x75, 0x08, /* Report Size (8), */
237 0x95, 0x30, /* Report Count (48), */
238 0x09, 0x01, /* Usage (Pointer), */
239 0xB1, 0x02, /* Feature (Variable), */
240 0xC0, /* End Collection, */
241 0xA1, 0x02, /* Collection (Logical), */
242 0x85, 0xEF, /* Report ID (239), */
243 0x75, 0x08, /* Report Size (8), */
244 0x95, 0x30, /* Report Count (48), */
245 0x09, 0x01, /* Usage (Pointer), */
246 0xB1, 0x02, /* Feature (Variable), */
247 0xC0, /* End Collection, */
248 0xC0 /* End Collection */
249};
250
Simon Woodb2723eb2015-06-17 00:08:53 -0600251/* PS/3 Navigation controller */
252static __u8 navigation_rdesc[] = {
253 0x05, 0x01, /* Usage Page (Desktop), */
254 0x09, 0x04, /* Usage (Joystik), */
255 0xA1, 0x01, /* Collection (Application), */
256 0xA1, 0x02, /* Collection (Logical), */
257 0x85, 0x01, /* Report ID (1), */
258 0x75, 0x08, /* Report Size (8), */
259 0x95, 0x01, /* Report Count (1), */
260 0x15, 0x00, /* Logical Minimum (0), */
261 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
262 0x81, 0x03, /* Input (Constant, Variable), */
263 0x75, 0x01, /* Report Size (1), */
264 0x95, 0x13, /* Report Count (19), */
265 0x15, 0x00, /* Logical Minimum (0), */
266 0x25, 0x01, /* Logical Maximum (1), */
267 0x35, 0x00, /* Physical Minimum (0), */
268 0x45, 0x01, /* Physical Maximum (1), */
269 0x05, 0x09, /* Usage Page (Button), */
270 0x19, 0x01, /* Usage Minimum (01h), */
271 0x29, 0x13, /* Usage Maximum (13h), */
272 0x81, 0x02, /* Input (Variable), */
273 0x75, 0x01, /* Report Size (1), */
274 0x95, 0x0D, /* Report Count (13), */
275 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
276 0x81, 0x03, /* Input (Constant, Variable), */
277 0x15, 0x00, /* Logical Minimum (0), */
278 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
279 0x05, 0x01, /* Usage Page (Desktop), */
280 0x09, 0x01, /* Usage (Pointer), */
281 0xA1, 0x00, /* Collection (Physical), */
282 0x75, 0x08, /* Report Size (8), */
283 0x95, 0x02, /* Report Count (2), */
284 0x35, 0x00, /* Physical Minimum (0), */
285 0x46, 0xFF, 0x00, /* Physical Maximum (255), */
286 0x09, 0x30, /* Usage (X), */
287 0x09, 0x31, /* Usage (Y), */
288 0x81, 0x02, /* Input (Variable), */
289 0xC0, /* End Collection, */
290 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
291 0x95, 0x06, /* Report Count (6), */
292 0x81, 0x03, /* Input (Constant, Variable), */
293 0x05, 0x01, /* Usage Page (Desktop), */
294 0x75, 0x08, /* Report Size (8), */
295 0x95, 0x05, /* Report Count (5), */
296 0x09, 0x01, /* Usage (Pointer), */
297 0x81, 0x02, /* Input (Variable), */
298 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
Simon Wood2259b5bb2015-07-10 00:10:21 -0600299 0x95, 0x01, /* Report Count (1), */
300 0x81, 0x02, /* Input (Variable), */
301 0x05, 0x01, /* Usage Page (Desktop), */
302 0x95, 0x01, /* Report Count (1), */
303 0x09, 0x01, /* Usage (Pointer), */
304 0x81, 0x02, /* Input (Variable), */
305 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
306 0x95, 0x1E, /* Report Count (24), */
Simon Woodb2723eb2015-06-17 00:08:53 -0600307 0x81, 0x02, /* Input (Variable), */
308 0x75, 0x08, /* Report Size (8), */
309 0x95, 0x30, /* Report Count (48), */
310 0x09, 0x01, /* Usage (Pointer), */
311 0x91, 0x02, /* Output (Variable), */
312 0x75, 0x08, /* Report Size (8), */
313 0x95, 0x30, /* Report Count (48), */
314 0x09, 0x01, /* Usage (Pointer), */
315 0xB1, 0x02, /* Feature (Variable), */
316 0xC0, /* End Collection, */
317 0xA1, 0x02, /* Collection (Logical), */
318 0x85, 0x02, /* Report ID (2), */
319 0x75, 0x08, /* Report Size (8), */
320 0x95, 0x30, /* Report Count (48), */
321 0x09, 0x01, /* Usage (Pointer), */
322 0xB1, 0x02, /* Feature (Variable), */
323 0xC0, /* End Collection, */
324 0xA1, 0x02, /* Collection (Logical), */
325 0x85, 0xEE, /* Report ID (238), */
326 0x75, 0x08, /* Report Size (8), */
327 0x95, 0x30, /* Report Count (48), */
328 0x09, 0x01, /* Usage (Pointer), */
329 0xB1, 0x02, /* Feature (Variable), */
330 0xC0, /* End Collection, */
331 0xA1, 0x02, /* Collection (Logical), */
332 0x85, 0xEF, /* Report ID (239), */
333 0x75, 0x08, /* Report Size (8), */
334 0x95, 0x30, /* Report Count (48), */
335 0x09, 0x01, /* Usage (Pointer), */
336 0xB1, 0x02, /* Feature (Variable), */
337 0xC0, /* End Collection, */
338 0xC0 /* End Collection */
339};
Frank Praznikc5e0c1c2015-05-05 20:47:30 -0400340
Frank Praznikad142b92014-02-20 11:36:00 -0500341/*
342 * The default descriptor doesn't provide mapping for the accelerometers
Frank Praznik58d70272014-01-20 12:27:01 -0500343 * or orientation sensors. This fixed descriptor maps the accelerometers
344 * to usage values 0x40, 0x41 and 0x42 and maps the orientation sensors
345 * to usage values 0x43, 0x44 and 0x45.
346 */
Frank Prazniked19d8c2014-01-16 21:43:12 -0500347static u8 dualshock4_usb_rdesc[] = {
Frank Praznik58d70272014-01-20 12:27:01 -0500348 0x05, 0x01, /* Usage Page (Desktop), */
349 0x09, 0x05, /* Usage (Gamepad), */
350 0xA1, 0x01, /* Collection (Application), */
351 0x85, 0x01, /* Report ID (1), */
352 0x09, 0x30, /* Usage (X), */
353 0x09, 0x31, /* Usage (Y), */
354 0x09, 0x32, /* Usage (Z), */
355 0x09, 0x35, /* Usage (Rz), */
356 0x15, 0x00, /* Logical Minimum (0), */
357 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
358 0x75, 0x08, /* Report Size (8), */
359 0x95, 0x04, /* Report Count (4), */
360 0x81, 0x02, /* Input (Variable), */
361 0x09, 0x39, /* Usage (Hat Switch), */
362 0x15, 0x00, /* Logical Minimum (0), */
363 0x25, 0x07, /* Logical Maximum (7), */
364 0x35, 0x00, /* Physical Minimum (0), */
365 0x46, 0x3B, 0x01, /* Physical Maximum (315), */
366 0x65, 0x14, /* Unit (Degrees), */
367 0x75, 0x04, /* Report Size (4), */
368 0x95, 0x01, /* Report Count (1), */
369 0x81, 0x42, /* Input (Variable, Null State), */
370 0x65, 0x00, /* Unit, */
371 0x05, 0x09, /* Usage Page (Button), */
372 0x19, 0x01, /* Usage Minimum (01h), */
373 0x29, 0x0E, /* Usage Maximum (0Eh), */
374 0x15, 0x00, /* Logical Minimum (0), */
375 0x25, 0x01, /* Logical Maximum (1), */
376 0x75, 0x01, /* Report Size (1), */
377 0x95, 0x0E, /* Report Count (14), */
378 0x81, 0x02, /* Input (Variable), */
379 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
380 0x09, 0x20, /* Usage (20h), */
381 0x75, 0x06, /* Report Size (6), */
382 0x95, 0x01, /* Report Count (1), */
383 0x15, 0x00, /* Logical Minimum (0), */
Frank Praznikfb291cb2014-09-14 11:56:38 -0400384 0x25, 0x3F, /* Logical Maximum (63), */
Frank Praznik58d70272014-01-20 12:27:01 -0500385 0x81, 0x02, /* Input (Variable), */
386 0x05, 0x01, /* Usage Page (Desktop), */
387 0x09, 0x33, /* Usage (Rx), */
388 0x09, 0x34, /* Usage (Ry), */
389 0x15, 0x00, /* Logical Minimum (0), */
390 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
391 0x75, 0x08, /* Report Size (8), */
392 0x95, 0x02, /* Report Count (2), */
393 0x81, 0x02, /* Input (Variable), */
394 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
395 0x09, 0x21, /* Usage (21h), */
396 0x95, 0x03, /* Report Count (3), */
397 0x81, 0x02, /* Input (Variable), */
398 0x05, 0x01, /* Usage Page (Desktop), */
399 0x19, 0x40, /* Usage Minimum (40h), */
400 0x29, 0x42, /* Usage Maximum (42h), */
401 0x16, 0x00, 0x80, /* Logical Minimum (-32768), */
402 0x26, 0x00, 0x7F, /* Logical Maximum (32767), */
403 0x75, 0x10, /* Report Size (16), */
404 0x95, 0x03, /* Report Count (3), */
405 0x81, 0x02, /* Input (Variable), */
406 0x19, 0x43, /* Usage Minimum (43h), */
407 0x29, 0x45, /* Usage Maximum (45h), */
Frank Praznikfb291cb2014-09-14 11:56:38 -0400408 0x16, 0x00, 0xE0, /* Logical Minimum (-8192), */
409 0x26, 0xFF, 0x1F, /* Logical Maximum (8191), */
Frank Praznik58d70272014-01-20 12:27:01 -0500410 0x95, 0x03, /* Report Count (3), */
411 0x81, 0x02, /* Input (Variable), */
412 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
413 0x09, 0x21, /* Usage (21h), */
414 0x15, 0x00, /* Logical Minimum (0), */
Frank Praznikfb291cb2014-09-14 11:56:38 -0400415 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
Frank Praznik58d70272014-01-20 12:27:01 -0500416 0x75, 0x08, /* Report Size (8), */
417 0x95, 0x27, /* Report Count (39), */
418 0x81, 0x02, /* Input (Variable), */
419 0x85, 0x05, /* Report ID (5), */
420 0x09, 0x22, /* Usage (22h), */
421 0x95, 0x1F, /* Report Count (31), */
422 0x91, 0x02, /* Output (Variable), */
423 0x85, 0x04, /* Report ID (4), */
424 0x09, 0x23, /* Usage (23h), */
425 0x95, 0x24, /* Report Count (36), */
426 0xB1, 0x02, /* Feature (Variable), */
427 0x85, 0x02, /* Report ID (2), */
428 0x09, 0x24, /* Usage (24h), */
429 0x95, 0x24, /* Report Count (36), */
430 0xB1, 0x02, /* Feature (Variable), */
431 0x85, 0x08, /* Report ID (8), */
432 0x09, 0x25, /* Usage (25h), */
433 0x95, 0x03, /* Report Count (3), */
434 0xB1, 0x02, /* Feature (Variable), */
435 0x85, 0x10, /* Report ID (16), */
436 0x09, 0x26, /* Usage (26h), */
437 0x95, 0x04, /* Report Count (4), */
438 0xB1, 0x02, /* Feature (Variable), */
439 0x85, 0x11, /* Report ID (17), */
440 0x09, 0x27, /* Usage (27h), */
441 0x95, 0x02, /* Report Count (2), */
442 0xB1, 0x02, /* Feature (Variable), */
443 0x85, 0x12, /* Report ID (18), */
444 0x06, 0x02, 0xFF, /* Usage Page (FF02h), */
445 0x09, 0x21, /* Usage (21h), */
446 0x95, 0x0F, /* Report Count (15), */
447 0xB1, 0x02, /* Feature (Variable), */
448 0x85, 0x13, /* Report ID (19), */
449 0x09, 0x22, /* Usage (22h), */
450 0x95, 0x16, /* Report Count (22), */
451 0xB1, 0x02, /* Feature (Variable), */
452 0x85, 0x14, /* Report ID (20), */
453 0x06, 0x05, 0xFF, /* Usage Page (FF05h), */
454 0x09, 0x20, /* Usage (20h), */
455 0x95, 0x10, /* Report Count (16), */
456 0xB1, 0x02, /* Feature (Variable), */
457 0x85, 0x15, /* Report ID (21), */
458 0x09, 0x21, /* Usage (21h), */
459 0x95, 0x2C, /* Report Count (44), */
460 0xB1, 0x02, /* Feature (Variable), */
461 0x06, 0x80, 0xFF, /* Usage Page (FF80h), */
462 0x85, 0x80, /* Report ID (128), */
463 0x09, 0x20, /* Usage (20h), */
464 0x95, 0x06, /* Report Count (6), */
465 0xB1, 0x02, /* Feature (Variable), */
466 0x85, 0x81, /* Report ID (129), */
467 0x09, 0x21, /* Usage (21h), */
468 0x95, 0x06, /* Report Count (6), */
469 0xB1, 0x02, /* Feature (Variable), */
470 0x85, 0x82, /* Report ID (130), */
471 0x09, 0x22, /* Usage (22h), */
472 0x95, 0x05, /* Report Count (5), */
473 0xB1, 0x02, /* Feature (Variable), */
474 0x85, 0x83, /* Report ID (131), */
475 0x09, 0x23, /* Usage (23h), */
476 0x95, 0x01, /* Report Count (1), */
477 0xB1, 0x02, /* Feature (Variable), */
478 0x85, 0x84, /* Report ID (132), */
479 0x09, 0x24, /* Usage (24h), */
480 0x95, 0x04, /* Report Count (4), */
481 0xB1, 0x02, /* Feature (Variable), */
482 0x85, 0x85, /* Report ID (133), */
483 0x09, 0x25, /* Usage (25h), */
484 0x95, 0x06, /* Report Count (6), */
485 0xB1, 0x02, /* Feature (Variable), */
486 0x85, 0x86, /* Report ID (134), */
487 0x09, 0x26, /* Usage (26h), */
488 0x95, 0x06, /* Report Count (6), */
489 0xB1, 0x02, /* Feature (Variable), */
490 0x85, 0x87, /* Report ID (135), */
491 0x09, 0x27, /* Usage (27h), */
492 0x95, 0x23, /* Report Count (35), */
493 0xB1, 0x02, /* Feature (Variable), */
494 0x85, 0x88, /* Report ID (136), */
495 0x09, 0x28, /* Usage (28h), */
496 0x95, 0x22, /* Report Count (34), */
497 0xB1, 0x02, /* Feature (Variable), */
498 0x85, 0x89, /* Report ID (137), */
499 0x09, 0x29, /* Usage (29h), */
500 0x95, 0x02, /* Report Count (2), */
501 0xB1, 0x02, /* Feature (Variable), */
502 0x85, 0x90, /* Report ID (144), */
503 0x09, 0x30, /* Usage (30h), */
504 0x95, 0x05, /* Report Count (5), */
505 0xB1, 0x02, /* Feature (Variable), */
506 0x85, 0x91, /* Report ID (145), */
507 0x09, 0x31, /* Usage (31h), */
508 0x95, 0x03, /* Report Count (3), */
509 0xB1, 0x02, /* Feature (Variable), */
510 0x85, 0x92, /* Report ID (146), */
511 0x09, 0x32, /* Usage (32h), */
512 0x95, 0x03, /* Report Count (3), */
513 0xB1, 0x02, /* Feature (Variable), */
514 0x85, 0x93, /* Report ID (147), */
515 0x09, 0x33, /* Usage (33h), */
516 0x95, 0x0C, /* Report Count (12), */
517 0xB1, 0x02, /* Feature (Variable), */
518 0x85, 0xA0, /* Report ID (160), */
519 0x09, 0x40, /* Usage (40h), */
520 0x95, 0x06, /* Report Count (6), */
521 0xB1, 0x02, /* Feature (Variable), */
522 0x85, 0xA1, /* Report ID (161), */
523 0x09, 0x41, /* Usage (41h), */
524 0x95, 0x01, /* Report Count (1), */
525 0xB1, 0x02, /* Feature (Variable), */
526 0x85, 0xA2, /* Report ID (162), */
527 0x09, 0x42, /* Usage (42h), */
528 0x95, 0x01, /* Report Count (1), */
529 0xB1, 0x02, /* Feature (Variable), */
530 0x85, 0xA3, /* Report ID (163), */
531 0x09, 0x43, /* Usage (43h), */
532 0x95, 0x30, /* Report Count (48), */
533 0xB1, 0x02, /* Feature (Variable), */
534 0x85, 0xA4, /* Report ID (164), */
535 0x09, 0x44, /* Usage (44h), */
536 0x95, 0x0D, /* Report Count (13), */
537 0xB1, 0x02, /* Feature (Variable), */
538 0x85, 0xA5, /* Report ID (165), */
539 0x09, 0x45, /* Usage (45h), */
540 0x95, 0x15, /* Report Count (21), */
541 0xB1, 0x02, /* Feature (Variable), */
542 0x85, 0xA6, /* Report ID (166), */
543 0x09, 0x46, /* Usage (46h), */
544 0x95, 0x15, /* Report Count (21), */
545 0xB1, 0x02, /* Feature (Variable), */
546 0x85, 0xF0, /* Report ID (240), */
547 0x09, 0x47, /* Usage (47h), */
548 0x95, 0x3F, /* Report Count (63), */
549 0xB1, 0x02, /* Feature (Variable), */
550 0x85, 0xF1, /* Report ID (241), */
551 0x09, 0x48, /* Usage (48h), */
552 0x95, 0x3F, /* Report Count (63), */
553 0xB1, 0x02, /* Feature (Variable), */
554 0x85, 0xF2, /* Report ID (242), */
555 0x09, 0x49, /* Usage (49h), */
556 0x95, 0x0F, /* Report Count (15), */
557 0xB1, 0x02, /* Feature (Variable), */
558 0x85, 0xA7, /* Report ID (167), */
559 0x09, 0x4A, /* Usage (4Ah), */
560 0x95, 0x01, /* Report Count (1), */
561 0xB1, 0x02, /* Feature (Variable), */
562 0x85, 0xA8, /* Report ID (168), */
563 0x09, 0x4B, /* Usage (4Bh), */
564 0x95, 0x01, /* Report Count (1), */
565 0xB1, 0x02, /* Feature (Variable), */
566 0x85, 0xA9, /* Report ID (169), */
567 0x09, 0x4C, /* Usage (4Ch), */
568 0x95, 0x08, /* Report Count (8), */
569 0xB1, 0x02, /* Feature (Variable), */
570 0x85, 0xAA, /* Report ID (170), */
571 0x09, 0x4E, /* Usage (4Eh), */
572 0x95, 0x01, /* Report Count (1), */
573 0xB1, 0x02, /* Feature (Variable), */
574 0x85, 0xAB, /* Report ID (171), */
575 0x09, 0x4F, /* Usage (4Fh), */
576 0x95, 0x39, /* Report Count (57), */
577 0xB1, 0x02, /* Feature (Variable), */
578 0x85, 0xAC, /* Report ID (172), */
579 0x09, 0x50, /* Usage (50h), */
580 0x95, 0x39, /* Report Count (57), */
581 0xB1, 0x02, /* Feature (Variable), */
582 0x85, 0xAD, /* Report ID (173), */
583 0x09, 0x51, /* Usage (51h), */
584 0x95, 0x0B, /* Report Count (11), */
585 0xB1, 0x02, /* Feature (Variable), */
586 0x85, 0xAE, /* Report ID (174), */
587 0x09, 0x52, /* Usage (52h), */
588 0x95, 0x01, /* Report Count (1), */
589 0xB1, 0x02, /* Feature (Variable), */
590 0x85, 0xAF, /* Report ID (175), */
591 0x09, 0x53, /* Usage (53h), */
592 0x95, 0x02, /* Report Count (2), */
593 0xB1, 0x02, /* Feature (Variable), */
594 0x85, 0xB0, /* Report ID (176), */
595 0x09, 0x54, /* Usage (54h), */
596 0x95, 0x3F, /* Report Count (63), */
597 0xB1, 0x02, /* Feature (Variable), */
598 0xC0 /* End Collection */
Frank Prazniked19d8c2014-01-16 21:43:12 -0500599};
600
Frank Praznikad142b92014-02-20 11:36:00 -0500601/*
602 * The default behavior of the Dualshock 4 is to send reports using report
Frank Praznik077147a2014-09-14 11:56:39 -0400603 * type 1 when running over Bluetooth. However, when feature report 2 is
604 * requested during the controller initialization it starts sending input
605 * reports in report 17. Since report 17 is undefined in the default HID
Frank Praznikd8296742014-02-05 20:03:45 -0500606 * descriptor the button and axis definitions must be moved to report 17 or
Frank Praznik077147a2014-09-14 11:56:39 -0400607 * the HID layer won't process the received input.
Frank Praznikd8296742014-02-05 20:03:45 -0500608 */
609static u8 dualshock4_bt_rdesc[] = {
610 0x05, 0x01, /* Usage Page (Desktop), */
611 0x09, 0x05, /* Usage (Gamepad), */
612 0xA1, 0x01, /* Collection (Application), */
613 0x85, 0x01, /* Report ID (1), */
614 0x75, 0x08, /* Report Size (8), */
615 0x95, 0x0A, /* Report Count (9), */
616 0x81, 0x02, /* Input (Variable), */
617 0x06, 0x04, 0xFF, /* Usage Page (FF04h), */
618 0x85, 0x02, /* Report ID (2), */
619 0x09, 0x24, /* Usage (24h), */
620 0x95, 0x24, /* Report Count (36), */
621 0xB1, 0x02, /* Feature (Variable), */
622 0x85, 0xA3, /* Report ID (163), */
623 0x09, 0x25, /* Usage (25h), */
624 0x95, 0x30, /* Report Count (48), */
625 0xB1, 0x02, /* Feature (Variable), */
626 0x85, 0x05, /* Report ID (5), */
627 0x09, 0x26, /* Usage (26h), */
628 0x95, 0x28, /* Report Count (40), */
629 0xB1, 0x02, /* Feature (Variable), */
630 0x85, 0x06, /* Report ID (6), */
631 0x09, 0x27, /* Usage (27h), */
632 0x95, 0x34, /* Report Count (52), */
633 0xB1, 0x02, /* Feature (Variable), */
634 0x85, 0x07, /* Report ID (7), */
635 0x09, 0x28, /* Usage (28h), */
636 0x95, 0x30, /* Report Count (48), */
637 0xB1, 0x02, /* Feature (Variable), */
638 0x85, 0x08, /* Report ID (8), */
639 0x09, 0x29, /* Usage (29h), */
640 0x95, 0x2F, /* Report Count (47), */
641 0xB1, 0x02, /* Feature (Variable), */
642 0x06, 0x03, 0xFF, /* Usage Page (FF03h), */
643 0x85, 0x03, /* Report ID (3), */
644 0x09, 0x21, /* Usage (21h), */
645 0x95, 0x26, /* Report Count (38), */
646 0xB1, 0x02, /* Feature (Variable), */
647 0x85, 0x04, /* Report ID (4), */
648 0x09, 0x22, /* Usage (22h), */
649 0x95, 0x2E, /* Report Count (46), */
650 0xB1, 0x02, /* Feature (Variable), */
651 0x85, 0xF0, /* Report ID (240), */
652 0x09, 0x47, /* Usage (47h), */
653 0x95, 0x3F, /* Report Count (63), */
654 0xB1, 0x02, /* Feature (Variable), */
655 0x85, 0xF1, /* Report ID (241), */
656 0x09, 0x48, /* Usage (48h), */
657 0x95, 0x3F, /* Report Count (63), */
658 0xB1, 0x02, /* Feature (Variable), */
659 0x85, 0xF2, /* Report ID (242), */
660 0x09, 0x49, /* Usage (49h), */
661 0x95, 0x0F, /* Report Count (15), */
662 0xB1, 0x02, /* Feature (Variable), */
663 0x85, 0x11, /* Report ID (17), */
664 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
665 0x09, 0x20, /* Usage (20h), */
666 0x95, 0x02, /* Report Count (2), */
667 0x81, 0x02, /* Input (Variable), */
668 0x05, 0x01, /* Usage Page (Desktop), */
669 0x09, 0x30, /* Usage (X), */
670 0x09, 0x31, /* Usage (Y), */
671 0x09, 0x32, /* Usage (Z), */
672 0x09, 0x35, /* Usage (Rz), */
673 0x15, 0x00, /* Logical Minimum (0), */
674 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
675 0x75, 0x08, /* Report Size (8), */
676 0x95, 0x04, /* Report Count (4), */
677 0x81, 0x02, /* Input (Variable), */
678 0x09, 0x39, /* Usage (Hat Switch), */
679 0x15, 0x00, /* Logical Minimum (0), */
680 0x25, 0x07, /* Logical Maximum (7), */
681 0x75, 0x04, /* Report Size (4), */
682 0x95, 0x01, /* Report Count (1), */
683 0x81, 0x42, /* Input (Variable, Null State), */
684 0x05, 0x09, /* Usage Page (Button), */
685 0x19, 0x01, /* Usage Minimum (01h), */
686 0x29, 0x0E, /* Usage Maximum (0Eh), */
687 0x15, 0x00, /* Logical Minimum (0), */
688 0x25, 0x01, /* Logical Maximum (1), */
689 0x75, 0x01, /* Report Size (1), */
690 0x95, 0x0E, /* Report Count (14), */
691 0x81, 0x02, /* Input (Variable), */
692 0x75, 0x06, /* Report Size (6), */
693 0x95, 0x01, /* Report Count (1), */
694 0x81, 0x01, /* Input (Constant), */
695 0x05, 0x01, /* Usage Page (Desktop), */
696 0x09, 0x33, /* Usage (Rx), */
697 0x09, 0x34, /* Usage (Ry), */
698 0x15, 0x00, /* Logical Minimum (0), */
699 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
700 0x75, 0x08, /* Report Size (8), */
701 0x95, 0x02, /* Report Count (2), */
702 0x81, 0x02, /* Input (Variable), */
703 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
704 0x09, 0x20, /* Usage (20h), */
705 0x95, 0x03, /* Report Count (3), */
706 0x81, 0x02, /* Input (Variable), */
707 0x05, 0x01, /* Usage Page (Desktop), */
708 0x19, 0x40, /* Usage Minimum (40h), */
709 0x29, 0x42, /* Usage Maximum (42h), */
710 0x16, 0x00, 0x80, /* Logical Minimum (-32768), */
711 0x26, 0x00, 0x7F, /* Logical Maximum (32767), */
712 0x75, 0x10, /* Report Size (16), */
713 0x95, 0x03, /* Report Count (3), */
714 0x81, 0x02, /* Input (Variable), */
715 0x19, 0x43, /* Usage Minimum (43h), */
716 0x29, 0x45, /* Usage Maximum (45h), */
Frank Praznikfb291cb2014-09-14 11:56:38 -0400717 0x16, 0x00, 0xE0, /* Logical Minimum (-8192), */
718 0x26, 0xFF, 0x1F, /* Logical Maximum (8191), */
Frank Praznikd8296742014-02-05 20:03:45 -0500719 0x95, 0x03, /* Report Count (3), */
720 0x81, 0x02, /* Input (Variable), */
721 0x06, 0x00, 0xFF, /* Usage Page (FF00h), */
722 0x09, 0x20, /* Usage (20h), */
723 0x15, 0x00, /* Logical Minimum (0), */
724 0x26, 0xFF, 0x00, /* Logical Maximum (255), */
725 0x75, 0x08, /* Report Size (8), */
726 0x95, 0x31, /* Report Count (51), */
727 0x81, 0x02, /* Input (Variable), */
728 0x09, 0x21, /* Usage (21h), */
729 0x75, 0x08, /* Report Size (8), */
730 0x95, 0x4D, /* Report Count (77), */
731 0x91, 0x02, /* Output (Variable), */
732 0x85, 0x12, /* Report ID (18), */
733 0x09, 0x22, /* Usage (22h), */
734 0x95, 0x8D, /* Report Count (141), */
735 0x81, 0x02, /* Input (Variable), */
736 0x09, 0x23, /* Usage (23h), */
737 0x91, 0x02, /* Output (Variable), */
738 0x85, 0x13, /* Report ID (19), */
739 0x09, 0x24, /* Usage (24h), */
740 0x95, 0xCD, /* Report Count (205), */
741 0x81, 0x02, /* Input (Variable), */
742 0x09, 0x25, /* Usage (25h), */
743 0x91, 0x02, /* Output (Variable), */
744 0x85, 0x14, /* Report ID (20), */
745 0x09, 0x26, /* Usage (26h), */
746 0x96, 0x0D, 0x01, /* Report Count (269), */
747 0x81, 0x02, /* Input (Variable), */
748 0x09, 0x27, /* Usage (27h), */
749 0x91, 0x02, /* Output (Variable), */
750 0x85, 0x15, /* Report ID (21), */
751 0x09, 0x28, /* Usage (28h), */
752 0x96, 0x4D, 0x01, /* Report Count (333), */
753 0x81, 0x02, /* Input (Variable), */
754 0x09, 0x29, /* Usage (29h), */
755 0x91, 0x02, /* Output (Variable), */
756 0x85, 0x16, /* Report ID (22), */
757 0x09, 0x2A, /* Usage (2Ah), */
758 0x96, 0x8D, 0x01, /* Report Count (397), */
759 0x81, 0x02, /* Input (Variable), */
760 0x09, 0x2B, /* Usage (2Bh), */
761 0x91, 0x02, /* Output (Variable), */
762 0x85, 0x17, /* Report ID (23), */
763 0x09, 0x2C, /* Usage (2Ch), */
764 0x96, 0xCD, 0x01, /* Report Count (461), */
765 0x81, 0x02, /* Input (Variable), */
766 0x09, 0x2D, /* Usage (2Dh), */
767 0x91, 0x02, /* Output (Variable), */
768 0x85, 0x18, /* Report ID (24), */
769 0x09, 0x2E, /* Usage (2Eh), */
770 0x96, 0x0D, 0x02, /* Report Count (525), */
771 0x81, 0x02, /* Input (Variable), */
772 0x09, 0x2F, /* Usage (2Fh), */
773 0x91, 0x02, /* Output (Variable), */
774 0x85, 0x19, /* Report ID (25), */
775 0x09, 0x30, /* Usage (30h), */
776 0x96, 0x22, 0x02, /* Report Count (546), */
777 0x81, 0x02, /* Input (Variable), */
778 0x09, 0x31, /* Usage (31h), */
779 0x91, 0x02, /* Output (Variable), */
780 0x06, 0x80, 0xFF, /* Usage Page (FF80h), */
781 0x85, 0x82, /* Report ID (130), */
782 0x09, 0x22, /* Usage (22h), */
783 0x95, 0x3F, /* Report Count (63), */
784 0xB1, 0x02, /* Feature (Variable), */
785 0x85, 0x83, /* Report ID (131), */
786 0x09, 0x23, /* Usage (23h), */
787 0xB1, 0x02, /* Feature (Variable), */
788 0x85, 0x84, /* Report ID (132), */
789 0x09, 0x24, /* Usage (24h), */
790 0xB1, 0x02, /* Feature (Variable), */
791 0x85, 0x90, /* Report ID (144), */
792 0x09, 0x30, /* Usage (30h), */
793 0xB1, 0x02, /* Feature (Variable), */
794 0x85, 0x91, /* Report ID (145), */
795 0x09, 0x31, /* Usage (31h), */
796 0xB1, 0x02, /* Feature (Variable), */
797 0x85, 0x92, /* Report ID (146), */
798 0x09, 0x32, /* Usage (32h), */
799 0xB1, 0x02, /* Feature (Variable), */
800 0x85, 0x93, /* Report ID (147), */
801 0x09, 0x33, /* Usage (33h), */
802 0xB1, 0x02, /* Feature (Variable), */
803 0x85, 0xA0, /* Report ID (160), */
804 0x09, 0x40, /* Usage (40h), */
805 0xB1, 0x02, /* Feature (Variable), */
806 0x85, 0xA4, /* Report ID (164), */
807 0x09, 0x44, /* Usage (44h), */
808 0xB1, 0x02, /* Feature (Variable), */
809 0xC0 /* End Collection */
810};
811
Jiri Kosina078328d2013-06-13 12:03:49 +0200812static __u8 ps3remote_rdesc[] = {
813 0x05, 0x01, /* GUsagePage Generic Desktop */
814 0x09, 0x05, /* LUsage 0x05 [Game Pad] */
815 0xA1, 0x01, /* MCollection Application (mouse, keyboard) */
816
817 /* Use collection 1 for joypad buttons */
818 0xA1, 0x02, /* MCollection Logical (interrelated data) */
819
820 /* Ignore the 1st byte, maybe it is used for a controller
821 * number but it's not needed for correct operation */
822 0x75, 0x08, /* GReportSize 0x08 [8] */
823 0x95, 0x01, /* GReportCount 0x01 [1] */
824 0x81, 0x01, /* MInput 0x01 (Const[0] Arr[1] Abs[2]) */
825
826 /* Bytes from 2nd to 4th are a bitmap for joypad buttons, for these
827 * buttons multiple keypresses are allowed */
828 0x05, 0x09, /* GUsagePage Button */
829 0x19, 0x01, /* LUsageMinimum 0x01 [Button 1 (primary/trigger)] */
830 0x29, 0x18, /* LUsageMaximum 0x18 [Button 24] */
831 0x14, /* GLogicalMinimum [0] */
832 0x25, 0x01, /* GLogicalMaximum 0x01 [1] */
833 0x75, 0x01, /* GReportSize 0x01 [1] */
834 0x95, 0x18, /* GReportCount 0x18 [24] */
835 0x81, 0x02, /* MInput 0x02 (Data[0] Var[1] Abs[2]) */
836
837 0xC0, /* MEndCollection */
838
839 /* Use collection 2 for remote control buttons */
840 0xA1, 0x02, /* MCollection Logical (interrelated data) */
841
842 /* 5th byte is used for remote control buttons */
843 0x05, 0x09, /* GUsagePage Button */
844 0x18, /* LUsageMinimum [No button pressed] */
845 0x29, 0xFE, /* LUsageMaximum 0xFE [Button 254] */
846 0x14, /* GLogicalMinimum [0] */
847 0x26, 0xFE, 0x00, /* GLogicalMaximum 0x00FE [254] */
848 0x75, 0x08, /* GReportSize 0x08 [8] */
849 0x95, 0x01, /* GReportCount 0x01 [1] */
850 0x80, /* MInput */
851
852 /* Ignore bytes from 6th to 11th, 6th to 10th are always constant at
853 * 0xff and 11th is for press indication */
854 0x75, 0x08, /* GReportSize 0x08 [8] */
855 0x95, 0x06, /* GReportCount 0x06 [6] */
856 0x81, 0x01, /* MInput 0x01 (Const[0] Arr[1] Abs[2]) */
857
858 /* 12th byte is for battery strength */
859 0x05, 0x06, /* GUsagePage Generic Device Controls */
860 0x09, 0x20, /* LUsage 0x20 [Battery Strength] */
861 0x14, /* GLogicalMinimum [0] */
862 0x25, 0x05, /* GLogicalMaximum 0x05 [5] */
863 0x75, 0x08, /* GReportSize 0x08 [8] */
864 0x95, 0x01, /* GReportCount 0x01 [1] */
865 0x81, 0x02, /* MInput 0x02 (Data[0] Var[1] Abs[2]) */
866
867 0xC0, /* MEndCollection */
868
869 0xC0 /* MEndCollection [Game Pad] */
870};
871
872static const unsigned int ps3remote_keymap_joypad_buttons[] = {
873 [0x01] = KEY_SELECT,
874 [0x02] = BTN_THUMBL, /* L3 */
875 [0x03] = BTN_THUMBR, /* R3 */
876 [0x04] = BTN_START,
877 [0x05] = KEY_UP,
878 [0x06] = KEY_RIGHT,
879 [0x07] = KEY_DOWN,
880 [0x08] = KEY_LEFT,
881 [0x09] = BTN_TL2, /* L2 */
882 [0x0a] = BTN_TR2, /* R2 */
883 [0x0b] = BTN_TL, /* L1 */
884 [0x0c] = BTN_TR, /* R1 */
885 [0x0d] = KEY_OPTION, /* options/triangle */
886 [0x0e] = KEY_BACK, /* back/circle */
887 [0x0f] = BTN_0, /* cross */
888 [0x10] = KEY_SCREEN, /* view/square */
889 [0x11] = KEY_HOMEPAGE, /* PS button */
890 [0x14] = KEY_ENTER,
891};
892static const unsigned int ps3remote_keymap_remote_buttons[] = {
893 [0x00] = KEY_1,
894 [0x01] = KEY_2,
895 [0x02] = KEY_3,
896 [0x03] = KEY_4,
897 [0x04] = KEY_5,
898 [0x05] = KEY_6,
899 [0x06] = KEY_7,
900 [0x07] = KEY_8,
901 [0x08] = KEY_9,
902 [0x09] = KEY_0,
903 [0x0e] = KEY_ESC, /* return */
904 [0x0f] = KEY_CLEAR,
905 [0x16] = KEY_EJECTCD,
906 [0x1a] = KEY_MENU, /* top menu */
907 [0x28] = KEY_TIME,
908 [0x30] = KEY_PREVIOUS,
909 [0x31] = KEY_NEXT,
910 [0x32] = KEY_PLAY,
911 [0x33] = KEY_REWIND, /* scan back */
912 [0x34] = KEY_FORWARD, /* scan forward */
913 [0x38] = KEY_STOP,
914 [0x39] = KEY_PAUSE,
915 [0x40] = KEY_CONTEXT_MENU, /* pop up/menu */
916 [0x60] = KEY_FRAMEBACK, /* slow/step back */
917 [0x61] = KEY_FRAMEFORWARD, /* slow/step forward */
918 [0x63] = KEY_SUBTITLE,
919 [0x64] = KEY_AUDIO,
920 [0x65] = KEY_ANGLE,
921 [0x70] = KEY_INFO, /* display */
922 [0x80] = KEY_BLUE,
923 [0x81] = KEY_RED,
924 [0x82] = KEY_GREEN,
925 [0x83] = KEY_YELLOW,
926};
927
Colin Leitnerf04d5142013-05-27 23:41:05 +0200928static const unsigned int buzz_keymap[] = {
Frank Praznikad142b92014-02-20 11:36:00 -0500929 /*
930 * The controller has 4 remote buzzers, each with one LED and 5
Colin Leitnerf04d5142013-05-27 23:41:05 +0200931 * buttons.
932 *
933 * We use the mapping chosen by the controller, which is:
934 *
935 * Key Offset
936 * -------------------
937 * Buzz 1
938 * Blue 5
939 * Orange 4
940 * Green 3
941 * Yellow 2
942 *
943 * So, for example, the orange button on the third buzzer is mapped to
944 * BTN_TRIGGER_HAPPY14
945 */
946 [ 1] = BTN_TRIGGER_HAPPY1,
947 [ 2] = BTN_TRIGGER_HAPPY2,
948 [ 3] = BTN_TRIGGER_HAPPY3,
949 [ 4] = BTN_TRIGGER_HAPPY4,
950 [ 5] = BTN_TRIGGER_HAPPY5,
951 [ 6] = BTN_TRIGGER_HAPPY6,
952 [ 7] = BTN_TRIGGER_HAPPY7,
953 [ 8] = BTN_TRIGGER_HAPPY8,
954 [ 9] = BTN_TRIGGER_HAPPY9,
955 [10] = BTN_TRIGGER_HAPPY10,
956 [11] = BTN_TRIGGER_HAPPY11,
957 [12] = BTN_TRIGGER_HAPPY12,
958 [13] = BTN_TRIGGER_HAPPY13,
959 [14] = BTN_TRIGGER_HAPPY14,
960 [15] = BTN_TRIGGER_HAPPY15,
961 [16] = BTN_TRIGGER_HAPPY16,
962 [17] = BTN_TRIGGER_HAPPY17,
963 [18] = BTN_TRIGGER_HAPPY18,
964 [19] = BTN_TRIGGER_HAPPY19,
965 [20] = BTN_TRIGGER_HAPPY20,
966};
967
Frank Praznikd902f472014-01-27 10:17:36 -0500968static enum power_supply_property sony_battery_props[] = {
969 POWER_SUPPLY_PROP_PRESENT,
970 POWER_SUPPLY_PROP_CAPACITY,
971 POWER_SUPPLY_PROP_SCOPE,
972 POWER_SUPPLY_PROP_STATUS,
973};
974
Frank Praznik55d3b662014-04-14 10:11:32 -0400975struct sixaxis_led {
976 __u8 time_enabled; /* the total time the led is active (0xff means forever) */
977 __u8 duty_length; /* how long a cycle is in deciseconds (0 means "really fast") */
978 __u8 enabled;
979 __u8 duty_off; /* % of duty_length the led is off (0xff means 100%) */
980 __u8 duty_on; /* % of duty_length the led is on (0xff mean 100%) */
981} __packed;
982
983struct sixaxis_rumble {
984 __u8 padding;
985 __u8 right_duration; /* Right motor duration (0xff means forever) */
986 __u8 right_motor_on; /* Right (small) motor on/off, only supports values of 0 or 1 (off/on) */
987 __u8 left_duration; /* Left motor duration (0xff means forever) */
988 __u8 left_motor_force; /* left (large) motor, supports force values from 0 to 255 */
989} __packed;
990
991struct sixaxis_output_report {
992 __u8 report_id;
993 struct sixaxis_rumble rumble;
994 __u8 padding[4];
995 __u8 leds_bitmap; /* bitmap of enabled LEDs: LED_1 = 0x02, LED_2 = 0x04, ... */
996 struct sixaxis_led led[4]; /* LEDx at (4 - x) */
997 struct sixaxis_led _reserved; /* LED5, not actually soldered */
998} __packed;
999
1000union sixaxis_output_report_01 {
1001 struct sixaxis_output_report data;
1002 __u8 buf[36];
1003};
1004
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001005struct motion_output_report_02 {
1006 u8 type, zero;
1007 u8 r, g, b;
1008 u8 zero2;
1009 u8 rumble;
1010};
1011
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001012#define DS4_REPORT_0x02_SIZE 37
1013#define DS4_REPORT_0x05_SIZE 32
1014#define DS4_REPORT_0x11_SIZE 78
1015#define DS4_REPORT_0x81_SIZE 7
Antonio Ospite29b691a2015-02-16 18:12:21 +01001016#define SIXAXIS_REPORT_0xF2_SIZE 17
Antonio Ospitea85d67b2015-02-16 18:12:22 +01001017#define SIXAXIS_REPORT_0xF5_SIZE 8
Simon Wood41d2d422015-06-09 21:27:06 -06001018#define MOTION_REPORT_0x02_SIZE 49
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001019
Jiri Kosina8b402c92015-02-23 11:15:44 +01001020static DEFINE_SPINLOCK(sony_dev_list_lock);
Frank Praznikd2d782f2014-02-20 11:36:03 -05001021static LIST_HEAD(sony_device_list);
Frank Praznik80250872014-04-14 10:11:35 -04001022static DEFINE_IDA(sony_device_id_allocator);
Frank Praznikd2d782f2014-02-20 11:36:03 -05001023
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001024struct sony_sc {
Frank Praznikd902f472014-01-27 10:17:36 -05001025 spinlock_t lock;
Frank Praznikd2d782f2014-02-20 11:36:03 -05001026 struct list_head list_node;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001027 struct hid_device *hdev;
Frank Praznik60781cf2014-01-11 15:13:15 -05001028 struct led_classdev *leds[MAX_LEDS];
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001029 unsigned long quirks;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001030 struct work_struct state_worker;
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01001031 struct power_supply *battery;
1032 struct power_supply_desc battery_desc;
Frank Praznik80250872014-04-14 10:11:35 -04001033 int device_id;
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001034 __u8 *output_report_dmabuf;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001035
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001036#ifdef CONFIG_SONY_FF
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001037 __u8 left;
1038 __u8 right;
1039#endif
1040
Frank Praznikd2d782f2014-02-20 11:36:03 -05001041 __u8 mac_address[6];
Frank Praznik5f5750d2014-02-19 13:09:22 -05001042 __u8 worker_initialized;
Frank Praznikd902f472014-01-27 10:17:36 -05001043 __u8 cable_state;
1044 __u8 battery_charging;
1045 __u8 battery_capacity;
Frank Praznik60781cf2014-01-11 15:13:15 -05001046 __u8 led_state[MAX_LEDS];
Frank Praznikb3ed4582014-04-14 10:11:36 -04001047 __u8 led_delay_on[MAX_LEDS];
1048 __u8 led_delay_off[MAX_LEDS];
Frank Praznik60781cf2014-01-11 15:13:15 -05001049 __u8 led_count;
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001050};
1051
Antonio Ospitec607fb82014-06-24 13:28:41 +02001052static __u8 *sixaxis_fixup(struct hid_device *hdev, __u8 *rdesc,
1053 unsigned int *rsize)
1054{
1055 *rsize = sizeof(sixaxis_rdesc);
1056 return sixaxis_rdesc;
1057}
1058
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001059static u8 *motion_fixup(struct hid_device *hdev, u8 *rdesc,
1060 unsigned int *rsize)
1061{
1062 *rsize = sizeof(motion_rdesc);
1063 return motion_rdesc;
1064}
1065
Simon Woodb2723eb2015-06-17 00:08:53 -06001066static u8 *navigation_fixup(struct hid_device *hdev, u8 *rdesc,
1067 unsigned int *rsize)
1068{
1069 *rsize = sizeof(navigation_rdesc);
1070 return navigation_rdesc;
1071}
1072
Jiri Kosina078328d2013-06-13 12:03:49 +02001073static __u8 *ps3remote_fixup(struct hid_device *hdev, __u8 *rdesc,
1074 unsigned int *rsize)
1075{
1076 *rsize = sizeof(ps3remote_rdesc);
1077 return ps3remote_rdesc;
1078}
1079
1080static int ps3remote_mapping(struct hid_device *hdev, struct hid_input *hi,
1081 struct hid_field *field, struct hid_usage *usage,
1082 unsigned long **bit, int *max)
1083{
1084 unsigned int key = usage->hid & HID_USAGE;
1085
1086 if ((usage->hid & HID_USAGE_PAGE) != HID_UP_BUTTON)
1087 return -1;
1088
1089 switch (usage->collection_index) {
1090 case 1:
1091 if (key >= ARRAY_SIZE(ps3remote_keymap_joypad_buttons))
1092 return -1;
1093
1094 key = ps3remote_keymap_joypad_buttons[key];
1095 if (!key)
1096 return -1;
1097 break;
1098 case 2:
1099 if (key >= ARRAY_SIZE(ps3remote_keymap_remote_buttons))
1100 return -1;
1101
1102 key = ps3remote_keymap_remote_buttons[key];
1103 if (!key)
1104 return -1;
1105 break;
1106 default:
1107 return -1;
1108 }
1109
1110 hid_map_usage_clear(hi, usage, bit, max, EV_KEY, key);
1111 return 1;
1112}
1113
Nikolai Kondrashov73e40082010-08-06 23:03:06 +04001114static __u8 *sony_report_fixup(struct hid_device *hdev, __u8 *rdesc,
1115 unsigned int *rsize)
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001116{
1117 struct sony_sc *sc = hid_get_drvdata(hdev);
1118
Fernando Luis Vázquez Cao99d24902013-01-22 15:20:38 +09001119 /*
1120 * Some Sony RF receivers wrongly declare the mouse pointer as a
1121 * a constant non-data variable.
1122 */
1123 if ((sc->quirks & VAIO_RDESC_CONSTANT) && *rsize >= 56 &&
1124 /* usage page: generic desktop controls */
1125 /* rdesc[0] == 0x05 && rdesc[1] == 0x01 && */
1126 /* usage: mouse */
1127 rdesc[2] == 0x09 && rdesc[3] == 0x02 &&
1128 /* input (usage page for x,y axes): constant, variable, relative */
1129 rdesc[54] == 0x81 && rdesc[55] == 0x07) {
Fernando Luis Vázquez Caoa4649182013-01-15 19:40:48 +09001130 hid_info(hdev, "Fixing up Sony RF Receiver report descriptor\n");
Fernando Luis Vázquez Cao99d24902013-01-22 15:20:38 +09001131 /* input: data, variable, relative */
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001132 rdesc[55] = 0x06;
1133 }
Simon Wood61ab44b2011-06-10 12:00:26 +02001134
Frank Prazniked19d8c2014-01-16 21:43:12 -05001135 /*
1136 * The default Dualshock 4 USB descriptor doesn't assign
1137 * the gyroscope values to corresponding axes so we need a
1138 * modified one.
1139 */
1140 if ((sc->quirks & DUALSHOCK4_CONTROLLER_USB) && *rsize == 467) {
1141 hid_info(hdev, "Using modified Dualshock 4 report descriptor with gyroscope axes\n");
1142 rdesc = dualshock4_usb_rdesc;
1143 *rsize = sizeof(dualshock4_usb_rdesc);
Frank Praznikd8296742014-02-05 20:03:45 -05001144 } else if ((sc->quirks & DUALSHOCK4_CONTROLLER_BT) && *rsize == 357) {
1145 hid_info(hdev, "Using modified Dualshock 4 Bluetooth report descriptor\n");
1146 rdesc = dualshock4_bt_rdesc;
1147 *rsize = sizeof(dualshock4_bt_rdesc);
Frank Prazniked19d8c2014-01-16 21:43:12 -05001148 }
1149
Antonio Ospitec607fb82014-06-24 13:28:41 +02001150 if (sc->quirks & SIXAXIS_CONTROLLER)
1151 return sixaxis_fixup(hdev, rdesc, rsize);
Jiri Kosina078328d2013-06-13 12:03:49 +02001152
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001153 if (sc->quirks & MOTION_CONTROLLER)
1154 return motion_fixup(hdev, rdesc, rsize);
1155
Simon Wood4545ee02015-06-17 00:08:52 -06001156 if (sc->quirks & NAVIGATION_CONTROLLER)
Simon Woodb2723eb2015-06-17 00:08:53 -06001157 return navigation_fixup(hdev, rdesc, rsize);
Simon Wood4545ee02015-06-17 00:08:52 -06001158
Jiri Kosina078328d2013-06-13 12:03:49 +02001159 if (sc->quirks & PS3REMOTE)
1160 return ps3remote_fixup(hdev, rdesc, rsize);
1161
Nikolai Kondrashov73e40082010-08-06 23:03:06 +04001162 return rdesc;
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02001163}
1164
Frank Praznikd902f472014-01-27 10:17:36 -05001165static void sixaxis_parse_report(struct sony_sc *sc, __u8 *rd, int size)
1166{
1167 static const __u8 sixaxis_battery_capacity[] = { 0, 1, 25, 50, 75, 100 };
1168 unsigned long flags;
Simon Wood12e9a6d72015-06-09 21:27:05 -06001169 int offset;
Frank Praznikd902f472014-01-27 10:17:36 -05001170 __u8 cable_state, battery_capacity, battery_charging;
1171
Frank Praznikad142b92014-02-20 11:36:00 -05001172 /*
1173 * The sixaxis is charging if the battery value is 0xee
Frank Praznikd902f472014-01-27 10:17:36 -05001174 * and it is fully charged if the value is 0xef.
1175 * It does not report the actual level while charging so it
1176 * is set to 100% while charging is in progress.
1177 */
Simon Wood12e9a6d72015-06-09 21:27:05 -06001178 offset = (sc->quirks & MOTION_CONTROLLER) ? 12 : 30;
1179
1180 if (rd[offset] >= 0xee) {
Frank Praznikd902f472014-01-27 10:17:36 -05001181 battery_capacity = 100;
Simon Wood12e9a6d72015-06-09 21:27:05 -06001182 battery_charging = !(rd[offset] & 0x01);
Frank Praznik9fddd742014-08-29 13:11:52 -04001183 cable_state = 1;
Frank Praznikd902f472014-01-27 10:17:36 -05001184 } else {
Simon Wood12e9a6d72015-06-09 21:27:05 -06001185 __u8 index = rd[offset] <= 5 ? rd[offset] : 5;
Frank Praznikac3c9a92014-02-20 11:36:02 -05001186 battery_capacity = sixaxis_battery_capacity[index];
Frank Praznikd902f472014-01-27 10:17:36 -05001187 battery_charging = 0;
Frank Praznik9fddd742014-08-29 13:11:52 -04001188 cable_state = 0;
Frank Praznikd902f472014-01-27 10:17:36 -05001189 }
Frank Praznikd902f472014-01-27 10:17:36 -05001190
1191 spin_lock_irqsave(&sc->lock, flags);
1192 sc->cable_state = cable_state;
1193 sc->battery_capacity = battery_capacity;
1194 sc->battery_charging = battery_charging;
1195 spin_unlock_irqrestore(&sc->lock, flags);
1196}
1197
1198static void dualshock4_parse_report(struct sony_sc *sc, __u8 *rd, int size)
1199{
Frank Praznike5606232014-01-27 10:17:37 -05001200 struct hid_input *hidinput = list_entry(sc->hdev->inputs.next,
1201 struct hid_input, list);
1202 struct input_dev *input_dev = hidinput->input;
Frank Praznikd902f472014-01-27 10:17:36 -05001203 unsigned long flags;
Frank Praznik6c5f8602014-02-05 20:03:47 -05001204 int n, offset;
Frank Praznikd902f472014-01-27 10:17:36 -05001205 __u8 cable_state, battery_capacity, battery_charging;
1206
Frank Praznikad142b92014-02-20 11:36:00 -05001207 /*
1208 * Battery and touchpad data starts at byte 30 in the USB report and
Frank Praznik6c5f8602014-02-05 20:03:47 -05001209 * 32 in Bluetooth report.
1210 */
1211 offset = (sc->quirks & DUALSHOCK4_CONTROLLER_USB) ? 30 : 32;
1212
Frank Praznikad142b92014-02-20 11:36:00 -05001213 /*
1214 * The lower 4 bits of byte 30 contain the battery level
Frank Praznikd902f472014-01-27 10:17:36 -05001215 * and the 5th bit contains the USB cable state.
1216 */
Frank Praznik6c5f8602014-02-05 20:03:47 -05001217 cable_state = (rd[offset] >> 4) & 0x01;
1218 battery_capacity = rd[offset] & 0x0F;
Frank Praznikd902f472014-01-27 10:17:36 -05001219
Frank Praznikad142b92014-02-20 11:36:00 -05001220 /*
1221 * When a USB power source is connected the battery level ranges from
Frank Praznik6c5f8602014-02-05 20:03:47 -05001222 * 0 to 10, and when running on battery power it ranges from 0 to 9.
1223 * A battery level above 10 when plugged in means charge completed.
Frank Praznikd902f472014-01-27 10:17:36 -05001224 */
Frank Praznik6c5f8602014-02-05 20:03:47 -05001225 if (!cable_state || battery_capacity > 10)
Frank Praznikd902f472014-01-27 10:17:36 -05001226 battery_charging = 0;
1227 else
1228 battery_charging = 1;
1229
Frank Praznik6c5f8602014-02-05 20:03:47 -05001230 if (!cable_state)
1231 battery_capacity++;
Frank Praznikd902f472014-01-27 10:17:36 -05001232 if (battery_capacity > 10)
Frank Praznik6c5f8602014-02-05 20:03:47 -05001233 battery_capacity = 10;
1234
Frank Praznikd902f472014-01-27 10:17:36 -05001235 battery_capacity *= 10;
1236
1237 spin_lock_irqsave(&sc->lock, flags);
1238 sc->cable_state = cable_state;
1239 sc->battery_capacity = battery_capacity;
1240 sc->battery_charging = battery_charging;
1241 spin_unlock_irqrestore(&sc->lock, flags);
Frank Praznike5606232014-01-27 10:17:37 -05001242
Frank Praznik6c5f8602014-02-05 20:03:47 -05001243 offset += 5;
1244
Frank Praznikad142b92014-02-20 11:36:00 -05001245 /*
1246 * The Dualshock 4 multi-touch trackpad data starts at offset 35 on USB
Frank Praznik6c5f8602014-02-05 20:03:47 -05001247 * and 37 on Bluetooth.
Frank Praznike5606232014-01-27 10:17:37 -05001248 * The first 7 bits of the first byte is a counter and bit 8 is a touch
1249 * indicator that is 0 when pressed and 1 when not pressed.
1250 * The next 3 bytes are two 12 bit touch coordinates, X and Y.
1251 * The data for the second touch is in the same format and immediatly
1252 * follows the data for the first.
1253 */
1254 for (n = 0; n < 2; n++) {
1255 __u16 x, y;
1256
1257 x = rd[offset+1] | ((rd[offset+2] & 0xF) << 8);
1258 y = ((rd[offset+2] & 0xF0) >> 4) | (rd[offset+3] << 4);
1259
1260 input_mt_slot(input_dev, n);
1261 input_mt_report_slot_state(input_dev, MT_TOOL_FINGER,
1262 !(rd[offset] >> 7));
1263 input_report_abs(input_dev, ABS_MT_POSITION_X, x);
1264 input_report_abs(input_dev, ABS_MT_POSITION_Y, y);
1265
1266 offset += 4;
1267 }
Frank Praznikd902f472014-01-27 10:17:36 -05001268}
1269
Simon Woodc9e4d872011-06-10 12:00:27 +02001270static int sony_raw_event(struct hid_device *hdev, struct hid_report *report,
1271 __u8 *rd, int size)
1272{
1273 struct sony_sc *sc = hid_get_drvdata(hdev);
1274
Frank Praznikad142b92014-02-20 11:36:00 -05001275 /*
1276 * Sixaxis HID report has acclerometers/gyro with MSByte first, this
Simon Woodc9e4d872011-06-10 12:00:27 +02001277 * has to be BYTE_SWAPPED before passing up to joystick interface
1278 */
Frank Praznikfee4e2d2014-02-18 17:22:01 -05001279 if ((sc->quirks & SIXAXIS_CONTROLLER) && rd[0] == 0x01 && size == 49) {
Simon Woodc9e4d872011-06-10 12:00:27 +02001280 swap(rd[41], rd[42]);
1281 swap(rd[43], rd[44]);
1282 swap(rd[45], rd[46]);
1283 swap(rd[47], rd[48]);
Frank Praznikd902f472014-01-27 10:17:36 -05001284
1285 sixaxis_parse_report(sc, rd, size);
Simon Wood12e9a6d72015-06-09 21:27:05 -06001286 } else if ((sc->quirks & MOTION_CONTROLLER_BT) && rd[0] == 0x01 && size == 49) {
1287 sixaxis_parse_report(sc, rd, size);
Simon Wood4545ee02015-06-17 00:08:52 -06001288 } else if ((sc->quirks & NAVIGATION_CONTROLLER) && rd[0] == 0x01 &&
1289 size == 49) {
1290 sixaxis_parse_report(sc, rd, size);
Frank Praznik68330d82014-02-05 20:03:49 -05001291 } else if (((sc->quirks & DUALSHOCK4_CONTROLLER_USB) && rd[0] == 0x01 &&
1292 size == 64) || ((sc->quirks & DUALSHOCK4_CONTROLLER_BT)
1293 && rd[0] == 0x11 && size == 78)) {
Frank Praznikd902f472014-01-27 10:17:36 -05001294 dualshock4_parse_report(sc, rd, size);
Simon Woodc9e4d872011-06-10 12:00:27 +02001295 }
1296
1297 return 0;
1298}
1299
Colin Leitnerf04d5142013-05-27 23:41:05 +02001300static int sony_mapping(struct hid_device *hdev, struct hid_input *hi,
1301 struct hid_field *field, struct hid_usage *usage,
1302 unsigned long **bit, int *max)
1303{
1304 struct sony_sc *sc = hid_get_drvdata(hdev);
1305
1306 if (sc->quirks & BUZZ_CONTROLLER) {
1307 unsigned int key = usage->hid & HID_USAGE;
1308
1309 if ((usage->hid & HID_USAGE_PAGE) != HID_UP_BUTTON)
1310 return -1;
1311
1312 switch (usage->collection_index) {
1313 case 1:
1314 if (key >= ARRAY_SIZE(buzz_keymap))
1315 return -1;
1316
1317 key = buzz_keymap[key];
1318 if (!key)
1319 return -1;
1320 break;
1321 default:
1322 return -1;
1323 }
1324
1325 hid_map_usage_clear(hi, usage, bit, max, EV_KEY, key);
1326 return 1;
1327 }
1328
Jiri Kosina078328d2013-06-13 12:03:49 +02001329 if (sc->quirks & PS3REMOTE)
1330 return ps3remote_mapping(hdev, hi, field, usage, bit, max);
1331
Benjamin Tissoires6f498012013-07-24 16:53:07 +02001332 /* Let hid-core decide for the others */
1333 return 0;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001334}
1335
Frank Praznikce8efc32014-09-18 21:15:01 -04001336static int sony_register_touchpad(struct hid_input *hi, int touch_count,
1337 int w, int h)
1338{
1339 struct input_dev *input_dev = hi->input;
1340 int ret;
1341
1342 ret = input_mt_init_slots(input_dev, touch_count, 0);
1343 if (ret < 0)
1344 return ret;
1345
1346 input_set_abs_params(input_dev, ABS_MT_POSITION_X, 0, w, 0, 0);
1347 input_set_abs_params(input_dev, ABS_MT_POSITION_Y, 0, h, 0, 0);
1348
1349 return 0;
1350}
1351
1352static void sony_input_configured(struct hid_device *hdev,
1353 struct hid_input *hidinput)
1354{
1355 struct sony_sc *sc = hid_get_drvdata(hdev);
1356
1357 /*
1358 * The Dualshock 4 touchpad supports 2 touches and has a
Frank Praznik981c5b42014-09-24 09:38:19 -04001359 * resolution of 1920x942 (44.86 dots/mm).
Frank Praznikce8efc32014-09-18 21:15:01 -04001360 */
1361 if (sc->quirks & DUALSHOCK4_CONTROLLER) {
Frank Praznik981c5b42014-09-24 09:38:19 -04001362 if (sony_register_touchpad(hidinput, 2, 1920, 942) != 0)
Frank Praznikce8efc32014-09-18 21:15:01 -04001363 hid_err(sc->hdev,
1364 "Unable to initialize multi-touch slots\n");
1365 }
1366}
1367
Antonio Ospite5710fab2011-02-20 18:26:45 +01001368/*
Jiri Slabybd28ce02008-06-25 23:47:04 +02001369 * Sending HID_REQ_GET_REPORT changes the operation mode of the ps3 controller
1370 * to "operational". Without this, the ps3 controller will not report any
1371 * events.
1372 */
Antonio Ospite816651a2010-05-03 22:15:55 +02001373static int sixaxis_set_operational_usb(struct hid_device *hdev)
Jiri Slabybd28ce02008-06-25 23:47:04 +02001374{
Antonio Ospitea85d67b2015-02-16 18:12:22 +01001375 const int buf_size =
1376 max(SIXAXIS_REPORT_0xF2_SIZE, SIXAXIS_REPORT_0xF5_SIZE);
Antonio Ospite2e701a32015-02-16 18:12:24 +01001377 __u8 *buf;
Jiri Slabybd28ce02008-06-25 23:47:04 +02001378 int ret;
Jiri Slabybd28ce02008-06-25 23:47:04 +02001379
Antonio Ospite2e701a32015-02-16 18:12:24 +01001380 buf = kmalloc(buf_size, GFP_KERNEL);
Jiri Slabybd28ce02008-06-25 23:47:04 +02001381 if (!buf)
1382 return -ENOMEM;
1383
Antonio Ospitea85d67b2015-02-16 18:12:22 +01001384 ret = hid_hw_raw_request(hdev, 0xf2, buf, SIXAXIS_REPORT_0xF2_SIZE,
1385 HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
Lauri Kasanena7de9b82015-02-16 15:06:59 +02001386 if (ret < 0) {
1387 hid_err(hdev, "can't set operational mode: step 1\n");
1388 goto out;
1389 }
Benjamin Tissoiresf204828a2013-09-11 22:12:25 +02001390
Lauri Kasanena7de9b82015-02-16 15:06:59 +02001391 /*
1392 * Some compatible controllers like the Speedlink Strike FX and
1393 * Gasia need another query plus an USB interrupt to get operational.
1394 */
Antonio Ospitea85d67b2015-02-16 18:12:22 +01001395 ret = hid_hw_raw_request(hdev, 0xf5, buf, SIXAXIS_REPORT_0xF5_SIZE,
1396 HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
Lauri Kasanena7de9b82015-02-16 15:06:59 +02001397 if (ret < 0) {
1398 hid_err(hdev, "can't set operational mode: step 2\n");
1399 goto out;
1400 }
1401
1402 ret = hid_hw_output_report(hdev, buf, 1);
Jiri Slabybd28ce02008-06-25 23:47:04 +02001403 if (ret < 0)
Lauri Kasanena7de9b82015-02-16 15:06:59 +02001404 hid_err(hdev, "can't set operational mode: step 3\n");
Jiri Slabybd28ce02008-06-25 23:47:04 +02001405
Lauri Kasanena7de9b82015-02-16 15:06:59 +02001406out:
Jiri Slabybd28ce02008-06-25 23:47:04 +02001407 kfree(buf);
1408
1409 return ret;
1410}
1411
Antonio Ospite816651a2010-05-03 22:15:55 +02001412static int sixaxis_set_operational_bt(struct hid_device *hdev)
Bastien Noceraf9ce7c22010-01-20 12:01:53 +00001413{
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001414 static const __u8 report[] = { 0xf4, 0x42, 0x03, 0x00, 0x00 };
1415 __u8 *buf;
1416 int ret;
1417
1418 buf = kmemdup(report, sizeof(report), GFP_KERNEL);
1419 if (!buf)
1420 return -ENOMEM;
1421
1422 ret = hid_hw_raw_request(hdev, buf[0], buf, sizeof(report),
Benjamin Tissoiresb0dd72a2014-02-10 12:58:54 -05001423 HID_FEATURE_REPORT, HID_REQ_SET_REPORT);
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001424
1425 kfree(buf);
1426
1427 return ret;
Bastien Noceraf9ce7c22010-01-20 12:01:53 +00001428}
1429
Frank Praznikad142b92014-02-20 11:36:00 -05001430/*
1431 * Requesting feature report 0x02 in Bluetooth mode changes the state of the
Frank Praznik68330d82014-02-05 20:03:49 -05001432 * controller so that it sends full input reports of type 0x11.
1433 */
1434static int dualshock4_set_operational_bt(struct hid_device *hdev)
1435{
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001436 __u8 *buf;
1437 int ret;
Frank Praznik68330d82014-02-05 20:03:49 -05001438
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001439 buf = kmalloc(DS4_REPORT_0x02_SIZE, GFP_KERNEL);
1440 if (!buf)
1441 return -ENOMEM;
1442
1443 ret = hid_hw_raw_request(hdev, 0x02, buf, DS4_REPORT_0x02_SIZE,
Frank Praznik68330d82014-02-05 20:03:49 -05001444 HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001445
1446 kfree(buf);
1447
1448 return ret;
Jiri Slabybd28ce02008-06-25 23:47:04 +02001449}
1450
Frank Praznik221399b2015-05-05 20:47:32 -04001451static void sixaxis_set_leds_from_id(struct sony_sc *sc)
Frank Praznik80250872014-04-14 10:11:35 -04001452{
1453 static const __u8 sixaxis_leds[10][4] = {
1454 { 0x01, 0x00, 0x00, 0x00 },
1455 { 0x00, 0x01, 0x00, 0x00 },
1456 { 0x00, 0x00, 0x01, 0x00 },
1457 { 0x00, 0x00, 0x00, 0x01 },
1458 { 0x01, 0x00, 0x00, 0x01 },
1459 { 0x00, 0x01, 0x00, 0x01 },
1460 { 0x00, 0x00, 0x01, 0x01 },
1461 { 0x01, 0x00, 0x01, 0x01 },
1462 { 0x00, 0x01, 0x01, 0x01 },
1463 { 0x01, 0x01, 0x01, 0x01 }
1464 };
1465
Frank Praznik221399b2015-05-05 20:47:32 -04001466 int id = sc->device_id;
1467
1468 BUILD_BUG_ON(MAX_LEDS < ARRAY_SIZE(sixaxis_leds[0]));
Frank Praznik80250872014-04-14 10:11:35 -04001469
1470 if (id < 0)
1471 return;
1472
1473 id %= 10;
Frank Praznik221399b2015-05-05 20:47:32 -04001474 memcpy(sc->led_state, sixaxis_leds[id], sizeof(sixaxis_leds[id]));
Frank Praznik80250872014-04-14 10:11:35 -04001475}
1476
Frank Praznik221399b2015-05-05 20:47:32 -04001477static void dualshock4_set_leds_from_id(struct sony_sc *sc)
Frank Praznik80250872014-04-14 10:11:35 -04001478{
1479 /* The first 4 color/index entries match what the PS4 assigns */
1480 static const __u8 color_code[7][3] = {
1481 /* Blue */ { 0x00, 0x00, 0x01 },
1482 /* Red */ { 0x01, 0x00, 0x00 },
1483 /* Green */ { 0x00, 0x01, 0x00 },
1484 /* Pink */ { 0x02, 0x00, 0x01 },
1485 /* Orange */ { 0x02, 0x01, 0x00 },
1486 /* Teal */ { 0x00, 0x01, 0x01 },
1487 /* White */ { 0x01, 0x01, 0x01 }
1488 };
1489
Frank Praznik221399b2015-05-05 20:47:32 -04001490 int id = sc->device_id;
1491
1492 BUILD_BUG_ON(MAX_LEDS < ARRAY_SIZE(color_code[0]));
Frank Praznik80250872014-04-14 10:11:35 -04001493
1494 if (id < 0)
1495 return;
1496
1497 id %= 7;
Frank Praznik221399b2015-05-05 20:47:32 -04001498 memcpy(sc->led_state, color_code[id], sizeof(color_code[id]));
Frank Praznik80250872014-04-14 10:11:35 -04001499}
1500
Frank Praznik221399b2015-05-05 20:47:32 -04001501static void buzz_set_leds(struct sony_sc *sc)
Colin Leitnerf04d5142013-05-27 23:41:05 +02001502{
Frank Praznik221399b2015-05-05 20:47:32 -04001503 struct hid_device *hdev = sc->hdev;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001504 struct list_head *report_list =
1505 &hdev->report_enum[HID_OUTPUT_REPORT].report_list;
1506 struct hid_report *report = list_entry(report_list->next,
1507 struct hid_report, list);
1508 __s32 *value = report->field[0]->value;
1509
Frank Praznik221399b2015-05-05 20:47:32 -04001510 BUILD_BUG_ON(MAX_LEDS < 4);
1511
Colin Leitnerf04d5142013-05-27 23:41:05 +02001512 value[0] = 0x00;
Frank Praznik221399b2015-05-05 20:47:32 -04001513 value[1] = sc->led_state[0] ? 0xff : 0x00;
1514 value[2] = sc->led_state[1] ? 0xff : 0x00;
1515 value[3] = sc->led_state[2] ? 0xff : 0x00;
1516 value[4] = sc->led_state[3] ? 0xff : 0x00;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001517 value[5] = 0x00;
1518 value[6] = 0x00;
1519 hid_hw_request(hdev, report, HID_REQ_SET_REPORT);
1520}
1521
Frank Praznik221399b2015-05-05 20:47:32 -04001522static void sony_set_leds(struct sony_sc *sc)
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001523{
Frank Praznik221399b2015-05-05 20:47:32 -04001524 if (!(sc->quirks & BUZZ_CONTROLLER))
Frank Praznikfa57a812014-04-14 10:11:33 -04001525 schedule_work(&sc->state_worker);
Frank Praznik221399b2015-05-05 20:47:32 -04001526 else
1527 buzz_set_leds(sc);
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001528}
1529
Sven Eckelmannc5382512013-11-19 20:26:30 +01001530static void sony_led_set_brightness(struct led_classdev *led,
Colin Leitnerf04d5142013-05-27 23:41:05 +02001531 enum led_brightness value)
1532{
1533 struct device *dev = led->dev->parent;
1534 struct hid_device *hdev = container_of(dev, struct hid_device, dev);
1535 struct sony_sc *drv_data;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001536
1537 int n;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001538 int force_update;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001539
1540 drv_data = hid_get_drvdata(hdev);
Sven Eckelmann2251b852013-11-19 20:26:31 +01001541 if (!drv_data) {
Colin Leitnerf04d5142013-05-27 23:41:05 +02001542 hid_err(hdev, "No device data\n");
1543 return;
1544 }
Colin Leitnerf04d5142013-05-27 23:41:05 +02001545
Frank Praznikb3ed4582014-04-14 10:11:36 -04001546 /*
1547 * The Sixaxis on USB will override any LED settings sent to it
1548 * and keep flashing all of the LEDs until the PS button is pressed.
1549 * Updates, even if redundant, must be always be sent to the
1550 * controller to avoid having to toggle the state of an LED just to
1551 * stop the flashing later on.
1552 */
1553 force_update = !!(drv_data->quirks & SIXAXIS_CONTROLLER_USB);
1554
Frank Praznik60781cf2014-01-11 15:13:15 -05001555 for (n = 0; n < drv_data->led_count; n++) {
Frank Praznikb3ed4582014-04-14 10:11:36 -04001556 if (led == drv_data->leds[n] && (force_update ||
1557 (value != drv_data->led_state[n] ||
1558 drv_data->led_delay_on[n] ||
1559 drv_data->led_delay_off[n]))) {
1560
1561 drv_data->led_state[n] = value;
1562
1563 /* Setting the brightness stops the blinking */
1564 drv_data->led_delay_on[n] = 0;
1565 drv_data->led_delay_off[n] = 0;
1566
Frank Praznik221399b2015-05-05 20:47:32 -04001567 sony_set_leds(drv_data);
Colin Leitnerf04d5142013-05-27 23:41:05 +02001568 break;
1569 }
1570 }
1571}
1572
Sven Eckelmannc5382512013-11-19 20:26:30 +01001573static enum led_brightness sony_led_get_brightness(struct led_classdev *led)
Colin Leitnerf04d5142013-05-27 23:41:05 +02001574{
1575 struct device *dev = led->dev->parent;
1576 struct hid_device *hdev = container_of(dev, struct hid_device, dev);
1577 struct sony_sc *drv_data;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001578
1579 int n;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001580
1581 drv_data = hid_get_drvdata(hdev);
Sven Eckelmann2251b852013-11-19 20:26:31 +01001582 if (!drv_data) {
Colin Leitnerf04d5142013-05-27 23:41:05 +02001583 hid_err(hdev, "No device data\n");
1584 return LED_OFF;
1585 }
Colin Leitnerf04d5142013-05-27 23:41:05 +02001586
Frank Praznik60781cf2014-01-11 15:13:15 -05001587 for (n = 0; n < drv_data->led_count; n++) {
Simon Wood7db75042014-02-05 12:34:18 -07001588 if (led == drv_data->leds[n])
1589 return drv_data->led_state[n];
Colin Leitnerf04d5142013-05-27 23:41:05 +02001590 }
1591
Simon Wood7db75042014-02-05 12:34:18 -07001592 return LED_OFF;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001593}
Colin Leitnerf04d5142013-05-27 23:41:05 +02001594
Frank Praznikb3ed4582014-04-14 10:11:36 -04001595static int sony_led_blink_set(struct led_classdev *led, unsigned long *delay_on,
1596 unsigned long *delay_off)
1597{
1598 struct device *dev = led->dev->parent;
1599 struct hid_device *hdev = container_of(dev, struct hid_device, dev);
1600 struct sony_sc *drv_data = hid_get_drvdata(hdev);
1601 int n;
1602 __u8 new_on, new_off;
1603
1604 if (!drv_data) {
1605 hid_err(hdev, "No device data\n");
1606 return -EINVAL;
1607 }
1608
1609 /* Max delay is 255 deciseconds or 2550 milliseconds */
1610 if (*delay_on > 2550)
1611 *delay_on = 2550;
1612 if (*delay_off > 2550)
1613 *delay_off = 2550;
1614
1615 /* Blink at 1 Hz if both values are zero */
1616 if (!*delay_on && !*delay_off)
1617 *delay_on = *delay_off = 500;
1618
1619 new_on = *delay_on / 10;
1620 new_off = *delay_off / 10;
1621
1622 for (n = 0; n < drv_data->led_count; n++) {
1623 if (led == drv_data->leds[n])
1624 break;
1625 }
1626
1627 /* This LED is not registered on this device */
1628 if (n >= drv_data->led_count)
1629 return -EINVAL;
1630
1631 /* Don't schedule work if the values didn't change */
1632 if (new_on != drv_data->led_delay_on[n] ||
1633 new_off != drv_data->led_delay_off[n]) {
1634 drv_data->led_delay_on[n] = new_on;
1635 drv_data->led_delay_off[n] = new_off;
1636 schedule_work(&drv_data->state_worker);
1637 }
1638
1639 return 0;
1640}
1641
Frank Praznikfa57a812014-04-14 10:11:33 -04001642static void sony_leds_remove(struct sony_sc *sc)
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001643{
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001644 struct led_classdev *led;
1645 int n;
1646
Frank Praznikfa57a812014-04-14 10:11:33 -04001647 BUG_ON(!(sc->quirks & SONY_LED_SUPPORT));
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001648
Frank Praznikfa57a812014-04-14 10:11:33 -04001649 for (n = 0; n < sc->led_count; n++) {
1650 led = sc->leds[n];
1651 sc->leds[n] = NULL;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001652 if (!led)
1653 continue;
1654 led_classdev_unregister(led);
1655 kfree(led);
1656 }
Frank Praznik60781cf2014-01-11 15:13:15 -05001657
Frank Praznikfa57a812014-04-14 10:11:33 -04001658 sc->led_count = 0;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001659}
1660
Frank Praznikfa57a812014-04-14 10:11:33 -04001661static int sony_leds_init(struct sony_sc *sc)
Colin Leitnerf04d5142013-05-27 23:41:05 +02001662{
Frank Praznikfa57a812014-04-14 10:11:33 -04001663 struct hid_device *hdev = sc->hdev;
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001664 int n, ret = 0;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001665 int use_ds4_names;
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001666 struct led_classdev *led;
1667 size_t name_sz;
1668 char *name;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001669 size_t name_len;
1670 const char *name_fmt;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001671 static const char * const ds4_name_str[] = { "red", "green", "blue",
1672 "global" };
Frank Praznik5607c892014-07-29 19:55:48 -07001673 __u8 max_brightness[MAX_LEDS] = { [0 ... (MAX_LEDS - 1)] = 1 };
Frank Praznikb3ed4582014-04-14 10:11:36 -04001674 __u8 use_hw_blink[MAX_LEDS] = { 0 };
Colin Leitnerf04d5142013-05-27 23:41:05 +02001675
Frank Praznikfa57a812014-04-14 10:11:33 -04001676 BUG_ON(!(sc->quirks & SONY_LED_SUPPORT));
Colin Leitnerf04d5142013-05-27 23:41:05 +02001677
Frank Praznikfa57a812014-04-14 10:11:33 -04001678 if (sc->quirks & BUZZ_CONTROLLER) {
1679 sc->led_count = 4;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001680 use_ds4_names = 0;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001681 name_len = strlen("::buzz#");
1682 name_fmt = "%s::buzz%d";
1683 /* Validate expected report characteristics. */
1684 if (!hid_validate_values(hdev, HID_OUTPUT_REPORT, 0, 0, 7))
1685 return -ENODEV;
Frank Praznikfa57a812014-04-14 10:11:33 -04001686 } else if (sc->quirks & DUALSHOCK4_CONTROLLER) {
Frank Praznik221399b2015-05-05 20:47:32 -04001687 dualshock4_set_leds_from_id(sc);
1688 sc->led_state[3] = 1;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001689 sc->led_count = 4;
1690 memset(max_brightness, 255, 3);
1691 use_hw_blink[3] = 1;
1692 use_ds4_names = 1;
Frank Praznik61ebca92014-01-20 12:27:02 -05001693 name_len = 0;
1694 name_fmt = "%s:%s";
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001695 } else if (sc->quirks & MOTION_CONTROLLER) {
1696 sc->led_count = 3;
1697 memset(max_brightness, 255, 3);
1698 use_ds4_names = 1;
1699 name_len = 0;
1700 name_fmt = "%s:%s";
Simon Wood4545ee02015-06-17 00:08:52 -06001701 } else if (sc->quirks & NAVIGATION_CONTROLLER) {
1702 static const __u8 navigation_leds[4] = {0x01, 0x00, 0x00, 0x00};
1703
1704 memcpy(sc->led_state, navigation_leds, sizeof(navigation_leds));
1705 sc->led_count = 1;
1706 memset(use_hw_blink, 1, 4);
1707 use_ds4_names = 0;
1708 name_len = strlen("::sony#");
1709 name_fmt = "%s::sony%d";
Frank Praznik60781cf2014-01-11 15:13:15 -05001710 } else {
Frank Praznik221399b2015-05-05 20:47:32 -04001711 sixaxis_set_leds_from_id(sc);
Frank Praznikfa57a812014-04-14 10:11:33 -04001712 sc->led_count = 4;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001713 memset(use_hw_blink, 1, 4);
1714 use_ds4_names = 0;
Frank Praznik61ebca92014-01-20 12:27:02 -05001715 name_len = strlen("::sony#");
1716 name_fmt = "%s::sony%d";
Frank Praznik60781cf2014-01-11 15:13:15 -05001717 }
1718
Frank Praznikad142b92014-02-20 11:36:00 -05001719 /*
1720 * Clear LEDs as we have no way of reading their initial state. This is
Colin Leitnerf04d5142013-05-27 23:41:05 +02001721 * only relevant if the driver is loaded after somebody actively set the
Frank Praznikad142b92014-02-20 11:36:00 -05001722 * LEDs to on
1723 */
Frank Praznik221399b2015-05-05 20:47:32 -04001724 sony_set_leds(sc);
Colin Leitnerf04d5142013-05-27 23:41:05 +02001725
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001726 name_sz = strlen(dev_name(&hdev->dev)) + name_len + 1;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001727
Frank Praznikfa57a812014-04-14 10:11:33 -04001728 for (n = 0; n < sc->led_count; n++) {
Frank Praznik61ebca92014-01-20 12:27:02 -05001729
Frank Praznikb3ed4582014-04-14 10:11:36 -04001730 if (use_ds4_names)
1731 name_sz = strlen(dev_name(&hdev->dev)) + strlen(ds4_name_str[n]) + 2;
Frank Praznik61ebca92014-01-20 12:27:02 -05001732
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001733 led = kzalloc(sizeof(struct led_classdev) + name_sz, GFP_KERNEL);
1734 if (!led) {
1735 hid_err(hdev, "Couldn't allocate memory for LED %d\n", n);
Julia Lawall8cd5fcd2013-12-29 23:47:27 +01001736 ret = -ENOMEM;
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001737 goto error_leds;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001738 }
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001739
1740 name = (void *)(&led[1]);
Frank Praznikb3ed4582014-04-14 10:11:36 -04001741 if (use_ds4_names)
1742 snprintf(name, name_sz, name_fmt, dev_name(&hdev->dev),
1743 ds4_name_str[n]);
Frank Praznik61ebca92014-01-20 12:27:02 -05001744 else
1745 snprintf(name, name_sz, name_fmt, dev_name(&hdev->dev), n + 1);
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001746 led->name = name;
Frank Praznik221399b2015-05-05 20:47:32 -04001747 led->brightness = sc->led_state[n];
Frank Praznikb3ed4582014-04-14 10:11:36 -04001748 led->max_brightness = max_brightness[n];
Sven Eckelmannc5382512013-11-19 20:26:30 +01001749 led->brightness_get = sony_led_get_brightness;
1750 led->brightness_set = sony_led_set_brightness;
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001751
Frank Praznikb3ed4582014-04-14 10:11:36 -04001752 if (use_hw_blink[n])
1753 led->blink_set = sony_led_blink_set;
1754
Frank Praznik80250872014-04-14 10:11:35 -04001755 sc->leds[n] = led;
1756
Julia Lawall8cd5fcd2013-12-29 23:47:27 +01001757 ret = led_classdev_register(&hdev->dev, led);
1758 if (ret) {
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001759 hid_err(hdev, "Failed to register LED %d\n", n);
Frank Praznik80250872014-04-14 10:11:35 -04001760 sc->leds[n] = NULL;
Jiri Kosina40e32ee2013-05-28 11:22:09 +02001761 kfree(led);
1762 goto error_leds;
1763 }
Colin Leitnerf04d5142013-05-27 23:41:05 +02001764 }
Colin Leitnerf04d5142013-05-27 23:41:05 +02001765
1766 return ret;
1767
Colin Leitnerf04d5142013-05-27 23:41:05 +02001768error_leds:
Frank Praznikfa57a812014-04-14 10:11:33 -04001769 sony_leds_remove(sc);
Colin Leitnerf04d5142013-05-27 23:41:05 +02001770
Colin Leitnerf04d5142013-05-27 23:41:05 +02001771 return ret;
Colin Leitnerf04d5142013-05-27 23:41:05 +02001772}
1773
Frank Praznikcad665a2014-01-11 15:13:54 -05001774static void sixaxis_state_worker(struct work_struct *work)
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001775{
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001776 static const union sixaxis_output_report_01 default_report = {
Frank Praznik55d3b662014-04-14 10:11:32 -04001777 .buf = {
1778 0x01,
1779 0x00, 0xff, 0x00, 0xff, 0x00,
1780 0x00, 0x00, 0x00, 0x00, 0x00,
1781 0xff, 0x27, 0x10, 0x00, 0x32,
1782 0xff, 0x27, 0x10, 0x00, 0x32,
1783 0xff, 0x27, 0x10, 0x00, 0x32,
1784 0xff, 0x27, 0x10, 0x00, 0x32,
1785 0x00, 0x00, 0x00, 0x00, 0x00
1786 }
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001787 };
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001788 struct sony_sc *sc = container_of(work, struct sony_sc, state_worker);
1789 struct sixaxis_output_report *report =
1790 (struct sixaxis_output_report *)sc->output_report_dmabuf;
1791 int n;
1792
1793 /* Initialize the report with default values */
1794 memcpy(report, &default_report, sizeof(struct sixaxis_output_report));
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001795
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001796#ifdef CONFIG_SONY_FF
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001797 report->rumble.right_motor_on = sc->right ? 1 : 0;
1798 report->rumble.left_motor_force = sc->left;
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001799#endif
1800
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001801 report->leds_bitmap |= sc->led_state[0] << 1;
1802 report->leds_bitmap |= sc->led_state[1] << 2;
1803 report->leds_bitmap |= sc->led_state[2] << 3;
1804 report->leds_bitmap |= sc->led_state[3] << 4;
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001805
Simon Wood88f65762014-04-14 10:11:37 -04001806 /* Set flag for all leds off, required for 3rd party INTEC controller */
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001807 if ((report->leds_bitmap & 0x1E) == 0)
1808 report->leds_bitmap |= 0x20;
Simon Wood88f65762014-04-14 10:11:37 -04001809
Frank Praznikb3ed4582014-04-14 10:11:36 -04001810 /*
1811 * The LEDs in the report are indexed in reverse order to their
1812 * corresponding light on the controller.
1813 * Index 0 = LED 4, index 1 = LED 3, etc...
1814 *
1815 * In the case of both delay values being zero (blinking disabled) the
1816 * default report values should be used or the controller LED will be
1817 * always off.
1818 */
1819 for (n = 0; n < 4; n++) {
1820 if (sc->led_delay_on[n] || sc->led_delay_off[n]) {
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001821 report->led[3 - n].duty_off = sc->led_delay_off[n];
1822 report->led[3 - n].duty_on = sc->led_delay_on[n];
Frank Praznikb3ed4582014-04-14 10:11:36 -04001823 }
1824 }
1825
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001826 hid_hw_raw_request(sc->hdev, report->report_id, (__u8 *)report,
1827 sizeof(struct sixaxis_output_report),
1828 HID_OUTPUT_REPORT, HID_REQ_SET_REPORT);
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001829}
1830
Frank Praznik0bd88dd2014-01-11 15:12:42 -05001831static void dualshock4_state_worker(struct work_struct *work)
1832{
1833 struct sony_sc *sc = container_of(work, struct sony_sc, state_worker);
Frank Praznik0da8ea62014-01-16 21:42:51 -05001834 struct hid_device *hdev = sc->hdev;
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001835 __u8 *buf = sc->output_report_dmabuf;
Frank Praznik48220232014-02-05 20:03:44 -05001836 int offset;
Frank Praznik0da8ea62014-01-16 21:42:51 -05001837
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001838 if (sc->quirks & DUALSHOCK4_CONTROLLER_USB) {
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001839 memset(buf, 0, DS4_REPORT_0x05_SIZE);
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001840 buf[0] = 0x05;
Frank Praznikb3ed4582014-04-14 10:11:36 -04001841 buf[1] = 0xFF;
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001842 offset = 4;
1843 } else {
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001844 memset(buf, 0, DS4_REPORT_0x11_SIZE);
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001845 buf[0] = 0x11;
1846 buf[1] = 0xB0;
1847 buf[3] = 0x0F;
1848 offset = 6;
1849 }
Frank Praznik0bd88dd2014-01-11 15:12:42 -05001850
1851#ifdef CONFIG_SONY_FF
Frank Praznik48220232014-02-05 20:03:44 -05001852 buf[offset++] = sc->right;
1853 buf[offset++] = sc->left;
1854#else
1855 offset += 2;
Frank Praznik0bd88dd2014-01-11 15:12:42 -05001856#endif
1857
Frank Praznikb3ed4582014-04-14 10:11:36 -04001858 /* LED 3 is the global control */
1859 if (sc->led_state[3]) {
1860 buf[offset++] = sc->led_state[0];
1861 buf[offset++] = sc->led_state[1];
1862 buf[offset++] = sc->led_state[2];
1863 } else {
1864 offset += 3;
1865 }
1866
1867 /* If both delay values are zero the DualShock 4 disables blinking. */
1868 buf[offset++] = sc->led_delay_on[3];
1869 buf[offset++] = sc->led_delay_off[3];
Frank Praznik60781cf2014-01-11 15:13:15 -05001870
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001871 if (sc->quirks & DUALSHOCK4_CONTROLLER_USB)
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001872 hid_hw_output_report(hdev, buf, DS4_REPORT_0x05_SIZE);
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001873 else
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001874 hid_hw_raw_request(hdev, 0x11, buf, DS4_REPORT_0x11_SIZE,
Frank Praznikfdcf105d2014-02-05 20:03:46 -05001875 HID_OUTPUT_REPORT, HID_REQ_SET_REPORT);
Frank Praznik0bd88dd2014-01-11 15:12:42 -05001876}
1877
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001878static void motion_state_worker(struct work_struct *work)
1879{
1880 struct sony_sc *sc = container_of(work, struct sony_sc, state_worker);
1881 struct hid_device *hdev = sc->hdev;
1882 struct motion_output_report_02 *report =
1883 (struct motion_output_report_02 *)sc->output_report_dmabuf;
1884
Simon Wood41d2d422015-06-09 21:27:06 -06001885 memset(report, 0, MOTION_REPORT_0x02_SIZE);
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001886
1887 report->type = 0x02; /* set leds */
1888 report->r = sc->led_state[0];
1889 report->g = sc->led_state[1];
1890 report->b = sc->led_state[2];
1891
1892#ifdef CONFIG_SONY_FF
1893 report->rumble = max(sc->right, sc->left);
1894#endif
1895
Simon Wood41d2d422015-06-09 21:27:06 -06001896 hid_hw_output_report(hdev, (__u8 *)report, MOTION_REPORT_0x02_SIZE);
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001897}
1898
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001899static int sony_allocate_output_report(struct sony_sc *sc)
1900{
Simon Wood4545ee02015-06-17 00:08:52 -06001901 if ((sc->quirks & SIXAXIS_CONTROLLER) ||
1902 (sc->quirks & NAVIGATION_CONTROLLER))
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001903 sc->output_report_dmabuf =
1904 kmalloc(sizeof(union sixaxis_output_report_01),
1905 GFP_KERNEL);
1906 else if (sc->quirks & DUALSHOCK4_CONTROLLER_BT)
1907 sc->output_report_dmabuf = kmalloc(DS4_REPORT_0x11_SIZE,
1908 GFP_KERNEL);
1909 else if (sc->quirks & DUALSHOCK4_CONTROLLER_USB)
1910 sc->output_report_dmabuf = kmalloc(DS4_REPORT_0x05_SIZE,
1911 GFP_KERNEL);
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04001912 else if (sc->quirks & MOTION_CONTROLLER)
Simon Wood41d2d422015-06-09 21:27:06 -06001913 sc->output_report_dmabuf = kmalloc(MOTION_REPORT_0x02_SIZE,
1914 GFP_KERNEL);
Frank Praznik9b2b5c92014-11-12 14:10:09 -05001915 else
1916 return 0;
1917
1918 if (!sc->output_report_dmabuf)
1919 return -ENOMEM;
1920
1921 return 0;
1922}
1923
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01001924#ifdef CONFIG_SONY_FF
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001925static int sony_play_effect(struct input_dev *dev, void *data,
1926 struct ff_effect *effect)
1927{
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001928 struct hid_device *hid = input_get_drvdata(dev);
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001929 struct sony_sc *sc = hid_get_drvdata(hid);
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001930
1931 if (effect->type != FF_RUMBLE)
1932 return 0;
1933
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001934 sc->left = effect->u.rumble.strong_magnitude / 256;
Frank Praznik0bd88dd2014-01-11 15:12:42 -05001935 sc->right = effect->u.rumble.weak_magnitude / 256;
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001936
Sven Eckelmann92b5c412013-11-19 20:26:28 +01001937 schedule_work(&sc->state_worker);
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001938 return 0;
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001939}
1940
Frank Praznikfa57a812014-04-14 10:11:33 -04001941static int sony_init_ff(struct sony_sc *sc)
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001942{
Frank Praznikfa57a812014-04-14 10:11:33 -04001943 struct hid_input *hidinput = list_entry(sc->hdev->inputs.next,
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001944 struct hid_input, list);
1945 struct input_dev *input_dev = hidinput->input;
1946
1947 input_set_capability(input_dev, EV_FF, FF_RUMBLE);
1948 return input_ff_create_memless(input_dev, NULL, sony_play_effect);
1949}
1950
1951#else
Frank Praznikfa57a812014-04-14 10:11:33 -04001952static int sony_init_ff(struct sony_sc *sc)
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001953{
1954 return 0;
1955}
Sven Eckelmann9f323b62013-11-17 20:38:21 +01001956
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01001957#endif
1958
Frank Praznikd902f472014-01-27 10:17:36 -05001959static int sony_battery_get_property(struct power_supply *psy,
1960 enum power_supply_property psp,
1961 union power_supply_propval *val)
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05001962{
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01001963 struct sony_sc *sc = power_supply_get_drvdata(psy);
Frank Praznikd902f472014-01-27 10:17:36 -05001964 unsigned long flags;
1965 int ret = 0;
1966 u8 battery_charging, battery_capacity, cable_state;
1967
1968 spin_lock_irqsave(&sc->lock, flags);
1969 battery_charging = sc->battery_charging;
1970 battery_capacity = sc->battery_capacity;
1971 cable_state = sc->cable_state;
1972 spin_unlock_irqrestore(&sc->lock, flags);
1973
1974 switch (psp) {
1975 case POWER_SUPPLY_PROP_PRESENT:
1976 val->intval = 1;
1977 break;
1978 case POWER_SUPPLY_PROP_SCOPE:
1979 val->intval = POWER_SUPPLY_SCOPE_DEVICE;
1980 break;
1981 case POWER_SUPPLY_PROP_CAPACITY:
1982 val->intval = battery_capacity;
1983 break;
1984 case POWER_SUPPLY_PROP_STATUS:
1985 if (battery_charging)
1986 val->intval = POWER_SUPPLY_STATUS_CHARGING;
1987 else
1988 if (battery_capacity == 100 && cable_state)
1989 val->intval = POWER_SUPPLY_STATUS_FULL;
1990 else
1991 val->intval = POWER_SUPPLY_STATUS_DISCHARGING;
1992 break;
1993 default:
1994 ret = -EINVAL;
1995 break;
1996 }
1997 return ret;
1998}
1999
2000static int sony_battery_probe(struct sony_sc *sc)
2001{
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002002 struct power_supply_config psy_cfg = { .drv_data = sc, };
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002003 struct hid_device *hdev = sc->hdev;
Frank Praznikd902f472014-01-27 10:17:36 -05002004 int ret;
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002005
Frank Praznikad142b92014-02-20 11:36:00 -05002006 /*
2007 * Set the default battery level to 100% to avoid low battery warnings
Frank Praznikd9a293a2014-02-05 20:03:48 -05002008 * if the battery is polled before the first device report is received.
2009 */
2010 sc->battery_capacity = 100;
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002011
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002012 sc->battery_desc.properties = sony_battery_props;
2013 sc->battery_desc.num_properties = ARRAY_SIZE(sony_battery_props);
2014 sc->battery_desc.get_property = sony_battery_get_property;
2015 sc->battery_desc.type = POWER_SUPPLY_TYPE_BATTERY;
2016 sc->battery_desc.use_for_apm = 0;
2017 sc->battery_desc.name = kasprintf(GFP_KERNEL,
2018 "sony_controller_battery_%pMR",
2019 sc->mac_address);
2020 if (!sc->battery_desc.name)
Frank Praznikd902f472014-01-27 10:17:36 -05002021 return -ENOMEM;
2022
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002023 sc->battery = power_supply_register(&hdev->dev, &sc->battery_desc,
2024 &psy_cfg);
2025 if (IS_ERR(sc->battery)) {
2026 ret = PTR_ERR(sc->battery);
Frank Praznikd902f472014-01-27 10:17:36 -05002027 hid_err(hdev, "Unable to register battery device\n");
2028 goto err_free;
2029 }
2030
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002031 power_supply_powers(sc->battery, &hdev->dev);
Frank Praznikd902f472014-01-27 10:17:36 -05002032 return 0;
2033
2034err_free:
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002035 kfree(sc->battery_desc.name);
2036 sc->battery_desc.name = NULL;
Frank Praznikd902f472014-01-27 10:17:36 -05002037 return ret;
2038}
2039
2040static void sony_battery_remove(struct sony_sc *sc)
2041{
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002042 if (!sc->battery_desc.name)
Frank Praznikd902f472014-01-27 10:17:36 -05002043 return;
2044
Krzysztof Kozlowski297d7162015-03-12 08:44:11 +01002045 power_supply_unregister(sc->battery);
2046 kfree(sc->battery_desc.name);
2047 sc->battery_desc.name = NULL;
Frank Praznikd902f472014-01-27 10:17:36 -05002048}
2049
Frank Praznikd2d782f2014-02-20 11:36:03 -05002050/*
2051 * If a controller is plugged in via USB while already connected via Bluetooth
2052 * it will show up as two devices. A global list of connected controllers and
2053 * their MAC addresses is maintained to ensure that a device is only connected
2054 * once.
2055 */
2056static int sony_check_add_dev_list(struct sony_sc *sc)
2057{
2058 struct sony_sc *entry;
2059 unsigned long flags;
2060 int ret;
2061
2062 spin_lock_irqsave(&sony_dev_list_lock, flags);
2063
2064 list_for_each_entry(entry, &sony_device_list, list_node) {
2065 ret = memcmp(sc->mac_address, entry->mac_address,
2066 sizeof(sc->mac_address));
2067 if (!ret) {
2068 ret = -EEXIST;
2069 hid_info(sc->hdev, "controller with MAC address %pMR already connected\n",
2070 sc->mac_address);
2071 goto unlock;
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002072 }
2073 }
2074
Frank Praznikd2d782f2014-02-20 11:36:03 -05002075 ret = 0;
2076 list_add(&(sc->list_node), &sony_device_list);
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002077
Frank Praznikd2d782f2014-02-20 11:36:03 -05002078unlock:
2079 spin_unlock_irqrestore(&sony_dev_list_lock, flags);
2080 return ret;
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002081}
2082
Frank Praznikd2d782f2014-02-20 11:36:03 -05002083static void sony_remove_dev_list(struct sony_sc *sc)
2084{
2085 unsigned long flags;
2086
2087 if (sc->list_node.next) {
2088 spin_lock_irqsave(&sony_dev_list_lock, flags);
2089 list_del(&(sc->list_node));
2090 spin_unlock_irqrestore(&sony_dev_list_lock, flags);
2091 }
2092}
2093
2094static int sony_get_bt_devaddr(struct sony_sc *sc)
2095{
2096 int ret;
2097
2098 /* HIDP stores the device MAC address as a string in the uniq field. */
2099 ret = strlen(sc->hdev->uniq);
2100 if (ret != 17)
2101 return -EINVAL;
2102
2103 ret = sscanf(sc->hdev->uniq,
2104 "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx",
2105 &sc->mac_address[5], &sc->mac_address[4], &sc->mac_address[3],
2106 &sc->mac_address[2], &sc->mac_address[1], &sc->mac_address[0]);
2107
2108 if (ret != 6)
2109 return -EINVAL;
2110
2111 return 0;
2112}
2113
2114static int sony_check_add(struct sony_sc *sc)
2115{
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002116 __u8 *buf = NULL;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002117 int n, ret;
2118
2119 if ((sc->quirks & DUALSHOCK4_CONTROLLER_BT) ||
Simon Wood12e9a6d72015-06-09 21:27:05 -06002120 (sc->quirks & MOTION_CONTROLLER_BT) ||
Simon Wood4545ee02015-06-17 00:08:52 -06002121 (sc->quirks & NAVIGATION_CONTROLLER_BT) ||
Frank Praznikd2d782f2014-02-20 11:36:03 -05002122 (sc->quirks & SIXAXIS_CONTROLLER_BT)) {
2123 /*
2124 * sony_get_bt_devaddr() attempts to parse the Bluetooth MAC
2125 * address from the uniq string where HIDP stores it.
2126 * As uniq cannot be guaranteed to be a MAC address in all cases
2127 * a failure of this function should not prevent the connection.
2128 */
2129 if (sony_get_bt_devaddr(sc) < 0) {
2130 hid_warn(sc->hdev, "UNIQ does not contain a MAC address; duplicate check skipped\n");
2131 return 0;
2132 }
2133 } else if (sc->quirks & DUALSHOCK4_CONTROLLER_USB) {
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002134 buf = kmalloc(DS4_REPORT_0x81_SIZE, GFP_KERNEL);
2135 if (!buf)
2136 return -ENOMEM;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002137
2138 /*
2139 * The MAC address of a DS4 controller connected via USB can be
2140 * retrieved with feature report 0x81. The address begins at
2141 * offset 1.
2142 */
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002143 ret = hid_hw_raw_request(sc->hdev, 0x81, buf,
2144 DS4_REPORT_0x81_SIZE, HID_FEATURE_REPORT,
2145 HID_REQ_GET_REPORT);
Frank Praznikd2d782f2014-02-20 11:36:03 -05002146
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002147 if (ret != DS4_REPORT_0x81_SIZE) {
Frank Praznikd2d782f2014-02-20 11:36:03 -05002148 hid_err(sc->hdev, "failed to retrieve feature report 0x81 with the DualShock 4 MAC address\n");
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002149 ret = ret < 0 ? ret : -EINVAL;
2150 goto out_free;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002151 }
2152
2153 memcpy(sc->mac_address, &buf[1], sizeof(sc->mac_address));
Simon Wood4545ee02015-06-17 00:08:52 -06002154 } else if ((sc->quirks & SIXAXIS_CONTROLLER_USB) ||
2155 (sc->quirks & NAVIGATION_CONTROLLER_USB)) {
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002156 buf = kmalloc(SIXAXIS_REPORT_0xF2_SIZE, GFP_KERNEL);
2157 if (!buf)
2158 return -ENOMEM;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002159
2160 /*
2161 * The MAC address of a Sixaxis controller connected via USB can
2162 * be retrieved with feature report 0xf2. The address begins at
2163 * offset 4.
2164 */
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002165 ret = hid_hw_raw_request(sc->hdev, 0xf2, buf,
2166 SIXAXIS_REPORT_0xF2_SIZE, HID_FEATURE_REPORT,
2167 HID_REQ_GET_REPORT);
Frank Praznikd2d782f2014-02-20 11:36:03 -05002168
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002169 if (ret != SIXAXIS_REPORT_0xF2_SIZE) {
Frank Praznikd2d782f2014-02-20 11:36:03 -05002170 hid_err(sc->hdev, "failed to retrieve feature report 0xf2 with the Sixaxis MAC address\n");
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002171 ret = ret < 0 ? ret : -EINVAL;
2172 goto out_free;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002173 }
2174
2175 /*
2176 * The Sixaxis device MAC in the report is big-endian and must
2177 * be byte-swapped.
2178 */
2179 for (n = 0; n < 6; n++)
2180 sc->mac_address[5-n] = buf[4+n];
2181 } else {
2182 return 0;
2183 }
2184
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002185 ret = sony_check_add_dev_list(sc);
2186
2187out_free:
2188
2189 kfree(buf);
2190
2191 return ret;
Frank Praznikd2d782f2014-02-20 11:36:03 -05002192}
2193
Frank Praznik80250872014-04-14 10:11:35 -04002194static int sony_set_device_id(struct sony_sc *sc)
2195{
2196 int ret;
2197
2198 /*
2199 * Only DualShock 4 or Sixaxis controllers get an id.
2200 * All others are set to -1.
2201 */
2202 if ((sc->quirks & SIXAXIS_CONTROLLER) ||
2203 (sc->quirks & DUALSHOCK4_CONTROLLER)) {
2204 ret = ida_simple_get(&sony_device_id_allocator, 0, 0,
2205 GFP_KERNEL);
2206 if (ret < 0) {
2207 sc->device_id = -1;
2208 return ret;
2209 }
2210 sc->device_id = ret;
2211 } else {
2212 sc->device_id = -1;
2213 }
2214
2215 return 0;
2216}
2217
2218static void sony_release_device_id(struct sony_sc *sc)
2219{
2220 if (sc->device_id >= 0) {
2221 ida_simple_remove(&sony_device_id_allocator, sc->device_id);
2222 sc->device_id = -1;
2223 }
2224}
2225
Frank Praznik46262042014-04-14 10:11:31 -04002226static inline void sony_init_work(struct sony_sc *sc,
2227 void (*worker)(struct work_struct *))
2228{
2229 if (!sc->worker_initialized)
2230 INIT_WORK(&sc->state_worker, worker);
2231
2232 sc->worker_initialized = 1;
2233}
2234
2235static inline void sony_cancel_work_sync(struct sony_sc *sc)
2236{
2237 if (sc->worker_initialized)
2238 cancel_work_sync(&sc->state_worker);
2239}
Frank Praznikd2d782f2014-02-20 11:36:03 -05002240
Jiri Slabybd28ce02008-06-25 23:47:04 +02002241static int sony_probe(struct hid_device *hdev, const struct hid_device_id *id)
2242{
2243 int ret;
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002244 unsigned long quirks = id->driver_data;
2245 struct sony_sc *sc;
Colin Leitnerf04d5142013-05-27 23:41:05 +02002246 unsigned int connect_mask = HID_CONNECT_DEFAULT;
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002247
Benjamin Tissoiresabf832b2013-07-24 19:38:04 +02002248 sc = devm_kzalloc(&hdev->dev, sizeof(*sc), GFP_KERNEL);
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002249 if (sc == NULL) {
Joe Perches4291ee32010-12-09 19:29:03 -08002250 hid_err(hdev, "can't alloc sony descriptor\n");
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002251 return -ENOMEM;
2252 }
2253
Frank Praznikb94993f2015-02-22 20:42:46 -05002254 spin_lock_init(&sc->lock);
2255
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002256 sc->quirks = quirks;
2257 hid_set_drvdata(hdev, sc);
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01002258 sc->hdev = hdev;
Jiri Slabybd28ce02008-06-25 23:47:04 +02002259
Jiri Slabybd28ce02008-06-25 23:47:04 +02002260 ret = hid_parse(hdev);
2261 if (ret) {
Joe Perches4291ee32010-12-09 19:29:03 -08002262 hid_err(hdev, "parse failed\n");
Benjamin Tissoiresabf832b2013-07-24 19:38:04 +02002263 return ret;
Jiri Slabybd28ce02008-06-25 23:47:04 +02002264 }
2265
Colin Leitnerf04d5142013-05-27 23:41:05 +02002266 if (sc->quirks & VAIO_RDESC_CONSTANT)
2267 connect_mask |= HID_CONNECT_HIDDEV_FORCE;
Antonio Ospite50764652014-06-24 13:28:40 +02002268 else if (sc->quirks & SIXAXIS_CONTROLLER)
Colin Leitnerf04d5142013-05-27 23:41:05 +02002269 connect_mask |= HID_CONNECT_HIDDEV_FORCE;
2270
2271 ret = hid_hw_start(hdev, connect_mask);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002272 if (ret) {
Joe Perches4291ee32010-12-09 19:29:03 -08002273 hid_err(hdev, "hw start failed\n");
Benjamin Tissoiresabf832b2013-07-24 19:38:04 +02002274 return ret;
Jiri Slabybd28ce02008-06-25 23:47:04 +02002275 }
2276
Frank Praznik80250872014-04-14 10:11:35 -04002277 ret = sony_set_device_id(sc);
2278 if (ret < 0) {
2279 hid_err(hdev, "failed to allocate the device id\n");
2280 goto err_stop;
2281 }
2282
Frank Praznik131a8a92015-05-05 20:47:28 -04002283 ret = sony_allocate_output_report(sc);
2284 if (ret < 0) {
2285 hid_err(hdev, "failed to allocate the output report buffer\n");
2286 goto err_stop;
2287 }
2288
Simon Wood4545ee02015-06-17 00:08:52 -06002289 if ((sc->quirks & SIXAXIS_CONTROLLER_USB) ||
2290 (sc->quirks & NAVIGATION_CONTROLLER_USB)) {
Benjamin Tissoirese534a932014-03-08 22:52:42 -05002291 /*
2292 * The Sony Sixaxis does not handle HID Output Reports on the
2293 * Interrupt EP like it could, so we need to force HID Output
2294 * Reports to use HID_REQ_SET_REPORT on the Control EP.
2295 *
2296 * There is also another issue about HID Output Reports via USB,
2297 * the Sixaxis does not want the report_id as part of the data
2298 * packet, so we have to discard buf[0] when sending the actual
2299 * control message, even for numbered reports, humpf!
2300 */
2301 hdev->quirks |= HID_QUIRK_NO_OUTPUT_REPORTS_ON_INTR_EP;
2302 hdev->quirks |= HID_QUIRK_SKIP_OUTPUT_REPORT_ID;
Antonio Ospite816651a2010-05-03 22:15:55 +02002303 ret = sixaxis_set_operational_usb(hdev);
Frank Praznik46262042014-04-14 10:11:31 -04002304 sony_init_work(sc, sixaxis_state_worker);
Simon Wood4545ee02015-06-17 00:08:52 -06002305 } else if ((sc->quirks & SIXAXIS_CONTROLLER_BT) ||
2306 (sc->quirks & NAVIGATION_CONTROLLER_BT)) {
Frank Praznik2078b9bb2014-03-15 09:41:16 -04002307 /*
2308 * The Sixaxis wants output reports sent on the ctrl endpoint
2309 * when connected via Bluetooth.
2310 */
2311 hdev->quirks |= HID_QUIRK_NO_OUTPUT_REPORTS_ON_INTR_EP;
Antonio Ospite816651a2010-05-03 22:15:55 +02002312 ret = sixaxis_set_operational_bt(hdev);
Frank Praznik46262042014-04-14 10:11:31 -04002313 sony_init_work(sc, sixaxis_state_worker);
Frank Praznikfee4e2d2014-02-18 17:22:01 -05002314 } else if (sc->quirks & DUALSHOCK4_CONTROLLER) {
Frank Praznik68330d82014-02-05 20:03:49 -05002315 if (sc->quirks & DUALSHOCK4_CONTROLLER_BT) {
Frank Praznik2078b9bb2014-03-15 09:41:16 -04002316 /*
2317 * The DualShock 4 wants output reports sent on the ctrl
2318 * endpoint when connected via Bluetooth.
2319 */
2320 hdev->quirks |= HID_QUIRK_NO_OUTPUT_REPORTS_ON_INTR_EP;
Frank Praznik68330d82014-02-05 20:03:49 -05002321 ret = dualshock4_set_operational_bt(hdev);
2322 if (ret < 0) {
2323 hid_err(hdev, "failed to set the Dualshock 4 operational mode\n");
2324 goto err_stop;
2325 }
2326 }
Frank Praznikc4e1ddf2014-01-17 14:46:26 -05002327
Frank Praznik46262042014-04-14 10:11:31 -04002328 sony_init_work(sc, dualshock4_state_worker);
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04002329 } else if (sc->quirks & MOTION_CONTROLLER) {
2330 sony_init_work(sc, motion_state_worker);
Frank Praznik0bd88dd2014-01-11 15:12:42 -05002331 } else {
2332 ret = 0;
2333 }
Bastien Noceraf9ce7c22010-01-20 12:01:53 +00002334
Jiri Kosina4dfdc462008-12-30 00:49:59 +01002335 if (ret < 0)
Jiri Slabybd28ce02008-06-25 23:47:04 +02002336 goto err_stop;
2337
Frank Praznikd2d782f2014-02-20 11:36:03 -05002338 ret = sony_check_add(sc);
2339 if (ret < 0)
2340 goto err_stop;
2341
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01002342 if (sc->quirks & SONY_LED_SUPPORT) {
Frank Praznikfa57a812014-04-14 10:11:33 -04002343 ret = sony_leds_init(sc);
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01002344 if (ret < 0)
2345 goto err_stop;
2346 }
2347
Frank Praznikd902f472014-01-27 10:17:36 -05002348 if (sc->quirks & SONY_BATTERY_SUPPORT) {
2349 ret = sony_battery_probe(sc);
2350 if (ret < 0)
2351 goto err_stop;
2352
2353 /* Open the device to receive reports with battery info */
2354 ret = hid_hw_open(hdev);
2355 if (ret < 0) {
2356 hid_err(hdev, "hw open failed\n");
2357 goto err_stop;
2358 }
2359 }
2360
Frank Praznikc8de9db2014-02-20 11:36:01 -05002361 if (sc->quirks & SONY_FF_SUPPORT) {
Frank Praznikfa57a812014-04-14 10:11:33 -04002362 ret = sony_init_ff(sc);
Frank Praznikc8de9db2014-02-20 11:36:01 -05002363 if (ret < 0)
2364 goto err_close;
Frank Praznik5f5750d2014-02-19 13:09:22 -05002365 }
Sven Eckelmanna08c22c2013-11-09 19:25:57 +01002366
Jiri Slabybd28ce02008-06-25 23:47:04 +02002367 return 0;
Frank Praznikd902f472014-01-27 10:17:36 -05002368err_close:
2369 hid_hw_close(hdev);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002370err_stop:
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01002371 if (sc->quirks & SONY_LED_SUPPORT)
Frank Praznikfa57a812014-04-14 10:11:33 -04002372 sony_leds_remove(sc);
Frank Praznikd902f472014-01-27 10:17:36 -05002373 if (sc->quirks & SONY_BATTERY_SUPPORT)
2374 sony_battery_remove(sc);
Frank Praznik46262042014-04-14 10:11:31 -04002375 sony_cancel_work_sync(sc);
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002376 kfree(sc->output_report_dmabuf);
Frank Praznikd2d782f2014-02-20 11:36:03 -05002377 sony_remove_dev_list(sc);
Frank Praznik80250872014-04-14 10:11:35 -04002378 sony_release_device_id(sc);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002379 hid_hw_stop(hdev);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002380 return ret;
2381}
2382
Jiri Kosinacc6e0bb2008-10-23 12:58:38 +02002383static void sony_remove(struct hid_device *hdev)
2384{
Colin Leitnerf04d5142013-05-27 23:41:05 +02002385 struct sony_sc *sc = hid_get_drvdata(hdev);
2386
Sven Eckelmann0a286ef2013-11-19 20:26:32 +01002387 if (sc->quirks & SONY_LED_SUPPORT)
Frank Praznikfa57a812014-04-14 10:11:33 -04002388 sony_leds_remove(sc);
Colin Leitnerf04d5142013-05-27 23:41:05 +02002389
Frank Praznikd902f472014-01-27 10:17:36 -05002390 if (sc->quirks & SONY_BATTERY_SUPPORT) {
2391 hid_hw_close(hdev);
2392 sony_battery_remove(sc);
2393 }
2394
Frank Praznik46262042014-04-14 10:11:31 -04002395 sony_cancel_work_sync(sc);
Sven Eckelmann9f323b62013-11-17 20:38:21 +01002396
Frank Praznik9b2b5c92014-11-12 14:10:09 -05002397 kfree(sc->output_report_dmabuf);
2398
Frank Praznikd2d782f2014-02-20 11:36:03 -05002399 sony_remove_dev_list(sc);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002400
Frank Praznik80250872014-04-14 10:11:35 -04002401 sony_release_device_id(sc);
2402
Jiri Slabybd28ce02008-06-25 23:47:04 +02002403 hid_hw_stop(hdev);
2404}
2405
2406static const struct hid_device_id sony_devices[] = {
2407 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_CONTROLLER),
2408 .driver_data = SIXAXIS_CONTROLLER_USB },
2409 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER),
Simon Wood4545ee02015-06-17 00:08:52 -06002410 .driver_data = NAVIGATION_CONTROLLER_USB },
Simon Wood6eabaaa2015-06-17 00:08:51 -06002411 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_NAVIGATION_CONTROLLER),
Simon Wood4545ee02015-06-17 00:08:52 -06002412 .driver_data = NAVIGATION_CONTROLLER_BT },
Frank Praznikc5e0c1c2015-05-05 20:47:30 -04002413 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_MOTION_CONTROLLER),
Simon Woodb3bca322015-06-09 21:27:04 -06002414 .driver_data = MOTION_CONTROLLER_USB },
Simon Wooda4afa852015-06-03 09:45:19 -06002415 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_MOTION_CONTROLLER),
Simon Woodb3bca322015-06-09 21:27:04 -06002416 .driver_data = MOTION_CONTROLLER_BT },
Jiri Slabybd28ce02008-06-25 23:47:04 +02002417 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_CONTROLLER),
2418 .driver_data = SIXAXIS_CONTROLLER_BT },
2419 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGX_MOUSE),
2420 .driver_data = VAIO_RDESC_CONSTANT },
2421 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_VAIO_VGP_MOUSE),
2422 .driver_data = VAIO_RDESC_CONSTANT },
2423 /* Wired Buzz Controller. Reported as Sony Hub from its USB ID and as
2424 * Logitech joystick from the device descriptor. */
2425 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_BUZZ_CONTROLLER),
2426 .driver_data = BUZZ_CONTROLLER },
2427 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_WIRELESS_BUZZ_CONTROLLER),
2428 .driver_data = BUZZ_CONTROLLER },
2429 /* PS3 BD Remote Control */
2430 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS3_BDREMOTE),
2431 .driver_data = PS3REMOTE },
2432 /* Logitech Harmony Adapter for PS3 */
2433 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_HARMONY_PS3),
2434 .driver_data = PS3REMOTE },
Frank Praznik68a49e52014-11-12 14:52:28 -05002435 /* SMK-Link PS3 BD Remote Control */
2436 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SMK, USB_DEVICE_ID_SMK_PS3_BDREMOTE),
2437 .driver_data = PS3REMOTE },
Frank Praznik0bd88dd2014-01-11 15:12:42 -05002438 /* Sony Dualshock 4 controllers for PS4 */
2439 { HID_USB_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS4_CONTROLLER),
Frank Praznik8ab16762014-01-16 21:42:31 -05002440 .driver_data = DUALSHOCK4_CONTROLLER_USB },
Frank Praznik0bd88dd2014-01-11 15:12:42 -05002441 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SONY, USB_DEVICE_ID_SONY_PS4_CONTROLLER),
Frank Praznik8ab16762014-01-16 21:42:31 -05002442 .driver_data = DUALSHOCK4_CONTROLLER_BT },
Jiri Slabybd28ce02008-06-25 23:47:04 +02002443 { }
2444};
2445MODULE_DEVICE_TABLE(hid, sony_devices);
2446
2447static struct hid_driver sony_driver = {
Frank Praznikce8efc32014-09-18 21:15:01 -04002448 .name = "sony",
2449 .id_table = sony_devices,
2450 .input_mapping = sony_mapping,
2451 .input_configured = sony_input_configured,
2452 .probe = sony_probe,
2453 .remove = sony_remove,
2454 .report_fixup = sony_report_fixup,
2455 .raw_event = sony_raw_event
Jiri Slabybd28ce02008-06-25 23:47:04 +02002456};
Frank Praznik80250872014-04-14 10:11:35 -04002457
2458static int __init sony_init(void)
2459{
2460 dbg_hid("Sony:%s\n", __func__);
2461
2462 return hid_register_driver(&sony_driver);
2463}
2464
2465static void __exit sony_exit(void)
2466{
2467 dbg_hid("Sony:%s\n", __func__);
2468
Frank Praznik80250872014-04-14 10:11:35 -04002469 hid_unregister_driver(&sony_driver);
Antonio Ospite6c400652015-02-16 22:58:24 +01002470 ida_destroy(&sony_device_id_allocator);
Frank Praznik80250872014-04-14 10:11:35 -04002471}
2472module_init(sony_init);
2473module_exit(sony_exit);
Jiri Slabybd28ce02008-06-25 23:47:04 +02002474
2475MODULE_LICENSE("GPL");