scsi: qla2xxx: Reduce holding sess_lock to prevent CPU lock-up
[linux-2.6-block.git] / drivers / scsi / qla2xxx / qla_gbl.h
CommitLineData
fa90c54f
AV
1/*
2 * QLogic Fibre Channel HBA Driver
bd21eaf9 3 * Copyright (c) 2003-2014 QLogic Corporation
fa90c54f
AV
4 *
5 * See LICENSE.qla2xxx for copyright and licensing details.
6 */
1da177e4
LT
7#ifndef __QLA_GBL_H
8#define __QLA_GBL_H
9
10#include <linux/interrupt.h>
11
1da177e4
LT
12/*
13 * Global Function Prototypes in qla_init.c source file.
14 */
15extern int qla2x00_initialize_adapter(scsi_qla_host_t *);
abbd8870
AV
16
17extern int qla2100_pci_config(struct scsi_qla_host *);
18extern int qla2300_pci_config(struct scsi_qla_host *);
0107109e 19extern int qla24xx_pci_config(scsi_qla_host_t *);
c3a2f0df 20extern int qla25xx_pci_config(scsi_qla_host_t *);
abbd8870 21extern void qla2x00_reset_chip(struct scsi_qla_host *);
0107109e 22extern void qla24xx_reset_chip(struct scsi_qla_host *);
abbd8870 23extern int qla2x00_chip_diag(struct scsi_qla_host *);
0107109e 24extern int qla24xx_chip_diag(struct scsi_qla_host *);
abbd8870 25extern void qla2x00_config_rings(struct scsi_qla_host *);
0107109e 26extern void qla24xx_config_rings(struct scsi_qla_host *);
abbd8870 27extern void qla2x00_reset_adapter(struct scsi_qla_host *);
0107109e 28extern void qla24xx_reset_adapter(struct scsi_qla_host *);
abbd8870 29extern int qla2x00_nvram_config(struct scsi_qla_host *);
0107109e 30extern int qla24xx_nvram_config(struct scsi_qla_host *);
3a03eb79 31extern int qla81xx_nvram_config(struct scsi_qla_host *);
abbd8870 32extern void qla2x00_update_fw_options(struct scsi_qla_host *);
0107109e 33extern void qla24xx_update_fw_options(scsi_qla_host_t *);
3a03eb79 34extern void qla81xx_update_fw_options(scsi_qla_host_t *);
abbd8870 35extern int qla2x00_load_risc(struct scsi_qla_host *, uint32_t *);
5433383e 36extern int qla24xx_load_risc(scsi_qla_host_t *, uint32_t *);
eaac30be 37extern int qla81xx_load_risc(scsi_qla_host_t *, uint32_t *);
1da177e4 38
579d12b5 39extern int qla2x00_perform_loop_resync(scsi_qla_host_t *);
1da177e4
LT
40extern int qla2x00_loop_resync(scsi_qla_host_t *);
41
03bcfb57
JC
42extern int qla2x00_find_new_loop_id(scsi_qla_host_t *, fc_port_t *);
43
1da177e4 44extern int qla2x00_fabric_login(scsi_qla_host_t *, fc_port_t *, uint16_t *);
9a52a57c 45extern int qla2x00_local_device_login(scsi_qla_host_t *, fc_port_t *);
6eb54715
HM
46
47extern int qla24xx_els_dcmd_iocb(scsi_qla_host_t *, int, port_id_t);
8777e431 48extern int qla24xx_els_dcmd2_iocb(scsi_qla_host_t *, int, fc_port_t *, bool);
1da177e4 49
d97994dc 50extern void qla2x00_update_fcports(scsi_qla_host_t *);
1da177e4 51
1da177e4 52extern int qla2x00_abort_isp(scsi_qla_host_t *);
a9083016 53extern void qla2x00_abort_isp_cleanup(scsi_qla_host_t *);
8fcd6b8b 54extern void qla2x00_quiesce_io(scsi_qla_host_t *);
1da177e4 55
052c40c8 56extern void qla2x00_update_fcport(scsi_qla_host_t *, fc_port_t *);
cd4ed6b4 57void qla_register_fcport_fn(struct work_struct *);
a7a167bf 58extern void qla2x00_alloc_fw_dump(scsi_qla_host_t *);
18c6c127 59extern void qla2x00_try_to_stop_firmware(scsi_qla_host_t *);
a7a167bf 60
fe52f6e1 61extern int qla2x00_get_thermal_temp(scsi_qla_host_t *, uint16_t *);
794a5691 62
4d4df193
HK
63extern void qla84xx_put_chip(struct scsi_qla_host *);
64
ac280b67
AV
65extern int qla2x00_async_login(struct scsi_qla_host *, fc_port_t *,
66 uint16_t *);
67extern int qla2x00_async_logout(struct scsi_qla_host *, fc_port_t *);
11aea16a 68extern int qla2x00_async_prlo(struct scsi_qla_host *, fc_port_t *);
5ff1d584
AV
69extern int qla2x00_async_adisc(struct scsi_qla_host *, fc_port_t *,
70 uint16_t *);
3822263e 71extern int qla2x00_async_tm_cmd(fc_port_t *, uint32_t, uint32_t, uint32_t);
4916392b 72extern void qla2x00_async_login_done(struct scsi_qla_host *, fc_port_t *,
ac280b67 73 uint16_t *);
4916392b 74extern void qla2x00_async_logout_done(struct scsi_qla_host *, fc_port_t *,
ac280b67 75 uint16_t *);
4916392b 76extern void qla2x00_async_adisc_done(struct scsi_qla_host *, fc_port_t *,
5ff1d584 77 uint16_t *);
726b8548
QT
78struct qla_work_evt *qla2x00_alloc_work(struct scsi_qla_host *,
79 enum qla_work_type);
80extern int qla24xx_async_gnl(struct scsi_qla_host *, fc_port_t *);
81int qla2x00_post_work(struct scsi_qla_host *vha, struct qla_work_evt *e);
82de802a 82extern void *qla2x00_alloc_iocbs_ready(struct qla_qpair *, srb_t *);
21090cbe 83extern int qla24xx_update_fcport_fcp_prio(scsi_qla_host_t *, fc_port_t *);
ac280b67 84
9a069e19
GM
85extern fc_port_t *
86qla2x00_alloc_fcport(scsi_qla_host_t *, gfp_t );
7d613ac6
SV
87
88extern int __qla83xx_set_idc_control(scsi_qla_host_t *, uint32_t);
89extern int __qla83xx_get_idc_control(scsi_qla_host_t *, uint32_t *);
90extern void qla83xx_idc_audit(scsi_qla_host_t *, int);
91extern int qla83xx_nic_core_reset(scsi_qla_host_t *);
92extern void qla83xx_reset_ownership(scsi_qla_host_t *);
81178772 93extern int qla2xxx_mctp_dump(scsi_qla_host_t *);
7d613ac6 94
8d93f550
CD
95extern int
96qla2x00_alloc_outstanding_cmds(struct qla_hw_data *, struct req_que *);
8ae6d9c7 97extern int qla2x00_init_rings(scsi_qla_host_t *);
4243c115 98extern uint8_t qla27xx_find_valid_image(struct scsi_qla_host *);
d7459527 99extern struct qla_qpair *qla2xxx_create_qpair(struct scsi_qla_host *,
82de802a 100 int, int, bool);
d7459527 101extern int qla2xxx_delete_qpair(struct scsi_qla_host *, struct qla_qpair *);
726b8548
QT
102void qla2x00_fcport_event_handler(scsi_qla_host_t *, struct event_arg *);
103int qla24xx_async_gpdb(struct scsi_qla_host *, fc_port_t *, u8);
a5d42f4c 104int qla24xx_async_prli(struct scsi_qla_host *, fc_port_t *);
726b8548
QT
105int qla24xx_async_notify_ack(scsi_qla_host_t *, fc_port_t *,
106 struct imm_ntfy_from_isp *, int);
a4239945
QT
107int qla24xx_post_newsess_work(struct scsi_qla_host *, port_id_t *, u8 *, u8*,
108 void *, u8);
726b8548 109int qla24xx_fcport_handle_login(struct scsi_qla_host *, fc_port_t *);
e4e3a2ce 110int qla24xx_detect_sfp(scsi_qla_host_t *vha);
a07fc0a4 111int qla24xx_post_gpdb_work(struct scsi_qla_host *, fc_port_t *, u8);
cd4ed6b4 112
11aea16a
QT
113void qla2x00_async_prlo_done(struct scsi_qla_host *, fc_port_t *,
114 uint16_t *);
115extern int qla2x00_post_async_prlo_work(struct scsi_qla_host *, fc_port_t *,
116 uint16_t *);
117extern int qla2x00_post_async_prlo_done_work(struct scsi_qla_host *,
118 fc_port_t *, uint16_t *);
cc28e0ac
QT
119int qla_post_iidma_work(struct scsi_qla_host *vha, fc_port_t *fcport);
120void qla_do_iidma_work(struct scsi_qla_host *vha, fc_port_t *fcport);
f6602f3b 121int qla2x00_reserve_mgmt_server_loop_id(scsi_qla_host_t *);
1da177e4
LT
122/*
123 * Global Data in qla_os.c source file.
124 */
125extern char qla2x00_version_str[];
126
d7459527 127extern struct kmem_cache *srb_cachep;
b5d15312 128extern struct kmem_cache *qla_tgt_plogi_cachep;
d7459527 129
1da177e4
LT
130extern int ql2xlogintimeout;
131extern int qlport_down_retry;
1da177e4 132extern int ql2xplogiabsentdevice;
1da177e4 133extern int ql2xloginretrycount;
cca5335c 134extern int ql2xfdmienable;
a7a167bf 135extern int ql2xallocfwdump;
11010fec 136extern int ql2xextended_error_logging;
e5896bd5 137extern int ql2xiidmaenable;
d7459527 138extern int ql2xmqsupport;
e337d907 139extern int ql2xfwloadbin;
ae97c91e 140extern int ql2xetsenable;
a9083016
GM
141extern int ql2xshiftctondsd;
142extern int ql2xdbwr;
3822263e 143extern int ql2xasynctmfenable;
4da26e16 144extern int ql2xgffidenable;
bad75002
AE
145extern int ql2xenabledif;
146extern int ql2xenablehba_err_chk;
f4c496c1 147extern int ql2xtargetreset;
ed0de87c 148extern int ql2xdontresethba;
1abf635d 149extern uint64_t ql2xmaxlun;
08de2844
GM
150extern int ql2xmdcapmask;
151extern int ql2xmdenable;
b0d6cabd 152extern int ql2xexlogins;
2f56a7f1 153extern int ql2xexchoffld;
99e1b683 154extern int ql2xiniexchg;
f198cafa 155extern int ql2xfwholdabts;
41dc529a 156extern int ql2xmvasynctoatio;
09620eeb 157extern int ql2xuctrlirq;
e84067d7 158extern int ql2xnvmeenable;
e4e3a2ce 159extern int ql2xautodetectsfp;
e7240af5 160extern int ql2xenablemsix;
9ecf0b0d 161extern int qla2xuseresexchforels;
2c3dfe3f 162
a4722cf2 163extern int qla2x00_loop_reset(scsi_qla_host_t *);
df4bf0bb 164extern void qla2x00_abort_all_cmds(scsi_qla_host_t *, int);
0971de7f
AV
165extern int qla2x00_post_aen_work(struct scsi_qla_host *, enum
166 fc_host_event_code, u32);
8a659571 167extern int qla2x00_post_idc_ack_work(struct scsi_qla_host *, uint16_t *);
ac280b67
AV
168extern int qla2x00_post_async_login_work(struct scsi_qla_host *, fc_port_t *,
169 uint16_t *);
ac280b67
AV
170extern int qla2x00_post_async_logout_work(struct scsi_qla_host *, fc_port_t *,
171 uint16_t *);
172extern int qla2x00_post_async_logout_done_work(struct scsi_qla_host *,
173 fc_port_t *, uint16_t *);
5ff1d584
AV
174extern int qla2x00_post_async_adisc_work(struct scsi_qla_host *, fc_port_t *,
175 uint16_t *);
176extern int qla2x00_post_async_adisc_done_work(struct scsi_qla_host *,
177 fc_port_t *, uint16_t *);
b0d6cabd
HM
178extern int qla2x00_set_exlogins_buffer(struct scsi_qla_host *);
179extern void qla2x00_free_exlogin_buffer(struct qla_hw_data *);
2f56a7f1
HM
180extern int qla2x00_set_exchoffld_buffer(struct scsi_qla_host *);
181extern void qla2x00_free_exchoffld_buffer(struct qla_hw_data *);
ac280b67 182
6e181be5 183extern int qla81xx_restart_mpi_firmware(scsi_qla_host_t *);
a4722cf2 184
7b867cf7
AC
185extern struct scsi_qla_host *qla2x00_create_host(struct scsi_host_template *,
186 struct qla_hw_data *);
187extern void qla2x00_free_host(struct scsi_qla_host *);
188extern void qla2x00_relogin(struct scsi_qla_host *);
ac280b67 189extern void qla2x00_do_work(struct scsi_qla_host *);
8867048b 190extern void qla2x00_free_fcports(struct scsi_qla_host *);
ac280b67 191
7d613ac6
SV
192extern void qla83xx_schedule_work(scsi_qla_host_t *, int);
193extern void qla83xx_service_idc_aen(struct work_struct *);
194extern void qla83xx_nic_core_unrecoverable_work(struct work_struct *);
195extern void qla83xx_idc_state_handler_work(struct work_struct *);
196extern void qla83xx_nic_core_reset_work(struct work_struct *);
197
198extern void qla83xx_idc_lock(scsi_qla_host_t *, uint16_t);
199extern void qla83xx_idc_unlock(scsi_qla_host_t *, uint16_t);
200extern int qla83xx_idc_state_handler(scsi_qla_host_t *);
201extern int qla83xx_set_drv_presence(scsi_qla_host_t *vha);
202extern int __qla83xx_set_drv_presence(scsi_qla_host_t *vha);
203extern int qla83xx_clear_drv_presence(scsi_qla_host_t *vha);
204extern int __qla83xx_clear_drv_presence(scsi_qla_host_t *vha);
8ae6d9c7 205extern int qla2x00_post_uevent_work(struct scsi_qla_host *, u32);
7d613ac6 206
f3ddac19
CD
207extern int qla2x00_post_uevent_work(struct scsi_qla_host *, u32);
208extern void qla2x00_disable_board_on_pci_error(struct work_struct *);
25ff6af1
JC
209extern void qla2x00_sp_compl(void *, int);
210extern void qla2xxx_qpair_sp_free_dma(void *);
211extern void qla2xxx_qpair_sp_compl(void *, int);
cd4ed6b4 212extern void qla24xx_sched_upd_fcport(fc_port_t *);
726b8548
QT
213void qla2x00_handle_login_done_event(struct scsi_qla_host *, fc_port_t *,
214 uint16_t *);
215int qla24xx_post_gnl_work(struct scsi_qla_host *, fc_port_t *);
f6145e86 216int qla24xx_async_abort_cmd(srb_t *, bool);
9b3e0f4d 217int qla24xx_post_relogin_work(struct scsi_qla_host *vha);
efa93f48 218void qla2x00_wait_for_sess_deletion(scsi_qla_host_t *);
f3ddac19 219
2c3dfe3f
SJ
220/*
221 * Global Functions in qla_mid.c source file.
222 */
a5326f86 223extern struct scsi_host_template qla2xxx_driver_template;
2c3dfe3f 224extern struct scsi_transport_template *qla2xxx_transport_vport_template;
8e5f4ba0
KC
225extern void qla2x00_timer(struct timer_list *);
226extern void qla2x00_start_timer(scsi_qla_host_t *, unsigned long);
2c3dfe3f
SJ
227extern void qla24xx_deallocate_vp_id(scsi_qla_host_t *);
228extern int qla24xx_disable_vp (scsi_qla_host_t *);
229extern int qla24xx_enable_vp (scsi_qla_host_t *);
2c3dfe3f
SJ
230extern int qla24xx_control_vp(scsi_qla_host_t *, int );
231extern int qla24xx_modify_vp_config(scsi_qla_host_t *);
232extern int qla2x00_send_change_request(scsi_qla_host_t *, uint16_t, uint16_t);
233extern void qla2x00_vp_stop_timer(scsi_qla_host_t *);
234extern int qla24xx_configure_vhba (scsi_qla_host_t *);
2c3dfe3f
SJ
235extern void qla24xx_report_id_acquisition(scsi_qla_host_t *,
236 struct vp_rpt_id_entry_24xx *);
2c3dfe3f
SJ
237extern void qla2x00_do_dpc_all_vps(scsi_qla_host_t *);
238extern int qla24xx_vport_create_req_sanity_check(struct fc_vport *);
239extern scsi_qla_host_t * qla24xx_create_vhost(struct fc_vport *);
1da177e4 240
25ff6af1 241extern void qla2x00_sp_free_dma(void *);
1da177e4
LT
242extern char *qla2x00_get_fw_version_str(struct scsi_qla_host *, char *);
243
d97994dc 244extern void qla2x00_mark_device_lost(scsi_qla_host_t *, fc_port_t *, int, int);
245extern void qla2x00_mark_all_devices_lost(scsi_qla_host_t *, int);
1da177e4 246
5433383e 247extern struct fw_blob *qla2x00_request_firmware(scsi_qla_host_t *);
1da177e4 248
854165f4 249extern int qla2x00_wait_for_hba_online(scsi_qla_host_t *);
2533cf67 250extern int qla2x00_wait_for_chip_reset(scsi_qla_host_t *);
a9083016 251extern int qla2x00_wait_for_fcoe_ctx_reset(scsi_qla_host_t *);
854165f4 252
7b867cf7 253extern void qla2xxx_wake_dpc(struct scsi_qla_host *);
73208dfd
AC
254extern void qla2x00_alert_all_vps(struct rsp_que *, uint16_t *);
255extern void qla2x00_async_event(scsi_qla_host_t *, struct rsp_que *,
256 uint16_t *);
7b867cf7 257extern int qla2x00_vp_abort_isp(scsi_qla_host_t *);
39a11240 258
1da177e4
LT
259/*
260 * Global Function Prototypes in qla_iocb.c source file.
261 */
2d70c103 262
1da177e4
LT
263extern uint16_t qla2x00_calc_iocbs_32(uint16_t);
264extern uint16_t qla2x00_calc_iocbs_64(uint16_t);
265extern void qla2x00_build_scsi_iocbs_32(srb_t *, cmd_entry_t *, uint16_t);
266extern void qla2x00_build_scsi_iocbs_64(srb_t *, cmd_entry_t *, uint16_t);
d7459527
MH
267extern void qla24xx_build_scsi_iocbs(srb_t *, struct cmd_type_7 *,
268 uint16_t, struct req_que *);
1da177e4 269extern int qla2x00_start_scsi(srb_t *sp);
2b6c0cee 270extern int qla24xx_start_scsi(srb_t *sp);
73208dfd 271int qla2x00_marker(struct scsi_qla_host *, struct req_que *, struct rsp_que *,
9cb78c16 272 uint16_t, uint64_t, uint8_t);
ac280b67 273extern int qla2x00_start_sp(srb_t *);
bad75002 274extern int qla24xx_dif_start_scsi(srb_t *);
a9b6f722 275extern int qla2x00_start_bidir(srb_t *, struct scsi_qla_host *, uint32_t);
d7459527 276extern int qla2xxx_dif_start_scsi_mq(srb_t *);
a9b6f722 277extern unsigned long qla2x00_get_async_timeout(struct scsi_qla_host *);
a9083016 278
82de802a
QT
279extern void *qla2x00_alloc_iocbs(struct scsi_qla_host *, srb_t *);
280extern void *__qla2x00_alloc_iocbs(struct qla_qpair *, srb_t *);
2d70c103 281extern int qla2x00_issue_marker(scsi_qla_host_t *, int);
f83adb61 282extern int qla24xx_walk_and_build_sglist_no_difb(struct qla_hw_data *, srb_t *,
be25152c 283 uint32_t *, uint16_t, struct qla_tc_param *);
f83adb61 284extern int qla24xx_walk_and_build_sglist(struct qla_hw_data *, srb_t *,
be25152c 285 uint32_t *, uint16_t, struct qla_tc_param *);
f83adb61 286extern int qla24xx_walk_and_build_prot_sglist(struct qla_hw_data *, srb_t *,
be25152c 287 uint32_t *, uint16_t, struct qla_tc_param *);
d7459527
MH
288extern int qla24xx_get_one_block_sg(uint32_t, struct qla2_sgx *, uint32_t *);
289extern int qla24xx_configure_prot_mode(srb_t *, uint16_t *);
290extern int qla24xx_build_scsi_crc_2_iocbs(srb_t *,
291 struct cmd_type_crc_2 *, uint16_t, uint16_t, uint16_t);
1da177e4
LT
292
293/*
294 * Global Function Prototypes in qla_mbx.c source file.
295 */
296extern int
590f98e5 297qla2x00_load_ram(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
1da177e4 298
338c9161
AV
299extern int
300qla2x00_dump_ram(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
301
1da177e4 302extern int
1c7c6357 303qla2x00_execute_fw(scsi_qla_host_t *, uint32_t);
1da177e4 304
ca9e9c3e 305extern int
6246b8a1 306qla2x00_get_fw_version(scsi_qla_host_t *);
1da177e4
LT
307
308extern int
309qla2x00_get_fw_options(scsi_qla_host_t *, uint16_t *);
310
311extern int
312qla2x00_set_fw_options(scsi_qla_host_t *, uint16_t *);
313
314extern int
315qla2x00_mbx_reg_test(scsi_qla_host_t *);
316
317extern int
1c7c6357 318qla2x00_verify_checksum(scsi_qla_host_t *, uint32_t);
1da177e4
LT
319
320extern int
321qla2x00_issue_iocb(scsi_qla_host_t *, void *, dma_addr_t, size_t);
322
323extern int
2afa19a9 324qla2x00_abort_command(srb_t *);
1da177e4 325
1da177e4 326extern int
9cb78c16 327qla2x00_abort_target(struct fc_port *, uint64_t, int);
523ec773
AV
328
329extern int
9cb78c16 330qla2x00_lun_reset(struct fc_port *, uint64_t, int);
1da177e4 331
1da177e4
LT
332extern int
333qla2x00_get_adapter_id(scsi_qla_host_t *, uint16_t *, uint8_t *, uint8_t *,
2c3dfe3f 334 uint8_t *, uint16_t *, uint16_t *);
1da177e4
LT
335
336extern int
337qla2x00_get_retry_cnt(scsi_qla_host_t *, uint8_t *, uint8_t *, uint16_t *);
338
339extern int
340qla2x00_init_firmware(scsi_qla_host_t *, uint16_t);
341
342extern int
343qla2x00_get_port_database(scsi_qla_host_t *, fc_port_t *, uint8_t);
344
345extern int
346qla2x00_get_firmware_state(scsi_qla_host_t *, uint16_t *);
347
348extern int
349qla2x00_get_port_name(scsi_qla_host_t *, uint16_t, uint8_t *, uint8_t);
350
61e1b269
JC
351extern int
352qla24xx_link_initialize(scsi_qla_host_t *);
353
1da177e4
LT
354extern int
355qla2x00_lip_reset(scsi_qla_host_t *);
356
357extern int
358qla2x00_send_sns(scsi_qla_host_t *, dma_addr_t, uint16_t, size_t);
359
360extern int
361qla2x00_login_fabric(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t,
362 uint16_t *, uint8_t);
1c7c6357
AV
363extern int
364qla24xx_login_fabric(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t,
365 uint16_t *, uint8_t);
1da177e4
LT
366
367extern int
9a52a57c 368qla2x00_login_local_device(scsi_qla_host_t *, fc_port_t *, uint16_t *,
369 uint8_t);
1da177e4
LT
370
371extern int
1c7c6357
AV
372qla2x00_fabric_logout(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t);
373
374extern int
375qla24xx_fabric_logout(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t);
1da177e4
LT
376
377extern int
378qla2x00_full_login_lip(scsi_qla_host_t *ha);
379
380extern int
381qla2x00_get_id_list(scsi_qla_host_t *, void *, dma_addr_t, uint16_t *);
382
383extern int
03e8c680 384qla2x00_get_resource_cnts(scsi_qla_host_t *);
1da177e4
LT
385
386extern int
387qla2x00_get_fcal_position_map(scsi_qla_host_t *ha, char *pos_map);
388
392e2f65 389extern int
43ef0580
AV
390qla2x00_get_link_status(scsi_qla_host_t *, uint16_t, struct link_statistics *,
391 dma_addr_t);
392e2f65 392
393extern int
43ef0580 394qla24xx_get_isp_stats(scsi_qla_host_t *, struct link_statistics *,
15f30a57 395 dma_addr_t, uint16_t);
392e2f65 396
2afa19a9 397extern int qla24xx_abort_command(srb_t *);
4440e46d 398extern int qla24xx_async_abort_command(srb_t *);
2afa19a9 399extern int
9cb78c16 400qla24xx_abort_target(struct fc_port *, uint64_t, int);
2afa19a9 401extern int
9cb78c16 402qla24xx_lun_reset(struct fc_port *, uint64_t, int);
4d78c973
GM
403extern int
404qla2x00_eh_wait_for_pending_commands(scsi_qla_host_t *, unsigned int,
9cb78c16 405 uint64_t, enum nexus_wait_type);
68af0811
AV
406extern int
407qla2x00_system_error(scsi_qla_host_t *);
408
db64e930
JC
409extern int
410qla2x00_write_serdes_word(scsi_qla_host_t *, uint16_t, uint16_t);
411extern int
412qla2x00_read_serdes_word(scsi_qla_host_t *, uint16_t, uint16_t *);
413
e8887c51
JC
414extern int
415qla8044_write_serdes_word(scsi_qla_host_t *, uint32_t, uint32_t);
416extern int
417qla8044_read_serdes_word(scsi_qla_host_t *, uint32_t, uint32_t *);
418
1c7c6357
AV
419extern int
420qla2x00_set_serdes_params(scsi_qla_host_t *, uint16_t, uint16_t, uint16_t);
421
f6ef3b18
AV
422extern int
423qla2x00_stop_firmware(scsi_qla_host_t *);
424
a7a167bf 425extern int
00b6bd25
AV
426qla2x00_enable_eft_trace(scsi_qla_host_t *, dma_addr_t, uint16_t);
427extern int
428qla2x00_disable_eft_trace(scsi_qla_host_t *);
a7a167bf 429
df613b96
AV
430extern int
431qla2x00_enable_fce_trace(scsi_qla_host_t *, dma_addr_t, uint16_t , uint16_t *,
432 uint32_t *);
433
434extern int
435qla2x00_disable_fce_trace(scsi_qla_host_t *, uint64_t *, uint64_t *);
436
c46e65c7
JC
437extern int
438qla82xx_set_driver_version(scsi_qla_host_t *, char *);
439
440extern int
441qla25xx_set_driver_version(scsi_qla_host_t *, char *);
442
88729e53 443extern int
6766df9e
JC
444qla2x00_read_sfp(scsi_qla_host_t *, dma_addr_t, uint8_t *,
445 uint16_t, uint16_t, uint16_t, uint16_t);
88729e53 446
ad0ecd61 447extern int
6766df9e
JC
448qla2x00_write_sfp(scsi_qla_host_t *, dma_addr_t, uint8_t *,
449 uint16_t, uint16_t, uint16_t, uint16_t);
ad0ecd61 450
d8b45213
AV
451extern int
452qla2x00_set_idma_speed(scsi_qla_host_t *, uint16_t, uint16_t, uint16_t *);
453
4d4df193
HK
454extern int qla84xx_verify_chip(struct scsi_qla_host *, uint16_t *);
455
8a659571
AV
456extern int qla81xx_idc_ack(scsi_qla_host_t *, uint16_t *);
457
1d2874de
JC
458extern int
459qla81xx_fac_get_sector_size(scsi_qla_host_t *, uint32_t *);
460
461extern int
462qla81xx_fac_do_write_enable(scsi_qla_host_t *, int);
463
464extern int
465qla81xx_fac_erase_sector(scsi_qla_host_t *, uint32_t, uint32_t);
466
ce0423f4
AV
467extern int
468qla2x00_get_xgmac_stats(scsi_qla_host_t *, dma_addr_t, uint16_t, uint16_t *);
469
11bbc1d8
AV
470extern int
471qla2x00_get_dcbx_params(scsi_qla_host_t *, dma_addr_t, uint16_t);
472
18e7555a
AV
473extern int
474qla2x00_read_ram_word(scsi_qla_host_t *, uint32_t, uint32_t *);
475
476extern int
477qla2x00_write_ram_word(scsi_qla_host_t *, uint32_t, uint32_t);
478
b1d46989
MI
479extern int
480qla81xx_write_mpi_register(scsi_qla_host_t *, uint16_t *);
3064ff39 481extern int qla2x00_get_data_rate(scsi_qla_host_t *);
09ff701a
SR
482extern int qla24xx_set_fcp_prio(scsi_qla_host_t *, uint16_t, uint16_t,
483 uint16_t *);
23f2ebd1
SR
484extern int
485qla81xx_get_port_config(scsi_qla_host_t *, uint16_t *);
486
487extern int
488qla81xx_set_port_config(scsi_qla_host_t *, uint16_t *);
09ff701a 489
af11f64d
AV
490extern int
491qla2x00_port_logout(scsi_qla_host_t *, struct fc_port *);
492
81178772
SK
493extern int
494qla2x00_dump_mctp_data(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
495
ec891462
JC
496extern int
497qla26xx_dport_diagnostics(scsi_qla_host_t *, void *, uint, uint);
498
15f30a57
QT
499int qla24xx_send_mb_cmd(struct scsi_qla_host *, mbx_cmd_t *);
500int qla24xx_gpdb_wait(struct scsi_qla_host *, fc_port_t *, u8);
501int qla24xx_gidlist_wait(struct scsi_qla_host *, void *, dma_addr_t,
502 uint16_t *);
503int __qla24xx_parse_gpdb(struct scsi_qla_host *, fc_port_t *,
504 struct port_database_24xx *);
edd05de1
DG
505int qla24xx_get_port_login_templ(scsi_qla_host_t *, dma_addr_t,
506 void *, uint16_t);
15f30a57 507
deeae7a6
DG
508extern int qla27xx_get_zio_threshold(scsi_qla_host_t *, uint16_t *);
509extern int qla27xx_set_zio_threshold(scsi_qla_host_t *, uint16_t);
94d83e36 510int qla24xx_res_count_wait(struct scsi_qla_host *, uint16_t *, int);
deeae7a6 511
1da177e4
LT
512/*
513 * Global Function Prototypes in qla_isr.c source file.
514 */
7d12e780
DH
515extern irqreturn_t qla2100_intr_handler(int, void *);
516extern irqreturn_t qla2300_intr_handler(int, void *);
517extern irqreturn_t qla24xx_intr_handler(int, void *);
73208dfd 518extern void qla2x00_process_response_queue(struct rsp_que *);
2afa19a9
AC
519extern void
520qla24xx_process_response_queue(struct scsi_qla_host *, struct rsp_que *);
73208dfd 521extern int qla2x00_request_irqs(struct qla_hw_data *, struct rsp_que *);
a8488abe
AV
522extern void qla2x00_free_irqs(scsi_qla_host_t *);
523
a9083016 524extern int qla2x00_get_data_rate(scsi_qla_host_t *);
d0297c9a 525extern const char *qla2x00_get_link_speed_str(struct qla_hw_data *, uint16_t);
8ae6d9c7
GM
526extern srb_t *
527qla2x00_get_sp_from_handle(scsi_qla_host_t *, const char *, struct req_que *,
528 void *);
529extern void
530qla2x00_process_completed_request(struct scsi_qla_host *, struct req_que *,
531 uint32_t);
d7459527
MH
532extern irqreturn_t
533qla2xxx_msix_rsp_q(int irq, void *dev_id);
726b8548
QT
534fc_port_t *qla2x00_find_fcport_by_loopid(scsi_qla_host_t *, uint16_t);
535fc_port_t *qla2x00_find_fcport_by_wwpn(scsi_qla_host_t *, u8 *, u8);
536fc_port_t *qla2x00_find_fcport_by_nportid(scsi_qla_host_t *, port_id_t *, u8);
daae62a3 537
1da177e4
LT
538/*
539 * Global Function Prototypes in qla_sup.c source file.
540 */
1da177e4 541extern void qla2x00_release_nvram_protection(scsi_qla_host_t *);
459c5378 542extern uint32_t *qla24xx_read_flash_data(scsi_qla_host_t *, uint32_t *,
7ec0effd 543 uint32_t, uint32_t);
459c5378 544extern uint8_t *qla2x00_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 545 uint32_t);
459c5378 546extern uint8_t *qla24xx_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 547 uint32_t);
459c5378 548extern int qla2x00_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 549 uint32_t);
459c5378 550extern int qla24xx_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 551 uint32_t);
c3a2f0df 552extern uint8_t *qla25xx_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 553 uint32_t);
c3a2f0df 554extern int qla25xx_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
7ec0effd 555 uint32_t);
bb4cf5b7 556extern int qla2x00_is_a_vp_did(scsi_qla_host_t *, uint32_t);
c821e0d5
JL
557bool qla2x00_check_reg32_for_disconnect(scsi_qla_host_t *, uint32_t);
558bool qla2x00_check_reg16_for_disconnect(scsi_qla_host_t *, uint16_t);
459c5378 559
f6df144c 560extern int qla2x00_beacon_on(struct scsi_qla_host *);
561extern int qla2x00_beacon_off(struct scsi_qla_host *);
562extern void qla2x00_beacon_blink(struct scsi_qla_host *);
563extern int qla24xx_beacon_on(struct scsi_qla_host *);
564extern int qla24xx_beacon_off(struct scsi_qla_host *);
565extern void qla24xx_beacon_blink(struct scsi_qla_host *);
6246b8a1 566extern void qla83xx_beacon_blink(struct scsi_qla_host *);
999916dc
SK
567extern int qla82xx_beacon_on(struct scsi_qla_host *);
568extern int qla82xx_beacon_off(struct scsi_qla_host *);
7d613ac6
SV
569extern int qla83xx_wr_reg(scsi_qla_host_t *, uint32_t, uint32_t);
570extern int qla83xx_rd_reg(scsi_qla_host_t *, uint32_t, uint32_t *);
571extern int qla83xx_restart_nic_firmware(scsi_qla_host_t *);
572extern int qla83xx_access_control(scsi_qla_host_t *, uint16_t, uint32_t,
7ec0effd 573 uint32_t, uint16_t *);
f6df144c 574
854165f4 575extern uint8_t *qla2x00_read_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 576 uint32_t, uint32_t);
854165f4 577extern int qla2x00_write_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 578 uint32_t, uint32_t);
854165f4 579extern uint8_t *qla24xx_read_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 580 uint32_t, uint32_t);
854165f4 581extern int qla24xx_write_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 582 uint32_t, uint32_t);
338c9161 583extern uint8_t *qla25xx_read_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd
AD
584 uint32_t, uint32_t);
585extern uint8_t *qla8044_read_optrom_data(struct scsi_qla_host *,
586 uint8_t *, uint32_t, uint32_t);
587extern void qla8044_watchdog(struct scsi_qla_host *vha);
854165f4 588
30c47662
AV
589extern int qla2x00_get_flash_version(scsi_qla_host_t *, void *);
590extern int qla24xx_get_flash_version(scsi_qla_host_t *, void *);
7ec0effd 591extern int qla82xx_get_flash_version(scsi_qla_host_t *, void *);
30c47662 592
c00d8994 593extern int qla2xxx_get_flash_info(scsi_qla_host_t *);
1ee27146 594extern int qla2xxx_get_vpd_field(scsi_qla_host_t *, char *, char *, size_t);
7d232c74 595
272976ca 596extern void qla2xxx_flash_npiv_conf(scsi_qla_host_t *);
09ff701a 597extern int qla24xx_read_fcp_prio_cfg(scsi_qla_host_t *);
272976ca 598
1da177e4
LT
599/*
600 * Global Function Prototypes in qla_dbg.c source file.
601 */
602extern void qla2100_fw_dump(scsi_qla_host_t *, int);
603extern void qla2300_fw_dump(scsi_qla_host_t *, int);
6d9b61ed 604extern void qla24xx_fw_dump(scsi_qla_host_t *, int);
c3a2f0df 605extern void qla25xx_fw_dump(scsi_qla_host_t *, int);
3a03eb79 606extern void qla81xx_fw_dump(scsi_qla_host_t *, int);
a1b23c5a
CD
607extern void qla82xx_fw_dump(scsi_qla_host_t *, int);
608extern void qla8044_fw_dump(scsi_qla_host_t *, int);
f73cb695
CD
609
610extern void qla27xx_fwdump(scsi_qla_host_t *, int);
611extern ulong qla27xx_fwdt_calculate_dump_size(struct scsi_qla_host *);
612extern int qla27xx_fwdt_template_valid(void *);
613extern ulong qla27xx_fwdt_template_size(void *);
614extern const void *qla27xx_fwdt_template_default(void);
615extern ulong qla27xx_fwdt_template_default_size(void);
616
1da177e4
LT
617extern void qla2x00_dump_regs(scsi_qla_host_t *);
618extern void qla2x00_dump_buffer(uint8_t *, uint32_t);
bad75002 619extern void qla2x00_dump_buffer_zipped(uint8_t *, uint32_t);
3ce8866c
SK
620extern void ql_dump_regs(uint32_t, scsi_qla_host_t *, int32_t);
621extern void ql_dump_buffer(uint32_t, scsi_qla_host_t *, int32_t,
7ec0effd 622 uint8_t *, uint32_t);
08de2844 623extern void qla2xxx_dump_post_process(scsi_qla_host_t *, int);
1da177e4
LT
624
625/*
626 * Global Function Prototypes in qla_gs.c source file.
627 */
726b8548
QT
628extern void *qla2x00_prep_ms_iocb(scsi_qla_host_t *, struct ct_arg *);
629extern void *qla24xx_prep_ms_iocb(scsi_qla_host_t *, struct ct_arg *);
1da177e4
LT
630extern int qla2x00_ga_nxt(scsi_qla_host_t *, fc_port_t *);
631extern int qla2x00_gid_pt(scsi_qla_host_t *, sw_info_t *);
632extern int qla2x00_gpn_id(scsi_qla_host_t *, sw_info_t *);
633extern int qla2x00_gnn_id(scsi_qla_host_t *, sw_info_t *);
e8c72ba5 634extern void qla2x00_gff_id(scsi_qla_host_t *, sw_info_t *);
1da177e4 635extern int qla2x00_rft_id(scsi_qla_host_t *);
d3bae931 636extern int qla2x00_rff_id(scsi_qla_host_t *, u8);
1da177e4
LT
637extern int qla2x00_rnn_id(scsi_qla_host_t *);
638extern int qla2x00_rsnn_nn(scsi_qla_host_t *);
cca5335c
AV
639extern void *qla2x00_prep_ms_fdmi_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
640extern void *qla24xx_prep_ms_fdmi_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
641extern int qla2x00_fdmi_register(scsi_qla_host_t *);
d8b45213
AV
642extern int qla2x00_gfpn_id(scsi_qla_host_t *, sw_info_t *);
643extern int qla2x00_gpsc(scsi_qla_host_t *, sw_info_t *);
df57caba 644extern void qla2x00_get_sym_node_name(scsi_qla_host_t *, uint8_t *, size_t);
726b8548
QT
645extern int qla2x00_chk_ms_status(scsi_qla_host_t *, ms_iocb_entry_t *,
646 struct ct_sns_rsp *, const char *);
647extern void qla2x00_async_iocb_timeout(void *data);
648extern int qla24xx_async_gidpn(scsi_qla_host_t *, fc_port_t *);
649int qla24xx_post_gidpn_work(struct scsi_qla_host *, fc_port_t *);
650void qla24xx_handle_gidpn_event(scsi_qla_host_t *, struct event_arg *);
651
652extern void qla2x00_free_fcport(fc_port_t *);
653
654extern int qla24xx_post_gpnid_work(struct scsi_qla_host *, port_id_t *);
655extern int qla24xx_async_gpnid(scsi_qla_host_t *, port_id_t *);
726b8548
QT
656void qla24xx_handle_gpnid_event(scsi_qla_host_t *, struct event_arg *);
657
658int qla24xx_post_gpsc_work(struct scsi_qla_host *, fc_port_t *);
659int qla24xx_async_gpsc(scsi_qla_host_t *, fc_port_t *);
a4239945 660void qla24xx_handle_gpsc_event(scsi_qla_host_t *, struct event_arg *);
726b8548 661int qla2x00_mgmt_svr_login(scsi_qla_host_t *);
d3bae931
DG
662void qla24xx_handle_gffid_event(scsi_qla_host_t *vha, struct event_arg *ea);
663int qla24xx_async_gffid(scsi_qla_host_t *vha, fc_port_t *fcport);
33b28357 664int qla24xx_async_gpnft(scsi_qla_host_t *, u8, srb_t *);
a4239945
QT
665void qla24xx_async_gpnft_done(scsi_qla_host_t *, srb_t *);
666void qla24xx_async_gnnft_done(scsi_qla_host_t *, srb_t *);
667int qla24xx_async_gnnid(scsi_qla_host_t *, fc_port_t *);
668void qla24xx_handle_gnnid_event(scsi_qla_host_t *, struct event_arg *);
669int qla24xx_post_gnnid_work(struct scsi_qla_host *, fc_port_t *);
670int qla24xx_post_gfpnid_work(struct scsi_qla_host *, fc_port_t *);
671int qla24xx_async_gfpnid(scsi_qla_host_t *, fc_port_t *);
672void qla24xx_handle_gfpnid_event(scsi_qla_host_t *, struct event_arg *);
e374f9f5 673void qla24xx_sp_unmap(scsi_qla_host_t *, srb_t *);
f352eeb7 674void qla_scan_work_fn(struct work_struct *);
a4239945 675
8482e118 676/*
677 * Global Function Prototypes in qla_attr.c source file.
678 */
ee959b00
TJ
679struct device_attribute;
680extern struct device_attribute *qla2x00_host_attrs[];
1c97a12a
AV
681struct fc_function_template;
682extern struct fc_function_template qla2xxx_transport_functions;
2c3dfe3f 683extern struct fc_function_template qla2xxx_transport_vport_functions;
8482e118 684extern void qla2x00_alloc_sysfs_attr(scsi_qla_host_t *);
fe1b806f 685extern void qla2x00_free_sysfs_attr(scsi_qla_host_t *, bool);
8482e118 686extern void qla2x00_init_host_attr(scsi_qla_host_t *);
687extern void qla2x00_alloc_sysfs_attr(scsi_qla_host_t *);
9a069e19 688extern int qla2x00_loopback_test(scsi_qla_host_t *, struct msg_echo_lb *, uint16_t *);
09ff701a
SR
689extern int qla2x00_echo_test(scsi_qla_host_t *,
690 struct msg_echo_lb *, uint16_t *);
691extern int qla24xx_update_all_fcp_prio(scsi_qla_host_t *);
7c3df132
SK
692extern int qla24xx_fcp_prio_cfg_valid(scsi_qla_host_t *,
693 struct qla_fcp_prio_cfg *, uint8_t);
df613b96
AV
694
695/*
696 * Global Function Prototypes in qla_dfs.c source file.
697 */
698extern int qla2x00_dfs_setup(scsi_qla_host_t *);
699extern int qla2x00_dfs_remove(scsi_qla_host_t *);
73208dfd
AC
700
701/* Globa function prototypes for multi-q */
d7459527
MH
702extern int qla25xx_request_irq(struct qla_hw_data *, struct qla_qpair *,
703 struct qla_msix_entry *, int);
618a7523
AC
704extern int qla25xx_init_req_que(struct scsi_qla_host *, struct req_que *);
705extern int qla25xx_init_rsp_que(struct scsi_qla_host *, struct rsp_que *);
73208dfd 706extern int qla25xx_create_req_que(struct qla_hw_data *, uint16_t, uint8_t,
82de802a 707 uint16_t, int, uint8_t, bool);
73208dfd 708extern int qla25xx_create_rsp_que(struct qla_hw_data *, uint16_t, uint8_t,
82de802a 709 uint16_t, struct qla_qpair *, bool);
d7459527 710
73208dfd
AC
711extern void qla2x00_init_response_q_entries(struct rsp_que *);
712extern int qla25xx_delete_req_que(struct scsi_qla_host *, struct req_que *);
d7459527 713extern int qla25xx_delete_rsp_que(struct scsi_qla_host *, struct rsp_que *);
2afa19a9 714extern int qla25xx_delete_queues(struct scsi_qla_host *);
17d98630
AC
715extern uint16_t qla24xx_rd_req_reg(struct qla_hw_data *, uint16_t);
716extern uint16_t qla25xx_rd_req_reg(struct qla_hw_data *, uint16_t);
717extern void qla24xx_wrt_req_reg(struct qla_hw_data *, uint16_t, uint16_t);
718extern void qla25xx_wrt_req_reg(struct qla_hw_data *, uint16_t, uint16_t);
719extern void qla25xx_wrt_rsp_reg(struct qla_hw_data *, uint16_t, uint16_t);
720extern void qla24xx_wrt_rsp_reg(struct qla_hw_data *, uint16_t, uint16_t);
2afa19a9 721
8ae6d9c7
GM
722/* qlafx00 related functions */
723extern int qlafx00_pci_config(struct scsi_qla_host *);
724extern int qlafx00_initialize_adapter(struct scsi_qla_host *);
725extern void qlafx00_soft_reset(scsi_qla_host_t *);
726extern int qlafx00_chip_diag(scsi_qla_host_t *);
727extern void qlafx00_config_rings(struct scsi_qla_host *);
728extern char *qlafx00_pci_info_str(struct scsi_qla_host *, char *);
df57caba 729extern char *qlafx00_fw_version_str(struct scsi_qla_host *, char *, size_t);
8ae6d9c7
GM
730extern irqreturn_t qlafx00_intr_handler(int, void *);
731extern void qlafx00_enable_intrs(struct qla_hw_data *);
732extern void qlafx00_disable_intrs(struct qla_hw_data *);
9cb78c16
HR
733extern int qlafx00_abort_target(fc_port_t *, uint64_t, int);
734extern int qlafx00_lun_reset(fc_port_t *, uint64_t, int);
8ae6d9c7
GM
735extern int qlafx00_start_scsi(srb_t *);
736extern int qlafx00_abort_isp(scsi_qla_host_t *);
737extern int qlafx00_iospace_config(struct qla_hw_data *);
738extern int qlafx00_init_firmware(scsi_qla_host_t *, uint16_t);
42479343 739extern int qlafx00_driver_shutdown(scsi_qla_host_t *, int);
8ae6d9c7
GM
740extern int qlafx00_fw_ready(scsi_qla_host_t *);
741extern int qlafx00_configure_devices(scsi_qla_host_t *);
742extern int qlafx00_reset_initialize(scsi_qla_host_t *);
1f8deefe 743extern int qlafx00_fx_disc(scsi_qla_host_t *, fc_port_t *, uint16_t);
8ae6d9c7
GM
744extern int qlafx00_process_aen(struct scsi_qla_host *, struct qla_work_evt *);
745extern int qlafx00_post_aenfx_work(struct scsi_qla_host *, uint32_t,
746 uint32_t *, int);
747extern uint32_t qlafx00_fw_state_show(struct device *,
748 struct device_attribute *, char *);
749extern void qlafx00_get_host_speed(struct Scsi_Host *);
750extern void qlafx00_init_response_q_entries(struct rsp_que *);
751
752extern void qlafx00_tm_iocb(srb_t *, struct tsk_mgmt_entry_fx00 *);
753extern void qlafx00_abort_iocb(srb_t *, struct abort_iocb_entry_fx00 *);
754extern void qlafx00_fxdisc_iocb(srb_t *, struct fxdisc_entry_fx00 *);
755extern void qlafx00_timer_routine(scsi_qla_host_t *);
756extern int qlafx00_rescan_isp(scsi_qla_host_t *);
5854771e 757extern int qlafx00_loop_reset(scsi_qla_host_t *vha);
8ae6d9c7 758
a9083016
GM
759/* qla82xx related functions */
760
761/* PCI related functions */
762extern int qla82xx_pci_config(struct scsi_qla_host *);
763extern int qla82xx_pci_mem_read_2M(struct qla_hw_data *, u64, void *, int);
a9083016 764extern int qla82xx_pci_region_offset(struct pci_dev *, int);
a9083016
GM
765extern int qla82xx_iospace_config(struct qla_hw_data *);
766
767/* Initialization related functions */
768extern void qla82xx_reset_chip(struct scsi_qla_host *);
769extern void qla82xx_config_rings(struct scsi_qla_host *);
a9083016 770extern void qla82xx_watchdog(scsi_qla_host_t *);
a5b36321 771extern int qla82xx_start_firmware(scsi_qla_host_t *);
a9083016
GM
772
773/* Firmware and flash related functions */
774extern int qla82xx_load_risc(scsi_qla_host_t *, uint32_t *);
775extern uint8_t *qla82xx_read_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 776 uint32_t, uint32_t);
a9083016 777extern int qla82xx_write_optrom_data(struct scsi_qla_host *, uint8_t *,
7ec0effd 778 uint32_t, uint32_t);
a9083016
GM
779
780/* Mailbox related functions */
781extern int qla82xx_abort_isp(scsi_qla_host_t *);
782extern int qla82xx_restart_isp(scsi_qla_host_t *);
783
784/* IOCB related functions */
785extern int qla82xx_start_scsi(srb_t *);
25ff6af1 786extern void qla2x00_sp_free(void *);
8e5f4ba0 787extern void qla2x00_sp_timeout(struct timer_list *);
25ff6af1
JC
788extern void qla2x00_bsg_job_done(void *, int);
789extern void qla2x00_bsg_sp_free(void *);
2d70c103 790extern void qla2x00_start_iocbs(struct scsi_qla_host *, struct req_que *);
a9083016
GM
791
792/* Interrupt related */
793extern irqreturn_t qla82xx_intr_handler(int, void *);
794extern irqreturn_t qla82xx_msi_handler(int, void *);
795extern irqreturn_t qla82xx_msix_default(int, void *);
796extern irqreturn_t qla82xx_msix_rsp_q(int, void *);
797extern void qla82xx_enable_intrs(struct qla_hw_data *);
798extern void qla82xx_disable_intrs(struct qla_hw_data *);
a9083016
GM
799extern void qla82xx_poll(int, void *);
800extern void qla82xx_init_flags(struct qla_hw_data *);
801
802/* ISP 8021 hardware related */
a5b36321 803extern void qla82xx_set_drv_active(scsi_qla_host_t *);
a9083016
GM
804extern int qla82xx_wr_32(struct qla_hw_data *, ulong, u32);
805extern int qla82xx_rd_32(struct qla_hw_data *, ulong);
806extern int qla82xx_rdmem(struct qla_hw_data *, u64, void *, int);
807extern int qla82xx_wrmem(struct qla_hw_data *, u64, void *, int);
a9083016
GM
808
809/* ISP 8021 IDC */
810extern void qla82xx_clear_drv_active(struct qla_hw_data *);
579d12b5 811extern uint32_t qla82xx_wait_for_state_change(scsi_qla_host_t *, uint32_t);
a9083016
GM
812extern int qla82xx_idc_lock(struct qla_hw_data *);
813extern void qla82xx_idc_unlock(struct qla_hw_data *);
814extern int qla82xx_device_state_handler(scsi_qla_host_t *);
7d613ac6 815extern void qla8xxx_dev_failed_handler(scsi_qla_host_t *);
579d12b5 816extern void qla82xx_clear_qsnt_ready(scsi_qla_host_t *);
a9083016
GM
817
818extern void qla2x00_set_model_info(scsi_qla_host_t *, uint8_t *,
7ec0effd 819 size_t, char *);
a9083016
GM
820extern int qla82xx_mbx_intr_enable(scsi_qla_host_t *);
821extern int qla82xx_mbx_intr_disable(scsi_qla_host_t *);
5162cf0c 822extern void qla82xx_start_iocbs(scsi_qla_host_t *);
a9083016 823extern int qla82xx_fcoe_ctx_reset(scsi_qla_host_t *);
3173167f 824extern int qla82xx_check_md_needed(scsi_qla_host_t *);
7190575f 825extern void qla82xx_chip_reset_cleanup(scsi_qla_host_t *);
6246b8a1
GM
826extern int qla81xx_set_led_config(scsi_qla_host_t *, uint16_t *);
827extern int qla81xx_get_led_config(scsi_qla_host_t *, uint16_t *);
999916dc 828extern int qla82xx_mbx_beacon_ctl(scsi_qla_host_t *, int);
08de2844 829extern char *qdev_state(uint32_t);
c8f6544e 830extern void qla82xx_clear_pending_mbx(scsi_qla_host_t *);
1ae47cf3
JC
831extern int qla82xx_read_temperature(scsi_qla_host_t *);
832extern int qla8044_read_temperature(scsi_qla_host_t *);
e4e3a2ce 833extern int qla2x00_read_sfp_dev(struct scsi_qla_host *, char *, int);
a9083016 834
6e98016c 835/* BSG related functions */
75cc8cfc
JT
836extern int qla24xx_bsg_request(struct bsg_job *);
837extern int qla24xx_bsg_timeout(struct bsg_job *);
6e98016c
GM
838extern int qla84xx_reset_chip(scsi_qla_host_t *, uint16_t);
839extern int qla2x00_issue_iocb_timeout(scsi_qla_host_t *, void *,
840 dma_addr_t, size_t, uint32_t);
841extern int qla2x00_get_idma_speed(scsi_qla_host_t *, uint16_t,
842 uint16_t *, uint16_t *);
08de2844 843
6246b8a1
GM
844/* 83xx related functions */
845extern void qla83xx_fw_dump(scsi_qla_host_t *, int);
846
08de2844
GM
847/* Minidump related functions */
848extern int qla82xx_md_get_template_size(scsi_qla_host_t *);
849extern int qla82xx_md_get_template(scsi_qla_host_t *);
850extern int qla82xx_md_alloc(scsi_qla_host_t *);
851extern void qla82xx_md_free(scsi_qla_host_t *);
852extern int qla82xx_md_collect(scsi_qla_host_t *);
853extern void qla82xx_md_prep(scsi_qla_host_t *);
854extern void qla82xx_set_reset_owner(scsi_qla_host_t *);
7ec0effd
AD
855extern int qla82xx_validate_template_chksum(scsi_qla_host_t *vha);
856
857/* Function declarations for ISP8044 */
858extern int qla8044_idc_lock(struct qla_hw_data *ha);
859extern void qla8044_idc_unlock(struct qla_hw_data *ha);
860extern uint32_t qla8044_rd_reg(struct qla_hw_data *ha, ulong addr);
861extern void qla8044_wr_reg(struct qla_hw_data *ha, ulong addr, uint32_t val);
862extern void qla8044_read_reset_template(struct scsi_qla_host *ha);
863extern void qla8044_set_idc_dontreset(struct scsi_qla_host *ha);
864extern int qla8044_rd_direct(struct scsi_qla_host *vha, const uint32_t crb_reg);
865extern void qla8044_wr_direct(struct scsi_qla_host *vha,
866 const uint32_t crb_reg, const uint32_t value);
7ec0effd
AD
867extern int qla8044_device_state_handler(struct scsi_qla_host *vha);
868extern void qla8044_clear_qsnt_ready(struct scsi_qla_host *vha);
c41afc9a 869extern void qla8044_clear_drv_active(struct qla_hw_data *);
7ec0effd
AD
870void qla8044_get_minidump(struct scsi_qla_host *vha);
871int qla8044_collect_md_data(struct scsi_qla_host *vha);
872extern int qla8044_md_get_template(scsi_qla_host_t *);
873extern int qla8044_write_optrom_data(struct scsi_qla_host *, uint8_t *,
874 uint32_t, uint32_t);
875extern irqreturn_t qla8044_intr_handler(int, void *);
876extern void qla82xx_mbx_completion(scsi_qla_host_t *, uint16_t);
877extern int qla8044_abort_isp(scsi_qla_host_t *);
878extern int qla8044_check_fw_alive(struct scsi_qla_host *);
b0d6cabd
HM
879extern int qla_get_exlogin_status(scsi_qla_host_t *, uint16_t *,
880 uint16_t *);
881extern int qla_set_exlogin_mem_cfg(scsi_qla_host_t *vha, dma_addr_t phys_addr);
2f56a7f1 882extern int qla_get_exchoffld_status(scsi_qla_host_t *, uint16_t *, uint16_t *);
99e1b683 883extern int qla_set_exchoffld_mem_cfg(scsi_qla_host_t *);
82de802a
QT
884extern void qlt_handle_abts_recv(struct scsi_qla_host *, struct rsp_que *,
885 response_t *);
b0d6cabd 886
726b8548
QT
887int qla24xx_async_notify_ack(scsi_qla_host_t *, fc_port_t *,
888 struct imm_ntfy_from_isp *, int);
889void qla24xx_do_nack_work(struct scsi_qla_host *, struct qla_work_evt *);
890void qlt_plogi_ack_link(struct scsi_qla_host *, struct qlt_plogi_ack_t *,
891 struct fc_port *, enum qlt_plogi_link_t);
892void qlt_plogi_ack_unref(struct scsi_qla_host *, struct qlt_plogi_ack_t *);
94cff6e1 893extern void qlt_schedule_sess_for_deletion(struct fc_port *);
726b8548
QT
894extern struct fc_port *qlt_find_sess_invalidate_other(scsi_qla_host_t *,
895 uint64_t wwn, port_id_t port_id, uint16_t loop_id, struct fc_port **);
896void qla24xx_delete_sess_fn(struct work_struct *);
41dc529a 897void qlt_unknown_atio_work_fn(struct work_struct *);
482c9dc7
QT
898void qlt_update_host_map(struct scsi_qla_host *, port_id_t);
899void qlt_remove_target_resources(struct qla_hw_data *);
09620eeb 900void qlt_clr_qp_table(struct scsi_qla_host *vha);
726b8548 901
1da177e4 902#endif /* _QLA_GBL_H */