2008-04-17 10:28:51 +02:00
|
|
|
/** @file
|
2008-12-10 03:02:38 +01:00
|
|
|
The header file of CHAP configuration.
|
2007-12-24 03:20:21 +01:00
|
|
|
|
2009-11-04 09:18:34 +01:00
|
|
|
Copyright (c) 2004 - 2009, Intel Corporation.<BR>
|
2008-01-22 09:07:35 +01:00
|
|
|
All rights reserved. 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.
|
2007-12-24 03:20:21 +01:00
|
|
|
|
2008-04-17 10:28:51 +02:00
|
|
|
**/
|
2007-12-24 03:20:21 +01:00
|
|
|
|
|
|
|
#ifndef _ISCSI_CHAP_H_
|
|
|
|
#define _ISCSI_CHAP_H_
|
|
|
|
|
|
|
|
#define ISCSI_CHAP_AUTH_INFO_GUID \
|
|
|
|
{ \
|
2008-01-21 15:39:56 +01:00
|
|
|
0x786ec0ac, 0x65ae, 0x4d1b, {0xb1, 0x37, 0xd, 0x11, 0xa, 0x48, 0x37, 0x97} \
|
2007-12-24 03:20:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
extern EFI_GUID mIScsiCHAPAuthInfoGuid;
|
|
|
|
|
|
|
|
#define ISCSI_AUTH_METHOD_CHAP "CHAP"
|
|
|
|
|
|
|
|
#define ISCSI_KEY_CHAP_ALGORITHM "CHAP_A"
|
|
|
|
#define ISCSI_KEY_CHAP_IDENTIFIER "CHAP_I"
|
|
|
|
#define ISCSI_KEY_CHAP_CHALLENGE "CHAP_C"
|
|
|
|
#define ISCSI_KEY_CHAP_NAME "CHAP_N"
|
|
|
|
#define ISCSI_KEY_CHAP_RESPONSE "CHAP_R"
|
|
|
|
|
|
|
|
#define ISCSI_CHAP_ALGORITHM_MD5 5
|
|
|
|
|
|
|
|
#define ISCSI_CHAP_AUTH_MAX_LEN 1024
|
2008-12-10 03:02:38 +01:00
|
|
|
///
|
|
|
|
/// MD5_HASHSIZE
|
|
|
|
///
|
|
|
|
#define ISCSI_CHAP_RSP_LEN 16
|
2009-11-04 09:18:34 +01:00
|
|
|
|
|
|
|
#define ISCSI_CHAP_INITIAL 0
|
|
|
|
#define ISCSI_CHAP_STEP_ONE 1
|
|
|
|
#define ISCSI_CHAP_STEP_TWO 2
|
|
|
|
#define ISCSI_CHAP_STEP_THREE 3
|
|
|
|
#define ISCSI_CHAP_STEP_FOUR 4
|
2007-12-24 03:20:21 +01:00
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
|
|
|
|
typedef struct _ISCSI_CHAP_AUTH_CONFIG_NVDATA {
|
|
|
|
UINT8 CHAPType;
|
|
|
|
CHAR8 CHAPName[ISCSI_CHAP_NAME_MAX_LEN];
|
2009-07-01 02:47:09 +02:00
|
|
|
CHAR8 CHAPSecret[ISCSI_CHAP_SECRET_STORAGE];
|
2007-12-24 03:20:21 +01:00
|
|
|
CHAR8 ReverseCHAPName[ISCSI_CHAP_NAME_MAX_LEN];
|
2009-07-01 02:47:09 +02:00
|
|
|
CHAR8 ReverseCHAPSecret[ISCSI_CHAP_SECRET_STORAGE];
|
2007-12-24 03:20:21 +01:00
|
|
|
} ISCSI_CHAP_AUTH_CONFIG_NVDATA;
|
|
|
|
|
|
|
|
#pragma pack()
|
|
|
|
|
2008-12-10 03:02:38 +01:00
|
|
|
///
|
|
|
|
/// ISCSI CHAP Authentication Data
|
|
|
|
///
|
2007-12-24 03:20:21 +01:00
|
|
|
typedef struct _ISCSI_CHAP_AUTH_DATA {
|
|
|
|
ISCSI_CHAP_AUTH_CONFIG_NVDATA AuthConfig;
|
|
|
|
UINT32 InIdentifier;
|
|
|
|
UINT8 InChallenge[ISCSI_CHAP_AUTH_MAX_LEN];
|
|
|
|
UINT32 InChallengeLength;
|
|
|
|
//
|
|
|
|
// Calculated CHAP Response (CHAP_R) value
|
|
|
|
//
|
|
|
|
UINT8 CHAPResponse[ISCSI_CHAP_RSP_LEN];
|
|
|
|
|
|
|
|
//
|
|
|
|
// Auth-data to be sent out for mutual authentication
|
|
|
|
//
|
|
|
|
UINT32 OutIdentifier;
|
|
|
|
UINT8 OutChallenge[ISCSI_CHAP_AUTH_MAX_LEN];
|
|
|
|
UINT32 OutChallengeLength;
|
|
|
|
} ISCSI_CHAP_AUTH_DATA;
|
|
|
|
|
2008-04-17 10:28:51 +02:00
|
|
|
/**
|
|
|
|
This function checks the received iSCSI Login Response during the security
|
|
|
|
negotiation stage.
|
|
|
|
|
2008-12-10 03:02:38 +01:00
|
|
|
@param[in] Conn The iSCSI connection.
|
2008-04-17 10:28:51 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS The Login Response passed the CHAP validation.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
@retval EFI_PROTOCOL_ERROR Some kind of protocol error happend.
|
2008-12-12 08:03:44 +01:00
|
|
|
@retval Others Other errors as indicated.
|
2008-04-17 10:28:51 +02:00
|
|
|
**/
|
2007-12-24 03:20:21 +01:00
|
|
|
EFI_STATUS
|
|
|
|
IScsiCHAPOnRspReceived (
|
2008-12-14 13:25:48 +01:00
|
|
|
IN ISCSI_CONNECTION *Conn
|
2007-12-24 03:20:21 +01:00
|
|
|
);
|
2008-04-17 10:28:51 +02:00
|
|
|
/**
|
|
|
|
This function fills the CHAP authentication information into the login PDU
|
|
|
|
during the security negotiation stage in the iSCSI connection login.
|
|
|
|
|
2008-12-14 13:25:48 +01:00
|
|
|
@param[in] Conn The iSCSI connection.
|
|
|
|
@param[in, out] Pdu The PDU to send out.
|
2008-04-17 10:28:51 +02:00
|
|
|
|
|
|
|
@retval EFI_SUCCESS All check passed and the phase-related CHAP
|
|
|
|
authentication info is filled into the iSCSI PDU.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Failed to allocate memory.
|
|
|
|
@retval EFI_PROTOCOL_ERROR Some kind of protocol error happend.
|
|
|
|
**/
|
2007-12-24 03:20:21 +01:00
|
|
|
EFI_STATUS
|
|
|
|
IScsiCHAPToSendReq (
|
2008-12-14 13:25:48 +01:00
|
|
|
IN ISCSI_CONNECTION *Conn,
|
|
|
|
IN OUT NET_BUF *Pdu
|
2007-12-24 03:20:21 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|