Hi Benjamin, As dicussed here is v3 of my series to rework / cleanup the hidpp probing code. Note the $subject of the cover-letter is not entirely accurate anymore, but I kept it the same since this is the successor of series with the same subject. Changes in v3: - Call hid_connect() to connect the hid-input and hidraw drivers after retrieving the name + serial instead of restarting IO - Shuffle the series order to put patches with Fixes tags at the start - Squash 2 changes to G920 handling into one - Since probe() now no longer restarts IO the following patches have been dropped: "HID: logitech-hidpp: Add a hidpp_connect_and_start() helper" "HID: logitech-hidpp: Move the connected check to after restarting IO" "HID: logitech-hidpp: Avoid hidpp_connect_event() running while probe() restarts IO" - Add "HID: logitech-hidpp: Drop HIDPP_QUIRK_UNIFYING" Regards, Hans Hans de Goede (12): HID: logitech-hidpp: Don't restart IO, instead defer hid_connect() only HID: logitech-hidpp: Revert "Don't restart communication if not necessary" HID: logitech-hidpp: Move get_wireless_feature_index() check to hidpp_connect_event() HID: logitech-hidpp: Remove wtp_get_config() call from probe() HID: logitech-hidpp: Move g920_get_config() to just before hidpp_ff_init() HID: logitech-hidpp: Move hidpp_overwrite_name() to before connect check HID: logitech-hidpp: Add hidpp_non_unifying_init() helper HID: logitech-hidpp: Remove connected check for non-unifying devices HID: logitech-hidpp: Remove unused connected param from *_connect() HID: logitech-hidpp: Fix connect event race HID: logitech-hidpp: Drop delayed_work_cb() HID: logitech-hidpp: Drop HIDPP_QUIRK_UNIFYING drivers/hid/hid-logitech-hidpp.c | 173 +++++++++++-------------------- 1 file changed, 61 insertions(+), 112 deletions(-) -- 2.41.0