225 lines
6.2 KiB
C
225 lines
6.2 KiB
C
|
/*
|
||
|
* Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
|
||
|
* All rights reserved
|
||
|
* www.brocade.com
|
||
|
*
|
||
|
* Linux driver for Brocade Fibre Channel Host Bus Adapter.
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify it
|
||
|
* under the terms of the GNU General Public License (GPL) Version 2 as
|
||
|
* published by the Free Software Foundation
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful, but
|
||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
* General Public License for more details.
|
||
|
*/
|
||
|
|
||
|
#ifndef __FC_SP_H__
|
||
|
#define __FC_SP_H__
|
||
|
|
||
|
#include <protocol/types.h>
|
||
|
|
||
|
#pragma pack(1)
|
||
|
|
||
|
enum auth_els_flags{
|
||
|
FC_AUTH_ELS_MORE_FRAGS_FLAG = 0x80, /*! bit-7. More Fragments
|
||
|
* Follow
|
||
|
*/
|
||
|
FC_AUTH_ELS_CONCAT_FLAG = 0x40, /*! bit-6. Concatenation Flag */
|
||
|
FC_AUTH_ELS_SEQ_NUM_FLAG = 0x01 /*! bit-0. Sequence Number */
|
||
|
};
|
||
|
|
||
|
enum auth_msg_codes{
|
||
|
FC_AUTH_MC_AUTH_RJT = 0x0A, /*! Auth Reject */
|
||
|
FC_AUTH_MC_AUTH_NEG = 0x0B, /*! Auth Negotiate */
|
||
|
FC_AUTH_MC_AUTH_DONE = 0x0C, /*! Auth Done */
|
||
|
|
||
|
FC_AUTH_MC_DHCHAP_CHAL = 0x10, /*! DHCHAP Challenge */
|
||
|
FC_AUTH_MC_DHCHAP_REPLY = 0x11, /*! DHCHAP Reply */
|
||
|
FC_AUTH_MC_DHCHAP_SUCC = 0x12, /*! DHCHAP Success */
|
||
|
|
||
|
FC_AUTH_MC_FCAP_REQ = 0x13, /*! FCAP Request */
|
||
|
FC_AUTH_MC_FCAP_ACK = 0x14, /*! FCAP Acknowledge */
|
||
|
FC_AUTH_MC_FCAP_CONF = 0x15, /*! FCAP Confirm */
|
||
|
|
||
|
FC_AUTH_MC_FCPAP_INIT = 0x16, /*! FCPAP Init */
|
||
|
FC_AUTH_MC_FCPAP_ACC = 0x17, /*! FCPAP Accept */
|
||
|
FC_AUTH_MC_FCPAP_COMP = 0x18, /*! FCPAP Complete */
|
||
|
|
||
|
FC_AUTH_MC_IKE_SA_INIT = 0x22, /*! IKE SA INIT */
|
||
|
FC_AUTH_MC_IKE_SA_AUTH = 0x23, /*! IKE SA Auth */
|
||
|
FC_AUTH_MC_IKE_CREATE_CHILD_SA = 0x24, /*! IKE Create Child SA */
|
||
|
FC_AUTH_MC_IKE_INFO = 0x25, /*! IKE informational */
|
||
|
};
|
||
|
|
||
|
enum auth_proto_version{
|
||
|
FC_AUTH_PROTO_VER_1 = 1, /*! Protocol Version 1 */
|
||
|
};
|
||
|
|
||
|
enum {
|
||
|
FC_AUTH_ELS_COMMAND_CODE = 0x90,/*! Authentication ELS Command code */
|
||
|
FC_AUTH_PROTO_PARAM_LEN_SZ = 4, /*! Size of Proto Parameter Len Field */
|
||
|
FC_AUTH_PROTO_PARAM_VAL_SZ = 4, /*! Size of Proto Parameter Val Field */
|
||
|
FC_MAX_AUTH_SECRET_LEN = 256,
|
||
|
/*! Maximum secret string length */
|
||
|
FC_AUTH_NUM_USABLE_PROTO_LEN_SZ = 4,
|
||
|
/*! Size of usable protocols field */
|
||
|
FC_AUTH_RESP_VALUE_LEN_SZ = 4,
|
||
|
/*! Size of response value length */
|
||
|
FC_MAX_CHAP_KEY_LEN = 256, /*! Maximum md5 digest length */
|
||
|
FC_MAX_AUTH_RETRIES = 3, /*! Maximum number of retries */
|
||
|
FC_MD5_DIGEST_LEN = 16, /*! MD5 digest length */
|
||
|
FC_SHA1_DIGEST_LEN = 20, /*! SHA1 digest length */
|
||
|
FC_MAX_DHG_SUPPORTED = 1, /*! Maximum DH Groups supported */
|
||
|
FC_MAX_ALG_SUPPORTED = 1, /*! Maximum algorithms supported */
|
||
|
FC_MAX_PROTO_SUPPORTED = 1, /*! Maximum protocols supported */
|
||
|
FC_START_TXN_ID = 2, /*! Starting transaction ID */
|
||
|
};
|
||
|
|
||
|
enum auth_proto_id{
|
||
|
FC_AUTH_PROTO_DHCHAP = 0x00000001,
|
||
|
FC_AUTH_PROTO_FCAP = 0x00000002,
|
||
|
FC_AUTH_PROTO_FCPAP = 0x00000003,
|
||
|
FC_AUTH_PROTO_IKEv2 = 0x00000004,
|
||
|
FC_AUTH_PROTO_IKEv2_AUTH = 0x00000005,
|
||
|
};
|
||
|
|
||
|
struct auth_name_s{
|
||
|
u16 name_tag; /*! Name Tag = 1 for Authentication */
|
||
|
u16 name_len; /*! Name Length = 8 for Authentication
|
||
|
*/
|
||
|
wwn_t name; /*! Name. TODO - is this PWWN */
|
||
|
};
|
||
|
|
||
|
|
||
|
enum auth_hash_func{
|
||
|
FC_AUTH_HASH_FUNC_MD5 = 0x00000005,
|
||
|
FC_AUTH_HASH_FUNC_SHA_1 = 0x00000006,
|
||
|
};
|
||
|
|
||
|
enum auth_dh_gid{
|
||
|
FC_AUTH_DH_GID_0_DHG_NULL = 0x00000000,
|
||
|
FC_AUTH_DH_GID_1_DHG_1024 = 0x00000001,
|
||
|
FC_AUTH_DH_GID_2_DHG_1280 = 0x00000002,
|
||
|
FC_AUTH_DH_GID_3_DHG_1536 = 0x00000003,
|
||
|
FC_AUTH_DH_GID_4_DHG_2048 = 0x00000004,
|
||
|
FC_AUTH_DH_GID_6_DHG_3072 = 0x00000006,
|
||
|
FC_AUTH_DH_GID_7_DHG_4096 = 0x00000007,
|
||
|
FC_AUTH_DH_GID_8_DHG_6144 = 0x00000008,
|
||
|
FC_AUTH_DH_GID_9_DHG_8192 = 0x00000009,
|
||
|
};
|
||
|
|
||
|
struct auth_els_msg_s {
|
||
|
u8 auth_els_code; /* Authentication ELS Code (0x90) */
|
||
|
u8 auth_els_flag; /* Authentication ELS Flags */
|
||
|
u8 auth_msg_code; /* Authentication Message Code */
|
||
|
u8 proto_version; /* Protocol Version */
|
||
|
u32 msg_len; /* Message Length */
|
||
|
u32 trans_id; /* Transaction Identifier (T_ID) */
|
||
|
|
||
|
/* Msg payload follows... */
|
||
|
};
|
||
|
|
||
|
|
||
|
enum auth_neg_param_tags {
|
||
|
FC_AUTH_NEG_DHCHAP_HASHLIST = 0x0001,
|
||
|
FC_AUTH_NEG_DHCHAP_DHG_ID_LIST = 0x0002,
|
||
|
};
|
||
|
|
||
|
|
||
|
struct dhchap_param_format_s {
|
||
|
u16 tag; /*! Parameter Tag. See
|
||
|
* auth_neg_param_tags_t
|
||
|
*/
|
||
|
u16 word_cnt;
|
||
|
|
||
|
/* followed by variable length parameter value... */
|
||
|
};
|
||
|
|
||
|
struct auth_proto_params_s {
|
||
|
u32 proto_param_len;
|
||
|
u32 proto_id;
|
||
|
|
||
|
/*
|
||
|
* Followed by variable length Protocol specific parameters. DH-CHAP
|
||
|
* uses dhchap_param_format_t
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
struct auth_neg_msg_s {
|
||
|
struct auth_name_s auth_ini_name;
|
||
|
u32 usable_auth_protos;
|
||
|
struct auth_proto_params_s proto_params[1]; /*! (1..usable_auth_proto)
|
||
|
* protocol params
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
struct auth_dh_val_s {
|
||
|
u32 dh_val_len;
|
||
|
u32 dh_val[1];
|
||
|
};
|
||
|
|
||
|
struct auth_dhchap_chal_msg_s {
|
||
|
struct auth_els_msg_s hdr;
|
||
|
struct auth_name_s auth_responder_name; /* TODO VRK - is auth_name_t
|
||
|
* type OK?
|
||
|
*/
|
||
|
u32 hash_id;
|
||
|
u32 dh_grp_id;
|
||
|
u32 chal_val_len;
|
||
|
char chal_val[1];
|
||
|
|
||
|
/* ...followed by variable Challenge length/value and DH length/value */
|
||
|
};
|
||
|
|
||
|
|
||
|
enum auth_rjt_codes {
|
||
|
FC_AUTH_RJT_CODE_AUTH_FAILURE = 0x01,
|
||
|
FC_AUTH_RJT_CODE_LOGICAL_ERR = 0x02,
|
||
|
};
|
||
|
|
||
|
enum auth_rjt_code_exps {
|
||
|
FC_AUTH_CEXP_AUTH_MECH_NOT_USABLE = 0x01,
|
||
|
FC_AUTH_CEXP_DH_GROUP_NOT_USABLE = 0x02,
|
||
|
FC_AUTH_CEXP_HASH_FUNC_NOT_USABLE = 0x03,
|
||
|
FC_AUTH_CEXP_AUTH_XACT_STARTED = 0x04,
|
||
|
FC_AUTH_CEXP_AUTH_FAILED = 0x05,
|
||
|
FC_AUTH_CEXP_INCORRECT_PLD = 0x06,
|
||
|
FC_AUTH_CEXP_INCORRECT_PROTO_MSG = 0x07,
|
||
|
FC_AUTH_CEXP_RESTART_AUTH_PROTO = 0x08,
|
||
|
FC_AUTH_CEXP_AUTH_CONCAT_NOT_SUPP = 0x09,
|
||
|
FC_AUTH_CEXP_PROTO_VER_NOT_SUPP = 0x0A,
|
||
|
};
|
||
|
|
||
|
enum auth_status {
|
||
|
FC_AUTH_STATE_INPROGRESS = 0, /*! authentication in progress */
|
||
|
FC_AUTH_STATE_FAILED = 1, /*! authentication failed */
|
||
|
FC_AUTH_STATE_SUCCESS = 2 /*! authentication successful */
|
||
|
};
|
||
|
|
||
|
struct auth_rjt_msg_s {
|
||
|
struct auth_els_msg_s hdr;
|
||
|
u8 reason_code;
|
||
|
u8 reason_code_exp;
|
||
|
u8 rsvd[2];
|
||
|
};
|
||
|
|
||
|
|
||
|
struct auth_dhchap_neg_msg_s {
|
||
|
struct auth_els_msg_s hdr;
|
||
|
struct auth_neg_msg_s nego;
|
||
|
};
|
||
|
|
||
|
struct auth_dhchap_reply_msg_s {
|
||
|
struct auth_els_msg_s hdr;
|
||
|
|
||
|
/*
|
||
|
* followed by response value length & Value + DH Value Length & Value
|
||
|
*/
|
||
|
};
|
||
|
|
||
|
#pragma pack()
|
||
|
|
||
|
#endif /* __FC_SP_H__ */
|