1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * zfcp device driver 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * External function declarations. 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Copyright IBM Corp. 2002, 2020 8*4882a593Smuzhiyun */ 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #ifndef ZFCP_EXT_H 11*4882a593Smuzhiyun #define ZFCP_EXT_H 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #include <linux/types.h> 14*4882a593Smuzhiyun #include <scsi/fc/fc_els.h> 15*4882a593Smuzhiyun #include "zfcp_def.h" 16*4882a593Smuzhiyun #include "zfcp_fc.h" 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun /* zfcp_aux.c */ 19*4882a593Smuzhiyun extern struct zfcp_port *zfcp_get_port_by_wwpn(struct zfcp_adapter *, u64); 20*4882a593Smuzhiyun extern struct zfcp_adapter *zfcp_adapter_enqueue(struct ccw_device *); 21*4882a593Smuzhiyun extern struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *, u64, u32, 22*4882a593Smuzhiyun u32); 23*4882a593Smuzhiyun extern void zfcp_sg_free_table(struct scatterlist *, int); 24*4882a593Smuzhiyun extern int zfcp_sg_setup_table(struct scatterlist *, int); 25*4882a593Smuzhiyun extern void zfcp_adapter_release(struct kref *); 26*4882a593Smuzhiyun extern void zfcp_adapter_unregister(struct zfcp_adapter *); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun /* zfcp_ccw.c */ 29*4882a593Smuzhiyun extern struct ccw_driver zfcp_ccw_driver; 30*4882a593Smuzhiyun extern struct zfcp_adapter *zfcp_ccw_adapter_by_cdev(struct ccw_device *); 31*4882a593Smuzhiyun extern void zfcp_ccw_adapter_put(struct zfcp_adapter *); 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun /* zfcp_dbf.c */ 34*4882a593Smuzhiyun extern int zfcp_dbf_adapter_register(struct zfcp_adapter *); 35*4882a593Smuzhiyun extern void zfcp_dbf_adapter_unregister(struct zfcp_adapter *); 36*4882a593Smuzhiyun extern void zfcp_dbf_rec_trig(char *, struct zfcp_adapter *, 37*4882a593Smuzhiyun struct zfcp_port *, struct scsi_device *, u8, u8); 38*4882a593Smuzhiyun extern void zfcp_dbf_rec_trig_lock(char *tag, struct zfcp_adapter *adapter, 39*4882a593Smuzhiyun struct zfcp_port *port, 40*4882a593Smuzhiyun struct scsi_device *sdev, u8 want, u8 need); 41*4882a593Smuzhiyun extern void zfcp_dbf_rec_run(char *, struct zfcp_erp_action *); 42*4882a593Smuzhiyun extern void zfcp_dbf_rec_run_lvl(int level, char *tag, 43*4882a593Smuzhiyun struct zfcp_erp_action *erp); 44*4882a593Smuzhiyun extern void zfcp_dbf_rec_run_wka(char *, struct zfcp_fc_wka_port *, u64); 45*4882a593Smuzhiyun extern void zfcp_dbf_hba_fsf_uss(char *, struct zfcp_fsf_req *); 46*4882a593Smuzhiyun extern void zfcp_dbf_hba_fsf_res(char *, int, struct zfcp_fsf_req *); 47*4882a593Smuzhiyun extern void zfcp_dbf_hba_fsf_fces(char *tag, const struct zfcp_fsf_req *req, 48*4882a593Smuzhiyun u64 wwpn, u32 fc_security_old, 49*4882a593Smuzhiyun u32 fc_security_new); 50*4882a593Smuzhiyun extern void zfcp_dbf_hba_bit_err(char *, struct zfcp_fsf_req *); 51*4882a593Smuzhiyun extern void zfcp_dbf_hba_def_err(struct zfcp_adapter *, u64, u16, void **); 52*4882a593Smuzhiyun extern void zfcp_dbf_hba_basic(char *, struct zfcp_adapter *); 53*4882a593Smuzhiyun extern void zfcp_dbf_san_req(char *, struct zfcp_fsf_req *, u32); 54*4882a593Smuzhiyun extern void zfcp_dbf_san_res(char *, struct zfcp_fsf_req *); 55*4882a593Smuzhiyun extern void zfcp_dbf_san_in_els(char *, struct zfcp_fsf_req *); 56*4882a593Smuzhiyun extern void zfcp_dbf_scsi_common(char *tag, int level, struct scsi_device *sdev, 57*4882a593Smuzhiyun struct scsi_cmnd *sc, 58*4882a593Smuzhiyun struct zfcp_fsf_req *fsf); 59*4882a593Smuzhiyun extern void zfcp_dbf_scsi_eh(char *tag, struct zfcp_adapter *adapter, 60*4882a593Smuzhiyun unsigned int scsi_id, int ret); 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun /* zfcp_erp.c */ 63*4882a593Smuzhiyun extern void zfcp_erp_set_adapter_status(struct zfcp_adapter *, u32); 64*4882a593Smuzhiyun extern void zfcp_erp_clear_adapter_status(struct zfcp_adapter *, u32); 65*4882a593Smuzhiyun extern void zfcp_erp_port_forced_no_port_dbf(char *dbftag, 66*4882a593Smuzhiyun struct zfcp_adapter *adapter, 67*4882a593Smuzhiyun u64 port_name, u32 port_id); 68*4882a593Smuzhiyun extern void zfcp_erp_adapter_reopen(struct zfcp_adapter *, int, char *); 69*4882a593Smuzhiyun extern void zfcp_erp_adapter_shutdown(struct zfcp_adapter *, int, char *); 70*4882a593Smuzhiyun extern void zfcp_erp_set_port_status(struct zfcp_port *, u32); 71*4882a593Smuzhiyun extern void zfcp_erp_clear_port_status(struct zfcp_port *, u32); 72*4882a593Smuzhiyun extern void zfcp_erp_port_reopen(struct zfcp_port *port, int clear, 73*4882a593Smuzhiyun char *dbftag); 74*4882a593Smuzhiyun extern void zfcp_erp_port_shutdown(struct zfcp_port *, int, char *); 75*4882a593Smuzhiyun extern void zfcp_erp_port_forced_reopen(struct zfcp_port *, int, char *); 76*4882a593Smuzhiyun extern void zfcp_erp_port_forced_reopen_all(struct zfcp_adapter *adapter, 77*4882a593Smuzhiyun int clear, char *dbftag); 78*4882a593Smuzhiyun extern void zfcp_erp_set_lun_status(struct scsi_device *, u32); 79*4882a593Smuzhiyun extern void zfcp_erp_clear_lun_status(struct scsi_device *, u32); 80*4882a593Smuzhiyun extern void zfcp_erp_lun_reopen(struct scsi_device *, int, char *); 81*4882a593Smuzhiyun extern void zfcp_erp_lun_shutdown(struct scsi_device *, int, char *); 82*4882a593Smuzhiyun extern void zfcp_erp_lun_shutdown_wait(struct scsi_device *, char *); 83*4882a593Smuzhiyun extern int zfcp_erp_thread_setup(struct zfcp_adapter *); 84*4882a593Smuzhiyun extern void zfcp_erp_thread_kill(struct zfcp_adapter *); 85*4882a593Smuzhiyun extern void zfcp_erp_wait(struct zfcp_adapter *); 86*4882a593Smuzhiyun extern void zfcp_erp_notify(struct zfcp_erp_action *, unsigned long); 87*4882a593Smuzhiyun extern void zfcp_erp_timeout_handler(struct timer_list *t); 88*4882a593Smuzhiyun extern void zfcp_erp_adapter_reset_sync(struct zfcp_adapter *adapter, 89*4882a593Smuzhiyun char *dbftag); 90*4882a593Smuzhiyun 91*4882a593Smuzhiyun /* zfcp_fc.c */ 92*4882a593Smuzhiyun extern struct kmem_cache *zfcp_fc_req_cache; 93*4882a593Smuzhiyun extern void zfcp_fc_enqueue_event(struct zfcp_adapter *, 94*4882a593Smuzhiyun enum fc_host_event_code event_code, u32); 95*4882a593Smuzhiyun extern void zfcp_fc_post_event(struct work_struct *); 96*4882a593Smuzhiyun extern void zfcp_fc_scan_ports(struct work_struct *); 97*4882a593Smuzhiyun extern void zfcp_fc_incoming_els(struct zfcp_fsf_req *); 98*4882a593Smuzhiyun extern void zfcp_fc_port_did_lookup(struct work_struct *); 99*4882a593Smuzhiyun extern void zfcp_fc_trigger_did_lookup(struct zfcp_port *); 100*4882a593Smuzhiyun extern void zfcp_fc_plogi_evaluate(struct zfcp_port *, struct fc_els_flogi *); 101*4882a593Smuzhiyun extern void zfcp_fc_test_link(struct zfcp_port *); 102*4882a593Smuzhiyun extern void zfcp_fc_link_test_work(struct work_struct *); 103*4882a593Smuzhiyun extern void zfcp_fc_wka_ports_force_offline(struct zfcp_fc_wka_ports *); 104*4882a593Smuzhiyun extern int zfcp_fc_gs_setup(struct zfcp_adapter *); 105*4882a593Smuzhiyun extern void zfcp_fc_gs_destroy(struct zfcp_adapter *); 106*4882a593Smuzhiyun extern int zfcp_fc_exec_bsg_job(struct bsg_job *); 107*4882a593Smuzhiyun extern int zfcp_fc_timeout_bsg_job(struct bsg_job *); 108*4882a593Smuzhiyun extern void zfcp_fc_sym_name_update(struct work_struct *); 109*4882a593Smuzhiyun extern unsigned int zfcp_fc_port_scan_backoff(void); 110*4882a593Smuzhiyun extern void zfcp_fc_conditional_port_scan(struct zfcp_adapter *); 111*4882a593Smuzhiyun extern void zfcp_fc_inverse_conditional_port_scan(struct zfcp_adapter *); 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun /* zfcp_fsf.c */ 114*4882a593Smuzhiyun extern struct kmem_cache *zfcp_fsf_qtcb_cache; 115*4882a593Smuzhiyun extern int zfcp_fsf_open_port(struct zfcp_erp_action *); 116*4882a593Smuzhiyun extern int zfcp_fsf_open_wka_port(struct zfcp_fc_wka_port *); 117*4882a593Smuzhiyun extern int zfcp_fsf_close_wka_port(struct zfcp_fc_wka_port *); 118*4882a593Smuzhiyun extern int zfcp_fsf_close_port(struct zfcp_erp_action *); 119*4882a593Smuzhiyun extern int zfcp_fsf_close_physical_port(struct zfcp_erp_action *); 120*4882a593Smuzhiyun extern int zfcp_fsf_open_lun(struct zfcp_erp_action *); 121*4882a593Smuzhiyun extern int zfcp_fsf_close_lun(struct zfcp_erp_action *); 122*4882a593Smuzhiyun extern int zfcp_fsf_exchange_config_data(struct zfcp_erp_action *); 123*4882a593Smuzhiyun extern int zfcp_fsf_exchange_config_data_sync(struct zfcp_qdio *, 124*4882a593Smuzhiyun struct fsf_qtcb_bottom_config *); 125*4882a593Smuzhiyun extern int zfcp_fsf_exchange_port_data(struct zfcp_erp_action *); 126*4882a593Smuzhiyun extern int zfcp_fsf_exchange_port_data_sync(struct zfcp_qdio *, 127*4882a593Smuzhiyun struct fsf_qtcb_bottom_port *); 128*4882a593Smuzhiyun extern u32 zfcp_fsf_convert_portspeed(u32 fsf_speed); 129*4882a593Smuzhiyun extern void zfcp_fsf_req_dismiss_all(struct zfcp_adapter *); 130*4882a593Smuzhiyun extern int zfcp_fsf_status_read(struct zfcp_qdio *); 131*4882a593Smuzhiyun extern int zfcp_status_read_refill(struct zfcp_adapter *adapter); 132*4882a593Smuzhiyun extern int zfcp_fsf_send_ct(struct zfcp_fc_wka_port *, struct zfcp_fsf_ct_els *, 133*4882a593Smuzhiyun mempool_t *, unsigned int); 134*4882a593Smuzhiyun extern int zfcp_fsf_send_els(struct zfcp_adapter *, u32, 135*4882a593Smuzhiyun struct zfcp_fsf_ct_els *, unsigned int); 136*4882a593Smuzhiyun extern int zfcp_fsf_fcp_cmnd(struct scsi_cmnd *); 137*4882a593Smuzhiyun extern void zfcp_fsf_req_free(struct zfcp_fsf_req *); 138*4882a593Smuzhiyun extern void zfcp_fsf_fc_host_link_down(struct zfcp_adapter *adapter); 139*4882a593Smuzhiyun extern struct zfcp_fsf_req *zfcp_fsf_fcp_task_mgmt(struct scsi_device *sdev, 140*4882a593Smuzhiyun u8 tm_flags); 141*4882a593Smuzhiyun extern struct zfcp_fsf_req *zfcp_fsf_abort_fcp_cmnd(struct scsi_cmnd *); 142*4882a593Smuzhiyun extern void zfcp_fsf_reqid_check(struct zfcp_qdio *, int); 143*4882a593Smuzhiyun enum zfcp_fsf_print_fmt { 144*4882a593Smuzhiyun ZFCP_FSF_PRINT_FMT_LIST, 145*4882a593Smuzhiyun ZFCP_FSF_PRINT_FMT_SINGLEITEM, 146*4882a593Smuzhiyun }; 147*4882a593Smuzhiyun extern ssize_t zfcp_fsf_scnprint_fc_security(char *buf, size_t size, 148*4882a593Smuzhiyun u32 fc_security, 149*4882a593Smuzhiyun enum zfcp_fsf_print_fmt fmt); 150*4882a593Smuzhiyun 151*4882a593Smuzhiyun /* zfcp_qdio.c */ 152*4882a593Smuzhiyun extern int zfcp_qdio_setup(struct zfcp_adapter *); 153*4882a593Smuzhiyun extern void zfcp_qdio_destroy(struct zfcp_qdio *); 154*4882a593Smuzhiyun extern int zfcp_qdio_sbal_get(struct zfcp_qdio *); 155*4882a593Smuzhiyun extern int zfcp_qdio_send(struct zfcp_qdio *, struct zfcp_qdio_req *); 156*4882a593Smuzhiyun extern int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *, struct zfcp_qdio_req *, 157*4882a593Smuzhiyun struct scatterlist *); 158*4882a593Smuzhiyun extern void zfcp_qdio_shost_update(struct zfcp_adapter *const adapter, 159*4882a593Smuzhiyun const struct zfcp_qdio *const qdio); 160*4882a593Smuzhiyun extern int zfcp_qdio_open(struct zfcp_qdio *); 161*4882a593Smuzhiyun extern void zfcp_qdio_close(struct zfcp_qdio *); 162*4882a593Smuzhiyun extern void zfcp_qdio_siosl(struct zfcp_adapter *); 163*4882a593Smuzhiyun 164*4882a593Smuzhiyun /* zfcp_scsi.c */ 165*4882a593Smuzhiyun extern bool zfcp_experimental_dix; 166*4882a593Smuzhiyun extern struct scsi_transport_template *zfcp_scsi_transport_template; 167*4882a593Smuzhiyun extern int zfcp_scsi_adapter_register(struct zfcp_adapter *); 168*4882a593Smuzhiyun extern void zfcp_scsi_adapter_unregister(struct zfcp_adapter *); 169*4882a593Smuzhiyun extern struct fc_function_template zfcp_transport_functions; 170*4882a593Smuzhiyun extern void zfcp_scsi_rport_work(struct work_struct *); 171*4882a593Smuzhiyun extern void zfcp_scsi_schedule_rport_register(struct zfcp_port *); 172*4882a593Smuzhiyun extern void zfcp_scsi_schedule_rport_block(struct zfcp_port *); 173*4882a593Smuzhiyun extern void zfcp_scsi_schedule_rports_block(struct zfcp_adapter *); 174*4882a593Smuzhiyun extern void zfcp_scsi_set_prot(struct zfcp_adapter *); 175*4882a593Smuzhiyun extern void zfcp_scsi_dif_sense_error(struct scsi_cmnd *, int); 176*4882a593Smuzhiyun extern void zfcp_scsi_shost_update_config_data( 177*4882a593Smuzhiyun struct zfcp_adapter *const adapter, 178*4882a593Smuzhiyun const struct fsf_qtcb_bottom_config *const bottom, 179*4882a593Smuzhiyun const bool bottom_incomplete); 180*4882a593Smuzhiyun extern void zfcp_scsi_shost_update_port_data( 181*4882a593Smuzhiyun struct zfcp_adapter *const adapter, 182*4882a593Smuzhiyun const struct fsf_qtcb_bottom_port *const bottom); 183*4882a593Smuzhiyun 184*4882a593Smuzhiyun /* zfcp_sysfs.c */ 185*4882a593Smuzhiyun extern const struct attribute_group *zfcp_unit_attr_groups[]; 186*4882a593Smuzhiyun extern struct attribute_group zfcp_sysfs_adapter_attrs; 187*4882a593Smuzhiyun extern const struct attribute_group *zfcp_port_attr_groups[]; 188*4882a593Smuzhiyun extern struct mutex zfcp_sysfs_port_units_mutex; 189*4882a593Smuzhiyun extern struct device_attribute *zfcp_sysfs_sdev_attrs[]; 190*4882a593Smuzhiyun extern struct device_attribute *zfcp_sysfs_shost_attrs[]; 191*4882a593Smuzhiyun extern const struct attribute_group zfcp_sysfs_diag_attr_group; 192*4882a593Smuzhiyun bool zfcp_sysfs_port_is_removing(const struct zfcp_port *const port); 193*4882a593Smuzhiyun 194*4882a593Smuzhiyun /* zfcp_unit.c */ 195*4882a593Smuzhiyun extern int zfcp_unit_add(struct zfcp_port *, u64); 196*4882a593Smuzhiyun extern int zfcp_unit_remove(struct zfcp_port *, u64); 197*4882a593Smuzhiyun extern struct zfcp_unit *zfcp_unit_find(struct zfcp_port *, u64); 198*4882a593Smuzhiyun extern struct scsi_device *zfcp_unit_sdev(struct zfcp_unit *unit); 199*4882a593Smuzhiyun extern void zfcp_unit_scsi_scan(struct zfcp_unit *); 200*4882a593Smuzhiyun extern void zfcp_unit_queue_scsi_scan(struct zfcp_port *); 201*4882a593Smuzhiyun extern unsigned int zfcp_unit_sdev_status(struct zfcp_unit *); 202*4882a593Smuzhiyun 203*4882a593Smuzhiyun #endif /* ZFCP_EXT_H */ 204