2 * QLogic Fibre Channel HBA Driver
3 * Copyright (c) 2003-2014 QLogic Corporation
5 * See LICENSE.qla2xxx for copyright and licensing details.
8 #include "qla_target.h"
10 * qla24xx_calc_iocbs() - Determine number of Command Type 3 and
11 * Continuation Type 1 IOCBs to allocate.
14 * @dsds: number of data segment decriptors needed
16 * Returns the number of IOCB entries needed to store @dsds.
18 static inline uint16_t
19 qla24xx_calc_iocbs(scsi_qla_host_t
*vha
, uint16_t dsds
)
25 iocbs
+= (dsds
- 1) / 5;
33 * qla2x00_debounce_register
37 * port = register address.
42 static __inline__
uint16_t
43 qla2x00_debounce_register(volatile uint16_t __iomem
*addr
)
45 volatile uint16_t first
;
46 volatile uint16_t second
;
49 first
= RD_REG_WORD(addr
);
52 second
= RD_REG_WORD(addr
);
53 } while (first
!= second
);
59 qla2x00_poll(struct rsp_que
*rsp
)
61 struct qla_hw_data
*ha
= rsp
->hw
;
66 ha
->isp_ops
->intr_handler(0, rsp
);
69 static inline uint8_t *
70 host_to_fcp_swap(uint8_t *fcp
, uint32_t bsize
)
72 uint32_t *ifcp
= (uint32_t *) fcp
;
73 uint32_t *ofcp
= (uint32_t *) fcp
;
74 uint32_t iter
= bsize
>> 2;
77 *ofcp
++ = swab32(*ifcp
++);
83 host_to_adap(uint8_t *src
, uint8_t *dst
, uint32_t bsize
)
85 uint32_t *isrc
= (uint32_t *) src
;
86 __le32
*odest
= (__le32
*) dst
;
87 uint32_t iter
= bsize
>> 2;
89 for ( ; iter
--; isrc
++)
90 *odest
++ = cpu_to_le32(*isrc
);
94 qla2x00_clean_dsd_pool(struct qla_hw_data
*ha
, struct crc_context
*ctx
)
96 struct dsd_dma
*dsd
, *tdsd
;
98 /* clean up allocated prev pool */
99 list_for_each_entry_safe(dsd
, tdsd
, &ctx
->dsd_list
, list
) {
100 dma_pool_free(ha
->dl_dma_pool
, dsd
->dsd_addr
,
102 list_del(&dsd
->list
);
105 INIT_LIST_HEAD(&ctx
->dsd_list
);
109 qla2x00_set_fcport_disc_state(fc_port_t
*fcport
, int state
)
112 uint8_t shiftbits
, mask
;
114 /* This will have to change when the max no. of states > 16 */
116 mask
= (1 << shiftbits
) - 1;
118 fcport
->disc_state
= state
;
120 old_val
= atomic_read(&fcport
->shadow_disc_state
);
121 if (old_val
== atomic_cmpxchg(&fcport
->shadow_disc_state
,
122 old_val
, (old_val
<< shiftbits
) | state
)) {
123 ql_dbg(ql_dbg_disc
, fcport
->vha
, 0x2134,
124 "FCPort %8phC disc_state transition: %s to %s - portid=%06x.\n",
125 fcport
->port_name
, port_dstate_str
[old_val
& mask
],
126 port_dstate_str
[state
], fcport
->d_id
.b24
);
133 qla2x00_hba_err_chk_enabled(srb_t
*sp
)
136 * Uncomment when corresponding SCSI changes are done.
138 if (!sp->cmd->prot_chk)
142 switch (scsi_get_prot_op(GET_CMD_SP(sp
))) {
143 case SCSI_PROT_READ_STRIP
:
144 case SCSI_PROT_WRITE_INSERT
:
145 if (ql2xenablehba_err_chk
>= 1)
148 case SCSI_PROT_READ_PASS
:
149 case SCSI_PROT_WRITE_PASS
:
150 if (ql2xenablehba_err_chk
>= 2)
153 case SCSI_PROT_READ_INSERT
:
154 case SCSI_PROT_WRITE_STRIP
:
161 qla2x00_reset_active(scsi_qla_host_t
*vha
)
163 scsi_qla_host_t
*base_vha
= pci_get_drvdata(vha
->hw
->pdev
);
165 /* Test appropriate base-vha and vha flags. */
166 return test_bit(ISP_ABORT_NEEDED
, &base_vha
->dpc_flags
) ||
167 test_bit(ABORT_ISP_ACTIVE
, &base_vha
->dpc_flags
) ||
168 test_bit(ISP_ABORT_RETRY
, &base_vha
->dpc_flags
) ||
169 test_bit(ISP_ABORT_NEEDED
, &vha
->dpc_flags
) ||
170 test_bit(ABORT_ISP_ACTIVE
, &vha
->dpc_flags
);
174 qla2x00_chip_is_down(scsi_qla_host_t
*vha
)
176 return (qla2x00_reset_active(vha
) || !vha
->hw
->flags
.fw_started
);
179 static void qla2xxx_init_sp(srb_t
*sp
, scsi_qla_host_t
*vha
,
180 struct qla_qpair
*qpair
, fc_port_t
*fcport
)
182 memset(sp
, 0, sizeof(*sp
));
187 sp
->cmd_type
= TYPE_SRB
;
188 INIT_LIST_HEAD(&sp
->elem
);
191 static inline srb_t
*
192 qla2xxx_get_qpair_sp(scsi_qla_host_t
*vha
, struct qla_qpair
*qpair
,
193 fc_port_t
*fcport
, gfp_t flag
)
198 QLA_QPAIR_MARK_BUSY(qpair
, bail
);
202 sp
= mempool_alloc(qpair
->srb_mempool
, flag
);
204 qla2xxx_init_sp(sp
, vha
, qpair
, fcport
);
206 QLA_QPAIR_MARK_NOT_BUSY(qpair
);
211 qla2xxx_rel_qpair_sp(struct qla_qpair
*qpair
, srb_t
*sp
)
214 mempool_free(sp
, qpair
->srb_mempool
);
215 QLA_QPAIR_MARK_NOT_BUSY(qpair
);
218 static inline srb_t
*
219 qla2x00_get_sp(scsi_qla_host_t
*vha
, fc_port_t
*fcport
, gfp_t flag
)
223 struct qla_qpair
*qpair
;
225 QLA_VHA_MARK_BUSY(vha
, bail
);
229 qpair
= vha
->hw
->base_qpair
;
230 sp
= qla2xxx_get_qpair_sp(vha
, qpair
, fcport
, flag
);
237 QLA_VHA_MARK_NOT_BUSY(vha
);
242 qla2x00_rel_sp(srb_t
*sp
)
244 QLA_VHA_MARK_NOT_BUSY(sp
->vha
);
245 qla2xxx_rel_qpair_sp(sp
->qpair
, sp
);
249 qla2x00_gid_list_size(struct qla_hw_data
*ha
)
252 return sizeof(uint32_t) * 32;
254 return sizeof(struct gid_list_info
) * ha
->max_fibre_devices
;
258 qla2x00_handle_mbx_completion(struct qla_hw_data
*ha
, int status
)
260 if (test_bit(MBX_INTR_WAIT
, &ha
->mbx_cmd_flags
) &&
261 (status
& MBX_INTERRUPT
) && ha
->flags
.mbox_int
) {
262 set_bit(MBX_INTERRUPT
, &ha
->mbx_cmd_flags
);
263 clear_bit(MBX_INTR_WAIT
, &ha
->mbx_cmd_flags
);
264 complete(&ha
->mbx_intr_comp
);
269 qla2x00_set_retry_delay_timestamp(fc_port_t
*fcport
, uint16_t retry_delay
)
272 fcport
->retry_delay_timestamp
= jiffies
+
273 (retry_delay
* HZ
/ 10);
277 qla_is_exch_offld_enabled(struct scsi_qla_host
*vha
)
279 if (qla_ini_mode_enabled(vha
) &&
280 (vha
->ql2xiniexchg
> FW_DEF_EXCHANGES_CNT
))
282 else if (qla_tgt_mode_enabled(vha
) &&
283 (vha
->ql2xexchoffld
> FW_DEF_EXCHANGES_CNT
))
285 else if (qla_dual_mode_enabled(vha
) &&
286 ((vha
->ql2xiniexchg
+ vha
->ql2xexchoffld
) > FW_DEF_EXCHANGES_CNT
))
293 qla_cpu_update(struct qla_qpair
*qpair
, uint16_t cpuid
)
295 qpair
->cpuid
= cpuid
;
297 if (!list_empty(&qpair
->hints_list
)) {
298 struct qla_qpair_hint
*h
;
300 list_for_each_entry(h
, &qpair
->hints_list
, hint_elem
)
301 h
->cpuid
= qpair
->cpuid
;
305 static inline struct qla_qpair_hint
*
306 qla_qpair_to_hint(struct qla_tgt
*tgt
, struct qla_qpair
*qpair
)
308 struct qla_qpair_hint
*h
;
311 for (i
= 0; i
< tgt
->ha
->max_qpairs
+ 1; i
++) {
312 h
= &tgt
->qphints
[i
];
313 if (h
->qpair
== qpair
)
321 qla_83xx_start_iocbs(struct qla_qpair
*qpair
)
323 struct req_que
*req
= qpair
->req
;
326 if (req
->ring_index
== req
->length
) {
328 req
->ring_ptr
= req
->ring
;
332 WRT_REG_DWORD(req
->req_q_in
, req
->ring_index
);
336 qla2xxx_get_fc4_priority(struct scsi_qla_host
*vha
)
341 ((uint8_t *)vha
->hw
->nvram
)[NVRAM_DUAL_FCP_NVME_FLAG_OFFSET
];
344 return (data
>> 6) & BIT_0
? FC4_PRIORITY_FCP
: FC4_PRIORITY_NVME
;