2005-08-17 10:55:25 +00:00
|
|
|
/*
|
|
|
|
* drivers/mtd/nand_ecc.h
|
|
|
|
*
|
|
|
|
* Copyright (C) 2000 Steven J. Hill (sjhill@realitydiluted.com)
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This file is the header for the ECC algorithm.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MTD_NAND_ECC_H__
|
|
|
|
#define __MTD_NAND_ECC_H__
|
|
|
|
|
|
|
|
struct mtd_info;
|
|
|
|
|
2011-10-12 07:32:06 +00:00
|
|
|
#if defined(CONFIG_MTD_ECC_SOFT)
|
|
|
|
|
|
|
|
static inline int mtd_nand_has_ecc_soft(void) { return 1; }
|
|
|
|
|
2005-08-17 10:55:25 +00:00
|
|
|
/*
|
|
|
|
* Calculate 3 byte ECC code for 256 byte block
|
|
|
|
*/
|
|
|
|
int nand_calculate_ecc(struct mtd_info *mtd, const u_char *dat, u_char *ecc_code);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Detect and correct a 1 bit error for 256 byte block
|
|
|
|
*/
|
|
|
|
int nand_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_ecc, u_char *calc_ecc);
|
|
|
|
|
2011-10-12 07:32:06 +00:00
|
|
|
#else
|
|
|
|
|
|
|
|
static inline int mtd_nand_has_ecc_soft(void) { return 0; }
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
nand_calculate_ecc(struct mtd_info *mtd, const u_char *dat, u_char *ecc_code)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
nand_correct_data(struct mtd_info *mtd,
|
|
|
|
u_char *dat,
|
|
|
|
u_char *read_ecc,
|
|
|
|
u_char *calc_ecc)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2005-08-17 10:55:25 +00:00
|
|
|
#endif /* __MTD_NAND_ECC_H__ */
|