summaryrefslogtreecommitdiff
path: root/arch/arm/mach-imx/Kconfig
blob: 0616b05a0540037a8181cd8d97bbf34d3aa1e78e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
config MACH_IMX
	bool

config HAS_CAAM
	bool

config IMX_CONFIG
	string "DCD script to use"
	depends on MACH_IMX
	default "arch/arm/mach-imx/spl_sd.cfg"

config IMX_OPTEE
	bool "Support OP-TEE"
	help
	 Enable support for OP-TEE

config ROM_UNIFIED_SECTIONS
	bool

config SYSCOUNTER_TIMER
	bool

config GPT_TIMER
	bool

config IMX_RDC
	bool "i.MX Resource domain controller driver"
	depends on ARCH_MX6 || ARCH_MX7
	help
	  i.MX Resource domain controller is used to assign masters
	  and peripherals to differet domains. This can be used to
	  isolate resources.

config IMX_BOOTAUX
	bool "Support boot auxiliary core"
	depends on ARCH_MX7 || ARCH_MX6 || ARCH_VF610 || ARCH_IMX8 || ARCH_IMX8M
	help
	  bootaux [addr] to boot auxiliary core.

config IMX_MODULE_FUSE
	bool "i.MX Module Fuse"
	depends on ARCH_MX6
	help
	  i.MX module fuse to runtime disable some driver, including
	  Linux OS device node.

config IMX_VSERVICE_SHARED_BUFFER
	hex "Define the buffer address used for virtual service"
	depends on IMX_VSERVICE
	help
	  IMX virtual service will use this buffer for exchanging data with remote core.

config IMX_VSERVICE_SHARED_BUFFER_SIZE
	hex "Define the size of buffer address used for virtual service"
	default 0x400000
	depends on IMX_VSERVICE
	help
	  The buffer size for IMX virtual service needs enough large to fit all possible message.

config IMX_VSERVICE
	bool
    select MISC
    select IMX_M4_MU
	help
	  This enables imx virtual service provides framework for imx virtual driver working.

config USE_IMXIMG_PLUGIN
	bool "Use imximage plugin code"
	depends on ARCH_MX7 || ARCH_MX6 || ARCH_MX7ULP
	help
	  i.MX6/7 supports DCD and Plugin. Enable this configuration
	  to use Plugin, otherwise DCD will be used.

