提交 69481059 编写于 作者: H Hongye Yuan 提交者: Benjamin Tissoires

HID: sony: Transform one-time SHANWAN check into quirk

Transform the one-time check for a SHANWAN PS3 clone gamepad into a
quirk, to avoid doing the same string comparison in multiple places.
Signed-off-by: NHongye Yuan <outmatch@gmail.com>
Reviewed-by: NBastien Nocera <hadess@hadess.net>
Signed-off-by: NBenjamin Tissoires <benjamin.tissoires@redhat.com>
上级 cf26057a
...@@ -58,6 +58,7 @@ ...@@ -58,6 +58,7 @@
#define FUTUREMAX_DANCE_MAT BIT(13) #define FUTUREMAX_DANCE_MAT BIT(13)
#define NSG_MR5U_REMOTE_BT BIT(14) #define NSG_MR5U_REMOTE_BT BIT(14)
#define NSG_MR7U_REMOTE_BT BIT(15) #define NSG_MR7U_REMOTE_BT BIT(15)
#define SHANWAN_GAMEPAD BIT(16)
#define SIXAXIS_CONTROLLER (SIXAXIS_CONTROLLER_USB | SIXAXIS_CONTROLLER_BT) #define SIXAXIS_CONTROLLER (SIXAXIS_CONTROLLER_USB | SIXAXIS_CONTROLLER_BT)
#define MOTION_CONTROLLER (MOTION_CONTROLLER_USB | MOTION_CONTROLLER_BT) #define MOTION_CONTROLLER (MOTION_CONTROLLER_USB | MOTION_CONTROLLER_BT)
...@@ -1490,6 +1491,7 @@ static int sony_register_sensors(struct sony_sc *sc) ...@@ -1490,6 +1491,7 @@ static int sony_register_sensors(struct sony_sc *sc)
*/ */
static int sixaxis_set_operational_usb(struct hid_device *hdev) static int sixaxis_set_operational_usb(struct hid_device *hdev)
{ {
struct sony_sc *sc = hid_get_drvdata(hdev);
const int buf_size = const int buf_size =
max(SIXAXIS_REPORT_0xF2_SIZE, SIXAXIS_REPORT_0xF5_SIZE); max(SIXAXIS_REPORT_0xF2_SIZE, SIXAXIS_REPORT_0xF5_SIZE);
u8 *buf; u8 *buf;
...@@ -1519,14 +1521,15 @@ static int sixaxis_set_operational_usb(struct hid_device *hdev) ...@@ -1519,14 +1521,15 @@ static int sixaxis_set_operational_usb(struct hid_device *hdev)
/* /*
* But the USB interrupt would cause SHANWAN controllers to * But the USB interrupt would cause SHANWAN controllers to
* start rumbling non-stop. * start rumbling non-stop, so skip step 3 for these controllers.
*/ */
if (strcmp(hdev->name, "SHANWAN PS3 GamePad")) { if (sc->quirks & SHANWAN_GAMEPAD)
ret = hid_hw_output_report(hdev, buf, 1); goto out;
if (ret < 0) {
hid_info(hdev, "can't set operational mode: step 3, ignoring\n"); ret = hid_hw_output_report(hdev, buf, 1);
ret = 0; if (ret < 0) {
} hid_info(hdev, "can't set operational mode: step 3, ignoring\n");
ret = 0;
} }
out: out:
...@@ -2811,6 +2814,9 @@ static int sony_probe(struct hid_device *hdev, const struct hid_device_id *id) ...@@ -2811,6 +2814,9 @@ static int sony_probe(struct hid_device *hdev, const struct hid_device_id *id)
if (!strcmp(hdev->name, "FutureMax Dance Mat")) if (!strcmp(hdev->name, "FutureMax Dance Mat"))
quirks |= FUTUREMAX_DANCE_MAT; quirks |= FUTUREMAX_DANCE_MAT;
if (!strcmp(hdev->name, "SHANWAN PS3 GamePad"))
quirks |= SHANWAN_GAMEPAD;
sc = devm_kzalloc(&hdev->dev, sizeof(*sc), GFP_KERNEL); sc = devm_kzalloc(&hdev->dev, sizeof(*sc), GFP_KERNEL);
if (sc == NULL) { if (sc == NULL) {
hid_err(hdev, "can't alloc sony descriptor\n"); hid_err(hdev, "can't alloc sony descriptor\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册