| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 1 | /******************************************************************* | 
|  | 2 | * This file is part of the Emulex Linux Device Driver for         * | 
|  | 3 | * Fibre Channel Host Bus Adapters.                                * | 
| James Smart | 792581d | 2011-03-11 16:06:44 -0500 | [diff] [blame] | 4 | * Copyright (C) 2009-2011 Emulex.  All rights reserved.           * | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 5 | * EMULEX and SLI are trademarks of Emulex.                        * | 
|  | 6 | * www.emulex.com                                                  * | 
|  | 7 | *                                                                 * | 
|  | 8 | * This program is free software; you can redistribute it and/or   * | 
|  | 9 | * modify it under the terms of version 2 of the GNU General       * | 
|  | 10 | * Public License as published by the Free Software Foundation.    * | 
|  | 11 | * This program is distributed in the hope that it will be useful. * | 
|  | 12 | * ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND          * | 
|  | 13 | * WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY,  * | 
|  | 14 | * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT, ARE      * | 
|  | 15 | * DISCLAIMED, EXCEPT TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD * | 
|  | 16 | * TO BE LEGALLY INVALID.  See the GNU General Public License for  * | 
|  | 17 | * more details, a copy of which can be found in the file COPYING  * | 
|  | 18 | * included with this package.                                     * | 
|  | 19 | *******************************************************************/ | 
|  | 20 |  | 
|  | 21 | #define LPFC_ACTIVE_MBOX_WAIT_CNT               100 | 
| James Smart | 5af5eee | 2010-10-22 11:06:38 -0400 | [diff] [blame] | 22 | #define LPFC_XRI_EXCH_BUSY_WAIT_TMO		10000 | 
|  | 23 | #define LPFC_XRI_EXCH_BUSY_WAIT_T1   		10 | 
|  | 24 | #define LPFC_XRI_EXCH_BUSY_WAIT_T2              30000 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 25 | #define LPFC_RELEASE_NOTIFICATION_INTERVAL	32 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 26 | #define LPFC_RPI_LOW_WATER_MARK			10 | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 27 |  | 
| James Smart | a93ff37 | 2010-10-22 11:06:08 -0400 | [diff] [blame] | 28 | #define LPFC_UNREG_FCF                          1 | 
|  | 29 | #define LPFC_SKIP_UNREG_FCF                     0 | 
|  | 30 |  | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 31 | /* Amount of time in seconds for waiting FCF rediscovery to complete */ | 
|  | 32 | #define LPFC_FCF_REDISCOVER_WAIT_TMO		2000 /* msec */ | 
|  | 33 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 34 | /* Number of SGL entries can be posted in a 4KB nonembedded mbox command */ | 
|  | 35 | #define LPFC_NEMBED_MBOX_SGL_CNT		254 | 
|  | 36 |  | 
|  | 37 | /* Multi-queue arrangement for fast-path FCP work queues */ | 
|  | 38 | #define LPFC_FN_EQN_MAX       8 | 
|  | 39 | #define LPFC_SP_EQN_DEF       1 | 
| James Smart | def9c7a | 2009-12-21 17:02:28 -0500 | [diff] [blame] | 40 | #define LPFC_FP_EQN_DEF       4 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 41 | #define LPFC_FP_EQN_MIN       1 | 
|  | 42 | #define LPFC_FP_EQN_MAX       (LPFC_FN_EQN_MAX - LPFC_SP_EQN_DEF) | 
|  | 43 |  | 
|  | 44 | #define LPFC_FN_WQN_MAX       32 | 
|  | 45 | #define LPFC_SP_WQN_DEF       1 | 
|  | 46 | #define LPFC_FP_WQN_DEF       4 | 
|  | 47 | #define LPFC_FP_WQN_MIN       1 | 
|  | 48 | #define LPFC_FP_WQN_MAX       (LPFC_FN_WQN_MAX - LPFC_SP_WQN_DEF) | 
|  | 49 |  | 
|  | 50 | /* | 
|  | 51 | * Provide the default FCF Record attributes used by the driver | 
|  | 52 | * when nonFIP mode is configured and there is no other default | 
|  | 53 | * FCF Record attributes. | 
|  | 54 | */ | 
|  | 55 | #define LPFC_FCOE_FCF_DEF_INDEX	0 | 
|  | 56 | #define LPFC_FCOE_FCF_GET_FIRST	0xFFFF | 
|  | 57 | #define LPFC_FCOE_FCF_NEXT_NONE	0xFFFF | 
|  | 58 |  | 
| James Smart | dbb6b3a | 2010-06-08 18:31:37 -0400 | [diff] [blame] | 59 | #define LPFC_FCOE_NULL_VID	0xFFF | 
|  | 60 | #define LPFC_FCOE_IGNORE_VID	0xFFFF | 
|  | 61 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 62 | /* First 3 bytes of default FCF MAC is specified by FC_MAP */ | 
|  | 63 | #define LPFC_FCOE_FCF_MAC3	0xFF | 
|  | 64 | #define LPFC_FCOE_FCF_MAC4	0xFF | 
|  | 65 | #define LPFC_FCOE_FCF_MAC5	0xFE | 
|  | 66 | #define LPFC_FCOE_FCF_MAP0	0x0E | 
|  | 67 | #define LPFC_FCOE_FCF_MAP1	0xFC | 
|  | 68 | #define LPFC_FCOE_FCF_MAP2	0x00 | 
| James Smart | 98fc5dd | 2010-06-07 15:24:29 -0400 | [diff] [blame] | 69 | #define LPFC_FCOE_MAX_RCV_SIZE	0x800 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 70 | #define LPFC_FCOE_FKA_ADV_PER	0 | 
|  | 71 | #define LPFC_FCOE_FIP_PRIORITY	0x80 | 
|  | 72 |  | 
| James Smart | 6669f9b | 2009-10-02 15:16:45 -0400 | [diff] [blame] | 73 | #define sli4_sid_from_fc_hdr(fc_hdr)  \ | 
|  | 74 | ((fc_hdr)->fh_s_id[0] << 16 | \ | 
|  | 75 | (fc_hdr)->fh_s_id[1] <<  8 | \ | 
|  | 76 | (fc_hdr)->fh_s_id[2]) | 
|  | 77 |  | 
| James Smart | 5ffc266 | 2009-11-18 15:39:44 -0500 | [diff] [blame] | 78 | #define sli4_fctl_from_fc_hdr(fc_hdr)  \ | 
|  | 79 | ((fc_hdr)->fh_f_ctl[0] << 16 | \ | 
|  | 80 | (fc_hdr)->fh_f_ctl[1] <<  8 | \ | 
|  | 81 | (fc_hdr)->fh_f_ctl[2]) | 
|  | 82 |  | 
| James Smart | 88a2cfb | 2011-07-22 18:36:33 -0400 | [diff] [blame] | 83 | #define LPFC_FW_RESET_MAXIMUM_WAIT_10MS_CNT 12000 | 
|  | 84 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 85 | enum lpfc_sli4_queue_type { | 
|  | 86 | LPFC_EQ, | 
|  | 87 | LPFC_GCQ, | 
|  | 88 | LPFC_MCQ, | 
|  | 89 | LPFC_WCQ, | 
|  | 90 | LPFC_RCQ, | 
|  | 91 | LPFC_MQ, | 
|  | 92 | LPFC_WQ, | 
|  | 93 | LPFC_HRQ, | 
|  | 94 | LPFC_DRQ | 
|  | 95 | }; | 
|  | 96 |  | 
|  | 97 | /* The queue sub-type defines the functional purpose of the queue */ | 
|  | 98 | enum lpfc_sli4_queue_subtype { | 
|  | 99 | LPFC_NONE, | 
|  | 100 | LPFC_MBOX, | 
|  | 101 | LPFC_FCP, | 
|  | 102 | LPFC_ELS, | 
|  | 103 | LPFC_USOL | 
|  | 104 | }; | 
|  | 105 |  | 
|  | 106 | union sli4_qe { | 
|  | 107 | void *address; | 
|  | 108 | struct lpfc_eqe *eqe; | 
|  | 109 | struct lpfc_cqe *cqe; | 
|  | 110 | struct lpfc_mcqe *mcqe; | 
|  | 111 | struct lpfc_wcqe_complete *wcqe_complete; | 
|  | 112 | struct lpfc_wcqe_release *wcqe_release; | 
|  | 113 | struct sli4_wcqe_xri_aborted *wcqe_xri_aborted; | 
|  | 114 | struct lpfc_rcqe_complete *rcqe_complete; | 
|  | 115 | struct lpfc_mqe *mqe; | 
|  | 116 | union  lpfc_wqe *wqe; | 
|  | 117 | struct lpfc_rqe *rqe; | 
|  | 118 | }; | 
|  | 119 |  | 
|  | 120 | struct lpfc_queue { | 
|  | 121 | struct list_head list; | 
|  | 122 | enum lpfc_sli4_queue_type type; | 
|  | 123 | enum lpfc_sli4_queue_subtype subtype; | 
|  | 124 | struct lpfc_hba *phba; | 
|  | 125 | struct list_head child_list; | 
|  | 126 | uint32_t entry_count;	/* Number of entries to support on the queue */ | 
|  | 127 | uint32_t entry_size;	/* Size of each queue entry. */ | 
| James Smart | 73d91e5 | 2011-10-10 21:32:10 -0400 | [diff] [blame] | 128 | uint32_t entry_repost;	/* Count of entries before doorbell is rung */ | 
|  | 129 | #define LPFC_QUEUE_MIN_REPOST	8 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 130 | uint32_t queue_id;	/* Queue ID assigned by the hardware */ | 
| James Smart | 2a622bf | 2011-02-16 12:40:06 -0500 | [diff] [blame] | 131 | uint32_t assoc_qid;     /* Queue ID associated with, for CQ/WQ/MQ */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 132 | struct list_head page_list; | 
|  | 133 | uint32_t page_count;	/* Number of pages allocated for this queue */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 134 | uint32_t host_index;	/* The host's index for putting or getting */ | 
|  | 135 | uint32_t hba_index;	/* The last known hba index for get or put */ | 
|  | 136 | union sli4_qe qe[1];	/* array to index entries (must be last) */ | 
|  | 137 | }; | 
|  | 138 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 139 | struct lpfc_sli4_link { | 
|  | 140 | uint8_t speed; | 
|  | 141 | uint8_t duplex; | 
|  | 142 | uint8_t status; | 
| James Smart | 70f3c07 | 2010-12-15 17:57:33 -0500 | [diff] [blame] | 143 | uint8_t type; | 
|  | 144 | uint8_t number; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 145 | uint8_t fault; | 
| James Smart | 65467b6 | 2010-01-26 23:08:29 -0500 | [diff] [blame] | 146 | uint16_t logical_speed; | 
| James Smart | 70f3c07 | 2010-12-15 17:57:33 -0500 | [diff] [blame] | 147 | uint16_t topology; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 148 | }; | 
|  | 149 |  | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 150 | struct lpfc_fcf_rec { | 
|  | 151 | uint8_t  fabric_name[8]; | 
|  | 152 | uint8_t  switch_name[8]; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 153 | uint8_t  mac_addr[6]; | 
|  | 154 | uint16_t fcf_indx; | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 155 | uint32_t priority; | 
|  | 156 | uint16_t vlan_id; | 
|  | 157 | uint32_t addr_mode; | 
|  | 158 | uint32_t flag; | 
|  | 159 | #define BOOT_ENABLE	0x01 | 
|  | 160 | #define RECORD_VALID	0x02 | 
|  | 161 | }; | 
|  | 162 |  | 
| James Smart | 7d791df | 2011-07-22 18:37:52 -0400 | [diff] [blame] | 163 | struct lpfc_fcf_pri_rec { | 
|  | 164 | uint16_t fcf_index; | 
|  | 165 | #define LPFC_FCF_ON_PRI_LIST 0x0001 | 
|  | 166 | #define LPFC_FCF_FLOGI_FAILED 0x0002 | 
|  | 167 | uint16_t flag; | 
|  | 168 | uint32_t priority; | 
|  | 169 | }; | 
|  | 170 |  | 
|  | 171 | struct lpfc_fcf_pri { | 
|  | 172 | struct list_head list; | 
|  | 173 | struct lpfc_fcf_pri_rec fcf_rec; | 
|  | 174 | }; | 
|  | 175 |  | 
|  | 176 | /* | 
|  | 177 | * Maximum FCF table index, it is for driver internal book keeping, it | 
|  | 178 | * just needs to be no less than the supported HBA's FCF table size. | 
|  | 179 | */ | 
|  | 180 | #define LPFC_SLI4_FCF_TBL_INDX_MAX	32 | 
|  | 181 |  | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 182 | struct lpfc_fcf { | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 183 | uint16_t fcfi; | 
|  | 184 | uint32_t fcf_flag; | 
|  | 185 | #define FCF_AVAILABLE	0x01 /* FCF available for discovery */ | 
|  | 186 | #define FCF_REGISTERED	0x02 /* FCF registered with FW */ | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 187 | #define FCF_SCAN_DONE	0x04 /* FCF table scan done */ | 
|  | 188 | #define FCF_IN_USE	0x08 /* Atleast one discovery completed */ | 
| James Smart | 0c9ab6f | 2010-02-26 14:15:57 -0500 | [diff] [blame] | 189 | #define FCF_INIT_DISC	0x10 /* Initial FCF discovery */ | 
|  | 190 | #define FCF_DEAD_DISC	0x20 /* FCF DEAD fast FCF failover discovery */ | 
|  | 191 | #define FCF_ACVL_DISC	0x40 /* All CVL fast FCF failover discovery */ | 
|  | 192 | #define FCF_DISCOVERY	(FCF_INIT_DISC | FCF_DEAD_DISC | FCF_ACVL_DISC) | 
|  | 193 | #define FCF_REDISC_PEND	0x80 /* FCF rediscovery pending */ | 
|  | 194 | #define FCF_REDISC_EVT	0x100 /* FCF rediscovery event to worker thread */ | 
|  | 195 | #define FCF_REDISC_FOV	0x200 /* Post FCF rediscovery fast failover */ | 
| James Smart | a93ff37 | 2010-10-22 11:06:08 -0400 | [diff] [blame] | 196 | #define FCF_REDISC_PROG (FCF_REDISC_PEND | FCF_REDISC_EVT) | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 197 | uint32_t addr_mode; | 
| James Smart | 999d813 | 2010-03-15 11:24:56 -0400 | [diff] [blame] | 198 | uint32_t eligible_fcf_cnt; | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 199 | struct lpfc_fcf_rec current_rec; | 
|  | 200 | struct lpfc_fcf_rec failover_rec; | 
| James Smart | 7d791df | 2011-07-22 18:37:52 -0400 | [diff] [blame] | 201 | struct list_head fcf_pri_list; | 
|  | 202 | struct lpfc_fcf_pri fcf_pri[LPFC_SLI4_FCF_TBL_INDX_MAX]; | 
|  | 203 | uint32_t current_fcf_scan_pri; | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 204 | struct timer_list redisc_wait; | 
| James Smart | 0c9ab6f | 2010-02-26 14:15:57 -0500 | [diff] [blame] | 205 | unsigned long *fcf_rr_bmask; /* Eligible FCF indexes for RR failover */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 206 | }; | 
|  | 207 |  | 
| James Smart | 0c9ab6f | 2010-02-26 14:15:57 -0500 | [diff] [blame] | 208 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 209 | #define LPFC_REGION23_SIGNATURE "RG23" | 
|  | 210 | #define LPFC_REGION23_VERSION	1 | 
|  | 211 | #define LPFC_REGION23_LAST_REC  0xff | 
| James Smart | a0c87cb | 2009-07-19 10:01:10 -0400 | [diff] [blame] | 212 | #define DRIVER_SPECIFIC_TYPE	0xA2 | 
|  | 213 | #define LINUX_DRIVER_ID		0x20 | 
|  | 214 | #define PORT_STE_TYPE		0x1 | 
|  | 215 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 216 | struct lpfc_fip_param_hdr { | 
|  | 217 | uint8_t type; | 
|  | 218 | #define FCOE_PARAM_TYPE		0xA0 | 
|  | 219 | uint8_t length; | 
|  | 220 | #define FCOE_PARAM_LENGTH	2 | 
|  | 221 | uint8_t parm_version; | 
|  | 222 | #define FIPP_VERSION		0x01 | 
|  | 223 | uint8_t parm_flags; | 
|  | 224 | #define	lpfc_fip_param_hdr_fipp_mode_SHIFT	6 | 
|  | 225 | #define	lpfc_fip_param_hdr_fipp_mode_MASK	0x3 | 
|  | 226 | #define lpfc_fip_param_hdr_fipp_mode_WORD	parm_flags | 
| James Smart | 6a9c52c | 2009-10-02 15:16:51 -0400 | [diff] [blame] | 227 | #define	FIPP_MODE_ON				0x1 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 228 | #define	FIPP_MODE_OFF				0x0 | 
|  | 229 | #define FIPP_VLAN_VALID				0x1 | 
|  | 230 | }; | 
|  | 231 |  | 
|  | 232 | struct lpfc_fcoe_params { | 
|  | 233 | uint8_t fc_map[3]; | 
|  | 234 | uint8_t reserved1; | 
|  | 235 | uint16_t vlan_tag; | 
|  | 236 | uint8_t reserved[2]; | 
|  | 237 | }; | 
|  | 238 |  | 
|  | 239 | struct lpfc_fcf_conn_hdr { | 
|  | 240 | uint8_t type; | 
|  | 241 | #define FCOE_CONN_TBL_TYPE		0xA1 | 
|  | 242 | uint8_t length;   /* words */ | 
|  | 243 | uint8_t reserved[2]; | 
|  | 244 | }; | 
|  | 245 |  | 
|  | 246 | struct lpfc_fcf_conn_rec { | 
|  | 247 | uint16_t flags; | 
|  | 248 | #define	FCFCNCT_VALID		0x0001 | 
|  | 249 | #define	FCFCNCT_BOOT		0x0002 | 
|  | 250 | #define	FCFCNCT_PRIMARY		0x0004   /* if not set, Secondary */ | 
|  | 251 | #define	FCFCNCT_FBNM_VALID	0x0008 | 
|  | 252 | #define	FCFCNCT_SWNM_VALID	0x0010 | 
|  | 253 | #define	FCFCNCT_VLAN_VALID	0x0020 | 
|  | 254 | #define	FCFCNCT_AM_VALID	0x0040 | 
|  | 255 | #define	FCFCNCT_AM_PREFERRED	0x0080   /* if not set, AM Required */ | 
|  | 256 | #define	FCFCNCT_AM_SPMA		0x0100	 /* if not set, FPMA */ | 
|  | 257 |  | 
|  | 258 | uint16_t vlan_tag; | 
|  | 259 | uint8_t fabric_name[8]; | 
|  | 260 | uint8_t switch_name[8]; | 
|  | 261 | }; | 
|  | 262 |  | 
|  | 263 | struct lpfc_fcf_conn_entry { | 
|  | 264 | struct list_head list; | 
|  | 265 | struct lpfc_fcf_conn_rec conn_rec; | 
|  | 266 | }; | 
|  | 267 |  | 
|  | 268 | /* | 
|  | 269 | * Define the host's bootstrap mailbox.  This structure contains | 
|  | 270 | * the member attributes needed to create, use, and destroy the | 
|  | 271 | * bootstrap mailbox region. | 
|  | 272 | * | 
|  | 273 | * The macro definitions for the bmbx data structure are defined | 
|  | 274 | * in lpfc_hw4.h with the register definition. | 
|  | 275 | */ | 
|  | 276 | struct lpfc_bmbx { | 
|  | 277 | struct lpfc_dmabuf *dmabuf; | 
|  | 278 | struct dma_address dma_address; | 
|  | 279 | void *avirt; | 
|  | 280 | dma_addr_t aphys; | 
|  | 281 | uint32_t bmbx_size; | 
|  | 282 | }; | 
|  | 283 |  | 
|  | 284 | #define LPFC_EQE_SIZE LPFC_EQE_SIZE_4 | 
|  | 285 |  | 
|  | 286 | #define LPFC_EQE_SIZE_4B 	4 | 
|  | 287 | #define LPFC_EQE_SIZE_16B	16 | 
|  | 288 | #define LPFC_CQE_SIZE		16 | 
|  | 289 | #define LPFC_WQE_SIZE		64 | 
|  | 290 | #define LPFC_MQE_SIZE		256 | 
|  | 291 | #define LPFC_RQE_SIZE		8 | 
|  | 292 |  | 
|  | 293 | #define LPFC_EQE_DEF_COUNT	1024 | 
|  | 294 | #define LPFC_CQE_DEF_COUNT      256 | 
| James Smart | f112668 | 2009-06-10 17:22:44 -0400 | [diff] [blame] | 295 | #define LPFC_WQE_DEF_COUNT      256 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 296 | #define LPFC_MQE_DEF_COUNT      16 | 
|  | 297 | #define LPFC_RQE_DEF_COUNT	512 | 
|  | 298 |  | 
|  | 299 | #define LPFC_QUEUE_NOARM	false | 
|  | 300 | #define LPFC_QUEUE_REARM	true | 
|  | 301 |  | 
|  | 302 |  | 
|  | 303 | /* | 
|  | 304 | * SLI4 CT field defines | 
|  | 305 | */ | 
|  | 306 | #define SLI4_CT_RPI 0 | 
|  | 307 | #define SLI4_CT_VPI 1 | 
|  | 308 | #define SLI4_CT_VFI 2 | 
|  | 309 | #define SLI4_CT_FCFI 3 | 
|  | 310 |  | 
| James Smart | 28baac7 | 2010-02-12 14:42:03 -0500 | [diff] [blame] | 311 | #define LPFC_SLI4_FL1_MAX_SEGMENT_SIZE	0x10000 | 
|  | 312 | #define LPFC_SLI4_FL1_MAX_BUF_SIZE	0X2000 | 
|  | 313 | #define LPFC_SLI4_MIN_BUF_SIZE		0x400 | 
|  | 314 | #define LPFC_SLI4_MAX_BUF_SIZE		0x20000 | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 315 |  | 
|  | 316 | /* | 
|  | 317 | * SLI4 specific data structures | 
|  | 318 | */ | 
|  | 319 | struct lpfc_max_cfg_param { | 
|  | 320 | uint16_t max_xri; | 
|  | 321 | uint16_t xri_base; | 
|  | 322 | uint16_t xri_used; | 
|  | 323 | uint16_t max_rpi; | 
|  | 324 | uint16_t rpi_base; | 
|  | 325 | uint16_t rpi_used; | 
|  | 326 | uint16_t max_vpi; | 
|  | 327 | uint16_t vpi_base; | 
|  | 328 | uint16_t vpi_used; | 
|  | 329 | uint16_t max_vfi; | 
|  | 330 | uint16_t vfi_base; | 
|  | 331 | uint16_t vfi_used; | 
|  | 332 | uint16_t max_fcfi; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 333 | uint16_t fcfi_used; | 
|  | 334 | uint16_t max_eq; | 
|  | 335 | uint16_t max_rq; | 
|  | 336 | uint16_t max_cq; | 
|  | 337 | uint16_t max_wq; | 
|  | 338 | }; | 
|  | 339 |  | 
|  | 340 | struct lpfc_hba; | 
|  | 341 | /* SLI4 HBA multi-fcp queue handler struct */ | 
|  | 342 | struct lpfc_fcp_eq_hdl { | 
|  | 343 | uint32_t idx; | 
|  | 344 | struct lpfc_hba *phba; | 
|  | 345 | }; | 
|  | 346 |  | 
| James Smart | 28baac7 | 2010-02-12 14:42:03 -0500 | [diff] [blame] | 347 | /* Port Capabilities for SLI4 Parameters */ | 
|  | 348 | struct lpfc_pc_sli4_params { | 
|  | 349 | uint32_t supported; | 
|  | 350 | uint32_t if_type; | 
|  | 351 | uint32_t sli_rev; | 
|  | 352 | uint32_t sli_family; | 
|  | 353 | uint32_t featurelevel_1; | 
|  | 354 | uint32_t featurelevel_2; | 
|  | 355 | uint32_t proto_types; | 
|  | 356 | #define LPFC_SLI4_PROTO_FCOE	0x0000001 | 
|  | 357 | #define LPFC_SLI4_PROTO_FC	0x0000002 | 
|  | 358 | #define LPFC_SLI4_PROTO_NIC	0x0000004 | 
|  | 359 | #define LPFC_SLI4_PROTO_ISCSI	0x0000008 | 
|  | 360 | #define LPFC_SLI4_PROTO_RDMA	0x0000010 | 
|  | 361 | uint32_t sge_supp_len; | 
|  | 362 | uint32_t if_page_sz; | 
|  | 363 | uint32_t rq_db_window; | 
|  | 364 | uint32_t loopbk_scope; | 
|  | 365 | uint32_t eq_pages_max; | 
|  | 366 | uint32_t eqe_size; | 
|  | 367 | uint32_t cq_pages_max; | 
|  | 368 | uint32_t cqe_size; | 
|  | 369 | uint32_t mq_pages_max; | 
|  | 370 | uint32_t mqe_size; | 
|  | 371 | uint32_t mq_elem_cnt; | 
|  | 372 | uint32_t wq_pages_max; | 
|  | 373 | uint32_t wqe_size; | 
|  | 374 | uint32_t rq_pages_max; | 
|  | 375 | uint32_t rqe_size; | 
|  | 376 | uint32_t hdr_pages_max; | 
|  | 377 | uint32_t hdr_size; | 
|  | 378 | uint32_t hdr_pp_align; | 
|  | 379 | uint32_t sgl_pages_max; | 
|  | 380 | uint32_t sgl_pp_align; | 
| James Smart | fedd3b7 | 2011-02-16 12:39:24 -0500 | [diff] [blame] | 381 | uint8_t cqv; | 
|  | 382 | uint8_t mqv; | 
|  | 383 | uint8_t wqv; | 
|  | 384 | uint8_t rqv; | 
| James Smart | 28baac7 | 2010-02-12 14:42:03 -0500 | [diff] [blame] | 385 | }; | 
|  | 386 |  | 
| James Smart | 912e3ac | 2011-05-24 11:42:11 -0400 | [diff] [blame] | 387 | struct lpfc_iov { | 
|  | 388 | uint32_t pf_number; | 
|  | 389 | uint32_t vf_number; | 
|  | 390 | }; | 
|  | 391 |  | 
| James Smart | cd1c830 | 2011-10-10 21:33:25 -0400 | [diff] [blame] | 392 | struct lpfc_sli4_lnk_info { | 
|  | 393 | uint8_t lnk_dv; | 
|  | 394 | #define LPFC_LNK_DAT_INVAL	0 | 
|  | 395 | #define LPFC_LNK_DAT_VAL	1 | 
|  | 396 | uint8_t lnk_tp; | 
|  | 397 | #define LPFC_LNK_GE	0x0 /* FCoE */ | 
|  | 398 | #define LPFC_LNK_FC	0x1 /* FC   */ | 
|  | 399 | uint8_t lnk_no; | 
|  | 400 | }; | 
|  | 401 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 402 | /* SLI4 HBA data structure entries */ | 
|  | 403 | struct lpfc_sli4_hba { | 
|  | 404 | void __iomem *conf_regs_memmap_p; /* Kernel memory mapped address for | 
|  | 405 | PCI BAR0, config space registers */ | 
|  | 406 | void __iomem *ctrl_regs_memmap_p; /* Kernel memory mapped address for | 
|  | 407 | PCI BAR1, control registers */ | 
|  | 408 | void __iomem *drbl_regs_memmap_p; /* Kernel memory mapped address for | 
|  | 409 | PCI BAR2, doorbell registers */ | 
| James Smart | 2fcee4b | 2010-12-15 17:57:46 -0500 | [diff] [blame] | 410 | union { | 
|  | 411 | struct { | 
|  | 412 | /* IF Type 0, BAR 0 PCI cfg space reg mem map */ | 
|  | 413 | void __iomem *UERRLOregaddr; | 
|  | 414 | void __iomem *UERRHIregaddr; | 
|  | 415 | void __iomem *UEMASKLOregaddr; | 
|  | 416 | void __iomem *UEMASKHIregaddr; | 
|  | 417 | } if_type0; | 
|  | 418 | struct { | 
|  | 419 | /* IF Type 2, BAR 0 PCI cfg space reg mem map. */ | 
|  | 420 | void __iomem *STATUSregaddr; | 
|  | 421 | void __iomem *CTRLregaddr; | 
|  | 422 | void __iomem *ERR1regaddr; | 
|  | 423 | void __iomem *ERR2regaddr; | 
|  | 424 | } if_type2; | 
|  | 425 | } u; | 
|  | 426 |  | 
|  | 427 | /* IF type 0, BAR1 and if type 2, Bar 0 CSR register memory map */ | 
|  | 428 | void __iomem *PSMPHRregaddr; | 
|  | 429 |  | 
|  | 430 | /* Well-known SLI INTF register memory map. */ | 
|  | 431 | void __iomem *SLIINTFregaddr; | 
|  | 432 |  | 
|  | 433 | /* IF type 0, BAR 1 function CSR register memory map */ | 
|  | 434 | void __iomem *ISRregaddr;	/* HST_ISR register */ | 
|  | 435 | void __iomem *IMRregaddr;	/* HST_IMR register */ | 
|  | 436 | void __iomem *ISCRregaddr;	/* HST_ISCR register */ | 
|  | 437 | /* IF type 0, BAR 0 and if type 2, BAR 0 doorbell register memory map */ | 
|  | 438 | void __iomem *RQDBregaddr;	/* RQ_DOORBELL register */ | 
|  | 439 | void __iomem *WQDBregaddr;	/* WQ_DOORBELL register */ | 
|  | 440 | void __iomem *EQCQDBregaddr;	/* EQCQ_DOORBELL register */ | 
|  | 441 | void __iomem *MQDBregaddr;	/* MQ_DOORBELL register */ | 
|  | 442 | void __iomem *BMBXregaddr;	/* BootStrap MBX register */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 443 |  | 
| James Smart | a747c9c | 2009-11-18 15:41:10 -0500 | [diff] [blame] | 444 | uint32_t ue_mask_lo; | 
|  | 445 | uint32_t ue_mask_hi; | 
| James Smart | 28baac7 | 2010-02-12 14:42:03 -0500 | [diff] [blame] | 446 | struct lpfc_register sli_intf; | 
|  | 447 | struct lpfc_pc_sli4_params pc_sli4_params; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 448 | struct msix_entry *msix_entries; | 
|  | 449 | uint32_t cfg_eqn; | 
| James Smart | 75baf69 | 2010-06-08 18:31:21 -0400 | [diff] [blame] | 450 | uint32_t msix_vec_nr; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 451 | struct lpfc_fcp_eq_hdl *fcp_eq_hdl; /* FCP per-WQ handle */ | 
|  | 452 | /* Pointers to the constructed SLI4 queues */ | 
|  | 453 | struct lpfc_queue **fp_eq; /* Fast-path event queue */ | 
|  | 454 | struct lpfc_queue *sp_eq;  /* Slow-path event queue */ | 
|  | 455 | struct lpfc_queue **fcp_wq;/* Fast-path FCP work queue */ | 
|  | 456 | struct lpfc_queue *mbx_wq; /* Slow-path MBOX work queue */ | 
|  | 457 | struct lpfc_queue *els_wq; /* Slow-path ELS work queue */ | 
|  | 458 | struct lpfc_queue *hdr_rq; /* Slow-path Header Receive queue */ | 
|  | 459 | struct lpfc_queue *dat_rq; /* Slow-path Data Receive queue */ | 
|  | 460 | struct lpfc_queue **fcp_cq;/* Fast-path FCP compl queue */ | 
|  | 461 | struct lpfc_queue *mbx_cq; /* Slow-path mailbox complete queue */ | 
|  | 462 | struct lpfc_queue *els_cq; /* Slow-path ELS response complete queue */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 463 |  | 
|  | 464 | /* Setup information for various queue parameters */ | 
|  | 465 | int eq_esize; | 
|  | 466 | int eq_ecount; | 
|  | 467 | int cq_esize; | 
|  | 468 | int cq_ecount; | 
|  | 469 | int wq_esize; | 
|  | 470 | int wq_ecount; | 
|  | 471 | int mq_esize; | 
|  | 472 | int mq_ecount; | 
|  | 473 | int rq_esize; | 
|  | 474 | int rq_ecount; | 
|  | 475 | #define LPFC_SP_EQ_MAX_INTR_SEC         10000 | 
|  | 476 | #define LPFC_FP_EQ_MAX_INTR_SEC         10000 | 
|  | 477 |  | 
|  | 478 | uint32_t intr_enable; | 
|  | 479 | struct lpfc_bmbx bmbx; | 
|  | 480 | struct lpfc_max_cfg_param max_cfg_param; | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 481 | uint16_t extents_in_use; /* must allocate resource extents. */ | 
|  | 482 | uint16_t rpi_hdrs_in_use; /* must post rpi hdrs if set. */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 483 | uint16_t next_xri; /* last_xri - max_cfg_param.xri_base = used */ | 
|  | 484 | uint16_t next_rpi; | 
|  | 485 | uint16_t scsi_xri_max; | 
|  | 486 | uint16_t scsi_xri_cnt; | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 487 | uint16_t scsi_xri_start; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 488 | struct list_head lpfc_free_sgl_list; | 
|  | 489 | struct list_head lpfc_sgl_list; | 
|  | 490 | struct lpfc_sglq **lpfc_els_sgl_array; | 
|  | 491 | struct list_head lpfc_abts_els_sgl_list; | 
|  | 492 | struct lpfc_scsi_buf **lpfc_scsi_psb_array; | 
|  | 493 | struct list_head lpfc_abts_scsi_buf_list; | 
|  | 494 | uint32_t total_sglq_bufs; | 
|  | 495 | struct lpfc_sglq **lpfc_sglq_active_list; | 
|  | 496 | struct list_head lpfc_rpi_hdr_list; | 
|  | 497 | unsigned long *rpi_bmask; | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 498 | uint16_t *rpi_ids; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 499 | uint16_t rpi_count; | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 500 | struct list_head lpfc_rpi_blk_list; | 
|  | 501 | unsigned long *xri_bmask; | 
|  | 502 | uint16_t *xri_ids; | 
|  | 503 | uint16_t xri_count; | 
|  | 504 | struct list_head lpfc_xri_blk_list; | 
|  | 505 | unsigned long *vfi_bmask; | 
|  | 506 | uint16_t *vfi_ids; | 
|  | 507 | uint16_t vfi_count; | 
|  | 508 | struct list_head lpfc_vfi_blk_list; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 509 | struct lpfc_sli4_flags sli4_flags; | 
| James Smart | 45ed119 | 2009-10-02 15:17:02 -0400 | [diff] [blame] | 510 | struct list_head sp_queue_event; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 511 | struct list_head sp_cqe_event_pool; | 
|  | 512 | struct list_head sp_asynce_work_queue; | 
|  | 513 | struct list_head sp_fcp_xri_aborted_work_queue; | 
|  | 514 | struct list_head sp_els_xri_aborted_work_queue; | 
|  | 515 | struct list_head sp_unsol_work_queue; | 
|  | 516 | struct lpfc_sli4_link link_state; | 
| James Smart | cd1c830 | 2011-10-10 21:33:25 -0400 | [diff] [blame] | 517 | struct lpfc_sli4_lnk_info lnk_info; | 
|  | 518 | uint32_t pport_name_sta; | 
|  | 519 | #define LPFC_SLI4_PPNAME_NON	0 | 
|  | 520 | #define LPFC_SLI4_PPNAME_GET	1 | 
| James Smart | 912e3ac | 2011-05-24 11:42:11 -0400 | [diff] [blame] | 521 | struct lpfc_iov iov; | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 522 | spinlock_t abts_scsi_buf_list_lock; /* list of aborted SCSI IOs */ | 
|  | 523 | spinlock_t abts_sgl_list_lock; /* list of aborted els IOs */ | 
|  | 524 | }; | 
|  | 525 |  | 
|  | 526 | enum lpfc_sge_type { | 
|  | 527 | GEN_BUFF_TYPE, | 
|  | 528 | SCSI_BUFF_TYPE | 
|  | 529 | }; | 
|  | 530 |  | 
| James Smart | 0f65ff6 | 2010-02-26 14:14:23 -0500 | [diff] [blame] | 531 | enum lpfc_sgl_state { | 
|  | 532 | SGL_FREED, | 
|  | 533 | SGL_ALLOCATED, | 
|  | 534 | SGL_XRI_ABORTED | 
|  | 535 | }; | 
|  | 536 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 537 | struct lpfc_sglq { | 
|  | 538 | /* lpfc_sglqs are used in double linked lists */ | 
|  | 539 | struct list_head list; | 
|  | 540 | struct list_head clist; | 
|  | 541 | enum lpfc_sge_type buff_type; /* is this a scsi sgl */ | 
| James Smart | 0f65ff6 | 2010-02-26 14:14:23 -0500 | [diff] [blame] | 542 | enum lpfc_sgl_state state; | 
| James Smart | 19ca760 | 2010-11-20 23:11:55 -0500 | [diff] [blame] | 543 | struct lpfc_nodelist *ndlp; /* ndlp associated with IO */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 544 | uint16_t iotag;         /* pre-assigned IO tag */ | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 545 | uint16_t sli4_lxritag;  /* logical pre-assigned xri. */ | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 546 | uint16_t sli4_xritag;   /* pre-assigned XRI, (OXID) tag. */ | 
|  | 547 | struct sli4_sge *sgl;	/* pre-assigned SGL */ | 
|  | 548 | void *virt;		/* virtual address. */ | 
|  | 549 | dma_addr_t phys;	/* physical address */ | 
|  | 550 | }; | 
|  | 551 |  | 
|  | 552 | struct lpfc_rpi_hdr { | 
|  | 553 | struct list_head list; | 
|  | 554 | uint32_t len; | 
|  | 555 | struct lpfc_dmabuf *dmabuf; | 
|  | 556 | uint32_t page_count; | 
|  | 557 | uint32_t start_rpi; | 
|  | 558 | }; | 
|  | 559 |  | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 560 | struct lpfc_rsrc_blks { | 
|  | 561 | struct list_head list; | 
|  | 562 | uint16_t rsrc_start; | 
|  | 563 | uint16_t rsrc_size; | 
|  | 564 | uint16_t rsrc_used; | 
|  | 565 | }; | 
|  | 566 |  | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 567 | /* | 
|  | 568 | * SLI4 specific function prototypes | 
|  | 569 | */ | 
|  | 570 | int lpfc_pci_function_reset(struct lpfc_hba *); | 
| James Smart | 73d91e5 | 2011-10-10 21:32:10 -0400 | [diff] [blame] | 571 | int lpfc_sli4_pdev_status_reg_wait(struct lpfc_hba *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 572 | int lpfc_sli4_hba_setup(struct lpfc_hba *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 573 | int lpfc_sli4_config(struct lpfc_hba *, struct lpfcMboxq *, uint8_t, | 
|  | 574 | uint8_t, uint32_t, bool); | 
|  | 575 | void lpfc_sli4_mbox_cmd_free(struct lpfc_hba *, struct lpfcMboxq *); | 
|  | 576 | void lpfc_sli4_mbx_sge_set(struct lpfcMboxq *, uint32_t, dma_addr_t, uint32_t); | 
|  | 577 | void lpfc_sli4_mbx_sge_get(struct lpfcMboxq *, uint32_t, | 
|  | 578 | struct lpfc_mbx_sge *); | 
| James Smart | 0c9ab6f | 2010-02-26 14:15:57 -0500 | [diff] [blame] | 579 | int lpfc_sli4_mbx_read_fcf_rec(struct lpfc_hba *, struct lpfcMboxq *, | 
|  | 580 | uint16_t); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 581 |  | 
|  | 582 | void lpfc_sli4_hba_reset(struct lpfc_hba *); | 
|  | 583 | struct lpfc_queue *lpfc_sli4_queue_alloc(struct lpfc_hba *, uint32_t, | 
|  | 584 | uint32_t); | 
|  | 585 | void lpfc_sli4_queue_free(struct lpfc_queue *); | 
|  | 586 | uint32_t lpfc_eq_create(struct lpfc_hba *, struct lpfc_queue *, uint16_t); | 
|  | 587 | uint32_t lpfc_cq_create(struct lpfc_hba *, struct lpfc_queue *, | 
|  | 588 | struct lpfc_queue *, uint32_t, uint32_t); | 
| James Smart | b19a061 | 2010-04-06 14:48:51 -0400 | [diff] [blame] | 589 | int32_t lpfc_mq_create(struct lpfc_hba *, struct lpfc_queue *, | 
|  | 590 | struct lpfc_queue *, uint32_t); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 591 | uint32_t lpfc_wq_create(struct lpfc_hba *, struct lpfc_queue *, | 
|  | 592 | struct lpfc_queue *, uint32_t); | 
|  | 593 | uint32_t lpfc_rq_create(struct lpfc_hba *, struct lpfc_queue *, | 
|  | 594 | struct lpfc_queue *, struct lpfc_queue *, uint32_t); | 
| James Smart | 73d91e5 | 2011-10-10 21:32:10 -0400 | [diff] [blame] | 595 | void lpfc_rq_adjust_repost(struct lpfc_hba *, struct lpfc_queue *, int); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 596 | uint32_t lpfc_eq_destroy(struct lpfc_hba *, struct lpfc_queue *); | 
|  | 597 | uint32_t lpfc_cq_destroy(struct lpfc_hba *, struct lpfc_queue *); | 
|  | 598 | uint32_t lpfc_mq_destroy(struct lpfc_hba *, struct lpfc_queue *); | 
|  | 599 | uint32_t lpfc_wq_destroy(struct lpfc_hba *, struct lpfc_queue *); | 
|  | 600 | uint32_t lpfc_rq_destroy(struct lpfc_hba *, struct lpfc_queue *, | 
|  | 601 | struct lpfc_queue *); | 
|  | 602 | int lpfc_sli4_queue_setup(struct lpfc_hba *); | 
|  | 603 | void lpfc_sli4_queue_unset(struct lpfc_hba *); | 
|  | 604 | int lpfc_sli4_post_sgl(struct lpfc_hba *, dma_addr_t, dma_addr_t, uint16_t); | 
|  | 605 | int lpfc_sli4_repost_scsi_sgl_list(struct lpfc_hba *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 606 | uint16_t lpfc_sli4_next_xritag(struct lpfc_hba *); | 
|  | 607 | int lpfc_sli4_post_async_mbox(struct lpfc_hba *); | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 608 | int lpfc_sli4_post_els_sgl_list(struct lpfc_hba *phba); | 
|  | 609 | int lpfc_sli4_post_els_sgl_list_ext(struct lpfc_hba *phba); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 610 | int lpfc_sli4_post_scsi_sgl_block(struct lpfc_hba *, struct list_head *, int); | 
| James Smart | 6d368e5 | 2011-05-24 11:44:12 -0400 | [diff] [blame] | 611 | int lpfc_sli4_post_scsi_sgl_blk_ext(struct lpfc_hba *, struct list_head *, | 
|  | 612 | int); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 613 | struct lpfc_cq_event *__lpfc_sli4_cq_event_alloc(struct lpfc_hba *); | 
|  | 614 | struct lpfc_cq_event *lpfc_sli4_cq_event_alloc(struct lpfc_hba *); | 
|  | 615 | void __lpfc_sli4_cq_event_release(struct lpfc_hba *, struct lpfc_cq_event *); | 
|  | 616 | void lpfc_sli4_cq_event_release(struct lpfc_hba *, struct lpfc_cq_event *); | 
|  | 617 | int lpfc_sli4_init_rpi_hdrs(struct lpfc_hba *); | 
|  | 618 | int lpfc_sli4_post_rpi_hdr(struct lpfc_hba *, struct lpfc_rpi_hdr *); | 
|  | 619 | int lpfc_sli4_post_all_rpi_hdrs(struct lpfc_hba *); | 
|  | 620 | struct lpfc_rpi_hdr *lpfc_sli4_create_rpi_hdr(struct lpfc_hba *); | 
|  | 621 | void lpfc_sli4_remove_rpi_hdrs(struct lpfc_hba *); | 
|  | 622 | int lpfc_sli4_alloc_rpi(struct lpfc_hba *); | 
|  | 623 | void lpfc_sli4_free_rpi(struct lpfc_hba *, int); | 
|  | 624 | void lpfc_sli4_remove_rpis(struct lpfc_hba *); | 
|  | 625 | void lpfc_sli4_async_event_proc(struct lpfc_hba *); | 
| James Smart | ecfd03c | 2010-02-12 14:41:27 -0500 | [diff] [blame] | 626 | void lpfc_sli4_fcf_redisc_event_proc(struct lpfc_hba *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 627 | int lpfc_sli4_resume_rpi(struct lpfc_nodelist *); | 
|  | 628 | void lpfc_sli4_fcp_xri_abort_event_proc(struct lpfc_hba *); | 
|  | 629 | void lpfc_sli4_els_xri_abort_event_proc(struct lpfc_hba *); | 
|  | 630 | void lpfc_sli4_fcp_xri_aborted(struct lpfc_hba *, | 
|  | 631 | struct sli4_wcqe_xri_aborted *); | 
|  | 632 | void lpfc_sli4_els_xri_aborted(struct lpfc_hba *, | 
|  | 633 | struct sli4_wcqe_xri_aborted *); | 
| James Smart | 1151e3e | 2011-02-16 12:39:35 -0500 | [diff] [blame] | 634 | void lpfc_sli4_vport_delete_els_xri_aborted(struct lpfc_vport *); | 
|  | 635 | void lpfc_sli4_vport_delete_fcp_xri_aborted(struct lpfc_vport *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 636 | int lpfc_sli4_brdreset(struct lpfc_hba *); | 
|  | 637 | int lpfc_sli4_add_fcf_record(struct lpfc_hba *, struct fcf_record *); | 
|  | 638 | void lpfc_sli_remove_dflt_fcf(struct lpfc_hba *); | 
|  | 639 | int lpfc_sli4_get_els_iocb_cnt(struct lpfc_hba *); | 
| James Smart | 76a95d7 | 2010-11-20 23:11:48 -0500 | [diff] [blame] | 640 | int lpfc_sli4_init_vpi(struct lpfc_vport *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 641 | uint32_t lpfc_sli4_cq_release(struct lpfc_queue *, bool); | 
|  | 642 | uint32_t lpfc_sli4_eq_release(struct lpfc_queue *, bool); | 
|  | 643 | void lpfc_sli4_fcfi_unreg(struct lpfc_hba *, uint16_t); | 
| James Smart | 0c9ab6f | 2010-02-26 14:15:57 -0500 | [diff] [blame] | 644 | int lpfc_sli4_fcf_scan_read_fcf_rec(struct lpfc_hba *, uint16_t); | 
|  | 645 | int lpfc_sli4_fcf_rr_read_fcf_rec(struct lpfc_hba *, uint16_t); | 
|  | 646 | int lpfc_sli4_read_fcf_rec(struct lpfc_hba *, uint16_t); | 
|  | 647 | void lpfc_mbx_cmpl_fcf_scan_read_fcf_rec(struct lpfc_hba *, LPFC_MBOXQ_t *); | 
|  | 648 | void lpfc_mbx_cmpl_fcf_rr_read_fcf_rec(struct lpfc_hba *, LPFC_MBOXQ_t *); | 
|  | 649 | void lpfc_mbx_cmpl_read_fcf_rec(struct lpfc_hba *, LPFC_MBOXQ_t *); | 
|  | 650 | int lpfc_sli4_unregister_fcf(struct lpfc_hba *); | 
| James Smart | da0436e | 2009-05-22 14:51:39 -0400 | [diff] [blame] | 651 | int lpfc_sli4_post_status_check(struct lpfc_hba *); | 
| James Smart | a183a15 | 2011-10-10 21:32:43 -0400 | [diff] [blame] | 652 | uint8_t lpfc_sli_config_mbox_subsys_get(struct lpfc_hba *, LPFC_MBOXQ_t *); | 
|  | 653 | uint8_t lpfc_sli_config_mbox_opcode_get(struct lpfc_hba *, LPFC_MBOXQ_t *); |