mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-25 17:23:53 +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_
 |