2023-12-04 10:02:23 +00:00
---
obj: application
2023-12-10 00:57:29 +00:00
arch-wiki: https://wiki.archlinux.org/title/Systemd-boot
2024-12-17 09:56:02 +00:00
rev: 2024-12-17
2023-12-04 10:02:23 +00:00
---
# Systemd Boot
2024-02-12 14:32:44 +00:00
systemd-boot is a simple UEFI boot manager which executes configured EFI images. The default entry is selected by a configured pattern (glob) or an on-screen menu to be navigated via arrow keys. It is included with [systemd ](Systemd.md ), which is installed on an Arch system by default.
2023-12-04 10:02:23 +00:00
2024-02-12 14:32:44 +00:00
It is simple to configure but can only start EFI executables such as the [Linux ](../Linux.md ) kernel EFISTUB, UEFI shell, GRUB, or the [Windows ](../../windows/Windows.md ) Boot Manager.
2023-12-04 10:02:23 +00:00
## Install
Install:
```shell
bootctl install
```
Update:
```shell
bootctl update
```
## Configuration
2024-12-17 09:56:02 +00:00
The loader configuration is stored in the file `_esp_/loader/loader.conf` .
2023-12-04 10:02:23 +00:00
Example:
```
default arch.conf
timeout 4
console-mode max
editor no
```
### Adding loaders
2024-12-17 09:56:02 +00:00
_systemd-boot_ will search for boot menu items in `_esp_/loader/entries/*.conf` .
2023-12-04 10:02:23 +00:00
Values:
- `title` : Name
- `version` : Kernel Version
- `efi` : EFI Executable
- `options` : Kernel Parameter
Example:
`_esp_/loader/entries/arch.conf`
```
title Arch Linux
linux /vmlinuz-linux
initrd /intel-ucode.img
initrd /initramfs-linux.img
options root="LABEL=_arch_os_" rw
```
## Changing Boot
Choosing next boot:
```shell
systemctl reboot --boot-loader-entry=arch-custom.conf
```
Firmware Setup:
```shell
systemctl reboot --firmware-setup
2024-12-17 09:56:02 +00:00
```
## Keybindings
While the menu is shown, the following keys are active:
| Key | Description |
| ------------- | ----------------------------------------------------------------------------------- |
| `Up` / `Down` | Select menu entry |
| `Enter` | Boot the selected entry |
| `d` | select the default entry to boot (stored in a non-volatile EFI variable) |
| `t` / `T` | adjust the timeout (stored in a non-volatile EFI variable) |
| `e` | edit the option line (kernel command line) for this bootup to pass to the EFI image |
| `Q` | quit |
| `v` | show the systemd-boot and UEFI version |
| `P` | print the current configuration to the console |