1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * HIDPP protocol for Logitech receivers 4 * 5 * Copyright (c) 2011 Logitech (c) 6 * Copyright (c) 2012-2013 Google (c) 7 * Copyright (c) 2013-2014 Red Hat Inc. 8 */ 9 10 11 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt 12 13 #include <linux/device.h> 14 #include <linux/input.h> 15 #include <linux/usb.h> 16 #include <linux/hid.h> 17 #include <linux/module.h> 18 #include <linux/slab.h> 19 #include <linux/sched.h> 20 #include <linux/sched/clock.h> 21 #include <linux/kfifo.h> 22 #include <linux/input/mt.h> 23 #include <linux/workqueue.h> 24 #include <linux/atomic.h> 25 #include <linux/fixp-arith.h> 26 #include <asm/unaligned.h> 27 #include "usbhid/usbhid.h" 28 #include "hid-ids.h" 29 30 MODULE_LICENSE("GPL"); 31 MODULE_AUTHOR("Benjamin Tissoires <benjamin.tissoires@gmail.com>"); 32 MODULE_AUTHOR("Nestor Lopez Casado <nlopezcasad@logitech.com>"); 33 MODULE_AUTHOR("Bastien Nocera <hadess@hadess.net>"); 34 35 static bool disable_tap_to_click; 36 module_param(disable_tap_to_click, bool, 0644); 37 MODULE_PARM_DESC(disable_tap_to_click, 38 "Disable Tap-To-Click mode reporting for touchpads (only on the K400 currently)."); 39 40 /* Define a non-zero software ID to identify our own requests */ 41 #define LINUX_KERNEL_SW_ID 0x01 42 43 #define REPORT_ID_HIDPP_SHORT 0x10 44 #define REPORT_ID_HIDPP_LONG 0x11 45 #define REPORT_ID_HIDPP_VERY_LONG 0x12 46 47 #define HIDPP_REPORT_SHORT_LENGTH 7 48 #define HIDPP_REPORT_LONG_LENGTH 20 49 #define HIDPP_REPORT_VERY_LONG_MAX_LENGTH 64 50 51 #define HIDPP_REPORT_SHORT_SUPPORTED BIT(0) 52 #define HIDPP_REPORT_LONG_SUPPORTED BIT(1) 53 #define HIDPP_REPORT_VERY_LONG_SUPPORTED BIT(2) 54 55 #define HIDPP_SUB_ID_CONSUMER_VENDOR_KEYS 0x03 56 #define HIDPP_SUB_ID_ROLLER 0x05 57 #define HIDPP_SUB_ID_MOUSE_EXTRA_BTNS 0x06 58 #define HIDPP_SUB_ID_USER_IFACE_EVENT 0x08 59 #define HIDPP_USER_IFACE_EVENT_ENCRYPTION_KEY_LOST BIT(5) 60 61 #define HIDPP_QUIRK_CLASS_WTP BIT(0) 62 #define HIDPP_QUIRK_CLASS_M560 BIT(1) 63 #define HIDPP_QUIRK_CLASS_K400 BIT(2) 64 #define HIDPP_QUIRK_CLASS_G920 BIT(3) 65 #define HIDPP_QUIRK_CLASS_K750 BIT(4) 66 67 /* bits 2..20 are reserved for classes */ 68 /* #define HIDPP_QUIRK_CONNECT_EVENTS BIT(21) disabled */ 69 #define HIDPP_QUIRK_WTP_PHYSICAL_BUTTONS BIT(22) 70 #define HIDPP_QUIRK_DELAYED_INIT BIT(23) 71 #define HIDPP_QUIRK_FORCE_OUTPUT_REPORTS BIT(24) 72 #define HIDPP_QUIRK_HIDPP_WHEELS BIT(25) 73 #define HIDPP_QUIRK_HIDPP_EXTRA_MOUSE_BTNS BIT(26) 74 #define HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS BIT(27) 75 #define HIDPP_QUIRK_HI_RES_SCROLL_1P0 BIT(28) 76 #define HIDPP_QUIRK_WIRELESS_STATUS BIT(29) 77 78 /* These are just aliases for now */ 79 #define HIDPP_QUIRK_KBD_SCROLL_WHEEL HIDPP_QUIRK_HIDPP_WHEELS 80 #define HIDPP_QUIRK_KBD_ZOOM_WHEEL HIDPP_QUIRK_HIDPP_WHEELS 81 82 /* Convenience constant to check for any high-res support. */ 83 #define HIDPP_CAPABILITY_HI_RES_SCROLL (HIDPP_CAPABILITY_HIDPP10_FAST_SCROLL | \ 84 HIDPP_CAPABILITY_HIDPP20_HI_RES_SCROLL | \ 85 HIDPP_CAPABILITY_HIDPP20_HI_RES_WHEEL) 86 87 #define HIDPP_CAPABILITY_HIDPP10_BATTERY BIT(0) 88 #define HIDPP_CAPABILITY_HIDPP20_BATTERY BIT(1) 89 #define HIDPP_CAPABILITY_BATTERY_MILEAGE BIT(2) 90 #define HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS BIT(3) 91 #define HIDPP_CAPABILITY_BATTERY_VOLTAGE BIT(4) 92 #define HIDPP_CAPABILITY_BATTERY_PERCENTAGE BIT(5) 93 #define HIDPP_CAPABILITY_UNIFIED_BATTERY BIT(6) 94 #define HIDPP_CAPABILITY_HIDPP20_HI_RES_WHEEL BIT(7) 95 #define HIDPP_CAPABILITY_HIDPP20_HI_RES_SCROLL BIT(8) 96 #define HIDPP_CAPABILITY_HIDPP10_FAST_SCROLL BIT(9) 97 #define HIDPP_CAPABILITY_ADC_MEASUREMENT BIT(10) 98 99 #define lg_map_key_clear(c) hid_map_usage_clear(hi, usage, bit, max, EV_KEY, (c)) 100 101 /* 102 * There are two hidpp protocols in use, the first version hidpp10 is known 103 * as register access protocol or RAP, the second version hidpp20 is known as 104 * feature access protocol or FAP 105 * 106 * Most older devices (including the Unifying usb receiver) use the RAP protocol 107 * where as most newer devices use the FAP protocol. Both protocols are 108 * compatible with the underlying transport, which could be usb, Unifiying, or 109 * bluetooth. The message lengths are defined by the hid vendor specific report 110 * descriptor for the HIDPP_SHORT report type (total message lenth 7 bytes) and 111 * the HIDPP_LONG report type (total message length 20 bytes) 112 * 113 * The RAP protocol uses both report types, whereas the FAP only uses HIDPP_LONG 114 * messages. The Unifying receiver itself responds to RAP messages (device index 115 * is 0xFF for the receiver), and all messages (short or long) with a device 116 * index between 1 and 6 are passed untouched to the corresponding paired 117 * Unifying device. 118 * 119 * The paired device can be RAP or FAP, it will receive the message untouched 120 * from the Unifiying receiver. 121 */ 122 123 struct fap { 124 u8 feature_index; 125 u8 funcindex_clientid; 126 u8 params[HIDPP_REPORT_VERY_LONG_MAX_LENGTH - 4U]; 127 }; 128 129 struct rap { 130 u8 sub_id; 131 u8 reg_address; 132 u8 params[HIDPP_REPORT_VERY_LONG_MAX_LENGTH - 4U]; 133 }; 134 135 struct hidpp_report { 136 u8 report_id; 137 u8 device_index; 138 union { 139 struct fap fap; 140 struct rap rap; 141 u8 rawbytes[sizeof(struct fap)]; 142 }; 143 } __packed; 144 145 struct hidpp_battery { 146 u8 feature_index; 147 u8 solar_feature_index; 148 u8 voltage_feature_index; 149 u8 adc_measurement_feature_index; 150 struct power_supply_desc desc; 151 struct power_supply *ps; 152 char name[64]; 153 int status; 154 int capacity; 155 int level; 156 int voltage; 157 int charge_type; 158 bool online; 159 u8 supported_levels_1004; 160 }; 161 162 /** 163 * struct hidpp_scroll_counter - Utility class for processing high-resolution 164 * scroll events. 165 * @dev: the input device for which events should be reported. 166 * @wheel_multiplier: the scalar multiplier to be applied to each wheel event 167 * @remainder: counts the number of high-resolution units moved since the last 168 * low-resolution event (REL_WHEEL or REL_HWHEEL) was sent. Should 169 * only be used by class methods. 170 * @direction: direction of last movement (1 or -1) 171 * @last_time: last event time, used to reset remainder after inactivity 172 */ 173 struct hidpp_scroll_counter { 174 int wheel_multiplier; 175 int remainder; 176 int direction; 177 unsigned long long last_time; 178 }; 179 180 struct hidpp_device { 181 struct hid_device *hid_dev; 182 struct input_dev *input; 183 struct mutex send_mutex; 184 void *send_receive_buf; 185 char *name; /* will never be NULL and should not be freed */ 186 wait_queue_head_t wait; 187 int very_long_report_length; 188 bool answer_available; 189 u8 protocol_major; 190 u8 protocol_minor; 191 192 void *private_data; 193 194 struct work_struct work; 195 struct kfifo delayed_work_fifo; 196 struct input_dev *delayed_input; 197 198 unsigned long quirks; 199 unsigned long capabilities; 200 u8 supported_reports; 201 202 struct hidpp_battery battery; 203 struct hidpp_scroll_counter vertical_wheel_counter; 204 205 u8 wireless_feature_index; 206 207 bool connected_once; 208 }; 209 210 /* HID++ 1.0 error codes */ 211 #define HIDPP_ERROR 0x8f 212 #define HIDPP_ERROR_SUCCESS 0x00 213 #define HIDPP_ERROR_INVALID_SUBID 0x01 214 #define HIDPP_ERROR_INVALID_ADRESS 0x02 215 #define HIDPP_ERROR_INVALID_VALUE 0x03 216 #define HIDPP_ERROR_CONNECT_FAIL 0x04 217 #define HIDPP_ERROR_TOO_MANY_DEVICES 0x05 218 #define HIDPP_ERROR_ALREADY_EXISTS 0x06 219 #define HIDPP_ERROR_BUSY 0x07 220 #define HIDPP_ERROR_UNKNOWN_DEVICE 0x08 221 #define HIDPP_ERROR_RESOURCE_ERROR 0x09 222 #define HIDPP_ERROR_REQUEST_UNAVAILABLE 0x0a 223 #define HIDPP_ERROR_INVALID_PARAM_VALUE 0x0b 224 #define HIDPP_ERROR_WRONG_PIN_CODE 0x0c 225 /* HID++ 2.0 error codes */ 226 #define HIDPP20_ERROR_NO_ERROR 0x00 227 #define HIDPP20_ERROR_UNKNOWN 0x01 228 #define HIDPP20_ERROR_INVALID_ARGS 0x02 229 #define HIDPP20_ERROR_OUT_OF_RANGE 0x03 230 #define HIDPP20_ERROR_HW_ERROR 0x04 231 #define HIDPP20_ERROR_NOT_ALLOWED 0x05 232 #define HIDPP20_ERROR_INVALID_FEATURE_INDEX 0x06 233 #define HIDPP20_ERROR_INVALID_FUNCTION_ID 0x07 234 #define HIDPP20_ERROR_BUSY 0x08 235 #define HIDPP20_ERROR_UNSUPPORTED 0x09 236 #define HIDPP20_ERROR 0xff 237 238 static int __hidpp_send_report(struct hid_device *hdev, 239 struct hidpp_report *hidpp_report) 240 { 241 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 242 int fields_count, ret; 243 244 switch (hidpp_report->report_id) { 245 case REPORT_ID_HIDPP_SHORT: 246 fields_count = HIDPP_REPORT_SHORT_LENGTH; 247 break; 248 case REPORT_ID_HIDPP_LONG: 249 fields_count = HIDPP_REPORT_LONG_LENGTH; 250 break; 251 case REPORT_ID_HIDPP_VERY_LONG: 252 fields_count = hidpp->very_long_report_length; 253 break; 254 default: 255 return -ENODEV; 256 } 257 258 /* 259 * set the device_index as the receiver, it will be overwritten by 260 * hid_hw_request if needed 261 */ 262 hidpp_report->device_index = 0xff; 263 264 if (hidpp->quirks & HIDPP_QUIRK_FORCE_OUTPUT_REPORTS) { 265 ret = hid_hw_output_report(hdev, (u8 *)hidpp_report, fields_count); 266 } else { 267 ret = hid_hw_raw_request(hdev, hidpp_report->report_id, 268 (u8 *)hidpp_report, fields_count, HID_OUTPUT_REPORT, 269 HID_REQ_SET_REPORT); 270 } 271 272 return ret == fields_count ? 0 : -1; 273 } 274 275 /* 276 * Effectively send the message to the device, waiting for its answer. 277 * 278 * Must be called with hidpp->send_mutex locked 279 * 280 * Same return protocol than hidpp_send_message_sync(): 281 * - success on 0 282 * - negative error means transport error 283 * - positive value means protocol error 284 */ 285 static int __do_hidpp_send_message_sync(struct hidpp_device *hidpp, 286 struct hidpp_report *message, 287 struct hidpp_report *response) 288 { 289 int ret; 290 291 __must_hold(&hidpp->send_mutex); 292 293 hidpp->send_receive_buf = response; 294 hidpp->answer_available = false; 295 296 /* 297 * So that we can later validate the answer when it arrives 298 * in hidpp_raw_event 299 */ 300 *response = *message; 301 302 ret = __hidpp_send_report(hidpp->hid_dev, message); 303 if (ret) { 304 dbg_hid("__hidpp_send_report returned err: %d\n", ret); 305 memset(response, 0, sizeof(struct hidpp_report)); 306 return ret; 307 } 308 309 if (!wait_event_timeout(hidpp->wait, hidpp->answer_available, 310 5*HZ)) { 311 dbg_hid("%s:timeout waiting for response\n", __func__); 312 memset(response, 0, sizeof(struct hidpp_report)); 313 return -ETIMEDOUT; 314 } 315 316 if (response->report_id == REPORT_ID_HIDPP_SHORT && 317 response->rap.sub_id == HIDPP_ERROR) { 318 ret = response->rap.params[1]; 319 dbg_hid("%s:got hidpp error %02X\n", __func__, ret); 320 return ret; 321 } 322 323 if ((response->report_id == REPORT_ID_HIDPP_LONG || 324 response->report_id == REPORT_ID_HIDPP_VERY_LONG) && 325 response->fap.feature_index == HIDPP20_ERROR) { 326 ret = response->fap.params[1]; 327 dbg_hid("%s:got hidpp 2.0 error %02X\n", __func__, ret); 328 return ret; 329 } 330 331 return 0; 332 } 333 334 /* 335 * hidpp_send_message_sync() returns 0 in case of success, and something else 336 * in case of a failure. 337 * 338 * See __do_hidpp_send_message_sync() for a detailed explanation of the returned 339 * value. 340 */ 341 static int hidpp_send_message_sync(struct hidpp_device *hidpp, 342 struct hidpp_report *message, 343 struct hidpp_report *response) 344 { 345 int ret; 346 int max_retries = 3; 347 348 mutex_lock(&hidpp->send_mutex); 349 350 do { 351 ret = __do_hidpp_send_message_sync(hidpp, message, response); 352 if (ret != HIDPP20_ERROR_BUSY) 353 break; 354 355 dbg_hid("%s:got busy hidpp 2.0 error %02X, retrying\n", __func__, ret); 356 } while (--max_retries); 357 358 mutex_unlock(&hidpp->send_mutex); 359 return ret; 360 361 } 362 363 /* 364 * hidpp_send_fap_command_sync() returns 0 in case of success, and something else 365 * in case of a failure. 366 * 367 * See __do_hidpp_send_message_sync() for a detailed explanation of the returned 368 * value. 369 */ 370 static int hidpp_send_fap_command_sync(struct hidpp_device *hidpp, 371 u8 feat_index, u8 funcindex_clientid, u8 *params, int param_count, 372 struct hidpp_report *response) 373 { 374 struct hidpp_report *message; 375 int ret; 376 377 if (param_count > sizeof(message->fap.params)) { 378 hid_dbg(hidpp->hid_dev, 379 "Invalid number of parameters passed to command (%d != %llu)\n", 380 param_count, 381 (unsigned long long) sizeof(message->fap.params)); 382 return -EINVAL; 383 } 384 385 message = kzalloc(sizeof(struct hidpp_report), GFP_KERNEL); 386 if (!message) 387 return -ENOMEM; 388 389 if (param_count > (HIDPP_REPORT_LONG_LENGTH - 4)) 390 message->report_id = REPORT_ID_HIDPP_VERY_LONG; 391 else 392 message->report_id = REPORT_ID_HIDPP_LONG; 393 message->fap.feature_index = feat_index; 394 message->fap.funcindex_clientid = funcindex_clientid | LINUX_KERNEL_SW_ID; 395 memcpy(&message->fap.params, params, param_count); 396 397 ret = hidpp_send_message_sync(hidpp, message, response); 398 kfree(message); 399 return ret; 400 } 401 402 /* 403 * hidpp_send_rap_command_sync() returns 0 in case of success, and something else 404 * in case of a failure. 405 * 406 * See __do_hidpp_send_message_sync() for a detailed explanation of the returned 407 * value. 408 */ 409 static int hidpp_send_rap_command_sync(struct hidpp_device *hidpp_dev, 410 u8 report_id, u8 sub_id, u8 reg_address, u8 *params, int param_count, 411 struct hidpp_report *response) 412 { 413 struct hidpp_report *message; 414 int ret, max_count; 415 416 /* Send as long report if short reports are not supported. */ 417 if (report_id == REPORT_ID_HIDPP_SHORT && 418 !(hidpp_dev->supported_reports & HIDPP_REPORT_SHORT_SUPPORTED)) 419 report_id = REPORT_ID_HIDPP_LONG; 420 421 switch (report_id) { 422 case REPORT_ID_HIDPP_SHORT: 423 max_count = HIDPP_REPORT_SHORT_LENGTH - 4; 424 break; 425 case REPORT_ID_HIDPP_LONG: 426 max_count = HIDPP_REPORT_LONG_LENGTH - 4; 427 break; 428 case REPORT_ID_HIDPP_VERY_LONG: 429 max_count = hidpp_dev->very_long_report_length - 4; 430 break; 431 default: 432 return -EINVAL; 433 } 434 435 if (param_count > max_count) 436 return -EINVAL; 437 438 message = kzalloc(sizeof(struct hidpp_report), GFP_KERNEL); 439 if (!message) 440 return -ENOMEM; 441 message->report_id = report_id; 442 message->rap.sub_id = sub_id; 443 message->rap.reg_address = reg_address; 444 memcpy(&message->rap.params, params, param_count); 445 446 ret = hidpp_send_message_sync(hidpp_dev, message, response); 447 kfree(message); 448 return ret; 449 } 450 451 static inline bool hidpp_match_answer(struct hidpp_report *question, 452 struct hidpp_report *answer) 453 { 454 return (answer->fap.feature_index == question->fap.feature_index) && 455 (answer->fap.funcindex_clientid == question->fap.funcindex_clientid); 456 } 457 458 static inline bool hidpp_match_error(struct hidpp_report *question, 459 struct hidpp_report *answer) 460 { 461 return ((answer->rap.sub_id == HIDPP_ERROR) || 462 (answer->fap.feature_index == HIDPP20_ERROR)) && 463 (answer->fap.funcindex_clientid == question->fap.feature_index) && 464 (answer->fap.params[0] == question->fap.funcindex_clientid); 465 } 466 467 static inline bool hidpp_report_is_connect_event(struct hidpp_device *hidpp, 468 struct hidpp_report *report) 469 { 470 return (hidpp->wireless_feature_index && 471 (report->fap.feature_index == hidpp->wireless_feature_index)) || 472 ((report->report_id == REPORT_ID_HIDPP_SHORT) && 473 (report->rap.sub_id == 0x41)); 474 } 475 476 /* 477 * hidpp_prefix_name() prefixes the current given name with "Logitech ". 478 */ 479 static void hidpp_prefix_name(char **name, int name_length) 480 { 481 #define PREFIX_LENGTH 9 /* "Logitech " */ 482 483 int new_length; 484 char *new_name; 485 486 if (name_length > PREFIX_LENGTH && 487 strncmp(*name, "Logitech ", PREFIX_LENGTH) == 0) 488 /* The prefix has is already in the name */ 489 return; 490 491 new_length = PREFIX_LENGTH + name_length; 492 new_name = kzalloc(new_length, GFP_KERNEL); 493 if (!new_name) 494 return; 495 496 snprintf(new_name, new_length, "Logitech %s", *name); 497 498 kfree(*name); 499 500 *name = new_name; 501 } 502 503 /* 504 * Updates the USB wireless_status based on whether the headset 505 * is turned on and reachable. 506 */ 507 static void hidpp_update_usb_wireless_status(struct hidpp_device *hidpp) 508 { 509 struct hid_device *hdev = hidpp->hid_dev; 510 struct usb_interface *intf; 511 512 if (!(hidpp->quirks & HIDPP_QUIRK_WIRELESS_STATUS)) 513 return; 514 if (!hid_is_usb(hdev)) 515 return; 516 517 intf = to_usb_interface(hdev->dev.parent); 518 usb_set_wireless_status(intf, hidpp->battery.online ? 519 USB_WIRELESS_STATUS_CONNECTED : 520 USB_WIRELESS_STATUS_DISCONNECTED); 521 } 522 523 /** 524 * hidpp_scroll_counter_handle_scroll() - Send high- and low-resolution scroll 525 * events given a high-resolution wheel 526 * movement. 527 * @input_dev: Pointer to the input device 528 * @counter: a hid_scroll_counter struct describing the wheel. 529 * @hi_res_value: the movement of the wheel, in the mouse's high-resolution 530 * units. 531 * 532 * Given a high-resolution movement, this function converts the movement into 533 * fractions of 120 and emits high-resolution scroll events for the input 534 * device. It also uses the multiplier from &struct hid_scroll_counter to 535 * emit low-resolution scroll events when appropriate for 536 * backwards-compatibility with userspace input libraries. 537 */ 538 static void hidpp_scroll_counter_handle_scroll(struct input_dev *input_dev, 539 struct hidpp_scroll_counter *counter, 540 int hi_res_value) 541 { 542 int low_res_value, remainder, direction; 543 unsigned long long now, previous; 544 545 hi_res_value = hi_res_value * 120/counter->wheel_multiplier; 546 input_report_rel(input_dev, REL_WHEEL_HI_RES, hi_res_value); 547 548 remainder = counter->remainder; 549 direction = hi_res_value > 0 ? 1 : -1; 550 551 now = sched_clock(); 552 previous = counter->last_time; 553 counter->last_time = now; 554 /* 555 * Reset the remainder after a period of inactivity or when the 556 * direction changes. This prevents the REL_WHEEL emulation point 557 * from sliding for devices that don't always provide the same 558 * number of movements per detent. 559 */ 560 if (now - previous > 1000000000 || direction != counter->direction) 561 remainder = 0; 562 563 counter->direction = direction; 564 remainder += hi_res_value; 565 566 /* Some wheels will rest 7/8ths of a detent from the previous detent 567 * after slow movement, so we want the threshold for low-res events to 568 * be in the middle between two detents (e.g. after 4/8ths) as 569 * opposed to on the detents themselves (8/8ths). 570 */ 571 if (abs(remainder) >= 60) { 572 /* Add (or subtract) 1 because we want to trigger when the wheel 573 * is half-way to the next detent (i.e. scroll 1 detent after a 574 * 1/2 detent movement, 2 detents after a 1 1/2 detent movement, 575 * etc.). 576 */ 577 low_res_value = remainder / 120; 578 if (low_res_value == 0) 579 low_res_value = (hi_res_value > 0 ? 1 : -1); 580 input_report_rel(input_dev, REL_WHEEL, low_res_value); 581 remainder -= low_res_value * 120; 582 } 583 counter->remainder = remainder; 584 } 585 586 /* -------------------------------------------------------------------------- */ 587 /* HIDP++ 1.0 commands */ 588 /* -------------------------------------------------------------------------- */ 589 590 #define HIDPP_SET_REGISTER 0x80 591 #define HIDPP_GET_REGISTER 0x81 592 #define HIDPP_SET_LONG_REGISTER 0x82 593 #define HIDPP_GET_LONG_REGISTER 0x83 594 595 /** 596 * hidpp10_set_register - Modify a HID++ 1.0 register. 597 * @hidpp_dev: the device to set the register on. 598 * @register_address: the address of the register to modify. 599 * @byte: the byte of the register to modify. Should be less than 3. 600 * @mask: mask of the bits to modify 601 * @value: new values for the bits in mask 602 * Return: 0 if successful, otherwise a negative error code. 603 */ 604 static int hidpp10_set_register(struct hidpp_device *hidpp_dev, 605 u8 register_address, u8 byte, u8 mask, u8 value) 606 { 607 struct hidpp_report response; 608 int ret; 609 u8 params[3] = { 0 }; 610 611 ret = hidpp_send_rap_command_sync(hidpp_dev, 612 REPORT_ID_HIDPP_SHORT, 613 HIDPP_GET_REGISTER, 614 register_address, 615 NULL, 0, &response); 616 if (ret) 617 return ret; 618 619 memcpy(params, response.rap.params, 3); 620 621 params[byte] &= ~mask; 622 params[byte] |= value & mask; 623 624 return hidpp_send_rap_command_sync(hidpp_dev, 625 REPORT_ID_HIDPP_SHORT, 626 HIDPP_SET_REGISTER, 627 register_address, 628 params, 3, &response); 629 } 630 631 #define HIDPP_REG_ENABLE_REPORTS 0x00 632 #define HIDPP_ENABLE_CONSUMER_REPORT BIT(0) 633 #define HIDPP_ENABLE_WHEEL_REPORT BIT(2) 634 #define HIDPP_ENABLE_MOUSE_EXTRA_BTN_REPORT BIT(3) 635 #define HIDPP_ENABLE_BAT_REPORT BIT(4) 636 #define HIDPP_ENABLE_HWHEEL_REPORT BIT(5) 637 638 static int hidpp10_enable_battery_reporting(struct hidpp_device *hidpp_dev) 639 { 640 return hidpp10_set_register(hidpp_dev, HIDPP_REG_ENABLE_REPORTS, 0, 641 HIDPP_ENABLE_BAT_REPORT, HIDPP_ENABLE_BAT_REPORT); 642 } 643 644 #define HIDPP_REG_FEATURES 0x01 645 #define HIDPP_ENABLE_SPECIAL_BUTTON_FUNC BIT(1) 646 #define HIDPP_ENABLE_FAST_SCROLL BIT(6) 647 648 /* On HID++ 1.0 devices, high-res scroll was called "scrolling acceleration". */ 649 static int hidpp10_enable_scrolling_acceleration(struct hidpp_device *hidpp_dev) 650 { 651 return hidpp10_set_register(hidpp_dev, HIDPP_REG_FEATURES, 0, 652 HIDPP_ENABLE_FAST_SCROLL, HIDPP_ENABLE_FAST_SCROLL); 653 } 654 655 #define HIDPP_REG_BATTERY_STATUS 0x07 656 657 static int hidpp10_battery_status_map_level(u8 param) 658 { 659 int level; 660 661 switch (param) { 662 case 1 ... 2: 663 level = POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL; 664 break; 665 case 3 ... 4: 666 level = POWER_SUPPLY_CAPACITY_LEVEL_LOW; 667 break; 668 case 5 ... 6: 669 level = POWER_SUPPLY_CAPACITY_LEVEL_NORMAL; 670 break; 671 case 7: 672 level = POWER_SUPPLY_CAPACITY_LEVEL_HIGH; 673 break; 674 default: 675 level = POWER_SUPPLY_CAPACITY_LEVEL_UNKNOWN; 676 } 677 678 return level; 679 } 680 681 static int hidpp10_battery_status_map_status(u8 param) 682 { 683 int status; 684 685 switch (param) { 686 case 0x00: 687 /* discharging (in use) */ 688 status = POWER_SUPPLY_STATUS_DISCHARGING; 689 break; 690 case 0x21: /* (standard) charging */ 691 case 0x24: /* fast charging */ 692 case 0x25: /* slow charging */ 693 status = POWER_SUPPLY_STATUS_CHARGING; 694 break; 695 case 0x26: /* topping charge */ 696 case 0x22: /* charge complete */ 697 status = POWER_SUPPLY_STATUS_FULL; 698 break; 699 case 0x20: /* unknown */ 700 status = POWER_SUPPLY_STATUS_UNKNOWN; 701 break; 702 /* 703 * 0x01...0x1F = reserved (not charging) 704 * 0x23 = charging error 705 * 0x27..0xff = reserved 706 */ 707 default: 708 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 709 break; 710 } 711 712 return status; 713 } 714 715 static int hidpp10_query_battery_status(struct hidpp_device *hidpp) 716 { 717 struct hidpp_report response; 718 int ret, status; 719 720 ret = hidpp_send_rap_command_sync(hidpp, 721 REPORT_ID_HIDPP_SHORT, 722 HIDPP_GET_REGISTER, 723 HIDPP_REG_BATTERY_STATUS, 724 NULL, 0, &response); 725 if (ret) 726 return ret; 727 728 hidpp->battery.level = 729 hidpp10_battery_status_map_level(response.rap.params[0]); 730 status = hidpp10_battery_status_map_status(response.rap.params[1]); 731 hidpp->battery.status = status; 732 /* the capacity is only available when discharging or full */ 733 hidpp->battery.online = status == POWER_SUPPLY_STATUS_DISCHARGING || 734 status == POWER_SUPPLY_STATUS_FULL; 735 736 return 0; 737 } 738 739 #define HIDPP_REG_BATTERY_MILEAGE 0x0D 740 741 static int hidpp10_battery_mileage_map_status(u8 param) 742 { 743 int status; 744 745 switch (param >> 6) { 746 case 0x00: 747 /* discharging (in use) */ 748 status = POWER_SUPPLY_STATUS_DISCHARGING; 749 break; 750 case 0x01: /* charging */ 751 status = POWER_SUPPLY_STATUS_CHARGING; 752 break; 753 case 0x02: /* charge complete */ 754 status = POWER_SUPPLY_STATUS_FULL; 755 break; 756 /* 757 * 0x03 = charging error 758 */ 759 default: 760 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 761 break; 762 } 763 764 return status; 765 } 766 767 static int hidpp10_query_battery_mileage(struct hidpp_device *hidpp) 768 { 769 struct hidpp_report response; 770 int ret, status; 771 772 ret = hidpp_send_rap_command_sync(hidpp, 773 REPORT_ID_HIDPP_SHORT, 774 HIDPP_GET_REGISTER, 775 HIDPP_REG_BATTERY_MILEAGE, 776 NULL, 0, &response); 777 if (ret) 778 return ret; 779 780 hidpp->battery.capacity = response.rap.params[0]; 781 status = hidpp10_battery_mileage_map_status(response.rap.params[2]); 782 hidpp->battery.status = status; 783 /* the capacity is only available when discharging or full */ 784 hidpp->battery.online = status == POWER_SUPPLY_STATUS_DISCHARGING || 785 status == POWER_SUPPLY_STATUS_FULL; 786 787 return 0; 788 } 789 790 static int hidpp10_battery_event(struct hidpp_device *hidpp, u8 *data, int size) 791 { 792 struct hidpp_report *report = (struct hidpp_report *)data; 793 int status, capacity, level; 794 bool changed; 795 796 if (report->report_id != REPORT_ID_HIDPP_SHORT) 797 return 0; 798 799 switch (report->rap.sub_id) { 800 case HIDPP_REG_BATTERY_STATUS: 801 capacity = hidpp->battery.capacity; 802 level = hidpp10_battery_status_map_level(report->rawbytes[1]); 803 status = hidpp10_battery_status_map_status(report->rawbytes[2]); 804 break; 805 case HIDPP_REG_BATTERY_MILEAGE: 806 capacity = report->rap.params[0]; 807 level = hidpp->battery.level; 808 status = hidpp10_battery_mileage_map_status(report->rawbytes[3]); 809 break; 810 default: 811 return 0; 812 } 813 814 changed = capacity != hidpp->battery.capacity || 815 level != hidpp->battery.level || 816 status != hidpp->battery.status; 817 818 /* the capacity is only available when discharging or full */ 819 hidpp->battery.online = status == POWER_SUPPLY_STATUS_DISCHARGING || 820 status == POWER_SUPPLY_STATUS_FULL; 821 822 if (changed) { 823 hidpp->battery.level = level; 824 hidpp->battery.status = status; 825 if (hidpp->battery.ps) 826 power_supply_changed(hidpp->battery.ps); 827 } 828 829 return 0; 830 } 831 832 #define HIDPP_REG_PAIRING_INFORMATION 0xB5 833 #define HIDPP_EXTENDED_PAIRING 0x30 834 #define HIDPP_DEVICE_NAME 0x40 835 836 static char *hidpp_unifying_get_name(struct hidpp_device *hidpp_dev) 837 { 838 struct hidpp_report response; 839 int ret; 840 u8 params[1] = { HIDPP_DEVICE_NAME }; 841 char *name; 842 int len; 843 844 ret = hidpp_send_rap_command_sync(hidpp_dev, 845 REPORT_ID_HIDPP_SHORT, 846 HIDPP_GET_LONG_REGISTER, 847 HIDPP_REG_PAIRING_INFORMATION, 848 params, 1, &response); 849 if (ret) 850 return NULL; 851 852 len = response.rap.params[1]; 853 854 if (2 + len > sizeof(response.rap.params)) 855 return NULL; 856 857 if (len < 4) /* logitech devices are usually at least Xddd */ 858 return NULL; 859 860 name = kzalloc(len + 1, GFP_KERNEL); 861 if (!name) 862 return NULL; 863 864 memcpy(name, &response.rap.params[2], len); 865 866 /* include the terminating '\0' */ 867 hidpp_prefix_name(&name, len + 1); 868 869 return name; 870 } 871 872 static int hidpp_unifying_get_serial(struct hidpp_device *hidpp, u32 *serial) 873 { 874 struct hidpp_report response; 875 int ret; 876 u8 params[1] = { HIDPP_EXTENDED_PAIRING }; 877 878 ret = hidpp_send_rap_command_sync(hidpp, 879 REPORT_ID_HIDPP_SHORT, 880 HIDPP_GET_LONG_REGISTER, 881 HIDPP_REG_PAIRING_INFORMATION, 882 params, 1, &response); 883 if (ret) 884 return ret; 885 886 /* 887 * We don't care about LE or BE, we will output it as a string 888 * with %4phD, so we need to keep the order. 889 */ 890 *serial = *((u32 *)&response.rap.params[1]); 891 return 0; 892 } 893 894 static int hidpp_unifying_init(struct hidpp_device *hidpp) 895 { 896 struct hid_device *hdev = hidpp->hid_dev; 897 const char *name; 898 u32 serial; 899 int ret; 900 901 ret = hidpp_unifying_get_serial(hidpp, &serial); 902 if (ret) 903 return ret; 904 905 snprintf(hdev->uniq, sizeof(hdev->uniq), "%4phD", &serial); 906 dbg_hid("HID++ Unifying: Got serial: %s\n", hdev->uniq); 907 908 name = hidpp_unifying_get_name(hidpp); 909 if (!name) 910 return -EIO; 911 912 snprintf(hdev->name, sizeof(hdev->name), "%s", name); 913 dbg_hid("HID++ Unifying: Got name: %s\n", name); 914 915 kfree(name); 916 return 0; 917 } 918 919 /* -------------------------------------------------------------------------- */ 920 /* 0x0000: Root */ 921 /* -------------------------------------------------------------------------- */ 922 923 #define HIDPP_PAGE_ROOT 0x0000 924 #define HIDPP_PAGE_ROOT_IDX 0x00 925 926 #define CMD_ROOT_GET_FEATURE 0x00 927 #define CMD_ROOT_GET_PROTOCOL_VERSION 0x10 928 929 static int hidpp_root_get_feature(struct hidpp_device *hidpp, u16 feature, 930 u8 *feature_index, u8 *feature_type) 931 { 932 struct hidpp_report response; 933 int ret; 934 u8 params[2] = { feature >> 8, feature & 0x00FF }; 935 936 ret = hidpp_send_fap_command_sync(hidpp, 937 HIDPP_PAGE_ROOT_IDX, 938 CMD_ROOT_GET_FEATURE, 939 params, 2, &response); 940 if (ret) 941 return ret; 942 943 if (response.fap.params[0] == 0) 944 return -ENOENT; 945 946 *feature_index = response.fap.params[0]; 947 *feature_type = response.fap.params[1]; 948 949 return ret; 950 } 951 952 static int hidpp_root_get_protocol_version(struct hidpp_device *hidpp) 953 { 954 const u8 ping_byte = 0x5a; 955 u8 ping_data[3] = { 0, 0, ping_byte }; 956 struct hidpp_report response; 957 int ret; 958 959 ret = hidpp_send_rap_command_sync(hidpp, 960 REPORT_ID_HIDPP_SHORT, 961 HIDPP_PAGE_ROOT_IDX, 962 CMD_ROOT_GET_PROTOCOL_VERSION | LINUX_KERNEL_SW_ID, 963 ping_data, sizeof(ping_data), &response); 964 965 if (ret == HIDPP_ERROR_INVALID_SUBID) { 966 hidpp->protocol_major = 1; 967 hidpp->protocol_minor = 0; 968 goto print_version; 969 } 970 971 /* the device might not be connected */ 972 if (ret == HIDPP_ERROR_RESOURCE_ERROR) 973 return -EIO; 974 975 if (ret > 0) { 976 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 977 __func__, ret); 978 return -EPROTO; 979 } 980 if (ret) 981 return ret; 982 983 if (response.rap.params[2] != ping_byte) { 984 hid_err(hidpp->hid_dev, "%s: ping mismatch 0x%02x != 0x%02x\n", 985 __func__, response.rap.params[2], ping_byte); 986 return -EPROTO; 987 } 988 989 hidpp->protocol_major = response.rap.params[0]; 990 hidpp->protocol_minor = response.rap.params[1]; 991 992 print_version: 993 if (!hidpp->connected_once) { 994 hid_info(hidpp->hid_dev, "HID++ %u.%u device connected.\n", 995 hidpp->protocol_major, hidpp->protocol_minor); 996 hidpp->connected_once = true; 997 } else 998 hid_dbg(hidpp->hid_dev, "HID++ %u.%u device connected.\n", 999 hidpp->protocol_major, hidpp->protocol_minor); 1000 return 0; 1001 } 1002 1003 /* -------------------------------------------------------------------------- */ 1004 /* 0x0003: Device Information */ 1005 /* -------------------------------------------------------------------------- */ 1006 1007 #define HIDPP_PAGE_DEVICE_INFORMATION 0x0003 1008 1009 #define CMD_GET_DEVICE_INFO 0x00 1010 1011 static int hidpp_get_serial(struct hidpp_device *hidpp, u32 *serial) 1012 { 1013 struct hidpp_report response; 1014 u8 feature_type; 1015 u8 feature_index; 1016 int ret; 1017 1018 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_DEVICE_INFORMATION, 1019 &feature_index, 1020 &feature_type); 1021 if (ret) 1022 return ret; 1023 1024 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1025 CMD_GET_DEVICE_INFO, 1026 NULL, 0, &response); 1027 if (ret) 1028 return ret; 1029 1030 /* See hidpp_unifying_get_serial() */ 1031 *serial = *((u32 *)&response.rap.params[1]); 1032 return 0; 1033 } 1034 1035 static int hidpp_serial_init(struct hidpp_device *hidpp) 1036 { 1037 struct hid_device *hdev = hidpp->hid_dev; 1038 u32 serial; 1039 int ret; 1040 1041 ret = hidpp_get_serial(hidpp, &serial); 1042 if (ret) 1043 return ret; 1044 1045 snprintf(hdev->uniq, sizeof(hdev->uniq), "%4phD", &serial); 1046 dbg_hid("HID++ DeviceInformation: Got serial: %s\n", hdev->uniq); 1047 1048 return 0; 1049 } 1050 1051 /* -------------------------------------------------------------------------- */ 1052 /* 0x0005: GetDeviceNameType */ 1053 /* -------------------------------------------------------------------------- */ 1054 1055 #define HIDPP_PAGE_GET_DEVICE_NAME_TYPE 0x0005 1056 1057 #define CMD_GET_DEVICE_NAME_TYPE_GET_COUNT 0x00 1058 #define CMD_GET_DEVICE_NAME_TYPE_GET_DEVICE_NAME 0x10 1059 #define CMD_GET_DEVICE_NAME_TYPE_GET_TYPE 0x20 1060 1061 static int hidpp_devicenametype_get_count(struct hidpp_device *hidpp, 1062 u8 feature_index, u8 *nameLength) 1063 { 1064 struct hidpp_report response; 1065 int ret; 1066 1067 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1068 CMD_GET_DEVICE_NAME_TYPE_GET_COUNT, NULL, 0, &response); 1069 1070 if (ret > 0) { 1071 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1072 __func__, ret); 1073 return -EPROTO; 1074 } 1075 if (ret) 1076 return ret; 1077 1078 *nameLength = response.fap.params[0]; 1079 1080 return ret; 1081 } 1082 1083 static int hidpp_devicenametype_get_device_name(struct hidpp_device *hidpp, 1084 u8 feature_index, u8 char_index, char *device_name, int len_buf) 1085 { 1086 struct hidpp_report response; 1087 int ret, i; 1088 int count; 1089 1090 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1091 CMD_GET_DEVICE_NAME_TYPE_GET_DEVICE_NAME, &char_index, 1, 1092 &response); 1093 1094 if (ret > 0) { 1095 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1096 __func__, ret); 1097 return -EPROTO; 1098 } 1099 if (ret) 1100 return ret; 1101 1102 switch (response.report_id) { 1103 case REPORT_ID_HIDPP_VERY_LONG: 1104 count = hidpp->very_long_report_length - 4; 1105 break; 1106 case REPORT_ID_HIDPP_LONG: 1107 count = HIDPP_REPORT_LONG_LENGTH - 4; 1108 break; 1109 case REPORT_ID_HIDPP_SHORT: 1110 count = HIDPP_REPORT_SHORT_LENGTH - 4; 1111 break; 1112 default: 1113 return -EPROTO; 1114 } 1115 1116 if (len_buf < count) 1117 count = len_buf; 1118 1119 for (i = 0; i < count; i++) 1120 device_name[i] = response.fap.params[i]; 1121 1122 return count; 1123 } 1124 1125 static char *hidpp_get_device_name(struct hidpp_device *hidpp) 1126 { 1127 u8 feature_type; 1128 u8 feature_index; 1129 u8 __name_length; 1130 char *name; 1131 unsigned index = 0; 1132 int ret; 1133 1134 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_GET_DEVICE_NAME_TYPE, 1135 &feature_index, &feature_type); 1136 if (ret) 1137 return NULL; 1138 1139 ret = hidpp_devicenametype_get_count(hidpp, feature_index, 1140 &__name_length); 1141 if (ret) 1142 return NULL; 1143 1144 name = kzalloc(__name_length + 1, GFP_KERNEL); 1145 if (!name) 1146 return NULL; 1147 1148 while (index < __name_length) { 1149 ret = hidpp_devicenametype_get_device_name(hidpp, 1150 feature_index, index, name + index, 1151 __name_length - index); 1152 if (ret <= 0) { 1153 kfree(name); 1154 return NULL; 1155 } 1156 index += ret; 1157 } 1158 1159 /* include the terminating '\0' */ 1160 hidpp_prefix_name(&name, __name_length + 1); 1161 1162 return name; 1163 } 1164 1165 /* -------------------------------------------------------------------------- */ 1166 /* 0x1000: Battery level status */ 1167 /* -------------------------------------------------------------------------- */ 1168 1169 #define HIDPP_PAGE_BATTERY_LEVEL_STATUS 0x1000 1170 1171 #define CMD_BATTERY_LEVEL_STATUS_GET_BATTERY_LEVEL_STATUS 0x00 1172 #define CMD_BATTERY_LEVEL_STATUS_GET_BATTERY_CAPABILITY 0x10 1173 1174 #define EVENT_BATTERY_LEVEL_STATUS_BROADCAST 0x00 1175 1176 #define FLAG_BATTERY_LEVEL_DISABLE_OSD BIT(0) 1177 #define FLAG_BATTERY_LEVEL_MILEAGE BIT(1) 1178 #define FLAG_BATTERY_LEVEL_RECHARGEABLE BIT(2) 1179 1180 static int hidpp_map_battery_level(int capacity) 1181 { 1182 if (capacity < 11) 1183 return POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL; 1184 /* 1185 * The spec says this should be < 31 but some devices report 30 1186 * with brand new batteries and Windows reports 30 as "Good". 1187 */ 1188 else if (capacity < 30) 1189 return POWER_SUPPLY_CAPACITY_LEVEL_LOW; 1190 else if (capacity < 81) 1191 return POWER_SUPPLY_CAPACITY_LEVEL_NORMAL; 1192 return POWER_SUPPLY_CAPACITY_LEVEL_FULL; 1193 } 1194 1195 static int hidpp20_batterylevel_map_status_capacity(u8 data[3], int *capacity, 1196 int *next_capacity, 1197 int *level) 1198 { 1199 int status; 1200 1201 *capacity = data[0]; 1202 *next_capacity = data[1]; 1203 *level = POWER_SUPPLY_CAPACITY_LEVEL_UNKNOWN; 1204 1205 /* When discharging, we can rely on the device reported capacity. 1206 * For all other states the device reports 0 (unknown). 1207 */ 1208 switch (data[2]) { 1209 case 0: /* discharging (in use) */ 1210 status = POWER_SUPPLY_STATUS_DISCHARGING; 1211 *level = hidpp_map_battery_level(*capacity); 1212 break; 1213 case 1: /* recharging */ 1214 status = POWER_SUPPLY_STATUS_CHARGING; 1215 break; 1216 case 2: /* charge in final stage */ 1217 status = POWER_SUPPLY_STATUS_CHARGING; 1218 break; 1219 case 3: /* charge complete */ 1220 status = POWER_SUPPLY_STATUS_FULL; 1221 *level = POWER_SUPPLY_CAPACITY_LEVEL_FULL; 1222 *capacity = 100; 1223 break; 1224 case 4: /* recharging below optimal speed */ 1225 status = POWER_SUPPLY_STATUS_CHARGING; 1226 break; 1227 /* 5 = invalid battery type 1228 6 = thermal error 1229 7 = other charging error */ 1230 default: 1231 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 1232 break; 1233 } 1234 1235 return status; 1236 } 1237 1238 static int hidpp20_batterylevel_get_battery_capacity(struct hidpp_device *hidpp, 1239 u8 feature_index, 1240 int *status, 1241 int *capacity, 1242 int *next_capacity, 1243 int *level) 1244 { 1245 struct hidpp_report response; 1246 int ret; 1247 u8 *params = (u8 *)response.fap.params; 1248 1249 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1250 CMD_BATTERY_LEVEL_STATUS_GET_BATTERY_LEVEL_STATUS, 1251 NULL, 0, &response); 1252 /* Ignore these intermittent errors */ 1253 if (ret == HIDPP_ERROR_RESOURCE_ERROR) 1254 return -EIO; 1255 if (ret > 0) { 1256 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1257 __func__, ret); 1258 return -EPROTO; 1259 } 1260 if (ret) 1261 return ret; 1262 1263 *status = hidpp20_batterylevel_map_status_capacity(params, capacity, 1264 next_capacity, 1265 level); 1266 1267 return 0; 1268 } 1269 1270 static int hidpp20_batterylevel_get_battery_info(struct hidpp_device *hidpp, 1271 u8 feature_index) 1272 { 1273 struct hidpp_report response; 1274 int ret; 1275 u8 *params = (u8 *)response.fap.params; 1276 unsigned int level_count, flags; 1277 1278 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1279 CMD_BATTERY_LEVEL_STATUS_GET_BATTERY_CAPABILITY, 1280 NULL, 0, &response); 1281 if (ret > 0) { 1282 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1283 __func__, ret); 1284 return -EPROTO; 1285 } 1286 if (ret) 1287 return ret; 1288 1289 level_count = params[0]; 1290 flags = params[1]; 1291 1292 if (level_count < 10 || !(flags & FLAG_BATTERY_LEVEL_MILEAGE)) 1293 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS; 1294 else 1295 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_MILEAGE; 1296 1297 return 0; 1298 } 1299 1300 static int hidpp20_query_battery_info_1000(struct hidpp_device *hidpp) 1301 { 1302 u8 feature_type; 1303 int ret; 1304 int status, capacity, next_capacity, level; 1305 1306 if (hidpp->battery.feature_index == 0xff) { 1307 ret = hidpp_root_get_feature(hidpp, 1308 HIDPP_PAGE_BATTERY_LEVEL_STATUS, 1309 &hidpp->battery.feature_index, 1310 &feature_type); 1311 if (ret) 1312 return ret; 1313 } 1314 1315 ret = hidpp20_batterylevel_get_battery_capacity(hidpp, 1316 hidpp->battery.feature_index, 1317 &status, &capacity, 1318 &next_capacity, &level); 1319 if (ret) 1320 return ret; 1321 1322 ret = hidpp20_batterylevel_get_battery_info(hidpp, 1323 hidpp->battery.feature_index); 1324 if (ret) 1325 return ret; 1326 1327 hidpp->battery.status = status; 1328 hidpp->battery.capacity = capacity; 1329 hidpp->battery.level = level; 1330 /* the capacity is only available when discharging or full */ 1331 hidpp->battery.online = status == POWER_SUPPLY_STATUS_DISCHARGING || 1332 status == POWER_SUPPLY_STATUS_FULL; 1333 1334 return 0; 1335 } 1336 1337 static int hidpp20_battery_event_1000(struct hidpp_device *hidpp, 1338 u8 *data, int size) 1339 { 1340 struct hidpp_report *report = (struct hidpp_report *)data; 1341 int status, capacity, next_capacity, level; 1342 bool changed; 1343 1344 if (report->fap.feature_index != hidpp->battery.feature_index || 1345 report->fap.funcindex_clientid != EVENT_BATTERY_LEVEL_STATUS_BROADCAST) 1346 return 0; 1347 1348 status = hidpp20_batterylevel_map_status_capacity(report->fap.params, 1349 &capacity, 1350 &next_capacity, 1351 &level); 1352 1353 /* the capacity is only available when discharging or full */ 1354 hidpp->battery.online = status == POWER_SUPPLY_STATUS_DISCHARGING || 1355 status == POWER_SUPPLY_STATUS_FULL; 1356 1357 changed = capacity != hidpp->battery.capacity || 1358 level != hidpp->battery.level || 1359 status != hidpp->battery.status; 1360 1361 if (changed) { 1362 hidpp->battery.level = level; 1363 hidpp->battery.capacity = capacity; 1364 hidpp->battery.status = status; 1365 if (hidpp->battery.ps) 1366 power_supply_changed(hidpp->battery.ps); 1367 } 1368 1369 return 0; 1370 } 1371 1372 /* -------------------------------------------------------------------------- */ 1373 /* 0x1001: Battery voltage */ 1374 /* -------------------------------------------------------------------------- */ 1375 1376 #define HIDPP_PAGE_BATTERY_VOLTAGE 0x1001 1377 1378 #define CMD_BATTERY_VOLTAGE_GET_BATTERY_VOLTAGE 0x00 1379 1380 #define EVENT_BATTERY_VOLTAGE_STATUS_BROADCAST 0x00 1381 1382 static int hidpp20_battery_map_status_voltage(u8 data[3], int *voltage, 1383 int *level, int *charge_type) 1384 { 1385 int status; 1386 1387 long flags = (long) data[2]; 1388 *level = POWER_SUPPLY_CAPACITY_LEVEL_UNKNOWN; 1389 1390 if (flags & 0x80) 1391 switch (flags & 0x07) { 1392 case 0: 1393 status = POWER_SUPPLY_STATUS_CHARGING; 1394 break; 1395 case 1: 1396 status = POWER_SUPPLY_STATUS_FULL; 1397 *level = POWER_SUPPLY_CAPACITY_LEVEL_FULL; 1398 break; 1399 case 2: 1400 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 1401 break; 1402 default: 1403 status = POWER_SUPPLY_STATUS_UNKNOWN; 1404 break; 1405 } 1406 else 1407 status = POWER_SUPPLY_STATUS_DISCHARGING; 1408 1409 *charge_type = POWER_SUPPLY_CHARGE_TYPE_STANDARD; 1410 if (test_bit(3, &flags)) { 1411 *charge_type = POWER_SUPPLY_CHARGE_TYPE_FAST; 1412 } 1413 if (test_bit(4, &flags)) { 1414 *charge_type = POWER_SUPPLY_CHARGE_TYPE_TRICKLE; 1415 } 1416 if (test_bit(5, &flags)) { 1417 *level = POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL; 1418 } 1419 1420 *voltage = get_unaligned_be16(data); 1421 1422 return status; 1423 } 1424 1425 static int hidpp20_battery_get_battery_voltage(struct hidpp_device *hidpp, 1426 u8 feature_index, 1427 int *status, int *voltage, 1428 int *level, int *charge_type) 1429 { 1430 struct hidpp_report response; 1431 int ret; 1432 u8 *params = (u8 *)response.fap.params; 1433 1434 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1435 CMD_BATTERY_VOLTAGE_GET_BATTERY_VOLTAGE, 1436 NULL, 0, &response); 1437 1438 if (ret > 0) { 1439 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1440 __func__, ret); 1441 return -EPROTO; 1442 } 1443 if (ret) 1444 return ret; 1445 1446 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_VOLTAGE; 1447 1448 *status = hidpp20_battery_map_status_voltage(params, voltage, 1449 level, charge_type); 1450 1451 return 0; 1452 } 1453 1454 static int hidpp20_map_battery_capacity(struct hid_device *hid_dev, int voltage) 1455 { 1456 /* NB: This voltage curve doesn't necessarily map perfectly to all 1457 * devices that implement the BATTERY_VOLTAGE feature. This is because 1458 * there are a few devices that use different battery technology. 1459 */ 1460 1461 static const int voltages[100] = { 1462 4186, 4156, 4143, 4133, 4122, 4113, 4103, 4094, 4086, 4075, 1463 4067, 4059, 4051, 4043, 4035, 4027, 4019, 4011, 4003, 3997, 1464 3989, 3983, 3976, 3969, 3961, 3955, 3949, 3942, 3935, 3929, 1465 3922, 3916, 3909, 3902, 3896, 3890, 3883, 3877, 3870, 3865, 1466 3859, 3853, 3848, 3842, 3837, 3833, 3828, 3824, 3819, 3815, 1467 3811, 3808, 3804, 3800, 3797, 3793, 3790, 3787, 3784, 3781, 1468 3778, 3775, 3772, 3770, 3767, 3764, 3762, 3759, 3757, 3754, 1469 3751, 3748, 3744, 3741, 3737, 3734, 3730, 3726, 3724, 3720, 1470 3717, 3714, 3710, 3706, 3702, 3697, 3693, 3688, 3683, 3677, 1471 3671, 3666, 3662, 3658, 3654, 3646, 3633, 3612, 3579, 3537 1472 }; 1473 1474 int i; 1475 1476 if (unlikely(voltage < 3500 || voltage >= 5000)) 1477 hid_warn_once(hid_dev, 1478 "%s: possibly using the wrong voltage curve\n", 1479 __func__); 1480 1481 for (i = 0; i < ARRAY_SIZE(voltages); i++) { 1482 if (voltage >= voltages[i]) 1483 return ARRAY_SIZE(voltages) - i; 1484 } 1485 1486 return 0; 1487 } 1488 1489 static int hidpp20_query_battery_voltage_info(struct hidpp_device *hidpp) 1490 { 1491 u8 feature_type; 1492 int ret; 1493 int status, voltage, level, charge_type; 1494 1495 if (hidpp->battery.voltage_feature_index == 0xff) { 1496 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_BATTERY_VOLTAGE, 1497 &hidpp->battery.voltage_feature_index, 1498 &feature_type); 1499 if (ret) 1500 return ret; 1501 } 1502 1503 ret = hidpp20_battery_get_battery_voltage(hidpp, 1504 hidpp->battery.voltage_feature_index, 1505 &status, &voltage, &level, &charge_type); 1506 1507 if (ret) 1508 return ret; 1509 1510 hidpp->battery.status = status; 1511 hidpp->battery.voltage = voltage; 1512 hidpp->battery.capacity = hidpp20_map_battery_capacity(hidpp->hid_dev, 1513 voltage); 1514 hidpp->battery.level = level; 1515 hidpp->battery.charge_type = charge_type; 1516 hidpp->battery.online = status != POWER_SUPPLY_STATUS_NOT_CHARGING; 1517 1518 return 0; 1519 } 1520 1521 static int hidpp20_battery_voltage_event(struct hidpp_device *hidpp, 1522 u8 *data, int size) 1523 { 1524 struct hidpp_report *report = (struct hidpp_report *)data; 1525 int status, voltage, level, charge_type; 1526 1527 if (report->fap.feature_index != hidpp->battery.voltage_feature_index || 1528 report->fap.funcindex_clientid != EVENT_BATTERY_VOLTAGE_STATUS_BROADCAST) 1529 return 0; 1530 1531 status = hidpp20_battery_map_status_voltage(report->fap.params, &voltage, 1532 &level, &charge_type); 1533 1534 hidpp->battery.online = status != POWER_SUPPLY_STATUS_NOT_CHARGING; 1535 1536 if (voltage != hidpp->battery.voltage || status != hidpp->battery.status) { 1537 hidpp->battery.voltage = voltage; 1538 hidpp->battery.capacity = hidpp20_map_battery_capacity(hidpp->hid_dev, 1539 voltage); 1540 hidpp->battery.status = status; 1541 hidpp->battery.level = level; 1542 hidpp->battery.charge_type = charge_type; 1543 if (hidpp->battery.ps) 1544 power_supply_changed(hidpp->battery.ps); 1545 } 1546 return 0; 1547 } 1548 1549 /* -------------------------------------------------------------------------- */ 1550 /* 0x1004: Unified battery */ 1551 /* -------------------------------------------------------------------------- */ 1552 1553 #define HIDPP_PAGE_UNIFIED_BATTERY 0x1004 1554 1555 #define CMD_UNIFIED_BATTERY_GET_CAPABILITIES 0x00 1556 #define CMD_UNIFIED_BATTERY_GET_STATUS 0x10 1557 1558 #define EVENT_UNIFIED_BATTERY_STATUS_EVENT 0x00 1559 1560 #define FLAG_UNIFIED_BATTERY_LEVEL_CRITICAL BIT(0) 1561 #define FLAG_UNIFIED_BATTERY_LEVEL_LOW BIT(1) 1562 #define FLAG_UNIFIED_BATTERY_LEVEL_GOOD BIT(2) 1563 #define FLAG_UNIFIED_BATTERY_LEVEL_FULL BIT(3) 1564 1565 #define FLAG_UNIFIED_BATTERY_FLAGS_RECHARGEABLE BIT(0) 1566 #define FLAG_UNIFIED_BATTERY_FLAGS_STATE_OF_CHARGE BIT(1) 1567 1568 static int hidpp20_unifiedbattery_get_capabilities(struct hidpp_device *hidpp, 1569 u8 feature_index) 1570 { 1571 struct hidpp_report response; 1572 int ret; 1573 u8 *params = (u8 *)response.fap.params; 1574 1575 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS || 1576 hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_PERCENTAGE) { 1577 /* we have already set the device capabilities, so let's skip */ 1578 return 0; 1579 } 1580 1581 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1582 CMD_UNIFIED_BATTERY_GET_CAPABILITIES, 1583 NULL, 0, &response); 1584 /* Ignore these intermittent errors */ 1585 if (ret == HIDPP_ERROR_RESOURCE_ERROR) 1586 return -EIO; 1587 if (ret > 0) { 1588 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1589 __func__, ret); 1590 return -EPROTO; 1591 } 1592 if (ret) 1593 return ret; 1594 1595 /* 1596 * If the device supports state of charge (battery percentage) we won't 1597 * export the battery level information. there are 4 possible battery 1598 * levels and they all are optional, this means that the device might 1599 * not support any of them, we are just better off with the battery 1600 * percentage. 1601 */ 1602 if (params[1] & FLAG_UNIFIED_BATTERY_FLAGS_STATE_OF_CHARGE) { 1603 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_PERCENTAGE; 1604 hidpp->battery.supported_levels_1004 = 0; 1605 } else { 1606 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS; 1607 hidpp->battery.supported_levels_1004 = params[0]; 1608 } 1609 1610 return 0; 1611 } 1612 1613 static int hidpp20_unifiedbattery_map_status(struct hidpp_device *hidpp, 1614 u8 charging_status, 1615 u8 external_power_status) 1616 { 1617 int status; 1618 1619 switch (charging_status) { 1620 case 0: /* discharging */ 1621 status = POWER_SUPPLY_STATUS_DISCHARGING; 1622 break; 1623 case 1: /* charging */ 1624 case 2: /* charging slow */ 1625 status = POWER_SUPPLY_STATUS_CHARGING; 1626 break; 1627 case 3: /* complete */ 1628 status = POWER_SUPPLY_STATUS_FULL; 1629 break; 1630 case 4: /* error */ 1631 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 1632 hid_info(hidpp->hid_dev, "%s: charging error", 1633 hidpp->name); 1634 break; 1635 default: 1636 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 1637 break; 1638 } 1639 1640 return status; 1641 } 1642 1643 static int hidpp20_unifiedbattery_map_level(struct hidpp_device *hidpp, 1644 u8 battery_level) 1645 { 1646 /* cler unsupported level bits */ 1647 battery_level &= hidpp->battery.supported_levels_1004; 1648 1649 if (battery_level & FLAG_UNIFIED_BATTERY_LEVEL_FULL) 1650 return POWER_SUPPLY_CAPACITY_LEVEL_FULL; 1651 else if (battery_level & FLAG_UNIFIED_BATTERY_LEVEL_GOOD) 1652 return POWER_SUPPLY_CAPACITY_LEVEL_NORMAL; 1653 else if (battery_level & FLAG_UNIFIED_BATTERY_LEVEL_LOW) 1654 return POWER_SUPPLY_CAPACITY_LEVEL_LOW; 1655 else if (battery_level & FLAG_UNIFIED_BATTERY_LEVEL_CRITICAL) 1656 return POWER_SUPPLY_CAPACITY_LEVEL_CRITICAL; 1657 1658 return POWER_SUPPLY_CAPACITY_LEVEL_UNKNOWN; 1659 } 1660 1661 static int hidpp20_unifiedbattery_get_status(struct hidpp_device *hidpp, 1662 u8 feature_index, 1663 u8 *state_of_charge, 1664 int *status, 1665 int *level) 1666 { 1667 struct hidpp_report response; 1668 int ret; 1669 u8 *params = (u8 *)response.fap.params; 1670 1671 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1672 CMD_UNIFIED_BATTERY_GET_STATUS, 1673 NULL, 0, &response); 1674 /* Ignore these intermittent errors */ 1675 if (ret == HIDPP_ERROR_RESOURCE_ERROR) 1676 return -EIO; 1677 if (ret > 0) { 1678 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1679 __func__, ret); 1680 return -EPROTO; 1681 } 1682 if (ret) 1683 return ret; 1684 1685 *state_of_charge = params[0]; 1686 *status = hidpp20_unifiedbattery_map_status(hidpp, params[2], params[3]); 1687 *level = hidpp20_unifiedbattery_map_level(hidpp, params[1]); 1688 1689 return 0; 1690 } 1691 1692 static int hidpp20_query_battery_info_1004(struct hidpp_device *hidpp) 1693 { 1694 u8 feature_type; 1695 int ret; 1696 u8 state_of_charge; 1697 int status, level; 1698 1699 if (hidpp->battery.feature_index == 0xff) { 1700 ret = hidpp_root_get_feature(hidpp, 1701 HIDPP_PAGE_UNIFIED_BATTERY, 1702 &hidpp->battery.feature_index, 1703 &feature_type); 1704 if (ret) 1705 return ret; 1706 } 1707 1708 ret = hidpp20_unifiedbattery_get_capabilities(hidpp, 1709 hidpp->battery.feature_index); 1710 if (ret) 1711 return ret; 1712 1713 ret = hidpp20_unifiedbattery_get_status(hidpp, 1714 hidpp->battery.feature_index, 1715 &state_of_charge, 1716 &status, 1717 &level); 1718 if (ret) 1719 return ret; 1720 1721 hidpp->capabilities |= HIDPP_CAPABILITY_UNIFIED_BATTERY; 1722 hidpp->battery.capacity = state_of_charge; 1723 hidpp->battery.status = status; 1724 hidpp->battery.level = level; 1725 hidpp->battery.online = true; 1726 1727 return 0; 1728 } 1729 1730 static int hidpp20_battery_event_1004(struct hidpp_device *hidpp, 1731 u8 *data, int size) 1732 { 1733 struct hidpp_report *report = (struct hidpp_report *)data; 1734 u8 *params = (u8 *)report->fap.params; 1735 int state_of_charge, status, level; 1736 bool changed; 1737 1738 if (report->fap.feature_index != hidpp->battery.feature_index || 1739 report->fap.funcindex_clientid != EVENT_UNIFIED_BATTERY_STATUS_EVENT) 1740 return 0; 1741 1742 state_of_charge = params[0]; 1743 status = hidpp20_unifiedbattery_map_status(hidpp, params[2], params[3]); 1744 level = hidpp20_unifiedbattery_map_level(hidpp, params[1]); 1745 1746 changed = status != hidpp->battery.status || 1747 (state_of_charge != hidpp->battery.capacity && 1748 hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_PERCENTAGE) || 1749 (level != hidpp->battery.level && 1750 hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS); 1751 1752 if (changed) { 1753 hidpp->battery.capacity = state_of_charge; 1754 hidpp->battery.status = status; 1755 hidpp->battery.level = level; 1756 if (hidpp->battery.ps) 1757 power_supply_changed(hidpp->battery.ps); 1758 } 1759 1760 return 0; 1761 } 1762 1763 /* -------------------------------------------------------------------------- */ 1764 /* Battery feature helpers */ 1765 /* -------------------------------------------------------------------------- */ 1766 1767 static enum power_supply_property hidpp_battery_props[] = { 1768 POWER_SUPPLY_PROP_ONLINE, 1769 POWER_SUPPLY_PROP_STATUS, 1770 POWER_SUPPLY_PROP_SCOPE, 1771 POWER_SUPPLY_PROP_MODEL_NAME, 1772 POWER_SUPPLY_PROP_MANUFACTURER, 1773 POWER_SUPPLY_PROP_SERIAL_NUMBER, 1774 0, /* placeholder for POWER_SUPPLY_PROP_CAPACITY, */ 1775 0, /* placeholder for POWER_SUPPLY_PROP_CAPACITY_LEVEL, */ 1776 0, /* placeholder for POWER_SUPPLY_PROP_VOLTAGE_NOW, */ 1777 }; 1778 1779 static int hidpp_battery_get_property(struct power_supply *psy, 1780 enum power_supply_property psp, 1781 union power_supply_propval *val) 1782 { 1783 struct hidpp_device *hidpp = power_supply_get_drvdata(psy); 1784 int ret = 0; 1785 1786 switch(psp) { 1787 case POWER_SUPPLY_PROP_STATUS: 1788 val->intval = hidpp->battery.status; 1789 break; 1790 case POWER_SUPPLY_PROP_CAPACITY: 1791 val->intval = hidpp->battery.capacity; 1792 break; 1793 case POWER_SUPPLY_PROP_CAPACITY_LEVEL: 1794 val->intval = hidpp->battery.level; 1795 break; 1796 case POWER_SUPPLY_PROP_SCOPE: 1797 val->intval = POWER_SUPPLY_SCOPE_DEVICE; 1798 break; 1799 case POWER_SUPPLY_PROP_ONLINE: 1800 val->intval = hidpp->battery.online; 1801 break; 1802 case POWER_SUPPLY_PROP_MODEL_NAME: 1803 if (!strncmp(hidpp->name, "Logitech ", 9)) 1804 val->strval = hidpp->name + 9; 1805 else 1806 val->strval = hidpp->name; 1807 break; 1808 case POWER_SUPPLY_PROP_MANUFACTURER: 1809 val->strval = "Logitech"; 1810 break; 1811 case POWER_SUPPLY_PROP_SERIAL_NUMBER: 1812 val->strval = hidpp->hid_dev->uniq; 1813 break; 1814 case POWER_SUPPLY_PROP_VOLTAGE_NOW: 1815 /* hardware reports voltage in mV. sysfs expects uV */ 1816 val->intval = hidpp->battery.voltage * 1000; 1817 break; 1818 case POWER_SUPPLY_PROP_CHARGE_TYPE: 1819 val->intval = hidpp->battery.charge_type; 1820 break; 1821 default: 1822 ret = -EINVAL; 1823 break; 1824 } 1825 1826 return ret; 1827 } 1828 1829 /* -------------------------------------------------------------------------- */ 1830 /* 0x1d4b: Wireless device status */ 1831 /* -------------------------------------------------------------------------- */ 1832 #define HIDPP_PAGE_WIRELESS_DEVICE_STATUS 0x1d4b 1833 1834 static int hidpp_get_wireless_feature_index(struct hidpp_device *hidpp, u8 *feature_index) 1835 { 1836 u8 feature_type; 1837 int ret; 1838 1839 ret = hidpp_root_get_feature(hidpp, 1840 HIDPP_PAGE_WIRELESS_DEVICE_STATUS, 1841 feature_index, &feature_type); 1842 1843 return ret; 1844 } 1845 1846 /* -------------------------------------------------------------------------- */ 1847 /* 0x1f20: ADC measurement */ 1848 /* -------------------------------------------------------------------------- */ 1849 1850 #define HIDPP_PAGE_ADC_MEASUREMENT 0x1f20 1851 1852 #define CMD_ADC_MEASUREMENT_GET_ADC_MEASUREMENT 0x00 1853 1854 #define EVENT_ADC_MEASUREMENT_STATUS_BROADCAST 0x00 1855 1856 static int hidpp20_map_adc_measurement_1f20_capacity(struct hid_device *hid_dev, int voltage) 1857 { 1858 /* NB: This voltage curve doesn't necessarily map perfectly to all 1859 * devices that implement the ADC_MEASUREMENT feature. This is because 1860 * there are a few devices that use different battery technology. 1861 * 1862 * Adapted from: 1863 * https://github.com/Sapd/HeadsetControl/blob/acd972be0468e039b93aae81221f20a54d2d60f7/src/devices/logitech_g633_g933_935.c#L44-L52 1864 */ 1865 static const int voltages[100] = { 1866 4030, 4024, 4018, 4011, 4003, 3994, 3985, 3975, 3963, 3951, 1867 3937, 3922, 3907, 3893, 3880, 3868, 3857, 3846, 3837, 3828, 1868 3820, 3812, 3805, 3798, 3791, 3785, 3779, 3773, 3768, 3762, 1869 3757, 3752, 3747, 3742, 3738, 3733, 3729, 3724, 3720, 3716, 1870 3712, 3708, 3704, 3700, 3696, 3692, 3688, 3685, 3681, 3677, 1871 3674, 3670, 3667, 3663, 3660, 3657, 3653, 3650, 3646, 3643, 1872 3640, 3637, 3633, 3630, 3627, 3624, 3620, 3617, 3614, 3611, 1873 3608, 3604, 3601, 3598, 3595, 3592, 3589, 3585, 3582, 3579, 1874 3576, 3573, 3569, 3566, 3563, 3560, 3556, 3553, 3550, 3546, 1875 3543, 3539, 3536, 3532, 3529, 3525, 3499, 3466, 3433, 3399, 1876 }; 1877 1878 int i; 1879 1880 if (voltage == 0) 1881 return 0; 1882 1883 if (unlikely(voltage < 3400 || voltage >= 5000)) 1884 hid_warn_once(hid_dev, 1885 "%s: possibly using the wrong voltage curve\n", 1886 __func__); 1887 1888 for (i = 0; i < ARRAY_SIZE(voltages); i++) { 1889 if (voltage >= voltages[i]) 1890 return ARRAY_SIZE(voltages) - i; 1891 } 1892 1893 return 0; 1894 } 1895 1896 static int hidpp20_map_adc_measurement_1f20(u8 data[3], int *voltage) 1897 { 1898 int status; 1899 u8 flags; 1900 1901 flags = data[2]; 1902 1903 switch (flags) { 1904 case 0x01: 1905 status = POWER_SUPPLY_STATUS_DISCHARGING; 1906 break; 1907 case 0x03: 1908 status = POWER_SUPPLY_STATUS_CHARGING; 1909 break; 1910 case 0x07: 1911 status = POWER_SUPPLY_STATUS_FULL; 1912 break; 1913 case 0x0F: 1914 default: 1915 status = POWER_SUPPLY_STATUS_UNKNOWN; 1916 break; 1917 } 1918 1919 *voltage = get_unaligned_be16(data); 1920 1921 dbg_hid("Parsed 1f20 data as flag 0x%02x voltage %dmV\n", 1922 flags, *voltage); 1923 1924 return status; 1925 } 1926 1927 /* Return value is whether the device is online */ 1928 static bool hidpp20_get_adc_measurement_1f20(struct hidpp_device *hidpp, 1929 u8 feature_index, 1930 int *status, int *voltage) 1931 { 1932 struct hidpp_report response; 1933 int ret; 1934 u8 *params = (u8 *)response.fap.params; 1935 1936 *status = POWER_SUPPLY_STATUS_UNKNOWN; 1937 *voltage = 0; 1938 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 1939 CMD_ADC_MEASUREMENT_GET_ADC_MEASUREMENT, 1940 NULL, 0, &response); 1941 1942 if (ret > 0) { 1943 hid_dbg(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 1944 __func__, ret); 1945 return false; 1946 } 1947 1948 *status = hidpp20_map_adc_measurement_1f20(params, voltage); 1949 return true; 1950 } 1951 1952 static int hidpp20_query_adc_measurement_info_1f20(struct hidpp_device *hidpp) 1953 { 1954 u8 feature_type; 1955 1956 if (hidpp->battery.adc_measurement_feature_index == 0xff) { 1957 int ret; 1958 1959 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_ADC_MEASUREMENT, 1960 &hidpp->battery.adc_measurement_feature_index, 1961 &feature_type); 1962 if (ret) 1963 return ret; 1964 1965 hidpp->capabilities |= HIDPP_CAPABILITY_ADC_MEASUREMENT; 1966 } 1967 1968 hidpp->battery.online = hidpp20_get_adc_measurement_1f20(hidpp, 1969 hidpp->battery.adc_measurement_feature_index, 1970 &hidpp->battery.status, 1971 &hidpp->battery.voltage); 1972 hidpp->battery.capacity = hidpp20_map_adc_measurement_1f20_capacity(hidpp->hid_dev, 1973 hidpp->battery.voltage); 1974 hidpp_update_usb_wireless_status(hidpp); 1975 1976 return 0; 1977 } 1978 1979 static int hidpp20_adc_measurement_event_1f20(struct hidpp_device *hidpp, 1980 u8 *data, int size) 1981 { 1982 struct hidpp_report *report = (struct hidpp_report *)data; 1983 int status, voltage; 1984 1985 if (report->fap.feature_index != hidpp->battery.adc_measurement_feature_index || 1986 report->fap.funcindex_clientid != EVENT_ADC_MEASUREMENT_STATUS_BROADCAST) 1987 return 0; 1988 1989 status = hidpp20_map_adc_measurement_1f20(report->fap.params, &voltage); 1990 1991 hidpp->battery.online = status != POWER_SUPPLY_STATUS_UNKNOWN; 1992 1993 if (voltage != hidpp->battery.voltage || status != hidpp->battery.status) { 1994 hidpp->battery.status = status; 1995 hidpp->battery.voltage = voltage; 1996 hidpp->battery.capacity = hidpp20_map_adc_measurement_1f20_capacity(hidpp->hid_dev, voltage); 1997 if (hidpp->battery.ps) 1998 power_supply_changed(hidpp->battery.ps); 1999 hidpp_update_usb_wireless_status(hidpp); 2000 } 2001 return 0; 2002 } 2003 2004 /* -------------------------------------------------------------------------- */ 2005 /* 0x2120: Hi-resolution scrolling */ 2006 /* -------------------------------------------------------------------------- */ 2007 2008 #define HIDPP_PAGE_HI_RESOLUTION_SCROLLING 0x2120 2009 2010 #define CMD_HI_RESOLUTION_SCROLLING_SET_HIGHRES_SCROLLING_MODE 0x10 2011 2012 static int hidpp_hrs_set_highres_scrolling_mode(struct hidpp_device *hidpp, 2013 bool enabled, u8 *multiplier) 2014 { 2015 u8 feature_index; 2016 u8 feature_type; 2017 int ret; 2018 u8 params[1]; 2019 struct hidpp_report response; 2020 2021 ret = hidpp_root_get_feature(hidpp, 2022 HIDPP_PAGE_HI_RESOLUTION_SCROLLING, 2023 &feature_index, 2024 &feature_type); 2025 if (ret) 2026 return ret; 2027 2028 params[0] = enabled ? BIT(0) : 0; 2029 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 2030 CMD_HI_RESOLUTION_SCROLLING_SET_HIGHRES_SCROLLING_MODE, 2031 params, sizeof(params), &response); 2032 if (ret) 2033 return ret; 2034 *multiplier = response.fap.params[1]; 2035 return 0; 2036 } 2037 2038 /* -------------------------------------------------------------------------- */ 2039 /* 0x2121: HiRes Wheel */ 2040 /* -------------------------------------------------------------------------- */ 2041 2042 #define HIDPP_PAGE_HIRES_WHEEL 0x2121 2043 2044 #define CMD_HIRES_WHEEL_GET_WHEEL_CAPABILITY 0x00 2045 #define CMD_HIRES_WHEEL_SET_WHEEL_MODE 0x20 2046 2047 static int hidpp_hrw_get_wheel_capability(struct hidpp_device *hidpp, 2048 u8 *multiplier) 2049 { 2050 u8 feature_index; 2051 u8 feature_type; 2052 int ret; 2053 struct hidpp_report response; 2054 2055 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_HIRES_WHEEL, 2056 &feature_index, &feature_type); 2057 if (ret) 2058 goto return_default; 2059 2060 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 2061 CMD_HIRES_WHEEL_GET_WHEEL_CAPABILITY, 2062 NULL, 0, &response); 2063 if (ret) 2064 goto return_default; 2065 2066 *multiplier = response.fap.params[0]; 2067 return 0; 2068 return_default: 2069 hid_warn(hidpp->hid_dev, 2070 "Couldn't get wheel multiplier (error %d)\n", ret); 2071 return ret; 2072 } 2073 2074 static int hidpp_hrw_set_wheel_mode(struct hidpp_device *hidpp, bool invert, 2075 bool high_resolution, bool use_hidpp) 2076 { 2077 u8 feature_index; 2078 u8 feature_type; 2079 int ret; 2080 u8 params[1]; 2081 struct hidpp_report response; 2082 2083 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_HIRES_WHEEL, 2084 &feature_index, &feature_type); 2085 if (ret) 2086 return ret; 2087 2088 params[0] = (invert ? BIT(2) : 0) | 2089 (high_resolution ? BIT(1) : 0) | 2090 (use_hidpp ? BIT(0) : 0); 2091 2092 return hidpp_send_fap_command_sync(hidpp, feature_index, 2093 CMD_HIRES_WHEEL_SET_WHEEL_MODE, 2094 params, sizeof(params), &response); 2095 } 2096 2097 /* -------------------------------------------------------------------------- */ 2098 /* 0x4301: Solar Keyboard */ 2099 /* -------------------------------------------------------------------------- */ 2100 2101 #define HIDPP_PAGE_SOLAR_KEYBOARD 0x4301 2102 2103 #define CMD_SOLAR_SET_LIGHT_MEASURE 0x00 2104 2105 #define EVENT_SOLAR_BATTERY_BROADCAST 0x00 2106 #define EVENT_SOLAR_BATTERY_LIGHT_MEASURE 0x10 2107 #define EVENT_SOLAR_CHECK_LIGHT_BUTTON 0x20 2108 2109 static int hidpp_solar_request_battery_event(struct hidpp_device *hidpp) 2110 { 2111 struct hidpp_report response; 2112 u8 params[2] = { 1, 1 }; 2113 u8 feature_type; 2114 int ret; 2115 2116 if (hidpp->battery.feature_index == 0xff) { 2117 ret = hidpp_root_get_feature(hidpp, 2118 HIDPP_PAGE_SOLAR_KEYBOARD, 2119 &hidpp->battery.solar_feature_index, 2120 &feature_type); 2121 if (ret) 2122 return ret; 2123 } 2124 2125 ret = hidpp_send_fap_command_sync(hidpp, 2126 hidpp->battery.solar_feature_index, 2127 CMD_SOLAR_SET_LIGHT_MEASURE, 2128 params, 2, &response); 2129 if (ret > 0) { 2130 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 2131 __func__, ret); 2132 return -EPROTO; 2133 } 2134 if (ret) 2135 return ret; 2136 2137 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_MILEAGE; 2138 2139 return 0; 2140 } 2141 2142 static int hidpp_solar_battery_event(struct hidpp_device *hidpp, 2143 u8 *data, int size) 2144 { 2145 struct hidpp_report *report = (struct hidpp_report *)data; 2146 int capacity, lux, status; 2147 u8 function; 2148 2149 function = report->fap.funcindex_clientid; 2150 2151 2152 if (report->fap.feature_index != hidpp->battery.solar_feature_index || 2153 !(function == EVENT_SOLAR_BATTERY_BROADCAST || 2154 function == EVENT_SOLAR_BATTERY_LIGHT_MEASURE || 2155 function == EVENT_SOLAR_CHECK_LIGHT_BUTTON)) 2156 return 0; 2157 2158 capacity = report->fap.params[0]; 2159 2160 switch (function) { 2161 case EVENT_SOLAR_BATTERY_LIGHT_MEASURE: 2162 lux = (report->fap.params[1] << 8) | report->fap.params[2]; 2163 if (lux > 200) 2164 status = POWER_SUPPLY_STATUS_CHARGING; 2165 else 2166 status = POWER_SUPPLY_STATUS_DISCHARGING; 2167 break; 2168 case EVENT_SOLAR_CHECK_LIGHT_BUTTON: 2169 default: 2170 if (capacity < hidpp->battery.capacity) 2171 status = POWER_SUPPLY_STATUS_DISCHARGING; 2172 else 2173 status = POWER_SUPPLY_STATUS_CHARGING; 2174 2175 } 2176 2177 if (capacity == 100) 2178 status = POWER_SUPPLY_STATUS_FULL; 2179 2180 hidpp->battery.online = true; 2181 if (capacity != hidpp->battery.capacity || 2182 status != hidpp->battery.status) { 2183 hidpp->battery.capacity = capacity; 2184 hidpp->battery.status = status; 2185 if (hidpp->battery.ps) 2186 power_supply_changed(hidpp->battery.ps); 2187 } 2188 2189 return 0; 2190 } 2191 2192 /* -------------------------------------------------------------------------- */ 2193 /* 0x6010: Touchpad FW items */ 2194 /* -------------------------------------------------------------------------- */ 2195 2196 #define HIDPP_PAGE_TOUCHPAD_FW_ITEMS 0x6010 2197 2198 #define CMD_TOUCHPAD_FW_ITEMS_SET 0x10 2199 2200 struct hidpp_touchpad_fw_items { 2201 uint8_t presence; 2202 uint8_t desired_state; 2203 uint8_t state; 2204 uint8_t persistent; 2205 }; 2206 2207 /* 2208 * send a set state command to the device by reading the current items->state 2209 * field. items is then filled with the current state. 2210 */ 2211 static int hidpp_touchpad_fw_items_set(struct hidpp_device *hidpp, 2212 u8 feature_index, 2213 struct hidpp_touchpad_fw_items *items) 2214 { 2215 struct hidpp_report response; 2216 int ret; 2217 u8 *params = (u8 *)response.fap.params; 2218 2219 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 2220 CMD_TOUCHPAD_FW_ITEMS_SET, &items->state, 1, &response); 2221 2222 if (ret > 0) { 2223 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 2224 __func__, ret); 2225 return -EPROTO; 2226 } 2227 if (ret) 2228 return ret; 2229 2230 items->presence = params[0]; 2231 items->desired_state = params[1]; 2232 items->state = params[2]; 2233 items->persistent = params[3]; 2234 2235 return 0; 2236 } 2237 2238 /* -------------------------------------------------------------------------- */ 2239 /* 0x6100: TouchPadRawXY */ 2240 /* -------------------------------------------------------------------------- */ 2241 2242 #define HIDPP_PAGE_TOUCHPAD_RAW_XY 0x6100 2243 2244 #define CMD_TOUCHPAD_GET_RAW_INFO 0x00 2245 #define CMD_TOUCHPAD_SET_RAW_REPORT_STATE 0x20 2246 2247 #define EVENT_TOUCHPAD_RAW_XY 0x00 2248 2249 #define TOUCHPAD_RAW_XY_ORIGIN_LOWER_LEFT 0x01 2250 #define TOUCHPAD_RAW_XY_ORIGIN_UPPER_LEFT 0x03 2251 2252 struct hidpp_touchpad_raw_info { 2253 u16 x_size; 2254 u16 y_size; 2255 u8 z_range; 2256 u8 area_range; 2257 u8 timestamp_unit; 2258 u8 maxcontacts; 2259 u8 origin; 2260 u16 res; 2261 }; 2262 2263 struct hidpp_touchpad_raw_xy_finger { 2264 u8 contact_type; 2265 u8 contact_status; 2266 u16 x; 2267 u16 y; 2268 u8 z; 2269 u8 area; 2270 u8 finger_id; 2271 }; 2272 2273 struct hidpp_touchpad_raw_xy { 2274 u16 timestamp; 2275 struct hidpp_touchpad_raw_xy_finger fingers[2]; 2276 u8 spurious_flag; 2277 u8 end_of_frame; 2278 u8 finger_count; 2279 u8 button; 2280 }; 2281 2282 static int hidpp_touchpad_get_raw_info(struct hidpp_device *hidpp, 2283 u8 feature_index, struct hidpp_touchpad_raw_info *raw_info) 2284 { 2285 struct hidpp_report response; 2286 int ret; 2287 u8 *params = (u8 *)response.fap.params; 2288 2289 ret = hidpp_send_fap_command_sync(hidpp, feature_index, 2290 CMD_TOUCHPAD_GET_RAW_INFO, NULL, 0, &response); 2291 2292 if (ret > 0) { 2293 hid_err(hidpp->hid_dev, "%s: received protocol error 0x%02x\n", 2294 __func__, ret); 2295 return -EPROTO; 2296 } 2297 if (ret) 2298 return ret; 2299 2300 raw_info->x_size = get_unaligned_be16(¶ms[0]); 2301 raw_info->y_size = get_unaligned_be16(¶ms[2]); 2302 raw_info->z_range = params[4]; 2303 raw_info->area_range = params[5]; 2304 raw_info->maxcontacts = params[7]; 2305 raw_info->origin = params[8]; 2306 /* res is given in unit per inch */ 2307 raw_info->res = get_unaligned_be16(¶ms[13]) * 2 / 51; 2308 2309 return ret; 2310 } 2311 2312 static int hidpp_touchpad_set_raw_report_state(struct hidpp_device *hidpp_dev, 2313 u8 feature_index, bool send_raw_reports, 2314 bool sensor_enhanced_settings) 2315 { 2316 struct hidpp_report response; 2317 2318 /* 2319 * Params: 2320 * bit 0 - enable raw 2321 * bit 1 - 16bit Z, no area 2322 * bit 2 - enhanced sensitivity 2323 * bit 3 - width, height (4 bits each) instead of area 2324 * bit 4 - send raw + gestures (degrades smoothness) 2325 * remaining bits - reserved 2326 */ 2327 u8 params = send_raw_reports | (sensor_enhanced_settings << 2); 2328 2329 return hidpp_send_fap_command_sync(hidpp_dev, feature_index, 2330 CMD_TOUCHPAD_SET_RAW_REPORT_STATE, ¶ms, 1, &response); 2331 } 2332 2333 static void hidpp_touchpad_touch_event(u8 *data, 2334 struct hidpp_touchpad_raw_xy_finger *finger) 2335 { 2336 u8 x_m = data[0] << 2; 2337 u8 y_m = data[2] << 2; 2338 2339 finger->x = x_m << 6 | data[1]; 2340 finger->y = y_m << 6 | data[3]; 2341 2342 finger->contact_type = data[0] >> 6; 2343 finger->contact_status = data[2] >> 6; 2344 2345 finger->z = data[4]; 2346 finger->area = data[5]; 2347 finger->finger_id = data[6] >> 4; 2348 } 2349 2350 static void hidpp_touchpad_raw_xy_event(struct hidpp_device *hidpp_dev, 2351 u8 *data, struct hidpp_touchpad_raw_xy *raw_xy) 2352 { 2353 memset(raw_xy, 0, sizeof(struct hidpp_touchpad_raw_xy)); 2354 raw_xy->end_of_frame = data[8] & 0x01; 2355 raw_xy->spurious_flag = (data[8] >> 1) & 0x01; 2356 raw_xy->finger_count = data[15] & 0x0f; 2357 raw_xy->button = (data[8] >> 2) & 0x01; 2358 2359 if (raw_xy->finger_count) { 2360 hidpp_touchpad_touch_event(&data[2], &raw_xy->fingers[0]); 2361 hidpp_touchpad_touch_event(&data[9], &raw_xy->fingers[1]); 2362 } 2363 } 2364 2365 /* -------------------------------------------------------------------------- */ 2366 /* 0x8123: Force feedback support */ 2367 /* -------------------------------------------------------------------------- */ 2368 2369 #define HIDPP_FF_GET_INFO 0x01 2370 #define HIDPP_FF_RESET_ALL 0x11 2371 #define HIDPP_FF_DOWNLOAD_EFFECT 0x21 2372 #define HIDPP_FF_SET_EFFECT_STATE 0x31 2373 #define HIDPP_FF_DESTROY_EFFECT 0x41 2374 #define HIDPP_FF_GET_APERTURE 0x51 2375 #define HIDPP_FF_SET_APERTURE 0x61 2376 #define HIDPP_FF_GET_GLOBAL_GAINS 0x71 2377 #define HIDPP_FF_SET_GLOBAL_GAINS 0x81 2378 2379 #define HIDPP_FF_EFFECT_STATE_GET 0x00 2380 #define HIDPP_FF_EFFECT_STATE_STOP 0x01 2381 #define HIDPP_FF_EFFECT_STATE_PLAY 0x02 2382 #define HIDPP_FF_EFFECT_STATE_PAUSE 0x03 2383 2384 #define HIDPP_FF_EFFECT_CONSTANT 0x00 2385 #define HIDPP_FF_EFFECT_PERIODIC_SINE 0x01 2386 #define HIDPP_FF_EFFECT_PERIODIC_SQUARE 0x02 2387 #define HIDPP_FF_EFFECT_PERIODIC_TRIANGLE 0x03 2388 #define HIDPP_FF_EFFECT_PERIODIC_SAWTOOTHUP 0x04 2389 #define HIDPP_FF_EFFECT_PERIODIC_SAWTOOTHDOWN 0x05 2390 #define HIDPP_FF_EFFECT_SPRING 0x06 2391 #define HIDPP_FF_EFFECT_DAMPER 0x07 2392 #define HIDPP_FF_EFFECT_FRICTION 0x08 2393 #define HIDPP_FF_EFFECT_INERTIA 0x09 2394 #define HIDPP_FF_EFFECT_RAMP 0x0A 2395 2396 #define HIDPP_FF_EFFECT_AUTOSTART 0x80 2397 2398 #define HIDPP_FF_EFFECTID_NONE -1 2399 #define HIDPP_FF_EFFECTID_AUTOCENTER -2 2400 #define HIDPP_AUTOCENTER_PARAMS_LENGTH 18 2401 2402 #define HIDPP_FF_MAX_PARAMS 20 2403 #define HIDPP_FF_RESERVED_SLOTS 1 2404 2405 struct hidpp_ff_private_data { 2406 struct hidpp_device *hidpp; 2407 u8 feature_index; 2408 u8 version; 2409 u16 gain; 2410 s16 range; 2411 u8 slot_autocenter; 2412 u8 num_effects; 2413 int *effect_ids; 2414 struct workqueue_struct *wq; 2415 atomic_t workqueue_size; 2416 }; 2417 2418 struct hidpp_ff_work_data { 2419 struct work_struct work; 2420 struct hidpp_ff_private_data *data; 2421 int effect_id; 2422 u8 command; 2423 u8 params[HIDPP_FF_MAX_PARAMS]; 2424 u8 size; 2425 }; 2426 2427 static const signed short hidpp_ff_effects[] = { 2428 FF_CONSTANT, 2429 FF_PERIODIC, 2430 FF_SINE, 2431 FF_SQUARE, 2432 FF_SAW_UP, 2433 FF_SAW_DOWN, 2434 FF_TRIANGLE, 2435 FF_SPRING, 2436 FF_DAMPER, 2437 FF_AUTOCENTER, 2438 FF_GAIN, 2439 -1 2440 }; 2441 2442 static const signed short hidpp_ff_effects_v2[] = { 2443 FF_RAMP, 2444 FF_FRICTION, 2445 FF_INERTIA, 2446 -1 2447 }; 2448 2449 static const u8 HIDPP_FF_CONDITION_CMDS[] = { 2450 HIDPP_FF_EFFECT_SPRING, 2451 HIDPP_FF_EFFECT_FRICTION, 2452 HIDPP_FF_EFFECT_DAMPER, 2453 HIDPP_FF_EFFECT_INERTIA 2454 }; 2455 2456 static const char *HIDPP_FF_CONDITION_NAMES[] = { 2457 "spring", 2458 "friction", 2459 "damper", 2460 "inertia" 2461 }; 2462 2463 2464 static u8 hidpp_ff_find_effect(struct hidpp_ff_private_data *data, int effect_id) 2465 { 2466 int i; 2467 2468 for (i = 0; i < data->num_effects; i++) 2469 if (data->effect_ids[i] == effect_id) 2470 return i+1; 2471 2472 return 0; 2473 } 2474 2475 static void hidpp_ff_work_handler(struct work_struct *w) 2476 { 2477 struct hidpp_ff_work_data *wd = container_of(w, struct hidpp_ff_work_data, work); 2478 struct hidpp_ff_private_data *data = wd->data; 2479 struct hidpp_report response; 2480 u8 slot; 2481 int ret; 2482 2483 /* add slot number if needed */ 2484 switch (wd->effect_id) { 2485 case HIDPP_FF_EFFECTID_AUTOCENTER: 2486 wd->params[0] = data->slot_autocenter; 2487 break; 2488 case HIDPP_FF_EFFECTID_NONE: 2489 /* leave slot as zero */ 2490 break; 2491 default: 2492 /* find current slot for effect */ 2493 wd->params[0] = hidpp_ff_find_effect(data, wd->effect_id); 2494 break; 2495 } 2496 2497 /* send command and wait for reply */ 2498 ret = hidpp_send_fap_command_sync(data->hidpp, data->feature_index, 2499 wd->command, wd->params, wd->size, &response); 2500 2501 if (ret) { 2502 hid_err(data->hidpp->hid_dev, "Failed to send command to device!\n"); 2503 goto out; 2504 } 2505 2506 /* parse return data */ 2507 switch (wd->command) { 2508 case HIDPP_FF_DOWNLOAD_EFFECT: 2509 slot = response.fap.params[0]; 2510 if (slot > 0 && slot <= data->num_effects) { 2511 if (wd->effect_id >= 0) 2512 /* regular effect uploaded */ 2513 data->effect_ids[slot-1] = wd->effect_id; 2514 else if (wd->effect_id >= HIDPP_FF_EFFECTID_AUTOCENTER) 2515 /* autocenter spring uploaded */ 2516 data->slot_autocenter = slot; 2517 } 2518 break; 2519 case HIDPP_FF_DESTROY_EFFECT: 2520 if (wd->effect_id >= 0) 2521 /* regular effect destroyed */ 2522 data->effect_ids[wd->params[0]-1] = -1; 2523 else if (wd->effect_id >= HIDPP_FF_EFFECTID_AUTOCENTER) 2524 /* autocenter spring destoyed */ 2525 data->slot_autocenter = 0; 2526 break; 2527 case HIDPP_FF_SET_GLOBAL_GAINS: 2528 data->gain = (wd->params[0] << 8) + wd->params[1]; 2529 break; 2530 case HIDPP_FF_SET_APERTURE: 2531 data->range = (wd->params[0] << 8) + wd->params[1]; 2532 break; 2533 default: 2534 /* no action needed */ 2535 break; 2536 } 2537 2538 out: 2539 atomic_dec(&data->workqueue_size); 2540 kfree(wd); 2541 } 2542 2543 static int hidpp_ff_queue_work(struct hidpp_ff_private_data *data, int effect_id, u8 command, u8 *params, u8 size) 2544 { 2545 struct hidpp_ff_work_data *wd = kzalloc(sizeof(*wd), GFP_KERNEL); 2546 int s; 2547 2548 if (!wd) 2549 return -ENOMEM; 2550 2551 INIT_WORK(&wd->work, hidpp_ff_work_handler); 2552 2553 wd->data = data; 2554 wd->effect_id = effect_id; 2555 wd->command = command; 2556 wd->size = size; 2557 memcpy(wd->params, params, size); 2558 2559 s = atomic_inc_return(&data->workqueue_size); 2560 queue_work(data->wq, &wd->work); 2561 2562 /* warn about excessive queue size */ 2563 if (s >= 20 && s % 20 == 0) 2564 hid_warn(data->hidpp->hid_dev, "Force feedback command queue contains %d commands, causing substantial delays!", s); 2565 2566 return 0; 2567 } 2568 2569 static int hidpp_ff_upload_effect(struct input_dev *dev, struct ff_effect *effect, struct ff_effect *old) 2570 { 2571 struct hidpp_ff_private_data *data = dev->ff->private; 2572 u8 params[20]; 2573 u8 size; 2574 int force; 2575 2576 /* set common parameters */ 2577 params[2] = effect->replay.length >> 8; 2578 params[3] = effect->replay.length & 255; 2579 params[4] = effect->replay.delay >> 8; 2580 params[5] = effect->replay.delay & 255; 2581 2582 switch (effect->type) { 2583 case FF_CONSTANT: 2584 force = (effect->u.constant.level * fixp_sin16((effect->direction * 360) >> 16)) >> 15; 2585 params[1] = HIDPP_FF_EFFECT_CONSTANT; 2586 params[6] = force >> 8; 2587 params[7] = force & 255; 2588 params[8] = effect->u.constant.envelope.attack_level >> 7; 2589 params[9] = effect->u.constant.envelope.attack_length >> 8; 2590 params[10] = effect->u.constant.envelope.attack_length & 255; 2591 params[11] = effect->u.constant.envelope.fade_level >> 7; 2592 params[12] = effect->u.constant.envelope.fade_length >> 8; 2593 params[13] = effect->u.constant.envelope.fade_length & 255; 2594 size = 14; 2595 dbg_hid("Uploading constant force level=%d in dir %d = %d\n", 2596 effect->u.constant.level, 2597 effect->direction, force); 2598 dbg_hid(" envelope attack=(%d, %d ms) fade=(%d, %d ms)\n", 2599 effect->u.constant.envelope.attack_level, 2600 effect->u.constant.envelope.attack_length, 2601 effect->u.constant.envelope.fade_level, 2602 effect->u.constant.envelope.fade_length); 2603 break; 2604 case FF_PERIODIC: 2605 { 2606 switch (effect->u.periodic.waveform) { 2607 case FF_SINE: 2608 params[1] = HIDPP_FF_EFFECT_PERIODIC_SINE; 2609 break; 2610 case FF_SQUARE: 2611 params[1] = HIDPP_FF_EFFECT_PERIODIC_SQUARE; 2612 break; 2613 case FF_SAW_UP: 2614 params[1] = HIDPP_FF_EFFECT_PERIODIC_SAWTOOTHUP; 2615 break; 2616 case FF_SAW_DOWN: 2617 params[1] = HIDPP_FF_EFFECT_PERIODIC_SAWTOOTHDOWN; 2618 break; 2619 case FF_TRIANGLE: 2620 params[1] = HIDPP_FF_EFFECT_PERIODIC_TRIANGLE; 2621 break; 2622 default: 2623 hid_err(data->hidpp->hid_dev, "Unexpected periodic waveform type %i!\n", effect->u.periodic.waveform); 2624 return -EINVAL; 2625 } 2626 force = (effect->u.periodic.magnitude * fixp_sin16((effect->direction * 360) >> 16)) >> 15; 2627 params[6] = effect->u.periodic.magnitude >> 8; 2628 params[7] = effect->u.periodic.magnitude & 255; 2629 params[8] = effect->u.periodic.offset >> 8; 2630 params[9] = effect->u.periodic.offset & 255; 2631 params[10] = effect->u.periodic.period >> 8; 2632 params[11] = effect->u.periodic.period & 255; 2633 params[12] = effect->u.periodic.phase >> 8; 2634 params[13] = effect->u.periodic.phase & 255; 2635 params[14] = effect->u.periodic.envelope.attack_level >> 7; 2636 params[15] = effect->u.periodic.envelope.attack_length >> 8; 2637 params[16] = effect->u.periodic.envelope.attack_length & 255; 2638 params[17] = effect->u.periodic.envelope.fade_level >> 7; 2639 params[18] = effect->u.periodic.envelope.fade_length >> 8; 2640 params[19] = effect->u.periodic.envelope.fade_length & 255; 2641 size = 20; 2642 dbg_hid("Uploading periodic force mag=%d/dir=%d, offset=%d, period=%d ms, phase=%d\n", 2643 effect->u.periodic.magnitude, effect->direction, 2644 effect->u.periodic.offset, 2645 effect->u.periodic.period, 2646 effect->u.periodic.phase); 2647 dbg_hid(" envelope attack=(%d, %d ms) fade=(%d, %d ms)\n", 2648 effect->u.periodic.envelope.attack_level, 2649 effect->u.periodic.envelope.attack_length, 2650 effect->u.periodic.envelope.fade_level, 2651 effect->u.periodic.envelope.fade_length); 2652 break; 2653 } 2654 case FF_RAMP: 2655 params[1] = HIDPP_FF_EFFECT_RAMP; 2656 force = (effect->u.ramp.start_level * fixp_sin16((effect->direction * 360) >> 16)) >> 15; 2657 params[6] = force >> 8; 2658 params[7] = force & 255; 2659 force = (effect->u.ramp.end_level * fixp_sin16((effect->direction * 360) >> 16)) >> 15; 2660 params[8] = force >> 8; 2661 params[9] = force & 255; 2662 params[10] = effect->u.ramp.envelope.attack_level >> 7; 2663 params[11] = effect->u.ramp.envelope.attack_length >> 8; 2664 params[12] = effect->u.ramp.envelope.attack_length & 255; 2665 params[13] = effect->u.ramp.envelope.fade_level >> 7; 2666 params[14] = effect->u.ramp.envelope.fade_length >> 8; 2667 params[15] = effect->u.ramp.envelope.fade_length & 255; 2668 size = 16; 2669 dbg_hid("Uploading ramp force level=%d -> %d in dir %d = %d\n", 2670 effect->u.ramp.start_level, 2671 effect->u.ramp.end_level, 2672 effect->direction, force); 2673 dbg_hid(" envelope attack=(%d, %d ms) fade=(%d, %d ms)\n", 2674 effect->u.ramp.envelope.attack_level, 2675 effect->u.ramp.envelope.attack_length, 2676 effect->u.ramp.envelope.fade_level, 2677 effect->u.ramp.envelope.fade_length); 2678 break; 2679 case FF_FRICTION: 2680 case FF_INERTIA: 2681 case FF_SPRING: 2682 case FF_DAMPER: 2683 params[1] = HIDPP_FF_CONDITION_CMDS[effect->type - FF_SPRING]; 2684 params[6] = effect->u.condition[0].left_saturation >> 9; 2685 params[7] = (effect->u.condition[0].left_saturation >> 1) & 255; 2686 params[8] = effect->u.condition[0].left_coeff >> 8; 2687 params[9] = effect->u.condition[0].left_coeff & 255; 2688 params[10] = effect->u.condition[0].deadband >> 9; 2689 params[11] = (effect->u.condition[0].deadband >> 1) & 255; 2690 params[12] = effect->u.condition[0].center >> 8; 2691 params[13] = effect->u.condition[0].center & 255; 2692 params[14] = effect->u.condition[0].right_coeff >> 8; 2693 params[15] = effect->u.condition[0].right_coeff & 255; 2694 params[16] = effect->u.condition[0].right_saturation >> 9; 2695 params[17] = (effect->u.condition[0].right_saturation >> 1) & 255; 2696 size = 18; 2697 dbg_hid("Uploading %s force left coeff=%d, left sat=%d, right coeff=%d, right sat=%d\n", 2698 HIDPP_FF_CONDITION_NAMES[effect->type - FF_SPRING], 2699 effect->u.condition[0].left_coeff, 2700 effect->u.condition[0].left_saturation, 2701 effect->u.condition[0].right_coeff, 2702 effect->u.condition[0].right_saturation); 2703 dbg_hid(" deadband=%d, center=%d\n", 2704 effect->u.condition[0].deadband, 2705 effect->u.condition[0].center); 2706 break; 2707 default: 2708 hid_err(data->hidpp->hid_dev, "Unexpected force type %i!\n", effect->type); 2709 return -EINVAL; 2710 } 2711 2712 return hidpp_ff_queue_work(data, effect->id, HIDPP_FF_DOWNLOAD_EFFECT, params, size); 2713 } 2714 2715 static int hidpp_ff_playback(struct input_dev *dev, int effect_id, int value) 2716 { 2717 struct hidpp_ff_private_data *data = dev->ff->private; 2718 u8 params[2]; 2719 2720 params[1] = value ? HIDPP_FF_EFFECT_STATE_PLAY : HIDPP_FF_EFFECT_STATE_STOP; 2721 2722 dbg_hid("St%sing playback of effect %d.\n", value?"art":"opp", effect_id); 2723 2724 return hidpp_ff_queue_work(data, effect_id, HIDPP_FF_SET_EFFECT_STATE, params, ARRAY_SIZE(params)); 2725 } 2726 2727 static int hidpp_ff_erase_effect(struct input_dev *dev, int effect_id) 2728 { 2729 struct hidpp_ff_private_data *data = dev->ff->private; 2730 u8 slot = 0; 2731 2732 dbg_hid("Erasing effect %d.\n", effect_id); 2733 2734 return hidpp_ff_queue_work(data, effect_id, HIDPP_FF_DESTROY_EFFECT, &slot, 1); 2735 } 2736 2737 static void hidpp_ff_set_autocenter(struct input_dev *dev, u16 magnitude) 2738 { 2739 struct hidpp_ff_private_data *data = dev->ff->private; 2740 u8 params[HIDPP_AUTOCENTER_PARAMS_LENGTH]; 2741 2742 dbg_hid("Setting autocenter to %d.\n", magnitude); 2743 2744 /* start a standard spring effect */ 2745 params[1] = HIDPP_FF_EFFECT_SPRING | HIDPP_FF_EFFECT_AUTOSTART; 2746 /* zero delay and duration */ 2747 params[2] = params[3] = params[4] = params[5] = 0; 2748 /* set coeff to 25% of saturation */ 2749 params[8] = params[14] = magnitude >> 11; 2750 params[9] = params[15] = (magnitude >> 3) & 255; 2751 params[6] = params[16] = magnitude >> 9; 2752 params[7] = params[17] = (magnitude >> 1) & 255; 2753 /* zero deadband and center */ 2754 params[10] = params[11] = params[12] = params[13] = 0; 2755 2756 hidpp_ff_queue_work(data, HIDPP_FF_EFFECTID_AUTOCENTER, HIDPP_FF_DOWNLOAD_EFFECT, params, ARRAY_SIZE(params)); 2757 } 2758 2759 static void hidpp_ff_set_gain(struct input_dev *dev, u16 gain) 2760 { 2761 struct hidpp_ff_private_data *data = dev->ff->private; 2762 u8 params[4]; 2763 2764 dbg_hid("Setting gain to %d.\n", gain); 2765 2766 params[0] = gain >> 8; 2767 params[1] = gain & 255; 2768 params[2] = 0; /* no boost */ 2769 params[3] = 0; 2770 2771 hidpp_ff_queue_work(data, HIDPP_FF_EFFECTID_NONE, HIDPP_FF_SET_GLOBAL_GAINS, params, ARRAY_SIZE(params)); 2772 } 2773 2774 static ssize_t hidpp_ff_range_show(struct device *dev, struct device_attribute *attr, char *buf) 2775 { 2776 struct hid_device *hid = to_hid_device(dev); 2777 struct hid_input *hidinput = list_entry(hid->inputs.next, struct hid_input, list); 2778 struct input_dev *idev = hidinput->input; 2779 struct hidpp_ff_private_data *data = idev->ff->private; 2780 2781 return scnprintf(buf, PAGE_SIZE, "%u\n", data->range); 2782 } 2783 2784 static ssize_t hidpp_ff_range_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) 2785 { 2786 struct hid_device *hid = to_hid_device(dev); 2787 struct hid_input *hidinput = list_entry(hid->inputs.next, struct hid_input, list); 2788 struct input_dev *idev = hidinput->input; 2789 struct hidpp_ff_private_data *data = idev->ff->private; 2790 u8 params[2]; 2791 int range = simple_strtoul(buf, NULL, 10); 2792 2793 range = clamp(range, 180, 900); 2794 2795 params[0] = range >> 8; 2796 params[1] = range & 0x00FF; 2797 2798 hidpp_ff_queue_work(data, -1, HIDPP_FF_SET_APERTURE, params, ARRAY_SIZE(params)); 2799 2800 return count; 2801 } 2802 2803 static DEVICE_ATTR(range, S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH, hidpp_ff_range_show, hidpp_ff_range_store); 2804 2805 static void hidpp_ff_destroy(struct ff_device *ff) 2806 { 2807 struct hidpp_ff_private_data *data = ff->private; 2808 struct hid_device *hid = data->hidpp->hid_dev; 2809 2810 hid_info(hid, "Unloading HID++ force feedback.\n"); 2811 2812 device_remove_file(&hid->dev, &dev_attr_range); 2813 destroy_workqueue(data->wq); 2814 kfree(data->effect_ids); 2815 } 2816 2817 static int hidpp_ff_init(struct hidpp_device *hidpp, 2818 struct hidpp_ff_private_data *data) 2819 { 2820 struct hid_device *hid = hidpp->hid_dev; 2821 struct hid_input *hidinput; 2822 struct input_dev *dev; 2823 struct usb_device_descriptor *udesc; 2824 u16 bcdDevice; 2825 struct ff_device *ff; 2826 int error, j, num_slots = data->num_effects; 2827 u8 version; 2828 2829 if (!hid_is_usb(hid)) { 2830 hid_err(hid, "device is not USB\n"); 2831 return -ENODEV; 2832 } 2833 2834 if (list_empty(&hid->inputs)) { 2835 hid_err(hid, "no inputs found\n"); 2836 return -ENODEV; 2837 } 2838 hidinput = list_entry(hid->inputs.next, struct hid_input, list); 2839 dev = hidinput->input; 2840 2841 if (!dev) { 2842 hid_err(hid, "Struct input_dev not set!\n"); 2843 return -EINVAL; 2844 } 2845 2846 /* Get firmware release */ 2847 udesc = &(hid_to_usb_dev(hid)->descriptor); 2848 bcdDevice = le16_to_cpu(udesc->bcdDevice); 2849 version = bcdDevice & 255; 2850 2851 /* Set supported force feedback capabilities */ 2852 for (j = 0; hidpp_ff_effects[j] >= 0; j++) 2853 set_bit(hidpp_ff_effects[j], dev->ffbit); 2854 if (version > 1) 2855 for (j = 0; hidpp_ff_effects_v2[j] >= 0; j++) 2856 set_bit(hidpp_ff_effects_v2[j], dev->ffbit); 2857 2858 error = input_ff_create(dev, num_slots); 2859 2860 if (error) { 2861 hid_err(dev, "Failed to create FF device!\n"); 2862 return error; 2863 } 2864 /* 2865 * Create a copy of passed data, so we can transfer memory 2866 * ownership to FF core 2867 */ 2868 data = kmemdup(data, sizeof(*data), GFP_KERNEL); 2869 if (!data) 2870 return -ENOMEM; 2871 data->effect_ids = kcalloc(num_slots, sizeof(int), GFP_KERNEL); 2872 if (!data->effect_ids) { 2873 kfree(data); 2874 return -ENOMEM; 2875 } 2876 data->wq = create_singlethread_workqueue("hidpp-ff-sendqueue"); 2877 if (!data->wq) { 2878 kfree(data->effect_ids); 2879 kfree(data); 2880 return -ENOMEM; 2881 } 2882 2883 data->hidpp = hidpp; 2884 data->version = version; 2885 for (j = 0; j < num_slots; j++) 2886 data->effect_ids[j] = -1; 2887 2888 ff = dev->ff; 2889 ff->private = data; 2890 2891 ff->upload = hidpp_ff_upload_effect; 2892 ff->erase = hidpp_ff_erase_effect; 2893 ff->playback = hidpp_ff_playback; 2894 ff->set_gain = hidpp_ff_set_gain; 2895 ff->set_autocenter = hidpp_ff_set_autocenter; 2896 ff->destroy = hidpp_ff_destroy; 2897 2898 /* Create sysfs interface */ 2899 error = device_create_file(&(hidpp->hid_dev->dev), &dev_attr_range); 2900 if (error) 2901 hid_warn(hidpp->hid_dev, "Unable to create sysfs interface for \"range\", errno %d!\n", error); 2902 2903 /* init the hardware command queue */ 2904 atomic_set(&data->workqueue_size, 0); 2905 2906 hid_info(hid, "Force feedback support loaded (firmware release %d).\n", 2907 version); 2908 2909 return 0; 2910 } 2911 2912 /* ************************************************************************** */ 2913 /* */ 2914 /* Device Support */ 2915 /* */ 2916 /* ************************************************************************** */ 2917 2918 /* -------------------------------------------------------------------------- */ 2919 /* Touchpad HID++ devices */ 2920 /* -------------------------------------------------------------------------- */ 2921 2922 #define WTP_MANUAL_RESOLUTION 39 2923 2924 struct wtp_data { 2925 u16 x_size, y_size; 2926 u8 finger_count; 2927 u8 mt_feature_index; 2928 u8 button_feature_index; 2929 u8 maxcontacts; 2930 bool flip_y; 2931 unsigned int resolution; 2932 }; 2933 2934 static int wtp_input_mapping(struct hid_device *hdev, struct hid_input *hi, 2935 struct hid_field *field, struct hid_usage *usage, 2936 unsigned long **bit, int *max) 2937 { 2938 return -1; 2939 } 2940 2941 static void wtp_populate_input(struct hidpp_device *hidpp, 2942 struct input_dev *input_dev) 2943 { 2944 struct wtp_data *wd = hidpp->private_data; 2945 2946 __set_bit(EV_ABS, input_dev->evbit); 2947 __set_bit(EV_KEY, input_dev->evbit); 2948 __clear_bit(EV_REL, input_dev->evbit); 2949 __clear_bit(EV_LED, input_dev->evbit); 2950 2951 input_set_abs_params(input_dev, ABS_MT_POSITION_X, 0, wd->x_size, 0, 0); 2952 input_abs_set_res(input_dev, ABS_MT_POSITION_X, wd->resolution); 2953 input_set_abs_params(input_dev, ABS_MT_POSITION_Y, 0, wd->y_size, 0, 0); 2954 input_abs_set_res(input_dev, ABS_MT_POSITION_Y, wd->resolution); 2955 2956 /* Max pressure is not given by the devices, pick one */ 2957 input_set_abs_params(input_dev, ABS_MT_PRESSURE, 0, 50, 0, 0); 2958 2959 input_set_capability(input_dev, EV_KEY, BTN_LEFT); 2960 2961 if (hidpp->quirks & HIDPP_QUIRK_WTP_PHYSICAL_BUTTONS) 2962 input_set_capability(input_dev, EV_KEY, BTN_RIGHT); 2963 else 2964 __set_bit(INPUT_PROP_BUTTONPAD, input_dev->propbit); 2965 2966 input_mt_init_slots(input_dev, wd->maxcontacts, INPUT_MT_POINTER | 2967 INPUT_MT_DROP_UNUSED); 2968 } 2969 2970 static void wtp_touch_event(struct hidpp_device *hidpp, 2971 struct hidpp_touchpad_raw_xy_finger *touch_report) 2972 { 2973 struct wtp_data *wd = hidpp->private_data; 2974 int slot; 2975 2976 if (!touch_report->finger_id || touch_report->contact_type) 2977 /* no actual data */ 2978 return; 2979 2980 slot = input_mt_get_slot_by_key(hidpp->input, touch_report->finger_id); 2981 2982 input_mt_slot(hidpp->input, slot); 2983 input_mt_report_slot_state(hidpp->input, MT_TOOL_FINGER, 2984 touch_report->contact_status); 2985 if (touch_report->contact_status) { 2986 input_event(hidpp->input, EV_ABS, ABS_MT_POSITION_X, 2987 touch_report->x); 2988 input_event(hidpp->input, EV_ABS, ABS_MT_POSITION_Y, 2989 wd->flip_y ? wd->y_size - touch_report->y : 2990 touch_report->y); 2991 input_event(hidpp->input, EV_ABS, ABS_MT_PRESSURE, 2992 touch_report->area); 2993 } 2994 } 2995 2996 static void wtp_send_raw_xy_event(struct hidpp_device *hidpp, 2997 struct hidpp_touchpad_raw_xy *raw) 2998 { 2999 int i; 3000 3001 for (i = 0; i < 2; i++) 3002 wtp_touch_event(hidpp, &(raw->fingers[i])); 3003 3004 if (raw->end_of_frame && 3005 !(hidpp->quirks & HIDPP_QUIRK_WTP_PHYSICAL_BUTTONS)) 3006 input_event(hidpp->input, EV_KEY, BTN_LEFT, raw->button); 3007 3008 if (raw->end_of_frame || raw->finger_count <= 2) { 3009 input_mt_sync_frame(hidpp->input); 3010 input_sync(hidpp->input); 3011 } 3012 } 3013 3014 static int wtp_mouse_raw_xy_event(struct hidpp_device *hidpp, u8 *data) 3015 { 3016 struct wtp_data *wd = hidpp->private_data; 3017 u8 c1_area = ((data[7] & 0xf) * (data[7] & 0xf) + 3018 (data[7] >> 4) * (data[7] >> 4)) / 2; 3019 u8 c2_area = ((data[13] & 0xf) * (data[13] & 0xf) + 3020 (data[13] >> 4) * (data[13] >> 4)) / 2; 3021 struct hidpp_touchpad_raw_xy raw = { 3022 .timestamp = data[1], 3023 .fingers = { 3024 { 3025 .contact_type = 0, 3026 .contact_status = !!data[7], 3027 .x = get_unaligned_le16(&data[3]), 3028 .y = get_unaligned_le16(&data[5]), 3029 .z = c1_area, 3030 .area = c1_area, 3031 .finger_id = data[2], 3032 }, { 3033 .contact_type = 0, 3034 .contact_status = !!data[13], 3035 .x = get_unaligned_le16(&data[9]), 3036 .y = get_unaligned_le16(&data[11]), 3037 .z = c2_area, 3038 .area = c2_area, 3039 .finger_id = data[8], 3040 } 3041 }, 3042 .finger_count = wd->maxcontacts, 3043 .spurious_flag = 0, 3044 .end_of_frame = (data[0] >> 7) == 0, 3045 .button = data[0] & 0x01, 3046 }; 3047 3048 wtp_send_raw_xy_event(hidpp, &raw); 3049 3050 return 1; 3051 } 3052 3053 static int wtp_raw_event(struct hid_device *hdev, u8 *data, int size) 3054 { 3055 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3056 struct wtp_data *wd = hidpp->private_data; 3057 struct hidpp_report *report = (struct hidpp_report *)data; 3058 struct hidpp_touchpad_raw_xy raw; 3059 3060 if (!wd || !hidpp->input) 3061 return 1; 3062 3063 switch (data[0]) { 3064 case 0x02: 3065 if (size < 2) { 3066 hid_err(hdev, "Received HID report of bad size (%d)", 3067 size); 3068 return 1; 3069 } 3070 if (hidpp->quirks & HIDPP_QUIRK_WTP_PHYSICAL_BUTTONS) { 3071 input_event(hidpp->input, EV_KEY, BTN_LEFT, 3072 !!(data[1] & 0x01)); 3073 input_event(hidpp->input, EV_KEY, BTN_RIGHT, 3074 !!(data[1] & 0x02)); 3075 input_sync(hidpp->input); 3076 return 0; 3077 } else { 3078 if (size < 21) 3079 return 1; 3080 return wtp_mouse_raw_xy_event(hidpp, &data[7]); 3081 } 3082 case REPORT_ID_HIDPP_LONG: 3083 /* size is already checked in hidpp_raw_event. */ 3084 if ((report->fap.feature_index != wd->mt_feature_index) || 3085 (report->fap.funcindex_clientid != EVENT_TOUCHPAD_RAW_XY)) 3086 return 1; 3087 hidpp_touchpad_raw_xy_event(hidpp, data + 4, &raw); 3088 3089 wtp_send_raw_xy_event(hidpp, &raw); 3090 return 0; 3091 } 3092 3093 return 0; 3094 } 3095 3096 static int wtp_get_config(struct hidpp_device *hidpp) 3097 { 3098 struct wtp_data *wd = hidpp->private_data; 3099 struct hidpp_touchpad_raw_info raw_info = {0}; 3100 u8 feature_type; 3101 int ret; 3102 3103 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_TOUCHPAD_RAW_XY, 3104 &wd->mt_feature_index, &feature_type); 3105 if (ret) 3106 /* means that the device is not powered up */ 3107 return ret; 3108 3109 ret = hidpp_touchpad_get_raw_info(hidpp, wd->mt_feature_index, 3110 &raw_info); 3111 if (ret) 3112 return ret; 3113 3114 wd->x_size = raw_info.x_size; 3115 wd->y_size = raw_info.y_size; 3116 wd->maxcontacts = raw_info.maxcontacts; 3117 wd->flip_y = raw_info.origin == TOUCHPAD_RAW_XY_ORIGIN_LOWER_LEFT; 3118 wd->resolution = raw_info.res; 3119 if (!wd->resolution) 3120 wd->resolution = WTP_MANUAL_RESOLUTION; 3121 3122 return 0; 3123 } 3124 3125 static int wtp_allocate(struct hid_device *hdev, const struct hid_device_id *id) 3126 { 3127 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3128 struct wtp_data *wd; 3129 3130 wd = devm_kzalloc(&hdev->dev, sizeof(struct wtp_data), 3131 GFP_KERNEL); 3132 if (!wd) 3133 return -ENOMEM; 3134 3135 hidpp->private_data = wd; 3136 3137 return 0; 3138 }; 3139 3140 static int wtp_connect(struct hid_device *hdev) 3141 { 3142 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3143 struct wtp_data *wd = hidpp->private_data; 3144 int ret; 3145 3146 if (!wd->x_size) { 3147 ret = wtp_get_config(hidpp); 3148 if (ret) { 3149 hid_err(hdev, "Can not get wtp config: %d\n", ret); 3150 return ret; 3151 } 3152 } 3153 3154 return hidpp_touchpad_set_raw_report_state(hidpp, wd->mt_feature_index, 3155 true, true); 3156 } 3157 3158 /* ------------------------------------------------------------------------- */ 3159 /* Logitech M560 devices */ 3160 /* ------------------------------------------------------------------------- */ 3161 3162 /* 3163 * Logitech M560 protocol overview 3164 * 3165 * The Logitech M560 mouse, is designed for windows 8. When the middle and/or 3166 * the sides buttons are pressed, it sends some keyboard keys events 3167 * instead of buttons ones. 3168 * To complicate things further, the middle button keys sequence 3169 * is different from the odd press and the even press. 3170 * 3171 * forward button -> Super_R 3172 * backward button -> Super_L+'d' (press only) 3173 * middle button -> 1st time: Alt_L+SuperL+XF86TouchpadOff (press only) 3174 * 2nd time: left-click (press only) 3175 * NB: press-only means that when the button is pressed, the 3176 * KeyPress/ButtonPress and KeyRelease/ButtonRelease events are generated 3177 * together sequentially; instead when the button is released, no event is 3178 * generated ! 3179 * 3180 * With the command 3181 * 10<xx>0a 3500af03 (where <xx> is the mouse id), 3182 * the mouse reacts differently: 3183 * - it never sends a keyboard key event 3184 * - for the three mouse button it sends: 3185 * middle button press 11<xx>0a 3500af00... 3186 * side 1 button (forward) press 11<xx>0a 3500b000... 3187 * side 2 button (backward) press 11<xx>0a 3500ae00... 3188 * middle/side1/side2 button release 11<xx>0a 35000000... 3189 */ 3190 3191 static const u8 m560_config_parameter[] = {0x00, 0xaf, 0x03}; 3192 3193 /* how buttons are mapped in the report */ 3194 #define M560_MOUSE_BTN_LEFT 0x01 3195 #define M560_MOUSE_BTN_RIGHT 0x02 3196 #define M560_MOUSE_BTN_WHEEL_LEFT 0x08 3197 #define M560_MOUSE_BTN_WHEEL_RIGHT 0x10 3198 3199 #define M560_SUB_ID 0x0a 3200 #define M560_BUTTON_MODE_REGISTER 0x35 3201 3202 static int m560_send_config_command(struct hid_device *hdev) 3203 { 3204 struct hidpp_report response; 3205 struct hidpp_device *hidpp_dev; 3206 3207 hidpp_dev = hid_get_drvdata(hdev); 3208 3209 return hidpp_send_rap_command_sync( 3210 hidpp_dev, 3211 REPORT_ID_HIDPP_SHORT, 3212 M560_SUB_ID, 3213 M560_BUTTON_MODE_REGISTER, 3214 (u8 *)m560_config_parameter, 3215 sizeof(m560_config_parameter), 3216 &response 3217 ); 3218 } 3219 3220 static int m560_raw_event(struct hid_device *hdev, u8 *data, int size) 3221 { 3222 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3223 3224 /* sanity check */ 3225 if (!hidpp->input) { 3226 hid_err(hdev, "error in parameter\n"); 3227 return -EINVAL; 3228 } 3229 3230 if (size < 7) { 3231 hid_err(hdev, "error in report\n"); 3232 return 0; 3233 } 3234 3235 if (data[0] == REPORT_ID_HIDPP_LONG && 3236 data[2] == M560_SUB_ID && data[6] == 0x00) { 3237 /* 3238 * m560 mouse report for middle, forward and backward button 3239 * 3240 * data[0] = 0x11 3241 * data[1] = device-id 3242 * data[2] = 0x0a 3243 * data[5] = 0xaf -> middle 3244 * 0xb0 -> forward 3245 * 0xae -> backward 3246 * 0x00 -> release all 3247 * data[6] = 0x00 3248 */ 3249 3250 switch (data[5]) { 3251 case 0xaf: 3252 input_report_key(hidpp->input, BTN_MIDDLE, 1); 3253 break; 3254 case 0xb0: 3255 input_report_key(hidpp->input, BTN_FORWARD, 1); 3256 break; 3257 case 0xae: 3258 input_report_key(hidpp->input, BTN_BACK, 1); 3259 break; 3260 case 0x00: 3261 input_report_key(hidpp->input, BTN_BACK, 0); 3262 input_report_key(hidpp->input, BTN_FORWARD, 0); 3263 input_report_key(hidpp->input, BTN_MIDDLE, 0); 3264 break; 3265 default: 3266 hid_err(hdev, "error in report\n"); 3267 return 0; 3268 } 3269 input_sync(hidpp->input); 3270 3271 } else if (data[0] == 0x02) { 3272 /* 3273 * Logitech M560 mouse report 3274 * 3275 * data[0] = type (0x02) 3276 * data[1..2] = buttons 3277 * data[3..5] = xy 3278 * data[6] = wheel 3279 */ 3280 3281 int v; 3282 3283 input_report_key(hidpp->input, BTN_LEFT, 3284 !!(data[1] & M560_MOUSE_BTN_LEFT)); 3285 input_report_key(hidpp->input, BTN_RIGHT, 3286 !!(data[1] & M560_MOUSE_BTN_RIGHT)); 3287 3288 if (data[1] & M560_MOUSE_BTN_WHEEL_LEFT) { 3289 input_report_rel(hidpp->input, REL_HWHEEL, -1); 3290 input_report_rel(hidpp->input, REL_HWHEEL_HI_RES, 3291 -120); 3292 } else if (data[1] & M560_MOUSE_BTN_WHEEL_RIGHT) { 3293 input_report_rel(hidpp->input, REL_HWHEEL, 1); 3294 input_report_rel(hidpp->input, REL_HWHEEL_HI_RES, 3295 120); 3296 } 3297 3298 v = hid_snto32(hid_field_extract(hdev, data+3, 0, 12), 12); 3299 input_report_rel(hidpp->input, REL_X, v); 3300 3301 v = hid_snto32(hid_field_extract(hdev, data+3, 12, 12), 12); 3302 input_report_rel(hidpp->input, REL_Y, v); 3303 3304 v = hid_snto32(data[6], 8); 3305 if (v != 0) 3306 hidpp_scroll_counter_handle_scroll(hidpp->input, 3307 &hidpp->vertical_wheel_counter, v); 3308 3309 input_sync(hidpp->input); 3310 } 3311 3312 return 1; 3313 } 3314 3315 static void m560_populate_input(struct hidpp_device *hidpp, 3316 struct input_dev *input_dev) 3317 { 3318 __set_bit(EV_KEY, input_dev->evbit); 3319 __set_bit(BTN_MIDDLE, input_dev->keybit); 3320 __set_bit(BTN_RIGHT, input_dev->keybit); 3321 __set_bit(BTN_LEFT, input_dev->keybit); 3322 __set_bit(BTN_BACK, input_dev->keybit); 3323 __set_bit(BTN_FORWARD, input_dev->keybit); 3324 3325 __set_bit(EV_REL, input_dev->evbit); 3326 __set_bit(REL_X, input_dev->relbit); 3327 __set_bit(REL_Y, input_dev->relbit); 3328 __set_bit(REL_WHEEL, input_dev->relbit); 3329 __set_bit(REL_HWHEEL, input_dev->relbit); 3330 __set_bit(REL_WHEEL_HI_RES, input_dev->relbit); 3331 __set_bit(REL_HWHEEL_HI_RES, input_dev->relbit); 3332 } 3333 3334 static int m560_input_mapping(struct hid_device *hdev, struct hid_input *hi, 3335 struct hid_field *field, struct hid_usage *usage, 3336 unsigned long **bit, int *max) 3337 { 3338 return -1; 3339 } 3340 3341 /* ------------------------------------------------------------------------- */ 3342 /* Logitech K400 devices */ 3343 /* ------------------------------------------------------------------------- */ 3344 3345 /* 3346 * The Logitech K400 keyboard has an embedded touchpad which is seen 3347 * as a mouse from the OS point of view. There is a hardware shortcut to disable 3348 * tap-to-click but the setting is not remembered accross reset, annoying some 3349 * users. 3350 * 3351 * We can toggle this feature from the host by using the feature 0x6010: 3352 * Touchpad FW items 3353 */ 3354 3355 struct k400_private_data { 3356 u8 feature_index; 3357 }; 3358 3359 static int k400_disable_tap_to_click(struct hidpp_device *hidpp) 3360 { 3361 struct k400_private_data *k400 = hidpp->private_data; 3362 struct hidpp_touchpad_fw_items items = {}; 3363 int ret; 3364 u8 feature_type; 3365 3366 if (!k400->feature_index) { 3367 ret = hidpp_root_get_feature(hidpp, 3368 HIDPP_PAGE_TOUCHPAD_FW_ITEMS, 3369 &k400->feature_index, &feature_type); 3370 if (ret) 3371 /* means that the device is not powered up */ 3372 return ret; 3373 } 3374 3375 ret = hidpp_touchpad_fw_items_set(hidpp, k400->feature_index, &items); 3376 if (ret) 3377 return ret; 3378 3379 return 0; 3380 } 3381 3382 static int k400_allocate(struct hid_device *hdev) 3383 { 3384 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3385 struct k400_private_data *k400; 3386 3387 k400 = devm_kzalloc(&hdev->dev, sizeof(struct k400_private_data), 3388 GFP_KERNEL); 3389 if (!k400) 3390 return -ENOMEM; 3391 3392 hidpp->private_data = k400; 3393 3394 return 0; 3395 }; 3396 3397 static int k400_connect(struct hid_device *hdev) 3398 { 3399 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3400 3401 if (!disable_tap_to_click) 3402 return 0; 3403 3404 return k400_disable_tap_to_click(hidpp); 3405 } 3406 3407 /* ------------------------------------------------------------------------- */ 3408 /* Logitech G920 Driving Force Racing Wheel for Xbox One */ 3409 /* ------------------------------------------------------------------------- */ 3410 3411 #define HIDPP_PAGE_G920_FORCE_FEEDBACK 0x8123 3412 3413 static int g920_ff_set_autocenter(struct hidpp_device *hidpp, 3414 struct hidpp_ff_private_data *data) 3415 { 3416 struct hidpp_report response; 3417 u8 params[HIDPP_AUTOCENTER_PARAMS_LENGTH] = { 3418 [1] = HIDPP_FF_EFFECT_SPRING | HIDPP_FF_EFFECT_AUTOSTART, 3419 }; 3420 int ret; 3421 3422 /* initialize with zero autocenter to get wheel in usable state */ 3423 3424 dbg_hid("Setting autocenter to 0.\n"); 3425 ret = hidpp_send_fap_command_sync(hidpp, data->feature_index, 3426 HIDPP_FF_DOWNLOAD_EFFECT, 3427 params, ARRAY_SIZE(params), 3428 &response); 3429 if (ret) 3430 hid_warn(hidpp->hid_dev, "Failed to autocenter device!\n"); 3431 else 3432 data->slot_autocenter = response.fap.params[0]; 3433 3434 return ret; 3435 } 3436 3437 static int g920_get_config(struct hidpp_device *hidpp, 3438 struct hidpp_ff_private_data *data) 3439 { 3440 struct hidpp_report response; 3441 u8 feature_type; 3442 int ret; 3443 3444 memset(data, 0, sizeof(*data)); 3445 3446 /* Find feature and store for later use */ 3447 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_G920_FORCE_FEEDBACK, 3448 &data->feature_index, &feature_type); 3449 if (ret) 3450 return ret; 3451 3452 /* Read number of slots available in device */ 3453 ret = hidpp_send_fap_command_sync(hidpp, data->feature_index, 3454 HIDPP_FF_GET_INFO, 3455 NULL, 0, 3456 &response); 3457 if (ret) { 3458 if (ret < 0) 3459 return ret; 3460 hid_err(hidpp->hid_dev, 3461 "%s: received protocol error 0x%02x\n", __func__, ret); 3462 return -EPROTO; 3463 } 3464 3465 data->num_effects = response.fap.params[0] - HIDPP_FF_RESERVED_SLOTS; 3466 3467 /* reset all forces */ 3468 ret = hidpp_send_fap_command_sync(hidpp, data->feature_index, 3469 HIDPP_FF_RESET_ALL, 3470 NULL, 0, 3471 &response); 3472 if (ret) 3473 hid_warn(hidpp->hid_dev, "Failed to reset all forces!\n"); 3474 3475 ret = hidpp_send_fap_command_sync(hidpp, data->feature_index, 3476 HIDPP_FF_GET_APERTURE, 3477 NULL, 0, 3478 &response); 3479 if (ret) { 3480 hid_warn(hidpp->hid_dev, 3481 "Failed to read range from device!\n"); 3482 } 3483 data->range = ret ? 3484 900 : get_unaligned_be16(&response.fap.params[0]); 3485 3486 /* Read the current gain values */ 3487 ret = hidpp_send_fap_command_sync(hidpp, data->feature_index, 3488 HIDPP_FF_GET_GLOBAL_GAINS, 3489 NULL, 0, 3490 &response); 3491 if (ret) 3492 hid_warn(hidpp->hid_dev, 3493 "Failed to read gain values from device!\n"); 3494 data->gain = ret ? 3495 0xffff : get_unaligned_be16(&response.fap.params[0]); 3496 3497 /* ignore boost value at response.fap.params[2] */ 3498 3499 return g920_ff_set_autocenter(hidpp, data); 3500 } 3501 3502 /* -------------------------------------------------------------------------- */ 3503 /* Logitech Dinovo Mini keyboard with builtin touchpad */ 3504 /* -------------------------------------------------------------------------- */ 3505 #define DINOVO_MINI_PRODUCT_ID 0xb30c 3506 3507 static int lg_dinovo_input_mapping(struct hid_device *hdev, struct hid_input *hi, 3508 struct hid_field *field, struct hid_usage *usage, 3509 unsigned long **bit, int *max) 3510 { 3511 if ((usage->hid & HID_USAGE_PAGE) != HID_UP_LOGIVENDOR) 3512 return 0; 3513 3514 switch (usage->hid & HID_USAGE) { 3515 case 0x00d: lg_map_key_clear(KEY_MEDIA); break; 3516 default: 3517 return 0; 3518 } 3519 return 1; 3520 } 3521 3522 /* -------------------------------------------------------------------------- */ 3523 /* HID++1.0 devices which use HID++ reports for their wheels */ 3524 /* -------------------------------------------------------------------------- */ 3525 static int hidpp10_wheel_connect(struct hidpp_device *hidpp) 3526 { 3527 return hidpp10_set_register(hidpp, HIDPP_REG_ENABLE_REPORTS, 0, 3528 HIDPP_ENABLE_WHEEL_REPORT | HIDPP_ENABLE_HWHEEL_REPORT, 3529 HIDPP_ENABLE_WHEEL_REPORT | HIDPP_ENABLE_HWHEEL_REPORT); 3530 } 3531 3532 static int hidpp10_wheel_raw_event(struct hidpp_device *hidpp, 3533 u8 *data, int size) 3534 { 3535 s8 value, hvalue; 3536 3537 if (!hidpp->input) 3538 return -EINVAL; 3539 3540 if (size < 7) 3541 return 0; 3542 3543 if (data[0] != REPORT_ID_HIDPP_SHORT || data[2] != HIDPP_SUB_ID_ROLLER) 3544 return 0; 3545 3546 value = data[3]; 3547 hvalue = data[4]; 3548 3549 input_report_rel(hidpp->input, REL_WHEEL, value); 3550 input_report_rel(hidpp->input, REL_WHEEL_HI_RES, value * 120); 3551 input_report_rel(hidpp->input, REL_HWHEEL, hvalue); 3552 input_report_rel(hidpp->input, REL_HWHEEL_HI_RES, hvalue * 120); 3553 input_sync(hidpp->input); 3554 3555 return 1; 3556 } 3557 3558 static void hidpp10_wheel_populate_input(struct hidpp_device *hidpp, 3559 struct input_dev *input_dev) 3560 { 3561 __set_bit(EV_REL, input_dev->evbit); 3562 __set_bit(REL_WHEEL, input_dev->relbit); 3563 __set_bit(REL_WHEEL_HI_RES, input_dev->relbit); 3564 __set_bit(REL_HWHEEL, input_dev->relbit); 3565 __set_bit(REL_HWHEEL_HI_RES, input_dev->relbit); 3566 } 3567 3568 /* -------------------------------------------------------------------------- */ 3569 /* HID++1.0 mice which use HID++ reports for extra mouse buttons */ 3570 /* -------------------------------------------------------------------------- */ 3571 static int hidpp10_extra_mouse_buttons_connect(struct hidpp_device *hidpp) 3572 { 3573 return hidpp10_set_register(hidpp, HIDPP_REG_ENABLE_REPORTS, 0, 3574 HIDPP_ENABLE_MOUSE_EXTRA_BTN_REPORT, 3575 HIDPP_ENABLE_MOUSE_EXTRA_BTN_REPORT); 3576 } 3577 3578 static int hidpp10_extra_mouse_buttons_raw_event(struct hidpp_device *hidpp, 3579 u8 *data, int size) 3580 { 3581 int i; 3582 3583 if (!hidpp->input) 3584 return -EINVAL; 3585 3586 if (size < 7) 3587 return 0; 3588 3589 if (data[0] != REPORT_ID_HIDPP_SHORT || 3590 data[2] != HIDPP_SUB_ID_MOUSE_EXTRA_BTNS) 3591 return 0; 3592 3593 /* 3594 * Buttons are either delivered through the regular mouse report *or* 3595 * through the extra buttons report. At least for button 6 how it is 3596 * delivered differs per receiver firmware version. Even receivers with 3597 * the same usb-id show different behavior, so we handle both cases. 3598 */ 3599 for (i = 0; i < 8; i++) 3600 input_report_key(hidpp->input, BTN_MOUSE + i, 3601 (data[3] & (1 << i))); 3602 3603 /* Some mice report events on button 9+, use BTN_MISC */ 3604 for (i = 0; i < 8; i++) 3605 input_report_key(hidpp->input, BTN_MISC + i, 3606 (data[4] & (1 << i))); 3607 3608 input_sync(hidpp->input); 3609 return 1; 3610 } 3611 3612 static void hidpp10_extra_mouse_buttons_populate_input( 3613 struct hidpp_device *hidpp, struct input_dev *input_dev) 3614 { 3615 /* BTN_MOUSE - BTN_MOUSE+7 are set already by the descriptor */ 3616 __set_bit(BTN_0, input_dev->keybit); 3617 __set_bit(BTN_1, input_dev->keybit); 3618 __set_bit(BTN_2, input_dev->keybit); 3619 __set_bit(BTN_3, input_dev->keybit); 3620 __set_bit(BTN_4, input_dev->keybit); 3621 __set_bit(BTN_5, input_dev->keybit); 3622 __set_bit(BTN_6, input_dev->keybit); 3623 __set_bit(BTN_7, input_dev->keybit); 3624 } 3625 3626 /* -------------------------------------------------------------------------- */ 3627 /* HID++1.0 kbds which only report 0x10xx consumer usages through sub-id 0x03 */ 3628 /* -------------------------------------------------------------------------- */ 3629 3630 /* Find the consumer-page input report desc and change Maximums to 0x107f */ 3631 static u8 *hidpp10_consumer_keys_report_fixup(struct hidpp_device *hidpp, 3632 u8 *_rdesc, unsigned int *rsize) 3633 { 3634 /* Note 0 terminated so we can use strnstr to search for this. */ 3635 static const char consumer_rdesc_start[] = { 3636 0x05, 0x0C, /* USAGE_PAGE (Consumer Devices) */ 3637 0x09, 0x01, /* USAGE (Consumer Control) */ 3638 0xA1, 0x01, /* COLLECTION (Application) */ 3639 0x85, 0x03, /* REPORT_ID = 3 */ 3640 0x75, 0x10, /* REPORT_SIZE (16) */ 3641 0x95, 0x02, /* REPORT_COUNT (2) */ 3642 0x15, 0x01, /* LOGICAL_MIN (1) */ 3643 0x26, 0x00 /* LOGICAL_MAX (... */ 3644 }; 3645 char *consumer_rdesc, *rdesc = (char *)_rdesc; 3646 unsigned int size; 3647 3648 consumer_rdesc = strnstr(rdesc, consumer_rdesc_start, *rsize); 3649 size = *rsize - (consumer_rdesc - rdesc); 3650 if (consumer_rdesc && size >= 25) { 3651 consumer_rdesc[15] = 0x7f; 3652 consumer_rdesc[16] = 0x10; 3653 consumer_rdesc[20] = 0x7f; 3654 consumer_rdesc[21] = 0x10; 3655 } 3656 return _rdesc; 3657 } 3658 3659 static int hidpp10_consumer_keys_connect(struct hidpp_device *hidpp) 3660 { 3661 return hidpp10_set_register(hidpp, HIDPP_REG_ENABLE_REPORTS, 0, 3662 HIDPP_ENABLE_CONSUMER_REPORT, 3663 HIDPP_ENABLE_CONSUMER_REPORT); 3664 } 3665 3666 static int hidpp10_consumer_keys_raw_event(struct hidpp_device *hidpp, 3667 u8 *data, int size) 3668 { 3669 u8 consumer_report[5]; 3670 3671 if (size < 7) 3672 return 0; 3673 3674 if (data[0] != REPORT_ID_HIDPP_SHORT || 3675 data[2] != HIDPP_SUB_ID_CONSUMER_VENDOR_KEYS) 3676 return 0; 3677 3678 /* 3679 * Build a normal consumer report (3) out of the data, this detour 3680 * is necessary to get some keyboards to report their 0x10xx usages. 3681 */ 3682 consumer_report[0] = 0x03; 3683 memcpy(&consumer_report[1], &data[3], 4); 3684 /* We are called from atomic context */ 3685 hid_report_raw_event(hidpp->hid_dev, HID_INPUT_REPORT, 3686 consumer_report, 5, 1); 3687 3688 return 1; 3689 } 3690 3691 /* -------------------------------------------------------------------------- */ 3692 /* High-resolution scroll wheels */ 3693 /* -------------------------------------------------------------------------- */ 3694 3695 static int hi_res_scroll_enable(struct hidpp_device *hidpp) 3696 { 3697 int ret; 3698 u8 multiplier = 1; 3699 3700 if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP20_HI_RES_WHEEL) { 3701 ret = hidpp_hrw_set_wheel_mode(hidpp, false, true, false); 3702 if (ret == 0) 3703 ret = hidpp_hrw_get_wheel_capability(hidpp, &multiplier); 3704 } else if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP20_HI_RES_SCROLL) { 3705 ret = hidpp_hrs_set_highres_scrolling_mode(hidpp, true, 3706 &multiplier); 3707 } else /* if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP10_FAST_SCROLL) */ { 3708 ret = hidpp10_enable_scrolling_acceleration(hidpp); 3709 multiplier = 8; 3710 } 3711 if (ret) { 3712 hid_dbg(hidpp->hid_dev, 3713 "Could not enable hi-res scrolling: %d\n", ret); 3714 return ret; 3715 } 3716 3717 if (multiplier == 0) { 3718 hid_dbg(hidpp->hid_dev, 3719 "Invalid multiplier 0 from device, setting it to 1\n"); 3720 multiplier = 1; 3721 } 3722 3723 hidpp->vertical_wheel_counter.wheel_multiplier = multiplier; 3724 hid_dbg(hidpp->hid_dev, "wheel multiplier = %d\n", multiplier); 3725 return 0; 3726 } 3727 3728 static int hidpp_initialize_hires_scroll(struct hidpp_device *hidpp) 3729 { 3730 int ret; 3731 unsigned long capabilities; 3732 3733 capabilities = hidpp->capabilities; 3734 3735 if (hidpp->protocol_major >= 2) { 3736 u8 feature_index; 3737 u8 feature_type; 3738 3739 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_HIRES_WHEEL, 3740 &feature_index, &feature_type); 3741 if (!ret) { 3742 hidpp->capabilities |= HIDPP_CAPABILITY_HIDPP20_HI_RES_WHEEL; 3743 hid_dbg(hidpp->hid_dev, "Detected HID++ 2.0 hi-res scroll wheel\n"); 3744 return 0; 3745 } 3746 ret = hidpp_root_get_feature(hidpp, HIDPP_PAGE_HI_RESOLUTION_SCROLLING, 3747 &feature_index, &feature_type); 3748 if (!ret) { 3749 hidpp->capabilities |= HIDPP_CAPABILITY_HIDPP20_HI_RES_SCROLL; 3750 hid_dbg(hidpp->hid_dev, "Detected HID++ 2.0 hi-res scrolling\n"); 3751 } 3752 } else { 3753 /* We cannot detect fast scrolling support on HID++ 1.0 devices */ 3754 if (hidpp->quirks & HIDPP_QUIRK_HI_RES_SCROLL_1P0) { 3755 hidpp->capabilities |= HIDPP_CAPABILITY_HIDPP10_FAST_SCROLL; 3756 hid_dbg(hidpp->hid_dev, "Detected HID++ 1.0 fast scroll\n"); 3757 } 3758 } 3759 3760 if (hidpp->capabilities == capabilities) 3761 hid_dbg(hidpp->hid_dev, "Did not detect HID++ hi-res scrolling hardware support\n"); 3762 return 0; 3763 } 3764 3765 /* -------------------------------------------------------------------------- */ 3766 /* Generic HID++ devices */ 3767 /* -------------------------------------------------------------------------- */ 3768 3769 static u8 *hidpp_report_fixup(struct hid_device *hdev, u8 *rdesc, 3770 unsigned int *rsize) 3771 { 3772 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3773 3774 if (!hidpp) 3775 return rdesc; 3776 3777 /* For 27 MHz keyboards the quirk gets set after hid_parse. */ 3778 if (hdev->group == HID_GROUP_LOGITECH_27MHZ_DEVICE || 3779 (hidpp->quirks & HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS)) 3780 rdesc = hidpp10_consumer_keys_report_fixup(hidpp, rdesc, rsize); 3781 3782 return rdesc; 3783 } 3784 3785 static int hidpp_input_mapping(struct hid_device *hdev, struct hid_input *hi, 3786 struct hid_field *field, struct hid_usage *usage, 3787 unsigned long **bit, int *max) 3788 { 3789 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3790 3791 if (!hidpp) 3792 return 0; 3793 3794 if (hidpp->quirks & HIDPP_QUIRK_CLASS_WTP) 3795 return wtp_input_mapping(hdev, hi, field, usage, bit, max); 3796 else if (hidpp->quirks & HIDPP_QUIRK_CLASS_M560 && 3797 field->application != HID_GD_MOUSE) 3798 return m560_input_mapping(hdev, hi, field, usage, bit, max); 3799 3800 if (hdev->product == DINOVO_MINI_PRODUCT_ID) 3801 return lg_dinovo_input_mapping(hdev, hi, field, usage, bit, max); 3802 3803 return 0; 3804 } 3805 3806 static int hidpp_input_mapped(struct hid_device *hdev, struct hid_input *hi, 3807 struct hid_field *field, struct hid_usage *usage, 3808 unsigned long **bit, int *max) 3809 { 3810 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3811 3812 if (!hidpp) 3813 return 0; 3814 3815 /* Ensure that Logitech G920 is not given a default fuzz/flat value */ 3816 if (hidpp->quirks & HIDPP_QUIRK_CLASS_G920) { 3817 if (usage->type == EV_ABS && (usage->code == ABS_X || 3818 usage->code == ABS_Y || usage->code == ABS_Z || 3819 usage->code == ABS_RZ)) { 3820 field->application = HID_GD_MULTIAXIS; 3821 } 3822 } 3823 3824 return 0; 3825 } 3826 3827 3828 static void hidpp_populate_input(struct hidpp_device *hidpp, 3829 struct input_dev *input) 3830 { 3831 hidpp->input = input; 3832 3833 if (hidpp->quirks & HIDPP_QUIRK_CLASS_WTP) 3834 wtp_populate_input(hidpp, input); 3835 else if (hidpp->quirks & HIDPP_QUIRK_CLASS_M560) 3836 m560_populate_input(hidpp, input); 3837 3838 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_WHEELS) 3839 hidpp10_wheel_populate_input(hidpp, input); 3840 3841 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_EXTRA_MOUSE_BTNS) 3842 hidpp10_extra_mouse_buttons_populate_input(hidpp, input); 3843 } 3844 3845 static int hidpp_input_configured(struct hid_device *hdev, 3846 struct hid_input *hidinput) 3847 { 3848 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3849 struct input_dev *input = hidinput->input; 3850 3851 if (!hidpp) 3852 return 0; 3853 3854 hidpp_populate_input(hidpp, input); 3855 3856 return 0; 3857 } 3858 3859 static int hidpp_raw_hidpp_event(struct hidpp_device *hidpp, u8 *data, 3860 int size) 3861 { 3862 struct hidpp_report *question = hidpp->send_receive_buf; 3863 struct hidpp_report *answer = hidpp->send_receive_buf; 3864 struct hidpp_report *report = (struct hidpp_report *)data; 3865 int ret; 3866 3867 /* 3868 * If the mutex is locked then we have a pending answer from a 3869 * previously sent command. 3870 */ 3871 if (unlikely(mutex_is_locked(&hidpp->send_mutex))) { 3872 /* 3873 * Check for a correct hidpp20 answer or the corresponding 3874 * error 3875 */ 3876 if (hidpp_match_answer(question, report) || 3877 hidpp_match_error(question, report)) { 3878 *answer = *report; 3879 hidpp->answer_available = true; 3880 wake_up(&hidpp->wait); 3881 /* 3882 * This was an answer to a command that this driver sent 3883 * We return 1 to hid-core to avoid forwarding the 3884 * command upstream as it has been treated by the driver 3885 */ 3886 3887 return 1; 3888 } 3889 } 3890 3891 if (unlikely(hidpp_report_is_connect_event(hidpp, report))) { 3892 if (schedule_work(&hidpp->work) == 0) 3893 dbg_hid("%s: connect event already queued\n", __func__); 3894 return 1; 3895 } 3896 3897 if (hidpp->hid_dev->group == HID_GROUP_LOGITECH_27MHZ_DEVICE && 3898 data[0] == REPORT_ID_HIDPP_SHORT && 3899 data[2] == HIDPP_SUB_ID_USER_IFACE_EVENT && 3900 (data[3] & HIDPP_USER_IFACE_EVENT_ENCRYPTION_KEY_LOST)) { 3901 dev_err_ratelimited(&hidpp->hid_dev->dev, 3902 "Error the keyboard's wireless encryption key has been lost, your keyboard will not work unless you re-configure encryption.\n"); 3903 dev_err_ratelimited(&hidpp->hid_dev->dev, 3904 "See: https://gitlab.freedesktop.org/jwrdegoede/logitech-27mhz-keyboard-encryption-setup/\n"); 3905 } 3906 3907 if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP20_BATTERY) { 3908 ret = hidpp20_battery_event_1000(hidpp, data, size); 3909 if (ret != 0) 3910 return ret; 3911 ret = hidpp20_battery_event_1004(hidpp, data, size); 3912 if (ret != 0) 3913 return ret; 3914 ret = hidpp_solar_battery_event(hidpp, data, size); 3915 if (ret != 0) 3916 return ret; 3917 ret = hidpp20_battery_voltage_event(hidpp, data, size); 3918 if (ret != 0) 3919 return ret; 3920 ret = hidpp20_adc_measurement_event_1f20(hidpp, data, size); 3921 if (ret != 0) 3922 return ret; 3923 } 3924 3925 if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP10_BATTERY) { 3926 ret = hidpp10_battery_event(hidpp, data, size); 3927 if (ret != 0) 3928 return ret; 3929 } 3930 3931 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_WHEELS) { 3932 ret = hidpp10_wheel_raw_event(hidpp, data, size); 3933 if (ret != 0) 3934 return ret; 3935 } 3936 3937 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_EXTRA_MOUSE_BTNS) { 3938 ret = hidpp10_extra_mouse_buttons_raw_event(hidpp, data, size); 3939 if (ret != 0) 3940 return ret; 3941 } 3942 3943 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS) { 3944 ret = hidpp10_consumer_keys_raw_event(hidpp, data, size); 3945 if (ret != 0) 3946 return ret; 3947 } 3948 3949 return 0; 3950 } 3951 3952 static int hidpp_raw_event(struct hid_device *hdev, struct hid_report *report, 3953 u8 *data, int size) 3954 { 3955 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 3956 int ret = 0; 3957 3958 if (!hidpp) 3959 return 0; 3960 3961 /* Generic HID++ processing. */ 3962 switch (data[0]) { 3963 case REPORT_ID_HIDPP_VERY_LONG: 3964 if (size != hidpp->very_long_report_length) { 3965 hid_err(hdev, "received hid++ report of bad size (%d)", 3966 size); 3967 return 1; 3968 } 3969 ret = hidpp_raw_hidpp_event(hidpp, data, size); 3970 break; 3971 case REPORT_ID_HIDPP_LONG: 3972 if (size != HIDPP_REPORT_LONG_LENGTH) { 3973 hid_err(hdev, "received hid++ report of bad size (%d)", 3974 size); 3975 return 1; 3976 } 3977 ret = hidpp_raw_hidpp_event(hidpp, data, size); 3978 break; 3979 case REPORT_ID_HIDPP_SHORT: 3980 if (size != HIDPP_REPORT_SHORT_LENGTH) { 3981 hid_err(hdev, "received hid++ report of bad size (%d)", 3982 size); 3983 return 1; 3984 } 3985 ret = hidpp_raw_hidpp_event(hidpp, data, size); 3986 break; 3987 } 3988 3989 /* If no report is available for further processing, skip calling 3990 * raw_event of subclasses. */ 3991 if (ret != 0) 3992 return ret; 3993 3994 if (hidpp->quirks & HIDPP_QUIRK_CLASS_WTP) 3995 return wtp_raw_event(hdev, data, size); 3996 else if (hidpp->quirks & HIDPP_QUIRK_CLASS_M560) 3997 return m560_raw_event(hdev, data, size); 3998 3999 return 0; 4000 } 4001 4002 static int hidpp_event(struct hid_device *hdev, struct hid_field *field, 4003 struct hid_usage *usage, __s32 value) 4004 { 4005 /* This function will only be called for scroll events, due to the 4006 * restriction imposed in hidpp_usages. 4007 */ 4008 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 4009 struct hidpp_scroll_counter *counter; 4010 4011 if (!hidpp) 4012 return 0; 4013 4014 counter = &hidpp->vertical_wheel_counter; 4015 /* A scroll event may occur before the multiplier has been retrieved or 4016 * the input device set, or high-res scroll enabling may fail. In such 4017 * cases we must return early (falling back to default behaviour) to 4018 * avoid a crash in hidpp_scroll_counter_handle_scroll. 4019 */ 4020 if (!(hidpp->capabilities & HIDPP_CAPABILITY_HI_RES_SCROLL) 4021 || value == 0 || hidpp->input == NULL 4022 || counter->wheel_multiplier == 0) 4023 return 0; 4024 4025 hidpp_scroll_counter_handle_scroll(hidpp->input, counter, value); 4026 return 1; 4027 } 4028 4029 static int hidpp_initialize_battery(struct hidpp_device *hidpp) 4030 { 4031 static atomic_t battery_no = ATOMIC_INIT(0); 4032 struct power_supply_config cfg = { .drv_data = hidpp }; 4033 struct power_supply_desc *desc = &hidpp->battery.desc; 4034 enum power_supply_property *battery_props; 4035 struct hidpp_battery *battery; 4036 unsigned int num_battery_props; 4037 unsigned long n; 4038 int ret; 4039 4040 if (hidpp->battery.ps) 4041 return 0; 4042 4043 hidpp->battery.feature_index = 0xff; 4044 hidpp->battery.solar_feature_index = 0xff; 4045 hidpp->battery.voltage_feature_index = 0xff; 4046 hidpp->battery.adc_measurement_feature_index = 0xff; 4047 4048 if (hidpp->protocol_major >= 2) { 4049 if (hidpp->quirks & HIDPP_QUIRK_CLASS_K750) 4050 ret = hidpp_solar_request_battery_event(hidpp); 4051 else { 4052 /* we only support one battery feature right now, so let's 4053 first check the ones that support battery level first 4054 and leave voltage for last */ 4055 ret = hidpp20_query_battery_info_1000(hidpp); 4056 if (ret) 4057 ret = hidpp20_query_battery_info_1004(hidpp); 4058 if (ret) 4059 ret = hidpp20_query_battery_voltage_info(hidpp); 4060 if (ret) 4061 ret = hidpp20_query_adc_measurement_info_1f20(hidpp); 4062 } 4063 4064 if (ret) 4065 return ret; 4066 hidpp->capabilities |= HIDPP_CAPABILITY_HIDPP20_BATTERY; 4067 } else { 4068 ret = hidpp10_query_battery_status(hidpp); 4069 if (ret) { 4070 ret = hidpp10_query_battery_mileage(hidpp); 4071 if (ret) 4072 return -ENOENT; 4073 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_MILEAGE; 4074 } else { 4075 hidpp->capabilities |= HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS; 4076 } 4077 hidpp->capabilities |= HIDPP_CAPABILITY_HIDPP10_BATTERY; 4078 } 4079 4080 battery_props = devm_kmemdup(&hidpp->hid_dev->dev, 4081 hidpp_battery_props, 4082 sizeof(hidpp_battery_props), 4083 GFP_KERNEL); 4084 if (!battery_props) 4085 return -ENOMEM; 4086 4087 num_battery_props = ARRAY_SIZE(hidpp_battery_props) - 3; 4088 4089 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_MILEAGE || 4090 hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_PERCENTAGE || 4091 hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_VOLTAGE || 4092 hidpp->capabilities & HIDPP_CAPABILITY_ADC_MEASUREMENT) 4093 battery_props[num_battery_props++] = 4094 POWER_SUPPLY_PROP_CAPACITY; 4095 4096 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_LEVEL_STATUS) 4097 battery_props[num_battery_props++] = 4098 POWER_SUPPLY_PROP_CAPACITY_LEVEL; 4099 4100 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_VOLTAGE || 4101 hidpp->capabilities & HIDPP_CAPABILITY_ADC_MEASUREMENT) 4102 battery_props[num_battery_props++] = 4103 POWER_SUPPLY_PROP_VOLTAGE_NOW; 4104 4105 battery = &hidpp->battery; 4106 4107 n = atomic_inc_return(&battery_no) - 1; 4108 desc->properties = battery_props; 4109 desc->num_properties = num_battery_props; 4110 desc->get_property = hidpp_battery_get_property; 4111 sprintf(battery->name, "hidpp_battery_%ld", n); 4112 desc->name = battery->name; 4113 desc->type = POWER_SUPPLY_TYPE_BATTERY; 4114 desc->use_for_apm = 0; 4115 4116 battery->ps = devm_power_supply_register(&hidpp->hid_dev->dev, 4117 &battery->desc, 4118 &cfg); 4119 if (IS_ERR(battery->ps)) 4120 return PTR_ERR(battery->ps); 4121 4122 power_supply_powers(battery->ps, &hidpp->hid_dev->dev); 4123 4124 return ret; 4125 } 4126 4127 /* Get name + serial for USB and Bluetooth HID++ devices */ 4128 static void hidpp_non_unifying_init(struct hidpp_device *hidpp) 4129 { 4130 struct hid_device *hdev = hidpp->hid_dev; 4131 char *name; 4132 4133 /* Bluetooth devices already have their serialnr set */ 4134 if (hid_is_usb(hdev)) 4135 hidpp_serial_init(hidpp); 4136 4137 name = hidpp_get_device_name(hidpp); 4138 if (name) { 4139 dbg_hid("HID++: Got name: %s\n", name); 4140 snprintf(hdev->name, sizeof(hdev->name), "%s", name); 4141 kfree(name); 4142 } 4143 } 4144 4145 static int hidpp_input_open(struct input_dev *dev) 4146 { 4147 struct hid_device *hid = input_get_drvdata(dev); 4148 4149 return hid_hw_open(hid); 4150 } 4151 4152 static void hidpp_input_close(struct input_dev *dev) 4153 { 4154 struct hid_device *hid = input_get_drvdata(dev); 4155 4156 hid_hw_close(hid); 4157 } 4158 4159 static struct input_dev *hidpp_allocate_input(struct hid_device *hdev) 4160 { 4161 struct input_dev *input_dev = devm_input_allocate_device(&hdev->dev); 4162 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 4163 4164 if (!input_dev) 4165 return NULL; 4166 4167 input_set_drvdata(input_dev, hdev); 4168 input_dev->open = hidpp_input_open; 4169 input_dev->close = hidpp_input_close; 4170 4171 input_dev->name = hidpp->name; 4172 input_dev->phys = hdev->phys; 4173 input_dev->uniq = hdev->uniq; 4174 input_dev->id.bustype = hdev->bus; 4175 input_dev->id.vendor = hdev->vendor; 4176 input_dev->id.product = hdev->product; 4177 input_dev->id.version = hdev->version; 4178 input_dev->dev.parent = &hdev->dev; 4179 4180 return input_dev; 4181 } 4182 4183 static void hidpp_connect_event(struct work_struct *work) 4184 { 4185 struct hidpp_device *hidpp = container_of(work, struct hidpp_device, work); 4186 struct hid_device *hdev = hidpp->hid_dev; 4187 struct input_dev *input; 4188 char *name, *devm_name; 4189 int ret; 4190 4191 /* Get device version to check if it is connected */ 4192 ret = hidpp_root_get_protocol_version(hidpp); 4193 if (ret) { 4194 hid_dbg(hidpp->hid_dev, "Disconnected\n"); 4195 if (hidpp->battery.ps) { 4196 hidpp->battery.online = false; 4197 hidpp->battery.status = POWER_SUPPLY_STATUS_UNKNOWN; 4198 hidpp->battery.level = POWER_SUPPLY_CAPACITY_LEVEL_UNKNOWN; 4199 power_supply_changed(hidpp->battery.ps); 4200 } 4201 return; 4202 } 4203 4204 if (hidpp->quirks & HIDPP_QUIRK_CLASS_WTP) { 4205 ret = wtp_connect(hdev); 4206 if (ret) 4207 return; 4208 } else if (hidpp->quirks & HIDPP_QUIRK_CLASS_M560) { 4209 ret = m560_send_config_command(hdev); 4210 if (ret) 4211 return; 4212 } else if (hidpp->quirks & HIDPP_QUIRK_CLASS_K400) { 4213 ret = k400_connect(hdev); 4214 if (ret) 4215 return; 4216 } 4217 4218 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_WHEELS) { 4219 ret = hidpp10_wheel_connect(hidpp); 4220 if (ret) 4221 return; 4222 } 4223 4224 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_EXTRA_MOUSE_BTNS) { 4225 ret = hidpp10_extra_mouse_buttons_connect(hidpp); 4226 if (ret) 4227 return; 4228 } 4229 4230 if (hidpp->quirks & HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS) { 4231 ret = hidpp10_consumer_keys_connect(hidpp); 4232 if (ret) 4233 return; 4234 } 4235 4236 if (hidpp->protocol_major >= 2) { 4237 u8 feature_index; 4238 4239 if (!hidpp_get_wireless_feature_index(hidpp, &feature_index)) 4240 hidpp->wireless_feature_index = feature_index; 4241 } 4242 4243 if (hidpp->name == hdev->name && hidpp->protocol_major >= 2) { 4244 name = hidpp_get_device_name(hidpp); 4245 if (name) { 4246 devm_name = devm_kasprintf(&hdev->dev, GFP_KERNEL, 4247 "%s", name); 4248 kfree(name); 4249 if (!devm_name) 4250 return; 4251 4252 hidpp->name = devm_name; 4253 } 4254 } 4255 4256 hidpp_initialize_battery(hidpp); 4257 if (!hid_is_usb(hidpp->hid_dev)) 4258 hidpp_initialize_hires_scroll(hidpp); 4259 4260 /* forward current battery state */ 4261 if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP10_BATTERY) { 4262 hidpp10_enable_battery_reporting(hidpp); 4263 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_MILEAGE) 4264 hidpp10_query_battery_mileage(hidpp); 4265 else 4266 hidpp10_query_battery_status(hidpp); 4267 } else if (hidpp->capabilities & HIDPP_CAPABILITY_HIDPP20_BATTERY) { 4268 if (hidpp->capabilities & HIDPP_CAPABILITY_BATTERY_VOLTAGE) 4269 hidpp20_query_battery_voltage_info(hidpp); 4270 else if (hidpp->capabilities & HIDPP_CAPABILITY_UNIFIED_BATTERY) 4271 hidpp20_query_battery_info_1004(hidpp); 4272 else if (hidpp->capabilities & HIDPP_CAPABILITY_ADC_MEASUREMENT) 4273 hidpp20_query_adc_measurement_info_1f20(hidpp); 4274 else 4275 hidpp20_query_battery_info_1000(hidpp); 4276 } 4277 if (hidpp->battery.ps) 4278 power_supply_changed(hidpp->battery.ps); 4279 4280 if (hidpp->capabilities & HIDPP_CAPABILITY_HI_RES_SCROLL) 4281 hi_res_scroll_enable(hidpp); 4282 4283 if (!(hidpp->quirks & HIDPP_QUIRK_DELAYED_INIT) || hidpp->delayed_input) 4284 /* if the input nodes are already created, we can stop now */ 4285 return; 4286 4287 input = hidpp_allocate_input(hdev); 4288 if (!input) { 4289 hid_err(hdev, "cannot allocate new input device: %d\n", ret); 4290 return; 4291 } 4292 4293 hidpp_populate_input(hidpp, input); 4294 4295 ret = input_register_device(input); 4296 if (ret) { 4297 input_free_device(input); 4298 return; 4299 } 4300 4301 hidpp->delayed_input = input; 4302 } 4303 4304 static DEVICE_ATTR(builtin_power_supply, 0000, NULL, NULL); 4305 4306 static struct attribute *sysfs_attrs[] = { 4307 &dev_attr_builtin_power_supply.attr, 4308 NULL 4309 }; 4310 4311 static const struct attribute_group ps_attribute_group = { 4312 .attrs = sysfs_attrs 4313 }; 4314 4315 static int hidpp_get_report_length(struct hid_device *hdev, int id) 4316 { 4317 struct hid_report_enum *re; 4318 struct hid_report *report; 4319 4320 re = &(hdev->report_enum[HID_OUTPUT_REPORT]); 4321 report = re->report_id_hash[id]; 4322 if (!report) 4323 return 0; 4324 4325 return report->field[0]->report_count + 1; 4326 } 4327 4328 static u8 hidpp_validate_device(struct hid_device *hdev) 4329 { 4330 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 4331 int id, report_length; 4332 u8 supported_reports = 0; 4333 4334 id = REPORT_ID_HIDPP_SHORT; 4335 report_length = hidpp_get_report_length(hdev, id); 4336 if (report_length) { 4337 if (report_length < HIDPP_REPORT_SHORT_LENGTH) 4338 goto bad_device; 4339 4340 supported_reports |= HIDPP_REPORT_SHORT_SUPPORTED; 4341 } 4342 4343 id = REPORT_ID_HIDPP_LONG; 4344 report_length = hidpp_get_report_length(hdev, id); 4345 if (report_length) { 4346 if (report_length < HIDPP_REPORT_LONG_LENGTH) 4347 goto bad_device; 4348 4349 supported_reports |= HIDPP_REPORT_LONG_SUPPORTED; 4350 } 4351 4352 id = REPORT_ID_HIDPP_VERY_LONG; 4353 report_length = hidpp_get_report_length(hdev, id); 4354 if (report_length) { 4355 if (report_length < HIDPP_REPORT_LONG_LENGTH || 4356 report_length > HIDPP_REPORT_VERY_LONG_MAX_LENGTH) 4357 goto bad_device; 4358 4359 supported_reports |= HIDPP_REPORT_VERY_LONG_SUPPORTED; 4360 hidpp->very_long_report_length = report_length; 4361 } 4362 4363 return supported_reports; 4364 4365 bad_device: 4366 hid_warn(hdev, "not enough values in hidpp report %d\n", id); 4367 return false; 4368 } 4369 4370 static bool hidpp_application_equals(struct hid_device *hdev, 4371 unsigned int application) 4372 { 4373 struct list_head *report_list; 4374 struct hid_report *report; 4375 4376 report_list = &hdev->report_enum[HID_INPUT_REPORT].report_list; 4377 report = list_first_entry_or_null(report_list, struct hid_report, list); 4378 return report && report->application == application; 4379 } 4380 4381 static int hidpp_probe(struct hid_device *hdev, const struct hid_device_id *id) 4382 { 4383 struct hidpp_device *hidpp; 4384 int ret; 4385 unsigned int connect_mask = HID_CONNECT_DEFAULT; 4386 4387 /* report_fixup needs drvdata to be set before we call hid_parse */ 4388 hidpp = devm_kzalloc(&hdev->dev, sizeof(*hidpp), GFP_KERNEL); 4389 if (!hidpp) 4390 return -ENOMEM; 4391 4392 hidpp->hid_dev = hdev; 4393 hidpp->name = hdev->name; 4394 hidpp->quirks = id->driver_data; 4395 hid_set_drvdata(hdev, hidpp); 4396 4397 ret = hid_parse(hdev); 4398 if (ret) { 4399 hid_err(hdev, "%s:parse failed\n", __func__); 4400 return ret; 4401 } 4402 4403 /* 4404 * Make sure the device is HID++ capable, otherwise treat as generic HID 4405 */ 4406 hidpp->supported_reports = hidpp_validate_device(hdev); 4407 4408 if (!hidpp->supported_reports) { 4409 hid_set_drvdata(hdev, NULL); 4410 devm_kfree(&hdev->dev, hidpp); 4411 return hid_hw_start(hdev, HID_CONNECT_DEFAULT); 4412 } 4413 4414 if (id->group == HID_GROUP_LOGITECH_27MHZ_DEVICE && 4415 hidpp_application_equals(hdev, HID_GD_MOUSE)) 4416 hidpp->quirks |= HIDPP_QUIRK_HIDPP_WHEELS | 4417 HIDPP_QUIRK_HIDPP_EXTRA_MOUSE_BTNS; 4418 4419 if (id->group == HID_GROUP_LOGITECH_27MHZ_DEVICE && 4420 hidpp_application_equals(hdev, HID_GD_KEYBOARD)) 4421 hidpp->quirks |= HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS; 4422 4423 if (hidpp->quirks & HIDPP_QUIRK_CLASS_WTP) { 4424 ret = wtp_allocate(hdev, id); 4425 if (ret) 4426 return ret; 4427 } else if (hidpp->quirks & HIDPP_QUIRK_CLASS_K400) { 4428 ret = k400_allocate(hdev); 4429 if (ret) 4430 return ret; 4431 } 4432 4433 INIT_WORK(&hidpp->work, hidpp_connect_event); 4434 mutex_init(&hidpp->send_mutex); 4435 init_waitqueue_head(&hidpp->wait); 4436 4437 /* indicates we are handling the battery properties in the kernel */ 4438 ret = sysfs_create_group(&hdev->dev.kobj, &ps_attribute_group); 4439 if (ret) 4440 hid_warn(hdev, "Cannot allocate sysfs group for %s\n", 4441 hdev->name); 4442 4443 /* 4444 * First call hid_hw_start(hdev, 0) to allow IO without connecting any 4445 * hid subdrivers (hid-input, hidraw). This allows retrieving the dev's 4446 * name and serial number and store these in hdev->name and hdev->uniq, 4447 * before the hid-input and hidraw drivers expose these to userspace. 4448 */ 4449 ret = hid_hw_start(hdev, 0); 4450 if (ret) { 4451 hid_err(hdev, "hw start failed\n"); 4452 goto hid_hw_start_fail; 4453 } 4454 4455 ret = hid_hw_open(hdev); 4456 if (ret < 0) { 4457 dev_err(&hdev->dev, "%s:hid_hw_open returned error:%d\n", 4458 __func__, ret); 4459 goto hid_hw_open_fail; 4460 } 4461 4462 /* Allow incoming packets */ 4463 hid_device_io_start(hdev); 4464 4465 /* Get name + serial, store in hdev->name + hdev->uniq */ 4466 if (id->group == HID_GROUP_LOGITECH_DJ_DEVICE) 4467 hidpp_unifying_init(hidpp); 4468 else 4469 hidpp_non_unifying_init(hidpp); 4470 4471 if (hidpp->quirks & HIDPP_QUIRK_DELAYED_INIT) 4472 connect_mask &= ~HID_CONNECT_HIDINPUT; 4473 4474 /* Now export the actual inputs and hidraw nodes to the world */ 4475 hid_device_io_stop(hdev); 4476 ret = hid_connect(hdev, connect_mask); 4477 if (ret) { 4478 hid_err(hdev, "%s:hid_connect returned error %d\n", __func__, ret); 4479 goto hid_hw_init_fail; 4480 } 4481 4482 /* Check for connected devices now that incoming packets will not be disabled again */ 4483 hid_device_io_start(hdev); 4484 schedule_work(&hidpp->work); 4485 flush_work(&hidpp->work); 4486 4487 if (hidpp->quirks & HIDPP_QUIRK_CLASS_G920) { 4488 struct hidpp_ff_private_data data; 4489 4490 ret = g920_get_config(hidpp, &data); 4491 if (!ret) 4492 ret = hidpp_ff_init(hidpp, &data); 4493 4494 if (ret) 4495 hid_warn(hidpp->hid_dev, 4496 "Unable to initialize force feedback support, errno %d\n", 4497 ret); 4498 } 4499 4500 /* 4501 * This relies on logi_dj_ll_close() being a no-op so that DJ connection 4502 * events will still be received. 4503 */ 4504 hid_hw_close(hdev); 4505 return ret; 4506 4507 hid_hw_init_fail: 4508 hid_hw_close(hdev); 4509 hid_hw_open_fail: 4510 hid_hw_stop(hdev); 4511 hid_hw_start_fail: 4512 sysfs_remove_group(&hdev->dev.kobj, &ps_attribute_group); 4513 cancel_work_sync(&hidpp->work); 4514 mutex_destroy(&hidpp->send_mutex); 4515 return ret; 4516 } 4517 4518 static void hidpp_remove(struct hid_device *hdev) 4519 { 4520 struct hidpp_device *hidpp = hid_get_drvdata(hdev); 4521 4522 if (!hidpp) 4523 return hid_hw_stop(hdev); 4524 4525 sysfs_remove_group(&hdev->dev.kobj, &ps_attribute_group); 4526 4527 hid_hw_stop(hdev); 4528 cancel_work_sync(&hidpp->work); 4529 mutex_destroy(&hidpp->send_mutex); 4530 } 4531 4532 #define LDJ_DEVICE(product) \ 4533 HID_DEVICE(BUS_USB, HID_GROUP_LOGITECH_DJ_DEVICE, \ 4534 USB_VENDOR_ID_LOGITECH, (product)) 4535 4536 #define L27MHZ_DEVICE(product) \ 4537 HID_DEVICE(BUS_USB, HID_GROUP_LOGITECH_27MHZ_DEVICE, \ 4538 USB_VENDOR_ID_LOGITECH, (product)) 4539 4540 static const struct hid_device_id hidpp_devices[] = { 4541 { /* wireless touchpad */ 4542 LDJ_DEVICE(0x4011), 4543 .driver_data = HIDPP_QUIRK_CLASS_WTP | HIDPP_QUIRK_DELAYED_INIT | 4544 HIDPP_QUIRK_WTP_PHYSICAL_BUTTONS }, 4545 { /* wireless touchpad T650 */ 4546 LDJ_DEVICE(0x4101), 4547 .driver_data = HIDPP_QUIRK_CLASS_WTP | HIDPP_QUIRK_DELAYED_INIT }, 4548 { /* wireless touchpad T651 */ 4549 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 4550 USB_DEVICE_ID_LOGITECH_T651), 4551 .driver_data = HIDPP_QUIRK_CLASS_WTP | HIDPP_QUIRK_DELAYED_INIT }, 4552 { /* Mouse Logitech Anywhere MX */ 4553 LDJ_DEVICE(0x1017), .driver_data = HIDPP_QUIRK_HI_RES_SCROLL_1P0 }, 4554 { /* Mouse logitech M560 */ 4555 LDJ_DEVICE(0x402d), 4556 .driver_data = HIDPP_QUIRK_DELAYED_INIT | HIDPP_QUIRK_CLASS_M560 }, 4557 { /* Mouse Logitech M705 (firmware RQM17) */ 4558 LDJ_DEVICE(0x101b), .driver_data = HIDPP_QUIRK_HI_RES_SCROLL_1P0 }, 4559 { /* Mouse Logitech Performance MX */ 4560 LDJ_DEVICE(0x101a), .driver_data = HIDPP_QUIRK_HI_RES_SCROLL_1P0 }, 4561 { /* Keyboard logitech K400 */ 4562 LDJ_DEVICE(0x4024), 4563 .driver_data = HIDPP_QUIRK_CLASS_K400 }, 4564 { /* Solar Keyboard Logitech K750 */ 4565 LDJ_DEVICE(0x4002), 4566 .driver_data = HIDPP_QUIRK_CLASS_K750 }, 4567 { /* Keyboard MX5000 (Bluetooth-receiver in HID proxy mode) */ 4568 LDJ_DEVICE(0xb305), 4569 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4570 { /* Dinovo Edge (Bluetooth-receiver in HID proxy mode) */ 4571 LDJ_DEVICE(0xb309), 4572 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4573 { /* Keyboard MX5500 (Bluetooth-receiver in HID proxy mode) */ 4574 LDJ_DEVICE(0xb30b), 4575 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4576 4577 { LDJ_DEVICE(HID_ANY_ID) }, 4578 4579 { /* Keyboard LX501 (Y-RR53) */ 4580 L27MHZ_DEVICE(0x0049), 4581 .driver_data = HIDPP_QUIRK_KBD_ZOOM_WHEEL }, 4582 { /* Keyboard MX3000 (Y-RAM74) */ 4583 L27MHZ_DEVICE(0x0057), 4584 .driver_data = HIDPP_QUIRK_KBD_SCROLL_WHEEL }, 4585 { /* Keyboard MX3200 (Y-RAV80) */ 4586 L27MHZ_DEVICE(0x005c), 4587 .driver_data = HIDPP_QUIRK_KBD_ZOOM_WHEEL }, 4588 { /* S510 Media Remote */ 4589 L27MHZ_DEVICE(0x00fe), 4590 .driver_data = HIDPP_QUIRK_KBD_SCROLL_WHEEL }, 4591 4592 { L27MHZ_DEVICE(HID_ANY_ID) }, 4593 4594 { /* Logitech G403 Wireless Gaming Mouse over USB */ 4595 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC082) }, 4596 { /* Logitech G502 Lightspeed Wireless Gaming Mouse over USB */ 4597 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC08D) }, 4598 { /* Logitech G703 Gaming Mouse over USB */ 4599 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC087) }, 4600 { /* Logitech G703 Hero Gaming Mouse over USB */ 4601 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC090) }, 4602 { /* Logitech G900 Gaming Mouse over USB */ 4603 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC081) }, 4604 { /* Logitech G903 Gaming Mouse over USB */ 4605 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC086) }, 4606 { /* Logitech G Pro Gaming Mouse over USB */ 4607 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC088) }, 4608 { /* MX Vertical over USB */ 4609 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC08A) }, 4610 { /* Logitech G703 Hero Gaming Mouse over USB */ 4611 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC090) }, 4612 { /* Logitech G903 Hero Gaming Mouse over USB */ 4613 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC091) }, 4614 { /* Logitech G915 TKL Keyboard over USB */ 4615 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC343) }, 4616 { /* Logitech G920 Wheel over USB */ 4617 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_G920_WHEEL), 4618 .driver_data = HIDPP_QUIRK_CLASS_G920 | HIDPP_QUIRK_FORCE_OUTPUT_REPORTS}, 4619 { /* Logitech G923 Wheel (Xbox version) over USB */ 4620 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, USB_DEVICE_ID_LOGITECH_G923_XBOX_WHEEL), 4621 .driver_data = HIDPP_QUIRK_CLASS_G920 | HIDPP_QUIRK_FORCE_OUTPUT_REPORTS }, 4622 { /* Logitech G Pro X Superlight Gaming Mouse over USB */ 4623 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC094) }, 4624 { /* Logitech G Pro X Superlight 2 Gaming Mouse over USB */ 4625 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0xC09b) }, 4626 4627 { /* G935 Gaming Headset */ 4628 HID_USB_DEVICE(USB_VENDOR_ID_LOGITECH, 0x0a87), 4629 .driver_data = HIDPP_QUIRK_WIRELESS_STATUS }, 4630 4631 { /* MX5000 keyboard over Bluetooth */ 4632 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb305), 4633 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4634 { /* Dinovo Edge keyboard over Bluetooth */ 4635 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb309), 4636 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4637 { /* MX5500 keyboard over Bluetooth */ 4638 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb30b), 4639 .driver_data = HIDPP_QUIRK_HIDPP_CONSUMER_VENDOR_KEYS }, 4640 { /* Logitech G915 TKL keyboard over Bluetooth */ 4641 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb35f) }, 4642 { /* M-RCQ142 V470 Cordless Laser Mouse over Bluetooth */ 4643 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb008) }, 4644 { /* MX Master mouse over Bluetooth */ 4645 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb012) }, 4646 { /* M720 Triathlon mouse over Bluetooth */ 4647 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb015) }, 4648 { /* MX Master 2S mouse over Bluetooth */ 4649 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb019) }, 4650 { /* MX Ergo trackball over Bluetooth */ 4651 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb01d) }, 4652 { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb01e) }, 4653 { /* MX Vertical mouse over Bluetooth */ 4654 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb020) }, 4655 { /* Signature M650 over Bluetooth */ 4656 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb02a) }, 4657 { /* MX Master 3 mouse over Bluetooth */ 4658 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb023) }, 4659 { /* MX Anywhere 3 mouse over Bluetooth */ 4660 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb025) }, 4661 { /* MX Master 3S mouse over Bluetooth */ 4662 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb034) }, 4663 { /* MX Anywhere 3SB mouse over Bluetooth */ 4664 HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_LOGITECH, 0xb038) }, 4665 {} 4666 }; 4667 4668 MODULE_DEVICE_TABLE(hid, hidpp_devices); 4669 4670 static const struct hid_usage_id hidpp_usages[] = { 4671 { HID_GD_WHEEL, EV_REL, REL_WHEEL_HI_RES }, 4672 { HID_ANY_ID - 1, HID_ANY_ID - 1, HID_ANY_ID - 1} 4673 }; 4674 4675 static struct hid_driver hidpp_driver = { 4676 .name = "logitech-hidpp-device", 4677 .id_table = hidpp_devices, 4678 .report_fixup = hidpp_report_fixup, 4679 .probe = hidpp_probe, 4680 .remove = hidpp_remove, 4681 .raw_event = hidpp_raw_event, 4682 .usage_table = hidpp_usages, 4683 .event = hidpp_event, 4684 .input_configured = hidpp_input_configured, 4685 .input_mapping = hidpp_input_mapping, 4686 .input_mapped = hidpp_input_mapped, 4687 }; 4688 4689 module_hid_driver(hidpp_driver); 4690