hc
2024-08-19 a51341d8c7882adfad4f167bc7c3ca616908b53d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * 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;
struct nand_chip;
struct nand_bch_control;
 
#if IS_ENABLED(CONFIG_MTD_NAND_ECC_SW_BCH)
 
static inline int mtd_nand_has_bch(void) { return 1; }
 
/*
 * Calculate BCH ecc code
 */
int nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
              u_char *ecc_code);
 
/*
 * Detect and correct bit errors
 */
int nand_bch_correct_data(struct nand_chip *chip, u_char *dat,
             u_char *read_ecc, u_char *calc_ecc);
/*
 * Initialize BCH encoder/decoder
 */
struct nand_bch_control *nand_bch_init(struct mtd_info *mtd);
/*
 * Release BCH encoder/decoder resources
 */
void nand_bch_free(struct nand_bch_control *nbc);
 
#else /* !CONFIG_MTD_NAND_ECC_SW_BCH */
 
static inline int mtd_nand_has_bch(void) { return 0; }
 
static inline int
nand_bch_calculate_ecc(struct nand_chip *chip, const u_char *dat,
              u_char *ecc_code)
{
   return -1;
}
 
static inline int
nand_bch_correct_data(struct nand_chip *chip, unsigned char *buf,
             unsigned char *read_ecc, unsigned char *calc_ecc)
{
   return -ENOTSUPP;
}
 
static inline struct nand_bch_control *nand_bch_init(struct mtd_info *mtd)
{
   return NULL;
}
 
static inline void nand_bch_free(struct nand_bch_control *nbc) {}
 
#endif /* CONFIG_MTD_NAND_ECC_SW_BCH */
 
#endif /* __MTD_NAND_BCH_H__ */