Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2713762pxb; Sun, 24 Jan 2021 18:01:33 -0800 (PST) X-Google-Smtp-Source: ABdhPJwTFdPNO+egqvpC8u/mXVehVQGkqV1bHt88DXa7sB8QB/xi30KlnwmqMcbotRT/sJFwB0q4 X-Received: by 2002:a05:6402:757:: with SMTP id p23mr709885edy.245.1611540093169; Sun, 24 Jan 2021 18:01:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611540093; cv=none; d=google.com; s=arc-20160816; b=LmnpNXDB7OMumjRKcVFwBHu8d2C+T6oe2pGg0v5MgTaE947NnNmWSgLE0LwZHg9A0S HCCNQoIBeTEGewFcFfoGfGLMSDsKJZhCWVyoMEe1n8wMI58IkBs+I3g791E1u8aW94Ng lvbYYVVvwSmECZnDTSJgy0JVfsKQvounoqWb4Gpv49mKbiwr8ylzA+JwAD7xewwL1IEi i0JHHrRtL/Ve3CGmrz5kiF0cYrowhGEd+30QcGjLQAfEBM61dpv1sqlb7I+3bLKgD4S5 S94yXBHm1FaWJKKJ0zU9whBVwvgwCI9xA+cvGAaxSbUB7KvzM6VcOuoC/TG4p6vAurqJ oGCg== 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=uygFBJpKnyr4XyrkAG444giOkhyvFU806TIXb4yKgMM=; b=j9LU74CR1LOhAn6zfB5b3Fy65BRhHlHZz8I8GlbdAlDtjuVNSZmCV1Aquj55saIcdl ioKaty1hQbjY7dSbFd+cwmqWbmjPcARPMerKEcE/HeeZkGy6vATKXTPkLcCA+YGQsXl3 LYwedFe+uRE5hJhVDvf20Vfm/ju6XDiWz0h74MKSfoShbBTPa0mwTmcX2KAfQJ/BJ9iq oGxdEFdINdtTWF1yFpGb1p+oAgAkRvNPrtwQONbhfYlqQIoINefbwz8MC6XcEzimwOTK unMiDFeTzPIU8CVlTAhinSe/xVxEXmPrqwlczw9UzqQTh5AK0+GCALdH+dgrCaVm6ScW kttQ== 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 x59si6744042ede.287.2021.01.24.18.01.10; Sun, 24 Jan 2021 18:01:33 -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 S1726677AbhAYB7D (ORCPT + 99 others); Sun, 24 Jan 2021 20:59:03 -0500 Received: from mga11.intel.com ([192.55.52.93]:4250 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726727AbhAYBwL (ORCPT ); Sun, 24 Jan 2021 20:52:11 -0500 IronPort-SDR: 4eMgmFBCId3OZ3m4tlA2+X8RepdM3i4+HRrSM6TCGrb+jfX0oJxSsbnGG0SjUbIM4BnKAA8VGA 8khv+YZSrRJw== X-IronPort-AV: E=McAfee;i="6000,8403,9874"; a="176137821" X-IronPort-AV: E=Sophos;i="5.79,372,1602572400"; d="scan'208";a="176137821" Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Jan 2021 17:50:45 -0800 IronPort-SDR: FOQr4JXj4odrmJ4K02BT+u9dCgX3ODHLjZ+T6C4WTuhcFHuZsyUtaYy46td37nT75E0Sx8ApEf V6T9bP11k15A== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.79,372,1602572400"; d="scan'208";a="352795942" Received: from jsia-hp-z620-workstation.png.intel.com ([10.221.118.135]) by orsmga003.jf.intel.com with ESMTP; 24 Jan 2021 17:50:43 -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 v12 08/17] dmaengine: dw-axi-dmac: Support of_dma_controller_register() Date: Mon, 25 Jan 2021 09:32:46 +0800 Message-Id: <20210125013255.25799-9-jee.heng.sia@intel.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20210125013255.25799-1-jee.heng.sia@intel.com> References: <20210125013255.25799-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. 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 | 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 a76299360f69..a8b6c8c8ef58 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