[PATCH next 1/2] mtd: nand: qpic-common: add defines for ECC_MODE values

Md Sadre Alam quic_mdalam at quicinc.com
Mon May 5 04:08:06 PDT 2025



On 5/3/2025 1:01 AM, Gabor Juhos wrote:
> Add defines for the values of the ECC_MODE field of the NAND_DEV0_ECC_CFG
> register and change both the 'qcom-nandc' and 'spi-qpic-snand' drivers to
> use those instead of magic numbers.
> 
> No functional changes. This is in preparation for adding 8 bit ECC strength
> support for the 'spi-qpic-snand' driver.
> 
> Signed-off-by: Gabor Juhos <j4g8y7 at gmail.com>
> ---
>   drivers/mtd/nand/raw/qcom_nandc.c    | 6 +++---
>   drivers/spi/spi-qpic-snand.c         | 2 +-
>   include/linux/mtd/nand-qpic-common.h | 2 ++
>   3 files changed, 6 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/mtd/nand/raw/qcom_nandc.c b/drivers/mtd/nand/raw/qcom_nandc.c
> index 5eaa0be367cdb847d48dbed6f8326a75a5922347..67641ce28bd6435fffda3ffe5e38c777f4708cf8 100644
> --- a/drivers/mtd/nand/raw/qcom_nandc.c
> +++ b/drivers/mtd/nand/raw/qcom_nandc.c
> @@ -1379,7 +1379,7 @@ static int qcom_nand_attach_chip(struct nand_chip *chip)
>   	struct qcom_nand_controller *nandc = get_qcom_nand_controller(chip);
>   	int cwperpage, bad_block_byte, ret;
>   	bool wide_bus;
> -	int ecc_mode = 1;
> +	int ecc_mode = ECC_MODE_8BIT;
>   
>   	/* controller only supports 512 bytes data steps */
>   	ecc->size = NANDC_STEP_SIZE;
> @@ -1400,7 +1400,7 @@ static int qcom_nand_attach_chip(struct nand_chip *chip)
>   	if (ecc->strength >= 8) {
>   		/* 8 bit ECC defaults to BCH ECC on all platforms */
>   		host->bch_enabled = true;
> -		ecc_mode = 1;
> +		ecc_mode = ECC_MODE_8BIT;
>   
>   		if (wide_bus) {
>   			host->ecc_bytes_hw = 14;
> @@ -1420,7 +1420,7 @@ static int qcom_nand_attach_chip(struct nand_chip *chip)
>   		if (nandc->props->ecc_modes & ECC_BCH_4BIT) {
>   			/* BCH */
>   			host->bch_enabled = true;
> -			ecc_mode = 0;
> +			ecc_mode = ECC_MODE_4BIT;
>   
>   			if (wide_bus) {
>   				host->ecc_bytes_hw = 8;
> diff --git a/drivers/spi/spi-qpic-snand.c b/drivers/spi/spi-qpic-snand.c
> index 88f8fa98687fa292861d46648872135aa7fad80f..dfc8cc5d97624fe741121228b97d2b3562cc5cc4 100644
> --- a/drivers/spi/spi-qpic-snand.c
> +++ b/drivers/spi/spi-qpic-snand.c
> @@ -349,7 +349,7 @@ static int qcom_spi_ecc_init_ctx_pipelined(struct nand_device *nand)
>   			       FIELD_PREP(ECC_SW_RESET, 0) |
>   			       FIELD_PREP(ECC_NUM_DATA_BYTES_MASK, ecc_cfg->cw_data) |
>   			       FIELD_PREP(ECC_FORCE_CLK_OPEN, 1) |
> -			       FIELD_PREP(ECC_MODE_MASK, 0) |
> +			       FIELD_PREP(ECC_MODE_MASK, ECC_MODE_4BIT) |
>   			       FIELD_PREP(ECC_PARITY_SIZE_BYTES_BCH_MASK, ecc_cfg->ecc_bytes_hw);
>   
>   	ecc_cfg->ecc_buf_cfg = 0x203 << NUM_STEPS;
> diff --git a/include/linux/mtd/nand-qpic-common.h b/include/linux/mtd/nand-qpic-common.h
> index cd7172e6c1bbffeee0363a14044980a72ea17723..a070af4593754384d9df4f6206a24665e2040aad 100644
> --- a/include/linux/mtd/nand-qpic-common.h
> +++ b/include/linux/mtd/nand-qpic-common.h
> @@ -101,6 +101,8 @@
>   #define	ECC_SW_RESET			BIT(1)
>   #define	ECC_MODE			4
>   #define	ECC_MODE_MASK			GENMASK(5, 4)
> +#define	ECC_MODE_4BIT			0
> +#define	ECC_MODE_8BIT			1
>   #define	ECC_PARITY_SIZE_BYTES_BCH	8
>   #define	ECC_PARITY_SIZE_BYTES_BCH_MASK	GENMASK(12, 8)
>   #define	ECC_NUM_DATA_BYTES		16
> 

Reviewed-by: Md Sadre Alam <quic_mdalam at quicinc.com>



More information about the linux-mtd mailing list