driver: soc: xilinx: fix memory leak in xlnx_add_cb_for_notify_event()
authorGaosheng Cui <cuigaosheng1@huawei.com>
Tue, 29 Nov 2022 01:01:46 +0000 (09:01 +0800)
committerMichal Simek <michal.simek@amd.com>
Thu, 5 Jan 2023 08:46:51 +0000 (09:46 +0100)
The kfree() should be called when memory fails to be allocated for
cb_data in xlnx_add_cb_for_notify_event(), otherwise there will be
a memory leak, so add kfree() to fix it.

Fixes: 05e5ba40ea7a ("driver: soc: xilinx: Add support of multiple callbacks for same event in event management driver")
Signed-off-by: Gaosheng Cui <cuigaosheng1@huawei.com>
Acked-by: Michal Simek <michal.simek@amd.com>
Link: https://lore.kernel.org/r/20221129010146.1026685-1-cuigaosheng1@huawei.com
Signed-off-by: Michal Simek <michal.simek@amd.com>
drivers/soc/xilinx/xlnx_event_manager.c

index 2de0827..c763818 100644 (file)
@@ -116,8 +116,10 @@ static int xlnx_add_cb_for_notify_event(const u32 node_id, const u32 event, cons
                INIT_LIST_HEAD(&eve_data->cb_list_head);
 
                cb_data = kmalloc(sizeof(*cb_data), GFP_KERNEL);
-               if (!cb_data)
+               if (!cb_data) {
+                       kfree(eve_data);
                        return -ENOMEM;
+               }
                cb_data->eve_cb = cb_fun;
                cb_data->agent_data = data;