diff options
author | Marek Szyprowski <m.szyprowski@samsung.com> | 2022-09-30 13:34:08 +0200 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2022-09-30 13:56:29 +0200 |
commit | 8e9204cddcc3fea9affcfa411715ba4f66e97587 (patch) | |
tree | f647a8b9917e8efb5f04a0a25f1290f4410b6041 /drivers/spi | |
parent | spi: spi-gxp: Use devm_platform_ioremap_resource() (diff) | |
download | linux-8e9204cddcc3fea9affcfa411715ba4f66e97587.tar.xz linux-8e9204cddcc3fea9affcfa411715ba4f66e97587.zip |
spi: Ensure that sg_table won't be used after being freed
SPI code checks for non-zero sgt->orig_nents to determine if the buffer
has been DMA-mapped. Ensure that sg_table is really zeroed after free to
avoid potential NULL pointer dereference if the given SPI xfer object is
reused again without being DMA-mapped.
Fixes: 0c17ba73c08f ("spi: Fix cache corruption due to DMA/PIO overlap")
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
Link: https://lore.kernel.org/r/20220930113408.19720-1-m.szyprowski@samsung.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to '')
-rw-r--r-- | drivers/spi/spi.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c index a4771f69f5c3..29a3098cc157 100644 --- a/drivers/spi/spi.c +++ b/drivers/spi/spi.c @@ -1102,6 +1102,8 @@ static void spi_unmap_buf_attrs(struct spi_controller *ctlr, if (sgt->orig_nents) { dma_unmap_sgtable(dev, sgt, dir, attrs); sg_free_table(sgt); + sgt->orig_nents = 0; + sgt->nents = 0; } } |