Commit 411a20db authored by Oleksandr Natalenko's avatar Oleksandr Natalenko Committed by Jiri Kosina

HID: logitech-hidpp: Do not flood kernel log

Since commit 680ee411 ("HID: logitech-hidpp: Fix connect event race")
the following messages appear in the kernel log from time to time:

logitech-hidpp-device 0003:046D:408A.0005: HID++ 4.5 device connected.
logitech-hidpp-device 0003:046D:408A.0005: HID++ 4.5 device connected.
logitech-hidpp-device 0003:046D:4051.0006: Disconnected
logitech-hidpp-device 0003:046D:408A.0005: Disconnected

As discussed, print the first per-device "device connected" message
at info level, demoting subsequent messages to debug level. Also,
demote the "Disconnected message" to debug level unconditionally.

Link: https://lore.kernel.org/lkml/3277085.44csPzL39Z@natalenko.name/Signed-off-by: default avatarOleksandr Natalenko <oleksandr@natalenko.name>
Reviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarJiri Kosina <jkosina@suse.com>
parent 764ad6b0
...@@ -203,6 +203,8 @@ struct hidpp_device { ...@@ -203,6 +203,8 @@ struct hidpp_device {
struct hidpp_scroll_counter vertical_wheel_counter; struct hidpp_scroll_counter vertical_wheel_counter;
u8 wireless_feature_index; u8 wireless_feature_index;
bool connected_once;
}; };
/* HID++ 1.0 error codes */ /* HID++ 1.0 error codes */
...@@ -988,8 +990,13 @@ static int hidpp_root_get_protocol_version(struct hidpp_device *hidpp) ...@@ -988,8 +990,13 @@ static int hidpp_root_get_protocol_version(struct hidpp_device *hidpp)
hidpp->protocol_minor = response.rap.params[1]; hidpp->protocol_minor = response.rap.params[1];
print_version: print_version:
if (!hidpp->connected_once) {
hid_info(hidpp->hid_dev, "HID++ %u.%u device connected.\n", hid_info(hidpp->hid_dev, "HID++ %u.%u device connected.\n",
hidpp->protocol_major, hidpp->protocol_minor); hidpp->protocol_major, hidpp->protocol_minor);
hidpp->connected_once = true;
} else
hid_dbg(hidpp->hid_dev, "HID++ %u.%u device connected.\n",
hidpp->protocol_major, hidpp->protocol_minor);
return 0; return 0;
} }
...@@ -4184,7 +4191,7 @@ static void hidpp_connect_event(struct work_struct *work) ...@@ -4184,7 +4191,7 @@ static void hidpp_connect_event(struct work_struct *work)
/* Get device version to check if it is connected */ /* Get device version to check if it is connected */
ret = hidpp_root_get_protocol_version(hidpp); ret = hidpp_root_get_protocol_version(hidpp);
if (ret) { if (ret) {
hid_info(hidpp->hid_dev, "Disconnected\n"); hid_dbg(hidpp->hid_dev, "Disconnected\n");
if (hidpp->battery.ps) { if (hidpp->battery.ps) {
hidpp->battery.online = false; hidpp->battery.online = false;
hidpp->battery.status = POWER_SUPPLY_STATUS_UNKNOWN; hidpp->battery.status = POWER_SUPPLY_STATUS_UNKNOWN;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment