blob: 2ed77b7b3fcb56e631ee8283d0ea6d209453b93d [file] [log] [blame]
Thomas Gleixnerec8f24b2019-05-19 13:07:45 +01001# SPDX-License-Identifier: GPL-2.0-only
H Hartley Sweeten1dd78632010-08-19 17:28:50 -07002menuconfig MTD_UBI
3 tristate "Enable UBI - Unsorted block images"
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +04004 select CRC32
5 help
Andrew F. Davis2fae1312017-01-05 14:44:49 -06006 UBI is a software layer above MTD layer which admits use of LVM-like
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +04007 logical volumes on top of MTD devices, hides some complexities of
8 flash chips like wear and bad blocks and provides some other useful
9 capabilities. Please, consult the MTD web site for more details
10 (www.linux-mtd.infradead.org).
11
H Hartley Sweeten1dd78632010-08-19 17:28:50 -070012if MTD_UBI
13
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040014config MTD_UBI_WL_THRESHOLD
15 int "UBI wear-leveling threshold"
16 default 4096
17 range 2 65536
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040018 help
19 This parameter defines the maximum difference between the highest
20 erase counter value and the lowest erase counter value of eraseblocks
21 of UBI devices. When this threshold is exceeded, UBI starts performing
22 wear leveling by means of moving data from eraseblock with low erase
Artem Bityutskiy6e0c84e2008-03-27 17:18:45 +020023 counter to eraseblocks with high erase counter.
24
25 The default value should be OK for SLC NAND flashes, NOR flashes and
26 other flashes which have eraseblock life-cycle 100000 or more.
27 However, in case of MLC NAND flashes which typically have eraseblock
Shinya Kuribayashi3f502622010-05-06 19:21:47 +090028 life-cycle less than 10000, the threshold should be lessened (e.g.,
Artem Bityutskiy6e0c84e2008-03-27 17:18:45 +020029 to 128 or 256, although it does not have to be power of 2).
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040030
Shmulik Ladkani8beeb3b2012-07-04 11:06:00 +030031config MTD_UBI_BEB_LIMIT
Richard Genoudba4087e2012-07-10 18:23:41 +020032 int "Maximum expected bad eraseblock count per 1024 eraseblocks"
33 default 20
34 range 0 768
Shmulik Ladkani8beeb3b2012-07-04 11:06:00 +030035 help
36 This option specifies the maximum bad physical eraseblocks UBI
Richard Genoudba4087e2012-07-10 18:23:41 +020037 expects on the MTD device (per 1024 eraseblocks). If the underlying
38 flash does not admit of bad eraseblocks (e.g. NOR flash), this value
39 is ignored.
40
41 NAND datasheets often specify the minimum and maximum NVM (Number of
42 Valid Blocks) for the flashes' endurance lifetime. The maximum
43 expected bad eraseblocks per 1024 eraseblocks then can be calculated
44 as "1024 * (1 - MinNVB / MaxNVB)", which gives 20 for most NANDs
45 (MaxNVB is basically the total count of eraseblocks on the chip).
46
47 To put it differently, if this value is 20, UBI will try to reserve
48 about 1.9% of physical eraseblocks for bad blocks handling. And that
49 will be 1.9% of eraseblocks on the entire NAND chip, not just the MTD
50 partition UBI attaches. This means that if you have, say, a NAND
51 flash chip admits maximum 40 bad eraseblocks, and it is split on two
52 MTD partitions of the same size, UBI will reserve 40 eraseblocks when
53 attaching a partition.
54
Richard Genouddb7e21c2012-08-20 18:00:15 +020055 This option can be overridden by the "mtd=" UBI module parameter or
56 by the "attach" ioctl.
Richard Genoudedac4932012-08-20 18:00:14 +020057
Shmulik Ladkani8beeb3b2012-07-04 11:06:00 +030058 Leave the default value if unsure.
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040059
Richard Weinberger76ac66e2012-09-26 17:51:50 +020060config MTD_UBI_FASTMAP
61 bool "UBI Fastmap (Experimental feature)"
62 default n
63 help
64 Important: this feature is experimental so far and the on-flash
65 format for fastmap may change in the next kernel versions
66
67 Fastmap is a mechanism which allows attaching an UBI device
68 in nearly constant time. Instead of scanning the whole MTD device it
69 only has to locate a checkpoint (called fastmap) on the device.
70 The on-flash fastmap contains all information needed to attach
71 the device. Using fastmap makes only sense on large devices where
72 attaching by scanning takes long. UBI will not automatically install
73 a fastmap on old images, but you can set the UBI module parameter
74 fm_autoconvert to 1 if you want so. Please note that fastmap-enabled
75 images are still usable with UBI implementations without
76 fastmap support. On typical flash devices the whole fastmap fits
77 into one PEB. UBI will reserve PEBs to hold two fastmaps.
78
79 If in doubt, say "N".
80
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040081config MTD_UBI_GLUEBI
Dmitry Pervushin2ba3d762009-05-31 18:32:59 +040082 tristate "MTD devices emulation driver (gluebi)"
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040083 help
Dmitry Pervushin2ba3d762009-05-31 18:32:59 +040084 This option enables gluebi - an additional driver which emulates MTD
85 devices on top of UBI volumes: for each UBI volumes an MTD device is
86 created, and all I/O to this MTD device is redirected to the UBI
87 volume. This is handy to make MTD-oriented software (like JFFS2)
88 work on top of UBI. Do not enable this unless you use legacy
89 software.
Artem B. Bityutskiy801c1352006-06-27 12:22:22 +040090
Ezequiel Garcia9d54c8a2014-02-25 13:25:22 -030091config MTD_UBI_BLOCK
92 bool "Read-only block devices on top of UBI volumes"
93 default n
Ezequiel Garcia22d3ee52014-03-03 13:42:40 -030094 depends on BLOCK
Ezequiel Garcia9d54c8a2014-02-25 13:25:22 -030095 help
96 This option enables read-only UBI block devices support. UBI block
97 devices will be layered on top of UBI volumes, which means that the
98 UBI driver will transparently handle things like bad eraseblocks and
99 bit-flips. You can put any block-oriented file system on top of UBI
100 volumes in read-only mode (e.g., ext4), but it is probably most
101 practical for read-only file systems, like squashfs.
102
103 When selected, this feature will be built in the UBI driver.
104
105 If in doubt, say "N".
106
H Hartley Sweeten1dd78632010-08-19 17:28:50 -0700107endif # MTD_UBI