Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp304898pxu; Fri, 11 Dec 2020 02:47:21 -0800 (PST) X-Google-Smtp-Source: ABdhPJwj3cvPhN/XBmda9AnukCiUeaxvcBo6eTdxie2uiLHiXYSn3vcHidbZQv8WVZ/AlxlrsuD4 X-Received: by 2002:a17:906:3153:: with SMTP id e19mr10798887eje.17.1607683641230; Fri, 11 Dec 2020 02:47:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607683641; cv=none; d=google.com; s=arc-20160816; b=lcYEvmLNCvldvSVil2lgdY97axGCzbYNM7tsI2JaGlc+DgJKsvSOIYU+FHp4A+2aQ5 NvepnQmINsRnPoyS4LN0Pu26V5DXKJnZyz/6KW2XTSA3jrGvd3tqGoA3y/ig4KE5ePVF UJha7ZGTDmkdEJSwJ3o3imOgGYt/yKCiZGlvGk2ybb7UGSBgniO3uUWZj+OztnAS9Eqw XJThBj4g6iKg7YjkDErgqidPSDU2xW6Cf1fLyTwWOpSXkE5h9r7E3KtlDF7boY4cdpF5 uHfU5mL2Eh2qQxI0vsTbZ2F2Pzm9X0BaZMHzxLpz0sc8BajNGQ4yMvXhhCVkmNlV+Hj4 I8ww== 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=MRFTKgw/GHYcRUZ/GBrF4kcxlTW2VrUl1vDCHkKNRQFs01bWGbeTLZYL5h1hnyR3k0 yy3euDex6pe5EVmAvCft/hl0tzmsMyYysMd+adN+jO5hK48R3PVIUN+RPwSRWfoaWQ7G JoGC+lT8Wg+H78HtVHeDTGznPkrSS39JG4Cx0iiBARS/PUGG7X72yPJG4goCnkRa4liX gOj1UScFu57p+9yVrtP6Coi/5MLXvCZnAjx2NAbdJ3p44oGJuk23I7zb45fIXdCseSdF jnM6tPMJ7aiPFUEbXiyLpd3ftWg3RZe0KQNQxYpRQX4Uvca1jyaFgQvGQDBrM4BVj0sd buzg== 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 j20si4196977ejs.76.2020.12.11.02.46.58; Fri, 11 Dec 2020 02:47:21 -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 S2394331AbgLKBFs (ORCPT + 99 others); Thu, 10 Dec 2020 20:05:48 -0500 Received: from mga14.intel.com ([192.55.52.115]:12012 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2394188AbgLKBFS (ORCPT ); Thu, 10 Dec 2020 20:05:18 -0500 IronPort-SDR: eXGNDHmNFUvADr6bVnFnouLHoG05MdMPvuHNHruSuwwLnMAkOlHXPYIiw9GaEdVIAeKowVDV/t Xs9VXeAsNxzQ== X-IronPort-AV: E=McAfee;i="6000,8403,9831"; a="173596120" X-IronPort-AV: E=Sophos;i="5.78,409,1599548400"; d="scan'208";a="173596120" Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Dec 2020 17:04:38 -0800 IronPort-SDR: 2yNaRCNIhrRPqbBI93sUYKHk9stw3A6x+R4mCttFOWg6v2ofoAb+dZHg5jDufn085TUy5DEWlm Vjh+u018DRCg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.78,409,1599548400"; d="scan'208";a="320965836" Received: from jsia-hp-z620-workstation.png.intel.com ([10.221.118.135]) by fmsmga007.fm.intel.com with ESMTP; 10 Dec 2020 17:04:36 -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 v6 08/16] dmaengine: dw-axi-dmac: Support of_dma_controller_register() Date: Fri, 11 Dec 2020 08:46:34 +0800 Message-Id: <20201211004642.25393-9-jee.heng.sia@intel.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20201211004642.25393-1-jee.heng.sia@intel.com> References: <20201211004642.25393-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