]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
i3c: dw: Simplify xfer cleanup with __free(kfree)
authorFelix Gu <ustc.gu@gmail.com>
Sat, 4 Apr 2026 10:32:31 +0000 (18:32 +0800)
committerAlexandre Belloni <alexandre.belloni@bootlin.com>
Sun, 12 Apr 2026 14:52:32 +0000 (16:52 +0200)
Convert dw-i3c-master to use __free(kfree) guards for struct dw_i3c_xfer
allocations. This frees xfer objects automatically on scope exit, and
removes the now-unused dw_i3c_master_free_xfer() helper.

Signed-off-by: Felix Gu <ustc.gu@gmail.com>
Reviewed-by: Frank Li <Frank.Li@nxp.com>
Link: https://patch.msgid.link/20260404-dw-i3c-2-v3-2-8f7d146549c1@gmail.com
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
drivers/i3c/master/dw-i3c-master.c

index 259e4f5276655a47b3afe87d8c733a6b6e8f281d..655693a2187e5d6f4cf4d784c14abc460513658c 100644 (file)
@@ -394,11 +394,6 @@ dw_i3c_master_alloc_xfer(struct dw_i3c_master *master, unsigned int ncmds)
        return xfer;
 }
 
-static void dw_i3c_master_free_xfer(struct dw_i3c_xfer *xfer)
-{
-       kfree(xfer);
-}
-
 static void dw_i3c_master_start_xfer_locked(struct dw_i3c_master *master)
 {
        struct dw_i3c_xfer *xfer = master->xferqueue.cur;
@@ -716,7 +711,6 @@ static void dw_i3c_master_bus_cleanup(struct i3c_master_controller *m)
 static int dw_i3c_ccc_set(struct dw_i3c_master *master,
                          struct i3c_ccc_cmd *ccc)
 {
-       struct dw_i3c_xfer *xfer;
        struct dw_i3c_cmd *cmd;
        int ret, pos = 0;
 
@@ -726,7 +720,7 @@ static int dw_i3c_ccc_set(struct dw_i3c_master *master,
                        return pos;
        }
 
-       xfer = dw_i3c_master_alloc_xfer(master, 1);
+       struct dw_i3c_xfer *xfer __free(kfree) = dw_i3c_master_alloc_xfer(master, 1);
        if (!xfer)
                return -ENOMEM;
 
@@ -751,14 +745,11 @@ static int dw_i3c_ccc_set(struct dw_i3c_master *master,
        if (xfer->cmds[0].error == RESPONSE_ERROR_IBA_NACK)
                ccc->err = I3C_ERROR_M2;
 
-       dw_i3c_master_free_xfer(xfer);
-
        return ret;
 }
 
 static int dw_i3c_ccc_get(struct dw_i3c_master *master, struct i3c_ccc_cmd *ccc)
 {
-       struct dw_i3c_xfer *xfer;
        struct dw_i3c_cmd *cmd;
        int ret, pos;
 
@@ -766,7 +757,7 @@ static int dw_i3c_ccc_get(struct dw_i3c_master *master, struct i3c_ccc_cmd *ccc)
        if (pos < 0)
                return pos;
 
-       xfer = dw_i3c_master_alloc_xfer(master, 1);
+       struct dw_i3c_xfer *xfer __free(kfree) = dw_i3c_master_alloc_xfer(master, 1);
        if (!xfer)
                return -ENOMEM;
 
@@ -791,7 +782,6 @@ static int dw_i3c_ccc_get(struct dw_i3c_master *master, struct i3c_ccc_cmd *ccc)
        ret = xfer->ret;
        if (xfer->cmds[0].error == RESPONSE_ERROR_IBA_NACK)
                ccc->err = I3C_ERROR_M2;
-       dw_i3c_master_free_xfer(xfer);
 
        return ret;
 }
@@ -838,12 +828,15 @@ static int dw_i3c_master_send_ccc_cmd(struct i3c_master_controller *m,
 static int dw_i3c_master_daa(struct i3c_master_controller *m)
 {
        struct dw_i3c_master *master = to_dw_i3c_master(m);
-       struct dw_i3c_xfer *xfer;
        struct dw_i3c_cmd *cmd;
        u32 olddevs, newdevs;
        u8 last_addr = 0;
        int ret, pos;
 
+       struct dw_i3c_xfer *xfer __free(kfree) = dw_i3c_master_alloc_xfer(master, 1);
+       if (!xfer)
+               return -ENOMEM;
+
        ret = pm_runtime_resume_and_get(master->dev);
        if (ret < 0) {
                dev_err(master->dev,
@@ -877,15 +870,8 @@ static int dw_i3c_master_daa(struct i3c_master_controller *m)
                ret = 0;
        }
 
-       xfer = dw_i3c_master_alloc_xfer(master, 1);
-       if (!xfer) {
-               ret = -ENOMEM;
-               goto rpm_out;
-       }
-
        pos = dw_i3c_master_get_free_pos(master);
        if (pos < 0) {
-               dw_i3c_master_free_xfer(xfer);
                ret = pos;
                goto rpm_out;
        }
@@ -910,8 +896,6 @@ static int dw_i3c_master_daa(struct i3c_master_controller *m)
                        i3c_master_add_i3c_dev_locked(m, master->devs[pos].addr);
        }
 
-       dw_i3c_master_free_xfer(xfer);
-
 rpm_out:
        pm_runtime_put_autosuspend(master->dev);
        return ret;
@@ -1083,7 +1067,6 @@ static int dw_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
        struct i3c_master_controller *m = i2c_dev_get_master(dev);
        struct dw_i3c_master *master = to_dw_i3c_master(m);
        unsigned int nrxwords = 0, ntxwords = 0;
-       struct dw_i3c_xfer *xfer;
        int i, ret = 0;
 
        if (!i2c_nxfers)
@@ -1103,7 +1086,7 @@ static int dw_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
            nrxwords > master->caps.datafifodepth)
                return -EOPNOTSUPP;
 
-       xfer = dw_i3c_master_alloc_xfer(master, i2c_nxfers);
+       struct dw_i3c_xfer *xfer __free(kfree) = dw_i3c_master_alloc_xfer(master, i2c_nxfers);
        if (!xfer)
                return -ENOMEM;
 
@@ -1112,7 +1095,6 @@ static int dw_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
                dev_err(master->dev,
                        "<%s> cannot resume i3c bus master, err: %d\n",
                        __func__, ret);
-               dw_i3c_master_free_xfer(xfer);
                return ret;
        }
 
@@ -1144,7 +1126,6 @@ static int dw_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
                dw_i3c_master_dequeue_xfer(master, xfer);
 
        ret = xfer->ret;
-       dw_i3c_master_free_xfer(xfer);
 
        pm_runtime_put_autosuspend(master->dev);
        return ret;