aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/Kconfig190
-rw-r--r--fs/jffs2/Kconfig188
-rw-r--r--fs/jffs2/dir.c2
-rw-r--r--fs/jffs2/erase.c4
-rw-r--r--fs/jffs2/fs.c2
5 files changed, 194 insertions, 192 deletions
diff --git a/fs/Kconfig b/fs/Kconfig
index abccb5dab9a8..b7c88e1f0161 100644
--- a/fs/Kconfig
+++ b/fs/Kconfig
@@ -1136,195 +1136,7 @@ config EFS_FS
1136 To compile the EFS file system support as a module, choose M here: the 1136 To compile the EFS file system support as a module, choose M here: the
1137 module will be called efs. 1137 module will be called efs.
1138 1138
1139config JFFS2_FS 1139source "fs/jffs2/Kconfig"
1140 tristate "Journalling Flash File System v2 (JFFS2) support"
1141 select CRC32
1142 depends on MTD
1143 help
1144 JFFS2 is the second generation of the Journalling Flash File System
1145 for use on diskless embedded devices. It provides improved wear
1146 levelling, compression and support for hard links. You cannot use
1147 this on normal block devices, only on 'MTD' devices.
1148
1149 Further information on the design and implementation of JFFS2 is
1150 available at <http://sources.redhat.com/jffs2/>.
1151
1152config JFFS2_FS_DEBUG
1153 int "JFFS2 debugging verbosity (0 = quiet, 2 = noisy)"
1154 depends on JFFS2_FS
1155 default "0"
1156 help
1157 This controls the amount of debugging messages produced by the JFFS2
1158 code. Set it to zero for use in production systems. For evaluation,
1159 testing and debugging, it's advisable to set it to one. This will
1160 enable a few assertions and will print debugging messages at the
1161 KERN_DEBUG loglevel, where they won't normally be visible. Level 2
1162 is unlikely to be useful - it enables extra debugging in certain
1163 areas which at one point needed debugging, but when the bugs were
1164 located and fixed, the detailed messages were relegated to level 2.
1165
1166 If reporting bugs, please try to have available a full dump of the
1167 messages at debug level 1 while the misbehaviour was occurring.
1168
1169config JFFS2_FS_WRITEBUFFER
1170 bool "JFFS2 write-buffering support"
1171 depends on JFFS2_FS
1172 default y
1173 help
1174 This enables the write-buffering support in JFFS2.
1175
1176 This functionality is required to support JFFS2 on the following
1177 types of flash devices:
1178 - NAND flash
1179 - NOR flash with transparent ECC
1180 - DataFlash
1181
1182config JFFS2_FS_WBUF_VERIFY
1183 bool "Verify JFFS2 write-buffer reads"
1184 depends on JFFS2_FS_WRITEBUFFER
1185 default n
1186 help
1187 This causes JFFS2 to read back every page written through the
1188 write-buffer, and check for errors.
1189
1190config JFFS2_SUMMARY
1191 bool "JFFS2 summary support (EXPERIMENTAL)"
1192 depends on JFFS2_FS && EXPERIMENTAL
1193 default n
1194 help
1195 This feature makes it possible to use summary information
1196 for faster filesystem mount.
1197
1198 The summary information can be inserted into a filesystem image
1199 by the utility 'sumtool'.
1200
1201 If unsure, say 'N'.
1202
1203config JFFS2_FS_XATTR
1204 bool "JFFS2 XATTR support (EXPERIMENTAL)"
1205 depends on JFFS2_FS && EXPERIMENTAL
1206 default n
1207 help
1208 Extended attributes are name:value pairs associated with inodes by
1209 the kernel or by users (see the attr(5) manual page, or visit
1210 <http://acl.bestbits.at/> for details).
1211
1212 If unsure, say N.
1213
1214config JFFS2_FS_POSIX_ACL
1215 bool "JFFS2 POSIX Access Control Lists"
1216 depends on JFFS2_FS_XATTR
1217 default y
1218 select FS_POSIX_ACL
1219 help
1220 Posix Access Control Lists (ACLs) support permissions for users and
1221 groups beyond the owner/group/world scheme.
1222
1223 To learn more about Access Control Lists, visit the Posix ACLs for
1224 Linux website <http://acl.bestbits.at/>.
1225
1226 If you don't know what Access Control Lists are, say N
1227
1228config JFFS2_FS_SECURITY
1229 bool "JFFS2 Security Labels"
1230 depends on JFFS2_FS_XATTR
1231 default y
1232 help
1233 Security labels support alternative access control models
1234 implemented by security modules like SELinux. This option
1235 enables an extended attribute handler for file security
1236 labels in the jffs2 filesystem.
1237
1238 If you are not using a security module that requires using
1239 extended attributes for file security labels, say N.
1240
1241config JFFS2_COMPRESSION_OPTIONS
1242 bool "Advanced compression options for JFFS2"
1243 depends on JFFS2_FS
1244 default n
1245 help
1246 Enabling this option allows you to explicitly choose which
1247 compression modules, if any, are enabled in JFFS2. Removing
1248 compressors can mean you cannot read existing file systems,
1249 and enabling experimental compressors can mean that you
1250 write a file system which cannot be read by a standard kernel.
1251
1252 If unsure, you should _definitely_ say 'N'.
1253
1254config JFFS2_ZLIB
1255 bool "JFFS2 ZLIB compression support" if JFFS2_COMPRESSION_OPTIONS
1256 select ZLIB_INFLATE
1257 select ZLIB_DEFLATE
1258 depends on JFFS2_FS
1259 default y
1260 help
1261 Zlib is designed to be a free, general-purpose, legally unencumbered,
1262 lossless data-compression library for use on virtually any computer
1263 hardware and operating system. See <http://www.gzip.org/zlib/> for
1264 further information.
1265
1266 Say 'Y' if unsure.
1267
1268config JFFS2_LZO
1269 bool "JFFS2 LZO compression support" if JFFS2_COMPRESSION_OPTIONS
1270 select LZO_COMPRESS
1271 select LZO_DECOMPRESS
1272 depends on JFFS2_FS
1273 default n
1274 help
1275 minilzo-based compression. Generally works better than Zlib.
1276
1277 This feature was added in July, 2007. Say 'N' if you need
1278 compatibility with older bootloaders or kernels.
1279
1280config JFFS2_RTIME
1281 bool "JFFS2 RTIME compression support" if JFFS2_COMPRESSION_OPTIONS
1282 depends on JFFS2_FS
1283 default y
1284 help
1285 Rtime does manage to recompress already-compressed data. Say 'Y' if unsure.
1286
1287config JFFS2_RUBIN
1288 bool "JFFS2 RUBIN compression support" if JFFS2_COMPRESSION_OPTIONS
1289 depends on JFFS2_FS
1290 default n
1291 help
1292 RUBINMIPS and DYNRUBIN compressors. Say 'N' if unsure.
1293
1294choice
1295 prompt "JFFS2 default compression mode" if JFFS2_COMPRESSION_OPTIONS
1296 default JFFS2_CMODE_PRIORITY
1297 depends on JFFS2_FS
1298 help
1299 You can set here the default compression mode of JFFS2 from
1300 the available compression modes. Don't touch if unsure.
1301
1302config JFFS2_CMODE_NONE
1303 bool "no compression"
1304 help
1305 Uses no compression.
1306
1307config JFFS2_CMODE_PRIORITY
1308 bool "priority"
1309 help
1310 Tries the compressors in a predefined order and chooses the first
1311 successful one.
1312
1313config JFFS2_CMODE_SIZE
1314 bool "size (EXPERIMENTAL)"
1315 help
1316 Tries all compressors and chooses the one which has the smallest
1317 result.
1318
1319config JFFS2_CMODE_FAVOURLZO
1320 bool "Favour LZO"
1321 help
1322 Tries all compressors and chooses the one which has the smallest
1323 result but gives some preference to LZO (which has faster
1324 decompression) at the expense of size.
1325
1326endchoice
1327
1328# UBIFS File system configuration 1140# UBIFS File system configuration
1329source "fs/ubifs/Kconfig" 1141source "fs/ubifs/Kconfig"
1330 1142
diff --git a/fs/jffs2/Kconfig b/fs/jffs2/Kconfig
new file mode 100644
index 000000000000..6ae169cd8faa
--- /dev/null
+++ b/fs/jffs2/Kconfig
@@ -0,0 +1,188 @@
1config JFFS2_FS
2 tristate "Journalling Flash File System v2 (JFFS2) support"
3 select CRC32
4 depends on MTD
5 help
6 JFFS2 is the second generation of the Journalling Flash File System
7 for use on diskless embedded devices. It provides improved wear
8 levelling, compression and support for hard links. You cannot use
9 this on normal block devices, only on 'MTD' devices.
10
11 Further information on the design and implementation of JFFS2 is
12 available at <http://sources.redhat.com/jffs2/>.
13
14config JFFS2_FS_DEBUG
15 int "JFFS2 debugging verbosity (0 = quiet, 2 = noisy)"
16 depends on JFFS2_FS
17 default "0"
18 help
19 This controls the amount of debugging messages produced by the JFFS2
20 code. Set it to zero for use in production systems. For evaluation,
21 testing and debugging, it's advisable to set it to one. This will
22 enable a few assertions and will print debugging messages at the
23 KERN_DEBUG loglevel, where they won't normally be visible. Level 2
24 is unlikely to be useful - it enables extra debugging in certain
25 areas which at one point needed debugging, but when the bugs were
26 located and fixed, the detailed messages were relegated to level 2.
27
28 If reporting bugs, please try to have available a full dump of the
29 messages at debug level 1 while the misbehaviour was occurring.
30
31config JFFS2_FS_WRITEBUFFER
32 bool "JFFS2 write-buffering support"
33 depends on JFFS2_FS
34 default y
35 help
36 This enables the write-buffering support in JFFS2.
37
38 This functionality is required to support JFFS2 on the following
39 types of flash devices:
40 - NAND flash
41 - NOR flash with transparent ECC
42 - DataFlash
43
44config JFFS2_FS_WBUF_VERIFY
45 bool "Verify JFFS2 write-buffer reads"
46 depends on JFFS2_FS_WRITEBUFFER
47 default n
48 help
49 This causes JFFS2 to read back every page written through the
50 write-buffer, and check for errors.
51
52config JFFS2_SUMMARY
53 bool "JFFS2 summary support (EXPERIMENTAL)"
54 depends on JFFS2_FS && EXPERIMENTAL
55 default n
56 help
57 This feature makes it possible to use summary information
58 for faster filesystem mount.
59
60 The summary information can be inserted into a filesystem image
61 by the utility 'sumtool'.
62
63 If unsure, say 'N'.
64
65config JFFS2_FS_XATTR
66 bool "JFFS2 XATTR support (EXPERIMENTAL)"
67 depends on JFFS2_FS && EXPERIMENTAL
68 default n
69 help
70 Extended attributes are name:value pairs associated with inodes by
71 the kernel or by users (see the attr(5) manual page, or visit
72 <http://acl.bestbits.at/> for details).
73
74 If unsure, say N.
75
76config JFFS2_FS_POSIX_ACL
77 bool "JFFS2 POSIX Access Control Lists"
78 depends on JFFS2_FS_XATTR
79 default y
80 select FS_POSIX_ACL
81 help
82 Posix Access Control Lists (ACLs) support permissions for users and
83 groups beyond the owner/group/world scheme.
84
85 To learn more about Access Control Lists, visit the Posix ACLs for
86 Linux website <http://acl.bestbits.at/>.
87
88 If you don't know what Access Control Lists are, say N
89
90config JFFS2_FS_SECURITY
91 bool "JFFS2 Security Labels"
92 depends on JFFS2_FS_XATTR
93 default y
94 help
95 Security labels support alternative access control models
96 implemented by security modules like SELinux. This option
97 enables an extended attribute handler for file security
98 labels in the jffs2 filesystem.
99
100 If you are not using a security module that requires using
101 extended attributes for file security labels, say N.
102
103config JFFS2_COMPRESSION_OPTIONS
104 bool "Advanced compression options for JFFS2"
105 depends on JFFS2_FS
106 default n
107 help
108 Enabling this option allows you to explicitly choose which
109 compression modules, if any, are enabled in JFFS2. Removing
110 compressors can mean you cannot read existing file systems,
111 and enabling experimental compressors can mean that you
112 write a file system which cannot be read by a standard kernel.
113
114 If unsure, you should _definitely_ say 'N'.
115
116config JFFS2_ZLIB
117 bool "JFFS2 ZLIB compression support" if JFFS2_COMPRESSION_OPTIONS
118 select ZLIB_INFLATE
119 select ZLIB_DEFLATE
120 depends on JFFS2_FS
121 default y
122 help
123 Zlib is designed to be a free, general-purpose, legally unencumbered,
124 lossless data-compression library for use on virtually any computer
125 hardware and operating system. See <http://www.gzip.org/zlib/> for
126 further information.
127
128 Say 'Y' if unsure.
129
130config JFFS2_LZO
131 bool "JFFS2 LZO compression support" if JFFS2_COMPRESSION_OPTIONS
132 select LZO_COMPRESS
133 select LZO_DECOMPRESS
134 depends on JFFS2_FS
135 default n
136 help
137 minilzo-based compression. Generally works better than Zlib.
138
139 This feature was added in July, 2007. Say 'N' if you need
140 compatibility with older bootloaders or kernels.
141
142config JFFS2_RTIME
143 bool "JFFS2 RTIME compression support" if JFFS2_COMPRESSION_OPTIONS
144 depends on JFFS2_FS
145 default y
146 help
147 Rtime does manage to recompress already-compressed data. Say 'Y' if unsure.
148
149config JFFS2_RUBIN
150 bool "JFFS2 RUBIN compression support" if JFFS2_COMPRESSION_OPTIONS
151 depends on JFFS2_FS
152 default n
153 help
154 RUBINMIPS and DYNRUBIN compressors. Say 'N' if unsure.
155
156choice
157 prompt "JFFS2 default compression mode" if JFFS2_COMPRESSION_OPTIONS
158 default JFFS2_CMODE_PRIORITY
159 depends on JFFS2_FS
160 help
161 You can set here the default compression mode of JFFS2 from
162 the available compression modes. Don't touch if unsure.
163
164config JFFS2_CMODE_NONE
165 bool "no compression"
166 help
167 Uses no compression.
168
169config JFFS2_CMODE_PRIORITY
170 bool "priority"
171 help
172 Tries the compressors in a predefined order and chooses the first
173 successful one.
174
175config JFFS2_CMODE_SIZE
176 bool "size (EXPERIMENTAL)"
177 help
178 Tries all compressors and chooses the one which has the smallest
179 result.
180
181config JFFS2_CMODE_FAVOURLZO
182 bool "Favour LZO"
183 help
184 Tries all compressors and chooses the one which has the smallest
185 result but gives some preference to LZO (which has faster
186 decompression) at the expense of size.
187
188endchoice
diff --git a/fs/jffs2/dir.c b/fs/jffs2/dir.c
index cd219ef55254..b1aaae823a52 100644
--- a/fs/jffs2/dir.c
+++ b/fs/jffs2/dir.c
@@ -311,7 +311,7 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
311 /* FIXME: If you care. We'd need to use frags for the target 311 /* FIXME: If you care. We'd need to use frags for the target
312 if it grows much more than this */ 312 if it grows much more than this */
313 if (targetlen > 254) 313 if (targetlen > 254)
314 return -EINVAL; 314 return -ENAMETOOLONG;
315 315
316 ri = jffs2_alloc_raw_inode(); 316 ri = jffs2_alloc_raw_inode();
317 317
diff --git a/fs/jffs2/erase.c b/fs/jffs2/erase.c
index dddb2a6c9e2c..259461b910af 100644
--- a/fs/jffs2/erase.c
+++ b/fs/jffs2/erase.c
@@ -68,7 +68,7 @@ static void jffs2_erase_block(struct jffs2_sb_info *c,
68 instr->len = c->sector_size; 68 instr->len = c->sector_size;
69 instr->callback = jffs2_erase_callback; 69 instr->callback = jffs2_erase_callback;
70 instr->priv = (unsigned long)(&instr[1]); 70 instr->priv = (unsigned long)(&instr[1]);
71 instr->fail_addr = 0xffffffff; 71 instr->fail_addr = MTD_FAIL_ADDR_UNKNOWN;
72 72
73 ((struct erase_priv_struct *)instr->priv)->jeb = jeb; 73 ((struct erase_priv_struct *)instr->priv)->jeb = jeb;
74 ((struct erase_priv_struct *)instr->priv)->c = c; 74 ((struct erase_priv_struct *)instr->priv)->c = c;
@@ -175,7 +175,7 @@ static void jffs2_erase_failed(struct jffs2_sb_info *c, struct jffs2_eraseblock
175{ 175{
176 /* For NAND, if the failure did not occur at the device level for a 176 /* For NAND, if the failure did not occur at the device level for a
177 specific physical page, don't bother updating the bad block table. */ 177 specific physical page, don't bother updating the bad block table. */
178 if (jffs2_cleanmarker_oob(c) && (bad_offset != 0xffffffff)) { 178 if (jffs2_cleanmarker_oob(c) && (bad_offset != MTD_FAIL_ADDR_UNKNOWN)) {
179 /* We had a device-level failure to erase. Let's see if we've 179 /* We had a device-level failure to erase. Let's see if we've
180 failed too many times. */ 180 failed too many times. */
181 if (!jffs2_write_nand_badblock(c, jeb, bad_offset)) { 181 if (!jffs2_write_nand_badblock(c, jeb, bad_offset)) {
diff --git a/fs/jffs2/fs.c b/fs/jffs2/fs.c
index 086c43830221..89e9b735d8df 100644
--- a/fs/jffs2/fs.c
+++ b/fs/jffs2/fs.c
@@ -207,6 +207,8 @@ int jffs2_statfs(struct dentry *dentry, struct kstatfs *buf)
207 buf->f_files = 0; 207 buf->f_files = 0;
208 buf->f_ffree = 0; 208 buf->f_ffree = 0;
209 buf->f_namelen = JFFS2_MAX_NAME_LEN; 209 buf->f_namelen = JFFS2_MAX_NAME_LEN;
210 buf->f_fsid.val[0] = JFFS2_SUPER_MAGIC;
211 buf->f_fsid.val[1] = c->mtd->index;
210 212
211 spin_lock(&c->erase_completion_lock); 213 spin_lock(&c->erase_completion_lock);
212 avail = c->dirty_size + c->free_size; 214 avail = c->dirty_size + c->free_size;