4fdfefe529
ISP23xx and ISP24xx chips have support for an adaptive method of posting SCSI command completions for multiple SCSI commands during a single system interrupt. SCSI commands are placed on the system response queue without interrupting the host until 1) a delay timer expires; or 2) a SCSI command completes with an error. As long as the host software (qla2xxx) services the response queue for completions (this polling is done during queuecommand()) within the 'delay timer' period, the firmware will not generate system interrupt. Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
305 lines
10 KiB
C
305 lines
10 KiB
C
/********************************************************************************
|
|
* QLOGIC LINUX SOFTWARE
|
|
*
|
|
* QLogic ISP2x00 device driver for Linux 2.6.x
|
|
* Copyright (C) 2003-2005 QLogic Corporation
|
|
* (www.qlogic.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2, or (at your option) any
|
|
* later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
******************************************************************************
|
|
* Global include file.
|
|
******************************************************************************/
|
|
|
|
|
|
#ifndef __QLA_GBL_H
|
|
#define __QLA_GBL_H
|
|
|
|
#include <linux/interrupt.h>
|
|
|
|
extern void qla2x00_remove_one(struct pci_dev *);
|
|
extern int qla2x00_probe_one(struct pci_dev *, struct qla_board_info *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_init.c source file.
|
|
*/
|
|
extern int qla2x00_initialize_adapter(scsi_qla_host_t *);
|
|
|
|
extern int qla2100_pci_config(struct scsi_qla_host *);
|
|
extern int qla2300_pci_config(struct scsi_qla_host *);
|
|
extern int qla24xx_pci_config(scsi_qla_host_t *);
|
|
extern void qla2x00_reset_chip(struct scsi_qla_host *);
|
|
extern void qla24xx_reset_chip(struct scsi_qla_host *);
|
|
extern int qla2x00_chip_diag(struct scsi_qla_host *);
|
|
extern int qla24xx_chip_diag(struct scsi_qla_host *);
|
|
extern void qla2x00_config_rings(struct scsi_qla_host *);
|
|
extern void qla24xx_config_rings(struct scsi_qla_host *);
|
|
extern void qla2x00_reset_adapter(struct scsi_qla_host *);
|
|
extern void qla24xx_reset_adapter(struct scsi_qla_host *);
|
|
extern int qla2x00_nvram_config(struct scsi_qla_host *);
|
|
extern int qla24xx_nvram_config(struct scsi_qla_host *);
|
|
extern void qla2x00_update_fw_options(struct scsi_qla_host *);
|
|
extern void qla24xx_update_fw_options(scsi_qla_host_t *);
|
|
extern int qla2x00_load_risc(struct scsi_qla_host *, uint32_t *);
|
|
extern int qla24xx_load_risc_flash(scsi_qla_host_t *, uint32_t *);
|
|
extern int qla24xx_load_risc_hotplug(scsi_qla_host_t *, uint32_t *);
|
|
|
|
extern fc_port_t *qla2x00_alloc_fcport(scsi_qla_host_t *, gfp_t);
|
|
|
|
extern int qla2x00_loop_resync(scsi_qla_host_t *);
|
|
|
|
extern int qla2x00_find_new_loop_id(scsi_qla_host_t *, fc_port_t *);
|
|
extern int qla2x00_fabric_login(scsi_qla_host_t *, fc_port_t *, uint16_t *);
|
|
extern int qla2x00_local_device_login(scsi_qla_host_t *, uint16_t);
|
|
|
|
extern void qla2x00_restart_queues(scsi_qla_host_t *, uint8_t);
|
|
|
|
extern void qla2x00_rescan_fcports(scsi_qla_host_t *);
|
|
|
|
extern int qla2x00_abort_isp(scsi_qla_host_t *);
|
|
|
|
extern void qla2x00_reg_remote_port(scsi_qla_host_t *, fc_port_t *);
|
|
|
|
/*
|
|
* Global Data in qla_os.c source file.
|
|
*/
|
|
extern char qla2x00_version_str[];
|
|
|
|
extern int ql2xlogintimeout;
|
|
extern int qlport_down_retry;
|
|
extern int ql2xplogiabsentdevice;
|
|
extern int ql2xloginretrycount;
|
|
extern int ql2xfdmienable;
|
|
|
|
extern void qla2x00_sp_compl(scsi_qla_host_t *, srb_t *);
|
|
|
|
extern char *qla2x00_get_fw_version_str(struct scsi_qla_host *, char *);
|
|
|
|
extern void qla2x00_cmd_timeout(srb_t *);
|
|
|
|
extern void qla2x00_mark_device_lost(scsi_qla_host_t *, fc_port_t *, int);
|
|
extern void qla2x00_mark_all_devices_lost(scsi_qla_host_t *);
|
|
|
|
extern void qla2x00_blink_led(scsi_qla_host_t *);
|
|
|
|
extern int qla2x00_down_timeout(struct semaphore *, unsigned long);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_iocb.c source file.
|
|
*/
|
|
extern void qla2x00_isp_cmd(scsi_qla_host_t *);
|
|
|
|
extern uint16_t qla2x00_calc_iocbs_32(uint16_t);
|
|
extern uint16_t qla2x00_calc_iocbs_64(uint16_t);
|
|
extern void qla2x00_build_scsi_iocbs_32(srb_t *, cmd_entry_t *, uint16_t);
|
|
extern void qla2x00_build_scsi_iocbs_64(srb_t *, cmd_entry_t *, uint16_t);
|
|
extern int qla2x00_start_scsi(srb_t *sp);
|
|
extern int qla24xx_start_scsi(srb_t *sp);
|
|
int qla2x00_marker(scsi_qla_host_t *, uint16_t, uint16_t, uint8_t);
|
|
int __qla2x00_marker(scsi_qla_host_t *, uint16_t, uint16_t, uint8_t);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_mbx.c source file.
|
|
*/
|
|
extern int
|
|
qla2x00_load_ram(scsi_qla_host_t *, dma_addr_t, uint16_t, uint16_t);
|
|
|
|
extern int
|
|
qla2x00_load_ram_ext(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
|
|
|
|
extern int
|
|
qla2x00_execute_fw(scsi_qla_host_t *, uint32_t);
|
|
|
|
extern void
|
|
qla2x00_get_fw_version(scsi_qla_host_t *, uint16_t *,
|
|
uint16_t *, uint16_t *, uint16_t *, uint32_t *);
|
|
|
|
extern int
|
|
qla2x00_get_fw_options(scsi_qla_host_t *, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_set_fw_options(scsi_qla_host_t *, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_mbx_reg_test(scsi_qla_host_t *);
|
|
|
|
extern int
|
|
qla2x00_verify_checksum(scsi_qla_host_t *, uint32_t);
|
|
|
|
extern int
|
|
qla2x00_issue_iocb(scsi_qla_host_t *, void *, dma_addr_t, size_t);
|
|
|
|
extern int
|
|
qla2x00_abort_command(scsi_qla_host_t *, srb_t *);
|
|
|
|
#if USE_ABORT_TGT
|
|
extern int
|
|
qla2x00_abort_target(fc_port_t *);
|
|
#endif
|
|
|
|
extern int
|
|
qla2x00_get_adapter_id(scsi_qla_host_t *, uint16_t *, uint8_t *, uint8_t *,
|
|
uint8_t *, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_get_retry_cnt(scsi_qla_host_t *, uint8_t *, uint8_t *, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_init_firmware(scsi_qla_host_t *, uint16_t);
|
|
|
|
extern int
|
|
qla2x00_get_port_database(scsi_qla_host_t *, fc_port_t *, uint8_t);
|
|
|
|
extern int
|
|
qla2x00_get_firmware_state(scsi_qla_host_t *, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_get_port_name(scsi_qla_host_t *, uint16_t, uint8_t *, uint8_t);
|
|
|
|
extern int
|
|
qla2x00_lip_reset(scsi_qla_host_t *);
|
|
|
|
extern int
|
|
qla2x00_send_sns(scsi_qla_host_t *, dma_addr_t, uint16_t, size_t);
|
|
|
|
extern int
|
|
qla2x00_login_fabric(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t,
|
|
uint16_t *, uint8_t);
|
|
extern int
|
|
qla24xx_login_fabric(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t,
|
|
uint16_t *, uint8_t);
|
|
|
|
extern int
|
|
qla2x00_login_local_device(scsi_qla_host_t *, uint16_t, uint16_t *, uint8_t);
|
|
|
|
extern int
|
|
qla2x00_fabric_logout(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t);
|
|
|
|
extern int
|
|
qla24xx_fabric_logout(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t);
|
|
|
|
extern int
|
|
qla2x00_full_login_lip(scsi_qla_host_t *ha);
|
|
|
|
extern int
|
|
qla2x00_get_id_list(scsi_qla_host_t *, void *, dma_addr_t, uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_get_resource_cnts(scsi_qla_host_t *, uint16_t *, uint16_t *, uint16_t *,
|
|
uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_get_fcal_position_map(scsi_qla_host_t *ha, char *pos_map);
|
|
|
|
extern int qla24xx_abort_command(scsi_qla_host_t *, srb_t *);
|
|
extern int qla24xx_abort_target(fc_port_t *);
|
|
|
|
extern int qla2x00_system_error(scsi_qla_host_t *);
|
|
|
|
extern int
|
|
qla2x00_get_serdes_params(scsi_qla_host_t *, uint16_t *, uint16_t *,
|
|
uint16_t *);
|
|
|
|
extern int
|
|
qla2x00_set_serdes_params(scsi_qla_host_t *, uint16_t, uint16_t, uint16_t);
|
|
|
|
extern int
|
|
qla2x00_stop_firmware(scsi_qla_host_t *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_isr.c source file.
|
|
*/
|
|
extern irqreturn_t qla2100_intr_handler(int, void *, struct pt_regs *);
|
|
extern irqreturn_t qla2300_intr_handler(int, void *, struct pt_regs *);
|
|
extern irqreturn_t qla24xx_intr_handler(int, void *, struct pt_regs *);
|
|
extern void qla2x00_process_response_queue(struct scsi_qla_host *);
|
|
extern void qla24xx_process_response_queue(struct scsi_qla_host *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_sup.c source file.
|
|
*/
|
|
extern void qla2x00_lock_nvram_access(scsi_qla_host_t *);
|
|
extern void qla2x00_unlock_nvram_access(scsi_qla_host_t *);
|
|
extern void qla2x00_release_nvram_protection(scsi_qla_host_t *);
|
|
extern uint16_t qla2x00_get_nvram_word(scsi_qla_host_t *, uint32_t);
|
|
extern void qla2x00_write_nvram_word(scsi_qla_host_t *, uint32_t, uint16_t);
|
|
extern uint32_t *qla24xx_read_flash_data(scsi_qla_host_t *, uint32_t *,
|
|
uint32_t, uint32_t);
|
|
extern uint8_t *qla2x00_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
uint32_t);
|
|
extern uint8_t *qla24xx_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
uint32_t);
|
|
extern int qla2x00_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
uint32_t);
|
|
extern int qla24xx_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
uint32_t);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_dbg.c source file.
|
|
*/
|
|
extern void qla2100_fw_dump(scsi_qla_host_t *, int);
|
|
extern void qla2300_fw_dump(scsi_qla_host_t *, int);
|
|
extern void qla24xx_fw_dump(scsi_qla_host_t *, int);
|
|
extern void qla2100_ascii_fw_dump(scsi_qla_host_t *);
|
|
extern void qla2300_ascii_fw_dump(scsi_qla_host_t *);
|
|
extern void qla24xx_ascii_fw_dump(scsi_qla_host_t *);
|
|
extern void qla2x00_dump_regs(scsi_qla_host_t *);
|
|
extern void qla2x00_dump_buffer(uint8_t *, uint32_t);
|
|
extern void qla2x00_print_scsi_cmd(struct scsi_cmnd *);
|
|
extern void qla2x00_dump_pkt(void *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_gs.c source file.
|
|
*/
|
|
extern void *qla2x00_prep_ms_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
extern void *qla24xx_prep_ms_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
extern int qla2x00_ga_nxt(scsi_qla_host_t *, fc_port_t *);
|
|
extern int qla2x00_gid_pt(scsi_qla_host_t *, sw_info_t *);
|
|
extern int qla2x00_gpn_id(scsi_qla_host_t *, sw_info_t *);
|
|
extern int qla2x00_gnn_id(scsi_qla_host_t *, sw_info_t *);
|
|
extern int qla2x00_rft_id(scsi_qla_host_t *);
|
|
extern int qla2x00_rff_id(scsi_qla_host_t *);
|
|
extern int qla2x00_rnn_id(scsi_qla_host_t *);
|
|
extern int qla2x00_rsnn_nn(scsi_qla_host_t *);
|
|
extern void *qla2x00_prep_ms_fdmi_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
extern void *qla24xx_prep_ms_fdmi_iocb(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
extern int qla2x00_fdmi_register(scsi_qla_host_t *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_rscn.c source file.
|
|
*/
|
|
extern fc_port_t *qla2x00_alloc_rscn_fcport(scsi_qla_host_t *, gfp_t);
|
|
extern int qla2x00_handle_port_rscn(scsi_qla_host_t *, uint32_t, fc_port_t *,
|
|
int);
|
|
extern void qla2x00_process_iodesc(scsi_qla_host_t *, struct mbx_entry *);
|
|
extern void qla2x00_cancel_io_descriptors(scsi_qla_host_t *);
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_xioctl.c source file.
|
|
*/
|
|
#define qla2x00_enqueue_aen(ha, cmd, mode) do { } while (0)
|
|
#define qla2x00_alloc_ioctl_mem(ha) (0)
|
|
#define qla2x00_free_ioctl_mem(ha) do { } while (0)
|
|
|
|
/*
|
|
* Global Function Prototypes in qla_attr.c source file.
|
|
*/
|
|
struct class_device_attribute;
|
|
extern struct class_device_attribute *qla2x00_host_attrs[];
|
|
struct fc_function_template;
|
|
extern struct fc_function_template qla2xxx_transport_functions;
|
|
extern void qla2x00_alloc_sysfs_attr(scsi_qla_host_t *);
|
|
extern void qla2x00_free_sysfs_attr(scsi_qla_host_t *);
|
|
extern void qla2x00_init_host_attr(scsi_qla_host_t *);
|
|
extern void qla2x00_alloc_sysfs_attr(scsi_qla_host_t *);
|
|
extern void qla2x00_free_sysfs_attr(scsi_qla_host_t *);
|
|
#endif /* _QLA_GBL_H */
|