Input: alps - report V2 Dualpoint Stick events via the right evdev node

On V2 devices the DualPoint Stick reports bare packets, these should be
reported via the "AlpsPS/2 ALPS DualPoint Stick" dev2 evdev node, which also
has the INPUT_PROP_POINTING_STICK propbit set.

Note that since there is no way to distinguish these packets from an external
PS/2 mouse (insofar as these laptops have an external PS/2 port) this means
that we will be reporting PS/2 mouse events via this evdev node too, as we've
been doing in kernel 3.19 and older.

This has been tested on a Dell Latitude D620 and a Dell Latitude E6400,
which both have a V2 touchpad + a DualPoint Stick which reports bare packets.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Reviewed-by: Pali Rohár <pali.rohar@gmail.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>

authored by Hans de Goede and committed by Dmitry Torokhov e3a79212 59c30afb

Changed files
+6 -1
drivers
input
mouse
+6 -1
drivers/input/mouse/alps.c
··· 1161 1161 struct alps_data *priv = psmouse->private; 1162 1162 struct input_dev *dev; 1163 1163 1164 - if (unlikely(IS_ERR_OR_NULL(priv->dev3))) { 1164 + /* Figure out which device to use to report the bare packet */ 1165 + if (priv->proto_version == ALPS_PROTO_V2 && 1166 + (priv->flags & ALPS_DUALPOINT)) { 1167 + /* On V2 devices the DualPoint Stick reports bare packets */ 1168 + dev = priv->dev2; 1169 + } else if (unlikely(IS_ERR_OR_NULL(priv->dev3))) { 1165 1170 /* Register dev3 mouse if we received PS/2 packet first time */ 1166 1171 if (!IS_ERR(priv->dev3)) 1167 1172 psmouse_queue_work(psmouse, &priv->dev3_register_work,