Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2183311pxb; Fri, 5 Feb 2021 10:55:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJxdCO4JtEYg1QbiViS2IU2YsKvVnhLyAHLceFqH37G9NrogafuBwOucSW6/zg6N3AsjwCR0 X-Received: by 2002:a17:906:8516:: with SMTP id i22mr5421520ejx.200.1612551350332; Fri, 05 Feb 2021 10:55:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612551350; cv=none; d=google.com; s=arc-20160816; b=HT5FJNutKi5QWm3nCZFvIRdi4oPZWsh8yc/rzr3J5qYjnnxeX9EgVleoseYzHXedx4 zWrRD3q2TX74UHvkgSgwSuK3OuGVW3FmP67ycg9KtQjRPRkHp+sYR/jHFJh7ewuwjhmg +bMN8+AMI1/vqT24kQnuZl2FhArn3rn2VSXQeKkQTxCaP0lr5dBSZ6QI4YRmrLleqC6Q GisXUB5L8sA5RPglZiYuseTCKxp+EGCVp/BKKQtpkGbbIz9brTJ9UescH6ghK1et+LfR Bn5HMyZvX90NZFMiQvlkaAPwbmAvhf7hC81hmAc8U3OMvAL6KBzEPrSgx3K+JKTO9Cif /Sfg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:message-id:references:in-reply-to :subject:cc:to:from:date:content-transfer-encoding:mime-version :sender:dkim-signature; bh=GihQ9LYDjowEbBDzOOAmGj6l125OrpUDwG0EebZ3OFI=; b=uusLbG+MmlUW0fgFzXWTuyG42g2poFbtjDV3f0PoooLwr45xQvbo32OUFQ0UFr3msq ECCPVh5QjNlzNqtn/U2vBjoiTmix+nn65RjRnwqvK92RR/ZFVZ+9N8MffAvWMU3bsxP9 2QezGlhS/AyVC6iYYhPzzIPTgKy1yuVwLPEXwcpAl5a1UBYTT1Qg0/Fz1onxBIseRT7/ U7vGiEc+z+l+VVpjAebtfz4uJRq4U6XrzT8PbsEVh8skPTmS0heilHrC/K0x5hiwp4sk nynKGgS20wFdfSxPtcuKXXZtn9+DyvrxQNb2TXagpfpbpt4agSLu8+N53uMA/FsyK/GV 2C3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=lO2IHgHg; 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 l14si2422876edv.145.2021.02.05.10.55.24; Fri, 05 Feb 2021 10:55:50 -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; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=lO2IHgHg; 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 S233488AbhBERMB (ORCPT + 99 others); Fri, 5 Feb 2021 12:12:01 -0500 Received: from so15.mailgun.net ([198.61.254.15]:56973 "EHLO so15.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233606AbhBEQMX (ORCPT ); Fri, 5 Feb 2021 11:12:23 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1612547666; h=Message-ID: References: In-Reply-To: Subject: Cc: To: From: Date: Content-Transfer-Encoding: Content-Type: MIME-Version: Sender; bh=GihQ9LYDjowEbBDzOOAmGj6l125OrpUDwG0EebZ3OFI=; b=lO2IHgHgv3Ir/RcN1YJe7kVsibJz9gd/4SevUbYi1O7rSPofMo8Z2vbh3KftAYdWAje36va7 5AOWMg08dd6y8S9JtezhayfD+buzPxxznMBd8A7FSKNwUXcs7bBQhLliUWIPhav4IXPU+ZG1 V/Zsbu/GNBVWuWDRDiq79xd1ijM= X-Mailgun-Sending-Ip: 198.61.254.15 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n07.prod.us-east-1.postgun.com with SMTP id 601d862c81f6c45dce632396 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Fri, 05 Feb 2021 17:53:48 GMT Sender: mdalam=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 03231C43464; Fri, 5 Feb 2021 17:53:47 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) (using TLSv1 with cipher ECDHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) (Authenticated sender: mdalam) by smtp.codeaurora.org (Postfix) with ESMTPSA id 57FCFC43462; Fri, 5 Feb 2021 17:53:46 +0000 (UTC) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Fri, 05 Feb 2021 23:23:46 +0530 From: mdalam@codeaurora.org To: Manivannan Sadhasivam Cc: miquel.raynal@bootlin.com, richard@nod.at, vigneshr@ti.com, boris.brezillon@collabora.com, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org, sricharan@codeaurora.org, mdalam=codeaurora.org@codeaurora.org Subject: Re: [PATCH V3] mtd: rawnand: qcom: update last code word register In-Reply-To: References: <1610251305-20792-1-git-send-email-mdalam@codeaurora.org> <20210128075248.GA31543@thinkpad> Message-ID: <9820142a2f48cf72a1c36929c195749b@codeaurora.org> X-Sender: mdalam@codeaurora.org User-Agent: Roundcube Webmail/1.3.9 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021-01-29 10:41, mdalam@codeaurora.org wrote: > On 2021-01-28 13:22, Manivannan Sadhasivam wrote: >> On Sun, Jan 10, 2021 at 09:31:45AM +0530, Md Sadre Alam wrote: >>> From QPIC version 2.0 onwards new register got added to >>> read last codeword. This change will update the same. >>> >>> For first three code word READ_LOCATION_n register will be >>> use.For last code word READ_LOCATION_LAST_CW_n register will be >>> use. >>> >>> Signed-off-by: Md Sadre Alam >> >> I gave this patch a try on SDX55 board but not able to resolve an >> issue and >> I think it is related to reading the last code word which this patch >> is trying >> to address. For my patch on supporting QPIC v2 IP, I tested with >> SDX55-MTP board >> and I never hit any issue. But on my new dev board (Telit FN980), >> there seems to >> be an issue while populating the partitions and tracing down that bug >> lands me >> in copy_last_cw() function. >> >> The issue only happens while creating the 3rd partition on Telit board >> whose >> size differs when compared with MTP. The board just reboots into QDL >> mode >> whenever it tries to read the last code word. >> >> Below is the snippet of partition layout: >> >> Telit partitions: >> >> [ 1.082015] 0: sbl offs=0x00000000 size=0x0000000a attr:0x000000ff >> [ 1.082702] 1: mibib offs=0x0000000a size=0x0000000a >> attr:0x000000ff >> [ 1.083488] 2: ico offs=0x00000014 size=0x00000014 attr:0x000000ff >> [ 1.084572] 3: efs2 offs=0x00000028 size=0x0000002c attr:0x000000ff >> [ 1.085316] 4: tz offs=0x00000054 size=0x00000007 attr:0x000000ff >> [ 1.086089] 5: tz_devcfg offs=0x0000005b size=0x00000004 >> attr:0x000000ff >> .... >> >> MTP partitions: >> >> [ 1.573871] 0: sbl offs=0x00000000 size=0x0000000a attr:0x000000ff >> [ 1.581139] 1: mibib offs=0x0000000a size=0x0000000a >> attr:0x000000ff >> [ 1.587362] 2: efs2 offs=0x00000014 size=0x0000002c attr:0x000000ff >> [ 1.593853] 3: tz offs=0x00000040 size=0x00000007 attr:0x000000ff >> [ 1.599860] 4: tz_devcfg offs=0x00000047 size=0x00000004 >> attr:0x000000ff >> ... >> >> So until I figure this out, please keep this patch on hold! > > There was some corner case I missed in V3 patch. I have fixed this > in V4 patch. > I have done some tress testing as well with V4 patch on IPQ5018 > platform using "nand-utils" > and "mtd_test.ko" , Now its working fine. Can you test with V4 patch > once. ping! Do you need some more info for the V4 patch ? >> >> Thanks, >> Mani >> >>> --- >>> [V3] >>> * Added else condition for last code word in update_rw_regs(). >>> drivers/mtd/nand/raw/qcom_nandc.c | 84 >>> ++++++++++++++++++++++++++++++++------- >>> 1 file changed, 70 insertions(+), 14 deletions(-) >>> >>> diff --git a/drivers/mtd/nand/raw/qcom_nandc.c >>> b/drivers/mtd/nand/raw/qcom_nandc.c >>> index 667e4bf..50ff6e3 100644 >>> --- a/drivers/mtd/nand/raw/qcom_nandc.c >>> +++ b/drivers/mtd/nand/raw/qcom_nandc.c >>> @@ -48,6 +48,10 @@ >>> #define NAND_READ_LOCATION_1 0xf24 >>> #define NAND_READ_LOCATION_2 0xf28 >>> #define NAND_READ_LOCATION_3 0xf2c >>> +#define NAND_READ_LOCATION_LAST_CW_0 0xf40 >>> +#define NAND_READ_LOCATION_LAST_CW_1 0xf44 >>> +#define NAND_READ_LOCATION_LAST_CW_2 0xf48 >>> +#define NAND_READ_LOCATION_LAST_CW_3 0xf4c >>> >>> /* dummy register offsets, used by write_reg_dma */ >>> #define NAND_DEV_CMD1_RESTORE 0xdead >>> @@ -187,6 +191,12 @@ nandc_set_reg(nandc, >>> NAND_READ_LOCATION_##reg, \ >>> ((size) << READ_LOCATION_SIZE) | \ >>> ((is_last) << READ_LOCATION_LAST)) >>> >>> +#define nandc_set_read_loc_last(nandc, reg, offset, size, is_last) \ >>> +nandc_set_reg(nandc, NAND_READ_LOCATION_LAST_CW_##reg, \ >>> + ((offset) << READ_LOCATION_OFFSET) | \ >>> + ((size) << READ_LOCATION_SIZE) | \ >>> + ((is_last) << READ_LOCATION_LAST)) >>> + >>> /* >>> * Returns the actual register address for all NAND_DEV_ registers >>> * (i.e. NAND_DEV_CMD0, NAND_DEV_CMD1, NAND_DEV_CMD2 and >>> NAND_DEV_CMD_VLD) >>> @@ -316,6 +326,10 @@ struct nandc_regs { >>> __le32 read_location1; >>> __le32 read_location2; >>> __le32 read_location3; >>> + __le32 read_location_last0; >>> + __le32 read_location_last1; >>> + __le32 read_location_last2; >>> + __le32 read_location_last3; >>> >>> __le32 erased_cw_detect_cfg_clr; >>> __le32 erased_cw_detect_cfg_set; >>> @@ -644,6 +658,14 @@ static __le32 *offset_to_nandc_reg(struct >>> nandc_regs *regs, int offset) >>> return ®s->read_location2; >>> case NAND_READ_LOCATION_3: >>> return ®s->read_location3; >>> + case NAND_READ_LOCATION_LAST_CW_0: >>> + return ®s->read_location_last0; >>> + case NAND_READ_LOCATION_LAST_CW_1: >>> + return ®s->read_location_last1; >>> + case NAND_READ_LOCATION_LAST_CW_2: >>> + return ®s->read_location_last2; >>> + case NAND_READ_LOCATION_LAST_CW_3: >>> + return ®s->read_location_last3; >>> default: >>> return NULL; >>> } >>> @@ -719,9 +741,14 @@ static void update_rw_regs(struct qcom_nand_host >>> *host, int num_cw, bool read) >>> nandc_set_reg(nandc, NAND_READ_STATUS, host->clrreadstatus); >>> nandc_set_reg(nandc, NAND_EXEC_CMD, 1); >>> >>> - if (read) >>> - nandc_set_read_loc(nandc, 0, 0, host->use_ecc ? >>> - host->cw_data : host->cw_size, 1); >>> + if (read) { >>> + if (nandc->props->qpic_v2) >>> + nandc_set_read_loc_last(nandc, 0, 0, host->use_ecc ? >>> + host->cw_data : host->cw_size, 1); >>> + else >>> + nandc_set_read_loc(nandc, 0, 0, host->use_ecc ? >>> + host->cw_data : host->cw_size, 1); >>> + } >>> } >>> >>> /* >>> @@ -1096,9 +1123,13 @@ static void config_nand_page_read(struct >>> qcom_nand_controller *nandc) >>> static void >>> config_nand_cw_read(struct qcom_nand_controller *nandc, bool >>> use_ecc) >>> { >>> - if (nandc->props->is_bam) >>> + if (nandc->props->is_bam) { >>> + if (nandc->props->qpic_v2) >>> + write_reg_dma(nandc, NAND_READ_LOCATION_LAST_CW_0, >>> + 1, NAND_BAM_NEXT_SGL); >>> write_reg_dma(nandc, NAND_READ_LOCATION_0, 4, >>> NAND_BAM_NEXT_SGL); >>> + } >>> >>> write_reg_dma(nandc, NAND_FLASH_CMD, 1, NAND_BAM_NEXT_SGL); >>> write_reg_dma(nandc, NAND_EXEC_CMD, 1, NAND_BAM_NEXT_SGL); >>> @@ -1633,16 +1664,28 @@ qcom_nandc_read_cw_raw(struct mtd_info *mtd, >>> struct nand_chip *chip, >>> } >>> >>> if (nandc->props->is_bam) { >>> - nandc_set_read_loc(nandc, 0, read_loc, data_size1, 0); >>> + if (nandc->props->qpic_v2 && cw == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 0, read_loc, data_size1, 0); >>> + else >>> + nandc_set_read_loc(nandc, 0, read_loc, data_size1, 0); >>> read_loc += data_size1; >>> >>> - nandc_set_read_loc(nandc, 1, read_loc, oob_size1, 0); >>> + if (nandc->props->qpic_v2 && cw == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 1, read_loc, oob_size1, 0); >>> + else >>> + nandc_set_read_loc(nandc, 1, read_loc, oob_size1, 0); >>> read_loc += oob_size1; >>> >>> - nandc_set_read_loc(nandc, 2, read_loc, data_size2, 0); >>> + if (nandc->props->qpic_v2 && cw == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 2, read_loc, data_size2, 0); >>> + else >>> + nandc_set_read_loc(nandc, 2, read_loc, data_size2, 0); >>> read_loc += data_size2; >>> >>> - nandc_set_read_loc(nandc, 3, read_loc, oob_size2, 1); >>> + if (nandc->props->qpic_v2 && cw == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 3, read_loc, oob_size2, 0); >>> + else >>> + nandc_set_read_loc(nandc, 3, read_loc, oob_size2, 1); >>> } >>> >>> config_nand_cw_read(nandc, false); >>> @@ -1873,14 +1916,27 @@ static int read_page_ecc(struct >>> qcom_nand_host *host, u8 *data_buf, >>> >>> if (nandc->props->is_bam) { >>> if (data_buf && oob_buf) { >>> - nandc_set_read_loc(nandc, 0, 0, data_size, 0); >>> - nandc_set_read_loc(nandc, 1, data_size, >>> - oob_size, 1); >>> + if (nandc->props->qpic_v2 && i == (ecc->steps - 1)) { >>> + nandc_set_read_loc_last(nandc, 0, 0, data_size, 0); >>> + nandc_set_read_loc_last(nandc, 1, data_size, >>> + oob_size, 1); >>> + } else { >>> + nandc_set_read_loc(nandc, 0, 0, data_size, 0); >>> + nandc_set_read_loc(nandc, 1, data_size, >>> + oob_size, 1); >>> + } >>> } else if (data_buf) { >>> - nandc_set_read_loc(nandc, 0, 0, data_size, 1); >>> + if (nandc->props->qpic_v2 && i == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 0, 0, data_size, 1); >>> + else >>> + nandc_set_read_loc(nandc, 0, 0, data_size, 1); >>> } else { >>> - nandc_set_read_loc(nandc, 0, data_size, >>> - oob_size, 1); >>> + if (nandc->props->qpic_v2 && i == (ecc->steps - 1)) >>> + nandc_set_read_loc_last(nandc, 0, data_size, >>> + oob_size, 1); >>> + else >>> + nandc_set_read_loc(nandc, 0, data_size, >>> + oob_size, 1); >>> } >>> } >>> >>> -- >>> 2.7.4 >>>