2005-10-28 01:10:08 +07:00
|
|
|
/*
|
|
|
|
* QLogic Fibre Channel HBA Driver
|
2008-04-04 03:13:13 +07:00
|
|
|
* Copyright (c) 2003-2008 QLogic Corporation
|
2005-10-28 01:10:08 +07:00
|
|
|
*
|
|
|
|
* See LICENSE.qla2xxx for copyright and licensing details.
|
|
|
|
*/
|
2005-04-17 05:20:36 +07:00
|
|
|
#ifndef __QLA_GBL_H
|
|
|
|
#define __QLA_GBL_H
|
|
|
|
|
|
|
|
#include <linux/interrupt.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_init.c source file.
|
|
|
|
*/
|
|
|
|
extern int qla2x00_initialize_adapter(scsi_qla_host_t *);
|
2005-07-07 00:30:05 +07:00
|
|
|
|
|
|
|
extern int qla2100_pci_config(struct scsi_qla_host *);
|
|
|
|
extern int qla2300_pci_config(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern int qla24xx_pci_config(scsi_qla_host_t *);
|
2007-07-20 10:37:34 +07:00
|
|
|
extern int qla25xx_pci_config(scsi_qla_host_t *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern void qla2x00_reset_chip(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern void qla24xx_reset_chip(struct scsi_qla_host *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern int qla2x00_chip_diag(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern int qla24xx_chip_diag(struct scsi_qla_host *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern void qla2x00_config_rings(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern void qla24xx_config_rings(struct scsi_qla_host *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern void qla2x00_reset_adapter(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern void qla24xx_reset_adapter(struct scsi_qla_host *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern int qla2x00_nvram_config(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern int qla24xx_nvram_config(struct scsi_qla_host *);
|
2009-01-06 02:18:11 +07:00
|
|
|
extern int qla81xx_nvram_config(struct scsi_qla_host *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern void qla2x00_update_fw_options(struct scsi_qla_host *);
|
2005-07-07 00:31:37 +07:00
|
|
|
extern void qla24xx_update_fw_options(scsi_qla_host_t *);
|
2009-01-06 02:18:11 +07:00
|
|
|
extern void qla81xx_update_fw_options(scsi_qla_host_t *);
|
2005-07-07 00:30:05 +07:00
|
|
|
extern int qla2x00_load_risc(struct scsi_qla_host *, uint32_t *);
|
2005-11-10 06:49:04 +07:00
|
|
|
extern int qla24xx_load_risc(scsi_qla_host_t *, uint32_t *);
|
2009-01-23 00:45:32 +07:00
|
|
|
extern int qla81xx_load_risc(scsi_qla_host_t *, uint32_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int qla2x00_loop_resync(scsi_qla_host_t *);
|
|
|
|
|
|
|
|
extern int qla2x00_fabric_login(scsi_qla_host_t *, fc_port_t *, uint16_t *);
|
2006-03-10 05:27:44 +07:00
|
|
|
extern int qla2x00_local_device_login(scsi_qla_host_t *, fc_port_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2006-01-21 05:53:13 +07:00
|
|
|
extern void qla2x00_update_fcports(scsi_qla_host_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int qla2x00_abort_isp(scsi_qla_host_t *);
|
|
|
|
|
2006-01-21 05:53:19 +07:00
|
|
|
extern void qla2x00_update_fcport(scsi_qla_host_t *, fc_port_t *);
|
2005-04-18 03:04:54 +07:00
|
|
|
|
2006-06-24 06:10:29 +07:00
|
|
|
extern void qla2x00_alloc_fw_dump(scsi_qla_host_t *);
|
2006-10-13 23:33:38 +07:00
|
|
|
extern void qla2x00_try_to_stop_firmware(scsi_qla_host_t *);
|
2006-06-24 06:10:29 +07:00
|
|
|
|
2008-04-04 03:13:26 +07:00
|
|
|
extern void qla84xx_put_chip(struct scsi_qla_host *);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* 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;
|
2005-08-27 09:08:30 +07:00
|
|
|
extern int ql2xfdmienable;
|
2006-06-24 06:10:29 +07:00
|
|
|
extern int ql2xallocfwdump;
|
2006-10-06 23:54:59 +07:00
|
|
|
extern int ql2xextended_error_logging;
|
2006-10-13 23:33:39 +07:00
|
|
|
extern int ql2xqfullrampup;
|
2009-04-07 12:33:47 +07:00
|
|
|
extern int ql2xqfulltracking;
|
2008-07-11 06:55:52 +07:00
|
|
|
extern int ql2xiidmaenable;
|
2008-12-10 07:45:39 +07:00
|
|
|
extern int ql2xmaxqueues;
|
2009-04-07 12:33:40 +07:00
|
|
|
extern int ql2xmultique_tag;
|
2009-04-07 12:33:49 +07:00
|
|
|
extern int ql2xfwloadbin;
|
2007-07-06 03:16:51 +07:00
|
|
|
|
2008-01-18 00:02:12 +07:00
|
|
|
extern int qla2x00_loop_reset(scsi_qla_host_t *);
|
2008-02-01 03:33:46 +07:00
|
|
|
extern void qla2x00_abort_all_cmds(scsi_qla_host_t *, int);
|
2008-04-04 03:13:18 +07:00
|
|
|
extern int qla2x00_post_aen_work(struct scsi_qla_host *, enum
|
|
|
|
fc_host_event_code, u32);
|
2009-02-09 11:50:12 +07:00
|
|
|
extern int qla2x00_post_idc_ack_work(struct scsi_qla_host *, uint16_t *);
|
2009-03-26 22:49:17 +07:00
|
|
|
extern int qla81xx_restart_mpi_firmware(scsi_qla_host_t *);
|
2008-01-18 00:02:12 +07:00
|
|
|
|
2008-07-11 06:55:47 +07:00
|
|
|
extern void qla2x00_abort_fcport_cmds(fc_port_t *);
|
2008-11-07 01:40:19 +07:00
|
|
|
extern struct scsi_qla_host *qla2x00_create_host(struct scsi_host_template *,
|
|
|
|
struct qla_hw_data *);
|
|
|
|
extern void qla2x00_free_host(struct scsi_qla_host *);
|
|
|
|
extern void qla2x00_relogin(struct scsi_qla_host *);
|
2007-07-06 03:16:51 +07:00
|
|
|
/*
|
|
|
|
* Global Functions in qla_mid.c source file.
|
|
|
|
*/
|
2009-03-24 23:07:56 +07:00
|
|
|
extern struct scsi_host_template qla2xxx_driver_template;
|
2007-07-06 03:16:51 +07:00
|
|
|
extern struct scsi_transport_template *qla2xxx_transport_vport_template;
|
|
|
|
extern void qla2x00_timer(scsi_qla_host_t *);
|
|
|
|
extern void qla2x00_start_timer(scsi_qla_host_t *, void *, unsigned long);
|
|
|
|
extern void qla24xx_deallocate_vp_id(scsi_qla_host_t *);
|
|
|
|
extern int qla24xx_disable_vp (scsi_qla_host_t *);
|
|
|
|
extern int qla24xx_enable_vp (scsi_qla_host_t *);
|
|
|
|
extern int qla24xx_control_vp(scsi_qla_host_t *, int );
|
|
|
|
extern int qla24xx_modify_vp_config(scsi_qla_host_t *);
|
|
|
|
extern int qla2x00_send_change_request(scsi_qla_host_t *, uint16_t, uint16_t);
|
|
|
|
extern void qla2x00_vp_stop_timer(scsi_qla_host_t *);
|
|
|
|
extern int qla24xx_configure_vhba (scsi_qla_host_t *);
|
|
|
|
extern void qla24xx_report_id_acquisition(scsi_qla_host_t *,
|
|
|
|
struct vp_rpt_id_entry_24xx *);
|
|
|
|
extern void qla2x00_do_dpc_all_vps(scsi_qla_host_t *);
|
|
|
|
extern int qla24xx_vport_create_req_sanity_check(struct fc_vport *);
|
|
|
|
extern scsi_qla_host_t * qla24xx_create_vhost(struct fc_vport *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2008-12-10 07:45:39 +07:00
|
|
|
extern void qla2x00_sp_compl(struct qla_hw_data *, srb_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern char *qla2x00_get_fw_version_str(struct scsi_qla_host *, char *);
|
|
|
|
|
2006-01-21 05:53:13 +07:00
|
|
|
extern void qla2x00_mark_device_lost(scsi_qla_host_t *, fc_port_t *, int, int);
|
|
|
|
extern void qla2x00_mark_all_devices_lost(scsi_qla_host_t *, int);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2005-11-10 06:49:04 +07:00
|
|
|
extern struct fw_blob *qla2x00_request_firmware(scsi_qla_host_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2006-02-01 07:05:17 +07:00
|
|
|
extern int qla2x00_wait_for_hba_online(scsi_qla_host_t *);
|
2009-03-24 23:08:07 +07:00
|
|
|
extern int qla2x00_wait_for_chip_reset(scsi_qla_host_t *);
|
2006-02-01 07:05:17 +07:00
|
|
|
|
2008-11-07 01:40:19 +07:00
|
|
|
extern void qla2xxx_wake_dpc(struct scsi_qla_host *);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern void qla2x00_alert_all_vps(struct rsp_que *, uint16_t *);
|
|
|
|
extern void qla2x00_async_event(scsi_qla_host_t *, struct rsp_que *,
|
|
|
|
uint16_t *);
|
2008-11-07 01:40:19 +07:00
|
|
|
extern int qla2x00_vp_abort_isp(scsi_qla_host_t *);
|
2006-02-15 00:46:22 +07:00
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_iocb.c source file.
|
|
|
|
*/
|
|
|
|
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);
|
2005-07-07 00:31:17 +07:00
|
|
|
extern int qla24xx_start_scsi(srb_t *sp);
|
2008-12-10 07:45:39 +07:00
|
|
|
int qla2x00_marker(struct scsi_qla_host *, struct req_que *, struct rsp_que *,
|
|
|
|
uint16_t, uint16_t, uint8_t);
|
|
|
|
int __qla2x00_marker(struct scsi_qla_host *, struct req_que *, struct rsp_que *,
|
|
|
|
uint16_t, uint16_t, uint8_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_mbx.c source file.
|
|
|
|
*/
|
|
|
|
extern int
|
2006-01-14 08:05:37 +07:00
|
|
|
qla2x00_load_ram(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2007-09-21 04:07:33 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_dump_ram(scsi_qla_host_t *, dma_addr_t, uint32_t, uint32_t);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
extern int
|
2005-07-07 00:30:57 +07:00
|
|
|
qla2x00_execute_fw(scsi_qla_host_t *, uint32_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2009-06-03 23:55:20 +07:00
|
|
|
extern int
|
2009-03-24 23:08:03 +07:00
|
|
|
qla2x00_get_fw_version(scsi_qla_host_t *, uint16_t *, uint16_t *, uint16_t *,
|
|
|
|
uint16_t *, uint32_t *, uint8_t *, uint32_t *, uint8_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
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
|
2005-07-07 00:30:57 +07:00
|
|
|
qla2x00_verify_checksum(scsi_qla_host_t *, uint32_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_issue_iocb(scsi_qla_host_t *, void *, dma_addr_t, size_t);
|
|
|
|
|
|
|
|
extern int
|
2009-04-07 12:33:40 +07:00
|
|
|
qla2x00_abort_command(srb_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
2009-04-07 12:33:40 +07:00
|
|
|
qla2x00_abort_target(struct fc_port *, unsigned int, int);
|
2008-04-04 03:13:24 +07:00
|
|
|
|
|
|
|
extern int
|
2009-04-07 12:33:40 +07:00
|
|
|
qla2x00_lun_reset(struct fc_port *, unsigned int, int);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_get_adapter_id(scsi_qla_host_t *, uint16_t *, uint8_t *, uint8_t *,
|
2007-07-06 03:16:51 +07:00
|
|
|
uint8_t *, uint16_t *, uint16_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
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);
|
2005-07-07 00:30:57 +07:00
|
|
|
extern int
|
|
|
|
qla24xx_login_fabric(scsi_qla_host_t *, uint16_t, uint8_t, uint8_t, uint8_t,
|
|
|
|
uint16_t *, uint8_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
2006-03-10 05:27:44 +07:00
|
|
|
qla2x00_login_local_device(scsi_qla_host_t *, fc_port_t *, uint16_t *,
|
|
|
|
uint8_t);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
2005-07-07 00:30:57 +07:00
|
|
|
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);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
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
|
2007-09-21 04:07:43 +07:00
|
|
|
qla2x00_get_resource_cnts(scsi_qla_host_t *, uint16_t *, uint16_t *,
|
|
|
|
uint16_t *, uint16_t *, uint16_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_get_fcal_position_map(scsi_qla_host_t *ha, char *pos_map);
|
|
|
|
|
2006-02-01 07:05:02 +07:00
|
|
|
extern int
|
2008-01-18 00:02:08 +07:00
|
|
|
qla2x00_get_link_status(scsi_qla_host_t *, uint16_t, struct link_statistics *,
|
|
|
|
dma_addr_t);
|
2006-02-01 07:05:02 +07:00
|
|
|
|
|
|
|
extern int
|
2008-01-18 00:02:08 +07:00
|
|
|
qla24xx_get_isp_stats(scsi_qla_host_t *, struct link_statistics *,
|
|
|
|
dma_addr_t);
|
2006-02-01 07:05:02 +07:00
|
|
|
|
2009-04-07 12:33:40 +07:00
|
|
|
extern int qla24xx_abort_command(srb_t *);
|
|
|
|
extern int
|
|
|
|
qla24xx_abort_target(struct fc_port *, unsigned int, int);
|
|
|
|
extern int
|
|
|
|
qla24xx_lun_reset(struct fc_port *, unsigned int, int);
|
2005-07-07 00:30:57 +07:00
|
|
|
|
2008-05-13 12:21:13 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_system_error(scsi_qla_host_t *);
|
|
|
|
|
2005-07-07 00:30:57 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_set_serdes_params(scsi_qla_host_t *, uint16_t, uint16_t, uint16_t);
|
|
|
|
|
2005-08-27 09:10:20 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_stop_firmware(scsi_qla_host_t *);
|
|
|
|
|
2006-06-24 06:10:29 +07:00
|
|
|
extern int
|
2008-01-18 00:02:16 +07:00
|
|
|
qla2x00_enable_eft_trace(scsi_qla_host_t *, dma_addr_t, uint16_t);
|
|
|
|
extern int
|
|
|
|
qla2x00_disable_eft_trace(scsi_qla_host_t *);
|
2006-06-24 06:10:29 +07:00
|
|
|
|
2008-01-18 00:02:17 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_enable_fce_trace(scsi_qla_host_t *, dma_addr_t, uint16_t , uint16_t *,
|
|
|
|
uint32_t *);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_disable_fce_trace(scsi_qla_host_t *, uint64_t *, uint64_t *);
|
|
|
|
|
2006-06-24 06:10:50 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_read_sfp(scsi_qla_host_t *, dma_addr_t, uint16_t, uint16_t, uint16_t);
|
|
|
|
|
2009-03-24 23:08:12 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_read_edc(scsi_qla_host_t *, uint16_t, uint16_t, dma_addr_t,
|
|
|
|
uint8_t *, uint16_t, uint16_t);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_write_edc(scsi_qla_host_t *, uint16_t, uint16_t, dma_addr_t,
|
|
|
|
uint8_t *, uint16_t, uint16_t);
|
|
|
|
|
2006-10-03 02:00:43 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_set_idma_speed(scsi_qla_host_t *, uint16_t, uint16_t, uint16_t *);
|
|
|
|
|
2008-04-04 03:13:26 +07:00
|
|
|
extern int qla84xx_verify_chip(struct scsi_qla_host *, uint16_t *);
|
|
|
|
|
2009-02-09 11:50:12 +07:00
|
|
|
extern int qla81xx_idc_ack(scsi_qla_host_t *, uint16_t *);
|
|
|
|
|
2009-03-24 23:08:06 +07:00
|
|
|
extern int
|
|
|
|
qla81xx_fac_get_sector_size(scsi_qla_host_t *, uint32_t *);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
qla81xx_fac_do_write_enable(scsi_qla_host_t *, int);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
qla81xx_fac_erase_sector(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
|
|
|
2009-06-03 23:55:13 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_get_xgmac_stats(scsi_qla_host_t *, dma_addr_t, uint16_t, uint16_t *);
|
|
|
|
|
2009-06-03 23:55:14 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_get_dcbx_params(scsi_qla_host_t *, dma_addr_t, uint16_t);
|
|
|
|
|
2009-06-03 23:55:30 +07:00
|
|
|
extern int
|
|
|
|
qla2x00_read_ram_word(scsi_qla_host_t *, uint32_t, uint32_t *);
|
|
|
|
|
|
|
|
extern int
|
|
|
|
qla2x00_write_ram_word(scsi_qla_host_t *, uint32_t, uint32_t);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_isr.c source file.
|
|
|
|
*/
|
IRQ: Maintain regs pointer globally rather than passing to IRQ handlers
Maintain a per-CPU global "struct pt_regs *" variable which can be used instead
of passing regs around manually through all ~1800 interrupt handlers in the
Linux kernel.
The regs pointer is used in few places, but it potentially costs both stack
space and code to pass it around. On the FRV arch, removing the regs parameter
from all the genirq function results in a 20% speed up of the IRQ exit path
(ie: from leaving timer_interrupt() to leaving do_IRQ()).
Where appropriate, an arch may override the generic storage facility and do
something different with the variable. On FRV, for instance, the address is
maintained in GR28 at all times inside the kernel as part of general exception
handling.
Having looked over the code, it appears that the parameter may be handed down
through up to twenty or so layers of functions. Consider a USB character
device attached to a USB hub, attached to a USB controller that posts its
interrupts through a cascaded auxiliary interrupt controller. A character
device driver may want to pass regs to the sysrq handler through the input
layer which adds another few layers of parameter passing.
I've build this code with allyesconfig for x86_64 and i386. I've runtested the
main part of the code on FRV and i386, though I can't test most of the drivers.
I've also done partial conversion for powerpc and MIPS - these at least compile
with minimal configurations.
This will affect all archs. Mostly the changes should be relatively easy.
Take do_IRQ(), store the regs pointer at the beginning, saving the old one:
struct pt_regs *old_regs = set_irq_regs(regs);
And put the old one back at the end:
set_irq_regs(old_regs);
Don't pass regs through to generic_handle_irq() or __do_IRQ().
In timer_interrupt(), this sort of change will be necessary:
- update_process_times(user_mode(regs));
- profile_tick(CPU_PROFILING, regs);
+ update_process_times(user_mode(get_irq_regs()));
+ profile_tick(CPU_PROFILING);
I'd like to move update_process_times()'s use of get_irq_regs() into itself,
except that i386, alone of the archs, uses something other than user_mode().
Some notes on the interrupt handling in the drivers:
(*) input_dev() is now gone entirely. The regs pointer is no longer stored in
the input_dev struct.
(*) finish_unlinks() in drivers/usb/host/ohci-q.c needs checking. It does
something different depending on whether it's been supplied with a regs
pointer or not.
(*) Various IRQ handler function pointers have been moved to type
irq_handler_t.
Signed-Off-By: David Howells <dhowells@redhat.com>
(cherry picked from 1b16e7ac850969f38b375e511e3fa2f474a33867 commit)
2006-10-05 20:55:46 +07:00
|
|
|
extern irqreturn_t qla2100_intr_handler(int, void *);
|
|
|
|
extern irqreturn_t qla2300_intr_handler(int, void *);
|
|
|
|
extern irqreturn_t qla24xx_intr_handler(int, void *);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern void qla2x00_process_response_queue(struct rsp_que *);
|
2009-04-07 12:33:40 +07:00
|
|
|
extern void
|
|
|
|
qla24xx_process_response_queue(struct scsi_qla_host *, struct rsp_que *);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern int qla2x00_request_irqs(struct qla_hw_data *, struct rsp_que *);
|
2007-01-30 01:22:19 +07:00
|
|
|
extern void qla2x00_free_irqs(scsi_qla_host_t *);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_sup.c source file.
|
|
|
|
*/
|
|
|
|
extern void qla2x00_release_nvram_protection(scsi_qla_host_t *);
|
2005-07-07 00:31:07 +07:00
|
|
|
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);
|
2007-07-20 10:37:34 +07:00
|
|
|
extern uint8_t *qla25xx_read_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
|
|
uint32_t);
|
|
|
|
extern int qla25xx_write_nvram_data(scsi_qla_host_t *, uint8_t *, uint32_t,
|
|
|
|
uint32_t);
|
2005-07-07 00:31:07 +07:00
|
|
|
|
2006-02-01 07:05:07 +07:00
|
|
|
extern int qla2x00_beacon_on(struct scsi_qla_host *);
|
|
|
|
extern int qla2x00_beacon_off(struct scsi_qla_host *);
|
|
|
|
extern void qla2x00_beacon_blink(struct scsi_qla_host *);
|
|
|
|
extern int qla24xx_beacon_on(struct scsi_qla_host *);
|
|
|
|
extern int qla24xx_beacon_off(struct scsi_qla_host *);
|
|
|
|
extern void qla24xx_beacon_blink(struct scsi_qla_host *);
|
|
|
|
|
2006-02-01 07:05:17 +07:00
|
|
|
extern uint8_t *qla2x00_read_optrom_data(struct scsi_qla_host *, uint8_t *,
|
|
|
|
uint32_t, uint32_t);
|
|
|
|
extern int qla2x00_write_optrom_data(struct scsi_qla_host *, uint8_t *,
|
|
|
|
uint32_t, uint32_t);
|
|
|
|
extern uint8_t *qla24xx_read_optrom_data(struct scsi_qla_host *, uint8_t *,
|
|
|
|
uint32_t, uint32_t);
|
|
|
|
extern int qla24xx_write_optrom_data(struct scsi_qla_host *, uint8_t *,
|
|
|
|
uint32_t, uint32_t);
|
2007-09-21 04:07:33 +07:00
|
|
|
extern uint8_t *qla25xx_read_optrom_data(struct scsi_qla_host *, uint8_t *,
|
|
|
|
uint32_t, uint32_t);
|
2006-02-01 07:05:17 +07:00
|
|
|
|
2007-01-30 01:22:21 +07:00
|
|
|
extern int qla2x00_get_flash_version(scsi_qla_host_t *, void *);
|
|
|
|
extern int qla24xx_get_flash_version(scsi_qla_host_t *, void *);
|
|
|
|
|
2008-09-12 11:22:49 +07:00
|
|
|
extern int qla2xxx_get_flash_info(scsi_qla_host_t *);
|
2008-07-11 06:55:53 +07:00
|
|
|
extern int qla2xxx_get_vpd_field(scsi_qla_host_t *, char *, char *, size_t);
|
2008-04-04 03:13:22 +07:00
|
|
|
|
2008-09-12 11:22:50 +07:00
|
|
|
extern void qla2xxx_flash_npiv_conf(scsi_qla_host_t *);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* 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);
|
2005-07-07 00:30:36 +07:00
|
|
|
extern void qla24xx_fw_dump(scsi_qla_host_t *, int);
|
2007-07-20 10:37:34 +07:00
|
|
|
extern void qla25xx_fw_dump(scsi_qla_host_t *, int);
|
2009-01-06 02:18:11 +07:00
|
|
|
extern void qla81xx_fw_dump(scsi_qla_host_t *, int);
|
2005-04-17 05:20:36 +07:00
|
|
|
extern void qla2x00_dump_regs(scsi_qla_host_t *);
|
|
|
|
extern void qla2x00_dump_buffer(uint8_t *, uint32_t);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_gs.c source file.
|
|
|
|
*/
|
2005-07-07 00:30:47 +07:00
|
|
|
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);
|
2005-04-17 05:20:36 +07:00
|
|
|
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 *);
|
2005-08-27 09:08:30 +07:00
|
|
|
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 *);
|
2006-10-03 02:00:43 +07:00
|
|
|
extern int qla2x00_gfpn_id(scsi_qla_host_t *, sw_info_t *);
|
|
|
|
extern int qla2x00_gpsc(scsi_qla_host_t *, sw_info_t *);
|
2006-10-03 02:00:44 +07:00
|
|
|
extern void qla2x00_get_sym_node_name(scsi_qla_host_t *, uint8_t *);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2005-04-18 03:04:54 +07:00
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_attr.c source file.
|
|
|
|
*/
|
2008-02-22 06:13:36 +07:00
|
|
|
struct device_attribute;
|
|
|
|
extern struct device_attribute *qla2x00_host_attrs[];
|
2005-04-22 03:13:36 +07:00
|
|
|
struct fc_function_template;
|
|
|
|
extern struct fc_function_template qla2xxx_transport_functions;
|
2007-07-06 03:16:51 +07:00
|
|
|
extern struct fc_function_template qla2xxx_transport_vport_functions;
|
2005-04-18 03:04:54 +07:00
|
|
|
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 *);
|
2008-01-18 00:02:17 +07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Global Function Prototypes in qla_dfs.c source file.
|
|
|
|
*/
|
|
|
|
extern int qla2x00_dfs_setup(scsi_qla_host_t *);
|
|
|
|
extern int qla2x00_dfs_remove(scsi_qla_host_t *);
|
2008-12-10 07:45:39 +07:00
|
|
|
|
|
|
|
/* Globa function prototypes for multi-q */
|
|
|
|
extern int qla25xx_request_irq(struct rsp_que *);
|
2009-02-09 11:50:11 +07:00
|
|
|
extern int qla25xx_init_req_que(struct scsi_qla_host *, struct req_que *);
|
|
|
|
extern int qla25xx_init_rsp_que(struct scsi_qla_host *, struct rsp_que *);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern int qla25xx_create_req_que(struct qla_hw_data *, uint16_t, uint8_t,
|
2009-04-07 12:33:40 +07:00
|
|
|
uint16_t, int, uint8_t);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern int qla25xx_create_rsp_que(struct qla_hw_data *, uint16_t, uint8_t,
|
2009-04-07 12:33:40 +07:00
|
|
|
uint16_t, int);
|
2008-12-10 07:45:39 +07:00
|
|
|
extern int qla25xx_update_req_que(struct scsi_qla_host *, uint8_t, uint8_t);
|
|
|
|
extern void qla2x00_init_response_q_entries(struct rsp_que *);
|
|
|
|
extern int qla25xx_delete_req_que(struct scsi_qla_host *, struct req_que *);
|
|
|
|
extern int qla25xx_delete_rsp_que(struct scsi_qla_host *, struct rsp_que *);
|
|
|
|
extern int qla25xx_create_queues(struct scsi_qla_host *, uint8_t);
|
2009-04-07 12:33:40 +07:00
|
|
|
extern int qla25xx_delete_queues(struct scsi_qla_host *);
|
2008-12-19 01:06:15 +07:00
|
|
|
extern uint16_t qla24xx_rd_req_reg(struct qla_hw_data *, uint16_t);
|
|
|
|
extern uint16_t qla25xx_rd_req_reg(struct qla_hw_data *, uint16_t);
|
|
|
|
extern void qla24xx_wrt_req_reg(struct qla_hw_data *, uint16_t, uint16_t);
|
|
|
|
extern void qla25xx_wrt_req_reg(struct qla_hw_data *, uint16_t, uint16_t);
|
|
|
|
extern void qla25xx_wrt_rsp_reg(struct qla_hw_data *, uint16_t, uint16_t);
|
|
|
|
extern void qla24xx_wrt_rsp_reg(struct qla_hw_data *, uint16_t, uint16_t);
|
2009-04-07 12:33:40 +07:00
|
|
|
extern struct scsi_qla_host * qla25xx_get_host(struct rsp_que *);
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif /* _QLA_GBL_H */
|