UEFI explained

Unified Extensible Firmware Interface
Abbreviation:UEFI
Status:Published
Year Started:2006
Version:2.10
Version Date:August 29, 2022
Organization:UEFI Forum
Related Standards:ACPI, UEFI Platform Initialization
Predecessor:BIOS on IBM PC compatible computers
Domain:Firmware

Unified Extensible Firmware Interface (UEFI, or as an acronym) is a specification for the firmware architecture of a computing platform. When a computer is powered on, the UEFI-implementation is typically the first that runs, before starting the operating system. Examples include AMI Aptio, Phoenix SecureCore, TianoCore EDK II, InsydeH2O.

UEFI replaces the BIOS which was present in the boot ROM of all personal computers that are IBM PC compatible,[1] although it can provide backwards compatibility with the BIOS using CSM booting. Contrary to its predecessor BIOS which is a de facto standard originally created by IBM as proprietary software, UEFI is an open standard maintained by an industry consortium.

Intel developed the original Extensible Firmware Interface (EFI) specification. The last Intel version of EFI was 1.10 released in 2005. Subsequent versions have been developed as UEFI by the Unified EFI Forum.

UEFI is independent of platform and programming language, but C is used for the reference implementation TianoCore EDKII.

History

The original motivation for EFI came during early development of the first Intel–HP Itanium systems in the mid-1990s. BIOS limitations (such as 16-bit real mode, 1 MB addressable memory space,[2] assembly language programming, and PC AT hardware) had become too restrictive for the larger server platforms Itanium was targeting. The effort to address these concerns began in 1998 and was initially called Intel Boot Initiative. It was later renamed to Extensible Firmware Interface (EFI).

The first open source UEFI implementation, Tiano, was released by Intel in 2004. Tiano has since then been superseded by EDK[3] and EDK II[4] and is now maintained by the TianoCore community.[5]

In July 2005, Intel ceased its development of the EFI specification at version 1.10, and contributed it to the Unified EFI Forum, which has developed the specification as the Unified Extensible Firmware Interface (UEFI). The original EFI specification remains owned by Intel, which exclusively provides licenses for EFI-based products, but the UEFI specification is owned by the UEFI Forum.[6]

Version 2.0 of the UEFI specification was released on 31 January 2006. It added cryptography and security.

Version 2.1 of the UEFI specification was released on 7 January 2007. It added network authentication and the user interface architecture ('Human Interface Infrastructure' in UEFI).

In October 2018, Arm announced Arm ServerReady, a compliance certification program for landing the generic off-the-shelf operating systems and hypervisors on Arm-based servers. The program requires the system firmware to comply with Server Base Boot Requirements (SBBR). SBBR requires UEFI, ACPI and SMBIOS compliance. In October 2020, Arm announced the extension of the program to the edge and IoT market. The new program name is Arm SystemReady. Arm SystemReady defined the Base Boot Requirements (BBR) specification that currently provides three recipes, two of which are related to UEFI: 1) SBBR: which requires UEFI, ACPI and SMBIOS compliance suitable for enterprise level operating environments such as Windows, Red Hat Enterprise Linux, and VMware ESXi; and 2) EBBR: which requires compliance to a set of UEFI interfaces as defined in the Embedded Base Boot Requirements (EBBR) suitable for embedded environments such as Yocto. Many Linux and BSD distros can support both recipes.

In December 2018, Microsoft announced Project Mu, a fork of TianoCore EDK II used in Microsoft Surface and Hyper-V products. The project promotes the idea of firmware as a service.[7]

The latest UEFI specification, version 2.10, was published in August 2022.[8]

Advantages

The interface defined by the EFI specification includes data tables that contain platform information, and boot and runtime services that are available to the OS loader and OS. UEFI firmware provides several technical advantages over a BIOS:[9]

With UEFI, it is possible to store product keys for operating systems such as Windows, on the UEFI firmware of the device.[12] [13] [14] UEFI is required for devices shipping with Windows 8[15] [16] and above.

It is also possible for operating systems to access UEFI configuration data.[17]

Compatibility

Processor compatibility

