On Fri, Jun 06, 2014 at 04:08:15PM +0200, Hans de Goede wrote: > At least the Dell Vostro 5470 elantech *clickpad* reports right button > clicks when clicked in the right bottom area: > > https://bugzilla.redhat.com/show_bug.cgi?id=1103528 > > This is different from how (elantech) clickpads normally operate, > normally no matter where the user clicks on the pad the pad always reports > a left button event, since there is only 1 hardware button beneath the path. > > It looks like Dell has put 2 buttons under the pad, one under each bottom > corner, causing this. > > Since this however still clearly is a real clickpad hardware-wise, we still > want to report it as such to userspace, so that things like finger movement > in the bottom area can be properly ignored as it should be on clickpads. > > So deal with this weirdness by simply mapping a right click to a left click > on elantech clickpads. As an added advantage this is something which we can > simply do on all elantech clickpads, so no need to add special quirks for > this weird model. > > Reported-and-tested-by: Elder Marco <eldermarco@xxxxxxxxx> > Cc: stable@xxxxxxxxxxxxxxx > Signed-off-by: Hans de Goede <hdegoede@xxxxxxxxxx> Applied, thank you. > --- > drivers/input/mouse/elantech.c | 22 ++++++++++++++++++---- > 1 file changed, 18 insertions(+), 4 deletions(-) > > diff --git a/drivers/input/mouse/elantech.c b/drivers/input/mouse/elantech.c > index 4d79821..846926d 100644 > --- a/drivers/input/mouse/elantech.c > +++ b/drivers/input/mouse/elantech.c > @@ -473,8 +473,15 @@ static void elantech_report_absolute_v3(struct psmouse *psmouse, > input_report_key(dev, BTN_TOOL_FINGER, fingers == 1); > input_report_key(dev, BTN_TOOL_DOUBLETAP, fingers == 2); > input_report_key(dev, BTN_TOOL_TRIPLETAP, fingers == 3); > - input_report_key(dev, BTN_LEFT, packet[0] & 0x01); > - input_report_key(dev, BTN_RIGHT, packet[0] & 0x02); > + > + /* For clickpads map both buttons to BTN_LEFT */ > + if (etd->fw_version & 0x001000) { > + input_report_key(dev, BTN_LEFT, packet[0] & 0x03); > + } else { > + input_report_key(dev, BTN_LEFT, packet[0] & 0x01); > + input_report_key(dev, BTN_RIGHT, packet[0] & 0x02); > + } > + > input_report_abs(dev, ABS_PRESSURE, pres); > input_report_abs(dev, ABS_TOOL_WIDTH, width); > > @@ -484,10 +491,17 @@ static void elantech_report_absolute_v3(struct psmouse *psmouse, > static void elantech_input_sync_v4(struct psmouse *psmouse) > { > struct input_dev *dev = psmouse->dev; > + struct elantech_data *etd = psmouse->private; > unsigned char *packet = psmouse->packet; > > - input_report_key(dev, BTN_LEFT, packet[0] & 0x01); > - input_report_key(dev, BTN_RIGHT, packet[0] & 0x02); > + /* For clickpads map both buttons to BTN_LEFT */ > + if (etd->fw_version & 0x001000) { > + input_report_key(dev, BTN_LEFT, packet[0] & 0x03); > + } else { > + 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_sync(dev); > } > -- > 2.0.0 > -- Dmitry -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html