blob: 0f491d8abfdd3261554400117c0796620212bd04 [file] [log] [blame]
Thomas Gleixnerc942fdd2019-05-27 08:55:06 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Philip Avinashbf224332013-01-04 13:26:50 +05302/*
3 * BCH Error Location Module
4 *
5 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
Philip Avinashbf224332013-01-04 13:26:50 +05306 */
7
8#ifndef __ELM_H
9#define __ELM_H
10
11enum bch_ecc {
12 BCH4_ECC = 0,
13 BCH8_ECC,
pekon gupta2be589e2014-05-19 13:24:40 +053014 BCH16_ECC,
Philip Avinashbf224332013-01-04 13:26:50 +053015};
16
17/* ELM support 8 error syndrome process */
18#define ERROR_VECTOR_MAX 8
19
Philip Avinashbf224332013-01-04 13:26:50 +053020/**
21 * struct elm_errorvec - error vector for elm
22 * @error_reported: set true for vectors error is reported
23 * @error_uncorrectable: number of uncorrectable errors
24 * @error_count: number of correctable errors in the sector
25 * @error_loc: buffer for error location
26 *
27 */
28struct elm_errorvec {
29 bool error_reported;
30 bool error_uncorrectable;
31 int error_count;
pekon gupta2be589e2014-05-19 13:24:40 +053032 int error_loc[16];
Philip Avinashbf224332013-01-04 13:26:50 +053033};
34
Ezequiel García93af53b2014-09-20 17:53:12 +010035#if IS_ENABLED(CONFIG_MTD_NAND_OMAP_BCH)
Philip Avinashbf224332013-01-04 13:26:50 +053036void elm_decode_bch_error_page(struct device *dev, u8 *ecc_calc,
37 struct elm_errorvec *err_vec);
Pekon Gupta3f4eb142014-03-20 18:48:34 +053038int elm_config(struct device *dev, enum bch_ecc bch_type,
39 int ecc_steps, int ecc_step_size, int ecc_syndrome_size);
Ezequiel García93af53b2014-09-20 17:53:12 +010040#else
41static inline void
42elm_decode_bch_error_page(struct device *dev, u8 *ecc_calc,
43 struct elm_errorvec *err_vec)
44{
45}
46
47static inline int elm_config(struct device *dev, enum bch_ecc bch_type,
48 int ecc_steps, int ecc_step_size,
49 int ecc_syndrome_size)
50{
51 return -ENOSYS;
52}
Miquel Raynale90a6192019-02-07 15:28:24 +010053#endif /* CONFIG_MTD_NAND_OMAP_BCH */
Ezequiel García93af53b2014-09-20 17:53:12 +010054
Philip Avinashbf224332013-01-04 13:26:50 +053055#endif /* __ELM_H */