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