1 /*-
2  * Copyright (c) 2017 Broadcom. All rights reserved.
3  * The term "Broadcom" refers to Broadcom Limited and/or its subsidiaries.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice,
9  *    this list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  *    this list of conditions and the following disclaimer in the documentation
13  *    and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors
16  *    may be used to endorse or promote products derived from this software
17  *    without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  *
31  * $FreeBSD: stable/12/sys/dev/ocs_fc/ocs.h 371259 2021-12-17 10:05:57Z ram $
32  */
33 
34 /**
35  * @file
36  * OCS bsd driver common include file
37  */
38 
39 
40 #if !defined(__OCS_H__)
41 #define __OCS_H__
42 
43 #include "ocs_os.h"
44 #include "ocs_utils.h"
45 
46 #include "ocs_hw.h"
47 #include "ocs_scsi.h"
48 #include "ocs_io.h"
49 
50 #include "version.h"
51 
52 #define DRV_NAME			"ocs_fc"
53 #define DRV_VERSION 							\
54 	STR_BE_MAJOR "." STR_BE_MINOR "." STR_BE_BUILD "." STR_BE_BRANCH
55 
56 /**
57  * @brief Interrupt context
58  */
59 typedef struct ocs_intr_ctx_s {
60 	uint32_t	vec;		/** Zero based interrupt vector */
61 	void		*softc;		/** software context for interrupt */
62 	char		name[64];	/** label for this context */
63 } ocs_intr_ctx_t;
64 
65 typedef struct ocs_fc_rport_db_s {
66 	uint32_t	node_id;
67 	uint32_t	state;
68 	uint32_t	port_id;
69 	uint64_t	wwnn;
70 	uint64_t	wwpn;
71 	uint32_t	gone_timer;
72 } ocs_fc_target_t;
73 
74 #define OCS_TGT_STATE_NONE		0	/* Empty DB slot */
75 #define OCS_TGT_STATE_VALID		1	/* Valid*/
76 #define OCS_TGT_STATE_LOST		2	/* LOST*/
77 
78 typedef struct ocs_fcport_s {
79 	ocs_t			*ocs;
80 	struct cam_sim		*sim;
81 	struct cam_path		*path;
82 	uint32_t		role;
83 	uint32_t                fc_id;
84 
85 	ocs_fc_target_t	tgt[OCS_MAX_TARGETS];
86 	int lost_device_time;
87 	struct callout ldt;     /* device lost timer */
88 	struct task ltask;
89 
90 	ocs_tgt_resource_t	targ_rsrc_wildcard;
91 	ocs_tgt_resource_t	targ_rsrc[OCS_MAX_LUN];
92 	ocs_vport_spec_t	*vport;
93 } ocs_fcport;
94 
95 #define FCPORT(ocs, chan)	(&((ocs_fcport *)(ocs)->fcports)[(chan)])
96 
97 /**
98  * @brief Driver's context
99  */
100 
101 struct ocs_softc {
102 
103 	device_t		dev;
104 	struct cdev		*cdev;
105 
106 	ocs_pci_reg_t		reg[PCI_MAX_BAR];
107 
108 	uint32_t		instance_index;
109 	const char		*desc;
110 
111 	uint32_t		irqid;
112 	struct resource		*irq;
113 	void			*tag;
114 
115 	ocs_intr_ctx_t		intr_ctx;
116 	uint32_t		n_vec;
117 
118 	bus_dma_tag_t		dmat;	/** Parent DMA tag */
119 	bus_dma_tag_t		buf_dmat;/** IO buffer DMA tag */
120 	char display_name[OCS_DISPLAY_NAME_LENGTH];
121 	uint16_t		pci_vendor;
122 	uint16_t		pci_device;
123 	uint16_t		pci_subsystem_vendor;
124 	uint16_t		pci_subsystem_device;
125 	char			businfo[16];
126 	const char		*driver_version;
127 	const char		*fw_version;
128 	const char		*model;
129 
130 	ocs_hw_t hw;
131 
132 	ocs_rlock_t lock;	/**< device wide lock */
133 
134 	ocs_xport_e		ocs_xport;
135 	ocs_xport_t *xport;	/**< pointer to transport object */
136 	ocs_domain_t *domain;
137 	ocs_list_t domain_list;
138 	uint32_t domain_instance_count;
139 	void (*domain_list_empty_cb)(ocs_t *ocs, void *arg);
140 	void *domain_list_empty_cb_arg;
141 
142 	uint8_t enable_ini;
143 	uint8_t enable_tgt;
144 	uint8_t fc_type;
145 	int ctrlmask;
146 	uint8_t explicit_buffer_list;
147 	uint8_t external_loopback;
148 	uint8_t skip_hw_teardown;
149 	int speed;
150 	int topology;
151 	int ethernet_license;
152 	int num_scsi_ios;
153 	uint8_t enable_hlm;
154 	uint32_t hlm_group_size;
155 	uint32_t max_isr_time_msec;	/*>> Maximum ISR time */
156 	uint32_t auto_xfer_rdy_size; /*>> Max sized write to use auto xfer rdy*/
157 	uint8_t esoc;
158 	int logmask;
159 	char *hw_war_version;
160 	uint32_t num_vports;
161 	uint32_t target_io_timer_sec;
162 	uint32_t hw_bounce;
163 	uint8_t rq_threads;
164 	uint8_t rq_selection_policy;
165 	uint8_t rr_quanta;
166 	char *filter_def;
167 	uint32_t max_remote_nodes;
168 
169 	/*
170 	 * tgt_rscn_delay - delay in kicking off RSCN processing
171 	 * (nameserver queries) after receiving an RSCN on the target.
172 	 * This prevents thrashing of nameserver requests due to a huge burst of
173 	 * RSCNs received in a short period of time.
174 	 * Note: this is only valid when target RSCN handling is enabled -- see
175 	 * ctrlmask.
176 	 */
177 	time_t tgt_rscn_delay_msec;	/*>> minimum target RSCN delay */
178 
179 	/*
180 	 * tgt_rscn_period - determines maximum frequency when processing
181 	 * back-to-back RSCNs; e.g. if this value is 30, there will never be
182 	 * any more than 1 RSCN handling per 30s window. This prevents
183 	 * initiators on a faulty link generating many RSCN from causing the
184 	 * target to continually query the nameserver.
185 	 * Note: This is only valid when target RSCN handling is enabled
186 	 */
187 	time_t tgt_rscn_period_msec;	/*>> minimum target RSCN period */
188 
189 	uint32_t		enable_task_set_full;
190 	uint32_t		io_in_use;
191 	uint32_t		io_high_watermark; /**< used to send task set full */
192 	struct mtx		sim_lock;
193 	uint32_t		config_tgt:1,	/**< Configured to support target mode */
194 				config_ini:1;	/**< Configured to support initiator mode */
195 
196 
197 	uint32_t nodedb_mask;			/**< Node debugging mask */
198 
199 	char			modeldesc[64];
200 	char			serialnum[64];
201 	char			fwrev[64];
202 	char			sli_intf[9];
203 
204 	ocs_ramlog_t		*ramlog;
205 	ocs_textbuf_t		ddump_saved;
206 
207 	ocs_mgmt_functions_t	*mgmt_functions;
208 	ocs_mgmt_functions_t	*tgt_mgmt_functions;
209 	ocs_mgmt_functions_t	*ini_mgmt_functions;
210 
211 	ocs_err_injection_e err_injection;
212 	uint32_t cmd_err_inject;
213 	time_t delay_value_msec;
214 
215 	bool			attached;
216 	struct mtx		dbg_lock;
217 
218 	struct cam_devq		*devq;
219 	ocs_fcport		*fcports;
220 
221 	void*			tgt_ocs;
222 };
223 
224 static inline void
ocs_device_lock_init(ocs_t * ocs)225 ocs_device_lock_init(ocs_t *ocs)
226 {
227 	ocs_rlock_init(ocs, &ocs->lock, "ocsdevicelock");
228 }
229 
230 static inline int32_t
ocs_device_lock_try(ocs_t * ocs)231 ocs_device_lock_try(ocs_t *ocs)
232 {
233 	return ocs_rlock_try(&ocs->lock);
234 }
235 
236 static inline void
ocs_device_lock(ocs_t * ocs)237 ocs_device_lock(ocs_t *ocs)
238 {
239 	ocs_rlock_acquire(&ocs->lock);
240 }
241 
242 static inline void
ocs_device_unlock(ocs_t * ocs)243 ocs_device_unlock(ocs_t *ocs)
244 {
245 	ocs_rlock_release(&ocs->lock);
246 }
247 
248 static inline void
ocs_device_lock_free(ocs_t * ocs)249 ocs_device_lock_free(ocs_t *ocs)
250 {
251 	ocs_rlock_free(&ocs->lock);
252 }
253 
254 extern int32_t ocs_device_detach(ocs_t *ocs);
255 
256 extern int32_t ocs_device_attach(ocs_t *ocs);
257 
258 #define ocs_is_initiator_enabled()	(ocs->enable_ini)
259 #define ocs_is_target_enabled()	(ocs->enable_tgt)
260 
261 #include "ocs_xport.h"
262 #include "ocs_domain.h"
263 #include "ocs_sport.h"
264 #include "ocs_node.h"
265 #include "ocs_unsol.h"
266 #include "ocs_scsi.h"
267 #include "ocs_ioctl.h"
268 
269 static inline ocs_io_t *
ocs_io_alloc(ocs_t * ocs)270 ocs_io_alloc(ocs_t *ocs)
271 {
272 	return ocs_io_pool_io_alloc(ocs->xport->io_pool);
273 }
274 
275 static inline void
ocs_io_free(ocs_t * ocs,ocs_io_t * io)276 ocs_io_free(ocs_t *ocs, ocs_io_t *io)
277 {
278 	ocs_io_pool_io_free(ocs->xport->io_pool, io);
279 }
280 
281 #endif /* __OCS_H__ */
282