2014-10-17 13:50:37 +00:00
|
|
|
.\" Copyright (c) 2014 The FreeBSD Foundation
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2020-12-29 12:08:19 +08:00
|
|
|
.Dd May 9, 2020
|
2014-10-17 13:50:37 +00:00
|
|
|
.Dt UEFI 8
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm UEFI
|
|
|
|
.Nd Unified Extensible Firmware Interface bootstrapping procedures
|
|
|
|
.Sh DESCRIPTION
|
2014-10-17 18:16:40 +00:00
|
|
|
The
|
2014-10-17 13:50:37 +00:00
|
|
|
.Nm
|
|
|
|
Unified Extensible Firmware Interface provides boot- and run-time services
|
2014-10-17 18:16:40 +00:00
|
|
|
to operating systems.
|
2014-10-17 13:50:37 +00:00
|
|
|
.Nm
|
|
|
|
is a replacement for the legacy BIOS on the i386 and amd64 CPU architectures,
|
2017-10-23 20:32:18 +00:00
|
|
|
and is also used on arm, arm64 and ia64.
|
2014-10-17 13:50:37 +00:00
|
|
|
.Pp
|
2018-01-24 21:20:24 +00:00
|
|
|
The UEFI specification is the successor to the Extensible Firmware Interface
|
|
|
|
(EFI) specification.
|
|
|
|
The terms are often used interchangeably.
|
|
|
|
.Pp
|
2014-10-17 13:50:37 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
boot process loads system bootstrap code located in an EFI System Partition
|
|
|
|
(ESP).
|
2014-10-17 18:16:40 +00:00
|
|
|
The ESP is a GPT or MBR partition with a specific identifier that contains an
|
2014-10-17 13:50:37 +00:00
|
|
|
.Xr msdosfs 5
|
|
|
|
FAT file system with a specified file hierarchy.
|
|
|
|
.Bl -column -offset indent ".Sy Partition Scheme" ".Sy ESP Identifier"
|
|
|
|
.It Sy "Partition Scheme" Ta Sy "ESP Identifier"
|
|
|
|
.It GPT Ta C12A7328-F81F-11D2-BA4B-00A0C93EC93B
|
|
|
|
.It MBR Ta 0xEF
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
boot process proceeds as follows:
|
|
|
|
.Bl -enum -offset indent -compact
|
|
|
|
.It
|
|
|
|
.Nm
|
|
|
|
firmware runs at power up and searches for an OS loader in the EFI system
|
|
|
|
partition.
|
|
|
|
The path to the loader may be set by an EFI environment variable.
|
2018-01-25 14:36:47 +00:00
|
|
|
If not set, an architecture-specific default is used.
|
|
|
|
.Bl -column -offset indent "Architecture" "Default Path"
|
|
|
|
.It Sy Architecture Ta Sy Default Path
|
|
|
|
.It amd64 Ta Pa /EFI/BOOT/BOOTX64.EFI
|
2020-05-09 14:19:29 +00:00
|
|
|
.It arm Ta Pa /EFI/BOOT/BOOTARM.EFI
|
2018-01-25 14:36:47 +00:00
|
|
|
.It arm64 Ta Pa /EFI/BOOT/BOOTAA64.EFI
|
|
|
|
.El
|
|
|
|
.Pp
|
2014-10-17 13:50:37 +00:00
|
|
|
The default
|
|
|
|
.Nm
|
|
|
|
boot configuration for
|
|
|
|
.Fx
|
|
|
|
installs
|
2018-12-20 19:39:37 +00:00
|
|
|
.Pa loader.efi
|
2018-01-25 14:36:47 +00:00
|
|
|
in the default path.
|
2014-10-17 13:50:37 +00:00
|
|
|
.It
|
2018-12-20 19:39:37 +00:00
|
|
|
.Pa loader.efi
|
2016-02-11 01:30:43 +00:00
|
|
|
reads boot configuration from
|
|
|
|
.Pa /boot.config
|
|
|
|
or
|
|
|
|
.Pa /boot/config .
|
|
|
|
.It
|
2018-12-20 19:39:37 +00:00
|
|
|
.Pa loader.efi
|
2016-02-11 02:02:01 +00:00
|
|
|
searches partitions of type
|
|
|
|
.Li freebsd-ufs
|
|
|
|
and
|
|
|
|
.Li freebsd-zfs
|
|
|
|
for
|
|
|
|
.Pa loader.efi .
|
|
|
|
The search begins with partitions on the device from which
|
2018-12-20 19:39:37 +00:00
|
|
|
.Pa loader.efi
|
2016-02-11 02:02:01 +00:00
|
|
|
was loaded, and continues with other available partitions.
|
2016-02-11 14:45:18 +00:00
|
|
|
If both
|
|
|
|
.Li freebsd-ufs
|
|
|
|
and
|
|
|
|
.Li freebsd-zfs
|
|
|
|
partitions exist on the same device the
|
|
|
|
.Li freebsd-zfs
|
|
|
|
partition is preferred.
|
2014-10-17 13:50:37 +00:00
|
|
|
.It
|
|
|
|
.Pa loader.efi
|
|
|
|
loads and boots the kernel, as described in
|
|
|
|
.Xr loader 8 .
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Xr vt 4
|
|
|
|
system console is automatically selected when booting via
|
|
|
|
.Nm .
|
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width /boot/loader -compact
|
|
|
|
.Nm
|
|
|
|
bootstrap
|
|
|
|
.It Pa /boot/loader.efi
|
|
|
|
Final stage bootstrap
|
|
|
|
.It Pa /boot/kernel/kernel
|
|
|
|
default kernel
|
|
|
|
.It Pa /boot/kernel.old/kernel
|
|
|
|
typical non-default kernel (optional)
|
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr vt 4 ,
|
2016-02-11 01:30:43 +00:00
|
|
|
.Xr boot.config 5 ,
|
2014-10-17 13:50:37 +00:00
|
|
|
.Xr msdosfs 5 ,
|
|
|
|
.Xr boot 8 ,
|
2018-01-24 21:26:01 +00:00
|
|
|
.Xr efibootmgr 8 ,
|
|
|
|
.Xr efidp 8 ,
|
|
|
|
.Xr efivar 8 ,
|
2015-08-12 11:56:19 +00:00
|
|
|
.Xr gpart 8 ,
|
2015-02-26 09:16:36 +00:00
|
|
|
.Xr uefisign 8
|
2014-10-17 13:50:37 +00:00
|
|
|
.Sh HISTORY
|
2018-01-24 21:11:35 +00:00
|
|
|
EFI boot support for the ia64 architecture first appeared in
|
|
|
|
.Fx 5.0 .
|
2014-10-17 13:50:37 +00:00
|
|
|
.Nm
|
2018-01-24 21:11:35 +00:00
|
|
|
boot support for amd64 first appeared in
|
|
|
|
.Fx 10.1
|
|
|
|
and for arm64 in
|
|
|
|
.Fx 11.0 .
|
2014-10-17 18:16:40 +00:00
|
|
|
.Sh CAVEATS
|
|
|
|
EFI environment variables are not supported by
|
|
|
|
.Xr loader 8
|
|
|
|
or the kernel.
|