[PATCH 18/26] usb: gadget: legacy: remove using list iterator after loop body as a ptr

From: Jakob Koschel
Date: Sun Mar 06 2022 - 12:52:21 EST


If the list does not contain the expected element, the value of
list_for_each_entry() iterator will not point to a valid structure.
To avoid type confusion in such case, the list iterator
scope will be limited to list_for_each_entry() loop.

In preparation to limiting scope of a list iterator to the list traversal
loop, use a dedicated pointer to point to the found element [1].
Determining if an element was found is then simply checking if
the pointer is != NULL instead of using the potentially bogus pointer.

Link: https://lore.kernel.org/all/YhdfEIwI4EdtHdym@xxxxxxxxx/
Signed-off-by: Jakob Koschel <jakobkoschel@xxxxxxxxx>
---
drivers/usb/gadget/legacy/hid.c | 23 ++++++++++++-----------
1 file changed, 12 insertions(+), 11 deletions(-)

diff --git a/drivers/usb/gadget/legacy/hid.c b/drivers/usb/gadget/legacy/hid.c
index 3912cc805f3a..b7f1ff2ce951 100644
--- a/drivers/usb/gadget/legacy/hid.c
+++ b/drivers/usb/gadget/legacy/hid.c
@@ -134,7 +134,7 @@ static int hid_bind(struct usb_composite_dev *cdev)
{
struct usb_gadget *gadget = cdev->gadget;
struct list_head *tmp;
- struct hidg_func_node *n, *m;
+ struct hidg_func_node *n = NULL, *m, *tmp_n;
struct f_hid_opts *hid_opts;
int status, funcs = 0;

@@ -144,18 +144,19 @@ static int hid_bind(struct usb_composite_dev *cdev)
if (!funcs)
return -ENODEV;

- list_for_each_entry(n, &hidg_func_list, node) {
- n->fi = usb_get_function_instance("hid");
- if (IS_ERR(n->fi)) {
- status = PTR_ERR(n->fi);
+ list_for_each_entry(tmp_n, &hidg_func_list, node) {
+ tmp_n->fi = usb_get_function_instance("hid");
+ if (IS_ERR(tmp_n->fi)) {
+ status = PTR_ERR(tmp_n->fi);
+ n = tmp_n;
goto put;
}
- hid_opts = container_of(n->fi, struct f_hid_opts, func_inst);
- hid_opts->subclass = n->func->subclass;
- hid_opts->protocol = n->func->protocol;
- hid_opts->report_length = n->func->report_length;
- hid_opts->report_desc_length = n->func->report_desc_length;
- hid_opts->report_desc = n->func->report_desc;
+ hid_opts = container_of(tmp_n->fi, struct f_hid_opts, func_inst);
+ hid_opts->subclass = tmp_n->func->subclass;
+ hid_opts->protocol = tmp_n->func->protocol;
+ hid_opts->report_length = tmp_n->func->report_length;
+ hid_opts->report_desc_length = tmp_n->func->report_desc_length;
+ hid_opts->report_desc = tmp_n->func->report_desc;
}


--
2.25.1