Commit c7ea5ed6 authored by Bryan O'Donoghue's avatar Bryan O'Donoghue Committed by Greg Kroah-Hartman

greybus: loopback: ensure debugfs entires are cleaned up on exit

bdd4bba4 ('greybus/loopback: add module level sys/debug fs data points')
added a debugfs entry attached to gb_dev but omitted the cleanup on gb_init
error and gb_exit. This patchs fixes the missing debugfs_remove().
Signed-off-by: default avatarBryan O'Donoghue <bryan.odonoghue@linaro.org>
Reported-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 5f3e0d17
...@@ -34,6 +34,7 @@ struct gb_loopback_stats { ...@@ -34,6 +34,7 @@ struct gb_loopback_stats {
struct gb_loopback_device { struct gb_loopback_device {
struct dentry *root; struct dentry *root;
struct dentry *file;
u32 count; u32 count;
struct kfifo kfifo; struct kfifo kfifo;
...@@ -860,9 +861,9 @@ static int gb_loopback_connection_init(struct gb_connection *connection) ...@@ -860,9 +861,9 @@ static int gb_loopback_connection_init(struct gb_connection *connection)
if (!gb_dev.count) { if (!gb_dev.count) {
snprintf(name, sizeof(name), "raw_latency_endo0:%d", snprintf(name, sizeof(name), "raw_latency_endo0:%d",
connection->bundle->intf->module->module_id); connection->bundle->intf->module->module_id);
debugfs_create_file(name, S_IFREG | S_IRUGO, gb_dev.file = debugfs_create_file(name, S_IFREG | S_IRUGO,
gb_dev.root, &gb_dev, gb_dev.root, &gb_dev,
&gb_loopback_debugfs_dev_latency_ops); &gb_loopback_debugfs_dev_latency_ops);
retval = sysfs_create_groups(kobj, loopback_dev_groups); retval = sysfs_create_groups(kobj, loopback_dev_groups);
if (retval) if (retval)
goto out_sysfs; goto out_sysfs;
...@@ -925,8 +926,10 @@ static int gb_loopback_connection_init(struct gb_connection *connection) ...@@ -925,8 +926,10 @@ static int gb_loopback_connection_init(struct gb_connection *connection)
out_sysfs_conn: out_sysfs_conn:
sysfs_remove_groups(&connection->dev.kobj, loopback_con_groups); sysfs_remove_groups(&connection->dev.kobj, loopback_con_groups);
out_sysfs_dev: out_sysfs_dev:
if (!gb_dev.count) if (!gb_dev.count) {
sysfs_remove_groups(kobj, loopback_dev_groups); sysfs_remove_groups(kobj, loopback_dev_groups);
debugfs_remove(gb_dev.file);
}
debugfs_remove(gb->file); debugfs_remove(gb->file);
connection->private = NULL; connection->private = NULL;
out_sysfs: out_sysfs:
...@@ -950,8 +953,10 @@ static void gb_loopback_connection_exit(struct gb_connection *connection) ...@@ -950,8 +953,10 @@ static void gb_loopback_connection_exit(struct gb_connection *connection)
kfifo_free(&gb->kfifo_lat); kfifo_free(&gb->kfifo_lat);
kfifo_free(&gb->kfifo_ts); kfifo_free(&gb->kfifo_ts);
gb_dev.count--; gb_dev.count--;
if (!gb_dev.count) if (!gb_dev.count) {
sysfs_remove_groups(kobj, loopback_dev_groups); sysfs_remove_groups(kobj, loopback_dev_groups);
debugfs_remove(gb_dev.file);
}
sysfs_remove_groups(&connection->dev.kobj, loopback_con_groups); sysfs_remove_groups(&connection->dev.kobj, loopback_con_groups);
debugfs_remove(gb->file); debugfs_remove(gb->file);
list_del(&gb->entry); list_del(&gb->entry);
......
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