1.Updated EFI_FVB_ATTRIBUTES to EFI_FVB_ATTRIBUTES_2 to follow PI spec.
2.Changed parameter FvHeader into DriverName to follow PI spec. 3.Updated DXE services functions header to follow PI spec. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5796 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
		| @@ -103,7 +103,7 @@ EFI_STATUS | |||||||
| EFIAPI | EFIAPI | ||||||
| EfiFvbGetVolumeAttributes ( | EfiFvbGetVolumeAttributes ( | ||||||
|   IN UINTN                                Instance, |   IN UINTN                                Instance, | ||||||
|   OUT EFI_FVB_ATTRIBUTES                  *Attributes |   OUT EFI_FVB_ATTRIBUTES_2                *Attributes | ||||||
|   ); |   ); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -112,7 +112,7 @@ EfiFvbGetVolumeAttributes ( | |||||||
|   input parameter, and returns the new setting of the volume. |   input parameter, and returns the new setting of the volume. | ||||||
|  |  | ||||||
|   @param[in]     Instance    The FV instance. |   @param[in]     Instance    The FV instance. | ||||||
|   @param[in, out]Attributes  On input, it is a pointer to EFI_FVB_ATTRIBUTES  |   @param[in, out]Attributes  On input, it is a pointer to EFI_FVB_ATTRIBUTES_2  | ||||||
|                              containing the desired firmware volume settings. |                              containing the desired firmware volume settings. | ||||||
|                              On successful return, it contains the new settings |                              On successful return, it contains the new settings | ||||||
|                              of the firmware volume. |                              of the firmware volume. | ||||||
| @@ -125,7 +125,7 @@ EFI_STATUS | |||||||
| EFIAPI | EFIAPI | ||||||
| EfiFvbSetVolumeAttributes ( | EfiFvbSetVolumeAttributes ( | ||||||
|   IN     UINTN                                Instance, |   IN     UINTN                                Instance, | ||||||
|   IN OUT EFI_FVB_ATTRIBUTES                   *Attributes |   IN OUT EFI_FVB_ATTRIBUTES_2                   *Attributes | ||||||
|   ); |   ); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -115,7 +115,9 @@ typedef struct { | |||||||
|   ///  |   ///  | ||||||
|   EFI_PHYSICAL_ADDRESS  BaseAddress; |   EFI_PHYSICAL_ADDRESS  BaseAddress; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|   /// Number of bytes in the I/O region. |   /// Number of bytes in the I/O region. | ||||||
|  |   /// | ||||||
|   UINT64                Length; |   UINT64                Length; | ||||||
|  |  | ||||||
|   ///  |   ///  | ||||||
| @@ -147,12 +149,31 @@ typedef struct { | |||||||
|   Adds reserved memory, system memory, or memory-mapped I/O resources to the |   Adds reserved memory, system memory, or memory-mapped I/O resources to the | ||||||
|   global coherency domain of the processor. |   global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  GcdMemoryType    Memory type of the memory space. |   @param  GcdMemoryType    The type of memory resource being added. | ||||||
|   @param  BaseAddress      Base address of the memory space. |   @param  BaseAddress      The physical address that is the start address | ||||||
|   @param  Length           Length of the memory space. |                            of the memory resource being added. | ||||||
|   @param  Capabilities     alterable attributes of the memory space. |   @param  Length           The size, in bytes, of the memory resource that | ||||||
|  |                            is being added. | ||||||
|  |   @param  Capabilities     The bit mask of attributes that the memory  | ||||||
|  |                            resource region supports. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Merged this memory space into GCD map. |   @retval EFI_SUCCESS            The memory resource was added to the global | ||||||
|  |                                  coherency domain of the processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER  GcdMemoryType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER  Length is zero. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES   There are not enough system resources to add | ||||||
|  |                                  the memory resource to the global coherency  | ||||||
|  |                                  domain of the processor. | ||||||
|  |   @retval EFI_UNSUPPORTED        The processor does not support one or more bytes | ||||||
|  |                                  of the memory resource range specified by  | ||||||
|  |                                  BaseAddress and Length. | ||||||
|  |   @retval EFI_ACCESS_DENIED      One or more bytes of the memory resource range | ||||||
|  |                                  specified by BaseAddress and Length conflicts  | ||||||
|  |                                  with a memory resource range that was previously | ||||||
|  |                                  added to the global coherency domain of the processor. | ||||||
|  |   @retval EFI_ACCESS_DENIED      One or more bytes of the memory resource range | ||||||
|  |                                  specified by BaseAddress and Length was allocated | ||||||
|  |                                  in a prior call to AllocateMemorySpace().. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -169,17 +190,30 @@ EFI_STATUS | |||||||
|   Allocates nonexistent memory, reserved memory, system memory, or memorymapped |   Allocates nonexistent memory, reserved memory, system memory, or memorymapped | ||||||
|   I/O resources from the global coherency domain of the processor. |   I/O resources from the global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  GcdAllocateType  The type of allocate operation |   @param  GcdAllocateType  The type of allocation to perform. | ||||||
|   @param  GcdMemoryType    The desired memory type |   @param  GcdMemoryType    The type of memory resource being allocated. | ||||||
|   @param  Alignment        Align with 2^Alignment |   @param  Alignment        The log base 2 of the boundary that BaseAddress must | ||||||
|   @param  Length           Length to allocate |                            be aligned on output. Align with 2^Alignment. | ||||||
|   @param  BaseAddress      Base address to allocate |   @param  Length           The size in bytes of the memory resource range that | ||||||
|   @param  Imagehandle      The image handle consume the allocated space. |                            is being allocated. | ||||||
|   @param  DeviceHandle     The device handle consume the allocated space. |   @param  BaseAddress      A pointer to a physical address to allocate. | ||||||
|  |   @param  Imagehandle      The image handle of the agent that is allocating  | ||||||
|  |                            the memory resource. | ||||||
|  |   @param  DeviceHandle     The device handle for which the memory resource | ||||||
|  |                            is being allocated. | ||||||
|  |  | ||||||
|  |   @retval EFI_INVALID_PARAMETER GcdAllocateType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER GcdMemoryType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero. | ||||||
|  |   @retval EFI_INVALID_PARAMETER BaseAddress is NULL. | ||||||
|  |   @retval EFI_INVALID_PARAMETER ImageHandle is NULL. | ||||||
|  |   @retval EFI_NOT_FOUND         The memory resource request could not be satisfied. | ||||||
|  |                                 No descriptor contains the desired space. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to allocate the memory | ||||||
|  |                                 resource from the global coherency domain of the processor. | ||||||
|  |   @retval EFI_SUCCESS           The memory resource was allocated from the global coherency | ||||||
|  |                                 domain of the processor. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER Invalid parameter. |  | ||||||
|   @retval EFI_NOT_FOUND         No descriptor contains the desired space. |  | ||||||
|   @retval EFI_SUCCESS           Memory space successfully allocated. |  | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -199,10 +233,18 @@ EFI_STATUS | |||||||
|   Frees nonexistent memory, reserved memory, system memory, or memory-mapped |   Frees nonexistent memory, reserved memory, system memory, or memory-mapped | ||||||
|   I/O resources from the global coherency domain of the processor. |   I/O resources from the global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Base address of the segment. |   @param  BaseAddress      The physical address that is the start address of the memory resource being freed. | ||||||
|   @param  Length           Length of the segment. |   @param  Length           The size in bytes of the memory resource range that is being freed. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Space successfully freed. |   @retval EFI_SUCCESS           The memory resource was freed from the global coherency domain of | ||||||
|  |                                 the processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero.    | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the memory | ||||||
|  |                                 resource range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_NOT_FOUND         The memory resource range specified by BaseAddress and | ||||||
|  |                                 Length was not allocated with previous calls to AllocateMemorySpace(). | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to free the memory resource | ||||||
|  |                                 from the global coherency domain of the processor. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -217,10 +259,21 @@ EFI_STATUS | |||||||
|   Removes reserved memory, system memory, or memory-mapped I/O resources from |   Removes reserved memory, system memory, or memory-mapped I/O resources from | ||||||
|   the global coherency domain of the processor. |   the global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Base address of the memory space. |   @param  BaseAddress      The physical address that is the start address of the memory resource being removed. | ||||||
|   @param  Length           Length of the memory space. |   @param  Length           The size in bytes of the memory resource that is being removed. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Successfully remove a segment of memory space. |   @retval EFI_SUCCESS           The memory resource was removed from the global coherency | ||||||
|  |                                 domain of the processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero.  | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the memory | ||||||
|  |                                 resource range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_NOT_FOUND         One or more bytes of the memory resource range specified by | ||||||
|  |                                 BaseAddress and Length was not added with previous calls to | ||||||
|  |                                 AddMemorySpace(). | ||||||
|  |   @retval EFI_ACCESS_DEFINED    One or more bytes of the memory resource range specified by | ||||||
|  |                                 BaseAddress and Length has been allocated with AllocateMemorySpace(). | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to remove the memory | ||||||
|  |                                 resource from the global coherency domain of the processor. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -234,11 +287,13 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|   Retrieves the descriptor for a memory region containing a specified address. |   Retrieves the descriptor for a memory region containing a specified address. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Specified start address |   @param  BaseAddress      The physical address that is the start address of a memory region. | ||||||
|   @param  Descriptor       Specified length |   @param  Descriptor       A pointer to a caller allocated descriptor. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER Invalid parameter |   @retval EFI_SUCCESS           The descriptor for the memory resource region containing | ||||||
|   @retval EFI_SUCCESS           Successfully get memory space descriptor. |                                 BaseAddress was returned in Descriptor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Descriptor is NULL. | ||||||
|  |   @retval EFI_NOT_FOUND         A memory resource range containing BaseAddress was not found. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -253,11 +308,20 @@ EFI_STATUS | |||||||
|   Modifies the attributes for a memory region in the global coherency domain of the |   Modifies the attributes for a memory region in the global coherency domain of the | ||||||
|   processor. |   processor. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Specified start address |   @param  BaseAddress      The physical address that is the start address of a memory region. | ||||||
|   @param  Length           Specified length |   @param  Length           The size in bytes of the memory region. | ||||||
|   @param  Attributes       Specified attributes |   @param  Attributes       The bit mask of attributes to set for the memory region. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Successfully set attribute of a segment of memory space. |   @retval EFI_SUCCESS           The attributes were set for the memory region. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero.  | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the memory | ||||||
|  |                                 resource range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_UNSUPPORTED       The bit mask of attributes is not support for the memory resource | ||||||
|  |                                 range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_ACCESS_DEFINED    The attributes for the memory resource range specified by | ||||||
|  |                                 BaseAddress and Length cannot be modified. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to modify the attributes of | ||||||
|  |                                 the memory resource range. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -273,12 +337,15 @@ EFI_STATUS | |||||||
|   Returns a map of the memory resources in the global coherency domain of the |   Returns a map of the memory resources in the global coherency domain of the | ||||||
|   processor. |   processor. | ||||||
|  |  | ||||||
|   @param  NumberOfDescriptors Number of descriptors. |   @param  NumberOfDescriptors A pointer to number of descriptors returned in the MemorySpaceMap buffer. | ||||||
|   @param  MemorySpaceMap      Descriptor array |   @param  MemorySpaceMap      A pointer to the array of EFI_GCD_MEMORY_SPACE_DESCRIPTORs. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER Invalid parameter |   @retval EFI_SUCCESS           The memory space map was returned in the MemorySpaceMap | ||||||
|   @retval EFI_OUT_OF_RESOURCES  No enough buffer to allocate |                                 buffer, and the number of descriptors in MemorySpaceMap was | ||||||
|   @retval EFI_SUCCESS           Successfully get memory space map. |                                 returned in NumberOfDescriptors. | ||||||
|  |   @retval EFI_INVALID_PARAMETER NumberOfDescriptors is NULL. | ||||||
|  |   @retval EFI_INVALID_PARAMETER MemorySpaceMap is NULL. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough resources to allocate MemorySpaceMap. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -292,11 +359,25 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|   Adds reserved I/O or I/O resources to the global coherency domain of the processor. |   Adds reserved I/O or I/O resources to the global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  GcdIoType        IO type of the segment. |   @param  GcdIoType        The type of I/O resource being added. | ||||||
|   @param  BaseAddress      Base address of the segment. |   @param  BaseAddress      The physical address that is the start address of the I/O resource being added. | ||||||
|   @param  Length           Length of the segment. |   @param  Length           The size in bytes of the I/O resource that is being added. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Merged this segment into GCD map. |   @retval EFI_SUCCESS           The I/O resource was added to the global coherency domain of | ||||||
|  |                                 the processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER GcdIoType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to add the I/O resource to | ||||||
|  |                                 the global coherency domain of the processor. | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the I/O | ||||||
|  |                                 resource range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_ACCESS_DENIED     One or more bytes of the I/O resource range specified by | ||||||
|  |                                 BaseAddress and Length conflicts with an I/O resource | ||||||
|  |                                 range that was previously added to the global coherency domain | ||||||
|  |                                 of the processor. | ||||||
|  |   @retval EFI_ACCESS_DENIED     One or more bytes of the I/O resource range specified by | ||||||
|  |                                 BaseAddress and Length was allocated in a prior call to | ||||||
|  |                                 AllocateIoSpace(). | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -312,17 +393,24 @@ EFI_STATUS | |||||||
|   Allocates nonexistent I/O, reserved I/O, or I/O resources from the global coherency |   Allocates nonexistent I/O, reserved I/O, or I/O resources from the global coherency | ||||||
|   domain of the processor. |   domain of the processor. | ||||||
|  |  | ||||||
|   @param  GcdAllocateType  The type of allocate operation |   @param  GcdAllocateType  The type of allocation to perform. | ||||||
|   @param  GcdIoType        The desired IO type |   @param  GcdIoType        The type of I/O resource being allocated. | ||||||
|   @param  Alignment        Align with 2^Alignment |   @param  Alignment        The log base 2 of the boundary that BaseAddress must be aligned on output. | ||||||
|   @param  Length           Length to allocate |   @param  Length           The size in bytes of the I/O resource range that is being allocated. | ||||||
|   @param  BaseAddress      Base address to allocate |   @param  BaseAddress      A pointer to a physical address. | ||||||
|   @param  Imagehandle      The image handle consume the allocated space. |   @param  Imagehandle      The image handle of the agent that is allocating the I/O resource. | ||||||
|   @param  DeviceHandle     The device handle consume the allocated space. |   @param  DeviceHandle     The device handle for which the I/O resource is being allocated. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER Invalid parameter. |   @retval EFI_SUCCESS           The I/O resource was allocated from the global coherency domain | ||||||
|   @retval EFI_NOT_FOUND         No descriptor contains the desired space. |                                 of the processor. | ||||||
|   @retval EFI_SUCCESS           IO space successfully allocated. |   @retval EFI_INVALID_PARAMETER GcdAllocateType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER GcdIoType is invalid. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero. | ||||||
|  |   @retval EFI_INVALID_PARAMETER BaseAddress is NULL. | ||||||
|  |   @retval EFI_INVALID_PARAMETER ImageHandle is NULL. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to allocate the I/O | ||||||
|  |                                 resource from the global coherency domain of the processor. | ||||||
|  |   @retval EFI_NOT_FOUND         The I/O resource request could not be satisfied. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -342,10 +430,18 @@ EFI_STATUS | |||||||
|   Frees nonexistent I/O, reserved I/O, or I/O resources from the global coherency |   Frees nonexistent I/O, reserved I/O, or I/O resources from the global coherency | ||||||
|   domain of the processor. |   domain of the processor. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Base address of the segment. |   @param  BaseAddress      The physical address that is the start address of the I/O resource being freed. | ||||||
|   @param  Length           Length of the segment. |   @param  Length           The size in bytes of the I/O resource range that is being freed. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Space successfully freed. |   @retval EFI_SUCCESS           The I/O resource was freed from the global coherency domain of the | ||||||
|  |                                 processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero. | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the I/O resource | ||||||
|  |                                 range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_NOT_FOUND         The I/O resource range specified by BaseAddress and Length | ||||||
|  |                                 was not allocated with previous calls to AllocateIoSpace(). | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to free the I/O resource from | ||||||
|  |                                 the global coherency domain of the processor. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -360,10 +456,23 @@ EFI_STATUS | |||||||
|   Removes reserved I/O or I/O resources from the global coherency domain of the |   Removes reserved I/O or I/O resources from the global coherency domain of the | ||||||
|   processor. |   processor. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Base address of the segment. |   @param  BaseAddress      A pointer to a physical address that is the start address of the I/O resource being | ||||||
|   @param Length Length of the segment. |                            removed. | ||||||
|  |   @param Length            The size in bytes of the I/O resource that is being removed. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS           Successfully removed a segment of IO space. |   @retval EFI_SUCCESS           The I/O resource was removed from the global coherency domain | ||||||
|  |                                 of the processor. | ||||||
|  |   @retval EFI_INVALID_PARAMETER Length is zero. | ||||||
|  |   @retval EFI_UNSUPPORTED       The processor does not support one or more bytes of the I/O | ||||||
|  |                                 resource range specified by BaseAddress and Length. | ||||||
|  |   @retval EFI_NOT_FOUND         One or more bytes of the I/O resource range specified by | ||||||
|  |                                 BaseAddress and Length was not added with previous | ||||||
|  |                                 calls to AddIoSpace(). | ||||||
|  |   @retval EFI_ACCESS_DENIED     One or more bytes of the I/O resource range specified by | ||||||
|  |                                 BaseAddress and Length has been allocated with | ||||||
|  |                                 AllocateIoSpace(). | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough system resources to remove the I/O | ||||||
|  |                                 resource from the global coherency domain of the processor. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -377,11 +486,13 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|   Retrieves the descriptor for an I/O region containing a specified address. |   Retrieves the descriptor for an I/O region containing a specified address. | ||||||
|  |  | ||||||
|   @param  BaseAddress      Specified start address |   @param  BaseAddress      The physical address that is the start address of an I/O region. | ||||||
|   @param  Descriptor       Specified length |   @param  Descriptor       A pointer to a caller allocated descriptor. | ||||||
|  |  | ||||||
|  |   @retval EFI_SUCCESS           The descriptor for the I/O resource region containing | ||||||
|  |                                 BaseAddress was returned in Descriptor. | ||||||
|   @retval EFI_INVALID_PARAMETER Descriptor is NULL. |   @retval EFI_INVALID_PARAMETER Descriptor is NULL. | ||||||
|   @retval EFI_SUCCESS           Successfully get the IO space descriptor. |   @retval EFI_NOT_FOUND         An I/O resource range containing BaseAddress was not found. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -395,12 +506,16 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|   Returns a map of the I/O resources in the global coherency domain of the processor. |   Returns a map of the I/O resources in the global coherency domain of the processor. | ||||||
|  |  | ||||||
|   @param  NumberOfDescriptors Number of descriptors. |   @param  NumberOfDescriptors A pointer to number of descriptors returned in the IoSpaceMap buffer. | ||||||
|   @param  MemorySpaceMap      Descriptor array |   @param  MemorySpaceMap      A pointer to the array of EFI_GCD_IO_SPACE_DESCRIPTORs. | ||||||
|  |  | ||||||
|  |   @retval EFI_SUCCESS           The I/O space map was returned in the IoSpaceMap buffer, and | ||||||
|  |                                 the number of descriptors in IoSpaceMap was returned in | ||||||
|  |                                 NumberOfDescriptors. | ||||||
|  |   @retval EFI_INVALID_PARAMETER NumberOfDescriptors is NULL. | ||||||
|  |   @retval EFI_INVALID_PARAMETER IoSpaceMap is NULL. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES  There are not enough resources to allocate IoSpaceMap. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER Invalid parameter |  | ||||||
|   @retval EFI_OUT_OF_RESOURCES  No enough buffer to allocate |  | ||||||
|   @retval EFI_SUCCESS           Successfully get IO space map. |  | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -416,7 +531,17 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|   Loads and executed DXE drivers from firmware volumes. |   Loads and executed DXE drivers from firmware volumes. | ||||||
|  |  | ||||||
|   @return Status of dispatching and execution DXE drivers. |   The Dispatch() function searches for DXE drivers in firmware volumes that have been  | ||||||
|  |   installed since the last time the Dispatch() service was called. It then evaluates  | ||||||
|  |   the dependency expressions of all the DXE drivers and loads and executes those DXE | ||||||
|  |   drivers whose dependency expression evaluate to TRUE. This service must interact with | ||||||
|  |   the Security Architectural Protocol to authenticate DXE drivers before they are executed. | ||||||
|  |   This process is continued until no more DXE drivers can be executed. | ||||||
|  |  | ||||||
|  |   @retval EFI_SUCCESS         One or more DXE driver were dispatched. | ||||||
|  |   @retval EFI_NOT_FOUND       No DXE drivers were dispatched. | ||||||
|  |   @retval EFI_ALREADY_STARTED An attempt is being made to start the DXE Dispatcher recursively. | ||||||
|  |                               Thus no action was taken. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| @@ -430,16 +555,18 @@ EFI_STATUS | |||||||
|   Clears the Schedule on Request (SOR) flag for a component that is stored in a firmware volume. |   Clears the Schedule on Request (SOR) flag for a component that is stored in a firmware volume. | ||||||
|  |  | ||||||
|   @param  FirmwareVolumeHandle The handle of the firmware volume that contains the file specified by FileName. |   @param  FirmwareVolumeHandle The handle of the firmware volume that contains the file specified by FileName. | ||||||
|   @param  DriverName           A pointer to the name of the file in a firmware volume. |   @param  FileName             A pointer to the name of the file in a firmware volume. | ||||||
|  |  | ||||||
|   @return Status of clearing SOR. |   @retval EFI_SUCCESS         The DXE driver was found and its SOR bit was cleared. | ||||||
|  |   @retval EFI_NOT_FOUND       The DXE driver does not exist, or the DXE driver exists and its SOR | ||||||
|  |                               bit is not set. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| (EFIAPI *EFI_SCHEDULE)( | (EFIAPI *EFI_SCHEDULE)( | ||||||
|   IN EFI_HANDLE  FirmwareVolumeHandle, |   IN EFI_HANDLE  FirmwareVolumeHandle, | ||||||
|   IN EFI_GUID    *DriverName |   IN CONST EFI_GUID    *FileName | ||||||
|   ) |   ) | ||||||
| ; | ; | ||||||
|  |  | ||||||
| @@ -451,13 +578,14 @@ EFI_STATUS | |||||||
|  |  | ||||||
|   @return Status of promoting FFS from untrusted to trusted |   @return Status of promoting FFS from untrusted to trusted | ||||||
|           state. |           state. | ||||||
|  |   @retval EFI_NOT_FOUND       The file was not found in the untrusted state. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| (EFIAPI *EFI_TRUST)( | (EFIAPI *EFI_TRUST)( | ||||||
|   IN EFI_HANDLE  FirmwareVolumeHandle, |   IN EFI_HANDLE  FirmwareVolumeHandle, | ||||||
|   IN EFI_GUID    *DriverName |   IN CONST EFI_GUID    *FileName | ||||||
|   ) |   ) | ||||||
| ; | ; | ||||||
|  |  | ||||||
| @@ -468,13 +596,21 @@ EFI_STATUS | |||||||
|   @param  Size                 The size, in bytes, of the firmware volume. |   @param  Size                 The size, in bytes, of the firmware volume. | ||||||
|   @param  FirmwareVolumeHandle On output, a pointer to the created handle. |   @param  FirmwareVolumeHandle On output, a pointer to the created handle. | ||||||
|  |  | ||||||
|   @return Status of processing FV. |   @retval EFI_SUCCESS          The EFI_FIRMWARE_VOLUME_PROTOCOL and | ||||||
|  |                                EFI_DEVICE_PATH_PROTOCOL were installed onto | ||||||
|  |                                FirmwareVolumeHandle for the firmware volume described | ||||||
|  |                                by FirmwareVolumeHeader and Size. | ||||||
|  |   @retval EFI_VOLUME_CORRUPTED The firmware volume described by FirmwareVolumeHeader | ||||||
|  |                                and Size is corrupted. | ||||||
|  |   @retval EFI_OUT_OF_RESOURCES There are not enough system resources available to produce the | ||||||
|  |                                EFI_FIRMWARE_VOLUME_PROTOCOL and EFI_DEVICE_PATH_PROTOCOL  | ||||||
|  |                                for the firmware volume described by FirmwareVolumeHeader and Size. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
| EFI_STATUS | EFI_STATUS | ||||||
| (EFIAPI *EFI_PROCESS_FIRMWARE_VOLUME)( | (EFIAPI *EFI_PROCESS_FIRMWARE_VOLUME)( | ||||||
|   IN VOID                             *FvHeader, |   IN CONST VOID                       *FirmwareVolumeHeader, | ||||||
|   IN UINTN                            Size, |   IN UINTN                            Size, | ||||||
|   OUT EFI_HANDLE                      *FirmwareVolumeHandle |   OUT EFI_HANDLE                      *FirmwareVolumeHandle | ||||||
|   ) |   ) | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ typedef UINT32  EFI_FV_FILE_ATTRIBUTES; | |||||||
| /// | /// | ||||||
| /// type of EFI FVB attribute | /// type of EFI FVB attribute | ||||||
| ///  | ///  | ||||||
| typedef UINT32  EFI_FVB_ATTRIBUTES; | typedef UINT32  EFI_FVB_ATTRIBUTES_2; | ||||||
|  |  | ||||||
| //  | //  | ||||||
| // Attributes bit definitions | // Attributes bit definitions | ||||||
| @@ -103,7 +103,7 @@ typedef struct { | |||||||
|   EFI_GUID                  FileSystemGuid; |   EFI_GUID                  FileSystemGuid; | ||||||
|   UINT64                    FvLength; |   UINT64                    FvLength; | ||||||
|   UINT32                    Signature; |   UINT32                    Signature; | ||||||
|   EFI_FVB_ATTRIBUTES        Attributes; |   EFI_FVB_ATTRIBUTES_2      Attributes; | ||||||
|   UINT16                    HeaderLength; |   UINT16                    HeaderLength; | ||||||
|   UINT16                    Checksum; |   UINT16                    Checksum; | ||||||
|   UINT16                    ExtHeaderOffset; |   UINT16                    ExtHeaderOffset; | ||||||
|   | |||||||
| @@ -513,15 +513,12 @@ EFI_STATUS | |||||||
|  |  | ||||||
|   @param FileName       A pointer to the name of the file to |   @param FileName       A pointer to the name of the file to | ||||||
|                         find within the firmware volume. |                         find within the firmware volume. | ||||||
|  |  | ||||||
|   @param VolumeHandle   The firmware volume to search FileHandle |   @param VolumeHandle   The firmware volume to search FileHandle | ||||||
|                         Upon exit, points to the found file's |                         Upon exit, points to the found file's | ||||||
|                         handle or NULL if it could not be found. |                         handle or NULL if it could not be found. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS             File was found. |   @retval EFI_SUCCESS             File was found. | ||||||
|  |  | ||||||
|   @retval EFI_NOT_FOUND           File was not found. |   @retval EFI_NOT_FOUND           File was not found. | ||||||
|  |  | ||||||
|   @retval EFI_INVALID_PARAMETER   VolumeHandle or FileHandle or |   @retval EFI_INVALID_PARAMETER   VolumeHandle or FileHandle or | ||||||
|                                   FileName was NULL. |                                   FileName was NULL. | ||||||
|  |  | ||||||
| @@ -538,20 +535,16 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|     |     | ||||||
|   @param FileName   Name of the file. |   @param FileName   Name of the file. | ||||||
|  |  | ||||||
|   @param FileType   File type. See EFI_FV_FILETYPE, which is |   @param FileType   File type. See EFI_FV_FILETYPE, which is | ||||||
|                     defined in the Platform Initialization |                     defined in the Platform Initialization | ||||||
|                     Firmware Storage Specification. |                     Firmware Storage Specification. | ||||||
|  |  | ||||||
|   @param FileAttributes   Attributes of the file. Type |   @param FileAttributes   Attributes of the file. Type | ||||||
|                           EFI_FV_FILE_ATTRIBUTES is defined in |                           EFI_FV_FILE_ATTRIBUTES is defined in | ||||||
|                           the Platform Initialization Firmware |                           the Platform Initialization Firmware | ||||||
|                           Storage Specification. |                           Storage Specification. | ||||||
|  |  | ||||||
|   @param Buffer   Points to the file's data (not the header). |   @param Buffer   Points to the file's data (not the header). | ||||||
|                   Not valid if EFI_FV_FILE_ATTRIB_MEMORY_MAPPED |                   Not valid if EFI_FV_FILE_ATTRIB_MEMORY_MAPPED | ||||||
|                   is zero. |                   is zero. | ||||||
|  |  | ||||||
|   @param BufferSize   Size of the file's data. |   @param BufferSize   Size of the file's data. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| @@ -564,22 +557,18 @@ typedef struct { | |||||||
| } EFI_FV_FILE_INFO; | } EFI_FV_FILE_INFO; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|     |  | ||||||
|   This function returns information about a specific file, |   This function returns information about a specific file, | ||||||
|   including its file name, type, attributes, starting address and |   including its file name, type, attributes, starting address and | ||||||
|   size. If the firmware volume is not memory mapped then the |   size. If the firmware volume is not memory mapped then the | ||||||
|   Buffer member will be NULL. |   Buffer member will be NULL. | ||||||
|  |  | ||||||
|   @param FileHandle   Handle of the file. |   @param FileHandle   Handle of the file. | ||||||
|  |  | ||||||
|   @param FileInfo     Upon exit, points to the file's |   @param FileInfo     Upon exit, points to the file's | ||||||
|                       information. |                       information. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS             File information returned. |   @retval EFI_SUCCESS             File information returned. | ||||||
|    |  | ||||||
|   @retval EFI_INVALID_PARAMETER   If FileHandle does not |   @retval EFI_INVALID_PARAMETER   If FileHandle does not | ||||||
|                                   represent a valid file. |                                   represent a valid file. | ||||||
|    |  | ||||||
|   @retval EFI_INVALID_PARAMETER   If FileInfo is NULL. |   @retval EFI_INVALID_PARAMETER   If FileInfo is NULL. | ||||||
|    |    | ||||||
| **/ | **/ | ||||||
| @@ -594,7 +583,7 @@ EFI_STATUS | |||||||
| /** | /** | ||||||
|     |     | ||||||
|   @param FvAttributes   Attributes of the firmware volume. Type |   @param FvAttributes   Attributes of the firmware volume. Type | ||||||
|                         EFI_FVB_ATTRIBUTES is defined in the |                         EFI_FVB_ATTRIBUTES_2 is defined in the | ||||||
|                         Platform Initialization Firmware Storage |                         Platform Initialization Firmware Storage | ||||||
|                         Specficiation. |                         Specficiation. | ||||||
|  |  | ||||||
| @@ -616,11 +605,11 @@ EFI_STATUS | |||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef struct { | typedef struct { | ||||||
|   EFI_FVB_ATTRIBUTES  FvAttributes; |   EFI_FVB_ATTRIBUTES_2  FvAttributes; | ||||||
|   EFI_GUID            FvFormat; |   EFI_GUID              FvFormat; | ||||||
|   EFI_GUID            FvName; |   EFI_GUID              FvName; | ||||||
|   VOID                *FvStart; |   VOID                  *FvStart; | ||||||
|   UINT64              FvSize; |   UINT64                FvSize; | ||||||
| } EFI_FV_INFO; | } EFI_FV_INFO; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -635,10 +624,8 @@ typedef struct { | |||||||
|                         information. |                         information. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS             File information returned. |   @retval EFI_SUCCESS             File information returned. | ||||||
|    |  | ||||||
|   @retval EFI_INVALID_PARAMETER   If FileHandle does not |   @retval EFI_INVALID_PARAMETER   If FileHandle does not | ||||||
|                                   represent a valid file. |                                   represent a valid file. | ||||||
|    |  | ||||||
|   @retval EFI_INVALID_PARAMETER   If FileInfo is NULL. |   @retval EFI_INVALID_PARAMETER   If FileInfo is NULL. | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| @@ -664,14 +651,12 @@ EFI_STATUS | |||||||
|   @param FileHandle   PEIM's file handle. Must be the currently |   @param FileHandle   PEIM's file handle. Must be the currently | ||||||
|                       executing PEIM. |                       executing PEIM. | ||||||
|    |    | ||||||
|   @retval EFI_SUCCESS   The PEIM was successfully registered for |   @retval EFI_SUCCESS           The PEIM was successfully registered for | ||||||
|                         shadowing. |                                 shadowing. | ||||||
|  |  | ||||||
|   @retval EFI_ALREADY_STARTED   The PEIM was previously |   @retval EFI_ALREADY_STARTED   The PEIM was previously | ||||||
|                                 registered for shadowing. |                                 registered for shadowing. | ||||||
|  |   @retval EFI_NOT_FOUND         The FileHandle does not refer to a | ||||||
|   @retval EFI_NOT_FOUND   The FileHandle does not refer to a |                                 valid file handle. | ||||||
|                           valid file handle. |  | ||||||
|  |  | ||||||
| **/ | **/ | ||||||
| typedef | typedef | ||||||
|   | |||||||
| @@ -31,9 +31,9 @@ typedef struct _EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL EFI_FIRMWARE_VOLUME_BLOCK_PRO | |||||||
|  |  | ||||||
|   @param This       Indicates the EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL instance. |   @param This       Indicates the EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL instance. | ||||||
|  |  | ||||||
|   @param Attributes Pointer to EFI_FVB_ATTRIBUTES in which the |   @param Attributes Pointer to EFI_FVB_ATTRIBUTES_2 in which the | ||||||
|                     attributes and current settings are |                     attributes and current settings are | ||||||
|                     returned. Type EFI_FVB_ATTRIBUTES is defined |                     returned. Type EFI_FVB_ATTRIBUTES_2 is defined | ||||||
|                     in EFI_FIRMWARE_VOLUME_HEADER. |                     in EFI_FIRMWARE_VOLUME_HEADER. | ||||||
|  |  | ||||||
|   @retval EFI_SUCCESS The firmware volume attributes were |   @retval EFI_SUCCESS The firmware volume attributes were | ||||||
| @@ -44,7 +44,7 @@ typedef | |||||||
| EFI_STATUS | EFI_STATUS | ||||||
| (EFIAPI * EFI_FVB_GET_ATTRIBUTES)( | (EFIAPI * EFI_FVB_GET_ATTRIBUTES)( | ||||||
|   IN CONST  EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL  *This, |   IN CONST  EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL  *This, | ||||||
|   OUT       EFI_FVB_ATTRIBUTES                  *Attributes |   OUT       EFI_FVB_ATTRIBUTES_2                *Attributes | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -55,11 +55,11 @@ EFI_STATUS | |||||||
|   @param This         Indicates the EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL instance. |   @param This         Indicates the EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL instance. | ||||||
|  |  | ||||||
|   @param Attributes   On input, Attributes is a pointer to |   @param Attributes   On input, Attributes is a pointer to | ||||||
|                       EFI_FVB_ATTRIBUTES that contains the |                       EFI_FVB_ATTRIBUTES_2 that contains the | ||||||
|                       desired firmware volume settings. On |                       desired firmware volume settings. On | ||||||
|                       successful return, it contains the new |                       successful return, it contains the new | ||||||
|                       settings of the firmware volume. Type |                       settings of the firmware volume. Type | ||||||
|                       EFI_FVB_ATTRIBUTES is defined in |                       EFI_FVB_ATTRIBUTES_2 is defined in | ||||||
|                       EFI_FIRMWARE_VOLUME_HEADER. |                       EFI_FIRMWARE_VOLUME_HEADER. | ||||||
|    |    | ||||||
|   @retval EFI_SUCCESS           The firmware volume attributes were returned. |   @retval EFI_SUCCESS           The firmware volume attributes were returned. | ||||||
| @@ -74,7 +74,7 @@ typedef | |||||||
| EFI_STATUS | EFI_STATUS | ||||||
| (EFIAPI * EFI_FVB_SET_ATTRIBUTES)( | (EFIAPI * EFI_FVB_SET_ATTRIBUTES)( | ||||||
|   IN CONST  EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL  *This, |   IN CONST  EFI_FIRMWARE_VOLUME_BLOCK_PROTOCOL  *This, | ||||||
|   IN OUT    EFI_FVB_ATTRIBUTES                  *Attributes |   IN OUT    EFI_FVB_ATTRIBUTES_2                *Attributes | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user