config IMX_HAB
	bool "Support i.MX HAB features"
	depends on ARCH_MX7 || ARCH_MX6 || ARCH_MX5 || ARCH_IMX8M || ARCH_MX7ULP
	select FSL_CAAM if HAS_CAAM
	imply CMD_DEKBLOB if HAS_CAAM
	imply CMD_PROVISION_KEY if HAS_CAAM
	help
	  This option enables the support for secure boot (HAB).
	  See doc/imx/habv4/* for more details.

config CSF_SIZE
	hex "Maximum size for Command Sequence File (CSF) binary"
	depends on IMX_HAB
	default 0x2000 if ARCH_IMX8M
	default 0x2060
	help
	  Define the maximum size for Command Sequence File (CSF) binary
	  this information is used to define the image boot data.

config CMD_BMODE
	bool "Support the 'bmode' command"
	default y
	depends on ARCH_MX7 || ARCH_MX6 || ARCH_MX5
	help
	  This enables the 'bmode' (bootmode) command for forcing
	  a boot from specific media.

	  This is useful for forcing the ROM's usb downloader to
	  activate upon a watchdog reset which is nice when iterating
	  on U-Boot.  Using the reset button or running bmode normal
	  will set it back to normal.  This command currently
	  supports i.MX53 and i.MX6.

config CMD_DEKBLOB
	bool "Support the 'dek_blob' command"
	select IMX_CAAM_DEK_ENCAP if ARCH_MX6 || ARCH_MX7 || ARCH_MX7ULP
	select IMX_OPTEE_DEK_ENCAP if ARCH_IMX8M
	select IMX_SECO_DEK_ENCAP if ARCH_IMX8
	help
	  This enables the 'dek_blob' command which is used with the
	  Freescale secure boot mechanism. This command encapsulates and
	  creates a blob of data. See also CMD_BLOB and doc/imx/habv4/* for
	  more information.

config IMX_CAAM_DEK_ENCAP
	select FSL_BLOB
	bool "Support the DEK blob encapsulation with CAAM U-Boot driver"
	help
	  This enables the DEK blob encapsulation with the U-Boot CAAM driver.
	  This option is only available on imx6, imx7 and imx7ulp.

config IMX_OPTEE_DEK_ENCAP
	select TEE
	select OPTEE
	bool "Support the DEK blob encapsulation with OP-TEE"
	help
	  This enabled the DEK blob encapsulation with OP-TEE. The communication
	  with OP-TEE is done through a SMC call and OP-TEE shared memory. This
	  option is available on imx8mm.

config IMX_SECO_DEK_ENCAP
	bool "Support the DEK blob encapsulation with SECO"
	help
	  This enabled the DEK blob encapsulation with the SECO API. This option
	  is only available on imx8.

config CMD_PRIBLOB
	bool "Support the set_priblob_bitfield command"
	depends on HAS_CAAM && IMX_HAB
	help
	  This option enables the priblob command which can be used
		to set the priblob setting to 0x3.

config CMD_HDMIDETECT
	bool "Support the 'hdmidet' command"
	help
	  This enables the 'hdmidet' command which detects if an HDMI monitor
	  is connected.

config CMD_NANDBCB
	bool "i.MX6 NAND Boot Control Block(BCB) command"
	depends on MTD_RAW_NAND && CMD_MTDPARTS
	select BCH if MX6UL || MX6ULL
	default y if ((ARCH_MX6 || ARCH_MX7 || ARCH_IMX8M || ARCH_IMX8) && NAND_MXS)
	help
	  Unlike normal 'nand write/erase' commands, this command update
	  Boot Control Block(BCB) for i.MX6 platform NAND IP's.

	  This is similar to kobs-ng, which is used in Linux as separate
	  rootfs package.

config CMD_QSPIHDR
	bool "Q(F)SPI Boot Config Header command"
	depends on DM_SPI_FLASH
	default y
	help
	  Boot from Q(F)SPI need a boot config header, this command can
	  help to check if header already exists or add one if not.

config FSL_MFGPROT
	bool "Support the 'mfgprot' command"
	depends on IMX_HAB || AHAB_BOOT
	select IMX_CAAM_MFG_PROT if (ARCH_MX7 || ARCH_IMX8M)
	select IMX_SECO_MFG_PROT if ARCH_IMX8
	help
	  This option enables the manufacturing protection command
	  which can be used has a protection feature for Manufacturing
	  process. With this tool is possible to authenticate the
	  chip to the OEM's server.

config IMX_CAAM_MFG_PROT
	bool "Support the manufacturing protection with CAAM U-Boot driver"
	help
	  This enables the manufacturing protection feature with the U-Boot
	  CAAM driver. This option is only available on iMX7D/S.

config IMX_SECO_MFG_PROT
	bool "Support the manufacturing protection with SECO API"
	help
	  This enables the manufacturing protection feature with the SECO API.
	  This option is only available on iMX8/8x series.

config DBG_MONITOR
	bool "Enable the AXI debug monitor"
	depends on ARCH_MX6 || ARCH_MX7
	help
	  This option enables the debug monitor which prints out last
	  failed AXI access info when system reboot is caused by AXI
	  access failure.

config NXP_BOARD_REVISION
	bool "Read NXP board revision from fuses"
	depends on ARCH_MX6 || ARCH_MX7
	help
	  NXP boards based on i.MX6/7 contain the board revision information
	  stored in the fuses. Select this option if you want to be able to
	  retrieve the board revision information.

config FLASH_MCUFIRMWARE_SUPPORT
	bool "Enable mcu firmware flash support"
	depends on ARCH_MX7ULP || ARCH_IMX8M
	help
	  This enables the mcu firmware flash support for some SOCs.

config DDRMC_VF610_CALIBRATION
	bool "Enable DDRMC (DDR3) on-chip calibration"
	depends on ARCH_VF610
	help
	  Vybrid (vf610) SoC provides some on-chip facility to tune the DDR3
	  memory parameters. Select this option if you want to calculate them
	  at boot time.
	  NOTE:
	  NXP does NOT recommend to perform this calibration at each boot. One
	  shall perform it on a new PCB and then use those values to program
	  the ddrmc_cr_setting on relevant board file.

config SPL_IMX_ROMAPI_LOADADDR
	hex "Default load address to load image through ROM API"
	depends on IMX8MN || IMX8MP || IMX8ULP || IMX9

config IMX_DCD_ADDR
	hex "DCD Blocks location on the image"
	default 0x00910000 if (!ARCH_MX7ULP && !ARCH_MX7)
	default 0x00911000 if ARCH_MX7
	default 0x2f010000 if ARCH_MX7ULP
	help
	  Indicates where the Device Configuration Data, a binary table used by
	  the ROM code to configure the device at early boot stage, is located.
	  This information is shared with the user via mkimage -l just so the
	  image can be signed.

config SPL_LOAD_IMX_CONTAINER
	bool "Enable SPL loading U-Boot as a i.MX Container image"
	depends on SPL
	help
	  This is to let SPL could load i.MX Container image

config IMX_CONTAINER_CFG
	string "i.MX Container config file"
	depends on SPL
	help
	  This is to specific the cfg file for generating container
	  image which will be loaded by SPL.

config CMD_PROVISION_KEY
	bool "Support to provision a encrypted key as black blob"
	depends on IMX8MM || IMX8MN
	select IMX_CAAM_MFG_PROT
	help
	  reads manufacturing protection public key(MPPUBK).
	  derive PKEK = sha256(MPPUBK).
	  read encrypted key and decrypt it using PKEK.
	  generate black blob of decrypted key, add 20 bytes TAG to black blob.

config ANDROID_SUPPORT
	bool "Standard Android features support"
	default n
	select FSL_FASTBOOT
	select FASTBOOT_LOCK
	select BCB_SUPPORT
	select ANDROID_RECOVERY
	select SUPPORT_RAW_INITRD
	select LIBAVB
	select AVB_SUPPORT

config ANDROID_AUTO_SUPPORT
	bool "Android Automotive features support"
	default n
	select FSL_FASTBOOT
	select FASTBOOT_LOCK
	select BCB_SUPPORT
	select ANDROID_RECOVERY
	select SUPPORT_RAW_INITRD
	select LIBAVB
	select AVB_SUPPORT

config ANDROID_THINGS_SUPPORT
	bool "Android Things features support"
	default n
	select FSL_FASTBOOT
	select FASTBOOT_LOCK
	select BCB_SUPPORT
	select ANDROID_RECOVERY
	select SUPPORT_RAW_INITRD
	select LIBAVB
	select AVB_SUPPORT

config AT_AUTHENTICATE_UNLOCK
	bool "Enable authenticate unlock for Android Things devices"
	depends on ANDROID_THINGS_SUPPORT

config ANDROID_AB_SUPPORT
	bool "Android A/B slots support"
	depends on ANDROID_SUPPORT || ANDROID_AUTO_SUPPORT || ANDROID_THINGS_SUPPORT
	default n
	select SYSTEM_RAMDISK_SUPPORT

config SYSTEM_RAMDISK_SUPPORT
	bool "Support build ramdisk in system image"
	default n

menu "TRUSTY OS Support"

config IMX_TRUSTY_OS
	bool "Support Trusty OS related feature"
	select SYS_ARM_CACHE_WRITEALLOC
	select CMD_MMC_RPMB
	select SUPPORT_EMMC_RPMB
	select SPL_SUPPORT_EMMC_RPMB
	select SPL_MMC_WRITE

config TRUSTY_UNLOCK_PERMISSION
	bool "Support unlock permission protection in trusty"
	default y
	depends on IMX_TRUSTY_OS

config LOAD_KEY_FROM_RPMB
	bool "Support load AVB public key from RPMB storage"
	default y
	depends on IMX_TRUSTY_OS

config ID_ATTESTATION
	bool "Support device ID attestation"
	default y
	depends on IMX_TRUSTY_OS

config ATTESTATION_ID_BRAND
	string "brand name"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_DEVICE
	string "device name"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_PRODUCT
	string "product name"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_IMEI
	string "IMEI id"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_MEID
	string "MEID id"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_MANUFACTURER
	string "manufacture name"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config ATTESTATION_ID_MODEL
	string "model name"
	depends on IMX_TRUSTY_OS && ID_ATTESTATION
	default ""

config GENERATE_MPPUBK
	bool "Enable manufacturing production public key extraction"
	default y
	depends on IMX_TRUSTY_OS

config SECURE_UNLOCK
	bool "Enable secure unlock for Android devices, it can only be enabled on HAB closed board"
	depends on IMX_TRUSTY_OS

endmenu

config APPEND_BOOTARGS
	bool "Append bootargs support"

config DUAL_BOOTLOADER
	bool "Enable dual bootloader support"
	select SPL_MMC
	select SPL_MMC_WRITE
	help
	  Enable A/B bootloader select in SPL.

config ANDROID_DYNAMIC_PARTITION
	bool "Support to boot up Android with system image in logical partitions"

config VIRTUAL_AB_SUPPORT
	bool "Support virtual AB update"
	select ANDROID_DYNAMIC_PARTITION

config BOOTLOADER_MENU
	bool "Enable bootloader menu for android device"
	help
	bootloader menu feature for android device.