| .. 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 */ |