|
@@ -486,6 +486,7 @@ static void elantech_input_sync_v4(struct psmouse *psmouse)
|
|
unsigned char *packet = psmouse->packet;
|
|
unsigned char *packet = psmouse->packet;
|
|
|
|
|
|
input_report_key(dev, BTN_LEFT, packet[0] & 0x01);
|
|
input_report_key(dev, BTN_LEFT, packet[0] & 0x01);
|
|
|
|
+ input_report_key(dev, BTN_RIGHT, packet[0] & 0x02);
|
|
input_mt_report_pointer_emulation(dev, true);
|
|
input_mt_report_pointer_emulation(dev, true);
|
|
input_sync(dev);
|
|
input_sync(dev);
|
|
}
|
|
}
|
|
@@ -983,6 +984,44 @@ static int elantech_get_resolution_v4(struct psmouse *psmouse,
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ * Advertise INPUT_PROP_BUTTONPAD for clickpads. The testing of bit 12 in
|
|
|
|
+ * fw_version for this is based on the following fw_version & caps table:
|
|
|
|
+ *
|
|
|
|
+ * Laptop-model: fw_version: caps: buttons:
|
|
|
|
+ * Acer S3 0x461f00 10, 13, 0e clickpad
|
|
|
|
+ * Acer S7-392 0x581f01 50, 17, 0d clickpad
|
|
|
|
+ * Acer V5-131 0x461f02 01, 16, 0c clickpad
|
|
|
|
+ * Acer V5-551 0x461f00 ? clickpad
|
|
|
|
+ * Asus K53SV 0x450f01 78, 15, 0c 2 hw buttons
|
|
|
|
+ * Asus G46VW 0x460f02 00, 18, 0c 2 hw buttons
|
|
|
|
+ * Asus G750JX 0x360f00 00, 16, 0c 2 hw buttons
|
|
|
|
+ * Asus UX31 0x361f00 20, 15, 0e clickpad
|
|
|
|
+ * Asus UX32VD 0x361f02 00, 15, 0e clickpad
|
|
|
|
+ * Avatar AVIU-145A2 0x361f00 ? clickpad
|
|
|
|
+ * Gigabyte U2442 0x450f01 58, 17, 0c 2 hw buttons
|
|
|
|
+ * Lenovo L430 0x350f02 b9, 15, 0c 2 hw buttons (*)
|
|
|
|
+ * Samsung NF210 0x150b00 78, 14, 0a 2 hw buttons
|
|
|
|
+ * Samsung NP770Z5E 0x575f01 10, 15, 0f clickpad
|
|
|
|
+ * Samsung NP700Z5B 0x361f06 21, 15, 0f clickpad
|
|
|
|
+ * Samsung NP900X3E-A02 0x575f03 ? clickpad
|
|
|
|
+ * Samsung NP-QX410 0x851b00 19, 14, 0c clickpad
|
|
|
|
+ * Samsung RC512 0x450f00 08, 15, 0c 2 hw buttons
|
|
|
|
+ * Samsung RF710 0x450f00 ? 2 hw buttons
|
|
|
|
+ * System76 Pangolin 0x250f01 ? 2 hw buttons
|
|
|
|
+ * (*) + 3 trackpoint buttons
|
|
|
|
+ */
|
|
|
|
+static void elantech_set_buttonpad_prop(struct psmouse *psmouse)
|
|
|
|
+{
|
|
|
|
+ struct input_dev *dev = psmouse->dev;
|
|
|
|
+ struct elantech_data *etd = psmouse->private;
|
|
|
|
+
|
|
|
|
+ if (etd->fw_version & 0x001000) {
|
|
|
|
+ __set_bit(INPUT_PROP_BUTTONPAD, dev->propbit);
|
|
|
|
+ __clear_bit(BTN_RIGHT, dev->keybit);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* Set the appropriate event bits for the input subsystem
|
|
* Set the appropriate event bits for the input subsystem
|
|
*/
|
|
*/
|
|
@@ -1026,6 +1065,8 @@ static int elantech_set_input_params(struct psmouse *psmouse)
|
|
__set_bit(INPUT_PROP_SEMI_MT, dev->propbit);
|
|
__set_bit(INPUT_PROP_SEMI_MT, dev->propbit);
|
|
/* fall through */
|
|
/* fall through */
|
|
case 3:
|
|
case 3:
|
|
|
|
+ if (etd->hw_version == 3)
|
|
|
|
+ elantech_set_buttonpad_prop(psmouse);
|
|
input_set_abs_params(dev, ABS_X, x_min, x_max, 0, 0);
|
|
input_set_abs_params(dev, ABS_X, x_min, x_max, 0, 0);
|
|
input_set_abs_params(dev, ABS_Y, y_min, y_max, 0, 0);
|
|
input_set_abs_params(dev, ABS_Y, y_min, y_max, 0, 0);
|
|
if (etd->reports_pressure) {
|
|
if (etd->reports_pressure) {
|
|
@@ -1047,9 +1088,7 @@ static int elantech_set_input_params(struct psmouse *psmouse)
|
|
*/
|
|
*/
|
|
psmouse_warn(psmouse, "couldn't query resolution data.\n");
|
|
psmouse_warn(psmouse, "couldn't query resolution data.\n");
|
|
}
|
|
}
|
|
- /* v4 is clickpad, with only one button. */
|
|
|
|
- __set_bit(INPUT_PROP_BUTTONPAD, dev->propbit);
|
|
|
|
- __clear_bit(BTN_RIGHT, dev->keybit);
|
|
|
|
|
|
+ elantech_set_buttonpad_prop(psmouse);
|
|
__set_bit(BTN_TOOL_QUADTAP, dev->keybit);
|
|
__set_bit(BTN_TOOL_QUADTAP, dev->keybit);
|
|
/* For X to recognize me as touchpad. */
|
|
/* For X to recognize me as touchpad. */
|
|
input_set_abs_params(dev, ABS_X, x_min, x_max, 0, 0);
|
|
input_set_abs_params(dev, ABS_X, x_min, x_max, 0, 0);
|