[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250226182753.257559-1-ayaanmirzabaig85@gmail.com>
Date: Wed, 26 Feb 2025 23:57:52 +0530
From: Ayaan Mirza Baig <ayaanmirzabaig85@...il.com>
To: gregkh@...uxfoundation.org
Cc: dakr@...nel.org,
linux-kernel@...r.kernel.org,
Ayaan Mirza Baig <ayaanmirzabaig85@...il.com>
Subject: [PATCH] drivers/base: fix iterator cleanup in attribute_container
This patch addresses a long-standing FIXME in
dirvers/base/attribute_container.c, where the function
failed to call klist_iter_exit() before breaking
out of the loop when a matching class device was found.
The code is now refactored to use a goto-based cleanup approach
that ensure klist_iter_exit() is invoked exactly once regardless
of the exit path.
In addition, checkpatch.pl warnings were fixed along with this change.
Tested on a minimal Debian System in QEMU with GDB attached.
No regressions or errors were observed.
Signed-off-by: Ayaan Mirza Baig <ayaanmirzabaig85@...il.com>
---
drivers/base/attribute_container.c | 15 +++++++--------
1 file changed, 7 insertions(+), 8 deletions(-)
diff --git a/drivers/base/attribute_container.c b/drivers/base/attribute_container.c
index b6f941a6ab69..1e7af328dd49 100644
--- a/drivers/base/attribute_container.c
+++ b/drivers/base/attribute_container.c
@@ -5,7 +5,7 @@
* Copyright (c) 2005 - James Bottomley <James.Bottomley@...eleye.com>
*
* The basic idea here is to enable a device to be attached to an
- * aritrary numer of classes without having to allocate storage for them.
+ * aritrary number of classes without having to allocate storage for them.
* Instead, the contained classes select the devices they need to attach
* to via a matching function.
*/
@@ -21,7 +21,8 @@
#include "base.h"
/* This is a private structure used to tie the classdev and the
- * container .. it should never be visible outside this file */
+ * container .. it should never be visible outside this file
+ */
struct internal_container {
struct klist_node node;
struct attribute_container *cont;
@@ -42,7 +43,6 @@ static void internal_container_klist_put(struct klist_node *n)
put_device(&ic->classdev);
}
-
/**
* attribute_container_classdev_to_container - given a classdev, return the container
*
@@ -449,7 +449,7 @@ attribute_container_remove_attrs(struct device *classdev)
if (cont->grp) {
sysfs_remove_group(&classdev->kobj, cont->grp);
- return ;
+ return;
}
for (i = 0; attrs[i]; i++)
@@ -491,12 +491,11 @@ attribute_container_find_class_device(struct attribute_container *cont,
klist_for_each_entry(ic, &cont->containers, node, &iter) {
if (ic->classdev.parent == dev) {
cdev = &ic->classdev;
- /* FIXME: must exit iterator then break */
- klist_iter_exit(&iter);
- break;
+ goto out;
}
}
-
+out:
+ klist_iter_exit(&iter);
return cdev;
}
EXPORT_SYMBOL_GPL(attribute_container_find_class_device);
--
2.47.1
Powered by blists - more mailing lists