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