Commit 7afe9a4e authored by Wenwen Wang's avatar Wenwen Wang Committed by Boris Brezillon

i3c: master: fix a memory leak bug

In i3c_master_getmwl_locked(), the buffer used for the dest payload data is
allocated using kzalloc() in i3c_ccc_cmd_dest_init(). Later on, the length
of the dest payload data is checked against 'sizeof(*mwl)'. If they are not
equal, -EIO is returned to indicate the error. However, the allocated
buffer is not deallocated on this path, leading to a memory leak.

To fix the above issue, free the buffer before returning the error.
Signed-off-by: default avatarWenwen Wang <wenwen@cs.uga.edu>
Signed-off-by: default avatarBoris Brezillon <boris.brezillon@collabora.com>
parent b1ac3a4b
...@@ -1041,8 +1041,10 @@ static int i3c_master_getmwl_locked(struct i3c_master_controller *master, ...@@ -1041,8 +1041,10 @@ static int i3c_master_getmwl_locked(struct i3c_master_controller *master,
if (ret) if (ret)
goto out; goto out;
if (dest.payload.len != sizeof(*mwl)) if (dest.payload.len != sizeof(*mwl)) {
return -EIO; ret = -EIO;
goto out;
}
info->max_write_len = be16_to_cpu(mwl->len); info->max_write_len = be16_to_cpu(mwl->len);
......
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