As of version 2.5, processor bindings exist for Itanium, x86, x86-64, ARM (AArch32) and ARM64 (AArch64).[18] Only little-endian processors can be supported.[19] Unofficial UEFI support is under development for POWERPC64 by implementing TianoCore on top of OPAL,[20] the OpenPOWER abstraction layer, running in little-endian mode.[21] Similar projects exist for MIPS[22] and RISC-V.[23] As of UEFI 2.7, RISC-V processor bindings have been officially established for 32-, 64- and 128-bit modes.[24]

Standard PC BIOS is limited to a 16-bit processor mode and 1 MB of addressable memory space, resulting from the design based on the IBM 5150 that used a 16-bit Intel 8088 processor.[6] [25] In comparison, the processor mode in a UEFI environment can be either 32-bit (IA-32, AArch32) or 64-bit (x86-64, Itanium, and AArch64).[26] 64-bit UEFI firmware implementations support long mode, which allows applications in the preboot environment to use 64-bit addressing to get direct access to all of the machine's memory.[27]

UEFI requires the firmware and operating system loader (or kernel) to be size-matched; that is, a 64-bit UEFI firmware implementation can load only a 64-bit operating system (OS) boot loader or kernel (unless the CSM-based legacy boot is used) and the same applies to 32-bit. After the system transitions from boot services to runtime services, the operating system kernel takes over. At this point, the kernel can change processor modes if it desires, but this bars usage of the runtime services (unless the kernel switches back again). As of version 3.15, the Linux kernel supports 64-bit kernels to be booted on 32-bit UEFI firmware implementations running on x86-64 CPUs, with UEFI handover support from a UEFI boot loader as the requirement.[28] UEFI handover protocol deduplicates the UEFI initialization code between the kernel and UEFI boot loaders, leaving the initialization to be performed only by the Linux kernel's UEFI boot stub.[29] [30]

Disk device compatibility

In addition to the standard PC disk partition scheme that uses a master boot record (MBR), UEFI also works with the GUID Partition Table (GPT) partitioning scheme, which is free from many of the limitations of MBR. In particular, the MBR limits on the number and size of disk partitions (up to four primary partitions per disk, and up to 2 TB per disk) are relaxed.[31] More specifically, GPT allows for a maximum disk and partition size of 8 ZiB .[32] [33]

Linux

Support for GPT in Linux is enabled by turning on the option CONFIG_EFI_PARTITION (EFI GUID Partition Support) during kernel configuration.[34] This option allows Linux to recognize and use GPT disks after the system firmware passes control over the system to Linux.

For reverse compatibility, Linux can use GPT disks in BIOS-based systems for both data storage and booting, as both GRUB 2 and Linux are GPT-aware. Such a setup is usually referred to as BIOS-GPT.[35] As GPT incorporates the protective MBR, a BIOS-based computer can boot from a GPT disk using a GPT-aware boot loader stored in the protective MBR's bootstrap code area. In the case of GRUB, such a configuration requires a BIOS boot partition for GRUB to embed its second-stage code due to absence of the post-MBR gap in GPT partitioned disks (which is taken over by the GPT's Primary Header and Primary Partition Table). Commonly 1 MB in size, this partition's Globally Unique Identifier (GUID) in GPT scheme is and is used by GRUB only in BIOS-GPT setups. From GRUB's perspective, no such partition type exists in case of MBR partitioning. This partition is not required if the system is UEFI-based because no embedding of the second-stage code is needed in that case.[10]

UEFI systems can access GPT disks and boot directly from them, which allows Linux to use UEFI boot methods. Booting Linux from GPT disks on UEFI systems involves creation of an EFI system partition (ESP), which contains UEFI applications such as bootloaders, operating system kernels, and utility software.[36] [37] [38] Such a setup is usually referred to as UEFI-GPT, while ESP is recommended to be at least 512 MB in size and formatted with a FAT32 filesystem for maximum compatibility.[39]

For backward compatibility, some UEFI implementations also support booting from MBR-partitioned disks through the Compatibility Support Module (CSM) that provides legacy BIOS compatibility.[40] In that case, booting Linux on UEFI systems is the same as on legacy BIOS-based systems.

Microsoft Windows

Some of the EFI's practices and data formats mirror those of Microsoft Windows.[41] [42]

