xref: /openbmc/linux/drivers/mtd/parsers/Kconfig (revision 25c2e591)
1# SPDX-License-Identifier: GPL-2.0-only
2config MTD_AR7_PARTS
3	tristate "TI AR7 partitioning parser"
4	help
5	  TI AR7 partitioning parser support
6
7config MTD_BCM47XX_PARTS
8	tristate "BCM47XX partitioning parser"
9	depends on BCM47XX || ARCH_BCM_5301X
10	help
11	  This provides partitions parser for devices based on BCM47xx
12	  boards.
13
14config MTD_BCM63XX_PARTS
15	bool "BCM63XX CFE partitioning parser"
16	depends on BCM63XX || BMIPS_GENERIC || COMPILE_TEST
17	select CRC32
18	select MTD_PARSER_IMAGETAG
19	help
20	  This provides partition parsing for BCM63xx devices with CFE
21	  bootloaders.
22
23config MTD_BRCM_U_BOOT
24	tristate "Broadcom's U-Boot partition parser"
25	depends on ARCH_BCM4908 || COMPILE_TEST
26	help
27	  Broadcom uses a custom way of storing U-Boot environment variables.
28	  They are placed inside U-Boot partition itself at unspecified offset.
29	  It's possible to locate them by looking for a custom header with a
30	  magic value. This driver does that and creates subpartitions for
31	  each found environment variables block.
32
33config MTD_CMDLINE_PARTS
34	tristate "Command line partition table parsing"
35	depends on MTD
36	help
37	  Allow generic configuration of the MTD partition tables via the kernel
38	  command line. Multiple flash resources are supported for hardware where
39	  different kinds of flash memory are available.
40
41	  You will still need the parsing functions to be called by the driver
42	  for your particular device. It won't happen automatically. The
43	  SA1100 map driver (CONFIG_MTD_SA1100) has an option for this, for
44	  example.
45
46	  The format for the command line is as follows:
47
48	  mtdparts=<mtddef>[;<mtddef]
49	  <mtddef>  := <mtd-id>:<partdef>[,<partdef>]
50	  <partdef> := <size>[@offset][<name>][ro]
51	  <mtd-id>  := unique id used in mapping driver/device
52	  <size>    := standard linux memsize OR "-" to denote all
53	  remaining space
54	  <name>    := (NAME)
55
56	  Due to the way Linux handles the command line, no spaces are
57	  allowed in the partition definition, including mtd id's and partition
58	  names.
59
60	  Examples:
61
62	  1 flash resource (mtd-id "sa1100"), with 1 single writable partition:
63	  mtdparts=sa1100:-
64
65	  Same flash, but 2 named partitions, the first one being read-only:
66	  mtdparts=sa1100:256k(ARMboot)ro,-(root)
67
68	  If unsure, say 'N'.
69
70config MTD_OF_PARTS
71	tristate "OpenFirmware (device tree) partitioning parser"
72	default y
73	depends on OF
74	help
75	  This provides a open firmware device tree partition parser
76	  which derives the partition map from the children of the
77	  flash memory node, as described in
78	  Documentation/devicetree/bindings/mtd/partition.txt.
79
80config MTD_OF_PARTS_BCM4908
81	bool "BCM4908 partitioning support"
82	depends on MTD_OF_PARTS && (ARCH_BCMBCA || COMPILE_TEST)
83	default ARCH_BCMBCA
84	help
85	  This provides partitions parser for BCM4908 family devices
86	  that can have multiple "firmware" partitions. It takes care of
87	  finding currently used one and backup ones.
88
89config MTD_OF_PARTS_LINKSYS_NS
90	bool "Linksys Northstar partitioning support"
91	depends on MTD_OF_PARTS && (ARCH_BCM_5301X || ARCH_BCMBCA || COMPILE_TEST)
92	default ARCH_BCM_5301X
93	help
94	  This provides partitions parser for Linksys devices based on Broadcom
95	  Northstar architecture. Linksys commonly uses fixed flash layout with
96	  two "firmware" partitions. Currently used firmware has to be detected
97	  using CFE environment variable.
98
99config MTD_PARSER_IMAGETAG
100	tristate "Parser for BCM963XX Image Tag format partitions"
101	depends on BCM63XX || BMIPS_GENERIC || COMPILE_TEST
102	select CRC32
103	help
104	  Image Tag is the firmware header used by broadcom on their xDSL line
105	  of devices. It is used to describe the offsets and lengths of kernel
106	  and rootfs partitions.
107	  This driver adds support for parsing a partition with an Image Tag
108	  header and creates up to two partitions, kernel and rootfs.
109
110config MTD_AFS_PARTS
111	tristate "ARM Firmware Suite partition parsing"
112	depends on (ARM || ARM64)
113	help
114	  The ARM Firmware Suite allows the user to divide flash devices into
115	  multiple 'images'. Each such image has a header containing its name
116	  and offset/size etc.
117
118	  If you need code which can detect and parse these tables, and
119	  register MTD 'partitions' corresponding to each image detected,
120	  enable this option.
121
122	  You will still need the parsing functions to be called by the driver
123	  for your particular device. It won't happen automatically. The
124	  'physmap' map driver (CONFIG_MTD_PHYSMAP) does this, for example.
125
126config MTD_PARSER_TRX
127	tristate "Parser for TRX format partitions"
128	depends on MTD && (BCM47XX || ARCH_BCM_5301X || ARCH_MEDIATEK || RALINK || COMPILE_TEST)
129	help
130	  TRX is a firmware format used by Broadcom on their devices. It
131	  may contain up to 3/4 partitions (depending on the version).
132	  This driver will parse TRX header and report at least two partitions:
133	  kernel and rootfs.
134
135config MTD_SHARPSL_PARTS
136	tristate "Sharp SL Series NAND flash partition parser"
137	depends on MTD_NAND_SHARPSL || MTD_NAND_TMIO || COMPILE_TEST
138	help
139	  This provides the read-only FTL logic necessary to read the partition
140	  table from the NAND flash of Sharp SL Series (Zaurus) and the MTD
141	  partition parser using this code.
142
143config MTD_REDBOOT_PARTS
144	tristate "RedBoot partition table parsing"
145	help
146	  RedBoot is a ROM monitor and bootloader which deals with multiple
147	  'images' in flash devices by putting a table one of the erase
148	  blocks on the device, similar to a partition table, which gives
149	  the offsets, lengths and names of all the images stored in the
150	  flash.
151
152	  If you need code which can detect and parse this table, and register
153	  MTD 'partitions' corresponding to each image in the table, enable
154	  this option.
155
156	  You will still need the parsing functions to be called by the driver
157	  for your particular device. It won't happen automatically. The
158	  SA1100 map driver (CONFIG_MTD_SA1100) has an option for this, for
159	  example.
160
161if MTD_REDBOOT_PARTS
162
163config MTD_REDBOOT_DIRECTORY_BLOCK
164	int "Location of RedBoot partition table"
165	default "-1"
166	help
167	  This option is the Linux counterpart to the
168	  CYGNUM_REDBOOT_FIS_DIRECTORY_BLOCK RedBoot compile time
169	  option.
170
171	  The option specifies which Flash sectors holds the RedBoot
172	  partition table.  A zero or positive value gives an absolute
173	  erase block number. A negative value specifies a number of
174	  sectors before the end of the device.
175
176	  For example "2" means block number 2, "-1" means the last
177	  block and "-2" means the penultimate block.
178
179config MTD_REDBOOT_PARTS_UNALLOCATED
180	bool "Include unallocated flash regions"
181	help
182	  If you need to register each unallocated flash region as a MTD
183	  'partition', enable this option.
184
185config MTD_REDBOOT_PARTS_READONLY
186	bool "Force read-only for RedBoot system images"
187	help
188	  If you need to force read-only for 'RedBoot', 'RedBoot Config' and
189	  'FIS directory' images, enable this option.
190
191endif # MTD_REDBOOT_PARTS
192
193config MTD_QCOMSMEM_PARTS
194	tristate "Qualcomm SMEM flash partition parser"
195	depends on QCOM_SMEM
196	help
197	  This provides support for parsing partitions from Shared Memory (SMEM)
198	  for NAND and SPI flash on Qualcomm platforms.
199
200config MTD_SERCOMM_PARTS
201	tristate "Sercomm partition table parser"
202	depends on MTD && RALINK
203	help
204	  This provides partitions table parser for devices with Sercomm
205	  partition map. This partition table contains real partition
206	  offsets, which may differ from device to device depending on the
207	  number and location of bad blocks on NAND.
208