Based on kernel version 6.13
. Page generated on 2025-01-21 08:20 EST
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | .. SPDX-License-Identifier: GPL-2.0 ======================= Booting Linux/LoongArch ======================= :Author: Yanteng Si <siyanteng@loongson.cn> :Date: 18 Nov 2022 Information passed from BootLoader to kernel ============================================ LoongArch supports ACPI and FDT. The information that needs to be passed to the kernel includes the memmap, the initrd, the command line, optionally the ACPI/FDT tables, and so on. The kernel is passed the following arguments on `kernel_entry` : - a0 = efi_boot: `efi_boot` is a flag indicating whether this boot environment is fully UEFI-compliant. - a1 = cmdline: `cmdline` is a pointer to the kernel command line. - a2 = systemtable: `systemtable` points to the EFI system table. All pointers involved at this stage are in physical addresses. Header of Linux/LoongArch kernel images ======================================= Linux/LoongArch kernel images are EFI images. Being PE files, they have a 64-byte header structured like:: u32 MZ_MAGIC /* "MZ", MS-DOS header */ u32 res0 = 0 /* Reserved */ u64 kernel_entry /* Kernel entry point */ u64 _end - _text /* Kernel image effective size */ u64 load_offset /* Kernel image load offset from start of RAM */ u64 res1 = 0 /* Reserved */ u64 res2 = 0 /* Reserved */ u64 res3 = 0 /* Reserved */ u32 LINUX_PE_MAGIC /* Magic number */ u32 pe_header - _head /* Offset to the PE header */ |