summaryrefslogtreecommitdiffstats
path: root/drivers/hid
diff options
context:
space:
mode:
authorDmitry Torokhov <dmitry.torokhov@gmail.com>2022-02-25 17:18:58 -0800
committerJiri Kosina <jkosina@suse.cz>2022-03-01 15:31:17 +0100
commitcc71d37fd1f11e0495b1cf580909ebea37eaa886 (patch)
tree3947d96fc7680fdd5df7ce11c474ee59bcd9db39 /drivers/hid
parentfc3ef2e3297b3c0e2006b5d7b3d66965e3392036 (diff)
downloadlinux-cc71d37fd1f11e0495b1cf580909ebea37eaa886.tar.gz
linux-cc71d37fd1f11e0495b1cf580909ebea37eaa886.tar.xz
HID: vivaldi: fix sysfs attributes leak
The driver creates the top row map sysfs attribute in input_configured() method; unfortunately we do not have a callback that is executed when HID interface is unbound, thus we are leaking these sysfs attributes, for example when device is disconnected. To fix it let's switch to managed version of adding sysfs attributes which will ensure that they are destroyed when the driver is unbound. Fixes: 14c9c014babe ("HID: add vivaldi HID driver") Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> Tested-by: Stephen Boyd <swboyd@chromium.org> Reviewed-by: Stephen Boyd <swboyd@chromium.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid')
-rw-r--r--drivers/hid/hid-vivaldi.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/hid/hid-vivaldi.c b/drivers/hid/hid-vivaldi.c
index efa6140915f4..42ceb2058a09 100644
--- a/drivers/hid/hid-vivaldi.c
+++ b/drivers/hid/hid-vivaldi.c
@@ -144,7 +144,7 @@ out:
static int vivaldi_input_configured(struct hid_device *hdev,
struct hid_input *hidinput)
{
- return sysfs_create_group(&hdev->dev.kobj, &input_attribute_group);
+ return devm_device_add_group(&hdev->dev, &input_attribute_group);
}
static const struct hid_device_id vivaldi_table[] = {