usb: aspeed-vhub: Fix refcount leak bug in ast_vhub_init_desc()
authorLiang He <windhl@126.com>
Wed, 13 Jul 2022 12:05:28 +0000 (20:05 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 14 Jul 2022 14:10:12 +0000 (16:10 +0200)
We should call of_node_put() for the reference returned by
of_get_child_by_name() which has increased the refcount.

Fixes: 30d2617fd7ed ("usb: gadget: aspeed: allow to set usb strings in device tree")
Signed-off-by: Liang He <windhl@126.com>
Link: https://lore.kernel.org/r/20220713120528.368168-1-windhl@126.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/gadget/udc/aspeed-vhub/hub.c

index 65cd4e4..e2207d0 100644 (file)
@@ -1059,8 +1059,10 @@ static int ast_vhub_init_desc(struct ast_vhub *vhub)
        /* Initialize vhub String Descriptors. */
        INIT_LIST_HEAD(&vhub->vhub_str_desc);
        desc_np = of_get_child_by_name(vhub_np, "vhub-strings");
-       if (desc_np)
+       if (desc_np) {
                ret = ast_vhub_of_parse_str_desc(vhub, desc_np);
+               of_node_put(desc_np);
+       }
        else
                ret = ast_vhub_str_alloc_add(vhub, &ast_vhub_strings);