#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/err.h>
#include <linux/iopoll.h>
#include <linux/mtd/rawnand.h>
#include <linux/mtd/partitions.h>
#include <linux/slab.h>
#include <linux/of.h>
#define NRCSR_OFFSET …
#define NANDFCR_OFFSET …
#define NANDFSR_OFFSET …
#define NANDF1ECC_OFFSET …
#define NAND_4BIT_ECC_LOAD_OFFSET …
#define NAND_4BIT_ECC1_OFFSET …
#define NAND_4BIT_ECC2_OFFSET …
#define NAND_4BIT_ECC3_OFFSET …
#define NAND_4BIT_ECC4_OFFSET …
#define NAND_ERR_ADD1_OFFSET …
#define NAND_ERR_ADD2_OFFSET …
#define NAND_ERR_ERRVAL1_OFFSET …
#define NAND_ERR_ERRVAL2_OFFSET …
#define MASK_ALE …
#define MASK_CLE …
struct davinci_nand_pdata { … };
struct davinci_nand_info { … };
static DEFINE_SPINLOCK(davinci_nand_lock);
static bool ecc4_busy;
static inline struct davinci_nand_info *to_davinci_nand(struct mtd_info *mtd)
{ … }
static inline unsigned int davinci_nand_readl(struct davinci_nand_info *info,
int offset)
{ … }
static inline void davinci_nand_writel(struct davinci_nand_info *info,
int offset, unsigned long value)
{ … }
static inline uint32_t nand_davinci_readecc_1bit(struct mtd_info *mtd)
{ … }
static void nand_davinci_hwctl_1bit(struct nand_chip *chip, int mode)
{ … }
static int nand_davinci_calculate_1bit(struct nand_chip *chip,
const u_char *dat, u_char *ecc_code)
{ … }
static int nand_davinci_correct_1bit(struct nand_chip *chip, u_char *dat,
u_char *read_ecc, u_char *calc_ecc)
{ … }
static void nand_davinci_hwctl_4bit(struct nand_chip *chip, int mode)
{ … }
static void
nand_davinci_readecc_4bit(struct davinci_nand_info *info, u32 code[4])
{ … }
static int nand_davinci_calculate_4bit(struct nand_chip *chip,
const u_char *dat, u_char *ecc_code)
{ … }
static int nand_davinci_correct_4bit(struct nand_chip *chip, u_char *data,
u_char *ecc_code, u_char *null)
{ … }
static int hwecc4_ooblayout_small_ecc(struct mtd_info *mtd, int section,
struct mtd_oob_region *oobregion)
{ … }
static int hwecc4_ooblayout_small_free(struct mtd_info *mtd, int section,
struct mtd_oob_region *oobregion)
{ … }
static const struct mtd_ooblayout_ops hwecc4_small_ooblayout_ops = …;
#if defined(CONFIG_OF)
static const struct of_device_id davinci_nand_of_match[] = …;
MODULE_DEVICE_TABLE(of, davinci_nand_of_match);
static struct davinci_nand_pdata
*nand_davinci_get_pdata(struct platform_device *pdev)
{ … }
#else
static struct davinci_nand_pdata
*nand_davinci_get_pdata(struct platform_device *pdev)
{
return dev_get_platdata(&pdev->dev);
}
#endif
static int davinci_nand_attach_chip(struct nand_chip *chip)
{ … }
static void nand_davinci_data_in(struct davinci_nand_info *info, void *buf,
unsigned int len, bool force_8bit)
{ … }
static void nand_davinci_data_out(struct davinci_nand_info *info,
const void *buf, unsigned int len,
bool force_8bit)
{ … }
static int davinci_nand_exec_instr(struct davinci_nand_info *info,
const struct nand_op_instr *instr)
{ … }
static int davinci_nand_exec_op(struct nand_chip *chip,
const struct nand_operation *op,
bool check_only)
{ … }
static const struct nand_controller_ops davinci_nand_controller_ops = …;
static int nand_davinci_probe(struct platform_device *pdev)
{ … }
static void nand_davinci_remove(struct platform_device *pdev)
{ … }
static struct platform_driver nand_davinci_driver = …;
MODULE_ALIAS(…) …;
module_platform_driver(…) …;
MODULE_LICENSE(…) …;
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;