blob: ada11c1a09a66ea4259a6f10133c955c7eb75cdf [file] [log] [blame]
Anton Vorontsov6ab97e92008-01-14 23:09:32 +03001/*
2 * FSL UPM NAND driver
3 *
4 * Copyright (C) 2007 MontaVista Software, Inc.
5 * Anton Vorontsov <avorontsov@ru.mvista.com>
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License as
9 * published by the Free Software Foundation; either version 2 of
10 * the License, or (at your option) any later version.
11 */
12
13#ifndef __LINUX_MTD_NAND_FSL_UPM
14#define __LINUX_MTD_NAND_FSL_UPM
15
16#include <linux/mtd/nand.h>
17
18struct fsl_upm {
Anton Vorontsov6ab97e92008-01-14 23:09:32 +030019 void __iomem *mdr;
20 void __iomem *mxmr;
21 void __iomem *mar;
22 void __iomem *io_addr;
23};
24
25struct fsl_upm_nand {
26 struct fsl_upm upm;
27
28 int width;
29 int upm_cmd_offset;
30 int upm_addr_offset;
31 int wait_pattern;
Wolfgang Grandeggerf1540442009-02-11 18:38:21 +010032 int (*dev_ready)(int chip_nr);
Anton Vorontsov6ab97e92008-01-14 23:09:32 +030033 int chip_delay;
Wolfgang Grandeggerf1540442009-02-11 18:38:21 +010034 int chip_offset;
35 int chip_nr;
Anton Vorontsov67166032008-06-12 11:10:21 -050036
37 /* no need to fill */
38 int last_ctrl;
Anton Vorontsov6ab97e92008-01-14 23:09:32 +030039};
40
41extern int fsl_upm_nand_init(struct nand_chip *chip, struct fsl_upm_nand *fun);
42
43#endif