Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp263168ybg; Fri, 12 Jun 2020 00:26:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwsHFXdS7q8njwPWFf8MdJiWm8+ogoowTPHhk7vHfhp2UMPasdvnx+XqorsbKsnzpT2TKRi X-Received: by 2002:a17:906:ae14:: with SMTP id le20mr11637654ejb.307.1591946812110; Fri, 12 Jun 2020 00:26:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591946812; cv=none; d=google.com; s=arc-20160816; b=ufw9DdRLUhZLyyYTezdWAonrba594hXTYQSZwgrMnHQwO0d+l3qnFbIQ4olOKcMiV6 L2H8tjur+oqb9iYN4FKIxYS11cjtMZMGpiBo9X7kW6mdx6AWLC/dw5yY0hUc4SZZ5KOL I9zyBmrz9uBlS/tqCsmRTKw2L+fkEbMs6y0OQav00ZabInBCd/2/GD1UNHsii25jNvxK 6Q3fksIZf4Jmc1mQz9ilO9n22CIeSHwltVqNgCxo10idG0Q5SH1SDSBQhIiC8nxuG3gM Hsj841GHfnQzjmtv6cQ5+uS6CJPY6WHiuSk+P8umIBR5pw02i9sHBMD7WosX6hIW2j6x TDWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=tLQE7wV1NTfhoHgYd+Fp8LE1oVNwfk4+OvmuXppYs8Q=; b=WH20RfbfT1gHESLev+iI8E77lvoHoFLMa1C7NL/Se0GoNdLyK4tdnNCe1hDZGNZvD5 yL+ohYZY20deqqap7WBacwKO8Cs9+Dw5q2jboJnvuQF23nQNtq/yHoAvAdP3ubWKDLDb Zszf+g+n81XcY1ZdMqkJfAanY1yWbX9qNt03TRnzGG/jbK0CRzk7EroIOUr275SRYB/f yFnIxQ8No+B4CejnrkGUg5z8V68xxNHf9GcHTWOvmzjMA6aYA18BEjNrHd8q9Mmy5vSo YdsHfLD22PeGxOdypjr+3JFXqpgu8As3jYR+4bnU195/JptVD7SD8F3zF5K+Xu1phWIy 3OOQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j25si3356653ejs.86.2020.06.12.00.26.29; Fri, 12 Jun 2020 00:26:52 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726569AbgFLHXR convert rfc822-to-8bit (ORCPT + 99 others); Fri, 12 Jun 2020 03:23:17 -0400 Received: from relay7-d.mail.gandi.net ([217.70.183.200]:54707 "EHLO relay7-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726387AbgFLHXQ (ORCPT ); Fri, 12 Jun 2020 03:23:16 -0400 X-Originating-IP: 91.224.148.103 Received: from xps13 (unknown [91.224.148.103]) (Authenticated sender: miquel.raynal@bootlin.com) by relay7-d.mail.gandi.net (Postfix) with ESMTPSA id 926A320003; Fri, 12 Jun 2020 07:23:14 +0000 (UTC) Date: Fri, 12 Jun 2020 09:23:13 +0200 From: Miquel Raynal To: Sivaprakash Murugesan Cc: richard@nod.at, vigneshr@ti.com, peter.ujfalusi@ti.com, boris.brezillon@collabora.com, architt@codeaurora.org, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V3 2/2] mtd: rawnand: qcom: set BAM mode only if not set already Message-ID: <20200612092313.3d8df859@xps13> In-Reply-To: <1591944589-14357-3-git-send-email-sivaprak@codeaurora.org> References: <1591944589-14357-1-git-send-email-sivaprak@codeaurora.org> <1591944589-14357-3-git-send-email-sivaprak@codeaurora.org> Organization: Bootlin X-Mailer: Claws Mail 3.17.4 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Sivaprakash, Sivaprakash Murugesan wrote on Fri, 12 Jun 2020 12:19:49 +0530: > BAM is DMA controller on QCOM ipq platforms, BAM mode on NAND driver > is set by writing BAM_MODE_EN bit on NAND_CTRL register. > > NAND_CTRL is an operational register and in BAM mode operational > registers are read only. > > So, before writing into NAND_CTRL register check if BAM mode is already So, before enabling BAM mode by writing the NAND_CTRL register, check if BAM mode was already enabled by the bootloader. > enabled by bootloader, and set BAM mode only if it is not set already. > > Signed-off-by: Sivaprakash Murugesan > --- > [V3] > * Changed commit message to give a small info about BAM > drivers/mtd/nand/raw/qcom_nandc.c | 9 ++++++++- > 1 file changed, 8 insertions(+), 1 deletion(-) > > diff --git a/drivers/mtd/nand/raw/qcom_nandc.c b/drivers/mtd/nand/raw/qcom_nandc.c > index e0c55bb..4827edd 100644 > --- a/drivers/mtd/nand/raw/qcom_nandc.c > +++ b/drivers/mtd/nand/raw/qcom_nandc.c > @@ -2784,7 +2784,14 @@ static int qcom_nandc_setup(struct qcom_nand_controller *nandc) > /* enable ADM or BAM DMA */ > if (nandc->props->is_bam) { > nand_ctrl = nandc_read(nandc, NAND_CTRL); > - nandc_write(nandc, NAND_CTRL, nand_ctrl | BAM_MODE_EN); > + /* NAND_CTRL is an operational registers, and CPU > + * access to operational registers are read only > + * in BAM mode. So update the NAND_CTRL register > + * only if it is not in BAM mode. In most cases BAM BAM mode already (Bootloaders might have already entered this mode). > + * mode will be enabled in bootloader > + */ > + if (!(nand_ctrl | BAM_MODE_EN)) > + nandc_write(nandc, NAND_CTRL, nand_ctrl | BAM_MODE_EN); > } else { > nandc_write(nandc, NAND_FLASH_CHIP_SELECT, DM_EN); > } Thanks, Miquèl