xref: /freebsd/sys/dev/ocs_fc/ocs.h (revision 95ee2897)
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 
32ef270ab1SKenneth D. Merry /**
33ef270ab1SKenneth D. Merry  * @file
34ef270ab1SKenneth D. Merry  * OCS bsd driver common include file
35ef270ab1SKenneth D. Merry  */
36ef270ab1SKenneth D. Merry 
37ef270ab1SKenneth D. Merry #if !defined(__OCS_H__)
38ef270ab1SKenneth D. Merry #define __OCS_H__
39ef270ab1SKenneth D. Merry 
40ef270ab1SKenneth D. Merry #include "ocs_os.h"
41ef270ab1SKenneth D. Merry #include "ocs_utils.h"
42ef270ab1SKenneth D. Merry 
43ef270ab1SKenneth D. Merry #include "ocs_hw.h"
44ef270ab1SKenneth D. Merry #include "ocs_scsi.h"
45ef270ab1SKenneth D. Merry #include "ocs_io.h"
46ef270ab1SKenneth D. Merry 
47ef270ab1SKenneth D. Merry #include "version.h"
48ef270ab1SKenneth D. Merry 
49ef270ab1SKenneth D. Merry #define DRV_NAME			"ocs_fc"
50ef270ab1SKenneth D. Merry #define DRV_VERSION 							\
51ef270ab1SKenneth D. Merry 	STR_BE_MAJOR "." STR_BE_MINOR "." STR_BE_BUILD "." STR_BE_BRANCH
52ef270ab1SKenneth D. Merry 
53ef270ab1SKenneth D. Merry /**
54ef270ab1SKenneth D. Merry  * @brief Interrupt context
55ef270ab1SKenneth D. Merry  */
56ef270ab1SKenneth D. Merry typedef struct ocs_intr_ctx_s {
57ef270ab1SKenneth D. Merry 	uint32_t	vec;		/** Zero based interrupt vector */
58ef270ab1SKenneth D. Merry 	void		*softc;		/** software context for interrupt */
59ef270ab1SKenneth D. Merry 	char		name[64];	/** label for this context */
60ef270ab1SKenneth D. Merry } ocs_intr_ctx_t;
61ef270ab1SKenneth D. Merry 
626affb8ebSRam Kishore Vegesna typedef struct ocs_fc_rport_db_s {
636affb8ebSRam Kishore Vegesna 	uint32_t	node_id;
646affb8ebSRam Kishore Vegesna 	uint32_t	state;
656affb8ebSRam Kishore Vegesna 	uint32_t	port_id;
666affb8ebSRam Kishore Vegesna 	uint64_t	wwnn;
676affb8ebSRam Kishore Vegesna 	uint64_t	wwpn;
686affb8ebSRam Kishore Vegesna 	uint32_t	gone_timer;
696affb8ebSRam Kishore Vegesna } ocs_fc_target_t;
706affb8ebSRam Kishore Vegesna 
716affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_NONE		0	/* Empty DB slot */
726affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_VALID		1	/* Valid*/
736affb8ebSRam Kishore Vegesna #define OCS_TGT_STATE_LOST		2	/* LOST*/
746affb8ebSRam Kishore Vegesna 
75ef270ab1SKenneth D. Merry typedef struct ocs_fcport_s {
766affb8ebSRam Kishore Vegesna 	ocs_t			*ocs;
77ef270ab1SKenneth D. Merry 	struct cam_sim		*sim;
78ef270ab1SKenneth D. Merry 	struct cam_path		*path;
79ef270ab1SKenneth D. Merry 	uint32_t		role;
80b9732f78SRam Kishore Vegesna 	uint32_t                fc_id;
81ef270ab1SKenneth D. Merry 
826affb8ebSRam Kishore Vegesna 	ocs_fc_target_t	tgt[OCS_MAX_TARGETS];
836affb8ebSRam Kishore Vegesna 	int lost_device_time;
846affb8ebSRam Kishore Vegesna 	struct callout ldt;     /* device lost timer */
856affb8ebSRam Kishore Vegesna 	struct task ltask;
866affb8ebSRam Kishore Vegesna 
87ef270ab1SKenneth D. Merry 	ocs_tgt_resource_t	targ_rsrc_wildcard;
88ef270ab1SKenneth D. Merry 	ocs_tgt_resource_t	targ_rsrc[OCS_MAX_LUN];
89ef270ab1SKenneth D. Merry 	ocs_vport_spec_t	*vport;
90ef270ab1SKenneth D. Merry } ocs_fcport;
91ef270ab1SKenneth D. Merry 
92ef270ab1SKenneth D. Merry #define FCPORT(ocs, chan)	(&((ocs_fcport *)(ocs)->fcports)[(chan)])
93ef270ab1SKenneth D. Merry 
94ef270ab1SKenneth D. Merry /**
95ef270ab1SKenneth D. Merry  * @brief Driver's context
96ef270ab1SKenneth D. Merry  */
97ef270ab1SKenneth D. Merry 
98ef270ab1SKenneth D. Merry struct ocs_softc {
99ef270ab1SKenneth D. Merry 	device_t		dev;
100ef270ab1SKenneth D. Merry 	struct cdev		*cdev;
101ef270ab1SKenneth D. Merry 
102ef270ab1SKenneth D. Merry 	ocs_pci_reg_t		reg[PCI_MAX_BAR];
103ef270ab1SKenneth D. Merry 
104ef270ab1SKenneth D. Merry 	uint32_t		instance_index;
105ef270ab1SKenneth D. Merry 	const char		*desc;
106ef270ab1SKenneth D. Merry 
107ef270ab1SKenneth D. Merry 	uint32_t		irqid;
108ef270ab1SKenneth D. Merry 	struct resource		*irq;
109ef270ab1SKenneth D. Merry 	void			*tag;
110ef270ab1SKenneth D. Merry 
111ef270ab1SKenneth D. Merry 	ocs_intr_ctx_t		intr_ctx;
112ef270ab1SKenneth D. Merry 	uint32_t		n_vec;
113ef270ab1SKenneth D. Merry 
114ef270ab1SKenneth D. Merry 	bus_dma_tag_t		dmat;	/** Parent DMA tag */
115ef270ab1SKenneth D. Merry 	bus_dma_tag_t		buf_dmat;/** IO buffer DMA tag */
116ef270ab1SKenneth D. Merry 	char display_name[OCS_DISPLAY_NAME_LENGTH];
117ef270ab1SKenneth D. Merry 	uint16_t		pci_vendor;
118ef270ab1SKenneth D. Merry 	uint16_t		pci_device;
119ef270ab1SKenneth D. Merry 	uint16_t		pci_subsystem_vendor;
120ef270ab1SKenneth D. Merry 	uint16_t		pci_subsystem_device;
121ef270ab1SKenneth D. Merry 	char			businfo[16];
122ef270ab1SKenneth D. Merry 	const char		*driver_version;
123ef270ab1SKenneth D. Merry 	const char		*fw_version;
124ef270ab1SKenneth D. Merry 	const char		*model;
125ef270ab1SKenneth D. Merry 
126ef270ab1SKenneth D. Merry 	ocs_hw_t hw;
127ef270ab1SKenneth D. Merry 
128ef270ab1SKenneth D. Merry 	ocs_rlock_t lock;	/**< device wide lock */
129ef270ab1SKenneth D. Merry 
130ef270ab1SKenneth D. Merry 	ocs_xport_e		ocs_xport;
131ef270ab1SKenneth D. Merry 	ocs_xport_t *xport;	/**< pointer to transport object */
132ef270ab1SKenneth D. Merry 	ocs_domain_t *domain;
133ef270ab1SKenneth D. Merry 	ocs_list_t domain_list;
134ef270ab1SKenneth D. Merry 	uint32_t domain_instance_count;
135ef270ab1SKenneth D. Merry 	void (*domain_list_empty_cb)(ocs_t *ocs, void *arg);
136ef270ab1SKenneth D. Merry 	void *domain_list_empty_cb_arg;
137ef270ab1SKenneth D. Merry 
138ef270ab1SKenneth D. Merry 	uint8_t enable_ini;
139ef270ab1SKenneth D. Merry 	uint8_t enable_tgt;
140ef270ab1SKenneth D. Merry 	uint8_t fc_type;
141ef270ab1SKenneth D. Merry 	int ctrlmask;
142ef270ab1SKenneth D. Merry 	uint8_t explicit_buffer_list;
143ef270ab1SKenneth D. Merry 	uint8_t external_loopback;
144ef270ab1SKenneth D. Merry 	uint8_t skip_hw_teardown;
145ef270ab1SKenneth D. Merry 	int speed;
146ef270ab1SKenneth D. Merry 	int topology;
147ef270ab1SKenneth D. Merry 	int ethernet_license;
148ef270ab1SKenneth D. Merry 	int num_scsi_ios;
149ef270ab1SKenneth D. Merry 	uint8_t enable_hlm;
150ef270ab1SKenneth D. Merry 	uint32_t hlm_group_size;
151ef270ab1SKenneth D. Merry 	uint32_t max_isr_time_msec;	/*>> Maximum ISR time */
152ef270ab1SKenneth D. Merry 	uint32_t auto_xfer_rdy_size; /*>> Max sized write to use auto xfer rdy*/
153ef270ab1SKenneth D. Merry 	uint8_t esoc;
154ef270ab1SKenneth D. Merry 	int logmask;
155ef270ab1SKenneth D. Merry 	char *hw_war_version;
156ef270ab1SKenneth D. Merry 	uint32_t num_vports;
157ef270ab1SKenneth D. Merry 	uint32_t target_io_timer_sec;
158ef270ab1SKenneth D. Merry 	uint32_t hw_bounce;
159ef270ab1SKenneth D. Merry 	uint8_t rq_threads;
160ef270ab1SKenneth D. Merry 	uint8_t rq_selection_policy;
161ef270ab1SKenneth D. Merry 	uint8_t rr_quanta;
162ef270ab1SKenneth D. Merry 	char *filter_def;
163ef270ab1SKenneth D. Merry 	uint32_t max_remote_nodes;
164ef270ab1SKenneth D. Merry 
165ef270ab1SKenneth D. Merry 	/*
166ef270ab1SKenneth D. Merry 	 * tgt_rscn_delay - delay in kicking off RSCN processing
167ef270ab1SKenneth D. Merry 	 * (nameserver queries) after receiving an RSCN on the target.
168ef270ab1SKenneth D. Merry 	 * This prevents thrashing of nameserver requests due to a huge burst of
169ef270ab1SKenneth D. Merry 	 * RSCNs received in a short period of time.
170ef270ab1SKenneth D. Merry 	 * Note: this is only valid when target RSCN handling is enabled -- see
171ef270ab1SKenneth D. Merry 	 * ctrlmask.
172ef270ab1SKenneth D. Merry 	 */
173ef270ab1SKenneth D. Merry 	time_t tgt_rscn_delay_msec;	/*>> minimum target RSCN delay */
174ef270ab1SKenneth D. Merry 
175ef270ab1SKenneth D. Merry 	/*
176ef270ab1SKenneth D. Merry 	 * tgt_rscn_period - determines maximum frequency when processing
177ef270ab1SKenneth D. Merry 	 * back-to-back RSCNs; e.g. if this value is 30, there will never be
178ef270ab1SKenneth D. Merry 	 * any more than 1 RSCN handling per 30s window. This prevents
179ef270ab1SKenneth D. Merry 	 * initiators on a faulty link generating many RSCN from causing the
180ef270ab1SKenneth D. Merry 	 * target to continually query the nameserver.
181ef270ab1SKenneth D. Merry 	 * Note: This is only valid when target RSCN handling is enabled
182ef270ab1SKenneth D. Merry 	 */
183ef270ab1SKenneth D. Merry 	time_t tgt_rscn_period_msec;	/*>> minimum target RSCN period */
184ef270ab1SKenneth D. Merry 
185ef270ab1SKenneth D. Merry 	uint32_t		enable_task_set_full;
186ef270ab1SKenneth D. Merry 	uint32_t		io_in_use;
187ef270ab1SKenneth D. Merry 	uint32_t		io_high_watermark; /**< used to send task set full */
188ef270ab1SKenneth D. Merry 	struct mtx		sim_lock;
189ef270ab1SKenneth D. Merry 	uint32_t		config_tgt:1,	/**< Configured to support target mode */
190ef270ab1SKenneth D. Merry 				config_ini:1;	/**< Configured to support initiator mode */
191ef270ab1SKenneth D. Merry 
192ef270ab1SKenneth D. Merry 	uint32_t nodedb_mask;			/**< Node debugging mask */
193ef270ab1SKenneth D. Merry 
194ef270ab1SKenneth D. Merry 	char			modeldesc[64];
195ef270ab1SKenneth D. Merry 	char			serialnum[64];
196ef270ab1SKenneth D. Merry 	char			fwrev[64];
197ef270ab1SKenneth D. Merry 	char			sli_intf[9];
198ef270ab1SKenneth D. Merry 
199ef270ab1SKenneth D. Merry 	ocs_ramlog_t		*ramlog;
200ef270ab1SKenneth D. Merry 	ocs_textbuf_t		ddump_saved;
201ef270ab1SKenneth D. Merry 
202ef270ab1SKenneth D. Merry 	ocs_mgmt_functions_t	*mgmt_functions;
203ef270ab1SKenneth D. Merry 	ocs_mgmt_functions_t	*tgt_mgmt_functions;
204ef270ab1SKenneth D. Merry 	ocs_mgmt_functions_t	*ini_mgmt_functions;
205ef270ab1SKenneth D. Merry 
206ef270ab1SKenneth D. Merry 	ocs_err_injection_e err_injection;
207ef270ab1SKenneth D. Merry 	uint32_t cmd_err_inject;
208ef270ab1SKenneth D. Merry 	time_t delay_value_msec;
209ef270ab1SKenneth D. Merry 
210ef270ab1SKenneth D. Merry 	bool			attached;
211ef270ab1SKenneth D. Merry 	struct mtx		dbg_lock;
212ef270ab1SKenneth D. Merry 
213ef270ab1SKenneth D. Merry 	struct cam_devq		*devq;
214ef270ab1SKenneth D. Merry 	ocs_fcport		*fcports;
215ef270ab1SKenneth D. Merry 
216ef270ab1SKenneth D. Merry 	void*			tgt_ocs;
217ef270ab1SKenneth D. Merry };
218ef270ab1SKenneth D. Merry 
219ef270ab1SKenneth D. Merry static inline void
ocs_device_lock_init(ocs_t * ocs)220ef270ab1SKenneth D. Merry ocs_device_lock_init(ocs_t *ocs)
221ef270ab1SKenneth D. Merry {
222ef270ab1SKenneth D. Merry 	ocs_rlock_init(ocs, &ocs->lock, "ocsdevicelock");
223ef270ab1SKenneth D. Merry }
224ef270ab1SKenneth D. Merry 
225ef270ab1SKenneth D. Merry static inline int32_t
ocs_device_lock_try(ocs_t * ocs)226ef270ab1SKenneth D. Merry ocs_device_lock_try(ocs_t *ocs)
227ef270ab1SKenneth D. Merry {
228ef270ab1SKenneth D. Merry 	return ocs_rlock_try(&ocs->lock);
229ef270ab1SKenneth D. Merry }
230ef270ab1SKenneth D. Merry 
231ef270ab1SKenneth D. Merry static inline void
ocs_device_lock(ocs_t * ocs)232ef270ab1SKenneth D. Merry ocs_device_lock(ocs_t *ocs)
233ef270ab1SKenneth D. Merry {
234ef270ab1SKenneth D. Merry 	ocs_rlock_acquire(&ocs->lock);
235ef270ab1SKenneth D. Merry }
236ef270ab1SKenneth D. Merry 
237ef270ab1SKenneth D. Merry static inline void
ocs_device_unlock(ocs_t * ocs)238ef270ab1SKenneth D. Merry ocs_device_unlock(ocs_t *ocs)
239ef270ab1SKenneth D. Merry {
240ef270ab1SKenneth D. Merry 	ocs_rlock_release(&ocs->lock);
241ef270ab1SKenneth D. Merry }
242ef270ab1SKenneth D. Merry 
243ef270ab1SKenneth D. Merry static inline void
ocs_device_lock_free(ocs_t * ocs)244ef270ab1SKenneth D. Merry ocs_device_lock_free(ocs_t *ocs)
245ef270ab1SKenneth D. Merry {
246ef270ab1SKenneth D. Merry 	ocs_rlock_free(&ocs->lock);
247ef270ab1SKenneth D. Merry }
248ef270ab1SKenneth D. Merry 
249ef270ab1SKenneth D. Merry extern int32_t ocs_device_detach(ocs_t *ocs);
250ef270ab1SKenneth D. Merry 
251ef270ab1SKenneth D. Merry extern int32_t ocs_device_attach(ocs_t *ocs);
252ef270ab1SKenneth D. Merry 
253ef270ab1SKenneth D. Merry #define ocs_is_initiator_enabled()	(ocs->enable_ini)
254ef270ab1SKenneth D. Merry #define ocs_is_target_enabled()	(ocs->enable_tgt)
255ef270ab1SKenneth D. Merry 
256ef270ab1SKenneth D. Merry #include "ocs_xport.h"
257ef270ab1SKenneth D. Merry #include "ocs_domain.h"
258ef270ab1SKenneth D. Merry #include "ocs_sport.h"
259ef270ab1SKenneth D. Merry #include "ocs_node.h"
260ef270ab1SKenneth D. Merry #include "ocs_unsol.h"
261ef270ab1SKenneth D. Merry #include "ocs_scsi.h"
262ef270ab1SKenneth D. Merry #include "ocs_ioctl.h"
263ef270ab1SKenneth D. Merry 
264ef270ab1SKenneth D. Merry static inline ocs_io_t *
ocs_io_alloc(ocs_t * ocs)265ef270ab1SKenneth D. Merry ocs_io_alloc(ocs_t *ocs)
266ef270ab1SKenneth D. Merry {
267ef270ab1SKenneth D. Merry 	return ocs_io_pool_io_alloc(ocs->xport->io_pool);
268ef270ab1SKenneth D. Merry }
269ef270ab1SKenneth D. Merry 
270ef270ab1SKenneth D. Merry static inline void
ocs_io_free(ocs_t * ocs,ocs_io_t * io)271ef270ab1SKenneth D. Merry ocs_io_free(ocs_t *ocs, ocs_io_t *io)
272ef270ab1SKenneth D. Merry {
273ef270ab1SKenneth D. Merry 	ocs_io_pool_io_free(ocs->xport->io_pool, io);
274ef270ab1SKenneth D. Merry }
275ef270ab1SKenneth D. Merry 
276ef270ab1SKenneth D. Merry #endif /* __OCS_H__ */
277