blob: d5956cc48ba96e398857035e1e54e6fc79b38c08 [file] [log] [blame]
David Brazdil0f672f62019-12-10 10:32:29 +00001/* SPDX-License-Identifier: GPL-2.0-only */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00002/*
3 * Copyright © 2011 Ivan Djelic <ivan.djelic@parrot.com>
4 *
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00005 * This file is the header for the NAND BCH ECC implementation.
6 */
7
8#ifndef __MTD_NAND_BCH_H__
9#define __MTD_NAND_BCH_H__
10
11struct mtd_info;
David Brazdil0f672f62019-12-10 10:32:29 +000012struct nand_chip;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000013struct nand_bch_control;
14
David Brazdil0f672f62019-12-10 10:32:29 +000015#if IS_ENABLED(CONFIG_MTD_NAND_ECC_SW_BCH)
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000016
17static inline int mtd_nand_has_bch(void) { return 1; }
18
19/*
20 * Calculate BCH ecc code
21 */
David Brazdil0f672f62019-12-10 10:32:29 +000022int nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000023 u_char *ecc_code);
24
25/*
26 * Detect and correct bit errors
27 */
David Brazdil0f672f62019-12-10 10:32:29 +000028int nand_bch_correct_data(struct nand_chip *chip, u_char *dat,
29 u_char *read_ecc, u_char *calc_ecc);
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000030/*
31 * Initialize BCH encoder/decoder
32 */
33struct nand_bch_control *nand_bch_init(struct mtd_info *mtd);
34/*
35 * Release BCH encoder/decoder resources
36 */
37void nand_bch_free(struct nand_bch_control *nbc);
38
David Brazdil0f672f62019-12-10 10:32:29 +000039#else /* !CONFIG_MTD_NAND_ECC_SW_BCH */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000040
41static inline int mtd_nand_has_bch(void) { return 0; }
42
43static inline int
David Brazdil0f672f62019-12-10 10:32:29 +000044nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000045 u_char *ecc_code)
46{
47 return -1;
48}
49
50static inline int
David Brazdil0f672f62019-12-10 10:32:29 +000051nand_bch_correct_data(struct nand_chip *chip, unsigned char *buf,
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000052 unsigned char *read_ecc, unsigned char *calc_ecc)
53{
54 return -ENOTSUPP;
55}
56
57static inline struct nand_bch_control *nand_bch_init(struct mtd_info *mtd)
58{
59 return NULL;
60}
61
62static inline void nand_bch_free(struct nand_bch_control *nbc) {}
63
David Brazdil0f672f62019-12-10 10:32:29 +000064#endif /* CONFIG_MTD_NAND_ECC_SW_BCH */
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000065
66#endif /* __MTD_NAND_BCH_H__ */