blob: 8bdd23112b4f2cfd5c40079e8301c7ba2ba0966e [file] [log] [blame]
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +02001/*
William Juul52c07962007-10-31 13:53:06 +01002 * $Id: mtd-abi.h,v 1.13 2005/11/07 11:14:56 gleixner Exp $
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +02003 *
Wolfgang Denk7b9bc3a2005-09-14 23:53:32 +02004 * Portions of MTD ABI definition which are shared by kernel and user space
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +02005 */
6
7#ifndef __MTD_ABI_H__
8#define __MTD_ABI_H__
9
William Juul52c07962007-10-31 13:53:06 +010010#if 1
Mike Frysinger11d1a092012-04-09 13:39:55 +000011#include <linux/compat.h>
William Juul52c07962007-10-31 13:53:06 +010012#endif
13
Kim Phillips632fe9c2012-10-29 13:34:24 +000014#include <linux/compiler.h>
15
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020016struct erase_info_user {
17 uint32_t start;
18 uint32_t length;
19};
20
21struct mtd_oob_buf {
22 uint32_t start;
23 uint32_t length;
William Juul52c07962007-10-31 13:53:06 +010024 unsigned char __user *ptr;
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020025};
26
27#define MTD_ABSENT 0
28#define MTD_RAM 1
29#define MTD_ROM 2
30#define MTD_NORFLASH 3
31#define MTD_NANDFLASH 4
William Juul52c07962007-10-31 13:53:06 +010032#define MTD_DATAFLASH 6
33#define MTD_UBIVOLUME 7
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020034
William Juul52c07962007-10-31 13:53:06 +010035#define MTD_WRITEABLE 0x400 /* Device is writeable */
36#define MTD_BIT_WRITEABLE 0x800 /* Single bits can be flipped */
37#define MTD_NO_ERASE 0x1000 /* No erase necessary */
38#define MTD_STUPID_LOCK 0x2000 /* Always locked after reset */
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020039
Wolfgang Denk74e0dde2008-08-14 14:41:06 +020040/* Some common devices / combinations of capabilities */
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020041#define MTD_CAP_ROM 0
William Juul52c07962007-10-31 13:53:06 +010042#define MTD_CAP_RAM (MTD_WRITEABLE | MTD_BIT_WRITEABLE | MTD_NO_ERASE)
43#define MTD_CAP_NORFLASH (MTD_WRITEABLE | MTD_BIT_WRITEABLE)
44#define MTD_CAP_NANDFLASH (MTD_WRITEABLE)
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020045
46/* ECC byte placement */
Wolfgang Denk74e0dde2008-08-14 14:41:06 +020047#define MTD_NANDECC_OFF 0 /* Switch off ECC (Not recommended) */
48#define MTD_NANDECC_PLACE 1 /* Use the given placement in the structure (YAFFS1 legacy mode) */
49#define MTD_NANDECC_AUTOPLACE 2 /* Use the default placement scheme */
50#define MTD_NANDECC_PLACEONLY 3 /* Use the given placement in the structure (Do not store ecc result on read) */
51#define MTD_NANDECC_AUTOPL_USR 4 /* Use the given autoplacement scheme rather than using the default */
William Juul52c07962007-10-31 13:53:06 +010052
53/* OTP mode selection */
54#define MTD_OTP_OFF 0
55#define MTD_OTP_FACTORY 1
56#define MTD_OTP_USER 2
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020057
58struct mtd_info_user {
59 uint8_t type;
60 uint32_t flags;
Wolfgang Denk74e0dde2008-08-14 14:41:06 +020061 uint32_t size; /* Total size of the MTD */
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020062 uint32_t erasesize;
William Juul52c07962007-10-31 13:53:06 +010063 uint32_t writesize;
Wolfgang Denk74e0dde2008-08-14 14:41:06 +020064 uint32_t oobsize; /* Amount of OOB data per block (e.g. 16) */
William Juul52c07962007-10-31 13:53:06 +010065 /* The below two fields are obsolete and broken, do not use them
66 * (TODO: remove at some point) */
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020067 uint32_t ecctype;
68 uint32_t eccsize;
69};
70
71struct region_info_user {
Wolfgang Denk7b9bc3a2005-09-14 23:53:32 +020072 uint32_t offset; /* At which this region starts,
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020073 * from the beginning of the MTD */
74 uint32_t erasesize; /* For this region */
75 uint32_t numblocks; /* Number of blocks in this region */
76 uint32_t regionindex;
77};
78
William Juul52c07962007-10-31 13:53:06 +010079struct otp_info {
80 uint32_t start;
81 uint32_t length;
82 uint32_t locked;
83};
84
85#define MEMGETINFO _IOR('M', 1, struct mtd_info_user)
86#define MEMERASE _IOW('M', 2, struct erase_info_user)
87#define MEMWRITEOOB _IOWR('M', 3, struct mtd_oob_buf)
88#define MEMREADOOB _IOWR('M', 4, struct mtd_oob_buf)
89#define MEMLOCK _IOW('M', 5, struct erase_info_user)
90#define MEMUNLOCK _IOW('M', 6, struct erase_info_user)
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +020091#define MEMGETREGIONCOUNT _IOR('M', 7, int)
92#define MEMGETREGIONINFO _IOWR('M', 8, struct region_info_user)
93#define MEMSETOOBSEL _IOW('M', 9, struct nand_oobinfo)
94#define MEMGETOOBSEL _IOR('M', 10, struct nand_oobinfo)
95#define MEMGETBADBLOCK _IOW('M', 11, loff_t)
96#define MEMSETBADBLOCK _IOW('M', 12, loff_t)
William Juul52c07962007-10-31 13:53:06 +010097#define OTPSELECT _IOR('M', 13, int)
98#define OTPGETREGIONCOUNT _IOW('M', 14, int)
99#define OTPGETREGIONINFO _IOW('M', 15, struct otp_info)
100#define OTPLOCK _IOR('M', 16, struct otp_info)
101#define ECCGETLAYOUT _IOR('M', 17, struct nand_ecclayout)
102#define ECCGETSTATS _IOR('M', 18, struct mtd_ecc_stats)
103#define MTDFILEMODE _IO('M', 19)
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +0200104
William Juul52c07962007-10-31 13:53:06 +0100105/*
106 * Obsolete legacy interface. Keep it in order not to break userspace
107 * interfaces
108 */
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +0200109struct nand_oobinfo {
110 uint32_t useecc;
111 uint32_t eccbytes;
112 uint32_t oobfree[8][2];
Sergei Poselenov04fbaa02008-06-06 15:42:43 +0200113 uint32_t eccpos[48];
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +0200114};
115
William Juul52c07962007-10-31 13:53:06 +0100116struct nand_oobfree {
117 uint32_t offset;
118 uint32_t length;
119};
120
121#define MTD_MAX_OOBFREE_ENTRIES 8
122/*
123 * ECC layout control structure. Exported to userspace for
124 * diagnosis and to allow creation of raw images
125 */
126struct nand_ecclayout {
127 uint32_t eccbytes;
Sandeep Paulraj0fe90a42009-11-16 13:31:47 -0500128 uint32_t eccpos[128];
William Juul52c07962007-10-31 13:53:06 +0100129 uint32_t oobavail;
130 struct nand_oobfree oobfree[MTD_MAX_OOBFREE_ENTRIES];
131};
132
133/**
134 * struct mtd_ecc_stats - error correction stats
135 *
136 * @corrected: number of corrected bits
137 * @failed: number of uncorrectable errors
138 * @badblocks: number of bad blocks in this partition
139 * @bbtblocks: number of blocks reserved for bad block tables
140 */
141struct mtd_ecc_stats {
142 uint32_t corrected;
143 uint32_t failed;
144 uint32_t badblocks;
145 uint32_t bbtblocks;
146};
147
148/*
149 * Read/write file modes for access to MTD
150 */
151enum mtd_file_modes {
152 MTD_MODE_NORMAL = MTD_OTP_OFF,
153 MTD_MODE_OTP_FACTORY = MTD_OTP_FACTORY,
154 MTD_MODE_OTP_USER = MTD_OTP_USER,
155 MTD_MODE_RAW,
156};
157
Wolfgang Denk2f9b7e42005-08-17 12:55:25 +0200158#endif /* __MTD_ABI_H__ */