2019-06-04 16:11:33 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2011-03-11 18:05:33 +08:00
|
|
|
/*
|
|
|
|
* Copyright © 2011 Ivan Djelic <ivan.djelic@parrot.com>
|
|
|
|
*
|
|
|
|
* This file is the header for the NAND BCH ECC implementation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MTD_NAND_BCH_H__
|
|
|
|
#define __MTD_NAND_BCH_H__
|
|
|
|
|
|
|
|
struct mtd_info;
|
2018-09-06 20:05:18 +08:00
|
|
|
struct nand_chip;
|
2011-03-11 18:05:33 +08:00
|
|
|
struct nand_bch_control;
|
|
|
|
|
2019-02-06 22:12:27 +08:00
|
|
|
#if IS_ENABLED(CONFIG_MTD_NAND_ECC_SW_BCH)
|
2011-03-11 18:05:33 +08:00
|
|
|
|
|
|
|
static inline int mtd_nand_has_bch(void) { return 1; }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Calculate BCH ecc code
|
|
|
|
*/
|
2018-09-06 20:05:18 +08:00
|
|
|
int nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
|
2011-03-11 18:05:33 +08:00
|
|
|
u_char *ecc_code);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Detect and correct bit errors
|
|
|
|
*/
|
2018-09-06 20:05:19 +08:00
|
|
|
int nand_bch_correct_data(struct nand_chip *chip, u_char *dat,
|
|
|
|
u_char *read_ecc, u_char *calc_ecc);
|
2011-03-11 18:05:33 +08:00
|
|
|
/*
|
|
|
|
* Initialize BCH encoder/decoder
|
|
|
|
*/
|
2016-03-07 17:46:54 +08:00
|
|
|
struct nand_bch_control *nand_bch_init(struct mtd_info *mtd);
|
2011-03-11 18:05:33 +08:00
|
|
|
/*
|
|
|
|
* Release BCH encoder/decoder resources
|
|
|
|
*/
|
|
|
|
void nand_bch_free(struct nand_bch_control *nbc);
|
|
|
|
|
2019-02-06 22:12:27 +08:00
|
|
|
#else /* !CONFIG_MTD_NAND_ECC_SW_BCH */
|
2011-03-11 18:05:33 +08:00
|
|
|
|
|
|
|
static inline int mtd_nand_has_bch(void) { return 0; }
|
|
|
|
|
|
|
|
static inline int
|
2018-09-06 20:05:18 +08:00
|
|
|
nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
|
2011-03-11 18:05:33 +08:00
|
|
|
u_char *ecc_code)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int
|
2018-09-06 20:05:19 +08:00
|
|
|
nand_bch_correct_data(struct nand_chip *chip, unsigned char *buf,
|
2011-03-11 18:05:33 +08:00
|
|
|
unsigned char *read_ecc, unsigned char *calc_ecc)
|
|
|
|
{
|
2015-12-31 03:32:03 +08:00
|
|
|
return -ENOTSUPP;
|
2011-03-11 18:05:33 +08:00
|
|
|
}
|
|
|
|
|
2016-03-07 17:46:54 +08:00
|
|
|
static inline struct nand_bch_control *nand_bch_init(struct mtd_info *mtd)
|
2011-03-11 18:05:33 +08:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void nand_bch_free(struct nand_bch_control *nbc) {}
|
|
|
|
|
2019-02-06 22:12:27 +08:00
|
|
|
#endif /* CONFIG_MTD_NAND_ECC_SW_BCH */
|
2011-03-11 18:05:33 +08:00
|
|
|
|
|
|
|
#endif /* __MTD_NAND_BCH_H__ */
|