1/*-
2 * Copyright 2008-2011 Solarflare Communications Inc.  All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * 1. Redistributions of source code must retain the above copyright
8 *    notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 *    notice, this list of conditions and the following disclaimer in the
11 *    documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS AND
14 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23 * SUCH DAMAGE.
24 *
25 * $FreeBSD$
26 */
27
28#ifndef _SIENA_MC_DRIVER_PCOL_H
29#define	_SIENA_MC_DRIVER_PCOL_H
30
31
32/* Values to be written into FMCR_CZ_RESET_STATE_REG to control boot. */
33/* Power-on reset state */
34#define MC_FW_STATE_POR (1)
35/* If this is set in MC_RESET_STATE_REG then it should be
36 * possible to jump into IMEM without loading code from flash. */
37#define MC_FW_WARM_BOOT_OK (2)
38/* The MC main image has started to boot. */
39#define MC_FW_STATE_BOOTING (4)
40/* The Scheduler has started. */
41#define MC_FW_STATE_SCHED (8)
42
43/* Values to be written to the per-port status dword in shared
44 * memory on reboot and assert */
45#define MC_STATUS_DWORD_REBOOT (0xb007b007)
46#define MC_STATUS_DWORD_ASSERT (0xdeaddead)
47
48/* The current version of the MCDI protocol.
49 *
50 * Note that the ROM burnt into the card only talks V0, so at the very
51 * least every driver must support version 0 and MCDI_PCOL_VERSION
52 */
53#ifdef WITH_MCDI_V2
54#define MCDI_PCOL_VERSION 2
55#else
56#define MCDI_PCOL_VERSION 1
57#endif
58
59/* Unused commands: 0x23, 0x27, 0x30, 0x31 */
60
61/* Unused commands: 0x23, 0x27, 0x30, 0x31 */
62
63/**
64 * MCDI version 1
65 *
66 * Each MCDI request starts with an MCDI_HEADER, which is a 32byte
67 * structure, filled in by the client.
68 *
69 *       0       7  8     16    20     22  23  24    31
70 *      | CODE | R | LEN | SEQ | Rsvd | E | R | XFLAGS |
71 *               |                      |   |
72 *               |                      |   \--- Response
73 *               |                      \------- Error
74 *               \------------------------------ Resync (always set)
75 *
76 * The client writes it's request into MC shared memory, and rings the
77 * doorbell. Each request is completed by either by the MC writting
78 * back into shared memory, or by writting out an event.
79 *
80 * All MCDI commands support completion by shared memory response. Each
81 * request may also contain additional data (accounted for by HEADER.LEN),
82 * and some response's may also contain additional data (again, accounted
83 * for by HEADER.LEN).
84 *
85 * Some MCDI commands support completion by event, in which any associated
86 * response data is included in the event.
87 *
88 * The protocol requires one response to be delivered for every request, a
89 * request should not be sent unless the response for the previous request
90 * has been received (either by polling shared memory, or by receiving
91 * an event).
92 */
93
94/** Request/Response structure */
95#define MCDI_HEADER_OFST 0
96#define MCDI_HEADER_CODE_LBN 0
97#define MCDI_HEADER_CODE_WIDTH 7
98#define MCDI_HEADER_RESYNC_LBN 7
99#define MCDI_HEADER_RESYNC_WIDTH 1
100#define MCDI_HEADER_DATALEN_LBN 8
101#define MCDI_HEADER_DATALEN_WIDTH 8
102#define MCDI_HEADER_SEQ_LBN 16
103#define MCDI_HEADER_RSVD_LBN 20
104#define MCDI_HEADER_RSVD_WIDTH 2
105#define MCDI_HEADER_SEQ_WIDTH 4
106#define MCDI_HEADER_ERROR_LBN 22
107#define MCDI_HEADER_ERROR_WIDTH 1
108#define MCDI_HEADER_RESPONSE_LBN 23
109#define MCDI_HEADER_RESPONSE_WIDTH 1
110#define MCDI_HEADER_XFLAGS_LBN 24
111#define MCDI_HEADER_XFLAGS_WIDTH 8
112/* Request response using event */
113#define MCDI_HEADER_XFLAGS_EVREQ 0x01
114
115/* Maximum number of payload bytes */
116#if MCDI_PCOL_VERSION == 1
117#define MCDI_CTL_SDU_LEN_MAX 0xfc
118#elif  MCDI_PCOL_VERSION == 2
119#define MCDI_CTL_SDU_LEN_MAX 0x400
120#endif
121
122/* The MC can generate events for two reasons:
123 *   - To complete a shared memory request if XFLAGS_EVREQ was set
124 *   - As a notification (link state, i2c event), controlled
125 *     via MC_CMD_LOG_CTRL
126 *
127 * Both events share a common structure:
128 *
129 *  0      32     33      36    44     52     60
130 * | Data | Cont | Level | Src | Code | Rsvd |
131 *           |
132 *           \ There is another event pending in this notification
133 *
134 * If Code==CMDDONE, then the fields are further interpreted as:
135 *
136 *   - LEVEL==INFO    Command succeded
137 *   - LEVEL==ERR     Command failed
138 *
139 *    0     8         16      24     32
140 *   | Seq | Datalen | Errno | Rsvd |
141 *
142 *   These fields are taken directly out of the standard MCDI header, i.e.,
143 *   LEVEL==ERR, Datalen == 0 => Reboot
144 *
145 * Events can be squirted out of the UART (using LOG_CTRL) without a
146 * MCDI header.  An event can be distinguished from a MCDI response by
147 * examining the first byte which is 0xc0.  This corresponds to the
148 * non-existent MCDI command MC_CMD_DEBUG_LOG.
149 *
150 *      0         7        8
151 *     | command | Resync |     = 0xc0
152 *
153 * Since the event is written in big-endian byte order, this works
154 * providing bits 56-63 of the event are 0xc0.
155 *
156 *      56     60  63
157 *     | Rsvd | Code |    = 0xc0
158 *
159 * Which means for convenience the event code is 0xc for all MC
160 * generated events.
161 */
162#define FSE_AZ_EV_CODE_MCDI_EVRESPONSE 0xc
163
164
165/* Non-existent command target */
166#define MC_CMD_ERR_ENOENT 2
167/* assert() has killed the MC */
168#define MC_CMD_ERR_EINTR 4
169/* Caller does not hold required locks */
170#define MC_CMD_ERR_EACCES 13
171/* Resource is currently unavailable (e.g. lock contention) */
172#define MC_CMD_ERR_EBUSY 16
173/* Invalid argument to target */
174#define MC_CMD_ERR_EINVAL 22
175/* Non-recursive resource is already acquired */
176#define MC_CMD_ERR_EDEADLK 35
177/* Operation not implemented */
178#define MC_CMD_ERR_ENOSYS 38
179/* Operation timed out */
180#define MC_CMD_ERR_ETIME 62
181
182#define MC_CMD_ERR_CODE_OFST 0
183
184/* We define 8 "escape" commands to allow
185   for command number space extension */
186
187#define MC_CMD_CMD_SPACE_ESCAPE_0	      0x78
188#define MC_CMD_CMD_SPACE_ESCAPE_1	      0x79
189#define MC_CMD_CMD_SPACE_ESCAPE_2	      0x7A
190#define MC_CMD_CMD_SPACE_ESCAPE_3	      0x7B
191#define MC_CMD_CMD_SPACE_ESCAPE_4	      0x7C
192#define MC_CMD_CMD_SPACE_ESCAPE_5	      0x7D
193#define MC_CMD_CMD_SPACE_ESCAPE_6	      0x7E
194#define MC_CMD_CMD_SPACE_ESCAPE_7	      0x7F
195
196/* Vectors in the boot ROM */
197/* Point to the copycode entry point. */
198#define MC_BOOTROM_COPYCODE_VEC (0x7f4)
199/* Points to the recovery mode entry point. */
200#define MC_BOOTROM_NOFLASH_VEC (0x7f8)
201
202/* The command set exported by the boot ROM (MCDI v0) */
203#define MC_CMD_GET_VERSION_V0_SUPPORTED_FUNCS {		\
204	(1 << MC_CMD_READ32)	|			\
205	(1 << MC_CMD_WRITE32)	|			\
206	(1 << MC_CMD_COPYCODE)	|			\
207	(1 << MC_CMD_GET_VERSION),			\
208	0, 0, 0 }
209
210#define MC_CMD_SENSOR_INFO_OUT_OFFSET_OFST(_x) \
211	(MC_CMD_SENSOR_ENTRY_OFST + (_x))
212
213#define MC_CMD_DBI_WRITE_IN_ADDRESS_OFST(n) (  \
214        (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST+     \
215         MC_CMD_DBIWROP_TYPEDEF_ADDRESS_OFST)+ \
216         ((n)*MC_CMD_DBIWROP_TYPEDEF_LEN))
217
218#define MC_CMD_DBI_WRITE_IN_BYTE_MASK_OFST(n) (  \
219        (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST+     \
220         MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_OFST)+ \
221         ((n)*MC_CMD_DBIWROP_TYPEDEF_LEN))
222
223#define MC_CMD_DBI_WRITE_IN_VALUE_OFST(n) (  \
224        (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST+     \
225         MC_CMD_DBIWROP_TYPEDEF_VALUE_OFST)+ \
226         ((n)*MC_CMD_DBIWROP_TYPEDEF_LEN))
227
228
229#ifdef WITH_MCDI_V2
230
231/* Version 2 adds an optional argument to error returns: the errno value
232 * may be followed by the (0-based) number of the first argument that
233 * could not be processed.
234 */
235#define MC_CMD_ERR_ARG_OFST 4
236
237/* Try again */
238#define MC_CMD_ERR_EAGAIN 11
239/* No space */
240#define MC_CMD_ERR_ENOSPC 28
241
242#endif
243
244/* MCDI_EVENT structuredef */
245#define	MCDI_EVENT_LEN 8
246#define	MCDI_EVENT_CONT_LBN 32
247#define	MCDI_EVENT_CONT_WIDTH 1
248#define	MCDI_EVENT_LEVEL_LBN 33
249#define	MCDI_EVENT_LEVEL_WIDTH 3
250#define	MCDI_EVENT_LEVEL_INFO  0x0 /* enum */
251#define	MCDI_EVENT_LEVEL_WARN 0x1 /* enum */
252#define	MCDI_EVENT_LEVEL_ERR 0x2 /* enum */
253#define	MCDI_EVENT_LEVEL_FATAL 0x3 /* enum */
254#define	MCDI_EVENT_DATA_OFST 0
255#define	MCDI_EVENT_CMDDONE_SEQ_LBN 0
256#define	MCDI_EVENT_CMDDONE_SEQ_WIDTH 8
257#define	MCDI_EVENT_CMDDONE_DATALEN_LBN 8
258#define	MCDI_EVENT_CMDDONE_DATALEN_WIDTH 8
259#define	MCDI_EVENT_CMDDONE_ERRNO_LBN 16
260#define	MCDI_EVENT_CMDDONE_ERRNO_WIDTH 8
261#define	MCDI_EVENT_LINKCHANGE_LP_CAP_LBN 0
262#define	MCDI_EVENT_LINKCHANGE_LP_CAP_WIDTH 16
263#define	MCDI_EVENT_LINKCHANGE_SPEED_LBN 16
264#define	MCDI_EVENT_LINKCHANGE_SPEED_WIDTH 4
265#define	MCDI_EVENT_LINKCHANGE_SPEED_100M  0x1 /* enum */
266#define	MCDI_EVENT_LINKCHANGE_SPEED_1G  0x2 /* enum */
267#define	MCDI_EVENT_LINKCHANGE_SPEED_10G  0x3 /* enum */
268#define	MCDI_EVENT_LINKCHANGE_FCNTL_LBN 20
269#define	MCDI_EVENT_LINKCHANGE_FCNTL_WIDTH 4
270#define	MCDI_EVENT_LINKCHANGE_LINK_FLAGS_LBN 24
271#define	MCDI_EVENT_LINKCHANGE_LINK_FLAGS_WIDTH 8
272#define	MCDI_EVENT_SENSOREVT_MONITOR_LBN 0
273#define	MCDI_EVENT_SENSOREVT_MONITOR_WIDTH 8
274#define	MCDI_EVENT_SENSOREVT_STATE_LBN 8
275#define	MCDI_EVENT_SENSOREVT_STATE_WIDTH 8
276#define	MCDI_EVENT_SENSOREVT_VALUE_LBN 16
277#define	MCDI_EVENT_SENSOREVT_VALUE_WIDTH 16
278#define	MCDI_EVENT_FWALERT_DATA_LBN 8
279#define	MCDI_EVENT_FWALERT_DATA_WIDTH 24
280#define	MCDI_EVENT_FWALERT_REASON_LBN 0
281#define	MCDI_EVENT_FWALERT_REASON_WIDTH 8
282#define	MCDI_EVENT_FWALERT_REASON_SRAM_ACCESS 0x1 /* enum */
283#define	MCDI_EVENT_FLR_VF_LBN 0
284#define	MCDI_EVENT_FLR_VF_WIDTH 8
285#define	MCDI_EVENT_TX_ERR_TXQ_LBN 0
286#define	MCDI_EVENT_TX_ERR_TXQ_WIDTH 12
287#define	MCDI_EVENT_TX_ERR_TYPE_LBN 12
288#define	MCDI_EVENT_TX_ERR_TYPE_WIDTH 4
289#define	MCDI_EVENT_TX_ERR_DL_FAIL 0x1 /* enum */
290#define	MCDI_EVENT_TX_ERR_NO_EOP 0x2 /* enum */
291#define	MCDI_EVENT_TX_ERR_2BIG 0x3 /* enum */
292#define	MCDI_EVENT_TX_ERR_INFO_LBN 16
293#define	MCDI_EVENT_TX_ERR_INFO_WIDTH 16
294#define	MCDI_EVENT_TX_FLUSH_TXQ_LBN 0
295#define	MCDI_EVENT_TX_FLUSH_TXQ_WIDTH 12
296#define	MCDI_EVENT_DATA_LBN 0
297#define	MCDI_EVENT_DATA_WIDTH 32
298#define	MCDI_EVENT_SRC_LBN 36
299#define	MCDI_EVENT_SRC_WIDTH 8
300#define	MCDI_EVENT_EV_CODE_LBN 60
301#define	MCDI_EVENT_EV_CODE_WIDTH 4
302#define	MCDI_EVENT_CODE_LBN 44
303#define	MCDI_EVENT_CODE_WIDTH 8
304#define	MCDI_EVENT_CODE_BADSSERT 0x1 /* enum */
305#define	MCDI_EVENT_CODE_PMNOTICE 0x2 /* enum */
306#define	MCDI_EVENT_CODE_CMDDONE 0x3 /* enum */
307#define	MCDI_EVENT_CODE_LINKCHANGE 0x4 /* enum */
308#define	MCDI_EVENT_CODE_SENSOREVT 0x5 /* enum */
309#define	MCDI_EVENT_CODE_SCHEDERR 0x6 /* enum */
310#define	MCDI_EVENT_CODE_REBOOT 0x7 /* enum */
311#define	MCDI_EVENT_CODE_MAC_STATS_DMA 0x8 /* enum */
312#define	MCDI_EVENT_CODE_FWALERT 0x9 /* enum */
313#define	MCDI_EVENT_CODE_FLR 0xa /* enum */
314#define	MCDI_EVENT_CODE_TX_ERR 0xb /* enum */
315#define	MCDI_EVENT_CODE_TX_FLUSH  0xc /* enum */
316#define	MCDI_EVENT_CMDDONE_DATA_OFST 0
317#define	MCDI_EVENT_CMDDONE_DATA_LBN 0
318#define	MCDI_EVENT_CMDDONE_DATA_WIDTH 32
319#define	MCDI_EVENT_LINKCHANGE_DATA_OFST 0
320#define	MCDI_EVENT_LINKCHANGE_DATA_LBN 0
321#define	MCDI_EVENT_LINKCHANGE_DATA_WIDTH 32
322#define	MCDI_EVENT_SENSOREVT_DATA_OFST 0
323#define	MCDI_EVENT_SENSOREVT_DATA_LBN 0
324#define	MCDI_EVENT_SENSOREVT_DATA_WIDTH 32
325#define	MCDI_EVENT_MAC_STATS_DMA_GENERATION_OFST 0
326#define	MCDI_EVENT_MAC_STATS_DMA_GENERATION_LBN 0
327#define	MCDI_EVENT_MAC_STATS_DMA_GENERATION_WIDTH 32
328#define	MCDI_EVENT_TX_ERR_DATA_OFST 0
329#define	MCDI_EVENT_TX_ERR_DATA_LBN 0
330#define	MCDI_EVENT_TX_ERR_DATA_WIDTH 32
331
332
333/***********************************/
334/* MC_CMD_READ32
335 * Read multiple 32byte words from MC memory.
336 */
337#define	MC_CMD_READ32 0x1
338
339/* MC_CMD_READ32_IN msgrequest */
340#define	MC_CMD_READ32_IN_LEN 8
341#define	MC_CMD_READ32_IN_ADDR_OFST 0
342#define	MC_CMD_READ32_IN_NUMWORDS_OFST 4
343
344/* MC_CMD_READ32_OUT msgresponse */
345#define	MC_CMD_READ32_OUT_LENMIN 4
346#define	MC_CMD_READ32_OUT_LENMAX 252
347#define	MC_CMD_READ32_OUT_LEN(num) (0+4*(num))
348#define	MC_CMD_READ32_OUT_BUFFER_OFST 0
349#define	MC_CMD_READ32_OUT_BUFFER_LEN 4
350#define	MC_CMD_READ32_OUT_BUFFER_MINNUM 1
351#define	MC_CMD_READ32_OUT_BUFFER_MAXNUM 63
352
353
354/***********************************/
355/* MC_CMD_WRITE32
356 * Write multiple 32byte words to MC memory.
357 */
358#define	MC_CMD_WRITE32 0x2
359
360/* MC_CMD_WRITE32_IN msgrequest */
361#define	MC_CMD_WRITE32_IN_LENMIN 8
362#define	MC_CMD_WRITE32_IN_LENMAX 252
363#define	MC_CMD_WRITE32_IN_LEN(num) (4+4*(num))
364#define	MC_CMD_WRITE32_IN_ADDR_OFST 0
365#define	MC_CMD_WRITE32_IN_BUFFER_OFST 4
366#define	MC_CMD_WRITE32_IN_BUFFER_LEN 4
367#define	MC_CMD_WRITE32_IN_BUFFER_MINNUM 1
368#define	MC_CMD_WRITE32_IN_BUFFER_MAXNUM 62
369
370/* MC_CMD_WRITE32_OUT msgresponse */
371#define	MC_CMD_WRITE32_OUT_LEN 0
372
373
374/***********************************/
375/* MC_CMD_COPYCODE
376 * Copy MC code between two locations and jump.
377 */
378#define	MC_CMD_COPYCODE 0x3
379
380/* MC_CMD_COPYCODE_IN msgrequest */
381#define	MC_CMD_COPYCODE_IN_LEN 16
382#define	MC_CMD_COPYCODE_IN_SRC_ADDR_OFST 0
383#define	MC_CMD_COPYCODE_IN_DEST_ADDR_OFST 4
384#define	MC_CMD_COPYCODE_IN_NUMWORDS_OFST 8
385#define	MC_CMD_COPYCODE_IN_JUMP_OFST 12
386#define	MC_CMD_COPYCODE_JUMP_NONE 0x1 /* enum */
387
388/* MC_CMD_COPYCODE_OUT msgresponse */
389#define	MC_CMD_COPYCODE_OUT_LEN 0
390
391
392/***********************************/
393/* MC_CMD_SET_FUNC
394 */
395#define	MC_CMD_SET_FUNC  0x4
396
397/* MC_CMD_SET_FUNC_IN msgrequest */
398#define	MC_CMD_SET_FUNC_IN_LEN 4
399#define	MC_CMD_SET_FUNC_IN_FUNC_OFST 0
400
401/* MC_CMD_SET_FUNC_OUT msgresponse */
402#define	MC_CMD_SET_FUNC_OUT_LEN 0
403
404
405/***********************************/
406/* MC_CMD_GET_BOOT_STATUS
407 */
408#define	MC_CMD_GET_BOOT_STATUS 0x5
409
410/* MC_CMD_GET_BOOT_STATUS_IN msgrequest */
411#define	MC_CMD_GET_BOOT_STATUS_IN_LEN 0
412
413/* MC_CMD_GET_BOOT_STATUS_OUT msgresponse */
414#define	MC_CMD_GET_BOOT_STATUS_OUT_LEN 8
415#define	MC_CMD_GET_BOOT_STATUS_OUT_BOOT_OFFSET_OFST 0
416#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_OFST 4
417#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_WATCHDOG_LBN 0
418#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_WATCHDOG_WIDTH 1
419#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_PRIMARY_LBN 1
420#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_PRIMARY_WIDTH 1
421#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_BACKUP_LBN 2
422#define	MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_BACKUP_WIDTH 1
423
424
425/***********************************/
426/* MC_CMD_GET_ASSERTS
427 * Get and clear any assertion status.
428 */
429#define	MC_CMD_GET_ASSERTS  0x6
430
431/* MC_CMD_GET_ASSERTS_IN msgrequest */
432#define	MC_CMD_GET_ASSERTS_IN_LEN 4
433#define	MC_CMD_GET_ASSERTS_IN_CLEAR_OFST 0
434
435/* MC_CMD_GET_ASSERTS_OUT msgresponse */
436#define	MC_CMD_GET_ASSERTS_OUT_LEN 140
437#define	MC_CMD_GET_ASSERTS_OUT_GLOBAL_FLAGS_OFST 0
438#define	MC_CMD_GET_ASSERTS_FLAGS_NO_FAILS 0x1 /* enum */
439#define	MC_CMD_GET_ASSERTS_FLAGS_SYS_FAIL 0x2 /* enum */
440#define	MC_CMD_GET_ASSERTS_FLAGS_THR_FAIL 0x3 /* enum */
441#define	MC_CMD_GET_ASSERTS_FLAGS_WDOG_FIRED 0x4 /* enum */
442#define	MC_CMD_GET_ASSERTS_OUT_SAVED_PC_OFFS_OFST 4
443#define	MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_OFST 8
444#define	MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_LEN 4
445#define	MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_NUM 31
446#define	MC_CMD_GET_ASSERTS_OUT_THREAD_OFFS_OFST 132
447#define	MC_CMD_GET_ASSERTS_OUT_RESERVED_OFST 136
448
449
450/***********************************/
451/* MC_CMD_LOG_CTRL
452 * Configure the output stream for various events and messages.
453 */
454#define	MC_CMD_LOG_CTRL  0x7
455
456/* MC_CMD_LOG_CTRL_IN msgrequest */
457#define	MC_CMD_LOG_CTRL_IN_LEN 8
458#define	MC_CMD_LOG_CTRL_IN_LOG_DEST_OFST 0
459#define	MC_CMD_LOG_CTRL_IN_LOG_DEST_UART 0x1 /* enum */
460#define	MC_CMD_LOG_CTRL_IN_LOG_DEST_EVQ 0x2 /* enum */
461#define	MC_CMD_LOG_CTRL_IN_LOG_DEST_EVQ_OFST 4
462
463/* MC_CMD_LOG_CTRL_OUT msgresponse */
464#define	MC_CMD_LOG_CTRL_OUT_LEN 0
465
466
467/***********************************/
468/* MC_CMD_GET_VERSION
469 * Get version information about the MC firmware.
470 */
471#define	MC_CMD_GET_VERSION  0x8
472
473/* MC_CMD_GET_VERSION_IN msgrequest */
474#define	MC_CMD_GET_VERSION_IN_LEN 0
475
476/* MC_CMD_GET_VERSION_V0_OUT msgresponse */
477#define	MC_CMD_GET_VERSION_V0_OUT_LEN 4
478#define	MC_CMD_GET_VERSION_OUT_FIRMWARE_OFST 0
479#define	MC_CMD_GET_VERSION_OUT_FIRMWARE_ANY 0xffffffff /* enum */
480#define	MC_CMD_GET_VERSION_OUT_FIRMWARE_BOOTROM 0xb0070000 /* enum */
481
482/* MC_CMD_GET_VERSION_OUT msgresponse */
483#define	MC_CMD_GET_VERSION_OUT_LEN 32
484/*            MC_CMD_GET_VERSION_OUT_FIRMWARE_OFST 0 */
485/*            Enum values, see field(s): */
486/*               MC_CMD_GET_VERSION_V0_OUT/MC_CMD_GET_VERSION_OUT_FIRMWARE */
487#define	MC_CMD_GET_VERSION_OUT_PCOL_OFST 4
488#define	MC_CMD_GET_VERSION_OUT_SUPPORTED_FUNCS_OFST 8
489#define	MC_CMD_GET_VERSION_OUT_SUPPORTED_FUNCS_LEN 16
490#define	MC_CMD_GET_VERSION_OUT_VERSION_OFST 24
491#define	MC_CMD_GET_VERSION_OUT_VERSION_LEN 8
492#define	MC_CMD_GET_VERSION_OUT_VERSION_LO_OFST 24
493#define	MC_CMD_GET_VERSION_OUT_VERSION_HI_OFST 28
494
495
496/***********************************/
497/* MC_CMD_CSR_READ32
498 * Read 32bit words from the indirect memory map.
499 */
500#define	MC_CMD_CSR_READ32  0xc
501
502/* MC_CMD_CSR_READ32_IN msgrequest */
503#define	MC_CMD_CSR_READ32_IN_LEN 12
504#define	MC_CMD_CSR_READ32_IN_ADDR_OFST 0
505#define	MC_CMD_CSR_READ32_IN_STEP_OFST 4
506#define	MC_CMD_CSR_READ32_IN_NUMWORDS_OFST 8
507
508/* MC_CMD_CSR_READ32_OUT msgresponse */
509#define	MC_CMD_CSR_READ32_OUT_LENMIN 4
510#define	MC_CMD_CSR_READ32_OUT_LENMAX 252
511#define	MC_CMD_CSR_READ32_OUT_LEN(num) (0+4*(num))
512#define	MC_CMD_CSR_READ32_OUT_BUFFER_OFST 0
513#define	MC_CMD_CSR_READ32_OUT_BUFFER_LEN 4
514#define	MC_CMD_CSR_READ32_OUT_BUFFER_MINNUM 1
515#define	MC_CMD_CSR_READ32_OUT_BUFFER_MAXNUM 63
516
517
518/***********************************/
519/* MC_CMD_CSR_WRITE32
520 * Write 32bit dwords to the indirect memory map.
521 */
522#define	MC_CMD_CSR_WRITE32  0xd
523
524/* MC_CMD_CSR_WRITE32_IN msgrequest */
525#define	MC_CMD_CSR_WRITE32_IN_LENMIN 12
526#define	MC_CMD_CSR_WRITE32_IN_LENMAX 252
527#define	MC_CMD_CSR_WRITE32_IN_LEN(num) (8+4*(num))
528#define	MC_CMD_CSR_WRITE32_IN_ADDR_OFST 0
529#define	MC_CMD_CSR_WRITE32_IN_STEP_OFST 4
530#define	MC_CMD_CSR_WRITE32_IN_BUFFER_OFST 8
531#define	MC_CMD_CSR_WRITE32_IN_BUFFER_LEN 4
532#define	MC_CMD_CSR_WRITE32_IN_BUFFER_MINNUM 1
533#define	MC_CMD_CSR_WRITE32_IN_BUFFER_MAXNUM 61
534
535/* MC_CMD_CSR_WRITE32_OUT msgresponse */
536#define	MC_CMD_CSR_WRITE32_OUT_LEN 4
537#define	MC_CMD_CSR_WRITE32_OUT_STATUS_OFST 0
538
539
540/***********************************/
541/* MC_CMD_STACKINFO
542 * Get stack information.
543 */
544#define	MC_CMD_STACKINFO  0xf
545
546/* MC_CMD_STACKINFO_IN msgrequest */
547#define	MC_CMD_STACKINFO_IN_LEN 0
548
549/* MC_CMD_STACKINFO_OUT msgresponse */
550#define	MC_CMD_STACKINFO_OUT_LENMIN 12
551#define	MC_CMD_STACKINFO_OUT_LENMAX 252
552#define	MC_CMD_STACKINFO_OUT_LEN(num) (0+12*(num))
553#define	MC_CMD_STACKINFO_OUT_THREAD_INFO_OFST 0
554#define	MC_CMD_STACKINFO_OUT_THREAD_INFO_LEN 12
555#define	MC_CMD_STACKINFO_OUT_THREAD_INFO_MINNUM 1
556#define	MC_CMD_STACKINFO_OUT_THREAD_INFO_MAXNUM 21
557
558
559/***********************************/
560/* MC_CMD_MDIO_READ
561 * MDIO register read.
562 */
563#define	MC_CMD_MDIO_READ  0x10
564
565/* MC_CMD_MDIO_READ_IN msgrequest */
566#define	MC_CMD_MDIO_READ_IN_LEN 16
567#define	MC_CMD_MDIO_READ_IN_BUS_OFST 0
568#define	MC_CMD_MDIO_BUS_INTERNAL 0x0 /* enum */
569#define	MC_CMD_MDIO_BUS_EXTERNAL 0x1 /* enum */
570#define	MC_CMD_MDIO_READ_IN_PRTAD_OFST 4
571#define	MC_CMD_MDIO_READ_IN_DEVAD_OFST 8
572#define	MC_CMD_MDIO_CLAUSE22 0x20 /* enum */
573#define	MC_CMD_MDIO_READ_IN_ADDR_OFST 12
574
575/* MC_CMD_MDIO_READ_OUT msgresponse */
576#define	MC_CMD_MDIO_READ_OUT_LEN 8
577#define	MC_CMD_MDIO_READ_OUT_VALUE_OFST 0
578#define	MC_CMD_MDIO_READ_OUT_STATUS_OFST 4
579#define	MC_CMD_MDIO_STATUS_GOOD 0x8 /* enum */
580
581
582/***********************************/
583/* MC_CMD_MDIO_WRITE
584 * MDIO register write.
585 */
586#define	MC_CMD_MDIO_WRITE  0x11
587
588/* MC_CMD_MDIO_WRITE_IN msgrequest */
589#define	MC_CMD_MDIO_WRITE_IN_LEN 20
590#define	MC_CMD_MDIO_WRITE_IN_BUS_OFST 0
591/*               MC_CMD_MDIO_BUS_INTERNAL 0x0 */
592/*               MC_CMD_MDIO_BUS_EXTERNAL 0x1 */
593#define	MC_CMD_MDIO_WRITE_IN_PRTAD_OFST 4
594#define	MC_CMD_MDIO_WRITE_IN_DEVAD_OFST 8
595/*               MC_CMD_MDIO_CLAUSE22 0x20 */
596#define	MC_CMD_MDIO_WRITE_IN_ADDR_OFST 12
597#define	MC_CMD_MDIO_WRITE_IN_VALUE_OFST 16
598
599/* MC_CMD_MDIO_WRITE_OUT msgresponse */
600#define	MC_CMD_MDIO_WRITE_OUT_LEN 4
601#define	MC_CMD_MDIO_WRITE_OUT_STATUS_OFST 0
602/*               MC_CMD_MDIO_STATUS_GOOD 0x8 */
603
604
605/***********************************/
606/* MC_CMD_DBI_WRITE
607 * Write DBI register(s).
608 */
609#define	MC_CMD_DBI_WRITE  0x12
610
611/* MC_CMD_DBI_WRITE_IN msgrequest */
612#define	MC_CMD_DBI_WRITE_IN_LENMIN 12
613#define	MC_CMD_DBI_WRITE_IN_LENMAX 252
614#define	MC_CMD_DBI_WRITE_IN_LEN(num) (0+12*(num))
615#define	MC_CMD_DBI_WRITE_IN_DBIWROP_OFST 0
616#define	MC_CMD_DBI_WRITE_IN_DBIWROP_LEN 12
617#define	MC_CMD_DBI_WRITE_IN_DBIWROP_MINNUM 1
618#define	MC_CMD_DBI_WRITE_IN_DBIWROP_MAXNUM 21
619
620/* MC_CMD_DBI_WRITE_OUT msgresponse */
621#define	MC_CMD_DBI_WRITE_OUT_LEN 0
622
623/* MC_CMD_DBIWROP_TYPEDEF structuredef */
624#define	MC_CMD_DBIWROP_TYPEDEF_LEN 12
625#define	MC_CMD_DBIWROP_TYPEDEF_ADDRESS_OFST 0
626#define	MC_CMD_DBIWROP_TYPEDEF_ADDRESS_LBN 0
627#define	MC_CMD_DBIWROP_TYPEDEF_ADDRESS_WIDTH 32
628#define	MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_OFST 4
629#define	MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_LBN 32
630#define	MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_WIDTH 32
631#define	MC_CMD_DBIWROP_TYPEDEF_VALUE_OFST 8
632#define	MC_CMD_DBIWROP_TYPEDEF_VALUE_LBN 64
633#define	MC_CMD_DBIWROP_TYPEDEF_VALUE_WIDTH 32
634
635
636/***********************************/
637/* MC_CMD_PORT_READ32
638 * Read a 32-bit register from the indirect port register map.
639 */
640#define	MC_CMD_PORT_READ32  0x14
641
642/* MC_CMD_PORT_READ32_IN msgrequest */
643#define	MC_CMD_PORT_READ32_IN_LEN 4
644#define	MC_CMD_PORT_READ32_IN_ADDR_OFST 0
645
646/* MC_CMD_PORT_READ32_OUT msgresponse */
647#define	MC_CMD_PORT_READ32_OUT_LEN 8
648#define	MC_CMD_PORT_READ32_OUT_VALUE_OFST 0
649#define	MC_CMD_PORT_READ32_OUT_STATUS_OFST 4
650
651
652/***********************************/
653/* MC_CMD_PORT_WRITE32
654 * Write a 32-bit register to the indirect port register map.
655 */
656#define	MC_CMD_PORT_WRITE32  0x15
657
658/* MC_CMD_PORT_WRITE32_IN msgrequest */
659#define	MC_CMD_PORT_WRITE32_IN_LEN 8
660#define	MC_CMD_PORT_WRITE32_IN_ADDR_OFST 0
661#define	MC_CMD_PORT_WRITE32_IN_VALUE_OFST 4
662
663/* MC_CMD_PORT_WRITE32_OUT msgresponse */
664#define	MC_CMD_PORT_WRITE32_OUT_LEN 4
665#define	MC_CMD_PORT_WRITE32_OUT_STATUS_OFST 0
666
667
668/***********************************/
669/* MC_CMD_PORT_READ128
670 * Read a 128-bit register from the indirect port register map.
671 */
672#define	MC_CMD_PORT_READ128  0x16
673
674/* MC_CMD_PORT_READ128_IN msgrequest */
675#define	MC_CMD_PORT_READ128_IN_LEN 4
676#define	MC_CMD_PORT_READ128_IN_ADDR_OFST 0
677
678/* MC_CMD_PORT_READ128_OUT msgresponse */
679#define	MC_CMD_PORT_READ128_OUT_LEN 20
680#define	MC_CMD_PORT_READ128_OUT_VALUE_OFST 0
681#define	MC_CMD_PORT_READ128_OUT_VALUE_LEN 16
682#define	MC_CMD_PORT_READ128_OUT_STATUS_OFST 16
683
684
685/***********************************/
686/* MC_CMD_PORT_WRITE128
687 * Write a 128-bit register to the indirect port register map.
688 */
689#define	MC_CMD_PORT_WRITE128  0x17
690
691/* MC_CMD_PORT_WRITE128_IN msgrequest */
692#define	MC_CMD_PORT_WRITE128_IN_LEN 20
693#define	MC_CMD_PORT_WRITE128_IN_ADDR_OFST 0
694#define	MC_CMD_PORT_WRITE128_IN_VALUE_OFST 4
695#define	MC_CMD_PORT_WRITE128_IN_VALUE_LEN 16
696
697/* MC_CMD_PORT_WRITE128_OUT msgresponse */
698#define	MC_CMD_PORT_WRITE128_OUT_LEN 4
699#define	MC_CMD_PORT_WRITE128_OUT_STATUS_OFST 0
700
701
702/***********************************/
703/* MC_CMD_GET_BOARD_CFG
704 * Returns the MC firmware configuration structure.
705 */
706#define	MC_CMD_GET_BOARD_CFG  0x18
707
708/* MC_CMD_GET_BOARD_CFG_IN msgrequest */
709#define	MC_CMD_GET_BOARD_CFG_IN_LEN 0
710
711/* MC_CMD_GET_BOARD_CFG_OUT msgresponse */
712#define	MC_CMD_GET_BOARD_CFG_OUT_LEN 96
713#define	MC_CMD_GET_BOARD_CFG_OUT_BOARD_TYPE_OFST 0
714#define	MC_CMD_GET_BOARD_CFG_OUT_BOARD_NAME_OFST 4
715#define	MC_CMD_GET_BOARD_CFG_OUT_BOARD_NAME_LEN 32
716#define	MC_CMD_GET_BOARD_CFG_OUT_CAPABILITIES_PORT0_OFST 36
717#define	MC_CMD_CAPABILITIES_SMALL_BUF_TBL_LBN 0x0 /* enum */
718#define	MC_CMD_CAPABILITIES_SMALL_BUF_TBL_WIDTH 0x1 /* enum */
719#define	MC_CMD_GET_BOARD_CFG_OUT_CAPABILITIES_PORT1_OFST 40
720/*            Enum values, see field(s): */
721/*               CAPABILITIES_PORT0 */
722#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT0_OFST 44
723#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT0_LEN 6
724#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT1_OFST 50
725#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT1_LEN 6
726#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_COUNT_PORT0_OFST 56
727#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_COUNT_PORT1_OFST 60
728#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_STRIDE_PORT0_OFST 64
729#define	MC_CMD_GET_BOARD_CFG_OUT_MAC_STRIDE_PORT1_OFST 68
730#define	MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_OFST 72
731#define	MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_LEN 2
732#define	MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_NUM 12
733
734
735/***********************************/
736/* MC_CMD_DBI_READX
737 * Read DBI register(s).
738 */
739#define	MC_CMD_DBI_READX  0x19
740
741/* MC_CMD_DBI_READX_IN msgrequest */
742#define	MC_CMD_DBI_READX_IN_LENMIN 8
743#define	MC_CMD_DBI_READX_IN_LENMAX 248
744#define	MC_CMD_DBI_READX_IN_LEN(num) (0+8*(num))
745#define	MC_CMD_DBI_READX_IN_DBIRDOP_OFST 0
746#define	MC_CMD_DBI_READX_IN_DBIRDOP_LEN 8
747#define	MC_CMD_DBI_READX_IN_DBIRDOP_LO_OFST 0
748#define	MC_CMD_DBI_READX_IN_DBIRDOP_HI_OFST 4
749#define	MC_CMD_DBI_READX_IN_DBIRDOP_MINNUM 1
750#define	MC_CMD_DBI_READX_IN_DBIRDOP_MAXNUM 31
751
752/* MC_CMD_DBI_READX_OUT msgresponse */
753#define	MC_CMD_DBI_READX_OUT_LENMIN 4
754#define	MC_CMD_DBI_READX_OUT_LENMAX 252
755#define	MC_CMD_DBI_READX_OUT_LEN(num) (0+4*(num))
756#define	MC_CMD_DBI_READX_OUT_VALUE_OFST 0
757#define	MC_CMD_DBI_READX_OUT_VALUE_LEN 4
758#define	MC_CMD_DBI_READX_OUT_VALUE_MINNUM 1
759#define	MC_CMD_DBI_READX_OUT_VALUE_MAXNUM 63
760
761
762/***********************************/
763/* MC_CMD_SET_RAND_SEED
764 * Set the 16byte seed for the MC psuedo-random generator.
765 */
766#define	MC_CMD_SET_RAND_SEED  0x1a
767
768/* MC_CMD_SET_RAND_SEED_IN msgrequest */
769#define	MC_CMD_SET_RAND_SEED_IN_LEN 16
770#define	MC_CMD_SET_RAND_SEED_IN_SEED_OFST 0
771#define	MC_CMD_SET_RAND_SEED_IN_SEED_LEN 16
772
773/* MC_CMD_SET_RAND_SEED_OUT msgresponse */
774#define	MC_CMD_SET_RAND_SEED_OUT_LEN 0
775
776
777/***********************************/
778/* MC_CMD_LTSSM_HIST
779 * Retrieve the history of the PCIE LTSSM.
780 */
781#define	MC_CMD_LTSSM_HIST  0x1b
782
783/* MC_CMD_LTSSM_HIST_IN msgrequest */
784#define	MC_CMD_LTSSM_HIST_IN_LEN 0
785
786/* MC_CMD_LTSSM_HIST_OUT msgresponse */
787#define	MC_CMD_LTSSM_HIST_OUT_LENMIN 0
788#define	MC_CMD_LTSSM_HIST_OUT_LENMAX 252
789#define	MC_CMD_LTSSM_HIST_OUT_LEN(num) (0+4*(num))
790#define	MC_CMD_LTSSM_HIST_OUT_DATA_OFST 0
791#define	MC_CMD_LTSSM_HIST_OUT_DATA_LEN 4
792#define	MC_CMD_LTSSM_HIST_OUT_DATA_MINNUM 0
793#define	MC_CMD_LTSSM_HIST_OUT_DATA_MAXNUM 63
794
795
796/***********************************/
797/* MC_CMD_DRV_ATTACH
798 * Inform MCPU that this port is managed on the host.
799 */
800#define	MC_CMD_DRV_ATTACH  0x1c
801
802/* MC_CMD_DRV_ATTACH_IN msgrequest */
803#define	MC_CMD_DRV_ATTACH_IN_LEN 8
804#define	MC_CMD_DRV_ATTACH_IN_NEW_STATE_OFST 0
805#define	MC_CMD_DRV_ATTACH_IN_UPDATE_OFST 4
806
807/* MC_CMD_DRV_ATTACH_OUT msgresponse */
808#define	MC_CMD_DRV_ATTACH_OUT_LEN 4
809#define	MC_CMD_DRV_ATTACH_OUT_OLD_STATE_OFST 0
810
811
812/***********************************/
813/* MC_CMD_NCSI_PROD
814 * Trigger an NC-SI event.
815 */
816#define	MC_CMD_NCSI_PROD  0x1d
817
818/* MC_CMD_NCSI_PROD_IN msgrequest */
819#define	MC_CMD_NCSI_PROD_IN_LEN 4
820#define	MC_CMD_NCSI_PROD_IN_EVENTS_OFST 0
821#define	MC_CMD_NCSI_PROD_LINKCHANGE 0x0 /* enum */
822#define	MC_CMD_NCSI_PROD_RESET 0x1 /* enum */
823#define	MC_CMD_NCSI_PROD_DRVATTACH 0x2 /* enum */
824#define	MC_CMD_NCSI_PROD_IN_LINKCHANGE_LBN 0
825#define	MC_CMD_NCSI_PROD_IN_LINKCHANGE_WIDTH 1
826#define	MC_CMD_NCSI_PROD_IN_RESET_LBN 1
827#define	MC_CMD_NCSI_PROD_IN_RESET_WIDTH 1
828#define	MC_CMD_NCSI_PROD_IN_DRVATTACH_LBN 2
829#define	MC_CMD_NCSI_PROD_IN_DRVATTACH_WIDTH 1
830
831/* MC_CMD_NCSI_PROD_OUT msgresponse */
832#define	MC_CMD_NCSI_PROD_OUT_LEN 0
833
834
835/***********************************/
836/* MC_CMD_SHMUART
837 * Route UART output to circular buffer in shared memory instead.
838 */
839#define	MC_CMD_SHMUART  0x1f
840
841/* MC_CMD_SHMUART_IN msgrequest */
842#define	MC_CMD_SHMUART_IN_LEN 4
843#define	MC_CMD_SHMUART_IN_FLAG_OFST 0
844
845/* MC_CMD_SHMUART_OUT msgresponse */
846#define	MC_CMD_SHMUART_OUT_LEN 0
847
848
849/***********************************/
850/* MC_CMD_PORT_RESET
851 * Generic per-port reset.
852 */
853#define	MC_CMD_PORT_RESET  0x20
854
855/* MC_CMD_PORT_RESET_IN msgrequest */
856#define	MC_CMD_PORT_RESET_IN_LEN 0
857
858/* MC_CMD_PORT_RESET_OUT msgresponse */
859#define	MC_CMD_PORT_RESET_OUT_LEN 0
860
861
862/***********************************/
863/* MC_CMD_PCIE_CREDITS
864 * Read instantaneous and minimum flow control thresholds.
865 */
866#define	MC_CMD_PCIE_CREDITS  0x21
867
868/* MC_CMD_PCIE_CREDITS_IN msgrequest */
869#define	MC_CMD_PCIE_CREDITS_IN_LEN 8
870#define	MC_CMD_PCIE_CREDITS_IN_POLL_PERIOD_OFST 0
871#define	MC_CMD_PCIE_CREDITS_IN_WIPE_OFST 4
872
873/* MC_CMD_PCIE_CREDITS_OUT msgresponse */
874#define	MC_CMD_PCIE_CREDITS_OUT_LEN 16
875#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_HDR_OFST 0
876#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_HDR_LEN 2
877#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_DATA_OFST 2
878#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_DATA_LEN 2
879#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_HDR_OFST 4
880#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_HDR_LEN 2
881#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_DATA_OFST 6
882#define	MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_DATA_LEN 2
883#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_HDR_OFST 8
884#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_HDR_LEN 2
885#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_DATA_OFST 10
886#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_DATA_LEN 2
887#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_HDR_OFST 12
888#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_HDR_LEN 2
889#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_DATA_OFST 14
890#define	MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_DATA_LEN 2
891
892
893/***********************************/
894/* MC_CMD_RXD_MONITOR
895 * Get histogram of RX queue fill level.
896 */
897#define	MC_CMD_RXD_MONITOR  0x22
898
899/* MC_CMD_RXD_MONITOR_IN msgrequest */
900#define	MC_CMD_RXD_MONITOR_IN_LEN 12
901#define	MC_CMD_RXD_MONITOR_IN_QID_OFST 0
902#define	MC_CMD_RXD_MONITOR_IN_POLL_PERIOD_OFST 4
903#define	MC_CMD_RXD_MONITOR_IN_WIPE_OFST 8
904
905/* MC_CMD_RXD_MONITOR_OUT msgresponse */
906#define	MC_CMD_RXD_MONITOR_OUT_LEN 80
907#define	MC_CMD_RXD_MONITOR_OUT_QID_OFST 0
908#define	MC_CMD_RXD_MONITOR_OUT_RING_FILL_OFST 4
909#define	MC_CMD_RXD_MONITOR_OUT_CACHE_FILL_OFST 8
910#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_1_OFST 12
911#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_2_OFST 16
912#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_4_OFST 20
913#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_8_OFST 24
914#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_16_OFST 28
915#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_32_OFST 32
916#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_64_OFST 36
917#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_128_OFST 40
918#define	MC_CMD_RXD_MONITOR_OUT_RING_LT_256_OFST 44
919#define	MC_CMD_RXD_MONITOR_OUT_RING_GE_256_OFST 48
920#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_1_OFST 52
921#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_2_OFST 56
922#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_4_OFST 60
923#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_8_OFST 64
924#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_16_OFST 68
925#define	MC_CMD_RXD_MONITOR_OUT_CACHE_LT_32_OFST 72
926#define	MC_CMD_RXD_MONITOR_OUT_CACHE_GE_32_OFST 76
927
928
929/***********************************/
930/* MC_CMD_PUTS
931 * puts(3) implementation over MCDI
932 */
933#define	MC_CMD_PUTS  0x23
934
935/* MC_CMD_PUTS_IN msgrequest */
936#define	MC_CMD_PUTS_IN_LENMIN 13
937#define	MC_CMD_PUTS_IN_LENMAX 255
938#define	MC_CMD_PUTS_IN_LEN(num) (12+1*(num))
939#define	MC_CMD_PUTS_IN_DEST_OFST 0
940#define	MC_CMD_PUTS_IN_UART_LBN 0
941#define	MC_CMD_PUTS_IN_UART_WIDTH 1
942#define	MC_CMD_PUTS_IN_PORT_LBN 1
943#define	MC_CMD_PUTS_IN_PORT_WIDTH 1
944#define	MC_CMD_PUTS_IN_DHOST_OFST 4
945#define	MC_CMD_PUTS_IN_DHOST_LEN 6
946#define	MC_CMD_PUTS_IN_STRING_OFST 12
947#define	MC_CMD_PUTS_IN_STRING_LEN 1
948#define	MC_CMD_PUTS_IN_STRING_MINNUM 1
949#define	MC_CMD_PUTS_IN_STRING_MAXNUM 243
950
951/* MC_CMD_PUTS_OUT msgresponse */
952#define	MC_CMD_PUTS_OUT_LEN 0
953
954
955/***********************************/
956/* MC_CMD_GET_PHY_CFG
957 * Report PHY configuration.
958 */
959#define	MC_CMD_GET_PHY_CFG  0x24
960
961/* MC_CMD_GET_PHY_CFG_IN msgrequest */
962#define	MC_CMD_GET_PHY_CFG_IN_LEN 0
963
964/* MC_CMD_GET_PHY_CFG_OUT msgresponse */
965#define	MC_CMD_GET_PHY_CFG_OUT_LEN 72
966#define	MC_CMD_GET_PHY_CFG_OUT_FLAGS_OFST 0
967#define	MC_CMD_GET_PHY_CFG_OUT_PRESENT_LBN 0
968#define	MC_CMD_GET_PHY_CFG_OUT_PRESENT_WIDTH 1
969#define	MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_SHORT_LBN 1
970#define	MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_SHORT_WIDTH 1
971#define	MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_LONG_LBN 2
972#define	MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_LONG_WIDTH 1
973#define	MC_CMD_GET_PHY_CFG_OUT_LOWPOWER_LBN 3
974#define	MC_CMD_GET_PHY_CFG_OUT_LOWPOWER_WIDTH 1
975#define	MC_CMD_GET_PHY_CFG_OUT_POWEROFF_LBN 4
976#define	MC_CMD_GET_PHY_CFG_OUT_POWEROFF_WIDTH 1
977#define	MC_CMD_GET_PHY_CFG_OUT_TXDIS_LBN 5
978#define	MC_CMD_GET_PHY_CFG_OUT_TXDIS_WIDTH 1
979#define	MC_CMD_GET_PHY_CFG_OUT_BIST_LBN 6
980#define	MC_CMD_GET_PHY_CFG_OUT_BIST_WIDTH 1
981#define	MC_CMD_GET_PHY_CFG_OUT_TYPE_OFST 4
982#define	MC_CMD_GET_PHY_CFG_OUT_SUPPORTED_CAP_OFST 8
983#define	MC_CMD_PHY_CAP_10HDX_LBN 1
984#define	MC_CMD_PHY_CAP_10HDX_WIDTH 1
985#define	MC_CMD_PHY_CAP_10FDX_LBN 2
986#define	MC_CMD_PHY_CAP_10FDX_WIDTH 1
987#define	MC_CMD_PHY_CAP_100HDX_LBN 3
988#define	MC_CMD_PHY_CAP_100HDX_WIDTH 1
989#define	MC_CMD_PHY_CAP_100FDX_LBN 4
990#define	MC_CMD_PHY_CAP_100FDX_WIDTH 1
991#define	MC_CMD_PHY_CAP_1000HDX_LBN 5
992#define	MC_CMD_PHY_CAP_1000HDX_WIDTH 1
993#define	MC_CMD_PHY_CAP_1000FDX_LBN 6
994#define	MC_CMD_PHY_CAP_1000FDX_WIDTH 1
995#define	MC_CMD_PHY_CAP_10000FDX_LBN 7
996#define	MC_CMD_PHY_CAP_10000FDX_WIDTH 1
997#define	MC_CMD_PHY_CAP_PAUSE_LBN 8
998#define	MC_CMD_PHY_CAP_PAUSE_WIDTH 1
999#define	MC_CMD_PHY_CAP_ASYM_LBN 9
1000#define	MC_CMD_PHY_CAP_ASYM_WIDTH 1
1001#define	MC_CMD_PHY_CAP_AN_LBN 10
1002#define	MC_CMD_PHY_CAP_AN_WIDTH 1
1003#define	MC_CMD_GET_PHY_CFG_OUT_CHANNEL_OFST 12
1004#define	MC_CMD_GET_PHY_CFG_OUT_PRT_OFST 16
1005#define	MC_CMD_GET_PHY_CFG_OUT_STATS_MASK_OFST 20
1006#define	MC_CMD_GET_PHY_CFG_OUT_NAME_OFST 24
1007#define	MC_CMD_GET_PHY_CFG_OUT_NAME_LEN 20
1008#define	MC_CMD_GET_PHY_CFG_OUT_MEDIA_TYPE_OFST 44
1009#define	MC_CMD_MEDIA_XAUI 0x1 /* enum */
1010#define	MC_CMD_MEDIA_CX4 0x2 /* enum */
1011#define	MC_CMD_MEDIA_KX4 0x3 /* enum */
1012#define	MC_CMD_MEDIA_XFP 0x4 /* enum */
1013#define	MC_CMD_MEDIA_SFP_PLUS 0x5 /* enum */
1014#define	MC_CMD_MEDIA_BASE_T 0x6 /* enum */
1015#define	MC_CMD_GET_PHY_CFG_OUT_MMD_MASK_OFST 48
1016#define	MC_CMD_MMD_CLAUSE22 0x0 /* enum */
1017#define	MC_CMD_MMD_CLAUSE45_PMAPMD 0x1 /* enum */
1018#define	MC_CMD_MMD_CLAUSE45_WIS 0x2 /* enum */
1019#define	MC_CMD_MMD_CLAUSE45_PCS 0x3 /* enum */
1020#define	MC_CMD_MMD_CLAUSE45_PHYXS 0x4 /* enum */
1021#define	MC_CMD_MMD_CLAUSE45_DTEXS 0x5 /* enum */
1022#define	MC_CMD_MMD_CLAUSE45_TC 0x6 /* enum */
1023#define	MC_CMD_MMD_CLAUSE45_AN 0x7 /* enum */
1024#define	MC_CMD_MMD_CLAUSE45_C22EXT 0x1d /* enum */
1025#define	MC_CMD_MMD_CLAUSE45_VEND1 0x1e /* enum */
1026#define	MC_CMD_MMD_CLAUSE45_VEND2 0x1f /* enum */
1027#define	MC_CMD_GET_PHY_CFG_OUT_REVISION_OFST 52
1028#define	MC_CMD_GET_PHY_CFG_OUT_REVISION_LEN 20
1029
1030
1031/***********************************/
1032/* MC_CMD_START_BIST
1033 * Start a BIST test on the PHY.
1034 */
1035#define	MC_CMD_START_BIST  0x25
1036
1037/* MC_CMD_START_BIST_IN msgrequest */
1038#define	MC_CMD_START_BIST_IN_LEN 4
1039#define	MC_CMD_START_BIST_IN_TYPE_OFST 0
1040#define	MC_CMD_PHY_BIST_CABLE_SHORT 0x1 /* enum */
1041#define	MC_CMD_PHY_BIST_CABLE_LONG 0x2 /* enum */
1042#define	MC_CMD_BPX_SERDES_BIST 0x3 /* enum */
1043#define	MC_CMD_MC_LOOPBACK_BIST 0x4 /* enum */
1044#define	MC_CMD_PHY_BIST 0x5 /* enum */
1045
1046/* MC_CMD_START_BIST_OUT msgresponse */
1047#define	MC_CMD_START_BIST_OUT_LEN 0
1048
1049
1050/***********************************/
1051/* MC_CMD_POLL_BIST
1052 * Poll for BIST completion.
1053 */
1054#define	MC_CMD_POLL_BIST  0x26
1055
1056/* MC_CMD_POLL_BIST_IN msgrequest */
1057#define	MC_CMD_POLL_BIST_IN_LEN 0
1058
1059/* MC_CMD_POLL_BIST_OUT msgresponse */
1060#define	MC_CMD_POLL_BIST_OUT_LEN 8
1061#define	MC_CMD_POLL_BIST_OUT_RESULT_OFST 0
1062#define	MC_CMD_POLL_BIST_RUNNING 0x1 /* enum */
1063#define	MC_CMD_POLL_BIST_PASSED 0x2 /* enum */
1064#define	MC_CMD_POLL_BIST_FAILED 0x3 /* enum */
1065#define	MC_CMD_POLL_BIST_TIMEOUT 0x4 /* enum */
1066#define	MC_CMD_POLL_BIST_OUT_PRIVATE_OFST 4
1067
1068/* MC_CMD_POLL_BIST_OUT_SFT9001 msgresponse */
1069#define	MC_CMD_POLL_BIST_OUT_SFT9001_LEN 36
1070/*            MC_CMD_POLL_BIST_OUT_RESULT_OFST 0 */
1071/*            Enum values, see field(s): */
1072/*               MC_CMD_POLL_BIST_OUT/MC_CMD_POLL_BIST_OUT_RESULT */
1073#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_A_OFST 4
1074#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_B_OFST 8
1075#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_C_OFST 12
1076#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_D_OFST 16
1077#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_A_OFST 20
1078#define	MC_CMD_POLL_BIST_SFT9001_PAIR_OK 0x1 /* enum */
1079#define	MC_CMD_POLL_BIST_SFT9001_PAIR_OPEN 0x2 /* enum */
1080#define	MC_CMD_POLL_BIST_SFT9001_INTRA_PAIR_SHORT 0x3 /* enum */
1081#define	MC_CMD_POLL_BIST_SFT9001_INTER_PAIR_SHORT 0x4 /* enum */
1082#define	MC_CMD_POLL_BIST_SFT9001_PAIR_BUSY 0x9 /* enum */
1083#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_B_OFST 24
1084/*            Enum values, see field(s): */
1085/*               CABLE_STATUS_A */
1086#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_C_OFST 28
1087/*            Enum values, see field(s): */
1088/*               CABLE_STATUS_A */
1089#define	MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_D_OFST 32
1090/*            Enum values, see field(s): */
1091/*               CABLE_STATUS_A */
1092
1093/* MC_CMD_POLL_BIST_OUT_MRSFP msgresponse */
1094#define	MC_CMD_POLL_BIST_OUT_MRSFP_LEN 8
1095/*            MC_CMD_POLL_BIST_OUT_RESULT_OFST 0 */
1096/*            Enum values, see field(s): */
1097/*               MC_CMD_POLL_BIST_OUT/MC_CMD_POLL_BIST_OUT_RESULT */
1098#define	MC_CMD_POLL_BIST_OUT_MRSFP_TEST_OFST 4
1099#define	MC_CMD_POLL_BIST_MRSFP_TEST_COMPLETE 0x0 /* enum */
1100#define	MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_WRITE 0x1 /* enum */
1101#define	MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_NO_ACCESS_IO_EXP 0x2 /* enum */
1102#define	MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_NO_ACCESS_MODULE 0x3 /* enum */
1103#define	MC_CMD_POLL_BIST_MRSFP_TEST_IO_EXP_I2C_CONFIGURE 0x4 /* enum */
1104#define	MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_I2C_NO_CROSSTALK 0x5 /* enum */
1105#define	MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_PRESENCE 0x6 /* enum */
1106#define	MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_ID_I2C_ACCESS 0x7 /* enum */
1107#define	MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_ID_SANE_VALUE 0x8 /* enum */
1108
1109
1110/***********************************/
1111/* MC_CMD_FLUSH_RX_QUEUES
1112 * Flush receive queue(s).
1113 */
1114#define	MC_CMD_FLUSH_RX_QUEUES  0x27
1115
1116/* MC_CMD_FLUSH_RX_QUEUES_IN msgrequest */
1117#define	MC_CMD_FLUSH_RX_QUEUES_IN_LENMIN 4
1118#define	MC_CMD_FLUSH_RX_QUEUES_IN_LENMAX 252
1119#define	MC_CMD_FLUSH_RX_QUEUES_IN_LEN(num) (0+4*(num))
1120#define	MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_OFST 0
1121#define	MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_LEN 4
1122#define	MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_MINNUM 1
1123#define	MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_MAXNUM 63
1124
1125/* MC_CMD_FLUSH_RX_QUEUES_OUT msgresponse */
1126#define	MC_CMD_FLUSH_RX_QUEUES_OUT_LEN 0
1127
1128
1129/***********************************/
1130/* MC_CMD_GET_LOOPBACK_MODES
1131 * Get port's loopback modes.
1132 */
1133#define	MC_CMD_GET_LOOPBACK_MODES  0x28
1134
1135/* MC_CMD_GET_LOOPBACK_MODES_IN msgrequest */
1136#define	MC_CMD_GET_LOOPBACK_MODES_IN_LEN 0
1137
1138/* MC_CMD_GET_LOOPBACK_MODES_OUT msgresponse */
1139#define	MC_CMD_GET_LOOPBACK_MODES_OUT_LEN 32
1140#define	MC_CMD_GET_LOOPBACK_MODES_OUT_100M_OFST 0
1141#define	MC_CMD_GET_LOOPBACK_MODES_OUT_100M_LEN 8
1142#define	MC_CMD_GET_LOOPBACK_MODES_OUT_100M_LO_OFST 0
1143#define	MC_CMD_GET_LOOPBACK_MODES_OUT_100M_HI_OFST 4
1144#define	MC_CMD_LOOPBACK_NONE  0x0 /* enum */
1145#define	MC_CMD_LOOPBACK_DATA  0x1 /* enum */
1146#define	MC_CMD_LOOPBACK_GMAC  0x2 /* enum */
1147#define	MC_CMD_LOOPBACK_XGMII 0x3 /* enum */
1148#define	MC_CMD_LOOPBACK_XGXS  0x4 /* enum */
1149#define	MC_CMD_LOOPBACK_XAUI  0x5 /* enum */
1150#define	MC_CMD_LOOPBACK_GMII  0x6 /* enum */
1151#define	MC_CMD_LOOPBACK_SGMII  0x7 /* enum */
1152#define	MC_CMD_LOOPBACK_XGBR  0x8 /* enum */
1153#define	MC_CMD_LOOPBACK_XFI  0x9 /* enum */
1154#define	MC_CMD_LOOPBACK_XAUI_FAR  0xa /* enum */
1155#define	MC_CMD_LOOPBACK_GMII_FAR  0xb /* enum */
1156#define	MC_CMD_LOOPBACK_SGMII_FAR  0xc /* enum */
1157#define	MC_CMD_LOOPBACK_XFI_FAR  0xd /* enum */
1158#define	MC_CMD_LOOPBACK_GPHY  0xe /* enum */
1159#define	MC_CMD_LOOPBACK_PHYXS  0xf /* enum */
1160#define	MC_CMD_LOOPBACK_PCS  0x10 /* enum */
1161#define	MC_CMD_LOOPBACK_PMAPMD  0x11 /* enum */
1162#define	MC_CMD_LOOPBACK_XPORT  0x12 /* enum */
1163#define	MC_CMD_LOOPBACK_XGMII_WS  0x13 /* enum */
1164#define	MC_CMD_LOOPBACK_XAUI_WS  0x14 /* enum */
1165#define	MC_CMD_LOOPBACK_XAUI_WS_FAR  0x15 /* enum */
1166#define	MC_CMD_LOOPBACK_XAUI_WS_NEAR  0x16 /* enum */
1167#define	MC_CMD_LOOPBACK_GMII_WS  0x17 /* enum */
1168#define	MC_CMD_LOOPBACK_XFI_WS  0x18 /* enum */
1169#define	MC_CMD_LOOPBACK_XFI_WS_FAR  0x19 /* enum */
1170#define	MC_CMD_LOOPBACK_PHYXS_WS  0x1a /* enum */
1171#define	MC_CMD_GET_LOOPBACK_MODES_OUT_1G_OFST 8
1172#define	MC_CMD_GET_LOOPBACK_MODES_OUT_1G_LEN 8
1173#define	MC_CMD_GET_LOOPBACK_MODES_OUT_1G_LO_OFST 8
1174#define	MC_CMD_GET_LOOPBACK_MODES_OUT_1G_HI_OFST 12
1175/*            Enum values, see field(s): */
1176/*               100M */
1177#define	MC_CMD_GET_LOOPBACK_MODES_OUT_10G_OFST 16
1178#define	MC_CMD_GET_LOOPBACK_MODES_OUT_10G_LEN 8
1179#define	MC_CMD_GET_LOOPBACK_MODES_OUT_10G_LO_OFST 16
1180#define	MC_CMD_GET_LOOPBACK_MODES_OUT_10G_HI_OFST 20
1181/*            Enum values, see field(s): */
1182/*               100M */
1183#define	MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_OFST 24
1184#define	MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_LEN 8
1185#define	MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_LO_OFST 24
1186#define	MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_HI_OFST 28
1187/*            Enum values, see field(s): */
1188/*               100M */
1189
1190
1191/***********************************/
1192/* MC_CMD_GET_LINK
1193 * Read the unified MAC/PHY link state.
1194 */
1195#define	MC_CMD_GET_LINK  0x29
1196
1197/* MC_CMD_GET_LINK_IN msgrequest */
1198#define	MC_CMD_GET_LINK_IN_LEN 0
1199
1200/* MC_CMD_GET_LINK_OUT msgresponse */
1201#define	MC_CMD_GET_LINK_OUT_LEN 28
1202#define	MC_CMD_GET_LINK_OUT_CAP_OFST 0
1203#define	MC_CMD_GET_LINK_OUT_LP_CAP_OFST 4
1204#define	MC_CMD_GET_LINK_OUT_LINK_SPEED_OFST 8
1205#define	MC_CMD_GET_LINK_OUT_LOOPBACK_MODE_OFST 12
1206/*            Enum values, see field(s): */
1207/*               MC_CMD_GET_LOOPBACK_MODES/MC_CMD_GET_LOOPBACK_MODES_OUT/100M */
1208#define	MC_CMD_GET_LINK_OUT_FLAGS_OFST 16
1209#define	MC_CMD_GET_LINK_OUT_LINK_UP_LBN 0
1210#define	MC_CMD_GET_LINK_OUT_LINK_UP_WIDTH 1
1211#define	MC_CMD_GET_LINK_OUT_FULL_DUPLEX_LBN 1
1212#define	MC_CMD_GET_LINK_OUT_FULL_DUPLEX_WIDTH 1
1213#define	MC_CMD_GET_LINK_OUT_BPX_LINK_LBN 2
1214#define	MC_CMD_GET_LINK_OUT_BPX_LINK_WIDTH 1
1215#define	MC_CMD_GET_LINK_OUT_PHY_LINK_LBN 3
1216#define	MC_CMD_GET_LINK_OUT_PHY_LINK_WIDTH 1
1217#define	MC_CMD_GET_LINK_OUT_FCNTL_OFST 20
1218#define	MC_CMD_FCNTL_OFF 0x0 /* enum */
1219#define	MC_CMD_FCNTL_RESPOND 0x1 /* enum */
1220#define	MC_CMD_FCNTL_BIDIR 0x2 /* enum */
1221#define	MC_CMD_GET_LINK_OUT_MAC_FAULT_OFST 24
1222#define	MC_CMD_MAC_FAULT_XGMII_LOCAL_LBN 0
1223#define	MC_CMD_MAC_FAULT_XGMII_LOCAL_WIDTH 1
1224#define	MC_CMD_MAC_FAULT_XGMII_REMOTE_LBN 1
1225#define	MC_CMD_MAC_FAULT_XGMII_REMOTE_WIDTH 1
1226#define	MC_CMD_MAC_FAULT_SGMII_REMOTE_LBN 2
1227#define	MC_CMD_MAC_FAULT_SGMII_REMOTE_WIDTH 1
1228#define	MC_CMD_MAC_FAULT_PENDING_RECONFIG_LBN 3
1229#define	MC_CMD_MAC_FAULT_PENDING_RECONFIG_WIDTH 1
1230
1231
1232/***********************************/
1233/* MC_CMD_SET_LINK
1234 * Write the unified MAC/PHY link configuration.
1235 */
1236#define	MC_CMD_SET_LINK  0x2a
1237
1238/* MC_CMD_SET_LINK_IN msgrequest */
1239#define	MC_CMD_SET_LINK_IN_LEN 16
1240#define	MC_CMD_SET_LINK_IN_CAP_OFST 0
1241#define	MC_CMD_SET_LINK_IN_FLAGS_OFST 4
1242#define	MC_CMD_SET_LINK_IN_LOWPOWER_LBN 0
1243#define	MC_CMD_SET_LINK_IN_LOWPOWER_WIDTH 1
1244#define	MC_CMD_SET_LINK_IN_POWEROFF_LBN 1
1245#define	MC_CMD_SET_LINK_IN_POWEROFF_WIDTH 1
1246#define	MC_CMD_SET_LINK_IN_TXDIS_LBN 2
1247#define	MC_CMD_SET_LINK_IN_TXDIS_WIDTH 1
1248#define	MC_CMD_SET_LINK_IN_LOOPBACK_MODE_OFST 8
1249/*            Enum values, see field(s): */
1250/*               MC_CMD_GET_LOOPBACK_MODES/MC_CMD_GET_LOOPBACK_MODES_OUT/100M */
1251#define	MC_CMD_SET_LINK_IN_LOOPBACK_SPEED_OFST 12
1252
1253/* MC_CMD_SET_LINK_OUT msgresponse */
1254#define	MC_CMD_SET_LINK_OUT_LEN 0
1255
1256
1257/***********************************/
1258/* MC_CMD_SET_ID_LED
1259 * Set indentification LED state.
1260 */
1261#define	MC_CMD_SET_ID_LED  0x2b
1262
1263/* MC_CMD_SET_ID_LED_IN msgrequest */
1264#define	MC_CMD_SET_ID_LED_IN_LEN 4
1265#define	MC_CMD_SET_ID_LED_IN_STATE_OFST 0
1266#define	MC_CMD_LED_OFF  0x0 /* enum */
1267#define	MC_CMD_LED_ON  0x1 /* enum */
1268#define	MC_CMD_LED_DEFAULT  0x2 /* enum */
1269
1270/* MC_CMD_SET_ID_LED_OUT msgresponse */
1271#define	MC_CMD_SET_ID_LED_OUT_LEN 0
1272
1273
1274/***********************************/
1275/* MC_CMD_SET_MAC
1276 * Set MAC configuration.
1277 */
1278#define	MC_CMD_SET_MAC  0x2c
1279
1280/* MC_CMD_SET_MAC_IN msgrequest */
1281#define	MC_CMD_SET_MAC_IN_LEN 24
1282#define	MC_CMD_SET_MAC_IN_MTU_OFST 0
1283#define	MC_CMD_SET_MAC_IN_DRAIN_OFST 4
1284#define	MC_CMD_SET_MAC_IN_ADDR_OFST 8
1285#define	MC_CMD_SET_MAC_IN_ADDR_LEN 8
1286#define	MC_CMD_SET_MAC_IN_ADDR_LO_OFST 8
1287#define	MC_CMD_SET_MAC_IN_ADDR_HI_OFST 12
1288#define	MC_CMD_SET_MAC_IN_REJECT_OFST 16
1289#define	MC_CMD_SET_MAC_IN_REJECT_UNCST_LBN 0
1290#define	MC_CMD_SET_MAC_IN_REJECT_UNCST_WIDTH 1
1291#define	MC_CMD_SET_MAC_IN_REJECT_BRDCST_LBN 1
1292#define	MC_CMD_SET_MAC_IN_REJECT_BRDCST_WIDTH 1
1293#define	MC_CMD_SET_MAC_IN_FCNTL_OFST 20
1294/*               MC_CMD_FCNTL_OFF 0x0 */
1295/*               MC_CMD_FCNTL_RESPOND 0x1 */
1296/*               MC_CMD_FCNTL_BIDIR 0x2 */
1297#define	MC_CMD_FCNTL_AUTO 0x3 /* enum */
1298
1299/* MC_CMD_SET_MAC_OUT msgresponse */
1300#define	MC_CMD_SET_MAC_OUT_LEN 0
1301
1302
1303/***********************************/
1304/* MC_CMD_PHY_STATS
1305 * Get generic PHY statistics.
1306 */
1307#define	MC_CMD_PHY_STATS  0x2d
1308
1309/* MC_CMD_PHY_STATS_IN msgrequest */
1310#define	MC_CMD_PHY_STATS_IN_LEN 8
1311#define	MC_CMD_PHY_STATS_IN_DMA_ADDR_OFST 0
1312#define	MC_CMD_PHY_STATS_IN_DMA_ADDR_LEN 8
1313#define	MC_CMD_PHY_STATS_IN_DMA_ADDR_LO_OFST 0
1314#define	MC_CMD_PHY_STATS_IN_DMA_ADDR_HI_OFST 4
1315
1316/* MC_CMD_PHY_STATS_OUT_DMA msgresponse */
1317#define	MC_CMD_PHY_STATS_OUT_DMA_LEN 0
1318
1319/* MC_CMD_PHY_STATS_OUT_NO_DMA msgresponse */
1320#define	MC_CMD_PHY_STATS_OUT_NO_DMA_LEN (((MC_CMD_PHY_NSTATS*32))>>3)
1321#define	MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_OFST 0
1322#define	MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_LEN 4
1323#define	MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_NUM MC_CMD_PHY_NSTATS
1324#define	MC_CMD_OUI  0x0 /* enum */
1325#define	MC_CMD_PMA_PMD_LINK_UP  0x1 /* enum */
1326#define	MC_CMD_PMA_PMD_RX_FAULT  0x2 /* enum */
1327#define	MC_CMD_PMA_PMD_TX_FAULT  0x3 /* enum */
1328#define	MC_CMD_PMA_PMD_SIGNAL  0x4 /* enum */
1329#define	MC_CMD_PMA_PMD_SNR_A  0x5 /* enum */
1330#define	MC_CMD_PMA_PMD_SNR_B  0x6 /* enum */
1331#define	MC_CMD_PMA_PMD_SNR_C  0x7 /* enum */
1332#define	MC_CMD_PMA_PMD_SNR_D  0x8 /* enum */
1333#define	MC_CMD_PCS_LINK_UP  0x9 /* enum */
1334#define	MC_CMD_PCS_RX_FAULT  0xa /* enum */
1335#define	MC_CMD_PCS_TX_FAULT  0xb /* enum */
1336#define	MC_CMD_PCS_BER  0xc /* enum */
1337#define	MC_CMD_PCS_BLOCK_ERRORS  0xd /* enum */
1338#define	MC_CMD_PHYXS_LINK_UP  0xe /* enum */
1339#define	MC_CMD_PHYXS_RX_FAULT  0xf /* enum */
1340#define	MC_CMD_PHYXS_TX_FAULT  0x10 /* enum */
1341#define	MC_CMD_PHYXS_ALIGN  0x11 /* enum */
1342#define	MC_CMD_PHYXS_SYNC  0x12 /* enum */
1343#define	MC_CMD_AN_LINK_UP  0x13 /* enum */
1344#define	MC_CMD_AN_COMPLETE  0x14 /* enum */
1345#define	MC_CMD_AN_10GBT_STATUS  0x15 /* enum */
1346#define	MC_CMD_CL22_LINK_UP  0x16 /* enum */
1347#define	MC_CMD_PHY_NSTATS  0x17 /* enum */
1348
1349
1350/***********************************/
1351/* MC_CMD_MAC_STATS
1352 * Get generic MAC statistics.
1353 */
1354#define	MC_CMD_MAC_STATS  0x2e
1355
1356/* MC_CMD_MAC_STATS_IN msgrequest */
1357#define	MC_CMD_MAC_STATS_IN_LEN 16
1358#define	MC_CMD_MAC_STATS_IN_DMA_ADDR_OFST 0
1359#define	MC_CMD_MAC_STATS_IN_DMA_ADDR_LEN 8
1360#define	MC_CMD_MAC_STATS_IN_DMA_ADDR_LO_OFST 0
1361#define	MC_CMD_MAC_STATS_IN_DMA_ADDR_HI_OFST 4
1362#define	MC_CMD_MAC_STATS_IN_CMD_OFST 8
1363#define	MC_CMD_MAC_STATS_IN_DMA_LBN 0
1364#define	MC_CMD_MAC_STATS_IN_DMA_WIDTH 1
1365#define	MC_CMD_MAC_STATS_IN_CLEAR_LBN 1
1366#define	MC_CMD_MAC_STATS_IN_CLEAR_WIDTH 1
1367#define	MC_CMD_MAC_STATS_IN_PERIODIC_CHANGE_LBN 2
1368#define	MC_CMD_MAC_STATS_IN_PERIODIC_CHANGE_WIDTH 1
1369#define	MC_CMD_MAC_STATS_IN_PERIODIC_ENABLE_LBN 3
1370#define	MC_CMD_MAC_STATS_IN_PERIODIC_ENABLE_WIDTH 1
1371#define	MC_CMD_MAC_STATS_IN_PERIODIC_CLEAR_LBN 4
1372#define	MC_CMD_MAC_STATS_IN_PERIODIC_CLEAR_WIDTH 1
1373#define	MC_CMD_MAC_STATS_IN_PERIODIC_NOEVENT_LBN 5
1374#define	MC_CMD_MAC_STATS_IN_PERIODIC_NOEVENT_WIDTH 1
1375#define	MC_CMD_MAC_STATS_IN_PERIOD_MS_LBN 16
1376#define	MC_CMD_MAC_STATS_IN_PERIOD_MS_WIDTH 16
1377#define	MC_CMD_MAC_STATS_IN_DMA_LEN_OFST 12
1378
1379/* MC_CMD_MAC_STATS_OUT_DMA msgresponse */
1380#define	MC_CMD_MAC_STATS_OUT_DMA_LEN 0
1381
1382/* MC_CMD_MAC_STATS_OUT_NO_DMA msgresponse */
1383#define	MC_CMD_MAC_STATS_OUT_NO_DMA_LEN (((MC_CMD_MAC_NSTATS*64))>>3)
1384#define	MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_OFST 0
1385#define	MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_LEN 8
1386#define	MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_LO_OFST 0
1387#define	MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_HI_OFST 4
1388#define	MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_NUM MC_CMD_MAC_NSTATS
1389#define	MC_CMD_MAC_GENERATION_START  0x0 /* enum */
1390#define	MC_CMD_MAC_TX_PKTS  0x1 /* enum */
1391#define	MC_CMD_MAC_TX_PAUSE_PKTS  0x2 /* enum */
1392#define	MC_CMD_MAC_TX_CONTROL_PKTS  0x3 /* enum */
1393#define	MC_CMD_MAC_TX_UNICAST_PKTS  0x4 /* enum */
1394#define	MC_CMD_MAC_TX_MULTICAST_PKTS  0x5 /* enum */
1395#define	MC_CMD_MAC_TX_BROADCAST_PKTS  0x6 /* enum */
1396#define	MC_CMD_MAC_TX_BYTES  0x7 /* enum */
1397#define	MC_CMD_MAC_TX_BAD_BYTES  0x8 /* enum */
1398#define	MC_CMD_MAC_TX_LT64_PKTS  0x9 /* enum */
1399#define	MC_CMD_MAC_TX_64_PKTS  0xa /* enum */
1400#define	MC_CMD_MAC_TX_65_TO_127_PKTS  0xb /* enum */
1401#define	MC_CMD_MAC_TX_128_TO_255_PKTS  0xc /* enum */
1402#define	MC_CMD_MAC_TX_256_TO_511_PKTS  0xd /* enum */
1403#define	MC_CMD_MAC_TX_512_TO_1023_PKTS  0xe /* enum */
1404#define	MC_CMD_MAC_TX_1024_TO_15XX_PKTS  0xf /* enum */
1405#define	MC_CMD_MAC_TX_15XX_TO_JUMBO_PKTS  0x10 /* enum */
1406#define	MC_CMD_MAC_TX_GTJUMBO_PKTS  0x11 /* enum */
1407#define	MC_CMD_MAC_TX_BAD_FCS_PKTS  0x12 /* enum */
1408#define	MC_CMD_MAC_TX_SINGLE_COLLISION_PKTS  0x13 /* enum */
1409#define	MC_CMD_MAC_TX_MULTIPLE_COLLISION_PKTS  0x14 /* enum */
1410#define	MC_CMD_MAC_TX_EXCESSIVE_COLLISION_PKTS  0x15 /* enum */
1411#define	MC_CMD_MAC_TX_LATE_COLLISION_PKTS  0x16 /* enum */
1412#define	MC_CMD_MAC_TX_DEFERRED_PKTS  0x17 /* enum */
1413#define	MC_CMD_MAC_TX_EXCESSIVE_DEFERRED_PKTS  0x18 /* enum */
1414#define	MC_CMD_MAC_TX_NON_TCPUDP_PKTS  0x19 /* enum */
1415#define	MC_CMD_MAC_TX_MAC_SRC_ERR_PKTS  0x1a /* enum */
1416#define	MC_CMD_MAC_TX_IP_SRC_ERR_PKTS  0x1b /* enum */
1417#define	MC_CMD_MAC_RX_PKTS  0x1c /* enum */
1418#define	MC_CMD_MAC_RX_PAUSE_PKTS  0x1d /* enum */
1419#define	MC_CMD_MAC_RX_GOOD_PKTS  0x1e /* enum */
1420#define	MC_CMD_MAC_RX_CONTROL_PKTS  0x1f /* enum */
1421#define	MC_CMD_MAC_RX_UNICAST_PKTS  0x20 /* enum */
1422#define	MC_CMD_MAC_RX_MULTICAST_PKTS  0x21 /* enum */
1423#define	MC_CMD_MAC_RX_BROADCAST_PKTS  0x22 /* enum */
1424#define	MC_CMD_MAC_RX_BYTES  0x23 /* enum */
1425#define	MC_CMD_MAC_RX_BAD_BYTES  0x24 /* enum */
1426#define	MC_CMD_MAC_RX_64_PKTS  0x25 /* enum */
1427#define	MC_CMD_MAC_RX_65_TO_127_PKTS  0x26 /* enum */
1428#define	MC_CMD_MAC_RX_128_TO_255_PKTS  0x27 /* enum */
1429#define	MC_CMD_MAC_RX_256_TO_511_PKTS  0x28 /* enum */
1430#define	MC_CMD_MAC_RX_512_TO_1023_PKTS  0x29 /* enum */
1431#define	MC_CMD_MAC_RX_1024_TO_15XX_PKTS  0x2a /* enum */
1432#define	MC_CMD_MAC_RX_15XX_TO_JUMBO_PKTS  0x2b /* enum */
1433#define	MC_CMD_MAC_RX_GTJUMBO_PKTS  0x2c /* enum */
1434#define	MC_CMD_MAC_RX_UNDERSIZE_PKTS  0x2d /* enum */
1435#define	MC_CMD_MAC_RX_BAD_FCS_PKTS  0x2e /* enum */
1436#define	MC_CMD_MAC_RX_OVERFLOW_PKTS  0x2f /* enum */
1437#define	MC_CMD_MAC_RX_FALSE_CARRIER_PKTS  0x30 /* enum */
1438#define	MC_CMD_MAC_RX_SYMBOL_ERROR_PKTS  0x31 /* enum */
1439#define	MC_CMD_MAC_RX_ALIGN_ERROR_PKTS  0x32 /* enum */
1440#define	MC_CMD_MAC_RX_LENGTH_ERROR_PKTS  0x33 /* enum */
1441#define	MC_CMD_MAC_RX_INTERNAL_ERROR_PKTS  0x34 /* enum */
1442#define	MC_CMD_MAC_RX_JABBER_PKTS  0x35 /* enum */
1443#define	MC_CMD_MAC_RX_NODESC_DROPS  0x36 /* enum */
1444#define	MC_CMD_MAC_RX_LANES01_CHAR_ERR  0x37 /* enum */
1445#define	MC_CMD_MAC_RX_LANES23_CHAR_ERR  0x38 /* enum */
1446#define	MC_CMD_MAC_RX_LANES01_DISP_ERR  0x39 /* enum */
1447#define	MC_CMD_MAC_RX_LANES23_DISP_ERR  0x3a /* enum */
1448#define	MC_CMD_MAC_RX_MATCH_FAULT  0x3b /* enum */
1449#define	MC_CMD_GMAC_DMABUF_START  0x40 /* enum */
1450#define	MC_CMD_GMAC_DMABUF_END    0x5f /* enum */
1451#define	MC_CMD_MAC_GENERATION_END 0x60 /* enum */
1452#define	MC_CMD_MAC_NSTATS  0x61 /* enum */
1453
1454
1455/***********************************/
1456/* MC_CMD_SRIOV
1457 * to be documented
1458 */
1459#define	MC_CMD_SRIOV  0x30
1460
1461/* MC_CMD_SRIOV_IN msgrequest */
1462#define	MC_CMD_SRIOV_IN_LEN 12
1463#define	MC_CMD_SRIOV_IN_ENABLE_OFST 0
1464#define	MC_CMD_SRIOV_IN_VI_BASE_OFST 4
1465#define	MC_CMD_SRIOV_IN_VF_COUNT_OFST 8
1466
1467/* MC_CMD_SRIOV_OUT msgresponse */
1468#define	MC_CMD_SRIOV_OUT_LEN 8
1469#define	MC_CMD_SRIOV_OUT_VI_SCALE_OFST 0
1470#define	MC_CMD_SRIOV_OUT_VF_TOTAL_OFST 4
1471
1472/* MC_CMD_MEMCPY_RECORD_TYPEDEF structuredef */
1473#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_LEN 32
1474#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_OFST 0
1475#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_LBN 0
1476#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_WIDTH 32
1477#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_OFST 4
1478#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_LBN 32
1479#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_WIDTH 32
1480#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_OFST 8
1481#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LEN 8
1482#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LO_OFST 8
1483#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_HI_OFST 12
1484#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LBN 64
1485#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_WIDTH 64
1486#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_OFST 16
1487#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_RID_INLINE 0x100 /* enum */
1488#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_LBN 128
1489#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_WIDTH 32
1490#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_OFST 20
1491#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LEN 8
1492#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LO_OFST 20
1493#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_HI_OFST 24
1494#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LBN 160
1495#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_WIDTH 64
1496#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_OFST 28
1497#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_LBN 224
1498#define	MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_WIDTH 32
1499
1500
1501/***********************************/
1502/* MC_CMD_MEMCPY
1503 * Perform memory copy operation.
1504 */
1505#define	MC_CMD_MEMCPY  0x31
1506
1507/* MC_CMD_MEMCPY_IN msgrequest */
1508#define	MC_CMD_MEMCPY_IN_LENMIN 32
1509#define	MC_CMD_MEMCPY_IN_LENMAX 224
1510#define	MC_CMD_MEMCPY_IN_LEN(num) (0+32*(num))
1511#define	MC_CMD_MEMCPY_IN_RECORD_OFST 0
1512#define	MC_CMD_MEMCPY_IN_RECORD_LEN 32
1513#define	MC_CMD_MEMCPY_IN_RECORD_MINNUM 1
1514#define	MC_CMD_MEMCPY_IN_RECORD_MAXNUM 7
1515
1516/* MC_CMD_MEMCPY_OUT msgresponse */
1517#define	MC_CMD_MEMCPY_OUT_LEN 0
1518
1519
1520/***********************************/
1521/* MC_CMD_WOL_FILTER_SET
1522 * Set a WoL filter.
1523 */
1524#define	MC_CMD_WOL_FILTER_SET  0x32
1525
1526/* MC_CMD_WOL_FILTER_SET_IN msgrequest */
1527#define	MC_CMD_WOL_FILTER_SET_IN_LEN 192
1528#define	MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0
1529#define	MC_CMD_FILTER_MODE_SIMPLE    0x0 /* enum */
1530#define	MC_CMD_FILTER_MODE_STRUCTURED 0xffffffff /* enum */
1531#define	MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4
1532#define	MC_CMD_WOL_TYPE_MAGIC      0x0 /* enum */
1533#define	MC_CMD_WOL_TYPE_WIN_MAGIC 0x2 /* enum */
1534#define	MC_CMD_WOL_TYPE_IPV4_SYN   0x3 /* enum */
1535#define	MC_CMD_WOL_TYPE_IPV6_SYN   0x4 /* enum */
1536#define	MC_CMD_WOL_TYPE_BITMAP     0x5 /* enum */
1537#define	MC_CMD_WOL_TYPE_LINK       0x6 /* enum */
1538#define	MC_CMD_WOL_TYPE_MAX        0x7 /* enum */
1539#define	MC_CMD_WOL_FILTER_SET_IN_DATA_OFST 8
1540#define	MC_CMD_WOL_FILTER_SET_IN_DATA_LEN 4
1541#define	MC_CMD_WOL_FILTER_SET_IN_DATA_NUM 46
1542
1543/* MC_CMD_WOL_FILTER_SET_IN_MAGIC msgrequest */
1544#define	MC_CMD_WOL_FILTER_SET_IN_MAGIC_LEN 16
1545/*            MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1546/*            MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1547#define	MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_OFST 8
1548#define	MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_LEN 8
1549#define	MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_LO_OFST 8
1550#define	MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_HI_OFST 12
1551
1552/* MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN msgrequest */
1553#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_LEN 20
1554/*            MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1555/*            MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1556#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_IP_OFST 8
1557#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_IP_OFST 12
1558#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_PORT_OFST 16
1559#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_PORT_LEN 2
1560#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_PORT_OFST 18
1561#define	MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_PORT_LEN 2
1562
1563/* MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN msgrequest */
1564#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_LEN 44
1565/*            MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1566/*            MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1567#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_IP_OFST 8
1568#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_IP_LEN 16
1569#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_IP_OFST 24
1570#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_IP_LEN 16
1571#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_PORT_OFST 40
1572#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_PORT_LEN 2
1573#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_PORT_OFST 42
1574#define	MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_PORT_LEN 2
1575
1576/* MC_CMD_WOL_FILTER_SET_IN_BITMAP msgrequest */
1577#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN 187
1578/*            MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1579/*            MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1580#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_MASK_OFST 8
1581#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_MASK_LEN 48
1582#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_BITMAP_OFST 56
1583#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_BITMAP_LEN 128
1584#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN_OFST 184
1585#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN_LEN 1
1586#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER3_OFST 185
1587#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER3_LEN 1
1588#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER4_OFST 186
1589#define	MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER4_LEN 1
1590
1591/* MC_CMD_WOL_FILTER_SET_IN_LINK msgrequest */
1592#define	MC_CMD_WOL_FILTER_SET_IN_LINK_LEN 12
1593/*            MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1594/*            MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1595#define	MC_CMD_WOL_FILTER_SET_IN_LINK_MASK_OFST 8
1596#define	MC_CMD_WOL_FILTER_SET_IN_LINK_UP_LBN 0
1597#define	MC_CMD_WOL_FILTER_SET_IN_LINK_UP_WIDTH 1
1598#define	MC_CMD_WOL_FILTER_SET_IN_LINK_DOWN_LBN 1
1599#define	MC_CMD_WOL_FILTER_SET_IN_LINK_DOWN_WIDTH 1
1600
1601/* MC_CMD_WOL_FILTER_SET_OUT msgresponse */
1602#define	MC_CMD_WOL_FILTER_SET_OUT_LEN 4
1603#define	MC_CMD_WOL_FILTER_SET_OUT_FILTER_ID_OFST 0
1604
1605
1606/***********************************/
1607/* MC_CMD_WOL_FILTER_REMOVE
1608 * Remove a WoL filter.
1609 */
1610#define	MC_CMD_WOL_FILTER_REMOVE  0x33
1611
1612/* MC_CMD_WOL_FILTER_REMOVE_IN msgrequest */
1613#define	MC_CMD_WOL_FILTER_REMOVE_IN_LEN 4
1614#define	MC_CMD_WOL_FILTER_REMOVE_IN_FILTER_ID_OFST 0
1615
1616/* MC_CMD_WOL_FILTER_REMOVE_OUT msgresponse */
1617#define	MC_CMD_WOL_FILTER_REMOVE_OUT_LEN 0
1618
1619
1620/***********************************/
1621/* MC_CMD_WOL_FILTER_RESET
1622 * Reset (i.e. remove all) WoL filters.
1623 */
1624#define	MC_CMD_WOL_FILTER_RESET  0x34
1625
1626/* MC_CMD_WOL_FILTER_RESET_IN msgrequest */
1627#define	MC_CMD_WOL_FILTER_RESET_IN_LEN 4
1628#define	MC_CMD_WOL_FILTER_RESET_IN_MASK_OFST 0
1629#define	MC_CMD_WOL_FILTER_RESET_IN_WAKE_FILTERS 0x1 /* enum */
1630#define	MC_CMD_WOL_FILTER_RESET_IN_LIGHTSOUT_OFFLOADS 0x2 /* enum */
1631
1632/* MC_CMD_WOL_FILTER_RESET_OUT msgresponse */
1633#define	MC_CMD_WOL_FILTER_RESET_OUT_LEN 0
1634
1635
1636/***********************************/
1637/* MC_CMD_SET_MCAST_HASH
1638 * Set the MCASH hash value.
1639 */
1640#define	MC_CMD_SET_MCAST_HASH  0x35
1641
1642/* MC_CMD_SET_MCAST_HASH_IN msgrequest */
1643#define	MC_CMD_SET_MCAST_HASH_IN_LEN 32
1644#define	MC_CMD_SET_MCAST_HASH_IN_HASH0_OFST 0
1645#define	MC_CMD_SET_MCAST_HASH_IN_HASH0_LEN 16
1646#define	MC_CMD_SET_MCAST_HASH_IN_HASH1_OFST 16
1647#define	MC_CMD_SET_MCAST_HASH_IN_HASH1_LEN 16
1648
1649/* MC_CMD_SET_MCAST_HASH_OUT msgresponse */
1650#define	MC_CMD_SET_MCAST_HASH_OUT_LEN 0
1651
1652
1653/***********************************/
1654/* MC_CMD_NVRAM_TYPES
1655 * Get virtual NVRAM partitions information.
1656 */
1657#define	MC_CMD_NVRAM_TYPES  0x36
1658
1659/* MC_CMD_NVRAM_TYPES_IN msgrequest */
1660#define	MC_CMD_NVRAM_TYPES_IN_LEN 0
1661
1662/* MC_CMD_NVRAM_TYPES_OUT msgresponse */
1663#define	MC_CMD_NVRAM_TYPES_OUT_LEN 4
1664#define	MC_CMD_NVRAM_TYPES_OUT_TYPES_OFST 0
1665#define	MC_CMD_NVRAM_TYPE_DISABLED_CALLISTO 0x0 /* enum */
1666#define	MC_CMD_NVRAM_TYPE_MC_FW 0x1 /* enum */
1667#define	MC_CMD_NVRAM_TYPE_MC_FW_BACKUP 0x2 /* enum */
1668#define	MC_CMD_NVRAM_TYPE_STATIC_CFG_PORT0 0x3 /* enum */
1669#define	MC_CMD_NVRAM_TYPE_STATIC_CFG_PORT1 0x4 /* enum */
1670#define	MC_CMD_NVRAM_TYPE_DYNAMIC_CFG_PORT0 0x5 /* enum */
1671#define	MC_CMD_NVRAM_TYPE_DYNAMIC_CFG_PORT1 0x6 /* enum */
1672#define	MC_CMD_NVRAM_TYPE_EXP_ROM 0x7 /* enum */
1673#define	MC_CMD_NVRAM_TYPE_EXP_ROM_CFG_PORT0 0x8 /* enum */
1674#define	MC_CMD_NVRAM_TYPE_EXP_ROM_CFG_PORT1 0x9 /* enum */
1675#define	MC_CMD_NVRAM_TYPE_PHY_PORT0 0xa /* enum */
1676#define	MC_CMD_NVRAM_TYPE_PHY_PORT1 0xb /* enum */
1677#define	MC_CMD_NVRAM_TYPE_LOG 0xc /* enum */
1678
1679
1680/***********************************/
1681/* MC_CMD_NVRAM_INFO
1682 * Read info about a virtual NVRAM partition.
1683 */
1684#define	MC_CMD_NVRAM_INFO  0x37
1685
1686/* MC_CMD_NVRAM_INFO_IN msgrequest */
1687#define	MC_CMD_NVRAM_INFO_IN_LEN 4
1688#define	MC_CMD_NVRAM_INFO_IN_TYPE_OFST 0
1689/*            Enum values, see field(s): */
1690/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1691
1692/* MC_CMD_NVRAM_INFO_OUT msgresponse */
1693#define	MC_CMD_NVRAM_INFO_OUT_LEN 24
1694#define	MC_CMD_NVRAM_INFO_OUT_TYPE_OFST 0
1695/*            Enum values, see field(s): */
1696/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1697#define	MC_CMD_NVRAM_INFO_OUT_SIZE_OFST 4
1698#define	MC_CMD_NVRAM_INFO_OUT_ERASESIZE_OFST 8
1699#define	MC_CMD_NVRAM_INFO_OUT_FLAGS_OFST 12
1700#define	MC_CMD_NVRAM_INFO_OUT_PROTECTED_LBN 0
1701#define	MC_CMD_NVRAM_INFO_OUT_PROTECTED_WIDTH 1
1702#define	MC_CMD_NVRAM_INFO_OUT_PHYSDEV_OFST 16
1703#define	MC_CMD_NVRAM_INFO_OUT_PHYSADDR_OFST 20
1704
1705
1706/***********************************/
1707/* MC_CMD_NVRAM_UPDATE_START
1708 * Start a group of update operations on a virtual NVRAM partition.
1709 */
1710#define	MC_CMD_NVRAM_UPDATE_START  0x38
1711
1712/* MC_CMD_NVRAM_UPDATE_START_IN msgrequest */
1713#define	MC_CMD_NVRAM_UPDATE_START_IN_LEN 4
1714#define	MC_CMD_NVRAM_UPDATE_START_IN_TYPE_OFST 0
1715/*            Enum values, see field(s): */
1716/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1717
1718/* MC_CMD_NVRAM_UPDATE_START_OUT msgresponse */
1719#define	MC_CMD_NVRAM_UPDATE_START_OUT_LEN 0
1720
1721
1722/***********************************/
1723/* MC_CMD_NVRAM_READ
1724 * Read data from a virtual NVRAM partition.
1725 */
1726#define	MC_CMD_NVRAM_READ  0x39
1727
1728/* MC_CMD_NVRAM_READ_IN msgrequest */
1729#define	MC_CMD_NVRAM_READ_IN_LEN 12
1730#define	MC_CMD_NVRAM_READ_IN_TYPE_OFST 0
1731/*            Enum values, see field(s): */
1732/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1733#define	MC_CMD_NVRAM_READ_IN_OFFSET_OFST 4
1734#define	MC_CMD_NVRAM_READ_IN_LENGTH_OFST 8
1735
1736/* MC_CMD_NVRAM_READ_OUT msgresponse */
1737#define	MC_CMD_NVRAM_READ_OUT_LENMIN 1
1738#define	MC_CMD_NVRAM_READ_OUT_LENMAX 255
1739#define	MC_CMD_NVRAM_READ_OUT_LEN(num) (0+1*(num))
1740#define	MC_CMD_NVRAM_READ_OUT_READ_BUFFER_OFST 0
1741#define	MC_CMD_NVRAM_READ_OUT_READ_BUFFER_LEN 1
1742#define	MC_CMD_NVRAM_READ_OUT_READ_BUFFER_MINNUM 1
1743#define	MC_CMD_NVRAM_READ_OUT_READ_BUFFER_MAXNUM 255
1744
1745
1746/***********************************/
1747/* MC_CMD_NVRAM_WRITE
1748 * Write data to a virtual NVRAM partition.
1749 */
1750#define	MC_CMD_NVRAM_WRITE  0x3a
1751
1752/* MC_CMD_NVRAM_WRITE_IN msgrequest */
1753#define	MC_CMD_NVRAM_WRITE_IN_LENMIN 13
1754#define	MC_CMD_NVRAM_WRITE_IN_LENMAX 255
1755#define	MC_CMD_NVRAM_WRITE_IN_LEN(num) (12+1*(num))
1756#define	MC_CMD_NVRAM_WRITE_IN_TYPE_OFST 0
1757/*            Enum values, see field(s): */
1758/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1759#define	MC_CMD_NVRAM_WRITE_IN_OFFSET_OFST 4
1760#define	MC_CMD_NVRAM_WRITE_IN_LENGTH_OFST 8
1761#define	MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_OFST 12
1762#define	MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_LEN 1
1763#define	MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_MINNUM 1
1764#define	MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_MAXNUM 243
1765
1766/* MC_CMD_NVRAM_WRITE_OUT msgresponse */
1767#define	MC_CMD_NVRAM_WRITE_OUT_LEN 0
1768
1769
1770/***********************************/
1771/* MC_CMD_NVRAM_ERASE
1772 * Erase sector(s) from a virtual NVRAM partition.
1773 */
1774#define	MC_CMD_NVRAM_ERASE  0x3b
1775
1776/* MC_CMD_NVRAM_ERASE_IN msgrequest */
1777#define	MC_CMD_NVRAM_ERASE_IN_LEN 12
1778#define	MC_CMD_NVRAM_ERASE_IN_TYPE_OFST 0
1779/*            Enum values, see field(s): */
1780/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1781#define	MC_CMD_NVRAM_ERASE_IN_OFFSET_OFST 4
1782#define	MC_CMD_NVRAM_ERASE_IN_LENGTH_OFST 8
1783
1784/* MC_CMD_NVRAM_ERASE_OUT msgresponse */
1785#define	MC_CMD_NVRAM_ERASE_OUT_LEN 0
1786
1787
1788/***********************************/
1789/* MC_CMD_NVRAM_UPDATE_FINISH
1790 * Finish a group of update operations on a virtual NVRAM partition.
1791 */
1792#define	MC_CMD_NVRAM_UPDATE_FINISH  0x3c
1793
1794/* MC_CMD_NVRAM_UPDATE_FINISH_IN msgrequest */
1795#define	MC_CMD_NVRAM_UPDATE_FINISH_IN_LEN 8
1796#define	MC_CMD_NVRAM_UPDATE_FINISH_IN_TYPE_OFST 0
1797/*            Enum values, see field(s): */
1798/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1799#define	MC_CMD_NVRAM_UPDATE_FINISH_IN_REBOOT_OFST 4
1800
1801/* MC_CMD_NVRAM_UPDATE_FINISH_OUT msgresponse */
1802#define	MC_CMD_NVRAM_UPDATE_FINISH_OUT_LEN 0
1803
1804
1805/***********************************/
1806/* MC_CMD_REBOOT
1807 * Reboot the MC.
1808 */
1809#define	MC_CMD_REBOOT  0x3d
1810
1811/* MC_CMD_REBOOT_IN msgrequest */
1812#define	MC_CMD_REBOOT_IN_LEN 4
1813#define	MC_CMD_REBOOT_IN_FLAGS_OFST 0
1814#define	MC_CMD_REBOOT_FLAGS_AFTER_ASSERTION 0x1 /* enum */
1815
1816/* MC_CMD_REBOOT_OUT msgresponse */
1817#define	MC_CMD_REBOOT_OUT_LEN 0
1818
1819
1820/***********************************/
1821/* MC_CMD_SCHEDINFO
1822 * Request scheduler info.
1823 */
1824#define	MC_CMD_SCHEDINFO  0x3e
1825
1826/* MC_CMD_SCHEDINFO_IN msgrequest */
1827#define	MC_CMD_SCHEDINFO_IN_LEN 0
1828
1829/* MC_CMD_SCHEDINFO_OUT msgresponse */
1830#define	MC_CMD_SCHEDINFO_OUT_LENMIN 4
1831#define	MC_CMD_SCHEDINFO_OUT_LENMAX 252
1832#define	MC_CMD_SCHEDINFO_OUT_LEN(num) (0+4*(num))
1833#define	MC_CMD_SCHEDINFO_OUT_DATA_OFST 0
1834#define	MC_CMD_SCHEDINFO_OUT_DATA_LEN 4
1835#define	MC_CMD_SCHEDINFO_OUT_DATA_MINNUM 1
1836#define	MC_CMD_SCHEDINFO_OUT_DATA_MAXNUM 63
1837
1838
1839/***********************************/
1840/* MC_CMD_REBOOT_MODE
1841 */
1842#define	MC_CMD_REBOOT_MODE  0x3f
1843
1844/* MC_CMD_REBOOT_MODE_IN msgrequest */
1845#define	MC_CMD_REBOOT_MODE_IN_LEN 4
1846#define	MC_CMD_REBOOT_MODE_IN_VALUE_OFST 0
1847#define	MC_CMD_REBOOT_MODE_NORMAL 0x0 /* enum */
1848#define	MC_CMD_REBOOT_MODE_SNAPPER 0x3 /* enum */
1849
1850/* MC_CMD_REBOOT_MODE_OUT msgresponse */
1851#define	MC_CMD_REBOOT_MODE_OUT_LEN 4
1852#define	MC_CMD_REBOOT_MODE_OUT_VALUE_OFST 0
1853
1854
1855/***********************************/
1856/* MC_CMD_SENSOR_INFO
1857 * Returns information about every available sensor.
1858 */
1859#define	MC_CMD_SENSOR_INFO  0x41
1860
1861/* MC_CMD_SENSOR_INFO_IN msgrequest */
1862#define	MC_CMD_SENSOR_INFO_IN_LEN 0
1863
1864/* MC_CMD_SENSOR_INFO_OUT msgresponse */
1865#define	MC_CMD_SENSOR_INFO_OUT_LENMIN 12
1866#define	MC_CMD_SENSOR_INFO_OUT_LENMAX 252
1867#define	MC_CMD_SENSOR_INFO_OUT_LEN(num) (4+8*(num))
1868#define	MC_CMD_SENSOR_INFO_OUT_MASK_OFST 0
1869#define	MC_CMD_SENSOR_CONTROLLER_TEMP  0x0 /* enum */
1870#define	MC_CMD_SENSOR_PHY_COMMON_TEMP  0x1 /* enum */
1871#define	MC_CMD_SENSOR_CONTROLLER_COOLING  0x2 /* enum */
1872#define	MC_CMD_SENSOR_PHY0_TEMP  0x3 /* enum */
1873#define	MC_CMD_SENSOR_PHY0_COOLING  0x4 /* enum */
1874#define	MC_CMD_SENSOR_PHY1_TEMP  0x5 /* enum */
1875#define	MC_CMD_SENSOR_PHY1_COOLING  0x6 /* enum */
1876#define	MC_CMD_SENSOR_IN_1V0  0x7 /* enum */
1877#define	MC_CMD_SENSOR_IN_1V2  0x8 /* enum */
1878#define	MC_CMD_SENSOR_IN_1V8  0x9 /* enum */
1879#define	MC_CMD_SENSOR_IN_2V5  0xa /* enum */
1880#define	MC_CMD_SENSOR_IN_3V3  0xb /* enum */
1881#define	MC_CMD_SENSOR_IN_12V0  0xc /* enum */
1882#define	MC_CMD_SENSOR_ENTRY_OFST 4
1883#define	MC_CMD_SENSOR_ENTRY_LEN 8
1884#define	MC_CMD_SENSOR_ENTRY_LO_OFST 4
1885#define	MC_CMD_SENSOR_ENTRY_HI_OFST 8
1886#define	MC_CMD_SENSOR_ENTRY_MINNUM 1
1887#define	MC_CMD_SENSOR_ENTRY_MAXNUM 31
1888
1889/* MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF structuredef */
1890#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_LEN 8
1891#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_OFST 0
1892#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_LEN 2
1893#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_LBN 0
1894#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_WIDTH 16
1895#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_OFST 2
1896#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_LEN 2
1897#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_LBN 16
1898#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_WIDTH 16
1899#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_OFST 4
1900#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_LEN 2
1901#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_LBN 32
1902#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_WIDTH 16
1903#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_OFST 6
1904#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_LEN 2
1905#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_LBN 48
1906#define	MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_WIDTH 16
1907
1908
1909/***********************************/
1910/* MC_CMD_READ_SENSORS
1911 * Returns the current reading from each sensor.
1912 */
1913#define	MC_CMD_READ_SENSORS  0x42
1914
1915/* MC_CMD_READ_SENSORS_IN msgrequest */
1916#define	MC_CMD_READ_SENSORS_IN_LEN 8
1917#define	MC_CMD_READ_SENSORS_IN_DMA_ADDR_OFST 0
1918#define	MC_CMD_READ_SENSORS_IN_DMA_ADDR_LEN 8
1919#define	MC_CMD_READ_SENSORS_IN_DMA_ADDR_LO_OFST 0
1920#define	MC_CMD_READ_SENSORS_IN_DMA_ADDR_HI_OFST 4
1921
1922/* MC_CMD_READ_SENSORS_OUT msgresponse */
1923#define	MC_CMD_READ_SENSORS_OUT_LEN 0
1924
1925/* MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF structuredef */
1926#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_LEN 3
1927#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_OFST 0
1928#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_LEN 2
1929#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_LBN 0
1930#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_WIDTH 16
1931#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_OFST 2
1932#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_LEN 1
1933#define	MC_CMD_SENSOR_STATE_OK  0x0 /* enum */
1934#define	MC_CMD_SENSOR_STATE_WARNING  0x1 /* enum */
1935#define	MC_CMD_SENSOR_STATE_FATAL  0x2 /* enum */
1936#define	MC_CMD_SENSOR_STATE_BROKEN  0x3 /* enum */
1937#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_LBN 16
1938#define	MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_WIDTH 8
1939
1940
1941/***********************************/
1942/* MC_CMD_GET_PHY_STATE
1943 * Report current state of PHY.
1944 */
1945#define	MC_CMD_GET_PHY_STATE  0x43
1946
1947/* MC_CMD_GET_PHY_STATE_IN msgrequest */
1948#define	MC_CMD_GET_PHY_STATE_IN_LEN 0
1949
1950/* MC_CMD_GET_PHY_STATE_OUT msgresponse */
1951#define	MC_CMD_GET_PHY_STATE_OUT_LEN 4
1952#define	MC_CMD_GET_PHY_STATE_OUT_STATE_OFST 0
1953#define	MC_CMD_PHY_STATE_OK 0x1 /* enum */
1954#define	MC_CMD_PHY_STATE_ZOMBIE 0x2 /* enum */
1955
1956
1957/***********************************/
1958/* MC_CMD_SETUP_8021QBB
1959 * 802.1Qbb control.
1960 */
1961#define	MC_CMD_SETUP_8021QBB  0x44
1962
1963/* MC_CMD_SETUP_8021QBB_IN msgrequest */
1964#define	MC_CMD_SETUP_8021QBB_IN_LEN 32
1965#define	MC_CMD_SETUP_8021QBB_IN_TXQS_OFST 0
1966#define	MC_CMD_SETUP_8021QBB_IN_TXQS_LEN 32
1967
1968/* MC_CMD_SETUP_8021QBB_OUT msgresponse */
1969#define	MC_CMD_SETUP_8021QBB_OUT_LEN 0
1970
1971
1972/***********************************/
1973/* MC_CMD_WOL_FILTER_GET
1974 * Retrieve ID of any WoL filters.
1975 */
1976#define	MC_CMD_WOL_FILTER_GET  0x45
1977
1978/* MC_CMD_WOL_FILTER_GET_IN msgrequest */
1979#define	MC_CMD_WOL_FILTER_GET_IN_LEN 0
1980
1981/* MC_CMD_WOL_FILTER_GET_OUT msgresponse */
1982#define	MC_CMD_WOL_FILTER_GET_OUT_LEN 4
1983#define	MC_CMD_WOL_FILTER_GET_OUT_FILTER_ID_OFST 0
1984
1985
1986/***********************************/
1987/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD
1988 * Add a protocol offload to NIC for lights-out state.
1989 */
1990#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD  0x46
1991
1992/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN msgrequest */
1993#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LENMIN 8
1994#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LENMAX 252
1995#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LEN(num) (4+4*(num))
1996#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0
1997#define	MC_CMD_LIGHTSOUT_OFFLOAD_PROTOCOL_ARP 0x1 /* enum */
1998#define	MC_CMD_LIGHTSOUT_OFFLOAD_PROTOCOL_NS  0x2 /* enum */
1999#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_OFST 4
2000#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_LEN 4
2001#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_MINNUM 1
2002#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_MAXNUM 62
2003
2004/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP msgrequest */
2005#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_LEN 14
2006/*            MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0 */
2007#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_MAC_OFST 4
2008#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_MAC_LEN 6
2009#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_IP_OFST 10
2010
2011/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS msgrequest */
2012#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_LEN 42
2013/*            MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0 */
2014#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_MAC_OFST 4
2015#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_MAC_LEN 6
2016#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_SNIPV6_OFST 10
2017#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_SNIPV6_LEN 16
2018#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_IPV6_OFST 26
2019#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_IPV6_LEN 16
2020
2021/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT msgresponse */
2022#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT_LEN 4
2023#define	MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT_FILTER_ID_OFST 0
2024
2025
2026/***********************************/
2027/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD
2028 * Remove a protocol offload from NIC for lights-out state.
2029 */
2030#define	MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD  0x47
2031
2032/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN msgrequest */
2033#define	MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_LEN 8
2034#define	MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0
2035#define	MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_FILTER_ID_OFST 4
2036
2037/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_OUT msgresponse */
2038#define	MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_OUT_LEN 0
2039
2040
2041/***********************************/
2042/* MC_CMD_MAC_RESET_RESTORE
2043 * Restore MAC after block reset.
2044 */
2045#define	MC_CMD_MAC_RESET_RESTORE  0x48
2046
2047/* MC_CMD_MAC_RESET_RESTORE_IN msgrequest */
2048#define	MC_CMD_MAC_RESET_RESTORE_IN_LEN 0
2049
2050/* MC_CMD_MAC_RESET_RESTORE_OUT msgresponse */
2051#define	MC_CMD_MAC_RESET_RESTORE_OUT_LEN 0
2052
2053
2054/***********************************/
2055/* MC_CMD_TESTASSERT
2056 */
2057#define	MC_CMD_TESTASSERT   0x49
2058
2059/* MC_CMD_TESTASSERT_IN msgrequest */
2060#define	MC_CMD_TESTASSERT_IN_LEN 0
2061
2062/* MC_CMD_TESTASSERT_OUT msgresponse */
2063#define	MC_CMD_TESTASSERT_OUT_LEN 0
2064
2065
2066/***********************************/
2067/* MC_CMD_WORKAROUND
2068 * Enable/Disable a given workaround.
2069 */
2070#define	MC_CMD_WORKAROUND  0x4a
2071
2072/* MC_CMD_WORKAROUND_IN msgrequest */
2073#define	MC_CMD_WORKAROUND_IN_LEN 8
2074#define	MC_CMD_WORKAROUND_IN_TYPE_OFST 0
2075#define	MC_CMD_WORKAROUND_BUG17230 0x1 /* enum */
2076#define	MC_CMD_WORKAROUND_IN_ENABLED_OFST 4
2077
2078/* MC_CMD_WORKAROUND_OUT msgresponse */
2079#define	MC_CMD_WORKAROUND_OUT_LEN 0
2080
2081
2082/***********************************/
2083/* MC_CMD_GET_PHY_MEDIA_INFO
2084 * Read media-specific data from PHY.
2085 */
2086#define	MC_CMD_GET_PHY_MEDIA_INFO  0x4b
2087
2088/* MC_CMD_GET_PHY_MEDIA_INFO_IN msgrequest */
2089#define	MC_CMD_GET_PHY_MEDIA_INFO_IN_LEN 4
2090#define	MC_CMD_GET_PHY_MEDIA_INFO_IN_PAGE_OFST 0
2091
2092/* MC_CMD_GET_PHY_MEDIA_INFO_OUT msgresponse */
2093#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_LENMIN 5
2094#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_LENMAX 255
2095#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_LEN(num) (4+1*(num))
2096#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATALEN_OFST 0
2097#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_OFST 4
2098#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_LEN 1
2099#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_MINNUM 1
2100#define	MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_MAXNUM 251
2101
2102
2103/***********************************/
2104/* MC_CMD_NVRAM_TEST
2105 * Test a particular NVRAM partition.
2106 */
2107#define	MC_CMD_NVRAM_TEST  0x4c
2108
2109/* MC_CMD_NVRAM_TEST_IN msgrequest */
2110#define	MC_CMD_NVRAM_TEST_IN_LEN 4
2111#define	MC_CMD_NVRAM_TEST_IN_TYPE_OFST 0
2112/*            Enum values, see field(s): */
2113/*               MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
2114
2115/* MC_CMD_NVRAM_TEST_OUT msgresponse */
2116#define	MC_CMD_NVRAM_TEST_OUT_LEN 4
2117#define	MC_CMD_NVRAM_TEST_OUT_RESULT_OFST 0
2118#define	MC_CMD_NVRAM_TEST_PASS 0x0 /* enum */
2119#define	MC_CMD_NVRAM_TEST_FAIL 0x1 /* enum */
2120#define	MC_CMD_NVRAM_TEST_NOTSUPP 0x2 /* enum */
2121
2122
2123/***********************************/
2124/* MC_CMD_MRSFP_TWEAK
2125 * Read status and/or set parameters for the 'mrsfp' driver.
2126 */
2127#define	MC_CMD_MRSFP_TWEAK  0x4d
2128
2129/* MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG msgrequest */
2130#define	MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_LEN 16
2131#define	MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_TXEQ_LEVEL_OFST 0
2132#define	MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_TXEQ_DT_CFG_OFST 4
2133#define	MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_RXEQ_BOOST_OFST 8
2134#define	MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_RXEQ_DT_CFG_OFST 12
2135
2136/* MC_CMD_MRSFP_TWEAK_IN_READ_ONLY msgrequest */
2137#define	MC_CMD_MRSFP_TWEAK_IN_READ_ONLY_LEN 0
2138
2139/* MC_CMD_MRSFP_TWEAK_OUT msgresponse */
2140#define	MC_CMD_MRSFP_TWEAK_OUT_LEN 12
2141#define	MC_CMD_MRSFP_TWEAK_OUT_IOEXP_INPUTS_OFST 0
2142#define	MC_CMD_MRSFP_TWEAK_OUT_IOEXP_OUTPUTS_OFST 4
2143#define	MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_OFST 8
2144#define	MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_OUT 0x0 /* enum */
2145#define	MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_IN 0x1 /* enum */
2146
2147
2148/***********************************/
2149/* MC_CMD_SENSOR_SET_LIMS
2150 * Adjusts the sensor limits.
2151 */
2152#define	MC_CMD_SENSOR_SET_LIMS  0x4e
2153
2154/* MC_CMD_SENSOR_SET_LIMS_IN msgrequest */
2155#define	MC_CMD_SENSOR_SET_LIMS_IN_LEN 20
2156#define	MC_CMD_SENSOR_SET_LIMS_IN_SENSOR_OFST 0
2157/*            Enum values, see field(s): */
2158/*               MC_CMD_SENSOR_INFO/MC_CMD_SENSOR_INFO_OUT/MASK */
2159#define	MC_CMD_SENSOR_SET_LIMS_IN_LOW0_OFST 4
2160#define	MC_CMD_SENSOR_SET_LIMS_IN_HI0_OFST 8
2161#define	MC_CMD_SENSOR_SET_LIMS_IN_LOW1_OFST 12
2162#define	MC_CMD_SENSOR_SET_LIMS_IN_HI1_OFST 16
2163
2164/* MC_CMD_SENSOR_SET_LIMS_OUT msgresponse */
2165#define	MC_CMD_SENSOR_SET_LIMS_OUT_LEN 0
2166
2167
2168/***********************************/
2169/* MC_CMD_GET_RESOURCE_LIMITS
2170 */
2171#define	MC_CMD_GET_RESOURCE_LIMITS  0x4f
2172
2173/* MC_CMD_GET_RESOURCE_LIMITS_IN msgrequest */
2174#define	MC_CMD_GET_RESOURCE_LIMITS_IN_LEN 0
2175
2176/* MC_CMD_GET_RESOURCE_LIMITS_OUT msgresponse */
2177#define	MC_CMD_GET_RESOURCE_LIMITS_OUT_LEN 16
2178#define	MC_CMD_GET_RESOURCE_LIMITS_OUT_BUFTBL_OFST 0
2179#define	MC_CMD_GET_RESOURCE_LIMITS_OUT_EVQ_OFST 4
2180#define	MC_CMD_GET_RESOURCE_LIMITS_OUT_RXQ_OFST 8
2181#define	MC_CMD_GET_RESOURCE_LIMITS_OUT_TXQ_OFST 12
2182
2183/* MC_CMD_RESOURCE_SPECIFIER enum */
2184#define	MC_CMD_RESOURCE_INSTANCE_ANY 0xffffffff /* enum */
2185#define	MC_CMD_RESOURCE_INSTANCE_NONE 0xfffffffe /* enum */
2186
2187
2188/***********************************/
2189/* MC_CMD_INIT_EVQ
2190 */
2191#define	MC_CMD_INIT_EVQ  0x50
2192
2193/* MC_CMD_INIT_EVQ_IN msgrequest */
2194#define	MC_CMD_INIT_EVQ_IN_LENMIN 36
2195#define	MC_CMD_INIT_EVQ_IN_LENMAX 540
2196#define	MC_CMD_INIT_EVQ_IN_LEN(num) (28+8*(num))
2197#define	MC_CMD_INIT_EVQ_IN_SIZE_OFST 0
2198#define	MC_CMD_INIT_EVQ_IN_INSTANCE_OFST 4
2199#define	MC_CMD_INIT_EVQ_IN_TMR_LOAD_OFST 8
2200#define	MC_CMD_INIT_EVQ_IN_TMR_RELOAD_OFST 12
2201#define	MC_CMD_INIT_EVQ_IN_FLAGS_OFST 16
2202#define	MC_CMD_INIT_EVQ_IN_FLAG_INTERRUPTING_LBN 0
2203#define	MC_CMD_INIT_EVQ_IN_FLAG_INTERRUPTING_WIDTH 1
2204#define	MC_CMD_INIT_EVQ_IN_FLAG_RPTR_DOS_LBN 1
2205#define	MC_CMD_INIT_EVQ_IN_FLAG_RPTR_DOS_WIDTH 1
2206#define	MC_CMD_INIT_EVQ_IN_TMR_MODE_OFST 20
2207#define	MC_CMD_INIT_EVQ_IN_TMR_MODE_DIS 0x0 /* enum */
2208#define	MC_CMD_INIT_EVQ_IN_TMR_IMMED_START 0x1 /* enum */
2209#define	MC_CMD_INIT_EVQ_IN_TMR_TRIG_START 0x2 /* enum */
2210#define	MC_CMD_INIT_EVQ_IN_TMR_INT_HLDOFF 0x3 /* enum */
2211#define	MC_CMD_INIT_EVQ_IN_TARGET_EVQ_OFST 24
2212#define	MC_CMD_INIT_EVQ_IN_IRQ_NUM_OFST 24
2213#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_OFST 28
2214#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_LEN 8
2215#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_LO_OFST 28
2216#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_HI_OFST 32
2217#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_MINNUM 1
2218#define	MC_CMD_INIT_EVQ_IN_DMA_ADDR_MAXNUM 64
2219
2220/* MC_CMD_INIT_EVQ_OUT msgresponse */
2221#define	MC_CMD_INIT_EVQ_OUT_LEN 4
2222#define	MC_CMD_INIT_EVQ_OUT_IRQ_OFST 0
2223
2224/* QUEUE_CRC_MODE structuredef */
2225#define	QUEUE_CRC_MODE_LEN 1
2226#define	QUEUE_CRC_MODE_MODE_LBN 0
2227#define	QUEUE_CRC_MODE_MODE_WIDTH 4
2228#define	QUEUE_CRC_MODE_NONE  0x0 /* enum */
2229#define	QUEUE_CRC_MODE_FCOE  0x1 /* enum */
2230#define	QUEUE_CRC_MODE_ISCSI_HDR  0x2 /* enum */
2231#define	QUEUE_CRC_MODE_ISCSI  0x3 /* enum */
2232#define	QUEUE_CRC_MODE_FCOIPOE  0x4 /* enum */
2233#define	QUEUE_CRC_MODE_MPA  0x5 /* enum */
2234#define	QUEUE_CRC_MODE_SPARE_LBN 4
2235#define	QUEUE_CRC_MODE_SPARE_WIDTH 4
2236
2237
2238/***********************************/
2239/* MC_CMD_INIT_RXQ
2240 */
2241#define	MC_CMD_INIT_RXQ  0x51
2242
2243/* MC_CMD_INIT_RXQ_IN msgrequest */
2244#define	MC_CMD_INIT_RXQ_IN_LENMIN 32
2245#define	MC_CMD_INIT_RXQ_IN_LENMAX 248
2246#define	MC_CMD_INIT_RXQ_IN_LEN(num) (24+8*(num))
2247#define	MC_CMD_INIT_RXQ_IN_SIZE_OFST 0
2248#define	MC_CMD_INIT_RXQ_IN_TARGET_EVQ_OFST 4
2249#define	MC_CMD_INIT_RXQ_IN_LABEL_OFST 8
2250#define	MC_CMD_INIT_RXQ_IN_INSTANCE_OFST 12
2251#define	MC_CMD_INIT_RXQ_IN_FLAGS_OFST 16
2252#define	MC_CMD_INIT_RXQ_IN_FLAG_BUFF_MODE_LBN 0
2253#define	MC_CMD_INIT_RXQ_IN_FLAG_BUFF_MODE_WIDTH 1
2254#define	MC_CMD_INIT_RXQ_IN_FLAG_HDR_SPLIT_LBN 1
2255#define	MC_CMD_INIT_RXQ_IN_FLAG_HDR_SPLIT_WIDTH 1
2256#define	MC_CMD_INIT_RXQ_IN_FLAG_PKT_EDIT_LBN 2
2257#define	MC_CMD_INIT_RXQ_IN_FLAG_PKT_EDIT_WIDTH 1
2258#define	MC_CMD_INIT_RXQ_IN_CRC_MODE_LBN 3
2259#define	MC_CMD_INIT_RXQ_IN_CRC_MODE_WIDTH 4
2260#define	MC_CMD_INIT_RXQ_IN_OWNER_ID_OFST 20
2261#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_OFST 24
2262#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_LEN 8
2263#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_LO_OFST 24
2264#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_HI_OFST 28
2265#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_MINNUM 1
2266#define	MC_CMD_INIT_RXQ_IN_DMA_ADDR_MAXNUM 28
2267
2268/* MC_CMD_INIT_RXQ_OUT msgresponse */
2269#define	MC_CMD_INIT_RXQ_OUT_LEN 0
2270
2271
2272/***********************************/
2273/* MC_CMD_INIT_TXQ
2274 */
2275#define	MC_CMD_INIT_TXQ  0x52
2276
2277/* MC_CMD_INIT_TXQ_IN msgrequest */
2278#define	MC_CMD_INIT_TXQ_IN_LENMIN 32
2279#define	MC_CMD_INIT_TXQ_IN_LENMAX 248
2280#define	MC_CMD_INIT_TXQ_IN_LEN(num) (24+8*(num))
2281#define	MC_CMD_INIT_TXQ_IN_SIZE_OFST 0
2282#define	MC_CMD_INIT_TXQ_IN_TARGET_EVQ_OFST 4
2283#define	MC_CMD_INIT_TXQ_IN_LABEL_OFST 8
2284#define	MC_CMD_INIT_TXQ_IN_INSTANCE_OFST 12
2285#define	MC_CMD_INIT_TXQ_IN_FLAGS_OFST 16
2286#define	MC_CMD_INIT_TXQ_IN_FLAG_BUFF_MODE_LBN 0
2287#define	MC_CMD_INIT_TXQ_IN_FLAG_BUFF_MODE_WIDTH 1
2288#define	MC_CMD_INIT_TXQ_IN_FLAG_IP_CSUM_DIS_LBN 1
2289#define	MC_CMD_INIT_TXQ_IN_FLAG_IP_CSUM_DIS_WIDTH 1
2290#define	MC_CMD_INIT_TXQ_IN_FLAG_TCP_CSUM_DIS_LBN 2
2291#define	MC_CMD_INIT_TXQ_IN_FLAG_TCP_CSUM_DIS_WIDTH 1
2292#define	MC_CMD_INIT_TXQ_IN_CRC_MODE_LBN 4
2293#define	MC_CMD_INIT_TXQ_IN_CRC_MODE_WIDTH 4
2294#define	MC_CMD_INIT_TXQ_IN_OWNER_ID_OFST 20
2295#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_OFST 24
2296#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_LEN 8
2297#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_LO_OFST 24
2298#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_HI_OFST 28
2299#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_MINNUM 1
2300#define	MC_CMD_INIT_TXQ_IN_DMA_ADDR_MAXNUM 28
2301
2302/* MC_CMD_INIT_TXQ_OUT msgresponse */
2303#define	MC_CMD_INIT_TXQ_OUT_LEN 0
2304
2305
2306/***********************************/
2307/* MC_CMD_FINI_EVQ
2308 */
2309#define	MC_CMD_FINI_EVQ  0x55
2310
2311/* MC_CMD_FINI_EVQ_IN msgrequest */
2312#define	MC_CMD_FINI_EVQ_IN_LEN 4
2313#define	MC_CMD_FINI_EVQ_IN_INSTANCE_OFST 0
2314
2315/* MC_CMD_FINI_EVQ_OUT msgresponse */
2316#define	MC_CMD_FINI_EVQ_OUT_LEN 0
2317
2318
2319/***********************************/
2320/* MC_CMD_FINI_RXQ
2321 */
2322#define	MC_CMD_FINI_RXQ  0x56
2323
2324/* MC_CMD_FINI_RXQ_IN msgrequest */
2325#define	MC_CMD_FINI_RXQ_IN_LEN 4
2326#define	MC_CMD_FINI_RXQ_IN_INSTANCE_OFST 0
2327
2328/* MC_CMD_FINI_RXQ_OUT msgresponse */
2329#define	MC_CMD_FINI_RXQ_OUT_LEN 0
2330
2331
2332/***********************************/
2333/* MC_CMD_FINI_TXQ
2334 */
2335#define	MC_CMD_FINI_TXQ  0x57
2336
2337/* MC_CMD_FINI_TXQ_IN msgrequest */
2338#define	MC_CMD_FINI_TXQ_IN_LEN 4
2339#define	MC_CMD_FINI_TXQ_IN_INSTANCE_OFST 0
2340
2341/* MC_CMD_FINI_TXQ_OUT msgresponse */
2342#define	MC_CMD_FINI_TXQ_OUT_LEN 0
2343
2344
2345/***********************************/
2346/* MC_CMD_DRIVER_EVENT
2347 */
2348#define	MC_CMD_DRIVER_EVENT  0x5a
2349
2350/* MC_CMD_DRIVER_EVENT_IN msgrequest */
2351#define	MC_CMD_DRIVER_EVENT_IN_LEN 12
2352#define	MC_CMD_DRIVER_EVENT_IN_EVQ_OFST 0
2353#define	MC_CMD_DRIVER_EVENT_IN_DATA_OFST 4
2354#define	MC_CMD_DRIVER_EVENT_IN_DATA_LEN 8
2355#define	MC_CMD_DRIVER_EVENT_IN_DATA_LO_OFST 4
2356#define	MC_CMD_DRIVER_EVENT_IN_DATA_HI_OFST 8
2357
2358
2359/***********************************/
2360/* MC_CMD_PROXY_CMD
2361 */
2362#define	MC_CMD_PROXY_CMD  0x5b
2363
2364/* MC_CMD_PROXY_CMD_IN msgrequest */
2365#define	MC_CMD_PROXY_CMD_IN_LEN 4
2366#define	MC_CMD_PROXY_CMD_IN_TARGET_OFST 0
2367
2368
2369/***********************************/
2370/* MC_CMD_ALLOC_OWNER_IDS
2371 */
2372#define	MC_CMD_ALLOC_OWNER_IDS  0x54
2373
2374/* MC_CMD_ALLOC_OWNER_IDS_IN msgrequest */
2375#define	MC_CMD_ALLOC_OWNER_IDS_IN_LEN 4
2376#define	MC_CMD_ALLOC_OWNER_IDS_IN_NIDS_OFST 0
2377
2378/* MC_CMD_ALLOC_OWNER_IDS_OUT msgresponse */
2379#define	MC_CMD_ALLOC_OWNER_IDS_OUT_LEN 12
2380#define	MC_CMD_ALLOC_OWNER_IDS_OUT_HANDLE_OFST 0
2381#define	MC_CMD_ALLOC_OWNER_IDS_OUT_NIDS_OFST 4
2382#define	MC_CMD_ALLOC_OWNER_IDS_OUT_BASE_OFST 8
2383
2384
2385/***********************************/
2386/* MC_CMD_FREE_OWNER_IDS
2387 */
2388#define	MC_CMD_FREE_OWNER_IDS  0x59
2389
2390/* MC_CMD_FREE_OWNER_IDS_IN msgrequest */
2391#define	MC_CMD_FREE_OWNER_IDS_IN_LEN 4
2392#define	MC_CMD_FREE_OWNER_IDS_IN_HANDLE_OFST 0
2393
2394/* MC_CMD_FREE_OWNER_IDS_OUT msgresponse */
2395#define	MC_CMD_FREE_OWNER_IDS_OUT_LEN 0
2396
2397
2398/***********************************/
2399/* MC_CMD_ALLOC_BUFTBL_CHUNK
2400 */
2401#define	MC_CMD_ALLOC_BUFTBL_CHUNK  0x5c
2402
2403/* MC_CMD_ALLOC_BUFTBL_CHUNK_IN msgrequest */
2404#define	MC_CMD_ALLOC_BUFTBL_CHUNK_IN_LEN 8
2405#define	MC_CMD_ALLOC_BUFTBL_CHUNK_IN_OWNER_OFST 0
2406#define	MC_CMD_ALLOC_BUFTBL_CHUNK_IN_PAGE_SIZE_OFST 4
2407
2408/* MC_CMD_ALLOC_BUFTBL_CHUNK_OUT msgresponse */
2409#define	MC_CMD_ALLOC_BUFTBL_CHUNK_OUT_LEN 12
2410#define	MC_CMD_ALLOC_BUFTBL_CHUNK_OUT_HANDLE_OFST 0
2411#define	MC_CMD_ALLOC_BUFTBL_CHUNK_OUT_NUMENTRIES_OFST 4
2412#define	MC_CMD_ALLOC_BUFTBL_CHUNK_OUT_ID_OFST 8
2413
2414
2415/***********************************/
2416/* MC_CMD_PROGRAM_BUFTBL_ENTRIES
2417 */
2418#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES  0x5d
2419
2420/* MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN msgrequest */
2421#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_LENMIN 20
2422#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_LENMAX 252
2423#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_LEN(num) (12+8*(num))
2424#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_HANDLE_OFST 0
2425#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_FIRSTID_OFST 4
2426#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_NUMENTRIES_OFST 8
2427#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_OFST 12
2428#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_LEN 8
2429#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_LO_OFST 12
2430#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_HI_OFST 16
2431#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_MINNUM 1
2432#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_MAXNUM 30
2433
2434/* MC_CMD_PROGRAM_BUFTBL_ENTRIES_OUT msgresponse */
2435#define	MC_CMD_PROGRAM_BUFTBL_ENTRIES_OUT_LEN 0
2436
2437
2438/***********************************/
2439/* MC_CMD_FREE_BUFTBL_CHUNK
2440 */
2441#define	MC_CMD_FREE_BUFTBL_CHUNK  0x5e
2442
2443/* MC_CMD_FREE_BUFTBL_CHUNK_IN msgrequest */
2444#define	MC_CMD_FREE_BUFTBL_CHUNK_IN_LEN 4
2445#define	MC_CMD_FREE_BUFTBL_CHUNK_IN_HANDLE_OFST 0
2446
2447/* MC_CMD_FREE_BUFTBL_CHUNK_OUT msgresponse */
2448#define	MC_CMD_FREE_BUFTBL_CHUNK_OUT_LEN 0
2449
2450
2451/***********************************/
2452/* MC_CMD_GET_PF_COUNT
2453 */
2454#define	MC_CMD_GET_PF_COUNT  0x60
2455
2456/* MC_CMD_GET_PF_COUNT_IN msgrequest */
2457#define	MC_CMD_GET_PF_COUNT_IN_LEN 0
2458
2459/* MC_CMD_GET_PF_COUNT_OUT msgresponse */
2460#define	MC_CMD_GET_PF_COUNT_OUT_LEN 1
2461#define	MC_CMD_GET_PF_COUNT_OUT_PF_COUNT_OFST 0
2462#define	MC_CMD_GET_PF_COUNT_OUT_PF_COUNT_LEN 1
2463
2464
2465/***********************************/
2466/* MC_CMD_FILTER_OP
2467 */
2468#define	MC_CMD_FILTER_OP  0x61
2469
2470/* MC_CMD_FILTER_OP_IN msgrequest */
2471#define	MC_CMD_FILTER_OP_IN_LEN 100
2472#define	MC_CMD_FILTER_OP_IN_OP_OFST 0
2473#define	MC_CMD_FILTER_OP_IN_OP_INSERT  0x0 /* enum */
2474#define	MC_CMD_FILTER_OP_IN_OP_REMOVE  0x1 /* enum */
2475#define	MC_CMD_FILTER_OP_IN_OP_SUBSCRIBE  0x2 /* enum */
2476#define	MC_CMD_FILTER_OP_IN_OP_UNSUBSCRIBE  0x3 /* enum */
2477#define	MC_CMD_FILTER_OP_IN_HANDLE_OFST 4
2478#define	MC_CMD_FILTER_OP_IN_MATCH_FIELDS_OFST 8
2479#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_IP_LBN 0
2480#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_IP_WIDTH 1
2481#define	MC_CMD_FILTER_OP_IN_MATCH_DST_IP_LBN 1
2482#define	MC_CMD_FILTER_OP_IN_MATCH_DST_IP_WIDTH 1
2483#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_MAC_LBN 2
2484#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_MAC_WIDTH 1
2485#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_PORT_LBN 3
2486#define	MC_CMD_FILTER_OP_IN_MATCH_SRC_PORT_WIDTH 1
2487#define	MC_CMD_FILTER_OP_IN_MATCH_DST_MAC_LBN 4
2488#define	MC_CMD_FILTER_OP_IN_MATCH_DST_MAC_WIDTH 1
2489#define	MC_CMD_FILTER_OP_IN_MATCH_DST_PORT_LBN 5
2490#define	MC_CMD_FILTER_OP_IN_MATCH_DST_PORT_WIDTH 1
2491#define	MC_CMD_FILTER_OP_IN_MATCH_ETHER_TYPE_LBN 6
2492#define	MC_CMD_FILTER_OP_IN_MATCH_ETHER_TYPE_WIDTH 1
2493#define	MC_CMD_FILTER_OP_IN_MATCH_INNER_VLAN_LBN 7
2494#define	MC_CMD_FILTER_OP_IN_MATCH_INNER_VLAN_WIDTH 1
2495#define	MC_CMD_FILTER_OP_IN_MATCH_OUTER_VLAN_LBN 8
2496#define	MC_CMD_FILTER_OP_IN_MATCH_OUTER_VLAN_WIDTH 1
2497#define	MC_CMD_FILTER_OP_IN_MATCH_IP_PROTO_LBN 9
2498#define	MC_CMD_FILTER_OP_IN_MATCH_IP_PROTO_WIDTH 1
2499#define	MC_CMD_FILTER_OP_IN_MATCH_FWDEF0_LBN 10
2500#define	MC_CMD_FILTER_OP_IN_MATCH_FWDEF0_WIDTH 1
2501#define	MC_CMD_FILTER_OP_IN_MATCH_FWDEF1_LBN 11
2502#define	MC_CMD_FILTER_OP_IN_MATCH_FWDEF1_WIDTH 1
2503#define	MC_CMD_FILTER_OP_IN_RX_DEST_OFST 12
2504#define	MC_CMD_FILTER_OP_IN_RX_DEST_DROP  0x0 /* enum */
2505#define	MC_CMD_FILTER_OP_IN_RX_DEST_HOST  0x1 /* enum */
2506#define	MC_CMD_FILTER_OP_IN_RX_DEST_MC  0x2 /* enum */
2507#define	MC_CMD_FILTER_OP_IN_RX_DEST_TX0  0x3 /* enum */
2508#define	MC_CMD_FILTER_OP_IN_RX_DEST_TX1  0x4 /* enum */
2509#define	MC_CMD_FILTER_OP_IN_RX_QUEUE_OFST 16
2510#define	MC_CMD_FILTER_OP_IN_RX_FLAGS_OFST 20
2511#define	MC_CMD_FILTER_OP_IN_RX_FLAG_RSS_LBN 0
2512#define	MC_CMD_FILTER_OP_IN_RX_FLAG_RSS_WIDTH 1
2513#define	MC_CMD_FILTER_OP_IN_RSS_CONTEXT_OFST 24
2514#define	MC_CMD_FILTER_OP_IN_TX_DOMAIN_OFST 28
2515#define	MC_CMD_FILTER_OP_IN_TX_DEST_OFST 32
2516#define	MC_CMD_FILTER_OP_IN_TX_DEST_MAC_LBN 0
2517#define	MC_CMD_FILTER_OP_IN_TX_DEST_MAC_WIDTH 1
2518#define	MC_CMD_FILTER_OP_IN_TX_DEST_PM_LBN 1
2519#define	MC_CMD_FILTER_OP_IN_TX_DEST_PM_WIDTH 1
2520#define	MC_CMD_FILTER_OP_IN_SRC_MAC_OFST 36
2521#define	MC_CMD_FILTER_OP_IN_SRC_MAC_LEN 6
2522#define	MC_CMD_FILTER_OP_IN_SRC_PORT_OFST 42
2523#define	MC_CMD_FILTER_OP_IN_SRC_PORT_LEN 2
2524#define	MC_CMD_FILTER_OP_IN_DST_MAC_OFST 44
2525#define	MC_CMD_FILTER_OP_IN_DST_MAC_LEN 6
2526#define	MC_CMD_FILTER_OP_IN_DST_PORT_OFST 50
2527#define	MC_CMD_FILTER_OP_IN_DST_PORT_LEN 2
2528#define	MC_CMD_FILTER_OP_IN_ETHER_TYPE_OFST 52
2529#define	MC_CMD_FILTER_OP_IN_ETHER_TYPE_LEN 2
2530#define	MC_CMD_FILTER_OP_IN_INNER_VLAN_OFST 54
2531#define	MC_CMD_FILTER_OP_IN_INNER_VLAN_LEN 2
2532#define	MC_CMD_FILTER_OP_IN_OUTER_VLAN_OFST 56
2533#define	MC_CMD_FILTER_OP_IN_OUTER_VLAN_LEN 2
2534#define	MC_CMD_FILTER_OP_IN_IP_PROTO_OFST 58
2535#define	MC_CMD_FILTER_OP_IN_IP_PROTO_LEN 2
2536#define	MC_CMD_FILTER_OP_IN_FWDEF0_OFST 60
2537#define	MC_CMD_FILTER_OP_IN_FWDEF1_OFST 64
2538#define	MC_CMD_FILTER_OP_IN_SRC_IP_OFST 68
2539#define	MC_CMD_FILTER_OP_IN_SRC_IP_LEN 16
2540#define	MC_CMD_FILTER_OP_IN_DST_IP_OFST 84
2541#define	MC_CMD_FILTER_OP_IN_DST_IP_LEN 16
2542
2543/* MC_CMD_FILTER_OP_OUT msgresponse */
2544#define	MC_CMD_FILTER_OP_OUT_LEN 8
2545#define	MC_CMD_FILTER_OP_OUT_OP_OFST 0
2546#define	MC_CMD_FILTER_OP_OUT_OP_INSERT  0x0 /* enum */
2547#define	MC_CMD_FILTER_OP_OUT_OP_REMOVE  0x1 /* enum */
2548#define	MC_CMD_FILTER_OP_OUT_OP_SUBSCRIBE  0x2 /* enum */
2549#define	MC_CMD_FILTER_OP_OUT_OP_UNSUBSCRIBE  0x3 /* enum */
2550#define	MC_CMD_FILTER_OP_OUT_HANDLE_OFST 4
2551
2552
2553/***********************************/
2554/* MC_CMD_SET_PF_COUNT
2555 */
2556#define	MC_CMD_SET_PF_COUNT  0x62
2557
2558/* MC_CMD_SET_PF_COUNT_IN msgrequest */
2559#define	MC_CMD_SET_PF_COUNT_IN_LEN 4
2560#define	MC_CMD_SET_PF_COUNT_IN_PF_COUNT_OFST 0
2561
2562/* MC_CMD_SET_PF_COUNT_OUT msgresponse */
2563#define	MC_CMD_SET_PF_COUNT_OUT_LEN 0
2564
2565
2566/***********************************/
2567/* MC_CMD_GET_PORT_ASSIGNMENT
2568 */
2569#define	MC_CMD_GET_PORT_ASSIGNMENT  0x63
2570
2571/* MC_CMD_GET_PORT_ASSIGNMENT_IN msgrequest */
2572#define	MC_CMD_GET_PORT_ASSIGNMENT_IN_LEN 0
2573
2574/* MC_CMD_GET_PORT_ASSIGNMENT_OUT msgresponse */
2575#define	MC_CMD_GET_PORT_ASSIGNMENT_OUT_LEN 4
2576#define	MC_CMD_GET_PORT_ASSIGNMENT_OUT_PORT_OFST 0
2577
2578
2579/***********************************/
2580/* MC_CMD_SET_PORT_ASSIGNMENT
2581 */
2582#define	MC_CMD_SET_PORT_ASSIGNMENT  0x64
2583
2584/* MC_CMD_SET_PORT_ASSIGNMENT_IN msgrequest */
2585#define	MC_CMD_SET_PORT_ASSIGNMENT_IN_LEN 4
2586#define	MC_CMD_SET_PORT_ASSIGNMENT_IN_PORT_OFST 0
2587
2588/* MC_CMD_SET_PORT_ASSIGNMENT_OUT msgresponse */
2589#define	MC_CMD_SET_PORT_ASSIGNMENT_OUT_LEN 0
2590
2591
2592/***********************************/
2593/* MC_CMD_ALLOC_VIS
2594 */
2595#define	MC_CMD_ALLOC_VIS  0x65
2596
2597/* MC_CMD_ALLOC_VIS_IN msgrequest */
2598#define	MC_CMD_ALLOC_VIS_IN_LEN 4
2599#define	MC_CMD_ALLOC_VIS_IN_VI_COUNT_OFST 0
2600
2601/* MC_CMD_ALLOC_VIS_OUT msgresponse */
2602#define	MC_CMD_ALLOC_VIS_OUT_LEN 0
2603
2604
2605/***********************************/
2606/* MC_CMD_FREE_VIS
2607 */
2608#define	MC_CMD_FREE_VIS  0x66
2609
2610/* MC_CMD_FREE_VIS_IN msgrequest */
2611#define	MC_CMD_FREE_VIS_IN_LEN 0
2612
2613/* MC_CMD_FREE_VIS_OUT msgresponse */
2614#define	MC_CMD_FREE_VIS_OUT_LEN 0
2615
2616
2617/***********************************/
2618/* MC_CMD_GET_SRIOV_CFG
2619 */
2620#define	MC_CMD_GET_SRIOV_CFG  0x67
2621
2622/* MC_CMD_GET_SRIOV_CFG_IN msgrequest */
2623#define	MC_CMD_GET_SRIOV_CFG_IN_LEN 0
2624
2625/* MC_CMD_GET_SRIOV_CFG_OUT msgresponse */
2626#define	MC_CMD_GET_SRIOV_CFG_OUT_LEN 20
2627#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_CURRENT_OFST 0
2628#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_MAX_OFST 4
2629#define	MC_CMD_GET_SRIOV_CFG_OUT_FLAGS_OFST 8
2630#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_ENABLED_LBN 0
2631#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_ENABLED_WIDTH 1
2632#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_OFFSET_OFST 12
2633#define	MC_CMD_GET_SRIOV_CFG_OUT_VF_STRIDE_OFST 16
2634
2635
2636/***********************************/
2637/* MC_CMD_SET_SRIOV_CFG
2638 */
2639#define	MC_CMD_SET_SRIOV_CFG  0x68
2640
2641/* MC_CMD_SET_SRIOV_CFG_IN msgrequest */
2642#define	MC_CMD_SET_SRIOV_CFG_IN_LEN 20
2643#define	MC_CMD_SET_SRIOV_CFG_IN_VF_CURRENT_OFST 0
2644#define	MC_CMD_SET_SRIOV_CFG_IN_VF_MAX_OFST 4
2645#define	MC_CMD_SET_SRIOV_CFG_IN_FLAGS_OFST 8
2646#define	MC_CMD_SET_SRIOV_CFG_IN_VF_ENABLED_LBN 0
2647#define	MC_CMD_SET_SRIOV_CFG_IN_VF_ENABLED_WIDTH 1
2648#define	MC_CMD_SET_SRIOV_CFG_IN_VF_OFFSET_OFST 12
2649#define	MC_CMD_SET_SRIOV_CFG_IN_VF_STRIDE_OFST 16
2650
2651/* MC_CMD_SET_SRIOV_CFG_OUT msgresponse */
2652#define	MC_CMD_SET_SRIOV_CFG_OUT_LEN 0
2653
2654
2655/***********************************/
2656/* MC_CMD_GET_VI_COUNT
2657 */
2658#define	MC_CMD_GET_VI_COUNT  0x69
2659
2660/* MC_CMD_GET_VI_COUNT_IN msgrequest */
2661#define	MC_CMD_GET_VI_COUNT_IN_LEN 0
2662
2663/* MC_CMD_GET_VI_COUNT_OUT msgresponse */
2664#define	MC_CMD_GET_VI_COUNT_OUT_LEN 4
2665#define	MC_CMD_GET_VI_COUNT_OUT_VI_COUNT_OFST 0
2666
2667
2668/***********************************/
2669/* MC_CMD_GET_VECTOR_CFG
2670 */
2671#define	MC_CMD_GET_VECTOR_CFG  0x70
2672
2673/* MC_CMD_GET_VECTOR_CFG_IN msgrequest */
2674#define	MC_CMD_GET_VECTOR_CFG_IN_LEN 0
2675
2676/* MC_CMD_GET_VECTOR_CFG_OUT msgresponse */
2677#define	MC_CMD_GET_VECTOR_CFG_OUT_LEN 12
2678#define	MC_CMD_GET_VECTOR_CFG_OUT_VEC_BASE_OFST 0
2679#define	MC_CMD_GET_VECTOR_CFG_OUT_VECS_PER_PF_OFST 4
2680#define	MC_CMD_GET_VECTOR_CFG_OUT_VECS_PER_VF_OFST 8
2681
2682
2683/***********************************/
2684/* MC_CMD_SET_VECTOR_CFG
2685 */
2686#define	MC_CMD_SET_VECTOR_CFG  0x71
2687
2688/* MC_CMD_SET_VECTOR_CFG_IN msgrequest */
2689#define	MC_CMD_SET_VECTOR_CFG_IN_LEN 12
2690#define	MC_CMD_SET_VECTOR_CFG_IN_VEC_BASE_OFST 0
2691#define	MC_CMD_SET_VECTOR_CFG_IN_VECS_PER_PF_OFST 4
2692#define	MC_CMD_SET_VECTOR_CFG_IN_VECS_PER_VF_OFST 8
2693
2694/* MC_CMD_SET_VECTOR_CFG_OUT msgresponse */
2695#define	MC_CMD_SET_VECTOR_CFG_OUT_LEN 0
2696
2697
2698/***********************************/
2699/* MC_CMD_ALLOC_PIOBUF
2700 */
2701#define	MC_CMD_ALLOC_PIOBUF  0x72
2702
2703/* MC_CMD_ALLOC_PIOBUF_IN msgrequest */
2704#define	MC_CMD_ALLOC_PIOBUF_IN_LEN 0
2705
2706/* MC_CMD_ALLOC_PIOBUF_OUT msgresponse */
2707#define	MC_CMD_ALLOC_PIOBUF_OUT_LEN 4
2708#define	MC_CMD_ALLOC_PIOBUF_OUT_PIOBUF_HANDLE_OFST 0
2709
2710
2711/***********************************/
2712/* MC_CMD_FREE_PIOBUF
2713 */
2714#define	MC_CMD_FREE_PIOBUF  0x73
2715
2716/* MC_CMD_FREE_PIOBUF_IN msgrequest */
2717#define	MC_CMD_FREE_PIOBUF_IN_LEN 4
2718#define	MC_CMD_FREE_PIOBUF_IN_PIOBUF_HANDLE_OFST 0
2719
2720/* MC_CMD_FREE_PIOBUF_OUT msgresponse */
2721#define	MC_CMD_FREE_PIOBUF_OUT_LEN 0
2722
2723
2724/***********************************/
2725/* MC_CMD_V2_EXTN
2726 */
2727#define	MC_CMD_V2_EXTN  0x7f
2728
2729/* MC_CMD_V2_EXTN_IN msgrequest */
2730#define	MC_CMD_V2_EXTN_IN_LEN 4
2731#define	MC_CMD_V2_EXTN_IN_EXTENDED_CMD_LBN 0
2732#define	MC_CMD_V2_EXTN_IN_EXTENDED_CMD_WIDTH 15
2733#define	MC_CMD_V2_EXTN_IN_UNUSED_LBN 15
2734#define	MC_CMD_V2_EXTN_IN_UNUSED_WIDTH 1
2735#define	MC_CMD_V2_EXTN_IN_ACTUAL_LEN_LBN 16
2736#define	MC_CMD_V2_EXTN_IN_ACTUAL_LEN_WIDTH 10
2737#define	MC_CMD_V2_EXTN_IN_UNUSED2_LBN 26
2738#define	MC_CMD_V2_EXTN_IN_UNUSED2_WIDTH 6
2739
2740
2741/***********************************/
2742/* MC_CMD_TCM_BUCKET_ALLOC
2743 */
2744#define	MC_CMD_TCM_BUCKET_ALLOC  0x80
2745
2746/* MC_CMD_TCM_BUCKET_ALLOC_IN msgrequest */
2747#define	MC_CMD_TCM_BUCKET_ALLOC_IN_LEN 0
2748
2749/* MC_CMD_TCM_BUCKET_ALLOC_OUT msgresponse */
2750#define	MC_CMD_TCM_BUCKET_ALLOC_OUT_LEN 4
2751#define	MC_CMD_TCM_BUCKET_ALLOC_OUT_BUCKET_OFST 0
2752
2753
2754/***********************************/
2755/* MC_CMD_TCM_BUCKET_FREE
2756 */
2757#define	MC_CMD_TCM_BUCKET_FREE  0x81
2758
2759/* MC_CMD_TCM_BUCKET_FREE_IN msgrequest */
2760#define	MC_CMD_TCM_BUCKET_FREE_IN_LEN 4
2761#define	MC_CMD_TCM_BUCKET_FREE_IN_BUCKET_OFST 0
2762
2763/* MC_CMD_TCM_BUCKET_FREE_OUT msgresponse */
2764#define	MC_CMD_TCM_BUCKET_FREE_OUT_LEN 0
2765
2766
2767/***********************************/
2768/* MC_CMD_TCM_TXQ_INIT
2769 */
2770#define	MC_CMD_TCM_TXQ_INIT  0x82
2771
2772/* MC_CMD_TCM_TXQ_INIT_IN msgrequest */
2773#define	MC_CMD_TCM_TXQ_INIT_IN_LEN 28
2774#define	MC_CMD_TCM_TXQ_INIT_IN_QID_OFST 0
2775#define	MC_CMD_TCM_TXQ_INIT_IN_LABEL_OFST 4
2776#define	MC_CMD_TCM_TXQ_INIT_IN_PQ_FLAGS_OFST 8
2777#define	MC_CMD_TCM_TXQ_INIT_IN_RP_BKT_OFST 12
2778#define	MC_CMD_TCM_TXQ_INIT_IN_MAX_BKT1_OFST 16
2779#define	MC_CMD_TCM_TXQ_INIT_IN_MAX_BKT2_OFST 20
2780#define	MC_CMD_TCM_TXQ_INIT_IN_MIN_BKT_OFST 24
2781
2782/* MC_CMD_TCM_TXQ_INIT_OUT msgresponse */
2783#define	MC_CMD_TCM_TXQ_INIT_OUT_LEN 0
2784
2785#endif /* _SIENA_MC_DRIVER_PCOL_H */
2786