xref: /freebsd/sys/dev/sfxge/common/efx_check.h (revision b1f92fa22938fe29ab7e53692ffe0ed7a0ecc4d0)
1 /*-
2  * Copyright (c) 2012-2015 Solarflare Communications Inc.
3  * All rights reserved.
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  * 2. Redistributions in binary form must reproduce the above copyright notice,
11  *    this list of conditions and the following disclaimer in the documentation
12  *    and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
15  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
16  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
18  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
24  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  *
26  * The views and conclusions contained in the software and documentation are
27  * those of the authors and should not be interpreted as representing official
28  * policies, either expressed or implied, of the FreeBSD Project.
29  *
30  * $FreeBSD$
31  */
32 
33 #ifndef _SYS_EFX_CHECK_H
34 #define	_SYS_EFX_CHECK_H
35 
36 #include "efsys.h"
37 
38 /*
39  * Check that the efsys.h header in client code has a valid combination of
40  * EFSYS_OPT_xxx options.
41  *
42  * NOTE: Keep checks for obsolete options here to ensure that they are removed
43  * from client code (and do not reappear in merges from other branches).
44  */
45 
46 /* Support NVRAM based boot config */
47 #if EFSYS_OPT_BOOTCFG
48 # if !EFSYS_OPT_NVRAM
49 #  error "BOOTCFG requires NVRAM"
50 # endif
51 #endif /* EFSYS_OPT_BOOTCFG */
52 
53 /* Verify chip implements accessed registers */
54 #if EFSYS_OPT_CHECK_REG
55 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
56 #  error "CHECK_REG requires FALCON or SIENA or HUNTINGTON"
57 # endif
58 #endif /* EFSYS_OPT_CHECK_REG */
59 
60 /* Decode fatal errors */
61 #if EFSYS_OPT_DECODE_INTR_FATAL
62 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
63 #  if EFSYS_OPT_HUNTINGTON
64 #   error "INTR_FATAL not supported on HUNTINGTON"
65 #  endif
66 #  error "INTR_FATAL requires FALCON or SIENA"
67 # endif
68 #endif /* EFSYS_OPT_DECODE_INTR_FATAL */
69 
70 /* Support diagnostic hardware tests */
71 #if EFSYS_OPT_DIAG
72 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
73 #  error "DIAG requires FALCON or SIENA or HUNTINGTON"
74 # endif
75 #endif /* EFSYS_OPT_DIAG */
76 
77 /* Support optimized EVQ data access */
78 #if EFSYS_OPT_EV_PREFETCH
79 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
80 #  error "EV_PREFETCH requires FALCON or SIENA or HUNTINGTON"
81 # endif
82 #endif /* EFSYS_OPT_EV_PREFETCH */
83 
84 /* Support overriding the NVRAM and VPD configuration */
85 #if EFSYS_OPT_FALCON_NIC_CFG_OVERRIDE
86 # if !EFSYS_OPT_FALCON
87 #  error "FALCON_NIC_CFG_OVERRIDE requires FALCON"
88 # endif
89 #endif /* EFSYS_OPT_FALCON_NIC_CFG_OVERRIDE */
90 
91 /* Support hardware packet filters */
92 #if EFSYS_OPT_FILTER
93 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
94 #  error "FILTER requires FALCON or SIENA or HUNTINGTON"
95 # endif
96 #endif /* EFSYS_OPT_FILTER */
97 
98 #if EFSYS_OPT_HUNTINGTON
99 # if !EFSYS_OPT_FILTER
100 #  error "HUNTINGTON requires FILTER"
101 # endif
102 #endif /* EFSYS_OPT_HUNTINGTON */
103 
104 /* Support hardware loopback modes */
105 #if EFSYS_OPT_LOOPBACK
106 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
107 #  error "LOOPBACK requires FALCON or SIENA or HUNTINGTON"
108 # endif
109 #endif /* EFSYS_OPT_LOOPBACK */
110 
111 /* Support Falcon GMAC */
112 #if EFSYS_OPT_MAC_FALCON_GMAC
113 # if !EFSYS_OPT_FALCON
114 #  error "MAC_FALCON_GMAC requires FALCON"
115 # endif
116 #endif /* EFSYS_OPT_MAC_FALCON_GMAC */
117 
118 /* Support Falcon XMAC */
119 #if EFSYS_OPT_MAC_FALCON_XMAC
120 # if !EFSYS_OPT_FALCON
121 #  error "MAC_FALCON_XMAC requires FALCON"
122 # endif
123 #endif /* EFSYS_OPT_MAC_FALCON_XMAC */
124 
125 /* Support MAC statistics */
126 #if EFSYS_OPT_MAC_STATS
127 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
128 #  error "MAC_STATS requires FALCON or SIENA or HUNTINGTON"
129 # endif
130 #endif /* EFSYS_OPT_MAC_STATS */
131 
132 /* Support management controller messages */
133 #if EFSYS_OPT_MCDI
134 # if !(EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
135 #  if EFSYS_OPT_FALCON
136 #   error "MCDI not supported on FALCON"
137 #  endif
138 #  error "MCDI requires SIENA or HUNTINGTON"
139 # endif
140 #endif /* EFSYS_OPT_MCDI */
141 
142 #if EFSYS_OPT_SIENA && !EFSYS_OPT_MCDI
143 # error "SIENA requires MCDI"
144 #endif
145 #if EFSYS_OPT_HUNTINGTON && !EFSYS_OPT_MCDI
146 # error "HUNTINGTON requires MCDI"
147 #endif
148 
149 /* Support LM87 monitor */
150 #if EFSYS_OPT_MON_LM87
151 # if !EFSYS_OPT_FALCON
152 #  error "MON_LM87 requires FALCON"
153 # endif
154 #endif /* EFSYS_OPT_MON_LM87 */
155 
156 /* Support MAX6647 monitor */
157 #if EFSYS_OPT_MON_MAX6647
158 # if !EFSYS_OPT_FALCON
159 #  error "MON_MAX6647 requires FALCON"
160 # endif
161 #endif /* EFSYS_OPT_MON_MAX6647 */
162 
163 /* Support null monitor */
164 #if EFSYS_OPT_MON_NULL
165 # if !EFSYS_OPT_FALCON
166 #  error "MON_NULL requires FALCON"
167 # endif
168 #endif /* EFSYS_OPT_MON_NULL */
169 
170 /* Support Siena monitor */
171 #ifdef EFSYS_OPT_MON_SIENA
172 #  error "MON_SIENA is obsolete use MON_MCDI"
173 #endif /* EFSYS_OPT_MON_SIENA*/
174 
175 /* Support Huntington monitor */
176 #ifdef EFSYS_OPT_MON_HUNTINGTON
177 #  error "MON_HUNTINGTON is obsolete use MON_MCDI"
178 #endif /* EFSYS_OPT_MON_HUNTINGTON*/
179 
180 /* Support monitor statistics (voltage/temperature) */
181 #if EFSYS_OPT_MON_STATS
182 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
183 #  error "MON_STATS requires FALCON or SIENA or HUNTINGTON"
184 # endif
185 #endif /* EFSYS_OPT_MON_STATS */
186 
187 /* Support Monitor via mcdi */
188 #if EFSYS_OPT_MON_MCDI
189 # if !(EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
190 #  error "MON_MCDI requires SIENA or HUNTINGTON"
191 # endif
192 #endif /* EFSYS_OPT_MON_MCDI*/
193 
194 /* Support printable names for statistics */
195 #if EFSYS_OPT_NAMES
196 # if !(EFSYS_OPT_LOOPBACK || EFSYS_OPT_MAC_STATS || EFSYS_OPT_MCDI || \
197 	EFSYS_MON_STATS || EFSYS_OPT_PHY_PROPS || EFSYS_OPT_PHY_STATS || \
198 	EFSYS_OPT_QSTATS)
199 #  error "NAMES requires LOOPBACK or xxxSTATS or MCDI or PHY_PROPS"
200 # endif
201 #endif /* EFSYS_OPT_NAMES */
202 
203 /* Support non volatile configuration */
204 #if EFSYS_OPT_NVRAM
205 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
206 #  error "NVRAM requires FALCON or SIENA or HUNTINGTON"
207 # endif
208 #endif /* EFSYS_OPT_NVRAM */
209 
210 /* Support Falcon bootrom */
211 #if EFSYS_OPT_NVRAM_FALCON_BOOTROM
212 # if !EFSYS_OPT_NVRAM
213 #  error "NVRAM_FALCON_BOOTROM requires NVRAM"
214 # endif
215 # if !EFSYS_OPT_FALCON
216 #  error "NVRAM_FALCON_BOOTROM requires FALCON"
217 # endif
218 #endif /* EFSYS_OPT_NVRAM_FALCON_BOOTROM */
219 
220 /* Support NVRAM config for SFT9001 */
221 #if EFSYS_OPT_NVRAM_SFT9001
222 # if !EFSYS_OPT_NVRAM
223 #  error "NVRAM_SFT9001 requires NVRAM"
224 # endif
225 # if !EFSYS_OPT_FALCON
226 #  error "NVRAM_SFT9001 requires FALCON"
227 # endif
228 #endif /* EFSYS_OPT_NVRAM_SFT9001 */
229 
230 /* Support NVRAM config for SFX7101 */
231 #if EFSYS_OPT_NVRAM_SFX7101
232 # if !EFSYS_OPT_NVRAM
233 #  error "NVRAM_SFX7101 requires NVRAM"
234 # endif
235 # if !EFSYS_OPT_FALCON
236 #  error "NVRAM_SFX7101 requires FALCON"
237 # endif
238 #endif /* EFSYS_OPT_NVRAM_SFX7101 */
239 
240 /* Support PCIe interface tuning */
241 #if EFSYS_OPT_PCIE_TUNE
242 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
243 #  error "PCIE_TUNE requires FALCON or SIENA"
244 # endif
245 #endif /* EFSYS_OPT_PCIE_TUNE */
246 
247 /* Support PHY BIST diagnostics */
248 #if EFSYS_OPT_PHY_BIST
249 #  error "PHY_BIST is obsolete. It has been replaced by the BIST option."
250 #endif /* EFSYS_OPT_PHY_BIST */
251 
252 /* Support PHY flags */
253 #if EFSYS_OPT_PHY_FLAGS
254 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
255 #  error "PHY_FLAGS requires FALCON or SIENA"
256 # endif
257 #endif /* EFSYS_OPT_PHY_FLAGS */
258 
259 /* Support for PHY LED control */
260 #if EFSYS_OPT_PHY_LED_CONTROL
261 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
262 #  error "PHY_LED_CONTROL requires FALCON or SIENA"
263 # endif
264 #endif /* EFSYS_OPT_PHY_LED_CONTROL */
265 
266 /* Support NULL PHY */
267 #if EFSYS_OPT_PHY_NULL
268 # if !EFSYS_OPT_FALCON
269 #  error "PHY_NULL requires FALCON"
270 # endif
271 #endif /* EFSYS_OPT_PHY_NULL */
272 
273 /* Obsolete option */
274 #ifdef EFSYS_OPT_PHY_PM8358
275 # error "EFSYS_OPT_PHY_PM8358 is obsolete and is not supported."
276 #endif
277 
278 /* Support PHY properties */
279 #if EFSYS_OPT_PHY_PROPS
280 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
281 #  error "PHY_PROPS requires FALCON or SIENA"
282 # endif
283 #endif /* EFSYS_OPT_PHY_PROPS */
284 
285 /* Support QT2022C2 PHY */
286 #if EFSYS_OPT_PHY_QT2022C2
287 # if !EFSYS_OPT_FALCON
288 #  error "PHY_QT2022C2 requires FALCON"
289 # endif
290 #endif /* EFSYS_OPT_PHY_QT2022C2 */
291 
292 /* Support QT2025C PHY (Wakefield NIC) */
293 #if EFSYS_OPT_PHY_QT2025C
294 # if !EFSYS_OPT_FALCON
295 #  error "PHY_QT2025C requires FALCON"
296 # endif
297 #endif /* EFSYS_OPT_PHY_QT2025C */
298 
299 /* Support SFT9001 PHY (Starbolt NIC) */
300 #if EFSYS_OPT_PHY_SFT9001
301 # if !EFSYS_OPT_FALCON
302 #  error "PHY_SFT9001 requires FALCON"
303 # endif
304 #endif /* EFSYS_OPT_PHY_SFT9001 */
305 
306 /* Support SFX7101 PHY (SFE4001 NIC) */
307 #if EFSYS_OPT_PHY_SFX7101
308 # if !EFSYS_OPT_FALCON
309 #  error "PHY_SFX7101 requires FALCON"
310 # endif
311 #endif /* EFSYS_OPT_PHY_SFX7101 */
312 
313 /* Support PHY statistics */
314 #if EFSYS_OPT_PHY_STATS
315 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA)
316 #  error "PHY_STATS requires FALCON or SIENA"
317 # endif
318 #endif /* EFSYS_OPT_PHY_STATS */
319 
320 /* Support TXC43128 PHY (SFE4003 NIC) */
321 #if EFSYS_OPT_PHY_TXC43128
322 # if !EFSYS_OPT_FALCON
323 #  error "PHY_TXC43128 requires FALCON"
324 # endif
325 #endif /* EFSYS_OPT_PHY_TXC43128 */
326 
327 /* Support EVQ/RXQ/TXQ statistics */
328 #if EFSYS_OPT_QSTATS
329 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
330 #  error "QSTATS requires FALCON or SIENA or HUNTINGTON"
331 # endif
332 #endif /* EFSYS_OPT_QSTATS */
333 
334 /* Support receive header split */
335 #if EFSYS_OPT_RX_HDR_SPLIT
336 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
337 #  error "RX_HDR_SPLIT requires FALCON or SIENA or HUNTINGTON"
338 # endif
339 #endif /* EFSYS_OPT_RX_HDR_SPLIT */
340 
341 /* Support receive scaling (RSS) */
342 #if EFSYS_OPT_RX_SCALE
343 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
344 #  error "RX_SCALE requires FALCON or SIENA or HUNTINGTON"
345 # endif
346 #endif /* EFSYS_OPT_RX_SCALE */
347 
348 /* Support receive scatter DMA */
349 #if EFSYS_OPT_RX_SCATTER
350 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
351 #  error "RX_SCATTER requires FALCON or SIENA or HUNTINGTON"
352 # endif
353 #endif /* EFSYS_OPT_RX_SCATTER */
354 
355 /* Obsolete option */
356 #ifdef EFSYS_OPT_STAT_NAME
357 # error "EFSYS_OPT_STAT_NAME is obsolete (replaced by EFSYS_OPT_NAMES)."
358 #endif
359 
360 /* Support PCI Vital Product Data (VPD) */
361 #if EFSYS_OPT_VPD
362 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
363 #  error "VPD requires FALCON or SIENA or HUNTINGTON"
364 # endif
365 #endif /* EFSYS_OPT_VPD */
366 
367 /* Support Wake on LAN */
368 #if EFSYS_OPT_WOL
369 # if !EFSYS_OPT_SIENA
370 #  error "WOL requires SIENA"
371 # endif
372 #endif /* EFSYS_OPT_WOL */
373 
374 /* Support calculating multicast pktfilter in common code */
375 #if EFSYS_OPT_MCAST_FILTER_LIST
376 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
377 #  error "MCAST_FILTER_LIST requires FALCON or SIENA or HUNTINGTON"
378 # endif
379 #endif /* EFSYS_OPT_MCAST_FILTER_LIST */
380 
381 /* Support BIST */
382 #if EFSYS_OPT_BIST
383 # if !(EFSYS_OPT_FALCON || EFSYS_OPT_SIENA || EFSYS_OPT_HUNTINGTON)
384 #  error "BIST requires FALCON or SIENA or HUNTINGTON"
385 # endif
386 #endif /* EFSYS_OPT_BIST */
387 
388 #endif /* _SYS_EFX_CHECK_H */
389