From 163083fd80d5e4e24fe110a2be1b11c80445206d Mon Sep 17 00:00:00 2001 From: Gerd Hoffmann Date: Thu, 6 Jul 2023 17:31:43 +0200 Subject: [PATCH] OvmfPkg/PlatformBootManagerLib: setup virtio-mmio devices. Add DetectAndPreparePlatformVirtioDevicePath() helper function to setup virtio-mmio devices. Start with virtio-serial support. This makes virtio console usable with microvm. Signed-off-by: Gerd Hoffmann Acked-by: Ard Biesheuvel --- .../PlatformBootManagerLib/BdsPlatform.c | 31 +++++++++++++++++++ .../PlatformBootManagerLib.inf | 1 + 2 files changed, 32 insertions(+) diff --git a/OvmfPkg/Library/PlatformBootManagerLib/BdsPlatform.c b/OvmfPkg/Library/PlatformBootManagerLib/BdsPlatform.c index 8dc2bbf973..88c39df4ae 100644 --- a/OvmfPkg/Library/PlatformBootManagerLib/BdsPlatform.c +++ b/OvmfPkg/Library/PlatformBootManagerLib/BdsPlatform.c @@ -10,6 +10,7 @@ #include #include #include +#include #include #include #include @@ -1236,6 +1237,30 @@ DetectAndPreparePlatformPciDevicePath ( return Status; } +EFI_STATUS +EFIAPI +DetectAndPreparePlatformVirtioDevicePath ( + IN EFI_HANDLE Handle, + IN VOID *Instance, + IN VOID *Context + ) +{ + VIRTIO_DEVICE_PROTOCOL *VirtIo = (VIRTIO_DEVICE_PROTOCOL *)Instance; + + DEBUG ((DEBUG_INFO, "%a:%d: id %d\n", __func__, __LINE__, VirtIo->SubSystemDeviceId)); + + switch (VirtIo->SubSystemDeviceId) { + case 3: + PrepareVirtioSerialDevicePath (Handle); + break; + default: + /* nothing */ + break; + } + + return EFI_SUCCESS; +} + /** Connect the predefined platform default console device. @@ -1256,6 +1281,12 @@ PlatformInitializeConsole ( // VisitAllPciInstances (DetectAndPreparePlatformPciDevicePath); + VisitAllInstancesOfProtocol ( + &gVirtioDeviceProtocolGuid, + DetectAndPreparePlatformVirtioDevicePath, + NULL + ); + PrepareMicrovmDevicePath (); // diff --git a/OvmfPkg/Library/PlatformBootManagerLib/PlatformBootManagerLib.inf b/OvmfPkg/Library/PlatformBootManagerLib/PlatformBootManagerLib.inf index 6b396eac7d..c6ffc1ed9e 100644 --- a/OvmfPkg/Library/PlatformBootManagerLib/PlatformBootManagerLib.inf +++ b/OvmfPkg/Library/PlatformBootManagerLib/PlatformBootManagerLib.inf @@ -75,6 +75,7 @@ [Protocols] gEfiDecompressProtocolGuid gEfiPciRootBridgeIoProtocolGuid + gVirtioDeviceProtocolGuid gEfiS3SaveStateProtocolGuid # PROTOCOL SOMETIMES_CONSUMED gEfiDxeSmmReadyToLockProtocolGuid # PROTOCOL SOMETIMES_PRODUCED gEfiLoadedImageProtocolGuid # PROTOCOL SOMETIMES_PRODUCED