Commit b73e43dc authored by Guanhua Gao's avatar Guanhua Gao Committed by Vinod Koul

dmaengine: fsl-dpaa2-qdma: Fix the size of dma pools

In case of long format of qDMA command descriptor, there are one frame
descriptor, three entries in the frame list and two data entries. So the
size of dma_pool_create for these three fields should be the same with
the total size of entries respectively, or the contents may be overwritten
by the next allocated descriptor.

Fixes: 7fdf9b05 ("dmaengine: fsl-dpaa2-qdma: Add NXP dpaa2 qDMA controller driver for Layerscape SoCs")
Signed-off-by: default avatarGuanhua Gao <guanhua.gao@nxp.com>
Signed-off-by: default avatarFrank Li <Frank.Li@nxp.com>
Link: https://lore.kernel.org/r/20240118162917.2951450-1-Frank.Li@nxp.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent e4cec073
...@@ -38,15 +38,17 @@ static int dpaa2_qdma_alloc_chan_resources(struct dma_chan *chan) ...@@ -38,15 +38,17 @@ static int dpaa2_qdma_alloc_chan_resources(struct dma_chan *chan)
if (!dpaa2_chan->fd_pool) if (!dpaa2_chan->fd_pool)
goto err; goto err;
dpaa2_chan->fl_pool = dma_pool_create("fl_pool", dev, dpaa2_chan->fl_pool =
sizeof(struct dpaa2_fl_entry), dma_pool_create("fl_pool", dev,
sizeof(struct dpaa2_fl_entry) * 3,
sizeof(struct dpaa2_fl_entry), 0); sizeof(struct dpaa2_fl_entry), 0);
if (!dpaa2_chan->fl_pool) if (!dpaa2_chan->fl_pool)
goto err_fd; goto err_fd;
dpaa2_chan->sdd_pool = dpaa2_chan->sdd_pool =
dma_pool_create("sdd_pool", dev, dma_pool_create("sdd_pool", dev,
sizeof(struct dpaa2_qdma_sd_d), sizeof(struct dpaa2_qdma_sd_d) * 2,
sizeof(struct dpaa2_qdma_sd_d), 0); sizeof(struct dpaa2_qdma_sd_d), 0);
if (!dpaa2_chan->sdd_pool) if (!dpaa2_chan->sdd_pool)
goto err_fl; goto err_fl;
......
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