Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2135697ybi; Thu, 20 Jun 2019 09:38:48 -0700 (PDT) X-Google-Smtp-Source: APXvYqzLq7eE2t0c+h9r9/vnimPKS85usFHMxNmUdLv4xjjLFvrtgyt1n7GIJlSvZzjE23xMIIgy X-Received: by 2002:aa7:9f1c:: with SMTP id g28mr107353975pfr.81.1561048718694; Thu, 20 Jun 2019 09:38:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561048718; cv=none; d=google.com; s=arc-20160816; b=Xf0n7TqLHaIxqoS5AvW5vxbzFK3d/bDLCRWWvtIaqkFRlN4Ab51ni8lX475Tj2tF+p Ll9UQ5E8nG3H6gMwpnicJB6+8Lbf3T07+n+KickSR/enFqAIHrdvmr2wiGKAD+2MuJ+b AmdDddwWO7fxZin5kiFQ26TUkQJPH6vax+8homVdoaxkAdWESZEWDdCBOhK+UlOmJ+nJ qTGRiSL8dwrCDkIESaCAV60Jxyqb8dsU2lP64icDaW2GRQftNznXo+5WsD0zh5JjGO71 C7Ppug3DPc0eqODLJNR0YOqoiETs9juNFwAvoC3UHqpbytaVO8ADE6CCPY/+NMQzU9xK x1zg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=6RkFNLQpmzjRV3Rgys7kiM3j/nT+Z+Cc5BJVeuxsSpE=; b=PNA69H5AJ5f9xblmxXQU6HF3J+S7U8gtr2YR1g92nlwZUcCtpwB6z1xgkEvU0MU4qo 41M5PFIAzn7YLOZlwsPVM+kqXbN60Twi14np4On9ShJRdF7GTaRC9YpoC8nCB/7809DM Cjru4oMH8RtwzapQ7rV2v7ghH8Azl9Tfu8HsKzIyALC+WpKT3NwKeuLcVjv47ds1rsjM eMD4aPEARtJPvDPj+Lrd0bzpiLhhQWTxOWbAN3PLzNh0MC+xQg8pWqig2ARKBpx7l2yt R8vEo+ScOMAcRk9kX/9hCzro4+vP8OrGKwPVCJ1JZKmbZ94XgL2NseRH8mUyVED+0a8c 87FQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=KnAsXeS3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x22si160251pln.150.2019.06.20.09.38.23; Thu, 20 Jun 2019 09:38:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=KnAsXeS3; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726940AbfFTQhP (ORCPT + 99 others); Thu, 20 Jun 2019 12:37:15 -0400 Received: from hqemgate15.nvidia.com ([216.228.121.64]:12959 "EHLO hqemgate15.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726551AbfFTQhP (ORCPT ); Thu, 20 Jun 2019 12:37:15 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqemgate15.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Thu, 20 Jun 2019 09:37:15 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Thu, 20 Jun 2019 09:37:14 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Thu, 20 Jun 2019 09:37:14 -0700 Received: from [10.21.132.148] (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Thu, 20 Jun 2019 16:37:12 +0000 Subject: Re: [PATCH] dmaengine: tegra210-adma: fix transfer failure To: Sameer Pujar , , CC: , , , , References: <1561047348-14413-1-git-send-email-spujar@nvidia.com> From: Jon Hunter Message-ID: <1ea807ca-24b3-c884-6a4d-4e260f51ceaa@nvidia.com> Date: Thu, 20 Jun 2019 17:37:10 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <1561047348-14413-1-git-send-email-spujar@nvidia.com> X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL105.nvidia.com (172.20.187.12) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1561048635; bh=6RkFNLQpmzjRV3Rgys7kiM3j/nT+Z+Cc5BJVeuxsSpE=; h=X-PGP-Universal:Subject:To:CC:References:From:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=KnAsXeS3CRR79FZsSNkMGt6mfKt10Pxy3VUS+f0Vo4a6GInUIKRBkOa/ZFegxDwzB rW9mBDiV7T0NmlZdY3KEkoVYSxNicHAQb71NvLkABeLsdgg3pLLad3hJB/rgjGuYbr /P3FhNktZ8o9FPCSUfo61AmQn5pfQ0jDBr+r1NntC3ODSUkoo6N24iN9OeYGOiLeCd SLrmDHOjM06+auoUv8XuTUrsG4u/CCU6Fu69AhMXK876rJUo2ho/WfngejfLQ2Pv3c r+1xAiunf4cfbLSY/NO6O851cHHmxQJVKmQs6ap3JZD5woK5/CYX0FP5Tu9D07QoY5 XObonalYxZ2vQ== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20/06/2019 17:15, Sameer Pujar wrote: > From Tegra186 onwards OUTSTANDING_REQUESTS field is added in channel > configuration register (bits 7:4). ADMA allows a maximum of 8 reads > to source and that many writes to target memory be outstanding at any > given point of time. If this field is not programmed, DMA transfers > fail to happen. > > Thus added 'ch_pending_req' member in chip data structure and the > same is populated with maximum allowed pending requests. Since the > field is not applicable to Tegra210, mentioned bit fields are unused > and hence the member is initialized with 0. > > Fixes: 433de642a76c ("dmaengine: tegra210-adma: add support for Tegra186/Tegra194") > > Signed-off-by: Sameer Pujar > --- > drivers/dma/tegra210-adma.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/drivers/dma/tegra210-adma.c b/drivers/dma/tegra210-adma.c > index 17ea4dd99..8d291cf 100644 > --- a/drivers/dma/tegra210-adma.c > +++ b/drivers/dma/tegra210-adma.c > @@ -96,6 +96,7 @@ struct tegra_adma; > * @ch_req_tx_shift: Register offset for AHUB transmit channel select. > * @ch_req_rx_shift: Register offset for AHUB receive channel select. > * @ch_base_offset: Register offset of DMA channel registers. > + * @ch_pending_req: Outstaning DMA requests for a channel. > * @ch_fifo_ctrl: Default value for channel FIFO CTRL register. > * @ch_req_mask: Mask for Tx or Rx channel select. > * @ch_req_max: Maximum number of Tx or Rx channels available. > @@ -109,6 +110,7 @@ struct tegra_adma_chip_data { > unsigned int ch_req_tx_shift; > unsigned int ch_req_rx_shift; > unsigned int ch_base_offset; > + unsigned int ch_pending_req; > unsigned int ch_fifo_ctrl; > unsigned int ch_req_mask; > unsigned int ch_req_max; > @@ -613,6 +615,7 @@ static int tegra_adma_set_xfer_params(struct tegra_adma_chan *tdc, > ADMA_CH_CTRL_FLOWCTRL_EN; > ch_regs->config |= cdata->adma_get_burst_config(burst_size); > ch_regs->config |= ADMA_CH_CONFIG_WEIGHT_FOR_WRR(1); > + ch_regs->config |= cdata->ch_pending_req; > ch_regs->fifo_ctrl = cdata->ch_fifo_ctrl; > ch_regs->tc = desc->period_len & ADMA_CH_TC_COUNT_MASK; > > @@ -797,6 +800,7 @@ static const struct tegra_adma_chip_data tegra210_chip_data = { > .ch_req_tx_shift = 28, > .ch_req_rx_shift = 24, > .ch_base_offset = 0, > + .ch_pending_req = 0, > .ch_fifo_ctrl = TEGRA210_FIFO_CTRL_DEFAULT, > .ch_req_mask = 0xf, > .ch_req_max = 10, > @@ -811,6 +815,7 @@ static const struct tegra_adma_chip_data tegra186_chip_data = { > .ch_req_tx_shift = 27, > .ch_req_rx_shift = 22, > .ch_base_offset = 0x10000, > + .ch_pending_req = (8 << 4), So given that this is a value and a shift, I think that we should add a proper definition like we have for TEGRA186_FIFO_CTRL_DEFAULT below. > .ch_fifo_ctrl = TEGRA186_FIFO_CTRL_DEFAULT, > .ch_req_mask = 0x1f, > .ch_req_max = 20, > Please group your patches into a series if you have more than one for a given driver. Cheers Jon -- nvpublic