Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp3474145pxb; Mon, 6 Sep 2021 23:42:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyz4/13BwcPNvbYTl9VQUg3odqobOPUfS2XCf+TJBafyI3qxrznvmQiB5wPz+2GQWbObG/o X-Received: by 2002:a17:906:8802:: with SMTP id zh2mr17242743ejb.344.1630996925047; Mon, 06 Sep 2021 23:42:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630996925; cv=none; d=google.com; s=arc-20160816; b=KTZZQiexM0qRl8Ue61teTRn5n/CzF3OmLf1D6nJARbP50Og0/fxhlESsw2Bw1bvAFK EWZS2Tt6IEmlMnWtpB+ViCInaIR3MQKlw6Bnat8xvkFAHY56N32rDqQl52xB+NZHt/9d 1PMi/w4x6+UGfn0kQCrq5djlrpDan7h2MG5JBV9+u+JpCBAgplh2mJq5E5U9bW66bcgL cjAtHdJRGfzYcJVQn8xMTf7qFryDhNBnhOpopAkaiqVuCtuR2HyBwz8nSisq7jD+ouc9 0CtuKPrkDtrE/G3DBvkmmIp5ELGjW+c8e6JkUFr69FP50aYBdyxJL4Mb0eofPl5MfqkG m/ug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=hXI/Sl33Y4zWFXAEsePP4wDKH9kvjqLpDt6bcdMqbEY=; b=HLPbTpHM8+dTqgqbz6fkNvmz4nGt8KUGE4nUD3tINdXDY00+cQEF1PgLIiasVHTAIj eDT262TsbcO4dbj0C9WODnrEgN7fhCfGTAa3Jfhnh2smElvRckKNUJeY1ZNR2cbUnI9e uay3Gx3ZTyIVR+8DjVJuhBANMWNoeVvO/8HNb4RH/LpoLBstY3tve8C1STX/EB1EfsFs 56briQrdEVSUPCUBsNAz9/3zBBW8mJajuvFfFea9sJMJwipx+diDITC8NyiVhZEQZkIR CeNZYaBF5qdw3mmB57bH2Jhc4H0rmq8aoABjAjr5WnoE2k8y6dgm29urCywMiguprXjy sS7g== 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 l11si10897124ejo.259.2021.09.06.23.41.41; Mon, 06 Sep 2021 23:42:05 -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 S233430AbhIGGlA (ORCPT + 99 others); Tue, 7 Sep 2021 02:41:00 -0400 Received: from alexa-out.qualcomm.com ([129.46.98.28]:36681 "EHLO alexa-out.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231779AbhIGGk7 (ORCPT ); Tue, 7 Sep 2021 02:40:59 -0400 Received: from ironmsg09-lv.qualcomm.com ([10.47.202.153]) by alexa-out.qualcomm.com with ESMTP; 06 Sep 2021 23:39:53 -0700 X-QCInternal: smtphost Received: from ironmsg02-blr.qualcomm.com ([10.86.208.131]) by ironmsg09-lv.qualcomm.com with ESMTP/TLS/AES256-SHA; 06 Sep 2021 23:39:52 -0700 X-QCInternal: smtphost Received: from mdalam-linux.qualcomm.com ([10.201.2.71]) by ironmsg02-blr.qualcomm.com with ESMTP; 07 Sep 2021 12:09:41 +0530 Received: by mdalam-linux.qualcomm.com (Postfix, from userid 466583) id EC9CD222D3; Tue, 7 Sep 2021 12:09:39 +0530 (IST) From: Md Sadre Alam To: miquel.raynal@bootlin.com, mani@kernel.org, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Cc: mdalam@codeaurora.org, sricharan@codeaurora.org, stable@kernel.org Subject: [PATCH V5] mtd: rawnand: qcom: Update code word value for raw read Date: Tue, 7 Sep 2021 12:09:31 +0530 Message-Id: <1630996771-29866-1-git-send-email-mdalam@codeaurora.org> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From QPIC V2 onwards there is a separate register to read last code word "QPIC_NAND_READ_LOCATION_LAST_CW_n". qcom_nandc_read_cw_raw() is used to read only one code word at a time. If we will configure number of code words to 1 in in QPIC_NAND_DEV0_CFG0 register then QPIC controller thinks its reading the last code word, since from QPIC V2 onwards we are having separate register to read the last code word, we have to configure "QPIC_NAND_READ_LOCATION_LAST_CW_n" register to fetch data from controller buffer to system memory. Fixes: 503ee5aad43054a26cfd5cc592a31270c05539cd ("mtd: rawnand: qcom: update last code word register") Cc: stable@kernel.org Signed-off-by: Md Sadre Alam --- Changes in V5: * Incorporated "hash commit" comment from Mani. * Updated commit hash Changes in V4: * Incorporated "Change log" comment from Miquèl * Updated change log Changes in V3: * Incorporated "Fixes tags are missing" comment from Miquèl * Added Fixes tag Fixes:503ee5aa ("mtd: rawnand: qcom: update last code word register") Changes in V2: * Incorporated "stable tags are missing" comment from Miquèl * Added stable tags Cc:stable@kernel.org drivers/mtd/nand/raw/qcom_nandc.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/mtd/nand/raw/qcom_nandc.c b/drivers/mtd/nand/raw/qcom_nandc.c index ef0bade..04e6f7b 100644 --- a/drivers/mtd/nand/raw/qcom_nandc.c +++ b/drivers/mtd/nand/raw/qcom_nandc.c @@ -1676,13 +1676,17 @@ qcom_nandc_read_cw_raw(struct mtd_info *mtd, struct nand_chip *chip, struct nand_ecc_ctrl *ecc = &chip->ecc; int data_size1, data_size2, oob_size1, oob_size2; int ret, reg_off = FLASH_BUF_ACC, read_loc = 0; + int raw_cw = cw; nand_read_page_op(chip, page, 0, NULL, 0); host->use_ecc = false; + if (nandc->props->qpic_v2) + raw_cw = ecc->steps - 1; + clear_bam_transaction(nandc); set_address(host, host->cw_size * cw, page); - update_rw_regs(host, 1, true, cw); + update_rw_regs(host, 1, true, raw_cw); config_nand_page_read(chip); data_size1 = mtd->writesize - host->cw_size * (ecc->steps - 1); @@ -1711,7 +1715,7 @@ qcom_nandc_read_cw_raw(struct mtd_info *mtd, struct nand_chip *chip, nandc_set_read_loc(chip, cw, 3, read_loc, oob_size2, 1); } - config_nand_cw_read(chip, false, cw); + config_nand_cw_read(chip, false, raw_cw); read_data_dma(nandc, reg_off, data_buf, data_size1, 0); reg_off += data_size1; -- 2.7.4