Skip to content

Commit 65b851a

Browse files
mayer-chJiri Kosina
authored andcommitted
HID: steelseries: preparation for adding SteelSeries Arctis 9 support
Refactor code and add calls to hid_hw_open/hid_hw_closed in preparation for adding support for the SteelSeries Arctis 9 headset. Signed-off-by: Christian Mayer <git@mayer-bgk.de> Reviewed-by: Bastien Nocera <hadess@hadess.net> Tested-by: Bastien Nocera <hadess@hadess.net> Signed-off-by: Jiri Kosina <jkosina@suse.com>
1 parent 2a770b4 commit 65b851a

File tree

1 file changed

+13
-6
lines changed

1 file changed

+13
-6
lines changed

drivers/hid/hid-steelseries.c

Lines changed: 13 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -377,20 +377,21 @@ static void steelseries_srws1_remove(struct hid_device *hdev)
377377
#define ARCTIS_1_BATTERY_RESPONSE_LEN 8
378378
static const char arctis_1_battery_request[] = { 0x06, 0x12 };
379379

380-
static int steelseries_headset_arctis_1_fetch_battery(struct hid_device *hdev)
380+
static int steelseries_headset_request_battery(struct hid_device *hdev,
381+
const char *request, size_t len)
381382
{
382383
u8 *write_buf;
383384
int ret;
384385

385386
/* Request battery information */
386-
write_buf = kmemdup(arctis_1_battery_request, sizeof(arctis_1_battery_request), GFP_KERNEL);
387+
write_buf = kmemdup(request, len, GFP_KERNEL);
387388
if (!write_buf)
388389
return -ENOMEM;
389390

390-
ret = hid_hw_raw_request(hdev, arctis_1_battery_request[0],
391-
write_buf, sizeof(arctis_1_battery_request),
391+
hid_dbg(hdev, "Sending battery request report");
392+
ret = hid_hw_raw_request(hdev, request[0], write_buf, len,
392393
HID_OUTPUT_REPORT, HID_REQ_SET_REPORT);
393-
if (ret < (int)sizeof(arctis_1_battery_request)) {
394+
if (ret < (int)len) {
394395
hid_err(hdev, "hid_hw_raw_request() failed with %d\n", ret);
395396
ret = -ENODATA;
396397
}
@@ -404,7 +405,8 @@ static void steelseries_headset_fetch_battery(struct hid_device *hdev)
404405
int ret = 0;
405406

406407
if (sd->quirks & STEELSERIES_ARCTIS_1)
407-
ret = steelseries_headset_arctis_1_fetch_battery(hdev);
408+
ret = steelseries_headset_request_battery(hdev,
409+
arctis_1_battery_request, sizeof(arctis_1_battery_request));
408410

409411
if (ret < 0)
410412
hid_dbg(hdev,
@@ -554,6 +556,10 @@ static int steelseries_probe(struct hid_device *hdev, const struct hid_device_id
554556
if (ret)
555557
return ret;
556558

559+
ret = hid_hw_open(hdev);
560+
if (ret)
561+
return ret;
562+
557563
if (steelseries_headset_battery_register(sd) < 0)
558564
hid_err(sd->hdev,
559565
"Failed to register battery for headset\n");
@@ -580,6 +586,7 @@ static void steelseries_remove(struct hid_device *hdev)
580586

581587
cancel_delayed_work_sync(&sd->battery_work);
582588

589+
hid_hw_close(hdev);
583590
hid_hw_stop(hdev);
584591
}
585592

0 commit comments

Comments
 (0)