Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp543926pxu; Sun, 22 Nov 2020 18:55:12 -0800 (PST) X-Google-Smtp-Source: ABdhPJy/pdL+6Q54saRwxWw1WNw2QtNIcU9w4OhJWhPQVGppf6W2jgdVDYNmqVMcYDRAs5xwOApY X-Received: by 2002:a17:906:f186:: with SMTP id gs6mr43915809ejb.171.1606100111908; Sun, 22 Nov 2020 18:55:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606100111; cv=none; d=google.com; s=arc-20160816; b=D9ENcZ1LvtNut/lA2O6D9wGpD6t8bbY7W89wip93R17fSTMTV+7OMmiLWgpwMtx0YK uVKGyipkRu3Wkg9n2BIr8qCfadBR4IvlN+5fummOLwet2C30qZ18BWblFKM4myR3GfI8 rNwcJEcmXgL6+P4FAJpye9DUHhuearBQB+C1wWgUmRfMj7BfSLQ0WBcfWJyK9UBEqGaB JscKtqBnHSJ8fn/Hm//pKFcA+DpP6KRl5IVKuMQjetxxNe+B8DSD9/hHeoPXCvyF+B9w ufi2AES6zOiD2ilFWxDaWdqHPIEgbZjdQRpBh9PgPYHZJyXoMUcl7ucyxEbeycKPyAIL ammQ== 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=Q99OZhJtfXzy78q2L1fZ5/dParhj4J3XirlAmD0mxgQ=; b=SFvy1k8ddPy1+DEF79SmOgb/99LZmCHlaE/WxG9AdJmtOyDig+zPKHJMGDXbKF3Rs2 QnfiSxeD2I4ixBR3l9i+7tpLaQ2uRAPJgSBurN5nccA8P4YixvtdBXdFCWO3CEhQ3OqS 0FvF+GB9dNHRqZmqIvjOO/0Ki9N7Ust2R2k0u6Jx9sBj/1q7/Dq0aUQf6WyCf9NbEEAG SxIED6f3ze6QVZYXk1QXgGcR0w5RZUsdbuREzC/obB1V+SQb57n+dPOdyGqyqKDxTw+v bweavv02JOdE8PaEVYtDeOC3zXWsNeFsPX2bAU1w7N127FUyrtaSOr+Myp7/y8ZE3yEM xN4A== 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 h6si5569387ejb.104.2020.11.22.18.54.49; Sun, 22 Nov 2020 18:55:11 -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 S1727543AbgKWCv5 (ORCPT + 99 others); Sun, 22 Nov 2020 21:51:57 -0500 Received: from mga18.intel.com ([134.134.136.126]:60192 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727383AbgKWCv4 (ORCPT ); Sun, 22 Nov 2020 21:51:56 -0500 IronPort-SDR: 2B2PTPs4tilwEB0PRNd7KyeYNqXALh/SKCpsK30cYyev82d97OJmqipKW7q27J96yYT/bD8BT4 pykOems7Ijqg== X-IronPort-AV: E=McAfee;i="6000,8403,9813"; a="159460007" X-IronPort-AV: E=Sophos;i="5.78,361,1599548400"; d="scan'208";a="159460007" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Nov 2020 18:51:56 -0800 IronPort-SDR: Yr6OiTDp1PEx4ORnt6/ZtHyLhkCgTSi+fDEQtiTqsAOAxfQSLQXaxLxLrhKXr2aW5yzKDOITxD 4Dw/J29iyKyA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.78,361,1599548400"; d="scan'208";a="369879869" Received: from jsia-hp-z620-workstation.png.intel.com ([10.221.118.135]) by FMSMGA003.fm.intel.com with ESMTP; 22 Nov 2020 18:51:54 -0800 From: Sia Jee Heng To: vkoul@kernel.org, Eugeniy.Paltsev@synopsys.com, robh+dt@kernel.org Cc: andriy.shevchenko@linux.intel.com, dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org Subject: [PATCH v5 08/16] dmaengine: dw-axi-dmac: Support of_dma_controller_register() Date: Mon, 23 Nov 2020 10:34:44 +0800 Message-Id: <20201123023452.7894-9-jee.heng.sia@intel.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20201123023452.7894-1-jee.heng.sia@intel.com> References: <20201123023452.7894-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 b5f92f9cb2bc..40c4af0e0421 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 @@ -1044,6 +1045,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_handshake_num = dma_spec->args[0]; + return dchan; +} + static int parse_device_properties(struct axi_dma_chip *chip) { struct device *dev = chip->dev; @@ -1233,6 +1250,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); @@ -1266,6 +1290,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..3498bef5453b 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_handshake_num; atomic_t descs_allocated; struct dma_pool *desc_pool; -- 2.18.0