/** @file This file defines the EFI EAP Configuration protocol. Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR> SPDX-License-Identifier: BSD-2-Clause-Patent @par Revision Reference: This Protocol is introduced in UEFI Specification 2.5 **/ #ifndef __EFI_EAP_CONFIGURATION_PROTOCOL_H__ #define __EFI_EAP_CONFIGURATION_PROTOCOL_H__ /// /// EFI EAP Configuration protocol provides a way to set and get EAP configuration. /// #define EFI_EAP_CONFIGURATION_PROTOCOL_GUID \ { \ 0xe5b58dbb, 0x7688, 0x44b4, {0x97, 0xbf, 0x5f, 0x1d, 0x4b, 0x7c, 0xc8, 0xdb } \ } typedef struct _EFI_EAP_CONFIGURATION_PROTOCOL EFI_EAP_CONFIGURATION_PROTOCOL; /// /// Make sure it not conflict with any real EapTypeXXX /// #define EFI_EAP_TYPE_ATTRIBUTE 0 typedef enum { /// /// EFI_EAP_TYPE_ATTRIBUTE /// EfiEapConfigEapAuthMethod, EfiEapConfigEapSupportedAuthMethod, /// /// EapTypeIdentity /// EfiEapConfigIdentityString, /// /// EapTypeEAPTLS/EapTypePEAP /// EfiEapConfigEapTlsCACert, EfiEapConfigEapTlsClientCert, EfiEapConfigEapTlsClientPrivateKeyFile, EfiEapConfigEapTlsClientPrivateKeyFilePassword, // ASCII format, Volatile EfiEapConfigEapTlsCipherSuite, EfiEapConfigEapTlsSupportedCipherSuite, /// /// EapTypeMSChapV2 /// EfiEapConfigEapMSChapV2Password, // UNICODE format, Volatile /// /// EapTypePEAP /// EfiEapConfigEap2ndAuthMethod, /// /// More... /// } EFI_EAP_CONFIG_DATA_TYPE; /// /// EFI_EAP_TYPE /// typedef UINT8 EFI_EAP_TYPE; #define EFI_EAP_TYPE_ATTRIBUTE 0 #define EFI_EAP_TYPE_IDENTITY 1 #define EFI_EAP_TYPE_NOTIFICATION 2 #define EFI_EAP_TYPE_NAK 3 #define EFI_EAP_TYPE_MD5CHALLENGE 4 #define EFI_EAP_TYPE_OTP 5 #define EFI_EAP_TYPE_GTC 6 #define EFI_EAP_TYPE_EAPTLS 13 #define EFI_EAP_TYPE_EAPSIM 18 #define EFI_EAP_TYPE_TTLS 21 #define EFI_EAP_TYPE_PEAP 25 #define EFI_EAP_TYPE_MSCHAPV2 26 #define EFI_EAP_TYPE_EAP_EXTENSION 33 /** Set EAP configuration data. The SetData() function sets EAP configuration to non-volatile storage or volatile storage. @param[in] This Pointer to the EFI_EAP_CONFIGURATION_PROTOCOL instance. @param[in] EapType EAP type. @param[in] DataType Configuration data type. @param[in] Data Pointer to configuration data. @param[in] DataSize Total size of configuration data. @retval EFI_SUCCESS The EAP configuration data is set successfully. @retval EFI_INVALID_PARAMETER One or more of the following conditions is TRUE: Data is NULL. DataSize is 0. @retval EFI_UNSUPPORTED The EapType or DataType is unsupported. @retval EFI_OUT_OF_RESOURCES Required system resources could not be allocated. **/ typedef EFI_STATUS (EFIAPI *EFI_EAP_CONFIGURATION_SET_DATA) ( IN EFI_EAP_CONFIGURATION_PROTOCOL *This, IN EFI_EAP_TYPE EapType, IN EFI_EAP_CONFIG_DATA_TYPE DataType, IN VOID *Data, IN UINTN DataSize ); /** Get EAP configuration data. The GetData() function gets EAP configuration. @param[in] This Pointer to the EFI_EAP_CONFIGURATION_PROTOCOL instance. @param[in] EapType EAP type. @param[in] DataType Configuration data type. @param[in, out] Data Pointer to configuration data. @param[in, out] DataSize Total size of configuration data. On input, it means the size of Data buffer. On output, it means the size of copied Data buffer if EFI_SUCCESS, and means the size of desired Data buffer if EFI_BUFFER_TOO_SMALL. @retval EFI_SUCCESS The EAP configuration data is got successfully. @retval EFI_INVALID_PARAMETER One or more of the following conditions is TRUE: Data is NULL. DataSize is NULL. @retval EFI_UNSUPPORTED The EapType or DataType is unsupported. @retval EFI_NOT_FOUND The EAP configuration data is not found. @retval EFI_BUFFER_TOO_SMALL The buffer is too small to hold the buffer. **/ typedef EFI_STATUS (EFIAPI *EFI_EAP_CONFIGURATION_GET_DATA) ( IN EFI_EAP_CONFIGURATION_PROTOCOL *This, IN EFI_EAP_TYPE EapType, IN EFI_EAP_CONFIG_DATA_TYPE DataType, IN OUT VOID *Data, IN OUT UINTN *DataSize ); /// /// The EFI_EAP_CONFIGURATION_PROTOCOL /// is designed to provide a way to set and get EAP configuration, such as Certificate, /// private key file. /// struct _EFI_EAP_CONFIGURATION_PROTOCOL { EFI_EAP_CONFIGURATION_SET_DATA SetData; EFI_EAP_CONFIGURATION_GET_DATA GetData; }; extern EFI_GUID gEfiEapConfigurationProtocolGuid; #endif