1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * QLogic iSCSI Offload Driver 4*4882a593Smuzhiyun * Copyright (c) 2016 Cavium Inc. 5*4882a593Smuzhiyun */ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #ifndef NVM_ISCSI_CFG_H 8*4882a593Smuzhiyun #define NVM_ISCSI_CFG_H 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #define NUM_OF_ISCSI_TARGET_PER_PF 4 /* Defined as per the 11*4882a593Smuzhiyun * ISCSI IBFT constraint 12*4882a593Smuzhiyun */ 13*4882a593Smuzhiyun #define NUM_OF_ISCSI_PF_SUPPORTED 4 /* One PF per Port - 14*4882a593Smuzhiyun * assuming 4 port card 15*4882a593Smuzhiyun */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #define NVM_ISCSI_CFG_DHCP_NAME_MAX_LEN 256 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun union nvm_iscsi_dhcp_vendor_id { 20*4882a593Smuzhiyun u32 value[NVM_ISCSI_CFG_DHCP_NAME_MAX_LEN / 4]; 21*4882a593Smuzhiyun u8 byte[NVM_ISCSI_CFG_DHCP_NAME_MAX_LEN]; 22*4882a593Smuzhiyun }; 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun #define NVM_ISCSI_IPV4_ADDR_BYTE_LEN 4 25*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr { 26*4882a593Smuzhiyun u32 addr; 27*4882a593Smuzhiyun u8 byte[NVM_ISCSI_IPV4_ADDR_BYTE_LEN]; 28*4882a593Smuzhiyun }; 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun #define NVM_ISCSI_IPV6_ADDR_BYTE_LEN 16 31*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr { 32*4882a593Smuzhiyun u32 addr[4]; 33*4882a593Smuzhiyun u8 byte[NVM_ISCSI_IPV6_ADDR_BYTE_LEN]; 34*4882a593Smuzhiyun }; 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun struct nvm_iscsi_initiator_ipv4 { 37*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr addr; /* 0x0 */ 38*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr subnet_mask; /* 0x4 */ 39*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr gateway; /* 0x8 */ 40*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr primary_dns; /* 0xC */ 41*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr secondary_dns; /* 0x10 */ 42*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr dhcp_addr; /* 0x14 */ 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr isns_server; /* 0x18 */ 45*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr slp_server; /* 0x1C */ 46*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr primay_radius_server; /* 0x20 */ 47*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr secondary_radius_server; /* 0x24 */ 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr rsvd[4]; /* 0x28 */ 50*4882a593Smuzhiyun }; 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun struct nvm_iscsi_initiator_ipv6 { 53*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr addr; /* 0x0 */ 54*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr subnet_mask; /* 0x10 */ 55*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr gateway; /* 0x20 */ 56*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr primary_dns; /* 0x30 */ 57*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr secondary_dns; /* 0x40 */ 58*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr dhcp_addr; /* 0x50 */ 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr isns_server; /* 0x60 */ 61*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr slp_server; /* 0x70 */ 62*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr primay_radius_server; /* 0x80 */ 63*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr secondary_radius_server; /* 0x90 */ 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr rsvd[3]; /* 0xA0 */ 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun u32 config; /* 0xD0 */ 68*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IPV6_SUBNET_MASK_PREFIX_MASK 0x000000FF 69*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IPV6_SUBNET_MASK_PREFIX_OFFSET 0 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun u32 rsvd_1[3]; 72*4882a593Smuzhiyun }; 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun #define NVM_ISCSI_CFG_ISCSI_NAME_MAX_LEN 256 75*4882a593Smuzhiyun union nvm_iscsi_name { 76*4882a593Smuzhiyun u32 value[NVM_ISCSI_CFG_ISCSI_NAME_MAX_LEN / 4]; 77*4882a593Smuzhiyun u8 byte[NVM_ISCSI_CFG_ISCSI_NAME_MAX_LEN]; 78*4882a593Smuzhiyun }; 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun #define NVM_ISCSI_CFG_CHAP_NAME_MAX_LEN 256 81*4882a593Smuzhiyun union nvm_iscsi_chap_name { 82*4882a593Smuzhiyun u32 value[NVM_ISCSI_CFG_CHAP_NAME_MAX_LEN / 4]; 83*4882a593Smuzhiyun u8 byte[NVM_ISCSI_CFG_CHAP_NAME_MAX_LEN]; 84*4882a593Smuzhiyun }; 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun #define NVM_ISCSI_CFG_CHAP_PWD_MAX_LEN 16 /* md5 need per RFC1996 87*4882a593Smuzhiyun * is 16 octets 88*4882a593Smuzhiyun */ 89*4882a593Smuzhiyun union nvm_iscsi_chap_password { 90*4882a593Smuzhiyun u32 value[NVM_ISCSI_CFG_CHAP_PWD_MAX_LEN / 4]; 91*4882a593Smuzhiyun u8 byte[NVM_ISCSI_CFG_CHAP_PWD_MAX_LEN]; 92*4882a593Smuzhiyun }; 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun union nvm_iscsi_lun { 95*4882a593Smuzhiyun u8 byte[8]; 96*4882a593Smuzhiyun u32 value[2]; 97*4882a593Smuzhiyun }; 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun struct nvm_iscsi_generic { 100*4882a593Smuzhiyun u32 ctrl_flags; /* 0x0 */ 101*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_CHAP_ENABLED BIT(0) 102*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_DHCP_TCPIP_CONFIG_ENABLED BIT(1) 103*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_DHCP_ISCSI_CONFIG_ENABLED BIT(2) 104*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_IPV6_ENABLED BIT(3) 105*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_IPV4_FALLBACK_ENABLED BIT(4) 106*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_ISNS_WORLD_LOGIN BIT(5) 107*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_ISNS_SELECTIVE_LOGIN BIT(6) 108*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_ADDR_REDIRECT_ENABLED BIT(7) 109*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_CHAP_MUTUAL_ENABLED BIT(8) 110*4882a593Smuzhiyun 111*4882a593Smuzhiyun u32 timeout; /* 0x4 */ 112*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_DHCP_REQUEST_TIMEOUT_MASK 0x0000FFFF 113*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_DHCP_REQUEST_TIMEOUT_OFFSET 0 114*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_PORT_LOGIN_TIMEOUT_MASK 0xFFFF0000 115*4882a593Smuzhiyun #define NVM_ISCSI_CFG_GEN_PORT_LOGIN_TIMEOUT_OFFSET 16 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun union nvm_iscsi_dhcp_vendor_id dhcp_vendor_id; /* 0x8 */ 118*4882a593Smuzhiyun u32 rsvd[62]; /* 0x108 */ 119*4882a593Smuzhiyun }; 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun struct nvm_iscsi_initiator { 122*4882a593Smuzhiyun struct nvm_iscsi_initiator_ipv4 ipv4; /* 0x0 */ 123*4882a593Smuzhiyun struct nvm_iscsi_initiator_ipv6 ipv6; /* 0x38 */ 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun union nvm_iscsi_name initiator_name; /* 0x118 */ 126*4882a593Smuzhiyun union nvm_iscsi_chap_name chap_name; /* 0x218 */ 127*4882a593Smuzhiyun union nvm_iscsi_chap_password chap_password; /* 0x318 */ 128*4882a593Smuzhiyun 129*4882a593Smuzhiyun u32 generic_cont0; /* 0x398 */ 130*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_VLAN_MASK 0x0000FFFF 131*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_VLAN_OFFSET 0 132*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_MASK 0x00030000 133*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_OFFSET 16 134*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_4 1 135*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_6 2 136*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_4_AND_6 3 137*4882a593Smuzhiyun 138*4882a593Smuzhiyun u32 ctrl_flags; 139*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_IP_VERSION_PRIORITY_V6 BIT(0) 140*4882a593Smuzhiyun #define NVM_ISCSI_CFG_INITIATOR_VLAN_ENABLED BIT(1) 141*4882a593Smuzhiyun 142*4882a593Smuzhiyun u32 rsvd[116]; /* 0x32C */ 143*4882a593Smuzhiyun }; 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun struct nvm_iscsi_target { 146*4882a593Smuzhiyun u32 ctrl_flags; /* 0x0 */ 147*4882a593Smuzhiyun #define NVM_ISCSI_CFG_TARGET_ENABLED BIT(0) 148*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BOOT_TIME_LOGIN_STATUS BIT(1) 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun u32 generic_cont0; /* 0x4 */ 151*4882a593Smuzhiyun #define NVM_ISCSI_CFG_TARGET_TCP_PORT_MASK 0x0000FFFF 152*4882a593Smuzhiyun #define NVM_ISCSI_CFG_TARGET_TCP_PORT_OFFSET 0 153*4882a593Smuzhiyun 154*4882a593Smuzhiyun u32 ip_ver; 155*4882a593Smuzhiyun #define NVM_ISCSI_CFG_IPv4 4 156*4882a593Smuzhiyun #define NVM_ISCSI_CFG_IPv6 6 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun u32 rsvd_1[7]; /* 0x24 */ 159*4882a593Smuzhiyun union nvm_iscsi_ipv4_addr ipv4_addr; /* 0x28 */ 160*4882a593Smuzhiyun union nvm_iscsi_ipv6_addr ipv6_addr; /* 0x2C */ 161*4882a593Smuzhiyun union nvm_iscsi_lun lun; /* 0x3C */ 162*4882a593Smuzhiyun 163*4882a593Smuzhiyun union nvm_iscsi_name target_name; /* 0x44 */ 164*4882a593Smuzhiyun union nvm_iscsi_chap_name chap_name; /* 0x144 */ 165*4882a593Smuzhiyun union nvm_iscsi_chap_password chap_password; /* 0x244 */ 166*4882a593Smuzhiyun 167*4882a593Smuzhiyun u32 rsvd_2[107]; /* 0x2C4 */ 168*4882a593Smuzhiyun }; 169*4882a593Smuzhiyun 170*4882a593Smuzhiyun struct nvm_iscsi_block { 171*4882a593Smuzhiyun u32 id; /* 0x0 */ 172*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_MAPPED_PF_ID_MASK 0x0000000F 173*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_MAPPED_PF_ID_OFFSET 0 174*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_CTRL_FLAG_MASK 0x00000FF0 175*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_CTRL_FLAG_OFFSET 4 176*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_CTRL_FLAG_IS_NOT_EMPTY BIT(0) 177*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_CTRL_FLAG_PF_MAPPED BIT(1) 178*4882a593Smuzhiyun 179*4882a593Smuzhiyun u32 rsvd_1[5]; /* 0x4 */ 180*4882a593Smuzhiyun 181*4882a593Smuzhiyun struct nvm_iscsi_generic generic; /* 0x18 */ 182*4882a593Smuzhiyun struct nvm_iscsi_initiator initiator; /* 0x218 */ 183*4882a593Smuzhiyun struct nvm_iscsi_target target[NUM_OF_ISCSI_TARGET_PER_PF]; 184*4882a593Smuzhiyun /* 0x718 */ 185*4882a593Smuzhiyun 186*4882a593Smuzhiyun u32 rsvd_2[58]; /* 0x1718 */ 187*4882a593Smuzhiyun /* total size - 0x1800 - 6K block */ 188*4882a593Smuzhiyun }; 189*4882a593Smuzhiyun 190*4882a593Smuzhiyun struct nvm_iscsi_cfg { 191*4882a593Smuzhiyun u32 id; /* 0x0 */ 192*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_VERSION_MINOR_MASK 0x000000FF 193*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_VERSION_MAJOR_MASK 0x0000FF00 194*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_SIGNATURE_MASK 0xFFFF0000 195*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_SIGNATURE 0x49430000 /* IC - Iscsi 196*4882a593Smuzhiyun * Config 197*4882a593Smuzhiyun */ 198*4882a593Smuzhiyun 199*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_VERSION_MAJOR 0 200*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_VERSION_MINOR 10 201*4882a593Smuzhiyun #define NVM_ISCSI_CFG_BLK_VERSION ((NVM_ISCSI_CFG_BLK_VERSION_MAJOR << 8) | \ 202*4882a593Smuzhiyun NVM_ISCSI_CFG_BLK_VERSION_MINOR) 203*4882a593Smuzhiyun 204*4882a593Smuzhiyun struct nvm_iscsi_block block[NUM_OF_ISCSI_PF_SUPPORTED]; /* 0x4 */ 205*4882a593Smuzhiyun }; 206*4882a593Smuzhiyun 207*4882a593Smuzhiyun #endif 208