Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp4195031pxb; Sun, 24 Oct 2021 22:39:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyOWg0pdy708RFSrLKiLcvwh05qSZnMiXfyt1WEvF0tW/n4zQWiaQqBUZeNXTI54LUP3zUg X-Received: by 2002:a17:90b:4b89:: with SMTP id lr9mr18382316pjb.11.1635140351953; Sun, 24 Oct 2021 22:39:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635140351; cv=none; d=google.com; s=arc-20160816; b=oF/uNpc0bAFe5sffOHa+7WTR14DsHUJaI9t3JJ79bJFwbW6FCFEX/Zh53tH82y4Nz8 jsCRksFc6+KqjtvPnYjElAwuTGz6UGdY+6QVrAXZ+8/4rN9e0Ne56L/cNborpTfhxrIR 7Pt4arXwWzF5/zrEYTiqtooYcuus/IkJVG/WnoY1Qn/V2wAd2CMvKS7l2iBLenR34uD9 adCJ/3zJlR6GK2XnpOPKhmwbDEegTxV9LILxL9YtzlXNMAWBHt3BMqNErE0WT8icuAwW qo2nYXGBShPYP5WIk7Y9lBwEngjbUwwG50dy0o8zWYSl9vOFnt1RfR5vgqDpHp9HtpMn 1WNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Y/FgubGNiS2EbfeUsC6R3wk289mvBqwuxRIaa9JKvbk=; b=ExsuiCigC+4uec/O1LYYyrJAy53VPNnD0o9KEB6Lcut3DPC22/lWsQqYxsHrVWIu6R BWgttC0za17IJjhkRaCfFn56Rbp3y8DTfBQVjg41BK0qiUbputzOVYx3JZbVF6XzP+Py B9klRykEh7+TnF3lysd5ep/GfttI7ZL/Yh/wdZU9V8l5ArbmpeE4FKUcwL/qewMrI2Dz FPBv63P8cDBILEORG6idFzovCBXaZsGgdMr80ce7te9SPmgW8ICmlgzOeoepi4UH8Zeg JhYp5LNXo4/pGFZ6muholcMz4gvhd0YxeZJErR+XC23i/4rZGVOwGytFo2txHRsPPkuB s77A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=qrHBVDKp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z7si26559136plg.391.2021.10.24.22.38.59; Sun, 24 Oct 2021 22:39:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=qrHBVDKp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229841AbhJYFkU (ORCPT + 99 others); Mon, 25 Oct 2021 01:40:20 -0400 Received: from mail.kernel.org ([198.145.29.99]:35770 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229499AbhJYFkU (ORCPT ); Mon, 25 Oct 2021 01:40:20 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id AF13760F6F; Mon, 25 Oct 2021 05:37:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1635140278; bh=c96OBhe4vovwQbm2THAQJBbQ9XzPpKJJzhLKKpNcu2w=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=qrHBVDKpbsNZyym7zWE9rH0KHosZZ7k8RQL3SDF/Ft/2MHrXLkrQCS19soMlzpEGF EfjfxBeQnyb0yC8nuYOgSRDIfdc/oe2bnOsuF6OfBbxFxp+Gg3vNOJGEsgfjHUwipZ vXCkxxxKrjjGMLXl8KxUcgmcPCcftjFXI9n72hQvTCMkgLGfKV2CJVLS9FRewrRxSU C5cIuBIlUzzMiLK7YW8GaxcJv04pHqvXAZxIbkYozXENbyK8VAEvqr7edZXjI+pV+x bFrjI0V6sZyZ9ji2Z2FlUAeUEH3nFfwIVDommqjP4GQLZJWLLiElC1VvMBTbJl8cRx cdMmS2A2lj/iw== Date: Mon, 25 Oct 2021 11:07:53 +0530 From: Vinod Koul To: Joy Zou Cc: yibin.gong@nxp.com, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V3 1/1] dmaengine: fsl-edma: support edma memcpy Message-ID: References: <20211019062537.1209683-1-joy.zou@nxp.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20211019062537.1209683-1-joy.zou@nxp.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 19-10-21, 14:25, Joy Zou wrote: > Add memcpy in edma. The edma has the capability to transfer data by > software trigger so that it could be used for memory copy. Enable > MEMCPY for edma driver and it could be test directly by dmatest. > > Signed-off-by: Joy Zou > --- > Changes since (implicit) v2: > Remove 'Reported-by' tag in v3. > Robot report sparse warning on v1, fixed it in v2. > Add blank line in v3. > Add commit message in v3. > --- > drivers/dma/fsl-edma-common.c | 34 ++++++++++++++++++++++++++++++++-- > drivers/dma/fsl-edma-common.h | 4 ++++ > drivers/dma/fsl-edma.c | 7 +++++++ > 3 files changed, 43 insertions(+), 2 deletions(-) > > diff --git a/drivers/dma/fsl-edma-common.c b/drivers/dma/fsl-edma-common.c > index 930ae268c497..3f7c9faa8c9a 100644 > --- a/drivers/dma/fsl-edma-common.c > +++ b/drivers/dma/fsl-edma-common.c > @@ -343,11 +343,11 @@ enum dma_status fsl_edma_tx_status(struct dma_chan *chan, > EXPORT_SYMBOL_GPL(fsl_edma_tx_status); > > static void fsl_edma_set_tcd_regs(struct fsl_edma_chan *fsl_chan, > - struct fsl_edma_hw_tcd *tcd) > -{ > + struct fsl_edma_hw_tcd *tcd){ space b/w braces, checkpatch would have complained! Pls run that > struct fsl_edma_engine *edma = fsl_chan->edma; > struct edma_regs *regs = &fsl_chan->edma->regs; > u32 ch = fsl_chan->vchan.chan.chan_id; > + u16 csr = 0; > > /* > * TCD parameters are stored in struct fsl_edma_hw_tcd in little > @@ -373,6 +373,12 @@ static void fsl_edma_set_tcd_regs(struct fsl_edma_chan *fsl_chan, > edma_writel(edma, (s32)tcd->dlast_sga, > ®s->tcd[ch].dlast_sga); > > + if (fsl_chan->is_sw) { > + csr = le16_to_cpu(tcd->csr); > + csr |= EDMA_TCD_CSR_START; > + tcd->csr = cpu_to_le16(csr); > + } > + > edma_writew(edma, (s16)tcd->csr, ®s->tcd[ch].csr); > } > > @@ -587,6 +593,29 @@ struct dma_async_tx_descriptor *fsl_edma_prep_slave_sg( > } > EXPORT_SYMBOL_GPL(fsl_edma_prep_slave_sg); > > +struct dma_async_tx_descriptor *fsl_edma_prep_memcpy( statify pls > + struct dma_chan *chan, dma_addr_t dma_dst, > + dma_addr_t dma_src, size_t len, unsigned long flags) align to preceding open brace > +{ > + struct fsl_edma_chan *fsl_chan = to_fsl_edma_chan(chan); > + struct fsl_edma_desc *fsl_desc; > + > + fsl_desc = fsl_edma_alloc_desc(fsl_chan, 1); > + if (!fsl_desc) > + return NULL; > + fsl_desc->iscyclic = false; > + > + fsl_chan->is_sw = true; > + > + /* To match with copy_align and max_seg_size so 1 tcd is enough */ > + fsl_edma_fill_tcd(fsl_desc->tcd[0].vtcd, dma_src, dma_dst, > + EDMA_TCD_ATTR_SSIZE_32BYTE | EDMA_TCD_ATTR_DSIZE_32BYTE, > + 32, len, 0, 1, 1, 32, 0, true, true, false); > + > + return vchan_tx_prep(&fsl_chan->vchan, &fsl_desc->vdesc, flags); > +} > +EXPORT_SYMBOL_GPL(fsl_edma_prep_memcpy); > + > void fsl_edma_xfer_desc(struct fsl_edma_chan *fsl_chan) > { > struct virt_dma_desc *vdesc; > @@ -652,6 +681,7 @@ void fsl_edma_free_chan_resources(struct dma_chan *chan) > vchan_dma_desc_free_list(&fsl_chan->vchan, &head); > dma_pool_destroy(fsl_chan->tcd_pool); > fsl_chan->tcd_pool = NULL; > + fsl_chan->is_sw = false; > } > EXPORT_SYMBOL_GPL(fsl_edma_free_chan_resources); > > diff --git a/drivers/dma/fsl-edma-common.h b/drivers/dma/fsl-edma-common.h > index ec1169741de1..004ec4a6bc86 100644 > --- a/drivers/dma/fsl-edma-common.h > +++ b/drivers/dma/fsl-edma-common.h > @@ -121,6 +121,7 @@ struct fsl_edma_chan { > struct fsl_edma_desc *edesc; > struct dma_slave_config cfg; > u32 attr; > + bool is_sw; > struct dma_pool *tcd_pool; > dma_addr_t dma_dev_addr; > u32 dma_dev_size; > @@ -240,6 +241,9 @@ struct dma_async_tx_descriptor *fsl_edma_prep_slave_sg( > struct dma_chan *chan, struct scatterlist *sgl, > unsigned int sg_len, enum dma_transfer_direction direction, > unsigned long flags, void *context); > +struct dma_async_tx_descriptor *fsl_edma_prep_memcpy( > + struct dma_chan *chan, dma_addr_t dma_dst, dma_addr_t dma_src, > + size_t len, unsigned long flags); > void fsl_edma_xfer_desc(struct fsl_edma_chan *fsl_chan); > void fsl_edma_issue_pending(struct dma_chan *chan); > int fsl_edma_alloc_chan_resources(struct dma_chan *chan); > diff --git a/drivers/dma/fsl-edma.c b/drivers/dma/fsl-edma.c > index 90bb72af306c..76cbf54aec58 100644 > --- a/drivers/dma/fsl-edma.c > +++ b/drivers/dma/fsl-edma.c > @@ -17,6 +17,7 @@ > #include > #include > #include > +#include > > #include "fsl-edma-common.h" > > @@ -372,6 +373,7 @@ static int fsl_edma_probe(struct platform_device *pdev) > dma_cap_set(DMA_PRIVATE, fsl_edma->dma_dev.cap_mask); > dma_cap_set(DMA_SLAVE, fsl_edma->dma_dev.cap_mask); > dma_cap_set(DMA_CYCLIC, fsl_edma->dma_dev.cap_mask); > + dma_cap_set(DMA_MEMCPY, fsl_edma->dma_dev.cap_mask); > > fsl_edma->dma_dev.dev = &pdev->dev; > fsl_edma->dma_dev.device_alloc_chan_resources > @@ -381,6 +383,7 @@ static int fsl_edma_probe(struct platform_device *pdev) > fsl_edma->dma_dev.device_tx_status = fsl_edma_tx_status; > fsl_edma->dma_dev.device_prep_slave_sg = fsl_edma_prep_slave_sg; > fsl_edma->dma_dev.device_prep_dma_cyclic = fsl_edma_prep_dma_cyclic; > + fsl_edma->dma_dev.device_prep_dma_memcpy = fsl_edma_prep_memcpy; > fsl_edma->dma_dev.device_config = fsl_edma_slave_config; > fsl_edma->dma_dev.device_pause = fsl_edma_pause; > fsl_edma->dma_dev.device_resume = fsl_edma_resume; > @@ -392,6 +395,10 @@ static int fsl_edma_probe(struct platform_device *pdev) > fsl_edma->dma_dev.dst_addr_widths = FSL_EDMA_BUSWIDTHS; > fsl_edma->dma_dev.directions = BIT(DMA_DEV_TO_MEM) | BIT(DMA_MEM_TO_DEV); > > + fsl_edma->dma_dev.copy_align = DMAENGINE_ALIGN_32_BYTES; > + /* Per worst case 'nbytes = 1' take CITER as the max_seg_size */ > + dma_set_max_seg_size(fsl_edma->dma_dev.dev, 0x3fff); > + > platform_set_drvdata(pdev, fsl_edma); > > ret = dma_async_device_register(&fsl_edma->dma_dev); > -- > 2.25.1 -- ~Vinod