mirror of
https://github.com/acidanthera/audk.git
synced 2025-05-22 15:30:09 +02:00
Why is the virtio-mmio implementation of the protocol a library, instead of a driver binary? The UEFI driver model would encourage to create a virtio-mmio driver instead of a library. But the reasons why I created a library are: - A virtio-mmio driver would imply an additional protocol that would probably have a single attribute field: typedef struct { PHYSICAL_ADDRESS BaseAddress; } VIRTIO_MMIO_DEVICE_PROTOCOL; - There is no (easy) way to scan the available VirtIo devices on a platform. So, the UEFI firmware for this platform would need a driver to produce instances for every virtio devices it wants to expose in UEFI. A single call to a helper library (ie: VirtioMmioDeviceLib) make the porting easier. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Olivier Martin <olivier.martin@arm.com> v5: - typo fix in VirtioMmioInstallDevice() comment block - plug MmioDevice leak in VirtioMmioUninstallDevice() - return EFI_INVALID_PARAMETER in VirtioMmioGetQueueAddress() if QueueAddress is NULL - VirtioMmioSetQueueSize(): fix return value (it's a status code) - VirtioMmioSetPageSize(): check against EFI_PAGE_SIZE with "if" plus EFI_UNSUPPORTED, rather than ASSERT() - VirtioMmioDeviceWrite(), VirtioMmioDeviceRead(): remove redundant (FieldSize > 8) checks - VirtioMmioDeviceLib.inf: drop UefiDriverEntryPoint library dependency Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Jordan Justen <jordan.l.justen@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14965 6f19259b-4bc3-4df7-8a09-765794883524
67 lines
2.0 KiB
C
67 lines
2.0 KiB
C
/** @file
|
|
|
|
Definitions for the VirtIo MMIO Device Library
|
|
|
|
Copyright (C) 2013, ARM Ltd
|
|
|
|
This program and the accompanying materials are licensed and made available
|
|
under the terms and conditions of the BSD License which accompanies this
|
|
distribution. The full text of the license may be found at
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT
|
|
WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
**/
|
|
|
|
#ifndef _VIRTIO_MMIO_DEVICE_LIB_H_
|
|
#define _VIRTIO_MMIO_DEVICE_LIB_H_
|
|
|
|
/**
|
|
|
|
Initialize VirtIo Device and Install VIRTIO_DEVICE_PROTOCOL protocol
|
|
|
|
@param[in] BaseAddress Base Address of the VirtIo MMIO Device
|
|
|
|
@param[in] Handle Handle of the device the driver should be attached
|
|
to.
|
|
|
|
@retval EFI_SUCCESS The VirtIo Device has been installed
|
|
successfully.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES The function failed to allocate memory required
|
|
by the Virtio MMIO device initialization.
|
|
|
|
@retval EFI_UNSUPPORTED BaseAddress does not point to a VirtIo MMIO
|
|
device.
|
|
|
|
@return Status code returned by InstallProtocolInterface
|
|
Boot Service function.
|
|
|
|
**/
|
|
EFI_STATUS
|
|
VirtioMmioInstallDevice (
|
|
IN PHYSICAL_ADDRESS BaseAddress,
|
|
IN EFI_HANDLE Handle
|
|
);
|
|
|
|
/**
|
|
|
|
Uninstall the VirtIo Device
|
|
|
|
@param[in] Handle Handle of the device where the VirtIo Device protocol
|
|
should have been installed.
|
|
|
|
@retval EFI_SUCCESS The device has been un-initialized successfully.
|
|
|
|
@return Status code returned by UninstallProtocolInterface
|
|
Boot Service function.
|
|
|
|
**/
|
|
EFI_STATUS
|
|
VirtioMmioUninstallDevice (
|
|
IN EFI_HANDLE Handle
|
|
);
|
|
|
|
#endif // _VIRTIO_MMIO_DEVICE_LIB_H_
|