xref: /OK3568_Linux_fs/kernel/drivers/s390/scsi/zfcp_ext.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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