HID: surface-hid: Use correct event registry for managing HID events
authorMaximilian Luz <luzmaximilian@gmail.com>
Thu, 21 Oct 2021 13:09:03 +0000 (15:09 +0200)
committerHans de Goede <hdegoede@redhat.com>
Fri, 22 Oct 2021 08:54:51 +0000 (10:54 +0200)
Until now, we have only ever seen the REG-category registry being used
on devices addressed with target ID 2. In fact, we have only ever seen
Surface Aggregator Module (SAM) HID devices with target ID 2. For those
devices, the registry also has to be addressed with target ID 2.

Some devices, like the new Surface Laptop Studio, however, address their
HID devices on target ID 1. As a result of this, any target ID 2
commands time out. This includes event management commands addressed to
the target ID 2 REG-category registry. For these devices, the registry
has to be addressed via target ID 1 instead.

We therefore assume that the target ID of the registry to be used
depends on the target ID of the respective device. Implement this
accordingly.

Note that we currently allow the surface HID driver to only load against
devices with target ID 2, so these timeouts are not happening (yet).
This is just a preparation step before we allow the driver to load
against all target IDs.

Cc: stable@vger.kernel.org # 5.14+
Signed-off-by: Maximilian Luz <luzmaximilian@gmail.com>
Acked-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Link: https://lore.kernel.org/r/20211021130904.862610-3-luzmaximilian@gmail.com
Reviewed-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
drivers/hid/surface-hid/surface_hid.c
include/linux/surface_aggregator/controller.h

index a3a70e4f3f6c97c82bd02b0e3bc28c75ee6d4b74..daa452367c0b22801cac5ecdc559b74cd0ee52ea 100644 (file)
@@ -209,7 +209,7 @@ static int surface_hid_probe(struct ssam_device *sdev)
 
        shid->notif.base.priority = 1;
        shid->notif.base.fn = ssam_hid_event_fn;
-       shid->notif.event.reg = SSAM_EVENT_REGISTRY_REG;
+       shid->notif.event.reg = SSAM_EVENT_REGISTRY_REG(sdev->uid.target);
        shid->notif.event.id.target_category = sdev->uid.category;
        shid->notif.event.id.instance = sdev->uid.instance;
        shid->notif.event.mask = SSAM_EVENT_MASK_STRICT;
index 068e1982ad37133db28a431470c6231d3b319ba3..74bfdffaf7b0e05dc10f55509a8a5064675abd73 100644 (file)
@@ -792,8 +792,8 @@ enum ssam_event_mask {
 #define SSAM_EVENT_REGISTRY_KIP        \
        SSAM_EVENT_REGISTRY(SSAM_SSH_TC_KIP, 0x02, 0x27, 0x28)
 
-#define SSAM_EVENT_REGISTRY_REG \
-       SSAM_EVENT_REGISTRY(SSAM_SSH_TC_REG, 0x02, 0x01, 0x02)
+#define SSAM_EVENT_REGISTRY_REG(tid)\
+       SSAM_EVENT_REGISTRY(SSAM_SSH_TC_REG, tid, 0x01, 0x02)
 
 /**
  * enum ssam_event_notifier_flags - Flags for event notifiers.