[PATCH v1 2/4] dmaengine: imx-sdma: add check_bd_buswidth() to kill the dulicated code
From: Robin Gong <hidden>
Date: 2018-07-11 05:36:16
Also in:
dmaengine, lkml
-----Original Message----- From: Vinod [mailto:vkoul at kernel.org] Sent: 2018?7?10? 23:31 To: Robin Gong <redacted> Cc: dan.j.williams at intel.com; shawnguo at kernel.org; s.hauer at pengutronix.de; Fabio Estevam [off-list ref]; linux at armlinux.org.uk; linux-arm-kernel at lists.infradead.org; kernel at pengutronix.de; dmaengine at vger.kernel.org; linux-kernel at vger.kernel.org; dl-linux-imx [off-list ref] Subject: Re: [PATCH v1 2/4] dmaengine: imx-sdma: add check_bd_buswidth() to kill the dulicated code On 11-07-18, 00:23, Robin Gong wrote:quoted
Add check_bd_buswidth() to minimize the code size.this looks mostly fine and I think this should be first patch..
Since no need to check bus width in memcpy case, I'll remove this patch too.
quoted
Signed-off-by: Robin Gong <redacted> --- drivers/dma/imx-sdma.c | 64 +++++++++++++++++++++++--------------------------- 1 file changed, 29 insertions(+), 35 deletions(-)diff --git a/drivers/dma/imx-sdma.c b/drivers/dma/imx-sdma.c index27ccabf..ed2267d 100644--- a/drivers/dma/imx-sdma.c +++ b/drivers/dma/imx-sdma.c@@ -1326,6 +1326,33 @@ static struct sdma_desc*sdma_transfer_init(struct sdma_channel *sdmac,quoted
return NULL; } +static int check_bd_buswidth(struct sdma_buffer_descriptor *bd, + struct sdma_channel *sdmac, int count, + dma_addr_t dma_dst, dma_addr_t dma_src) { + int ret = 0; + + switch (sdmac->word_size) { + case DMA_SLAVE_BUSWIDTH_4_BYTES: + bd->mode.command = 0; + if ((count | dma_dst | dma_src) & 3) + ret = -EINVAL; + break;empty line after each break pleasequoted
+ case DMA_SLAVE_BUSWIDTH_2_BYTES: + bd->mode.command = 2; + if ((count | dma_dst | dma_src) & 1) + ret = -EINVAL; + break; + case DMA_SLAVE_BUSWIDTH_1_BYTE: + bd->mode.command = 1; + break; + default: + return -EINVAL; + } + + return ret; +} +-- ~Vinod