ArmVirtPkg: Move PlatformBootManagerLib to OvmfPkg
Moved the PlatformBootManagerLib to OvmfPkg and renamed to PlatformBootManagerLibLight for easy use by other ARCH. Build-tested only (with "ArmVirtQemu.dsc and OvmfPkgX64.dsc"). BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=4663 Cc: Ard Biesheuvel <ardb+tianocore@kernel.org> Cc: Laszlo Ersek <lersek@redhat.com> Cc: Leif Lindholm <quic_llindhol@quicinc.com> Cc: Sami Mujawar <sami.mujawar@arm.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Lazlo Ersek <lersek@redhat.com> Signed-off-by: Chao Li <lichao@loongson.cn> Reviewed-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
77
OvmfPkg/Library/PlatformBootManagerLibLight/QemuKernel.c
Normal file
77
OvmfPkg/Library/PlatformBootManagerLibLight/QemuKernel.c
Normal file
@@ -0,0 +1,77 @@
|
||||
/** @file
|
||||
Try to load an EFI-stubbed ARM Linux kernel from QEMU's fw_cfg.
|
||||
|
||||
This implementation differs from OvmfPkg/Library/LoadLinuxLib. An EFI
|
||||
stub in the subject kernel is a hard requirement here.
|
||||
|
||||
Copyright (C) 2014-2016, Red Hat, Inc.
|
||||
|
||||
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||
**/
|
||||
|
||||
#include <Library/QemuLoadImageLib.h>
|
||||
#include <Library/ReportStatusCodeLib.h>
|
||||
|
||||
#include "PlatformBm.h"
|
||||
|
||||
//
|
||||
// The entry point of the feature.
|
||||
//
|
||||
|
||||
/**
|
||||
Download the kernel, the initial ramdisk, and the kernel command line from
|
||||
QEMU's fw_cfg. Construct a minimal SimpleFileSystem that contains the two
|
||||
image files, and load and start the kernel from it.
|
||||
|
||||
The kernel will be instructed via its command line to load the initrd from
|
||||
the same Simple FileSystem.
|
||||
|
||||
@retval EFI_NOT_FOUND Kernel image was not found.
|
||||
@retval EFI_OUT_OF_RESOURCES Memory allocation failed.
|
||||
@retval EFI_PROTOCOL_ERROR Unterminated kernel command line.
|
||||
|
||||
@return Error codes from any of the underlying
|
||||
functions. On success, the function doesn't
|
||||
return.
|
||||
**/
|
||||
EFI_STATUS
|
||||
EFIAPI
|
||||
TryRunningQemuKernel (
|
||||
VOID
|
||||
)
|
||||
{
|
||||
EFI_STATUS Status;
|
||||
EFI_HANDLE KernelImageHandle;
|
||||
|
||||
Status = QemuLoadKernelImage (&KernelImageHandle);
|
||||
if (EFI_ERROR (Status)) {
|
||||
return Status;
|
||||
}
|
||||
|
||||
//
|
||||
// Signal the EFI_EVENT_GROUP_READY_TO_BOOT event.
|
||||
//
|
||||
EfiSignalEventReadyToBoot ();
|
||||
|
||||
REPORT_STATUS_CODE (
|
||||
EFI_PROGRESS_CODE,
|
||||
(EFI_SOFTWARE_DXE_BS_DRIVER | EFI_SW_DXE_BS_PC_READY_TO_BOOT_EVENT)
|
||||
);
|
||||
|
||||
//
|
||||
// Start the image.
|
||||
//
|
||||
Status = QemuStartKernelImage (&KernelImageHandle);
|
||||
if (EFI_ERROR (Status)) {
|
||||
DEBUG ((
|
||||
DEBUG_ERROR,
|
||||
"%a: QemuStartKernelImage(): %r\n",
|
||||
__func__,
|
||||
Status
|
||||
));
|
||||
}
|
||||
|
||||
QemuUnloadKernelImage (KernelImageHandle);
|
||||
|
||||
return Status;
|
||||
}
|
Reference in New Issue
Block a user