Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp611071pxb; Wed, 15 Sep 2021 09:09:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz0TUt1BBl9uVt1mdVBMTTtVou8U10q6Hy51q7OLPOKIBMXGMwUYCXEysAcll7QiyFXM3ed X-Received: by 2002:a5e:dc0b:: with SMTP id b11mr641665iok.91.1631722163842; Wed, 15 Sep 2021 09:09:23 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1631722163; cv=pass; d=google.com; s=arc-20160816; b=jKLP2Hu9jAq1qKiMUWc8b386jdLMnJ1xGuavFD/I/1F4EZ26fch7ocHSi5OJzRUKG4 viYzgCNrfNOGlAjL17ATSkIJrAT5ndxUwu/U1D3q0mKT+PKAIpM3Fh/grvTbKHLgwWcw 5V/dgIRRsJQxLAOYcnf46cnLtHJqCmof35nx22KJ1UF5zbl2b73vFmi1BnKdGKvHv3rm J04oq/6V9J4mAnCf4D8KnZLkYqTWvP4Iq7VygXJUHr65bHIHn48HVScNE2O9W9/C9Rl1 QGKRI3yLLjn40ApHO+J31YHJbLwDlpyLQe4arfwWOqAydQWW6WaW4krH+9vcNnCOGfqw 3Ygg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=OpXQJ08PSTw9sMnbLT/iyjMGkg/RcxTmwYosjmSqCng=; b=JHiJ5hsIzyU+IWMOO2VVNd9JFesUbbafhfnp0qVpPWOkIG6qU2Naax183I3bkpLrUB fCfJAuoK3LvFTV3ms2w4aZRGJAsA4Qn9sXpqSYu/CiX1IkZPGVjh4Ya0mWITgG+6gI7z Q7IFZV4XQfUOEQXE33ntu1yVUo45FJxc32JkLNT85M+Wf208B1pK/WkF9YLxd2rb/B25 tSIWMD44ijqGKHH/qeC6MCTijrsT2mrWBy15r4zkTDSXibMQ28hBIhJuPFQZ1JKJoADT tKRa9qa9L2CYl7YbM4Y6dKMj5Ro1ltnw0hVf/Np2Hz5MNdAryt4KCwk/+oJzvbMIH7nd rD+A== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@Nvidia.com header.s=selector2 header.b=EBoIiVal; arc=pass (i=1 spf=pass spfdomain=nvidia.com dmarc=pass fromdomain=nvidia.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=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s20si324016ioa.93.2021.09.15.09.09.10; Wed, 15 Sep 2021 09:09:23 -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; dkim=pass header.i=@Nvidia.com header.s=selector2 header.b=EBoIiVal; arc=pass (i=1 spf=pass spfdomain=nvidia.com dmarc=pass fromdomain=nvidia.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=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237250AbhIOQIz (ORCPT + 99 others); Wed, 15 Sep 2021 12:08:55 -0400 Received: from mail-mw2nam10on2061.outbound.protection.outlook.com ([40.107.94.61]:46433 "EHLO NAM10-MW2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S236847AbhIOQIn (ORCPT ); Wed, 15 Sep 2021 12:08:43 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=XzfvPU68eqy9EkxamKdAatoUp9MWWFCBw7JDEeO8/196YRIYAzV+GoHCusS9nPAX9NJiPGoI2mUwX0gskLkQMJWjPS5FHKwD3WZWT7M87wufJQz7dVa6hkilEWSnocMnEMYHa2I09iZUaUuoxB7woP9uWD1RmIl+f7drNG5TCwJEN5gGa0lSHQB6eUo6bPts+wza1TEinwwVfsqpmk0JSZasNeQz1C0tbvE1AYbKic61opfNBz1WZvuxHHGU97zny8Io1bUscfYRpqO0v+E2T/gFP9FoJrjLqK+J8wfbV27K2HuRL1lD8UacWLQxKZghDmV4XSr+yuywJVjo4hQPdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=OpXQJ08PSTw9sMnbLT/iyjMGkg/RcxTmwYosjmSqCng=; b=hw9dJqTAzv36e5Q8VeQCU+ccr4DtA7G+6zdBWgeBrLIU5aSDTu2+fN7Y2lGHVTVXSiGVZTdGt06B1nZR1h1HQ6c9Mx1/aS77XWczReiaRwFTvA3Wgkg3TUvX0bm88/1wB6m5r6PFQ6ODIjz+DXtG87R3VY/b0Pfr3/z/H3ZdNS9/jPqigbABASqXtp7gHVJTHTjO5VIfMOmxJQvTM5XPtY/cuZjiNhVNQYDv3A637MUU/tFpZR/hybXiUnhKmpbH8JfttDpXE1ZWzwjidbKyrRgsS9Ez81dHIKT9THts2XTqUTX7UXFhdIzw+6OaBVQgp+JXLVcEWF9VJiJvO7wz+w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.112.35) smtp.rcpttodomain=vger.kernel.org smtp.mailfrom=nvidia.com; dmarc=pass (p=quarantine sp=none pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=OpXQJ08PSTw9sMnbLT/iyjMGkg/RcxTmwYosjmSqCng=; b=EBoIiValaOaDpUJtVrn943l9gx/1Rdg+XsXRWn5GbJ/SbQeDGuDROJ3v0HopnXgb3RiGdoeO8yMnvXe6IJUcupIP0OIoUpCA/TRvqiwVI7YB/KHYSIQCMU6yghPIGArpadl/yEFJD5UazhKhu7/vAx+LEqAsNv8vlDKseJtrkflA75Q13vH0MhnuFOLumnQkaaa8r1nlutLKWKL61Xnqf7aS9MxLAPl0ffhGKIjYI//qtSgHgCAyFtM55BPrQrT9CW3QXiAYMFOmokzxH/oiKdp6isu+yQDBm0Jv9UcbHhGABbC0lCpRMWudj1Qs+xnn/Mtwgs0EuAE1xGEL3zd9fA== Received: from DS7PR03CA0305.namprd03.prod.outlook.com (2603:10b6:8:2b::25) by DM6PR12MB3307.namprd12.prod.outlook.com (2603:10b6:5:15d::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4500.14; Wed, 15 Sep 2021 16:07:22 +0000 Received: from DM6NAM11FT016.eop-nam11.prod.protection.outlook.com (2603:10b6:8:2b:cafe::c4) by DS7PR03CA0305.outlook.office365.com (2603:10b6:8:2b::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4523.14 via Frontend Transport; Wed, 15 Sep 2021 16:07:22 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.112.35) smtp.mailfrom=nvidia.com; vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.112.35 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.112.35; helo=mail.nvidia.com; Received: from mail.nvidia.com (216.228.112.35) by DM6NAM11FT016.mail.protection.outlook.com (10.13.173.139) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.4523.14 via Frontend Transport; Wed, 15 Sep 2021 16:07:22 +0000 Received: from HQMAIL109.nvidia.com (172.20.187.15) by HQMAIL111.nvidia.com (172.20.187.18) with Microsoft SMTP Server (TLS) id 15.0.1497.18; Wed, 15 Sep 2021 16:07:21 +0000 Received: from audio.nvidia.com (172.20.187.6) by mail.nvidia.com (172.20.187.15) with Microsoft SMTP Server id 15.0.1497.18 via Frontend Transport; Wed, 15 Sep 2021 09:07:19 -0700 From: Sameer Pujar To: , , , CC: , , , Sameer Pujar Subject: [RESEND PATCH 3/3] dmaengine: tegra210-adma: Override ADMA FIFO size Date: Wed, 15 Sep 2021 21:37:05 +0530 Message-ID: <1631722025-19873-4-git-send-email-spujar@nvidia.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1631722025-19873-1-git-send-email-spujar@nvidia.com> References: <1631722025-19873-1-git-send-email-spujar@nvidia.com> MIME-Version: 1.0 Content-Type: text/plain X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: bfaf17f5-d365-416b-fb4d-08d97862e6d4 X-MS-TrafficTypeDiagnostic: DM6PR12MB3307: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:9508; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: /+siz2i8AzT4EmLosATXOp/bN9DVQxYgY9+KCaOTDz2I3b9LeVVjg2MXs1Mlph04nQdLrAsaFoEbNS2vlvyNPxygVQnstCEUW2yIXXFQGwo6+mRdub/Y+toaTZgSBC5wKNZ2qhx8esQdx91KNf/noeOSUCynUvOB/DTwl139xutrqp/qODkLD8xJe36O8LkGH0ex2sYBGkL6N0vDrO7srLesfxyd+Ard3F4kB3MVXL7GS/0kpU6t0lPFyX+eN6Ea/cwSwbo5RZoCLhkICa01ytkygOHVostW350f0iq9YLLoQOWEWBEOerWUC6Rc1O39f2OfPqCBuRWXSwoNggabEdnOxgHJT8qy449qwCRvxp4qLRiLXvmmNZKS8pfZY/EzW4V5E0uTbmZdOVxWCbjOUdYAuqSturkX58WTWM8v3jKLnPseZdc/93ngS/NbHuOk5olA0wNQrPaL2g8h87jnZH9s4xC1PMZ5Hr/4cVeFo4dDFMUpkiI+0ICOn/Y7jKEhy53DrQfZDmHthJ79Vwva4n35oGFwlxuf1eZKtckJjrG57yvAZCf0nXgjbNQ8zK/y9hQtyboVLH81tSrIMS2VQH8eBI5HZbzVRG6/sNO4e/GGDU+3fUsWcpGEq/b2850jpWoGC01hC2I7A9eJD2E7HVK1jZZSQC/c6dPOUHyasEMz51gAmu1dlDqesFJza8F4q8bEQnq1H+ryqX9KQmbafA== X-Forefront-Antispam-Report: CIP:216.228.112.35;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:schybrid02.nvidia.com;CAT:NONE;SFS:(4636009)(376002)(136003)(346002)(396003)(39860400002)(46966006)(36840700001)(36906005)(82740400003)(316002)(82310400003)(47076005)(54906003)(86362001)(2616005)(36860700001)(5660300002)(6666004)(7696005)(70586007)(336012)(356005)(2906002)(8676002)(7636003)(186003)(70206006)(26005)(8936002)(4326008)(36756003)(478600001)(107886003)(83380400001)(110136005)(426003);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 Sep 2021 16:07:22.3432 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: bfaf17f5-d365-416b-fb4d-08d97862e6d4 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.112.35];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT016.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR12MB3307 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ADMAIF FIFO uses a ring buffer and it is divided amongst the available channels. The default FIFO size (in multiples of 16 words) of ADMAIF TX/RX channels is as below: * On Tegra210, channel 1 to 2 : size = 3 channel 3 to 10: size = 2 * On Tegra186 and later, channel 1 to 4 : size = 3 channel 5 to 20: size = 2 As per recommendation from HW, FIFO size of ADMA channel should be same as the corresponding ADMAIF channel it maps to. FIFO corruption is observed if the sizes do not match. We are using the default FIFO sizes for ADMAIF and there is no plan to support any custom values. Thus at runtime, override the ADMA channel FIFO size value depending on the corresponding ADMAIF channel. Fixes: 9ab59bf5dd63 ("dmaengine: tegra210-adma: Fix channel FIFO configuration") Signed-off-by: Sameer Pujar --- drivers/dma/tegra210-adma.c | 48 ++++++++++++++++++++++++++++++++------------- 1 file changed, 34 insertions(+), 14 deletions(-) diff --git a/drivers/dma/tegra210-adma.c b/drivers/dma/tegra210-adma.c index 03f9776..911533c 100644 --- a/drivers/dma/tegra210-adma.c +++ b/drivers/dma/tegra210-adma.c @@ -43,10 +43,8 @@ #define TEGRA186_ADMA_CH_CONFIG_OUTSTANDING_REQS(reqs) (reqs << 4) #define ADMA_CH_FIFO_CTRL 0x2c -#define TEGRA210_ADMA_CH_FIFO_CTRL_TXSIZE(val) (((val) & 0xf) << 8) -#define TEGRA210_ADMA_CH_FIFO_CTRL_RXSIZE(val) ((val) & 0xf) -#define TEGRA186_ADMA_CH_FIFO_CTRL_TXSIZE(val) (((val) & 0x1f) << 8) -#define TEGRA186_ADMA_CH_FIFO_CTRL_RXSIZE(val) ((val) & 0x1f) +#define ADMA_CH_TX_FIFO_SIZE_SHIFT 8 +#define ADMA_CH_RX_FIFO_SIZE_SHIFT 0 #define ADMA_CH_LOWER_SRC_ADDR 0x34 #define ADMA_CH_LOWER_TRG_ADDR 0x3c @@ -61,12 +59,6 @@ #define TEGRA_ADMA_BURST_COMPLETE_TIME 20 -#define TEGRA210_FIFO_CTRL_DEFAULT (TEGRA210_ADMA_CH_FIFO_CTRL_TXSIZE(3) | \ - TEGRA210_ADMA_CH_FIFO_CTRL_RXSIZE(3)) - -#define TEGRA186_FIFO_CTRL_DEFAULT (TEGRA186_ADMA_CH_FIFO_CTRL_TXSIZE(3) | \ - TEGRA186_ADMA_CH_FIFO_CTRL_RXSIZE(3)) - #define ADMA_CH_REG_FIELD_VAL(val, mask, shift) (((val) & mask) << shift) struct tegra_adma; @@ -84,6 +76,8 @@ struct tegra_adma; * @ch_req_max: Maximum number of Tx or Rx channels available. * @ch_reg_size: Size of DMA channel register space. * @nr_channels: Number of DMA channels available. + * @ch_fifo_size_mask: Mask for FIFO size field. + * @sreq_index_offset: Slave channel index offset. * @has_outstanding_reqs: If DMA channel can have outstanding requests. */ struct tegra_adma_chip_data { @@ -98,6 +92,8 @@ struct tegra_adma_chip_data { unsigned int ch_req_max; unsigned int ch_reg_size; unsigned int nr_channels; + unsigned int ch_fifo_size_mask; + unsigned int sreq_index_offset; bool has_outstanding_reqs; }; @@ -561,13 +557,14 @@ static int tegra_adma_set_xfer_params(struct tegra_adma_chan *tdc, { struct tegra_adma_chan_regs *ch_regs = &desc->ch_regs; const struct tegra_adma_chip_data *cdata = tdc->tdma->cdata; - unsigned int burst_size, adma_dir; + unsigned int burst_size, adma_dir, fifo_size_shift; if (desc->num_periods > ADMA_CH_CONFIG_MAX_BUFS) return -EINVAL; switch (direction) { case DMA_MEM_TO_DEV: + fifo_size_shift = ADMA_CH_TX_FIFO_SIZE_SHIFT; adma_dir = ADMA_CH_CTRL_DIR_MEM2AHUB; burst_size = tdc->sconfig.dst_maxburst; ch_regs->config = ADMA_CH_CONFIG_SRC_BUF(desc->num_periods - 1); @@ -578,6 +575,7 @@ static int tegra_adma_set_xfer_params(struct tegra_adma_chan *tdc, break; case DMA_DEV_TO_MEM: + fifo_size_shift = ADMA_CH_RX_FIFO_SIZE_SHIFT; adma_dir = ADMA_CH_CTRL_DIR_AHUB2MEM; burst_size = tdc->sconfig.src_maxburst; ch_regs->config = ADMA_CH_CONFIG_TRG_BUF(desc->num_periods - 1); @@ -599,7 +597,27 @@ static int tegra_adma_set_xfer_params(struct tegra_adma_chan *tdc, ch_regs->config |= ADMA_CH_CONFIG_WEIGHT_FOR_WRR(1); if (cdata->has_outstanding_reqs) ch_regs->config |= TEGRA186_ADMA_CH_CONFIG_OUTSTANDING_REQS(8); - ch_regs->fifo_ctrl = cdata->ch_fifo_ctrl; + + /* + * 'sreq_index' represents the current ADMAIF channel number and as per + * HW recommendation its FIFO size should match with the corresponding + * ADMA channel. + * + * ADMA FIFO size is set as per below (based on default ADMAIF channel + * FIFO sizes): + * fifo_size = 0x2 (sreq_index > sreq_index_offset) + * fifo_size = 0x3 (sreq_index <= sreq_index_offset) + * + */ + if (tdc->sreq_index > cdata->sreq_index_offset) + ch_regs->fifo_ctrl = + ADMA_CH_REG_FIELD_VAL(2, cdata->ch_fifo_size_mask, + fifo_size_shift); + else + ch_regs->fifo_ctrl = + ADMA_CH_REG_FIELD_VAL(3, cdata->ch_fifo_size_mask, + fifo_size_shift); + ch_regs->tc = desc->period_len & ADMA_CH_TC_COUNT_MASK; return tegra_adma_request_alloc(tdc, direction); @@ -783,11 +801,12 @@ 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_fifo_ctrl = TEGRA210_FIFO_CTRL_DEFAULT, .ch_req_mask = 0xf, .ch_req_max = 10, .ch_reg_size = 0x80, .nr_channels = 22, + .ch_fifo_size_mask = 0xf, + .sreq_index_offset = 2, .has_outstanding_reqs = false, }; @@ -798,11 +817,12 @@ 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_fifo_ctrl = TEGRA186_FIFO_CTRL_DEFAULT, .ch_req_mask = 0x1f, .ch_req_max = 20, .ch_reg_size = 0x100, .nr_channels = 32, + .ch_fifo_size_mask = 0x1f, + .sreq_index_offset = 4, .has_outstanding_reqs = true, }; -- 2.7.4