> -----Original Message----- > From: dmaengine-owner@xxxxxxxxxxxxxxx > [mailto:dmaengine-owner@xxxxxxxxxxxxxxx] On Behalf Of Li Yang > Sent: 2018年5月31日 2:51 > To: Wen He <wen.he_1@xxxxxxx> > Cc: vkoul@xxxxxxxxxx; dmaengine@xxxxxxxxxxxxxxx; Rob Herring > <robh+dt@xxxxxxxxxx>; open list:OPEN FIRMWARE AND FLATTENED DEVICE > TREE BINDINGS <devicetree@xxxxxxxxxxxxxxx>; Jiafei Pan > <jiafei.pan@xxxxxxx>; Jiaheng Fan <jiaheng.fan@xxxxxxx> > Subject: Re: [v5 2/6] dmaengine: fsl-qdma: Add qDMA controller driver for > Layerscape SoCs > > On Fri, May 25, 2018 at 6:19 AM, Wen He <wen.he_1@xxxxxxx> wrote: > > NXP Queue DMA controller(qDMA) on Layerscape SoCs supports channel > > virtuallization by allowing DMA jobs to be enqueued into different > > command queues. > > > > Note that this module depends on NXP DPAA. > > > > Signed-off-by: Wen He <wen.he_1@xxxxxxx> > > Signed-off-by: Jiaheng Fan <jiaheng.fan@xxxxxxx> > > --- > > change in v5: > > - Fixed the issues includes: > > * add error handler which every function > > * replace word to bit definition > > * move global variable to struct definition > > * add some comments to context > > > > change in v4: > > - Fixed the issues that Vinod point out in the mail list. > > > > change in v3: > > - Add 'depends on ARM || ARM64' in file 'drivers/dma/Kconfig' > > > > change in v2: > > - Replace GPL V2 License details by SPDX tags > > - Replace Freescale by NXP > > - Reduce and optimize header file references > > - Replace big_endian by feature in struct fsl_qdma_engine > > - Replace struct fsl_qdma_format by struct fsl_qdma_ccdf > > and struct fsl_qdma_csgf > > - Remove empty line > > - Replace 'if..else' by macro 'FSL_QDMA_IN/OUT' in function > > qdma_readl() and qdma_writel() > > - Remove function fsl_qdma_alloc_chan_resources() > > - Replace 'prei' by 'pre' > > - Replace '-1' by '-ENOMEM' in function > fsl_qdma_pre_request_enqueue_desc() > > - Fix dma pool allocation need to rolled back in function > > fsl_qdma_request_enqueue_desc() > > - Replace function of_property_read_u32_array() by > device_property_read_u32_array() > > - Add functions fsl_qdma_cleanup_vchan() and > fsl_qdma_irq_exit() to ensure > > irq and tasklets stopped > > - Replace dts node element 'channels' by 'dma-channels' > > - Replace function platform_driver_register() by > > module_platform_driver() > > > > drivers/dma/Kconfig | 13 + > > drivers/dma/Makefile | 1 + > > drivers/dma/fsl-qdma.c | 1101 > > ++++++++++++++++++++++++++++++++++++++++++++++++ > > 3 files changed, 1115 insertions(+), 0 deletions(-) create mode > > 100644 drivers/dma/fsl-qdma.c > > > > diff --git a/drivers/dma/Kconfig b/drivers/dma/Kconfig index > > 6d61cd0..99aff33 100644 > > --- a/drivers/dma/Kconfig > > +++ b/drivers/dma/Kconfig > > @@ -225,6 +225,19 @@ config FSL_EDMA > > multiplexing capability for DMA request sources(slot). > > This module can be found on Freescale Vybrid and LS-1 SoCs. > > > > +config FSL_QDMA > > + tristate "NXP Layerscape qDMA engine support" > > + depends on ARM || ARM64 > > + select DMA_ENGINE > > + select DMA_VIRTUAL_CHANNELS > > + select DMA_ENGINE_RAID > > + select ASYNC_TX_ENABLE_CHANNEL_SWITCH > > + help > > + Support the NXP Layerscape qDMA engine with command > queue and legacy mode. > > + Channel virtualization is supported through enqueuing of DMA > jobs to, > > + or dequeuing DMA jobs from, different work queues. > > + This module can be found on NXP Layerscape SoCs. > > + > > config FSL_RAID > > tristate "Freescale RAID engine Support" > > depends on FSL_SOC > && !ASYNC_TX_ENABLE_CHANNEL_SWITCH diff > > --git a/drivers/dma/Makefile b/drivers/dma/Makefile index > > 0f62a4d..93db0fc 100644 > > --- a/drivers/dma/Makefile > > +++ b/drivers/dma/Makefile > > @@ -33,6 +33,7 @@ obj-$(CONFIG_DW_DMAC_CORE) += dw/ > > obj-$(CONFIG_EP93XX_DMA) += ep93xx_dma.o > > obj-$(CONFIG_FSL_DMA) += fsldma.o > > obj-$(CONFIG_FSL_EDMA) += fsl-edma.o > > +obj-$(CONFIG_FSL_QDMA) += fsl-qdma.o > > obj-$(CONFIG_FSL_RAID) += fsl_raid.o > > obj-$(CONFIG_HSU_DMA) += hsu/ > > obj-$(CONFIG_IMG_MDC_DMA) += img-mdc-dma.o diff --git > > a/drivers/dma/fsl-qdma.c b/drivers/dma/fsl-qdma.c new file mode 100644 > > index 0000000..81df812 > > --- /dev/null > > +++ b/drivers/dma/fsl-qdma.c > > @@ -0,0 +1,1101 @@ > > Not a critical issue, but the format of the file header looks a little bit weird to > me. Would you mind clean it up? > Got it , you are right, Thanks. > > +// SPDX-License-Identifier: GPL-2.0 > > +// Copyright 2018 NXP > > I know the SPDX tag is recommended to be the 1st line, but copyright normally > goes below the file description not above. > > > + > > No newline needed. > > > +/* > > + * Driver for NXP Layerscape Queue Direct Memory Access Controller > > + * > > + * Author: > > + * Wen He <wen.he_1@xxxxxxx> > > + * Jiaheng Fan <jiaheng.fan@xxxxxxx> > > + * > > No newline needed. > > > + */ > > + > > > Regards, > Leo All right, but Vinod recommend this kind of writing. May be we need to discuss with Vinod. Best Regards, Wen > -- > To unsubscribe from this list: send the line "unsubscribe dmaengine" in the > body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at > https://emea01.safelinks.protection.outlook.com/?url=http%3A%2F%2Fvger. > kernel.org%2Fmajordomo-info.html&data=02%7C01%7Cwen.he_1%40nxp.co > m%7Cc1f3312f4d194cb4cd3708d5c65e562e%7C686ea1d3bc2b4c6fa92cd99 > c5c301635%7C0%7C0%7C636633030836265801&sdata=jtehE%2FlHxajqzP7V > 3gRBbCvEQvo3jMBBqlWOFxp55uA%3D&reserved=0 ��.n��������+%������w��{.n����z�{��ܨ}���Ơz�j:+v�����w����ޙ��&�)ߡ�a����z�ޗ���ݢj��w�f