From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Gupta, Pekon" To: Lee Jones , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" Subject: RE: [RFC 07/47] mtd: nand: stm_nand_bch: initialise the BCH Controller Date: Wed, 26 Mar 2014 10:25:52 +0000 Message-ID: <20980858CB6D3A4BAE95CA194937D5E73EAB5CB7@DBDE04.ent.ti.com> References: <1395735604-26706-1-git-send-email-lee.jones@linaro.org> <1395735604-26706-8-git-send-email-lee.jones@linaro.org> In-Reply-To: <1395735604-26706-8-git-send-email-lee.jones@linaro.org> Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Cc: "angus.clark@st.com" , "kernel@stlinux.com" , "linux-mtd@lists.infradead.org" , "Ezequiel Garcia \(ezequiel.garcia@free-electrons.com\)" , "computersforpeace@gmail.com" , "dwmw2@infradead.org" List-Id: Linux MTD discussion mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Hi Lee, >From: Lee Jones [mailto:lee.jones@linaro.org] missing commit log :-) Though $subject is self-explanatory, but you can add more description about assumption and hardware caveats about the controller, and its use. > >Signed-off-by: Lee Jones >--- > drivers/mtd/nand/stm_nand_bch.c | 56 ++++++++++++++++++++++++++++++++++++= +++++ > include/linux/mtd/stm_nand.h | 20 +++++++++++++++ > 2 files changed, 76 insertions(+) > >diff --git a/drivers/mtd/nand/stm_nand_bch.c b/drivers/mtd/nand/stm_nand_b= ch.c >index 76a0d02..1a93f8d 100644 >--- a/drivers/mtd/nand/stm_nand_bch.c >+++ b/drivers/mtd/nand/stm_nand_bch.c >@@ -14,6 +14,7 @@ > > #include > #include >+#include > #include > #include > #include >@@ -102,6 +103,56 @@ static void nandi_disable_interrupts(struct nandi_con= troller *nandi, > writel(val, nandi->base + NANDBCH_INT_EN); > } > >+static void nandi_init_bch(struct nandi_controller *nandi, int emi_bank) >+{ >+ dev_dbg(nandi->dev, "%s\n", __func__); >+ >+ /* Initialise BCH Controller */ >+ emiss_nandi_select(STM_NANDI_BCH); >+ >+ /* Reset and disable boot-mode controller */ >+ writel(BOOT_CFG_RESET, nandi->base + NANDBCH_BOOTBANK_CFG); >+ udelay(1); >+ writel(0x00000000, nandi->base + NANDBCH_BOOTBANK_CFG); Why using 'udelay' ? Isn't there any status register which tells you that controller is reset / = initialized ? Or may be polling on NANDBCH_BOOTBANK_CFG may itself give you status. >+ >+ /* Reset AFM controller */ >+ writel(CFG_RESET, nandi->base + NANDBCH_CONTROLLER_CFG); >+ udelay(1); >+ writel(0x00000000, nandi->base + NANDBCH_CONTROLLER_CFG); >+ >+ /* Set EMI Bank */ >+ writel(0x1 << emi_bank, nandi->base + NANDBCH_FLEX_MUXCTRL); >+ >+ /* Reset ECC stats */ >+ writel(0x7f0, nandi->base + NANDBCH_CONTROLLER_CFG); >+ udelay(1); >+ "0x7f0" ?? please use Macro instead. with regards, pekon