9890144d4161117a4388c132acb0d515a2bcab6d
[platform/kernel/u-boot.git] / lib / efi_loader / Kconfig
1 config EFI_LOADER
2         bool "Support running UEFI applications"
3         depends on OF_LIBFDT && ( \
4                 ARM && (SYS_CPU = arm1136 || \
5                         SYS_CPU = arm1176 || \
6                         SYS_CPU = armv7   || \
7                         SYS_CPU = armv8)  || \
8                 X86 || RISCV || SANDBOX)
9         # We need EFI_STUB_64BIT to be set on x86_64 with EFI_STUB
10         depends on !EFI_STUB || !X86_64 || EFI_STUB_64BIT
11         # We need EFI_STUB_32BIT to be set on x86_32 with EFI_STUB
12         depends on !EFI_STUB || !X86 || X86_64 || EFI_STUB_32BIT
13         default y if !ARM || SYS_CPU = armv7 || SYS_CPU = armv8
14         select LIB_UUID
15         select HAVE_BLOCK_DEVICE
16         select REGEX
17         imply CFB_CONSOLE_ANSI
18         imply USB_KEYBOARD_FN_KEYS
19         imply VIDEO_ANSI
20         help
21           Select this option if you want to run UEFI applications (like GNU
22           GRUB or iPXE) on top of U-Boot. If this option is enabled, U-Boot
23           will expose the UEFI API to a loaded application, enabling it to
24           reuse U-Boot's device drivers.
25
26 if EFI_LOADER
27
28 config EFI_GET_TIME
29         bool "GetTime() runtime service"
30         depends on DM_RTC
31         default y
32         help
33           Provide the GetTime() runtime service at boottime. This service
34           can be used by an EFI application to read the real time clock.
35
36 config EFI_SET_TIME
37         bool "SetTime() runtime service"
38         depends on EFI_GET_TIME
39         default n
40         help
41           Provide the SetTime() runtime service at boottime. This service
42           can be used by an EFI application to adjust the real time clock.
43
44 config EFI_DEVICE_PATH_TO_TEXT
45         bool "Device path to text protocol"
46         default y
47         help
48           The device path to text protocol converts device nodes and paths to
49           human readable strings.
50
51 config EFI_LOADER_HII
52         bool "HII protocols"
53         default y
54         help
55           The Human Interface Infrastructure is a complicated framework that
56           allows UEFI applications to draw fancy menus and hook strings using
57           a translation framework.
58
59           U-Boot implements enough of its features to be able to run the UEFI
60           Shell, but not more than that.
61
62 config EFI_UNICODE_COLLATION_PROTOCOL2
63         bool "Unicode collation protocol"
64         default y
65         help
66           The Unicode collation protocol is used for lexical comparisons. It is
67           required to run the UEFI shell.
68
69 if EFI_UNICODE_COLLATION_PROTOCOL2
70
71 config EFI_UNICODE_CAPITALIZATION
72         bool "Support Unicode capitalization"
73         default y
74         help
75           Select this option to enable correct handling of the capitalization of
76           Unicode codepoints in the range 0x0000-0xffff. If this option is not
77           set, only the the correct handling of the letters of the codepage
78           used by the FAT file system is ensured.
79
80 config EFI_UNICODE_COLLATION_PROTOCOL
81         bool "Deprecated version of the Unicode collation protocol"
82         default n
83         help
84           In EFI 1.10 a version of the Unicode collation protocol using ISO
85           639-2 language codes existed. This protocol is not part of the UEFI
86           specification any longer. Unfortunately it is required to run the
87           UEFI Self Certification Test (SCT) II, version 2.6, 2017.
88
89           Choose this option for testing only. It is bound to be removed.
90
91 endif
92
93 config EFI_LOADER_BOUNCE_BUFFER
94         bool "EFI Applications use bounce buffers for DMA operations"
95         depends on ARM64
96         default n
97         help
98           Some hardware does not support DMA to full 64bit addresses. For this
99           hardware we can create a bounce buffer so that payloads don't have to
100           worry about platform details.
101
102 config EFI_PLATFORM_LANG_CODES
103         string "Language codes supported by firmware"
104         default "en-US"
105         help
106           This value is used to initialize the PlatformLangCodes variable. Its
107           value is a semicolon (;) separated list of language codes in native
108           RFC 4646 format, e.g. "en-US;de-DE". The first language code is used
109           to initialize the PlatformLang variable.
110
111 config EFI_HAVE_RUNTIME_RESET
112         # bool "Reset runtime service is available"
113         bool
114         default y
115         depends on ARCH_BCM283X || FSL_LAYERSCAPE || PSCI_RESET || SYSRESET_X86
116
117 config EFI_GRUB_ARM32_WORKAROUND
118         bool "Workaround for GRUB on 32bit ARM"
119         default y
120         depends on ARM && !ARM64
121         help
122           GRUB prior to version 2.04 requires U-Boot to disable caches. This
123           workaround currently is also needed on systems with caches that
124           cannot be managed via CP15.
125
126 config EFI_RNG_PROTOCOL
127         bool "EFI_RNG_PROTOCOL support"
128         depends on DM_RNG
129         help
130           Provide a EFI_RNG_PROTOCOL implementation using the hardware random
131           number generator of the platform.
132
133 config EFI_LOAD_FILE2_INITRD
134         bool "EFI_FILE_LOAD2_PROTOCOL for Linux initial ramdisk"
135         default n
136         help
137           Expose a EFI_FILE_LOAD2_PROTOCOL that the Linux UEFI stub can
138           use to load the initial ramdisk. Once this is enabled using
139           initrd=<ramdisk> will stop working.
140
141 config EFI_INITRD_FILESPEC
142         string "initramfs path"
143         default "host 0:1 initrd"
144         depends on EFI_LOAD_FILE2_INITRD
145         help
146           Full path of the initramfs file, e.g. mmc 0:2 initramfs.cpio.gz.
147
148 endif