From: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
To: Christian Marangi <ansuelsmth@gmail.com>
Cc: Miquel Raynal <miquel.raynal@bootlin.com>,
Richard Weinberger <richard@nod.at>,
Vignesh Raghavendra <vigneshr@ti.com>,
Md Sadre Alam <quic_mdalam@quicinc.com>,
Konrad Dybcio <konrad.dybcio@oss.qualcomm.com>,
linux-mtd@lists.infradead.org, linux-arm-msm@vger.kernel.org,
linux-kernel@vger.kernel.org, stable@vger.kernel.org,
Robert Marko <robimarko@gmail.com>
Subject: Re: [PATCH v2] mtd: rawnand: qcom: fix broken config in qcom_param_page_type_exec
Date: Mon, 10 Feb 2025 22:39:50 +0530 [thread overview]
Message-ID: <20250210170950.zxgm5hjeb2a4evfn@thinkpad> (raw)
In-Reply-To: <20250209140941.16627-1-ansuelsmth@gmail.com>
On Sun, Feb 09, 2025 at 03:09:38PM +0100, Christian Marangi wrote:
> Fix broken config in qcom_param_page_type_exec caused by copy-paste error
> from commit 0c08080fd71c ("mtd: rawnand: qcom: use FIELD_PREP and GENMASK")
>
> In qcom_param_page_type_exec the value needs to be set to
> nandc->regs->cfg0 instead of host->cfg0. This wrong configuration caused
> the Qcom NANDC driver to malfunction on any device that makes use of it
> (IPQ806x, IPQ40xx, IPQ807x, IPQ60xx) with the following error:
>
I'm wondering whether the offending commit was really tested or not :(
> [ 0.885369] nand: device found, Manufacturer ID: 0x2c, Chip ID: 0xaa
> [ 0.885909] nand: Micron NAND 256MiB 1,8V 8-bit
> [ 0.892499] nand: 256 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64
> [ 0.896823] nand: ECC (step, strength) = (512, 8) does not fit in OOB
> [ 0.896836] qcom-nandc 79b0000.nand-controller: No valid ECC settings possible
> [ 0.910996] bam-dma-engine 7984000.dma-controller: Cannot free busy channel
> [ 0.918070] qcom-nandc: probe of 79b0000.nand-controller failed with error -28
>
> Restore original configuration fix the problem and makes the driver work
> again.
>
> Also restore the wrongly dropped cpu_to_le32 to correctly support BE
> systems.
>
> Cc: stable@vger.kernel.org
> Fixes: 0c08080fd71c ("mtd: rawnand: qcom: use FIELD_PREP and GENMASK")
> Tested-by: Robert Marko <robimarko@gmail.com> # IPQ8074 and IPQ6018
> Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
Reviewed-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Thanks for the fix!
- Mani
> ---
> Changes v2:
> - Fix smatch warning (add missing cpu_to_le32 that was also dropped
> from the FIELD_PREP patch)
>
> drivers/mtd/nand/raw/qcom_nandc.c | 24 ++++++++++++------------
> 1 file changed, 12 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/mtd/nand/raw/qcom_nandc.c b/drivers/mtd/nand/raw/qcom_nandc.c
> index d2d2aeee42a7..6720b547892b 100644
> --- a/drivers/mtd/nand/raw/qcom_nandc.c
> +++ b/drivers/mtd/nand/raw/qcom_nandc.c
> @@ -1881,18 +1881,18 @@ static int qcom_param_page_type_exec(struct nand_chip *chip, const struct nand_
> nandc->regs->addr0 = 0;
> nandc->regs->addr1 = 0;
>
> - host->cfg0 = FIELD_PREP(CW_PER_PAGE_MASK, 0) |
> - FIELD_PREP(UD_SIZE_BYTES_MASK, 512) |
> - FIELD_PREP(NUM_ADDR_CYCLES_MASK, 5) |
> - FIELD_PREP(SPARE_SIZE_BYTES_MASK, 0);
> -
> - host->cfg1 = FIELD_PREP(NAND_RECOVERY_CYCLES_MASK, 7) |
> - FIELD_PREP(BAD_BLOCK_BYTE_NUM_MASK, 17) |
> - FIELD_PREP(CS_ACTIVE_BSY, 0) |
> - FIELD_PREP(BAD_BLOCK_IN_SPARE_AREA, 1) |
> - FIELD_PREP(WR_RD_BSY_GAP_MASK, 2) |
> - FIELD_PREP(WIDE_FLASH, 0) |
> - FIELD_PREP(DEV0_CFG1_ECC_DISABLE, 1);
> + nandc->regs->cfg0 = cpu_to_le32(FIELD_PREP(CW_PER_PAGE_MASK, 0) |
> + FIELD_PREP(UD_SIZE_BYTES_MASK, 512) |
> + FIELD_PREP(NUM_ADDR_CYCLES_MASK, 5) |
> + FIELD_PREP(SPARE_SIZE_BYTES_MASK, 0));
> +
> + nandc->regs->cfg1 = cpu_to_le32(FIELD_PREP(NAND_RECOVERY_CYCLES_MASK, 7) |
> + FIELD_PREP(BAD_BLOCK_BYTE_NUM_MASK, 17) |
> + FIELD_PREP(CS_ACTIVE_BSY, 0) |
> + FIELD_PREP(BAD_BLOCK_IN_SPARE_AREA, 1) |
> + FIELD_PREP(WR_RD_BSY_GAP_MASK, 2) |
> + FIELD_PREP(WIDE_FLASH, 0) |
> + FIELD_PREP(DEV0_CFG1_ECC_DISABLE, 1));
>
> if (!nandc->props->qpic_version2)
> nandc->regs->ecc_buf_cfg = cpu_to_le32(ECC_CFG_ECC_DISABLE);
> --
> 2.47.1
>
--
மணிவண்ணன் சதாசிவம்
______________________________________________________
Linux MTD discussion mailing list
http://lists.infradead.org/mailman/listinfo/linux-mtd/
next prev parent reply other threads:[~2025-02-10 17:27 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-09 14:09 [PATCH v2] mtd: rawnand: qcom: fix broken config in qcom_param_page_type_exec Christian Marangi
2025-02-10 17:09 ` Manivannan Sadhasivam [this message]
2025-02-10 20:50 ` Christian Marangi
2025-02-11 12:54 ` Miquel Raynal
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250210170950.zxgm5hjeb2a4evfn@thinkpad \
--to=manivannan.sadhasivam@linaro.org \
--cc=ansuelsmth@gmail.com \
--cc=konrad.dybcio@oss.qualcomm.com \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mtd@lists.infradead.org \
--cc=miquel.raynal@bootlin.com \
--cc=quic_mdalam@quicinc.com \
--cc=richard@nod.at \
--cc=robimarko@gmail.com \
--cc=stable@vger.kernel.org \
--cc=vigneshr@ti.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox