Merge tag 'pci-v6.16-fixes-3' of git://git.kernel.org/pub/scm/linux/kernel/git/pci/pci
[linux-2.6-block.git] / drivers / s390 / scsi / zfcp_ext.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
41fa2ada 2/*
553448f6 3 * zfcp device driver
1da177e4 4 *
553448f6 5 * External function declarations.
41fa2ada 6 *
901b894a 7 * Copyright IBM Corp. 2002, 2023
1da177e4
LT
8 */
9
10#ifndef ZFCP_EXT_H
11#define ZFCP_EXT_H
12
9d05ce2c 13#include <linux/types.h>
20540a56 14#include <linux/sysfs.h>
9d05ce2c 15#include <scsi/fc/fc_els.h>
1da177e4 16#include "zfcp_def.h"
7c7dc196 17#include "zfcp_fc.h"
1da177e4 18
92c299d1 19/* zfcp_aux.c */
7ba58c9c 20extern struct zfcp_port *zfcp_get_port_by_wwpn(struct zfcp_adapter *, u64);
de3dc572 21extern struct zfcp_adapter *zfcp_adapter_enqueue(struct ccw_device *);
7ba58c9c 22extern struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *, u64, u32,
92c299d1 23 u32);
f3450c7b 24extern void zfcp_adapter_release(struct kref *);
de3dc572 25extern void zfcp_adapter_unregister(struct zfcp_adapter *);
1da177e4 26
92c299d1 27/* zfcp_ccw.c */
c5afd81e 28extern struct ccw_driver zfcp_ccw_driver;
de3dc572
SS
29extern struct zfcp_adapter *zfcp_ccw_adapter_by_cdev(struct ccw_device *);
30extern void zfcp_ccw_adapter_put(struct zfcp_adapter *);
24073b47 31
92c299d1 32/* zfcp_dbf.c */
5771710b 33extern int zfcp_dbf_adapter_register(struct zfcp_adapter *);
ea4a3a6a 34extern void zfcp_dbf_adapter_unregister(struct zfcp_adapter *);
ae0904f6
SS
35extern void zfcp_dbf_rec_trig(char *, struct zfcp_adapter *,
36 struct zfcp_port *, struct scsi_device *, u8, u8);
fa89adba
JR
37extern void zfcp_dbf_rec_trig_lock(char *tag, struct zfcp_adapter *adapter,
38 struct zfcp_port *port,
39 struct scsi_device *sdev, u8 want, u8 need);
ae0904f6 40extern void zfcp_dbf_rec_run(char *, struct zfcp_erp_action *);
6f2ce1c6
SM
41extern void zfcp_dbf_rec_run_lvl(int level, char *tag,
42 struct zfcp_erp_action *erp);
d27a7cb9 43extern void zfcp_dbf_rec_run_wka(char *, struct zfcp_fc_wka_port *, u64);
a54ca0f6 44extern void zfcp_dbf_hba_fsf_uss(char *, struct zfcp_fsf_req *);
35f040df 45extern void zfcp_dbf_hba_fsf_res(char *, int, struct zfcp_fsf_req *);
616da39e
JR
46extern void zfcp_dbf_hba_fsf_fces(char *tag, const struct zfcp_fsf_req *req,
47 u64 wwpn, u32 fc_security_old,
48 u32 fc_security_new);
901b894a
BB
49extern void zfcp_dbf_hba_fsf_reqid(const char *const tag, const int level,
50 struct zfcp_adapter *const adapter,
51 const u64 req_id);
a54ca0f6 52extern void zfcp_dbf_hba_bit_err(char *, struct zfcp_fsf_req *);
86a9668a 53extern void zfcp_dbf_hba_def_err(struct zfcp_adapter *, u64, u16, void **);
2c55b750
SS
54extern void zfcp_dbf_san_req(char *, struct zfcp_fsf_req *, u32);
55extern void zfcp_dbf_san_res(char *, struct zfcp_fsf_req *);
56extern void zfcp_dbf_san_in_els(char *, struct zfcp_fsf_req *);
82212118
SM
57extern void zfcp_dbf_scsi_common(char *tag, int level, struct scsi_device *sdev,
58 struct scsi_cmnd *sc,
59 struct zfcp_fsf_req *fsf);
df307816
SM
60extern void zfcp_dbf_scsi_eh(char *tag, struct zfcp_adapter *adapter,
61 unsigned int scsi_id, int ret);
1da177e4 62
92c299d1 63/* zfcp_erp.c */
edaed859
SS
64extern void zfcp_erp_set_adapter_status(struct zfcp_adapter *, u32);
65extern void zfcp_erp_clear_adapter_status(struct zfcp_adapter *, u32);
208d0961 66extern void zfcp_erp_port_forced_no_port_dbf(char *dbftag,
96d92704
SM
67 struct zfcp_adapter *adapter,
68 u64 port_name, u32 port_id);
ea4a3a6a
SS
69extern void zfcp_erp_adapter_reopen(struct zfcp_adapter *, int, char *);
70extern void zfcp_erp_adapter_shutdown(struct zfcp_adapter *, int, char *);
edaed859
SS
71extern void zfcp_erp_set_port_status(struct zfcp_port *, u32);
72extern void zfcp_erp_clear_port_status(struct zfcp_port *, u32);
208d0961
SM
73extern void zfcp_erp_port_reopen(struct zfcp_port *port, int clear,
74 char *dbftag);
ea4a3a6a
SS
75extern void zfcp_erp_port_shutdown(struct zfcp_port *, int, char *);
76extern void zfcp_erp_port_forced_reopen(struct zfcp_port *, int, char *);
242ec145
SM
77extern void zfcp_erp_port_forced_reopen_all(struct zfcp_adapter *adapter,
78 int clear, char *dbftag);
edaed859
SS
79extern void zfcp_erp_set_lun_status(struct scsi_device *, u32);
80extern void zfcp_erp_clear_lun_status(struct scsi_device *, u32);
ea4a3a6a
SS
81extern void zfcp_erp_lun_reopen(struct scsi_device *, int, char *);
82extern void zfcp_erp_lun_shutdown(struct scsi_device *, int, char *);
b62a8d9b 83extern void zfcp_erp_lun_shutdown_wait(struct scsi_device *, char *);
1da177e4 84extern int zfcp_erp_thread_setup(struct zfcp_adapter *);
287ac01a
CS
85extern void zfcp_erp_thread_kill(struct zfcp_adapter *);
86extern void zfcp_erp_wait(struct zfcp_adapter *);
87extern void zfcp_erp_notify(struct zfcp_erp_action *, unsigned long);
5c13db9b 88extern void zfcp_erp_timeout_handler(struct timer_list *t);
208d0961
SM
89extern void zfcp_erp_adapter_reset_sync(struct zfcp_adapter *adapter,
90 char *dbftag);
8a36e453 91
92c299d1 92/* zfcp_fc.c */
087897e3 93extern struct kmem_cache *zfcp_fc_req_cache;
2d1e547f
SS
94extern void zfcp_fc_enqueue_event(struct zfcp_adapter *,
95 enum fc_host_event_code event_code, u32);
96extern void zfcp_fc_post_event(struct work_struct *);
9eae07ef 97extern void zfcp_fc_scan_ports(struct work_struct *);
92c299d1 98extern void zfcp_fc_incoming_els(struct zfcp_fsf_req *);
799b76d0 99extern void zfcp_fc_port_did_lookup(struct work_struct *);
934aeb58 100extern void zfcp_fc_trigger_did_lookup(struct zfcp_port *);
9d05ce2c 101extern void zfcp_fc_plogi_evaluate(struct zfcp_port *, struct fc_els_flogi *);
6f53a2d2 102extern void zfcp_fc_test_link(struct zfcp_port *);
8fdf30d5 103extern void zfcp_fc_link_test_work(struct work_struct *);
bd0072ec 104extern void zfcp_fc_wka_ports_force_offline(struct zfcp_fc_wka_ports *);
d5a282a1
SS
105extern int zfcp_fc_gs_setup(struct zfcp_adapter *);
106extern void zfcp_fc_gs_destroy(struct zfcp_adapter *);
75cc8cfc
JT
107extern int zfcp_fc_exec_bsg_job(struct bsg_job *);
108extern int zfcp_fc_timeout_bsg_job(struct bsg_job *);
038d9446 109extern void zfcp_fc_sym_name_update(struct work_struct *);
18f87a67 110extern unsigned int zfcp_fc_port_scan_backoff(void);
43f60cbd
SM
111extern void zfcp_fc_conditional_port_scan(struct zfcp_adapter *);
112extern void zfcp_fc_inverse_conditional_port_scan(struct zfcp_adapter *);
92c299d1
CS
113
114/* zfcp_fsf.c */
259afe2e 115extern struct kmem_cache *zfcp_fsf_qtcb_cache;
92c299d1 116extern int zfcp_fsf_open_port(struct zfcp_erp_action *);
bd0072ec
CS
117extern int zfcp_fsf_open_wka_port(struct zfcp_fc_wka_port *);
118extern int zfcp_fsf_close_wka_port(struct zfcp_fc_wka_port *);
92c299d1
CS
119extern int zfcp_fsf_close_port(struct zfcp_erp_action *);
120extern int zfcp_fsf_close_physical_port(struct zfcp_erp_action *);
b62a8d9b
CS
121extern int zfcp_fsf_open_lun(struct zfcp_erp_action *);
122extern int zfcp_fsf_close_lun(struct zfcp_erp_action *);
92c299d1 123extern int zfcp_fsf_exchange_config_data(struct zfcp_erp_action *);
564e1c86 124extern int zfcp_fsf_exchange_config_data_sync(struct zfcp_qdio *,
92c299d1
CS
125 struct fsf_qtcb_bottom_config *);
126extern int zfcp_fsf_exchange_port_data(struct zfcp_erp_action *);
564e1c86 127extern int zfcp_fsf_exchange_port_data_sync(struct zfcp_qdio *,
92c299d1 128 struct fsf_qtcb_bottom_port *);
bd168481 129extern u32 zfcp_fsf_convert_portspeed(u32 fsf_speed);
92c299d1 130extern void zfcp_fsf_req_dismiss_all(struct zfcp_adapter *);
564e1c86 131extern int zfcp_fsf_status_read(struct zfcp_qdio *);
92c299d1 132extern int zfcp_status_read_refill(struct zfcp_adapter *adapter);
7c7dc196 133extern int zfcp_fsf_send_ct(struct zfcp_fc_wka_port *, struct zfcp_fsf_ct_els *,
51375ee8 134 mempool_t *, unsigned int);
7c7dc196 135extern int zfcp_fsf_send_els(struct zfcp_adapter *, u32,
51375ee8 136 struct zfcp_fsf_ct_els *, unsigned int);
b62a8d9b 137extern int zfcp_fsf_fcp_cmnd(struct scsi_cmnd *);
92c299d1 138extern void zfcp_fsf_req_free(struct zfcp_fsf_req *);
d0dff2ac 139extern void zfcp_fsf_fc_host_link_down(struct zfcp_adapter *adapter);
26f5fa9d
SM
140extern struct zfcp_fsf_req *zfcp_fsf_fcp_task_mgmt(struct scsi_device *sdev,
141 u8 tm_flags);
b62a8d9b 142extern struct zfcp_fsf_req *zfcp_fsf_abort_fcp_cmnd(struct scsi_cmnd *);
564e1c86 143extern void zfcp_fsf_reqid_check(struct zfcp_qdio *, int);
a17c7846
JR
144enum zfcp_fsf_print_fmt {
145 ZFCP_FSF_PRINT_FMT_LIST,
146 ZFCP_FSF_PRINT_FMT_SINGLEITEM,
147};
148extern ssize_t zfcp_fsf_scnprint_fc_security(char *buf, size_t size,
149 u32 fc_security,
150 enum zfcp_fsf_print_fmt fmt);
8a36e453 151
92c299d1 152/* zfcp_qdio.c */
d5a282a1
SS
153extern int zfcp_qdio_setup(struct zfcp_adapter *);
154extern void zfcp_qdio_destroy(struct zfcp_qdio *);
6b9e1520 155extern int zfcp_qdio_sbal_get(struct zfcp_qdio *);
34c2b712 156extern int zfcp_qdio_send(struct zfcp_qdio *, struct zfcp_qdio_req *);
1674b405 157extern int zfcp_qdio_sbals_from_sg(struct zfcp_qdio *, struct zfcp_qdio_req *,
01b04759 158 struct scatterlist *);
978857c7
BB
159extern void zfcp_qdio_shost_update(struct zfcp_adapter *const adapter,
160 const struct zfcp_qdio *const qdio);
564e1c86
SS
161extern int zfcp_qdio_open(struct zfcp_qdio *);
162extern void zfcp_qdio_close(struct zfcp_qdio *);
339f4f4e 163extern void zfcp_qdio_siosl(struct zfcp_adapter *);
92c299d1
CS
164
165/* zfcp_scsi.c */
636db60b 166extern bool zfcp_experimental_dix;
1947c72a
CS
167extern struct scsi_transport_template *zfcp_scsi_transport_template;
168extern int zfcp_scsi_adapter_register(struct zfcp_adapter *);
169extern void zfcp_scsi_adapter_unregister(struct zfcp_adapter *);
92c299d1 170extern struct fc_function_template zfcp_transport_functions;
a2fa0aed
CS
171extern void zfcp_scsi_rport_work(struct work_struct *);
172extern void zfcp_scsi_schedule_rport_register(struct zfcp_port *);
173extern void zfcp_scsi_schedule_rport_block(struct zfcp_port *);
174extern void zfcp_scsi_schedule_rports_block(struct zfcp_adapter *);
ef3eb71d
FB
175extern void zfcp_scsi_set_prot(struct zfcp_adapter *);
176extern void zfcp_scsi_dif_sense_error(struct scsi_cmnd *, int);
bd168481
BB
177extern void zfcp_scsi_shost_update_config_data(
178 struct zfcp_adapter *const adapter,
179 const struct fsf_qtcb_bottom_config *const bottom,
180 const bool bottom_incomplete);
52e61fde
BB
181extern void zfcp_scsi_shost_update_port_data(
182 struct zfcp_adapter *const adapter,
183 const struct fsf_qtcb_bottom_port *const bottom);
8a36e453 184
92c299d1 185/* zfcp_sysfs.c */
20540a56 186extern const struct attribute_group *zfcp_sysfs_adapter_attr_groups[];
86bdf218 187extern const struct attribute_group *zfcp_unit_attr_groups[];
83d4e1c3 188extern const struct attribute_group *zfcp_port_attr_groups[];
d99b601b 189extern struct mutex zfcp_sysfs_port_units_mutex;
d8d7cf3f
BVA
190extern const struct attribute_group *zfcp_sysfs_sdev_attr_groups[];
191extern const struct attribute_group *zfcp_sysfs_shost_attr_groups[];
ef4021fe 192bool zfcp_sysfs_port_is_removing(const struct zfcp_port *const port);
45633fdc 193
1daa4eb5
CS
194/* zfcp_unit.c */
195extern int zfcp_unit_add(struct zfcp_port *, u64);
196extern int zfcp_unit_remove(struct zfcp_port *, u64);
197extern struct zfcp_unit *zfcp_unit_find(struct zfcp_port *, u64);
198extern struct scsi_device *zfcp_unit_sdev(struct zfcp_unit *unit);
199extern void zfcp_unit_scsi_scan(struct zfcp_unit *);
200extern void zfcp_unit_queue_scsi_scan(struct zfcp_port *);
201extern unsigned int zfcp_unit_sdev_status(struct zfcp_unit *);
202
1da177e4 203#endif /* ZFCP_EXT_H */