Blame view

Documentation/arm/uefi.rst 2.78 KB
dc7a12bdf   Mauro Carvalho Chehab   docs: arm: conver...
1
2
3
  ================================================
  The Unified Extensible Firmware Interface (UEFI)
  ================================================
e1977464e   Leif Lindholm   doc: arm: add UEF...
4
5
6
7
8
9
10
11
12
13
14
15
16
  UEFI, the Unified Extensible Firmware Interface, is a specification
  governing the behaviours of compatible firmware interfaces. It is
  maintained by the UEFI Forum - http://www.uefi.org/.
  
  UEFI is an evolution of its predecessor 'EFI', so the terms EFI and
  UEFI are used somewhat interchangeably in this document and associated
  source code. As a rule, anything new uses 'UEFI', whereas 'EFI' refers
  to legacy code or specifications.
  
  UEFI support in Linux
  =====================
  Booting on a platform with firmware compliant with the UEFI specification
  makes it possible for the kernel to support additional features:
dc7a12bdf   Mauro Carvalho Chehab   docs: arm: conver...
17

e1977464e   Leif Lindholm   doc: arm: add UEF...
18
19
20
21
22
  - UEFI Runtime Services
  - Retrieving various configuration information through the standardised
    interface of UEFI configuration tables. (ACPI, SMBIOS, ...)
  
  For actually enabling [U]EFI support, enable:
dc7a12bdf   Mauro Carvalho Chehab   docs: arm: conver...
23

e1977464e   Leif Lindholm   doc: arm: add UEF...
24
  - CONFIG_EFI=y
963fabf37   Ard Biesheuvel   efi: efivars: lim...
25
  - CONFIG_EFIVAR_FS=y or m
e1977464e   Leif Lindholm   doc: arm: add UEF...
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
  
  The implementation depends on receiving information about the UEFI environment
  in a Flattened Device Tree (FDT) - so is only available with CONFIG_OF.
  
  UEFI stub
  =========
  The "stub" is a feature that extends the Image/zImage into a valid UEFI
  PE/COFF executable, including a loader application that makes it possible to
  load the kernel directly from the UEFI shell, boot menu, or one of the
  lightweight bootloaders like Gummiboot or rEFInd.
  
  The kernel image built with stub support remains a valid kernel image for
  booting in non-UEFI environments.
  
  UEFI kernel support on ARM
  ==========================
  UEFI kernel support on the ARM architectures (arm and arm64) is only available
  when boot is performed through the stub.
  
  When booting in UEFI mode, the stub deletes any memory nodes from a provided DT.
  Instead, the kernel reads the UEFI memory map.
  
  The stub populates the FDT /chosen node with (and the kernel scans for) the
  following parameters:
dc7a12bdf   Mauro Carvalho Chehab   docs: arm: conver...
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
  
  ==========================  ======   ===========================================
  Name                        Size     Description
  ==========================  ======   ===========================================
  linux,uefi-system-table     64-bit   Physical address of the UEFI System Table.
  
  linux,uefi-mmap-start       64-bit   Physical address of the UEFI memory map,
                                       populated by the UEFI GetMemoryMap() call.
  
  linux,uefi-mmap-size        32-bit   Size in bytes of the UEFI memory map
                                       pointed to in previous entry.
  
  linux,uefi-mmap-desc-size   32-bit   Size in bytes of each entry in the UEFI
                                       memory map.
  
  linux,uefi-mmap-desc-ver    32-bit   Version of the mmap descriptor format.
  ==========================  ======   ===========================================