Swen Schillig | 41fa2ad | 2007-09-07 09:15:31 +0200 | [diff] [blame] | 1 | /* |
Christof Schmitt | 553448f | 2008-06-10 18:20:58 +0200 | [diff] [blame] | 2 | * zfcp device driver |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 | * |
Christof Schmitt | 553448f | 2008-06-10 18:20:58 +0200 | [diff] [blame] | 4 | * External function declarations. |
Swen Schillig | 41fa2ad | 2007-09-07 09:15:31 +0200 | [diff] [blame] | 5 | * |
Heiko Carstens | a53c8fa | 2012-07-20 11:15:04 +0200 | [diff] [blame] | 6 | * Copyright IBM Corp. 2002, 2010 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | */ |
| 8 | |
| 9 | #ifndef ZFCP_EXT_H |
| 10 | #define ZFCP_EXT_H |
| 11 | |
Christof Schmitt | 9d05ce2 | 2009-11-24 16:54:09 +0100 | [diff] [blame] | 12 | #include <linux/types.h> |
| 13 | #include <scsi/fc/fc_els.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | #include "zfcp_def.h" |
Christof Schmitt | 7c7dc19 | 2009-11-24 16:54:13 +0100 | [diff] [blame] | 15 | #include "zfcp_fc.h" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 | |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 17 | /* zfcp_aux.c */ |
Swen Schillig | 7ba58c9 | 2008-10-01 12:42:18 +0200 | [diff] [blame] | 18 | extern struct zfcp_port *zfcp_get_port_by_wwpn(struct zfcp_adapter *, u64); |
Swen Schillig | de3dc57 | 2009-11-24 16:54:00 +0100 | [diff] [blame] | 19 | extern struct zfcp_adapter *zfcp_adapter_enqueue(struct ccw_device *); |
Swen Schillig | 7ba58c9 | 2008-10-01 12:42:18 +0200 | [diff] [blame] | 20 | extern struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *, u64, u32, |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 21 | u32); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 22 | extern void zfcp_sg_free_table(struct scatterlist *, int); |
| 23 | extern int zfcp_sg_setup_table(struct scatterlist *, int); |
Swen Schillig | f3450c7 | 2009-11-24 16:53:59 +0100 | [diff] [blame] | 24 | extern void zfcp_adapter_release(struct kref *); |
Swen Schillig | de3dc57 | 2009-11-24 16:54:00 +0100 | [diff] [blame] | 25 | extern void zfcp_adapter_unregister(struct zfcp_adapter *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 27 | /* zfcp_ccw.c */ |
Christof Schmitt | c5afd81 | 2009-09-24 10:23:22 +0200 | [diff] [blame] | 28 | extern struct ccw_driver zfcp_ccw_driver; |
Swen Schillig | de3dc57 | 2009-11-24 16:54:00 +0100 | [diff] [blame] | 29 | extern struct zfcp_adapter *zfcp_ccw_adapter_by_cdev(struct ccw_device *); |
| 30 | extern void zfcp_ccw_adapter_put(struct zfcp_adapter *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 32 | /* zfcp_dbf.c */ |
Swen Schillig | 5771710 | 2009-08-18 15:43:21 +0200 | [diff] [blame] | 33 | extern int zfcp_dbf_adapter_register(struct zfcp_adapter *); |
Swen Schillig | ea4a3a6 | 2010-12-02 15:16:16 +0100 | [diff] [blame] | 34 | extern void zfcp_dbf_adapter_unregister(struct zfcp_adapter *); |
Swen Schillig | ae0904f | 2010-12-02 15:16:12 +0100 | [diff] [blame] | 35 | extern void zfcp_dbf_rec_trig(char *, struct zfcp_adapter *, |
| 36 | struct zfcp_port *, struct scsi_device *, u8, u8); |
| 37 | extern void zfcp_dbf_rec_run(char *, struct zfcp_erp_action *); |
Swen Schillig | a54ca0f | 2010-12-02 15:16:14 +0100 | [diff] [blame] | 38 | extern void zfcp_dbf_hba_fsf_uss(char *, struct zfcp_fsf_req *); |
| 39 | extern void zfcp_dbf_hba_fsf_res(char *, struct zfcp_fsf_req *); |
| 40 | extern void zfcp_dbf_hba_bit_err(char *, struct zfcp_fsf_req *); |
Swen Schillig | 5771710 | 2009-08-18 15:43:21 +0200 | [diff] [blame] | 41 | extern void zfcp_dbf_hba_berr(struct zfcp_dbf *, struct zfcp_fsf_req *); |
Swen Schillig | 86a9668 | 2011-08-15 14:40:32 +0200 | [diff] [blame] | 42 | extern void zfcp_dbf_hba_def_err(struct zfcp_adapter *, u64, u16, void **); |
Steffen Maier | cb45214 | 2012-09-04 15:23:32 +0200 | [diff] [blame] | 43 | extern void zfcp_dbf_hba_basic(char *, struct zfcp_adapter *); |
Swen Schillig | 2c55b75 | 2010-12-02 15:16:13 +0100 | [diff] [blame] | 44 | extern void zfcp_dbf_san_req(char *, struct zfcp_fsf_req *, u32); |
| 45 | extern void zfcp_dbf_san_res(char *, struct zfcp_fsf_req *); |
| 46 | extern void zfcp_dbf_san_in_els(char *, struct zfcp_fsf_req *); |
Swen Schillig | 250a135 | 2010-12-02 15:16:15 +0100 | [diff] [blame] | 47 | extern void zfcp_dbf_scsi(char *, struct scsi_cmnd *, struct zfcp_fsf_req *); |
Maxim Shchetynin | 8a36e45 | 2005-09-13 21:50:38 +0200 | [diff] [blame] | 48 | |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 49 | /* zfcp_erp.c */ |
Swen Schillig | edaed85 | 2010-09-08 14:40:01 +0200 | [diff] [blame] | 50 | extern void zfcp_erp_set_adapter_status(struct zfcp_adapter *, u32); |
| 51 | extern void zfcp_erp_clear_adapter_status(struct zfcp_adapter *, u32); |
Swen Schillig | ea4a3a6 | 2010-12-02 15:16:16 +0100 | [diff] [blame] | 52 | extern void zfcp_erp_adapter_reopen(struct zfcp_adapter *, int, char *); |
| 53 | extern void zfcp_erp_adapter_shutdown(struct zfcp_adapter *, int, char *); |
Swen Schillig | edaed85 | 2010-09-08 14:40:01 +0200 | [diff] [blame] | 54 | extern void zfcp_erp_set_port_status(struct zfcp_port *, u32); |
| 55 | extern void zfcp_erp_clear_port_status(struct zfcp_port *, u32); |
Swen Schillig | ea4a3a6 | 2010-12-02 15:16:16 +0100 | [diff] [blame] | 56 | extern int zfcp_erp_port_reopen(struct zfcp_port *, int, char *); |
| 57 | extern void zfcp_erp_port_shutdown(struct zfcp_port *, int, char *); |
| 58 | extern void zfcp_erp_port_forced_reopen(struct zfcp_port *, int, char *); |
Swen Schillig | edaed85 | 2010-09-08 14:40:01 +0200 | [diff] [blame] | 59 | extern void zfcp_erp_set_lun_status(struct scsi_device *, u32); |
| 60 | extern void zfcp_erp_clear_lun_status(struct scsi_device *, u32); |
Swen Schillig | ea4a3a6 | 2010-12-02 15:16:16 +0100 | [diff] [blame] | 61 | extern void zfcp_erp_lun_reopen(struct scsi_device *, int, char *); |
| 62 | extern void zfcp_erp_lun_shutdown(struct scsi_device *, int, char *); |
Christof Schmitt | b62a8d9 | 2010-09-08 14:39:55 +0200 | [diff] [blame] | 63 | extern void zfcp_erp_lun_shutdown_wait(struct scsi_device *, char *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 64 | extern int zfcp_erp_thread_setup(struct zfcp_adapter *); |
| 65 | extern void zfcp_erp_thread_kill(struct zfcp_adapter *); |
| 66 | extern void zfcp_erp_wait(struct zfcp_adapter *); |
| 67 | extern void zfcp_erp_notify(struct zfcp_erp_action *, unsigned long); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 68 | extern void zfcp_erp_timeout_handler(unsigned long); |
| 69 | |
| 70 | /* zfcp_fc.c */ |
Christof Schmitt | 087897e | 2011-02-22 19:54:41 +0100 | [diff] [blame] | 71 | extern struct kmem_cache *zfcp_fc_req_cache; |
Sven Schuetz | 2d1e547 | 2010-07-16 15:37:39 +0200 | [diff] [blame] | 72 | extern void zfcp_fc_enqueue_event(struct zfcp_adapter *, |
| 73 | enum fc_host_event_code event_code, u32); |
| 74 | extern void zfcp_fc_post_event(struct work_struct *); |
Swen Schillig | 9eae07e | 2009-11-24 16:54:06 +0100 | [diff] [blame] | 75 | extern void zfcp_fc_scan_ports(struct work_struct *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 76 | extern void zfcp_fc_incoming_els(struct zfcp_fsf_req *); |
Christof Schmitt | 799b76d | 2009-08-18 15:43:20 +0200 | [diff] [blame] | 77 | extern void zfcp_fc_port_did_lookup(struct work_struct *); |
Christof Schmitt | 934aeb587 | 2009-10-14 11:00:43 +0200 | [diff] [blame] | 78 | extern void zfcp_fc_trigger_did_lookup(struct zfcp_port *); |
Christof Schmitt | 9d05ce2 | 2009-11-24 16:54:09 +0100 | [diff] [blame] | 79 | extern void zfcp_fc_plogi_evaluate(struct zfcp_port *, struct fc_els_flogi *); |
Swen Schillig | 6f53a2d | 2009-08-18 15:43:23 +0200 | [diff] [blame] | 80 | extern void zfcp_fc_test_link(struct zfcp_port *); |
Christof Schmitt | 8fdf30d | 2009-03-02 13:09:01 +0100 | [diff] [blame] | 81 | extern void zfcp_fc_link_test_work(struct work_struct *); |
Christof Schmitt | bd0072e | 2009-11-24 16:54:11 +0100 | [diff] [blame] | 82 | extern void zfcp_fc_wka_ports_force_offline(struct zfcp_fc_wka_ports *); |
Swen Schillig | d5a282a | 2009-08-18 15:43:22 +0200 | [diff] [blame] | 83 | extern int zfcp_fc_gs_setup(struct zfcp_adapter *); |
| 84 | extern void zfcp_fc_gs_destroy(struct zfcp_adapter *); |
Christof Schmitt | 7c7dc19 | 2009-11-24 16:54:13 +0100 | [diff] [blame] | 85 | extern int zfcp_fc_exec_bsg_job(struct fc_bsg_job *); |
Swen Schillig | 491ca44 | 2010-01-14 17:19:01 +0100 | [diff] [blame] | 86 | extern int zfcp_fc_timeout_bsg_job(struct fc_bsg_job *); |
Christof Schmitt | 038d944 | 2011-02-22 19:54:48 +0100 | [diff] [blame] | 87 | extern void zfcp_fc_sym_name_update(struct work_struct *); |
Martin Peschke | 18f87a6 | 2014-11-13 14:59:48 +0100 | [diff] [blame] | 88 | extern unsigned int zfcp_fc_port_scan_backoff(void); |
Steffen Maier | 43f60cb | 2012-09-04 15:23:35 +0200 | [diff] [blame] | 89 | extern void zfcp_fc_conditional_port_scan(struct zfcp_adapter *); |
| 90 | extern void zfcp_fc_inverse_conditional_port_scan(struct zfcp_adapter *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 91 | |
| 92 | /* zfcp_fsf.c */ |
Christof Schmitt | 259afe2 | 2011-02-22 19:54:44 +0100 | [diff] [blame] | 93 | extern struct kmem_cache *zfcp_fsf_qtcb_cache; |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 94 | extern int zfcp_fsf_open_port(struct zfcp_erp_action *); |
Christof Schmitt | bd0072e | 2009-11-24 16:54:11 +0100 | [diff] [blame] | 95 | extern int zfcp_fsf_open_wka_port(struct zfcp_fc_wka_port *); |
| 96 | extern int zfcp_fsf_close_wka_port(struct zfcp_fc_wka_port *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 97 | extern int zfcp_fsf_close_port(struct zfcp_erp_action *); |
| 98 | extern int zfcp_fsf_close_physical_port(struct zfcp_erp_action *); |
Christof Schmitt | b62a8d9 | 2010-09-08 14:39:55 +0200 | [diff] [blame] | 99 | extern int zfcp_fsf_open_lun(struct zfcp_erp_action *); |
| 100 | extern int zfcp_fsf_close_lun(struct zfcp_erp_action *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 101 | extern int zfcp_fsf_exchange_config_data(struct zfcp_erp_action *); |
Swen Schillig | 564e1c8 | 2009-08-18 15:43:19 +0200 | [diff] [blame] | 102 | extern int zfcp_fsf_exchange_config_data_sync(struct zfcp_qdio *, |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 103 | struct fsf_qtcb_bottom_config *); |
| 104 | extern int zfcp_fsf_exchange_port_data(struct zfcp_erp_action *); |
Swen Schillig | 564e1c8 | 2009-08-18 15:43:19 +0200 | [diff] [blame] | 105 | extern int zfcp_fsf_exchange_port_data_sync(struct zfcp_qdio *, |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 106 | struct fsf_qtcb_bottom_port *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 107 | extern void zfcp_fsf_req_dismiss_all(struct zfcp_adapter *); |
Swen Schillig | 564e1c8 | 2009-08-18 15:43:19 +0200 | [diff] [blame] | 108 | extern int zfcp_fsf_status_read(struct zfcp_qdio *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 109 | extern int zfcp_status_read_refill(struct zfcp_adapter *adapter); |
Christof Schmitt | 7c7dc19 | 2009-11-24 16:54:13 +0100 | [diff] [blame] | 110 | extern int zfcp_fsf_send_ct(struct zfcp_fc_wka_port *, struct zfcp_fsf_ct_els *, |
Swen Schillig | 51375ee | 2010-01-14 17:19:02 +0100 | [diff] [blame] | 111 | mempool_t *, unsigned int); |
Christof Schmitt | 7c7dc19 | 2009-11-24 16:54:13 +0100 | [diff] [blame] | 112 | extern int zfcp_fsf_send_els(struct zfcp_adapter *, u32, |
Swen Schillig | 51375ee | 2010-01-14 17:19:02 +0100 | [diff] [blame] | 113 | struct zfcp_fsf_ct_els *, unsigned int); |
Christof Schmitt | b62a8d9 | 2010-09-08 14:39:55 +0200 | [diff] [blame] | 114 | extern int zfcp_fsf_fcp_cmnd(struct scsi_cmnd *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 115 | extern void zfcp_fsf_req_free(struct zfcp_fsf_req *); |
Christof Schmitt | b62a8d9 | 2010-09-08 14:39:55 +0200 | [diff] [blame] | 116 | extern struct zfcp_fsf_req *zfcp_fsf_fcp_task_mgmt(struct scsi_cmnd *, u8); |
| 117 | extern struct zfcp_fsf_req *zfcp_fsf_abort_fcp_cmnd(struct scsi_cmnd *); |
Swen Schillig | 564e1c8 | 2009-08-18 15:43:19 +0200 | [diff] [blame] | 118 | extern void zfcp_fsf_reqid_check(struct zfcp_qdio *, int); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 119 | |
| 120 | /* zfcp_qdio.c */ |
Swen Schillig | d5a282a | 2009-08-18 15:43:22 +0200 | [diff] [blame] | 121 | extern int zfcp_qdio_setup(struct zfcp_adapter *); |
| 122 | extern void zfcp_qdio_destroy(struct zfcp_qdio *); |
Christof Schmitt | 6b9e152 | 2010-04-30 18:09:35 +0200 | [diff] [blame] | 123 | extern int zfcp_qdio_sbal_get(struct zfcp_qdio *); |
Christof Schmitt | 34c2b71 | 2010-02-17 11:18:59 +0100 | [diff] [blame] | 124 | extern int zfcp_qdio_send(struct zfcp_qdio *, struct zfcp_qdio_req *); |
Christof Schmitt | 1674b40 | 2010-04-30 18:09:34 +0200 | [diff] [blame] | 125 | extern int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *, struct zfcp_qdio_req *, |
Swen Schillig | 01b0475 | 2010-07-16 15:37:37 +0200 | [diff] [blame] | 126 | struct scatterlist *); |
Swen Schillig | 564e1c8 | 2009-08-18 15:43:19 +0200 | [diff] [blame] | 127 | extern int zfcp_qdio_open(struct zfcp_qdio *); |
| 128 | extern void zfcp_qdio_close(struct zfcp_qdio *); |
Christof Schmitt | 339f4f4 | 2010-07-16 15:37:43 +0200 | [diff] [blame] | 129 | extern void zfcp_qdio_siosl(struct zfcp_adapter *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 130 | |
| 131 | /* zfcp_scsi.c */ |
Christof Schmitt | 1947c72 | 2011-02-22 19:54:46 +0100 | [diff] [blame] | 132 | extern struct scsi_transport_template *zfcp_scsi_transport_template; |
| 133 | extern int zfcp_scsi_adapter_register(struct zfcp_adapter *); |
| 134 | extern void zfcp_scsi_adapter_unregister(struct zfcp_adapter *); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 135 | extern struct fc_function_template zfcp_transport_functions; |
Christof Schmitt | a2fa0ae | 2009-03-02 13:09:08 +0100 | [diff] [blame] | 136 | extern void zfcp_scsi_rport_work(struct work_struct *); |
| 137 | extern void zfcp_scsi_schedule_rport_register(struct zfcp_port *); |
| 138 | extern void zfcp_scsi_schedule_rport_block(struct zfcp_port *); |
| 139 | extern void zfcp_scsi_schedule_rports_block(struct zfcp_adapter *); |
Felix Beck | ef3eb71 | 2010-07-16 15:37:42 +0200 | [diff] [blame] | 140 | extern void zfcp_scsi_set_prot(struct zfcp_adapter *); |
| 141 | extern void zfcp_scsi_dif_sense_error(struct scsi_cmnd *, int); |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 142 | |
| 143 | /* zfcp_sysfs.c */ |
Sebastian Ott | 86bdf21 | 2013-04-26 16:13:49 +0200 | [diff] [blame] | 144 | extern const struct attribute_group *zfcp_unit_attr_groups[]; |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 145 | extern struct attribute_group zfcp_sysfs_adapter_attrs; |
Sebastian Ott | 83d4e1c | 2013-04-26 16:13:48 +0200 | [diff] [blame] | 146 | extern const struct attribute_group *zfcp_port_attr_groups[]; |
Steffen Maier | d99b601 | 2012-09-04 15:23:34 +0200 | [diff] [blame] | 147 | extern struct mutex zfcp_sysfs_port_units_mutex; |
Christof Schmitt | 92c299d | 2008-07-02 10:56:41 +0200 | [diff] [blame] | 148 | extern struct device_attribute *zfcp_sysfs_sdev_attrs[]; |
| 149 | extern struct device_attribute *zfcp_sysfs_shost_attrs[]; |
Christof Schmitt | 45633fd | 2008-06-10 18:20:55 +0200 | [diff] [blame] | 150 | |
Christof Schmitt | 1daa4eb | 2010-09-08 14:39:52 +0200 | [diff] [blame] | 151 | /* zfcp_unit.c */ |
| 152 | extern int zfcp_unit_add(struct zfcp_port *, u64); |
| 153 | extern int zfcp_unit_remove(struct zfcp_port *, u64); |
| 154 | extern struct zfcp_unit *zfcp_unit_find(struct zfcp_port *, u64); |
| 155 | extern struct scsi_device *zfcp_unit_sdev(struct zfcp_unit *unit); |
| 156 | extern void zfcp_unit_scsi_scan(struct zfcp_unit *); |
| 157 | extern void zfcp_unit_queue_scsi_scan(struct zfcp_port *); |
| 158 | extern unsigned int zfcp_unit_sdev_status(struct zfcp_unit *); |
| 159 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 160 | #endif /* ZFCP_EXT_H */ |