i3c: master: fix a memory leak bug
authorWenwen Wang <wenwen@cs.uga.edu>
Sun, 11 Aug 2019 18:33:06 +0000 (13:33 -0500)
committerBoris Brezillon <boris.brezillon@collabora.com>
Mon, 12 Aug 2019 08:11:29 +0000 (10:11 +0200)
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: Wenwen Wang <wenwen@cs.uga.edu>
Signed-off-by: Boris Brezillon <boris.brezillon@collabora.com>
drivers/i3c/master.c

index a38fdf325d30f6d5b66c7a3a10fe43d65459ecdb..8ff527263f469024cfffed25d78f74192992a096 100644 (file)
@@ -1041,8 +1041,10 @@ static int i3c_master_getmwl_locked(struct i3c_master_controller *master,
        if (ret)
                goto out;
 
-       if (dest.payload.len != sizeof(*mwl))
-               return -EIO;
+       if (dest.payload.len != sizeof(*mwl)) {
+               ret = -EIO;
+               goto out;
+       }
 
        info->max_write_len = be16_to_cpu(mwl->len);