Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp778591pxb; Wed, 20 Jan 2021 22:19:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJw10ob21Zbr0puZGf60DqGp5JiqaucTxceVWDWT9ILoEm56M4tVEy+hhRX6w+PA0ftk04Fs X-Received: by 2002:a17:906:3a55:: with SMTP id a21mr8424232ejf.516.1611209967184; Wed, 20 Jan 2021 22:19:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611209967; cv=none; d=google.com; s=arc-20160816; b=02n2krXSTSVcV5pRc+HhzyvgRsQXzesJ8gqybuy14M65K9w0d3tzylCFqvkHFlSDMy ou3wba2oyb0Qoyvf/dlfFUBWAn1lHpez4vXhLCSc/m0QzAxQbvZqs/zDbrg8sXyvTALT UF9PPIEITRW0KTaCcc3b08Vle5Wf7xtMmZ1BEdOeYWH2xUMrpb1uT+oKHinyPHEZ40Ev tO9dgvG7gJkb2dhEJa26AKCrqGuSBsX3hnRjjrjTYhBHU/i1jeoqpI+xLtwv+KyzYyKK EmC163JZAHXtgjyF8FFFM8TXTsQT0EgKhJbpaOwKkHBotsnFJjic1lrfYdIg1d5M0WMQ eqhA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=gIhS7QKgifQ6QdYGTKs59OulYpUqoBNdnbkcptU8WE4=; b=PwpGLi8OHLToE/UpWA2NzPjslTTEOIU1dh6qQudQePgvj/t1k+Ou5ffE7NwtCd81vc EcSvvrNNghU9h/zeIBY0XmtXySLPREHWSio7YShAAMbbsHU/dKl+H4GuAbRkuVN0gyzt +YSvLQXHkwhsTMLHT34FGvisAOjH9cIddqX+7o/+E1nMvv1ikY4SwI9gSbDFKBmB15m/ Kx09s4+a8Rfk6kyX904uigkYSbpIpOrPkzQPOqw1IiHjn8ZCg9a97psNZ41As/g624zR KIk7N14TTDNHcLd7MrNxb0OzKFV584KzmalRKFtBgDCG81spfR9XlfisZYKbWT4P1Hj3 wnPQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bu15si1496635ejb.667.2021.01.20.22.19.03; Wed, 20 Jan 2021 22:19:27 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726587AbhAUGRx (ORCPT + 99 others); Thu, 21 Jan 2021 01:17:53 -0500 Received: from mga11.intel.com ([192.55.52.93]:10408 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726722AbhAUGQP (ORCPT ); Thu, 21 Jan 2021 01:16:15 -0500 IronPort-SDR: NURAdHl8MSBFHv50Zx5qJjX/v21V+iEBiRyWCJsV5YcNHZ0WItrvAD3gyF3o8XbFrXMNubT6Sl vD7gdVbxdAyg== X-IronPort-AV: E=McAfee;i="6000,8403,9870"; a="175716810" X-IronPort-AV: E=Sophos;i="5.79,363,1602572400"; d="scan'208";a="175716810" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Jan 2021 22:14:51 -0800 IronPort-SDR: wC47xk1X8yIZkQ/XqP+BgMx0nqSRfGZKbTOWm/mX4fElKjBI3vR0i1HEXdqw8GsQFRKVRhb5qJ 1z+BjVrTYfGg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.79,363,1602572400"; d="scan'208";a="427201475" Received: from jsia-hp-z620-workstation.png.intel.com ([10.221.118.135]) by orsmga001.jf.intel.com with ESMTP; 20 Jan 2021 22:14:48 -0800 From: Sia Jee Heng To: vkoul@kernel.org, Eugeniy.Paltsev@synopsys.com, robh+dt@kernel.org Cc: andriy.shevchenko@linux.intel.com, jee.heng.sia@intel.com, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org Subject: [PATCH v10 14/16] dmaengine: dw-axi-dmac: Add Intel KeemBay AxiDMA BYTE and HALFWORD registers Date: Thu, 21 Jan 2021 13:56:39 +0800 Message-Id: <20210121055641.6307-15-jee.heng.sia@intel.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20210121055641.6307-1-jee.heng.sia@intel.com> References: <20210121055641.6307-1-jee.heng.sia@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support for Intel KeemBay AxiDMA BYTE and HALFWORD registers programming. Intel KeemBay AxiDMA supports data transfer between device to memory and memory to device operations. This code is needed by I2C, I3C, I2S, SPI and UART which uses FIFO size of 8bits and 16bits to perform memory to device data transfer operation. 0-padding functionality is provided to avoid pre-processing of data on CPU. Signed-off-by: Sia Jee Heng Reviewed-by: Andy Shevchenko Reviewed-by: Eugeniy Paltsev Tested-by: Eugeniy Paltsev --- .../dma/dw-axi-dmac/dw-axi-dmac-platform.c | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c b/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c index e19369f9365a..ea527b92e0fc 100644 --- a/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c +++ b/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c @@ -307,6 +307,30 @@ static void write_chan_llp(struct axi_dma_chan *chan, dma_addr_t adr) axi_chan_iowrite64(chan, CH_LLP, adr); } +static void dw_axi_dma_set_byte_halfword(struct axi_dma_chan *chan, bool set) +{ + u32 reg_width, offset, val; + + if (!chan->chip->apb_regs) { + dev_dbg(chan->chip->dev, "apb_regs not initialized\n"); + return; + } + + reg_width = __ffs(chan->config.dst_addr_width); + if (reg_width == DWAXIDMAC_TRANS_WIDTH_8) + offset = DMAC_APB_BYTE_WR_CH_EN; + else if (reg_width == DWAXIDMAC_TRANS_WIDTH_16) + offset = DMAC_APB_HALFWORD_WR_CH_EN; + + val = ioread32(chan->chip->apb_regs + offset); + + if (set) + val |= BIT(chan->id); + else + val &= ~BIT(chan->id); + + iowrite32(val, chan->chip->apb_regs + offset); +} /* Called in chan locked context */ static void axi_chan_block_xfer_start(struct axi_dma_chan *chan, struct axi_dma_desc *first) @@ -334,6 +358,7 @@ static void axi_chan_block_xfer_start(struct axi_dma_chan *chan, DWAXIDMAC_HS_SEL_HW << CH_CFG_H_HS_SEL_SRC_POS); switch (chan->direction) { case DMA_MEM_TO_DEV: + dw_axi_dma_set_byte_halfword(chan, true); reg |= (chan->config.device_fc ? DWAXIDMAC_TT_FC_MEM_TO_PER_DST : DWAXIDMAC_TT_FC_MEM_TO_PER_DMAC) @@ -1008,6 +1033,8 @@ static int dma_chan_terminate_all(struct dma_chan *dchan) if (chan->direction != DMA_MEM_TO_MEM) dw_axi_dma_set_hw_channel(chan->chip, chan->hw_handshake_num, false); + if (chan->direction == DMA_MEM_TO_DEV) + dw_axi_dma_set_byte_halfword(chan, false); spin_lock_irqsave(&chan->vc.lock, flags); -- 2.18.0