When you turn on your Linux computer, it goes through a series of phases before prompting you to a login screen for your username or password. During the boot-up process, every Linux distribution goes through four distinct stages.
The booting process consists of four steps, which we will go over in this thread:
• BIOS and UEFI Integrity check (POST)
• Loading of the Boot loader (GRUB2)
• Kernel initialization
• Starting systemd, the parent of all processes
1. BIOS and UEFI Integrity Verification (POST)
First, when the system boots, the BIOS (Basic Input/Output System) or UEFI (Unified Extensible Firmware Interface) program is launched and a Power On Self Test is performed (POST).
This is an integrity check that performs numerous diagnostic tests.
POST validates hardware components and peripherals such as the HDD or SSD, keyboard, RAM, USB ports, and any other hardware. It also performs tests to ensure that the computer is in good working order.
Furthermore, if this test detects an error, an error message will typically appear on the screen, requesting your intervention.
If the test fails to detect the RAM, POST emits a beeping sound; otherwise, the booting process advances to the next stage if the expected hardware is present and functioning properly.
BIOS and UEFI are firmware interfaces that computers use to boot up their operating systems (OS). The two programs, however, take different approaches to storing metadata on and about the drive:
• BIOS uses the Master Boot Record (MBR)
• UEFI uses the GUID Partition Table (GPT)
2. Loading of the Boot loader (GRUB2)
The BIOS or UEFI has now run the POST to check the machine’s status. The BIOS then looks up information about the bootloader and disc partitioning in the MBR (Master Boot Record).
The boot loader in a BIOS system is located in the first sector of the boot device; this is the MBR. It occupies the first 512 bytes of disk space which is typically /dev/sda or /dev/hda depending on the architecture of your drive.
On the other hand, a UEFI system stores all startup data in an .efi file. The file is located on the EFI System Partition, which also houses the bootloader. It should be noted, however, that the MBR can sometimes be found on a Live USB or DVD installation of Linux.
The boot loader, in particular, is a small program that loads the operating system. The boot loader’s primary function is to locate the kernel on the disk, insert it into memory, and execute it with the supplied options.
In Linux, there are four main types of bootloaders: LILO, SYSLINUX, GRUB, and GRUB2.
LILO (Linux Loader) was once one of the most popular Linux boot loaders. However, it has fallen out of favor due to its lack of support for multi-boot environments and UEFI.
Similarly, SYSLINUX is a boot loader for the Linux operating system that runs on a FAT filesystem, similar to that of a Windows system. In a nutshell, its goal is to make the process of installing Linux for the first time as simple as possible.
• ext2
• ext3
• ext4
• FAT
With some limitations, SYSLINUX can also support the Btrfs and XFS filesystems.
GRUB2 stands for GRand Unified Bootloader version 2, it is the most recent and primary bootloader in modern Linux distributions.
• the ability to boot several operating systems
• network-based diskless
• powerful command line interface for interactive configuration
• booting both a graphical and a text-based interfaceGRUB2 has now replaced its predecessor (GRUB), which is now known as GRUB Legacy.
If you’ve upgraded your system a few times, you might notice that different kernel versions are listed.
It also allows you to edit kernel parameters by pressing a combination of keyboard keys.
In addition, in a dual-boot setup with multiple OS installations, the grub menu allows you to choose which OS to boot into. The grub2 configuration file is located in /boot/grub2/grub2.cfg.
The primary goal of GRUB is to load the Linux kernel into the main memory.
[3] Kernel Initialization
The operating system now controls access to our computer resources after passing through BIOS or UEFI, POST, and using a boot loader to start the kernel.
The Linux kernel follows a set procedure in this case:
• decompress itself from its compressed version before undertaking any task
• perform hardware checks
• gain access to vital peripheral hardware
• initializes the /sbin/init program, also known as init.
Init is always the first program to be executed and is assigned the process ID or PID of 1. It’s the init process that spawns various daemons & mounts all partitions that are specified in the /etc/fstab file.
The kernel then mounts the initial RAM disk (initrd) which is a temporary root filesystem until the real root filesystem is mounted. All kernels are located in the `/boot` directory together with the initial RAM disk image.
[4] Starting Systemd
Finally, the kernel loads Systemd, which replaces the old SysV init. Systemd is the mother of all Linux processes, managing tasks such as mounting file systems and starting and stopping services, to name a few.
The /etc/systemd/system/default.target file is used by Systemd to determine the state or target into which the Linux system should boot.
• The default target value for a desktop workstation (with a graphical user interface) is 5, corresponding to run level 5 in the old SystemV init.
• The default target for a server is http://multi-user.target, which corresponds to run level 3 in SysV init.
The systemd targets are broken down as follows:
• http://poweroff.target (runlevel 0) – Power off or Shutdown the system.
• http://rescue.target (runlevel 1) – launches a rescue shell session.
• http://multi-user.target (runlevel 2,3,4) – Configures the system to a non-graphical (console) multi-user system.
• http://graphical.target (runlevel 5) – Configure the system to use a graphical multi-user interface to access network services.
• http://reboot.target (runlevel 6)- reboots the system.
Run the following command to determine the current target on your system:
$ systemctl get-default
You can change targets by entering the following command into the terminal:
$ init runlevel-value
Init 3, for example, configures the system to be non-graphical.
The init 6 command reboots your system, while init 0 turns it off. When switching between these two targets, make sure to use the sudo command.
The boot process is complete when the systemd loads all daemons and sets the target or run level value. At this point, you will be prompted for your username and password, after which you will gain access to your Linux system.
This information should be sufficient to help you understand the Linux booting process.
That’s all! Thank you for getting this far. I hope you find this information useful.