Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp1436002pxx; Tue, 27 Oct 2020 17:37:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwcJ4/X6dswaNcGlbheXvB6KBLvtnrmkaAXrAtAIaYm15jtJ9kxZzwF5pRGOmAJXOKeOe73 X-Received: by 2002:a17:906:8891:: with SMTP id ak17mr4984035ejc.176.1603845454441; Tue, 27 Oct 2020 17:37:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603845454; cv=none; d=google.com; s=arc-20160816; b=sPuTmUpWmo3nKTH0AaM4tI0zE1PNh7y6varjoNvDXaO/wNYIvkXWQXKeKRRs4O2iJi EW496RZ4Dj1NzBDsuraUC/++dwEZqvNgIwpnC83jOBARe18Z1YATpUJwJTgzITAj3SXT tmEMeg57kSSyu0a/occE/iLRBrr/ViUXNgUDuA80PsBxW2uVGM0ZIayvqCaxtVEEEz+M ko1gXqulj1Mv2uKDxZKk3OZBb2UPPsOpMpLKO0V4d8MXjY1yqqH9QSFmOG+zf0R8N7t7 s0t4AVf3R8LlD1gqEQ4RS4B61BOrRh3LyiLk4znUJnmQ2eiEVQbVeiprOoz8XCvKFDJP x1LA== 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=4jlY1+3ryXaORpVapRhiQMOXVCzV9ow8cBryuyr4eHI=; b=QnKWNbZUUs/h8JK2s4JogSux0B/QOiV3RHkkEf+fv6XHZ7yaMg9Wv+E+LUL71WX0g1 JfgRJB6kMknfu73fpEE4pnQanEivLtNI9hA+blapByR5M7prlJD4KorxVu1xujSxgf7m XNtmCmwV57bfYZh2HJSFRzj+U5fP0RJE/IsBenUo7klFel3ObBiIVAaJdAK63Ok89rmP R6EoOutaNI3Hsiki8zgqXGH/Vs/BDNINyZIGKfBpVZDKni+utY5/j46l0HOv23kksNES wJcua+KGVt7ieLxNL9KTDzBTEHK492KD2jBcDDmDhckzI2k05r16V5nezTlW+fpDrCfc J7yA== 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 y20si1992081ejw.238.2020.10.27.17.37.12; Tue, 27 Oct 2020 17:37:34 -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; 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 S2506949AbgJ0Gzm (ORCPT + 99 others); Tue, 27 Oct 2020 02:55:42 -0400 Received: from mga02.intel.com ([134.134.136.20]:42071 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2506930AbgJ0Gzl (ORCPT ); Tue, 27 Oct 2020 02:55:41 -0400 IronPort-SDR: XKkLEyHtBYSgq+qCM+5kfYTMO1jJsq4OKh3rulbv0jY4kTSDUlpZV6yEpMX71Y9YeHbIpf0Rkl FQbfRbvMhSEg== X-IronPort-AV: E=McAfee;i="6000,8403,9786"; a="155004166" X-IronPort-AV: E=Sophos;i="5.77,422,1596524400"; d="scan'208";a="155004166" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Oct 2020 23:55:40 -0700 IronPort-SDR: FZ2k/FPrj9MvP0pJJjFLbxAzxPB61vUE6kXqpndHFNi5se9f8ecnQ1tCN6o8AoiImn3NZ43g+m GrJRDHDLnCBg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,422,1596524400"; d="scan'208";a="350175865" Received: from jsia-hp-z620-workstation.png.intel.com ([10.221.118.135]) by orsmga008.jf.intel.com with ESMTP; 26 Oct 2020 23:55:38 -0700 From: Sia Jee Heng To: vkoul@kernel.org, Eugeniy.Paltsev@synopsys.com Cc: andriy.shevchenko@linux.intel.com, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 08/15] dmaengine: dw-axi-dmac: Support of_dma_controller_register() Date: Tue, 27 Oct 2020 14:38:51 +0800 Message-Id: <20201027063858.4877-9-jee.heng.sia@intel.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20201027063858.4877-1-jee.heng.sia@intel.com> References: <20201027063858.4877-1-jee.heng.sia@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support for of_dma_controller_register() so that DMA clients can pass in device handshake number to the AxiDMA driver. DMA clients shall code the device handshake number in the Device tree. When DMA activities are needed, DMA clients shall invoke OF helper function to pass in the device handshake number to the AxiDMA. Without register to the of_dma_controller_register(), data transfer between memory to device and device to memory operations would failed. Reviewed-by: Andy Shevchenko Signed-off-by: Sia Jee Heng --- .../dma/dw-axi-dmac/dw-axi-dmac-platform.c | 26 +++++++++++++++++++ drivers/dma/dw-axi-dmac/dw-axi-dmac.h | 1 + 2 files 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 9e574753aaf0..011cf7134f25 100644 --- a/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c +++ b/drivers/dma/dw-axi-dmac/dw-axi-dmac-platform.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -1103,6 +1104,22 @@ static int __maybe_unused axi_dma_runtime_resume(struct device *dev) return axi_dma_resume(chip); } +static struct dma_chan *dw_axi_dma_of_xlate(struct of_phandle_args *dma_spec, + struct of_dma *ofdma) +{ + struct dw_axi_dma *dw = ofdma->of_dma_data; + struct axi_dma_chan *chan; + struct dma_chan *dchan; + + dchan = dma_get_any_slave_channel(&dw->dma); + if (!dchan) + return NULL; + + chan = dchan_to_axi_dma_chan(dchan); + chan->hw_hs_num = dma_spec->args[0]; + return dchan; +} + static int parse_device_properties(struct axi_dma_chip *chip) { struct device *dev = chip->dev; @@ -1292,6 +1309,13 @@ static int dw_probe(struct platform_device *pdev) if (ret) goto err_pm_disable; + /* Register with OF helpers for DMA lookups */ + ret = of_dma_controller_register(pdev->dev.of_node, + dw_axi_dma_of_xlate, dw); + if (ret < 0) + dev_warn(&pdev->dev, + "Failed to register OF DMA controller, fallback to MEM_TO_MEM mode\n"); + dev_info(chip->dev, "DesignWare AXI DMA Controller, %d channels\n", dw->hdata->nr_channels); @@ -1325,6 +1349,8 @@ static int dw_remove(struct platform_device *pdev) devm_free_irq(chip->dev, chip->irq, chip); + of_dma_controller_free(chip->dev->of_node); + list_for_each_entry_safe(chan, _chan, &dw->dma.channels, vc.chan.device_node) { list_del(&chan->vc.chan.device_node); diff --git a/drivers/dma/dw-axi-dmac/dw-axi-dmac.h b/drivers/dma/dw-axi-dmac/dw-axi-dmac.h index a26b0a242a93..651874e5c88f 100644 --- a/drivers/dma/dw-axi-dmac/dw-axi-dmac.h +++ b/drivers/dma/dw-axi-dmac/dw-axi-dmac.h @@ -37,6 +37,7 @@ struct axi_dma_chan { struct axi_dma_chip *chip; void __iomem *chan_regs; u8 id; + u8 hw_hs_num; atomic_t descs_allocated; struct dma_pool *desc_pool; -- 2.18.0