mirror of https://github.com/acidanthera/audk.git
MdeModulePkg: Add IpmiLib and Ppi/Protocol header file.
Add IpmiLib and Ppi/Protocol header file. Update dec file for new IpmiLib and Ppi/Protocol header file. In V5,change for coding style. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Daocheng Bu <daocheng.bu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19485 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
aeff1d6edb
commit
54b330a4fa
|
@ -0,0 +1,51 @@
|
|||
/** @file
|
||||
This library abstract how to access IPMI device via IPMI command.
|
||||
|
||||
Copyright (c) 2011 - 2015, Intel Corporation. All rights reserved. <BR>
|
||||
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 _IPMI_LIB_H_
|
||||
#define _IPMI_LIB_H_
|
||||
|
||||
#include <Uefi.h>
|
||||
#include <IndustryStandard/Ipmi.h>
|
||||
|
||||
|
||||
/**
|
||||
This service enables submitting commands via Ipmi.
|
||||
|
||||
@param[in] NetFunction Net function of the command.
|
||||
@param[in] Command IPMI Command.
|
||||
@param[in] RequestData Command Request Data.
|
||||
@param[in] RequestDataSize Size of Command Request Data.
|
||||
@param[out] ResponseData Command Response Data. The completion code is the first byte of response data.
|
||||
@param[in, out] ResponseDataSize Size of Command Response Data.
|
||||
|
||||
@retval EFI_SUCCESS The command byte stream was successfully submit to the device and a response was successfully received.
|
||||
@retval EFI_NOT_FOUND The command was not successfully sent to the device or a response was not successfully received from the device.
|
||||
@retval EFI_NOT_READY Ipmi Device is not ready for Ipmi command access.
|
||||
@retval EFI_DEVICE_ERROR Ipmi Device hardware error.
|
||||
@retval EFI_TIMEOUT The command time out.
|
||||
@retval EFI_UNSUPPORTED The command was not successfully sent to the device.
|
||||
@retval EFI_OUT_OF_RESOURCES The resource allcation is out of resource or data size error.
|
||||
**/
|
||||
EFI_STATUS
|
||||
EFIAPI
|
||||
IpmiSubmitCommand (
|
||||
IN UINT8 NetFunction,
|
||||
IN UINT8 Command,
|
||||
IN UINT8 *RequestData,
|
||||
IN UINT32 RequestDataSize,
|
||||
OUT UINT8 *ResponseData,
|
||||
IN OUT UINT32 *ResponseDataSize
|
||||
);
|
||||
|
||||
#endif
|
|
@ -0,0 +1,65 @@
|
|||
/** @file
|
||||
Ppi for Ipmi of SMS.
|
||||
|
||||
Copyright (c) 2014 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||
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 _IPMI_PPI_H_
|
||||
#define _IPMI_PPI_H_
|
||||
|
||||
typedef struct _PEI_IPMI_PPI PEI_IPMI_PPI;
|
||||
|
||||
#define PEI_IPMI_PPI_GUID \
|
||||
{ \
|
||||
0xa9731431, 0xd968, 0x4277, 0xb7, 0x52, 0xa3, 0xa9, 0xa6, 0xae, 0x18, 0x98 \
|
||||
}
|
||||
|
||||
/**
|
||||
This service enables submitting commands via Ipmi.
|
||||
|
||||
@param[in] This This point for PEI_IPMI_PPI structure.
|
||||
@param[in] NetFunction Net function of the command.
|
||||
@param[in] Command IPMI Command.
|
||||
@param[in] RequestData Command Request Data.
|
||||
@param[in] RequestDataSize Size of Command Request Data.
|
||||
@param[out] ResponseData Command Response Data. The completion code is the first byte of response data.
|
||||
@param[in, out] ResponseDataSize Size of Command Response Data.
|
||||
|
||||
@retval EFI_SUCCESS The command byte stream was successfully submit to the device and a response was successfully received.
|
||||
@retval EFI_NOT_FOUND The command was not successfully sent to the device or a response was not successfully received from the device.
|
||||
@retval EFI_NOT_READY Ipmi Device is not ready for Ipmi command access.
|
||||
@retval EFI_DEVICE_ERROR Ipmi Device hardware error.
|
||||
@retval EFI_TIMEOUT The command time out.
|
||||
@retval EFI_UNSUPPORTED The command was not successfully sent to the device.
|
||||
@retval EFI_OUT_OF_RESOURCES The resource allcation is out of resource or data size error.
|
||||
**/
|
||||
typedef
|
||||
EFI_STATUS
|
||||
(EFIAPI *PEI_IPMI_SUBMIT_COMMAND) (
|
||||
IN PEI_IPMI_PPI *This,
|
||||
IN UINT8 NetFunction,
|
||||
IN UINT8 Command,
|
||||
IN UINT8 *RequestData,
|
||||
IN UINT32 RequestDataSize,
|
||||
OUT UINT8 *ResponseData,
|
||||
IN OUT UINT32 *ResponseDataSize
|
||||
);
|
||||
|
||||
//
|
||||
// IPMI PPI
|
||||
//
|
||||
struct _PEI_IPMI_PPI {
|
||||
PEI_IPMI_SUBMIT_COMMAND IpmiSubmitCommand;
|
||||
};
|
||||
|
||||
extern EFI_GUID gPeiIpmiPpiGuid;
|
||||
|
||||
#endif
|
|
@ -0,0 +1,72 @@
|
|||
/** @file
|
||||
Protocol of Ipmi for both SMS and SMM.
|
||||
|
||||
Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||
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 _IPMI_PROTOCOL_H_
|
||||
#define _IPMI_PROTOCOL_H_
|
||||
|
||||
typedef struct _IPMI_PROTOCOL IPMI_PROTOCOL;
|
||||
|
||||
#define IPMI_PROTOCOL_GUID \
|
||||
{ \
|
||||
0xdbc6381f, 0x5554, 0x4d14, 0x8f, 0xfd, 0x76, 0xd7, 0x87, 0xb8, 0xac, 0xbf \
|
||||
}
|
||||
|
||||
#define SMM_IPMI_PROTOCOL_GUID \
|
||||
{ \
|
||||
0x5169af60, 0x8c5a, 0x4243, 0xb3, 0xe9, 0x56, 0xc5, 0x6d, 0x18, 0xee, 0x26 \
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
This service enables submitting commands via Ipmi.
|
||||
|
||||
@param[in] This This point for IPMI_PROTOCOL structure.
|
||||
@param[in] NetFunction Net function of the command.
|
||||
@param[in] Command IPMI Command.
|
||||
@param[in] RequestData Command Request Data.
|
||||
@param[in] RequestDataSize Size of Command Request Data.
|
||||
@param[out] ResponseData Command Response Data. The completion code is the first byte of response data.
|
||||
@param[in, out] ResponseDataSize Size of Command Response Data.
|
||||
|
||||
@retval EFI_SUCCESS The command byte stream was successfully submit to the device and a response was successfully received.
|
||||
@retval EFI_NOT_FOUND The command was not successfully sent to the device or a response was not successfully received from the device.
|
||||
@retval EFI_NOT_READY Ipmi Device is not ready for Ipmi command access.
|
||||
@retval EFI_DEVICE_ERROR Ipmi Device hardware error.
|
||||
@retval EFI_TIMEOUT The command time out.
|
||||
@retval EFI_UNSUPPORTED The command was not successfully sent to the device.
|
||||
@retval EFI_OUT_OF_RESOURCES The resource allcation is out of resource or data size error.
|
||||
**/
|
||||
typedef
|
||||
EFI_STATUS
|
||||
(EFIAPI *IPMI_SUBMIT_COMMAND) (
|
||||
IN IPMI_PROTOCOL *This,
|
||||
IN UINT8 NetFunction,
|
||||
IN UINT8 Command,
|
||||
IN UINT8 *RequestData,
|
||||
IN UINT32 RequestDataSize,
|
||||
OUT UINT8 *ResponseData,
|
||||
IN OUT UINT32 *ResponseDataSize
|
||||
);
|
||||
|
||||
//
|
||||
// IPMI COMMAND PROTOCOL
|
||||
//
|
||||
struct _IPMI_PROTOCOL{
|
||||
IPMI_SUBMIT_COMMAND IpmiSubmitCommand;
|
||||
};
|
||||
|
||||
extern EFI_GUID gIpmiProtocolGuid;
|
||||
extern EFI_GUID gSmmIpmiProtocolGuid;
|
||||
|
||||
#endif
|
|
@ -143,6 +143,10 @@
|
|||
#
|
||||
BootLogoLib|Include/Library/BootLogoLib.h
|
||||
|
||||
## @libraryclass Provides interfaces about Ipmi submit generic commond.
|
||||
#
|
||||
IpmiLib|Include/Library/IpmiLib.h
|
||||
|
||||
[Guids]
|
||||
## MdeModule package token space guid
|
||||
# Include/Guid/MdeModulePkgTokenSpace.h
|
||||
|
@ -372,6 +376,9 @@
|
|||
## Include/Ppi/UfsHostController.h
|
||||
gEdkiiPeiUfsHostControllerPpiGuid = { 0xdc54b283, 0x1a77, 0x4cd6, { 0x83, 0xbb, 0xfd, 0xda, 0x46, 0x9a, 0x2e, 0xc6 }}
|
||||
|
||||
## Include/Ppi/IpmiPpi.h
|
||||
gPeiIpmiPpiGuid = { 0xa9731431, 0xd968, 0x4277, { 0xb7, 0x52, 0xa3, 0xa9, 0xa6, 0xae, 0x18, 0x98 }}
|
||||
|
||||
[Protocols]
|
||||
## Load File protocol provides capability to load and unload EFI image into memory and execute it.
|
||||
# Include/Protocol/LoadPe32Image.h
|
||||
|
@ -470,6 +477,10 @@
|
|||
## Include/Protocol/FileExplorer.h
|
||||
gEfiFileExplorerProtocolGuid = { 0x2C03C536, 0x4594, 0x4515, { 0x9E, 0x7A, 0xD3, 0xD2, 0x04, 0xFE, 0x13, 0x63 } }
|
||||
|
||||
## Include/Protocol/IpmiProtocol.h
|
||||
gIpmiProtocolGuid = { 0xdbc6381f, 0x5554, 0x4d14, { 0x8f, 0xfd, 0x76, 0xd7, 0x87, 0xb8, 0xac, 0xbf } }
|
||||
gSmmIpmiProtocolGuid = { 0x5169af60, 0x8c5a, 0x4243, { 0xb3, 0xe9, 0x56, 0xc5, 0x6d, 0x18, 0xee, 0x26 } }
|
||||
|
||||
#
|
||||
# [Error.gEfiMdeModulePkgTokenSpaceGuid]
|
||||
# 0x80000001 | Invalid value provided.
|
||||
|
|
Loading…
Reference in New Issue