The 64-bit versions of Windows Vista SP1 and later and 64-bit versions of Windows 8, 8.1, 10, and 11 can boot from a GPT disk that is larger than 2 TB.

Features

Services

EFI defines two types of services: boot services and runtime services. Boot services are available only while the firmware owns the platform (i.e., before the ExitBootServices call), and they include text and graphical consoles on various devices, and bus, block and file services. Runtime services are still accessible while the operating system is running; they include services such as date, time and NVRAM access.

Graphics Output Protocol (GOP) services
  • The Graphics Output Protocol (GOP) provides runtime services; see also Graphics features section below. The operating system is permitted to directly write to the framebuffer provided by GOP during runtime mode.[43]
    UEFI Memory map services
    SMM services
    ACPI services
    SMBIOS services
    Devicetree services (for RISC processors)
    Variable services
  • UEFI variables provide a way to store data, in particular non-volatile data. Some UEFI variables are shared between platform firmware and operating systems. Variable namespaces are identified by GUIDs, and variables are key/value pairs. For example, UEFI variables can be used to keep crash messages in NVRAM after a crash for the operating system to retrieve after a reboot.
    Time services
  • UEFI provides time services. Time services include support for time zone and daylight saving fields, which allow the hardware real-time clock to be set to local time or UTC.[44] On machines using a PC-AT real-time clock, by default the hardware clock still has to be set to local time for compatibility with BIOS-based Windows,[42] unless using recent versions and an entry in the Windows registry is set to indicate the use of UTC.

    Applications

    Beyond loading an OS, UEFI can run UEFI applications, which reside as files on the EFI system partition. They can be executed from the UEFI Shell, by the firmware's boot manager, or by other UEFI applications. UEFI applications can be developed and installed independently of the original equipment manufacturers (OEMs).

    A type of UEFI application is an OS boot loader such as GRUB, rEFInd, Gummiboot, and Windows Boot Manager, which loads some OS files into memory and executes them. Also, an OS boot loader can provide a user interface to allow the selection of another UEFI application to run. Utilities like the UEFI Shell are also UEFI applications.

    Protocols

    EFI defines protocols as a set of software interfaces used for communication between two binary modules. All EFI drivers must provide services to others via protocols. The EFI Protocols are similar to the BIOS interrupt calls.

    Device drivers

    In addition to standard instruction set architecture-specific device drivers, EFI provides for a ISA-independent device driver stored in non-volatile memory as EFI byte code or EBC. System firmware has an interpreter for EBC images. In that sense, EBC is analogous to Open Firmware, the ISA-independent firmware used in PowerPC-based Apple Macintosh and Sun Microsystems SPARC computers, among others.

    Some architecture-specific (non-EFI Byte Code) EFI drivers for some device types can have interfaces for use by the OS. This allows the OS to rely on EFI for drivers to perform basic graphics and network functions before, and if, operating-system-specific drivers are loaded.

    In other cases, the EFI driver can be filesystem drivers that allow for booting from other types of disk volumes. Examples include efifs for 37 file systems (based on GRUB2 code),[45] used by Rufus for chain-loading NTFS ESPs.[46]

    Graphics features

    The EFI 1.0 specification defined a UGA (Universal Graphic Adapter) protocol as a way to support graphics features. UEFI did not include UGA and replaced it with GOP (Graphics Output Protocol).[47]

    UEFI 2.1 defined a "Human Interface Infrastructure" (HII) to manage user input, localized strings, fonts, and forms (in the HTML sense). These enable original equipment manufacturers (OEMs) or independent BIOS vendors (IBVs) to design graphical interfaces for pre-boot configuration. UEFI uses UTF-16 to encode strings by default.

    Most early UEFI firmware implementations were console-based. Today many UEFI firmware implementations are GUI-based.

    EFI system partition

    See main article: EFI system partition.

    An EFI system partition, often abbreviated to ESP, is a data storage device partition that is used in computers adhering to the UEFI specification. Accessed by the UEFI firmware when a computer is powered up, it stores UEFI applications and the files these applications need to run, including operating system boot loaders. Supported partition table schemes include MBR and GPT, as well as El Torito volumes on optical discs.[48] For use on ESPs, UEFI defines a specific version of the FAT file system, which is maintained as part of the UEFI specification and independently from the original FAT specification, encompassing the FAT32, FAT16 and FAT12 file systems.[49] [50] [51] The ESP also provides space for a boot sector as part of the backward BIOS compatibility.

    Booting

    UEFI booting

    Unlike the legacy PC BIOS, UEFI does not rely on boot sectors, defining instead a boot manager as part of the UEFI specification. When a computer is powered on, the boot manager checks the boot configuration and, based on its settings, then executes the specified OS boot loader or operating system kernel (usually boot loader[52]). The boot configuration is defined by variables stored in NVRAM, including variables that indicate the file system paths to OS loaders or OS kernels.

    OS boot loaders can be automatically detected by UEFI, which enables easy booting from removable devices such as USB flash drives. This automated detection relies on standardized file paths to the OS boot loader, with the path varying depending on the computer architecture. The format of the file path is defined as

    Notes and References

    1. Web site: Solving BIOS Boot Issues with EFI . Michael . Kinney . 1 September 2000 . 14 September 2010 . 47–50 . 23 January 2007 . https://web.archive.org/web/20070123141151/http://systems.cs.colorado.edu/Documentation/IntelDataSheets/xscalemagazine.pdf . dead .
    2. Web site: Memory Map (x86) - OSDev Wiki. 2020-12-11. wiki.osdev.org.
    3. Web site: GitHub - tianocore/Edk: Git mirror of EDK.. GitHub. 19 March 2019.
    4. Web site: GitHub - tianocore/Tianocore.github.io: Tianocore website.. GitHub. 8 August 2019.
    5. Web site: What is TianoCore?.
    6. News: Emulex UEFI Implementation Delivers Industry-leading Features for IBM Systems . Emulex . 14 September 2010.
    7. Web site: Microsoft announces Project Mu, an open-source release of the UEFI core. 20 December 2018.
    8. Web site: Unified Extensible Firmware Interface (UEFI) Specification Version 2.10 . www.uefi.org . August 2022 . 16 Jan 2023.
    9. Web site: UEFI and Windows . Microsoft . 15 September 2009 . 14 September 2010 .
    10. Web site: Installation . 3.4 BIOS installation . 25 September 2013 . GNU GRUB.
    11. Web site: Non-boot disks can use a GPT partition table even with no UEFI bios.
    12. Web site: Using the OA 3.0 Tool on the factory floor . 25 October 2021 .
    13. Web site: OA 3.0 Tool: Command-line and config file syntax . 29 July 2021 .
    14. UEFI pre-boot guidelines and Microsoft® Windows® 8 UEFI Secure Boot for HP Business PCs . live.
    15. Web site: Next-gen boot spec could forever lock Linux off Windows 8 PCS .
    16. Web site: Windows 8 secure boot could complicate Linux installs . 21 September 2011 .
    17. Book: Beyond BIOS: Developing with the Unified Extensible Firmware Interface, Third Edition . 978-1-5015-0569-0 . Zimmer . Vincent . Rothman . Michael . Marisetty . Suresh . 2017 . Walter de Gruyter GmbH & Co KG .
    18. UEFI Specification 2.4, section 2.3
    19. UEFI specification 2.3.1, section 1.8.1.
    20. Web site: GitHub - andreiw/ppc64le-edk2: TianoCore UEFI for OPAL/PowerNV (PPC64/PowerPC64 Little-Endian). GitHub. 3 May 2021.
    21. Web site: Tianocore for OpenPOWER. Firmware Security. 12 October 2015.
    22. Web site: EFI-MIPS. kontais. SourceForge. 3 September 2015 .
    23. Web site: lowRISC · lowRISC.
    24. Web site: Unified Extensible Firmware Interface Specification, Version 2.7. May 2017.
    25. News: LBA explained — Solving the 3TB Problem? . bit-tech . Ben . Hardwidge . 1 June 2010 . 18 June 2010.
    26. News: Ask a BIOS Guy: "Why UEFI" . Intel Architecture Blog . Brian . Richardson . 10 May 2010 . 18 June 2010 . dead . https://web.archive.org/web/20101009214219/http://community.edc.intel.com/t5/New-to-Intel-Architecture-Blog/Ask-a-BIOS-Guy-quot-Why-UEFI-quot/ba-p/2781 . 9 October 2010 .
    27. News: UEFI Momentum — The AMD perspective . https://web.archive.org/web/20140104004546/http://download.microsoft.com/download/5/e/6/5e66b27b-988b-4f50-af3a-c2ff1e62180f/cor-t605_wh08.pptx . PPTX . 4 January 2014 . AMD . Gary . Simpson . 20 September 2014.
    28. Web site: Linux kernel 3.15, Section 1.3. EFI 64-bit kernels can be booted from 32-bit firmware . 8 June 2014 . 15 June 2014 . kernelnewbies.org.
    29. Web site: x86, efi: Handover Protocol . 19 July 2012 . 15 June 2014 . LWN.net.
    30. Web site: Linux kernel documentation: Documentation/efi-stub.txt . 1 February 2014 . 15 June 2014 . kernel.org.
    31. News: FAQ: Drive Partition Limits . UEFI Forum . 5 December 2019.
    32. News: FAQ: Drive Partition Limits . UEFI Forum . 9 June 2010 . 22 March 2013 . https://web.archive.org/web/20130322172831/http://www.uefi.org/learning_center/UEFI_MBR_Limits_v2.pdf . dead .
    33. Web site: Make the most of large drives with GPT and Linux . Roderick W. . Smith . . 3 July 2012 . 25 September 2013.
    34. Web site: block/partitions/Kconfig (3.11.1) . CONFIG_EFI_PARTITION (line #247) . kernel.org . 25 September 2013.
    35. Web site: GRUB . BIOS systems . . 25 September 2013.
    36. Web site: GRUB and the boot process on UEFI-based x86 systems . 14 November 2013 . redhat.com.
    37. Web site: UEFI Booting 64-bit Redhat Enterprise Linux 6 . September 2010 . 14 November 2013 . fpmurphy.com.
    38. Web site: UEFI Bootloaders . 25 September 2013 . archlinux.org.
    39. Web site: Unified Extensible Firmware Interface: EFI System Partition . 25 September 2013 . archlinux.org.
    40. Web site: UEFI system booting from MBR partition table and GRUB legacy . June 2012 . 6 October 2013 . Arch Linux Forums. live. https://web.archive.org/web/20231208223031/https://bbs.archlinux.org/viewtopic.php?id=142637. 2023-12-08.
    41. https://www.cl.cam.ac.uk/~mgk25/mswish/ut-rtc.html IBM PC Real Time Clock should run in UT
    42. Web site: EFI and Linux: The Future Is Here, and It's Awful . https://ghostarchive.org/varchive/youtube/20211113/V2aq5M3Q76U. 2021-11-13 . live. Matthew . Garrett . 19 January 2012 . linux.conf.au 2012 . 2 April 2012.
    43. Web site: What is efifb? — The Linux Kernel documentation. 2020-11-24. www.kernel.org.
    44. UEFI specification, section 7.3
    45. Web site: Free Software EFI Drivers .
    46. Web site: Batard . Pete . pbatard/uefi-ntfs . GitHub . 13 March 2020.
    47. Web site: Intel Embedded Graphics Drivers FAQ: BIOS and firmware . 19 May 2014 . Intel.
    48. Web site: UEFI Specifications (version 2.4 and older) . PDF . Unified EFI, Inc. . June 2013 . 25 September 2013.
    49. Web site: UEFI Specification Version 2.5, Section 12.3 File System Format . April 2015 . 29 May 2015 . uefi.org . PDF . 536, 537 . The file system supported by the Extensible Firmware Interface is based on the FAT file system. EFI defines a specific version of FAT that is explicitly documented and testable. Conformance to the EFI specification and its associate reference documents is the only definition of FAT that needs to be implemented to support EFI. To differentiate the EFI file system from pure FAT, a new partition file system type has been defined..
    50. Web site: Technical Note TN2166: Secrets of the GPT . 6 November 2006 . 6 May 2015 . developer.apple.com.
    51. Web site: UEFI - OSDev Wiki. 2020-09-26. wiki.osdev.org.
    52. Web site: EFISTUB - ArchWiki. 2020-10-27. wiki.archlinux.org.