i2c/designware: Fix an initialization issue
authorMichael J. Ruhl <michael.j.ruhl@intel.com>
Fri, 27 Jun 2025 14:35:11 +0000 (10:35 -0400)
committerAndi Shyti <andi.shyti@kernel.org>
Mon, 30 Jun 2025 17:57:08 +0000 (19:57 +0200)
The i2c_dw_xfer_init() function requires msgs and msg_write_idx from the
dev context to be initialized.

amd_i2c_dw_xfer_quirk() inits msgs and msgs_num, but not msg_write_idx.

This could allow an out of bounds access (of msgs).

Initialize msg_write_idx before calling i2c_dw_xfer_init().

Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Fixes: 17631e8ca2d3 ("i2c: designware: Add driver support for AMD NAVI GPU")
Cc: <stable@vger.kernel.org> # v5.13+
Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
Signed-off-by: Andi Shyti <andi.shyti@kernel.org>
Link: https://lore.kernel.org/r/20250627143511.489570-1-michael.j.ruhl@intel.com
drivers/i2c/busses/i2c-designware-master.c

index 9d7d9e47564a166b64e7749da6b6cf0dfe8f8f23..cbd88ffa561010ff2d29086836d9119da5b8885c 100644 (file)
@@ -363,6 +363,7 @@ static int amd_i2c_dw_xfer_quirk(struct i2c_adapter *adap, struct i2c_msg *msgs,
 
        dev->msgs = msgs;
        dev->msgs_num = num_msgs;
+       dev->msg_write_idx = 0;
        i2c_dw_xfer_init(dev);
 
        /* Initiate messages read/write transaction */