blob: 5f2846c82f2484023074b1b907d40521b9bddefe [file] [log] [blame]
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001/****************************************************************************
2 * Driver for Solarflare Solarstorm network controllers and boards
Ben Hutchings0a6f40c2011-02-25 00:01:34 +00003 * Copyright 2009-2011 Solarflare Communications Inc.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00004 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 as published
7 * by the Free Software Foundation, incorporated herein by reference.
8 */
9
10
11#ifndef MCDI_PCOL_H
12#define MCDI_PCOL_H
13
14/* Values to be written into FMCR_CZ_RESET_STATE_REG to control boot. */
15/* Power-on reset state */
16#define MC_FW_STATE_POR (1)
17/* If this is set in MC_RESET_STATE_REG then it should be
18 * possible to jump into IMEM without loading code from flash. */
19#define MC_FW_WARM_BOOT_OK (2)
20/* The MC main image has started to boot. */
21#define MC_FW_STATE_BOOTING (4)
22/* The Scheduler has started. */
23#define MC_FW_STATE_SCHED (8)
24
Ben Hutchings05a93202011-12-20 00:44:06 +000025/* Siena MC shared memmory offsets */
26/* The 'doorbell' addresses are hard-wired to alert the MC when written */
27#define MC_SMEM_P0_DOORBELL_OFST 0x000
28#define MC_SMEM_P1_DOORBELL_OFST 0x004
29/* The rest of these are firmware-defined */
30#define MC_SMEM_P0_PDU_OFST 0x008
31#define MC_SMEM_P1_PDU_OFST 0x108
32#define MC_SMEM_PDU_LEN 0x100
33#define MC_SMEM_P0_PTP_TIME_OFST 0x7f0
34#define MC_SMEM_P0_STATUS_OFST 0x7f8
35#define MC_SMEM_P1_STATUS_OFST 0x7fc
36
Steve Hodgsonf0d37f42009-11-29 15:15:07 +000037/* Values to be written to the per-port status dword in shared
38 * memory on reboot and assert */
39#define MC_STATUS_DWORD_REBOOT (0xb007b007)
40#define MC_STATUS_DWORD_ASSERT (0xdeaddead)
41
42/* The current version of the MCDI protocol.
43 *
44 * Note that the ROM burnt into the card only talks V0, so at the very
45 * least every driver must support version 0 and MCDI_PCOL_VERSION
46 */
47#define MCDI_PCOL_VERSION 1
48
Ben Hutchings05a93202011-12-20 00:44:06 +000049/* Unused commands: 0x23, 0x27, 0x30, 0x31 */
50
Ben Hutchings1aa8b472012-07-10 10:56:59 +000051/* MCDI version 1
Steve Hodgsonf0d37f42009-11-29 15:15:07 +000052 *
53 * Each MCDI request starts with an MCDI_HEADER, which is a 32byte
54 * structure, filled in by the client.
55 *
56 * 0 7 8 16 20 22 23 24 31
57 * | CODE | R | LEN | SEQ | Rsvd | E | R | XFLAGS |
58 * | | |
59 * | | \--- Response
60 * | \------- Error
61 * \------------------------------ Resync (always set)
62 *
63 * The client writes it's request into MC shared memory, and rings the
64 * doorbell. Each request is completed by either by the MC writting
65 * back into shared memory, or by writting out an event.
66 *
67 * All MCDI commands support completion by shared memory response. Each
68 * request may also contain additional data (accounted for by HEADER.LEN),
69 * and some response's may also contain additional data (again, accounted
70 * for by HEADER.LEN).
71 *
72 * Some MCDI commands support completion by event, in which any associated
73 * response data is included in the event.
74 *
75 * The protocol requires one response to be delivered for every request, a
76 * request should not be sent unless the response for the previous request
77 * has been received (either by polling shared memory, or by receiving
78 * an event).
79 */
80
81/** Request/Response structure */
82#define MCDI_HEADER_OFST 0
83#define MCDI_HEADER_CODE_LBN 0
84#define MCDI_HEADER_CODE_WIDTH 7
85#define MCDI_HEADER_RESYNC_LBN 7
86#define MCDI_HEADER_RESYNC_WIDTH 1
87#define MCDI_HEADER_DATALEN_LBN 8
88#define MCDI_HEADER_DATALEN_WIDTH 8
89#define MCDI_HEADER_SEQ_LBN 16
90#define MCDI_HEADER_RSVD_LBN 20
91#define MCDI_HEADER_RSVD_WIDTH 2
92#define MCDI_HEADER_SEQ_WIDTH 4
93#define MCDI_HEADER_ERROR_LBN 22
94#define MCDI_HEADER_ERROR_WIDTH 1
95#define MCDI_HEADER_RESPONSE_LBN 23
96#define MCDI_HEADER_RESPONSE_WIDTH 1
97#define MCDI_HEADER_XFLAGS_LBN 24
98#define MCDI_HEADER_XFLAGS_WIDTH 8
99/* Request response using event */
100#define MCDI_HEADER_XFLAGS_EVREQ 0x01
101
102/* Maximum number of payload bytes */
Ben Hutchingsd0c2ee92013-08-20 15:47:12 +0100103#define MCDI_CTL_SDU_LEN_MAX_V1 0xfc
104
105#define MCDI_CTL_SDU_LEN_MAX MCDI_CTL_SDU_LEN_MAX_V1
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000106
107/* The MC can generate events for two reasons:
108 * - To complete a shared memory request if XFLAGS_EVREQ was set
109 * - As a notification (link state, i2c event), controlled
110 * via MC_CMD_LOG_CTRL
111 *
112 * Both events share a common structure:
113 *
114 * 0 32 33 36 44 52 60
115 * | Data | Cont | Level | Src | Code | Rsvd |
116 * |
117 * \ There is another event pending in this notification
118 *
119 * If Code==CMDDONE, then the fields are further interpreted as:
120 *
Lucas De Marchi25985ed2011-03-30 22:57:33 -0300121 * - LEVEL==INFO Command succeeded
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000122 * - LEVEL==ERR Command failed
123 *
124 * 0 8 16 24 32
125 * | Seq | Datalen | Errno | Rsvd |
126 *
127 * These fields are taken directly out of the standard MCDI header, i.e.,
128 * LEVEL==ERR, Datalen == 0 => Reboot
129 *
130 * Events can be squirted out of the UART (using LOG_CTRL) without a
131 * MCDI header. An event can be distinguished from a MCDI response by
132 * examining the first byte which is 0xc0. This corresponds to the
133 * non-existent MCDI command MC_CMD_DEBUG_LOG.
134 *
135 * 0 7 8
136 * | command | Resync | = 0xc0
137 *
138 * Since the event is written in big-endian byte order, this works
139 * providing bits 56-63 of the event are 0xc0.
140 *
141 * 56 60 63
142 * | Rsvd | Code | = 0xc0
143 *
144 * Which means for convenience the event code is 0xc for all MC
145 * generated events.
146 */
147#define FSE_AZ_EV_CODE_MCDI_EVRESPONSE 0xc
148
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000149
150/* Non-existent command target */
151#define MC_CMD_ERR_ENOENT 2
152/* assert() has killed the MC */
153#define MC_CMD_ERR_EINTR 4
154/* Caller does not hold required locks */
155#define MC_CMD_ERR_EACCES 13
156/* Resource is currently unavailable (e.g. lock contention) */
157#define MC_CMD_ERR_EBUSY 16
158/* Invalid argument to target */
159#define MC_CMD_ERR_EINVAL 22
160/* Non-recursive resource is already acquired */
161#define MC_CMD_ERR_EDEADLK 35
162/* Operation not implemented */
163#define MC_CMD_ERR_ENOSYS 38
164/* Operation timed out */
165#define MC_CMD_ERR_ETIME 62
166
167#define MC_CMD_ERR_CODE_OFST 0
168
Ben Hutchings05a93202011-12-20 00:44:06 +0000169/* We define 8 "escape" commands to allow
170 for command number space extension */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000171
Ben Hutchings05a93202011-12-20 00:44:06 +0000172#define MC_CMD_CMD_SPACE_ESCAPE_0 0x78
173#define MC_CMD_CMD_SPACE_ESCAPE_1 0x79
174#define MC_CMD_CMD_SPACE_ESCAPE_2 0x7A
175#define MC_CMD_CMD_SPACE_ESCAPE_3 0x7B
176#define MC_CMD_CMD_SPACE_ESCAPE_4 0x7C
177#define MC_CMD_CMD_SPACE_ESCAPE_5 0x7D
178#define MC_CMD_CMD_SPACE_ESCAPE_6 0x7E
179#define MC_CMD_CMD_SPACE_ESCAPE_7 0x7F
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000180
181/* Vectors in the boot ROM */
182/* Point to the copycode entry point. */
183#define MC_BOOTROM_COPYCODE_VEC (0x7f4)
184/* Points to the recovery mode entry point. */
185#define MC_BOOTROM_NOFLASH_VEC (0x7f8)
186
Ben Hutchings05a93202011-12-20 00:44:06 +0000187/* The command set exported by the boot ROM (MCDI v0) */
188#define MC_CMD_GET_VERSION_V0_SUPPORTED_FUNCS { \
189 (1 << MC_CMD_READ32) | \
190 (1 << MC_CMD_WRITE32) | \
191 (1 << MC_CMD_COPYCODE) | \
192 (1 << MC_CMD_GET_VERSION), \
193 0, 0, 0 }
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000194
Ben Hutchings05a93202011-12-20 00:44:06 +0000195#define MC_CMD_SENSOR_INFO_OUT_OFFSET_OFST(_x) \
196 (MC_CMD_SENSOR_ENTRY_OFST + (_x))
197
198#define MC_CMD_DBI_WRITE_IN_ADDRESS_OFST(n) \
199 (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST + \
200 MC_CMD_DBIWROP_TYPEDEF_ADDRESS_OFST + \
201 (n) * MC_CMD_DBIWROP_TYPEDEF_LEN)
202
203#define MC_CMD_DBI_WRITE_IN_BYTE_MASK_OFST(n) \
204 (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST + \
205 MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_OFST + \
206 (n) * MC_CMD_DBIWROP_TYPEDEF_LEN)
207
208#define MC_CMD_DBI_WRITE_IN_VALUE_OFST(n) \
209 (MC_CMD_DBI_WRITE_IN_DBIWROP_OFST + \
210 MC_CMD_DBIWROP_TYPEDEF_VALUE_OFST + \
211 (n) * MC_CMD_DBIWROP_TYPEDEF_LEN)
212
213
214/* MCDI_EVENT structuredef */
215#define MCDI_EVENT_LEN 8
216#define MCDI_EVENT_CONT_LBN 32
217#define MCDI_EVENT_CONT_WIDTH 1
218#define MCDI_EVENT_LEVEL_LBN 33
219#define MCDI_EVENT_LEVEL_WIDTH 3
220#define MCDI_EVENT_LEVEL_INFO 0x0 /* enum */
221#define MCDI_EVENT_LEVEL_WARN 0x1 /* enum */
222#define MCDI_EVENT_LEVEL_ERR 0x2 /* enum */
223#define MCDI_EVENT_LEVEL_FATAL 0x3 /* enum */
224#define MCDI_EVENT_DATA_OFST 0
225#define MCDI_EVENT_CMDDONE_SEQ_LBN 0
226#define MCDI_EVENT_CMDDONE_SEQ_WIDTH 8
227#define MCDI_EVENT_CMDDONE_DATALEN_LBN 8
228#define MCDI_EVENT_CMDDONE_DATALEN_WIDTH 8
229#define MCDI_EVENT_CMDDONE_ERRNO_LBN 16
230#define MCDI_EVENT_CMDDONE_ERRNO_WIDTH 8
231#define MCDI_EVENT_LINKCHANGE_LP_CAP_LBN 0
232#define MCDI_EVENT_LINKCHANGE_LP_CAP_WIDTH 16
233#define MCDI_EVENT_LINKCHANGE_SPEED_LBN 16
234#define MCDI_EVENT_LINKCHANGE_SPEED_WIDTH 4
235#define MCDI_EVENT_LINKCHANGE_SPEED_100M 0x1 /* enum */
236#define MCDI_EVENT_LINKCHANGE_SPEED_1G 0x2 /* enum */
237#define MCDI_EVENT_LINKCHANGE_SPEED_10G 0x3 /* enum */
238#define MCDI_EVENT_LINKCHANGE_FCNTL_LBN 20
239#define MCDI_EVENT_LINKCHANGE_FCNTL_WIDTH 4
240#define MCDI_EVENT_LINKCHANGE_LINK_FLAGS_LBN 24
241#define MCDI_EVENT_LINKCHANGE_LINK_FLAGS_WIDTH 8
242#define MCDI_EVENT_SENSOREVT_MONITOR_LBN 0
243#define MCDI_EVENT_SENSOREVT_MONITOR_WIDTH 8
244#define MCDI_EVENT_SENSOREVT_STATE_LBN 8
245#define MCDI_EVENT_SENSOREVT_STATE_WIDTH 8
246#define MCDI_EVENT_SENSOREVT_VALUE_LBN 16
247#define MCDI_EVENT_SENSOREVT_VALUE_WIDTH 16
248#define MCDI_EVENT_FWALERT_DATA_LBN 8
249#define MCDI_EVENT_FWALERT_DATA_WIDTH 24
250#define MCDI_EVENT_FWALERT_REASON_LBN 0
251#define MCDI_EVENT_FWALERT_REASON_WIDTH 8
252#define MCDI_EVENT_FWALERT_REASON_SRAM_ACCESS 0x1 /* enum */
253#define MCDI_EVENT_FLR_VF_LBN 0
254#define MCDI_EVENT_FLR_VF_WIDTH 8
255#define MCDI_EVENT_TX_ERR_TXQ_LBN 0
256#define MCDI_EVENT_TX_ERR_TXQ_WIDTH 12
257#define MCDI_EVENT_TX_ERR_TYPE_LBN 12
258#define MCDI_EVENT_TX_ERR_TYPE_WIDTH 4
259#define MCDI_EVENT_TX_ERR_DL_FAIL 0x1 /* enum */
260#define MCDI_EVENT_TX_ERR_NO_EOP 0x2 /* enum */
261#define MCDI_EVENT_TX_ERR_2BIG 0x3 /* enum */
262#define MCDI_EVENT_TX_ERR_INFO_LBN 16
263#define MCDI_EVENT_TX_ERR_INFO_WIDTH 16
264#define MCDI_EVENT_TX_FLUSH_TXQ_LBN 0
265#define MCDI_EVENT_TX_FLUSH_TXQ_WIDTH 12
266#define MCDI_EVENT_PTP_ERR_TYPE_LBN 0
267#define MCDI_EVENT_PTP_ERR_TYPE_WIDTH 8
268#define MCDI_EVENT_PTP_ERR_PLL_LOST 0x1 /* enum */
269#define MCDI_EVENT_PTP_ERR_FILTER 0x2 /* enum */
270#define MCDI_EVENT_PTP_ERR_FIFO 0x3 /* enum */
271#define MCDI_EVENT_PTP_ERR_QUEUE 0x4 /* enum */
272#define MCDI_EVENT_DATA_LBN 0
273#define MCDI_EVENT_DATA_WIDTH 32
274#define MCDI_EVENT_SRC_LBN 36
275#define MCDI_EVENT_SRC_WIDTH 8
276#define MCDI_EVENT_EV_CODE_LBN 60
277#define MCDI_EVENT_EV_CODE_WIDTH 4
278#define MCDI_EVENT_CODE_LBN 44
279#define MCDI_EVENT_CODE_WIDTH 8
280#define MCDI_EVENT_CODE_BADSSERT 0x1 /* enum */
281#define MCDI_EVENT_CODE_PMNOTICE 0x2 /* enum */
282#define MCDI_EVENT_CODE_CMDDONE 0x3 /* enum */
283#define MCDI_EVENT_CODE_LINKCHANGE 0x4 /* enum */
284#define MCDI_EVENT_CODE_SENSOREVT 0x5 /* enum */
285#define MCDI_EVENT_CODE_SCHEDERR 0x6 /* enum */
286#define MCDI_EVENT_CODE_REBOOT 0x7 /* enum */
287#define MCDI_EVENT_CODE_MAC_STATS_DMA 0x8 /* enum */
288#define MCDI_EVENT_CODE_FWALERT 0x9 /* enum */
289#define MCDI_EVENT_CODE_FLR 0xa /* enum */
290#define MCDI_EVENT_CODE_TX_ERR 0xb /* enum */
291#define MCDI_EVENT_CODE_TX_FLUSH 0xc /* enum */
292#define MCDI_EVENT_CODE_PTP_RX 0xd /* enum */
293#define MCDI_EVENT_CODE_PTP_FAULT 0xe /* enum */
Stuart Hodgson7c236c42012-09-03 11:09:36 +0100294#define MCDI_EVENT_CODE_PTP_PPS 0xf /* enum */
Ben Hutchings05a93202011-12-20 00:44:06 +0000295#define MCDI_EVENT_CMDDONE_DATA_OFST 0
296#define MCDI_EVENT_CMDDONE_DATA_LBN 0
297#define MCDI_EVENT_CMDDONE_DATA_WIDTH 32
298#define MCDI_EVENT_LINKCHANGE_DATA_OFST 0
299#define MCDI_EVENT_LINKCHANGE_DATA_LBN 0
300#define MCDI_EVENT_LINKCHANGE_DATA_WIDTH 32
301#define MCDI_EVENT_SENSOREVT_DATA_OFST 0
302#define MCDI_EVENT_SENSOREVT_DATA_LBN 0
303#define MCDI_EVENT_SENSOREVT_DATA_WIDTH 32
304#define MCDI_EVENT_MAC_STATS_DMA_GENERATION_OFST 0
305#define MCDI_EVENT_MAC_STATS_DMA_GENERATION_LBN 0
306#define MCDI_EVENT_MAC_STATS_DMA_GENERATION_WIDTH 32
307#define MCDI_EVENT_TX_ERR_DATA_OFST 0
308#define MCDI_EVENT_TX_ERR_DATA_LBN 0
309#define MCDI_EVENT_TX_ERR_DATA_WIDTH 32
310#define MCDI_EVENT_PTP_SECONDS_OFST 0
311#define MCDI_EVENT_PTP_SECONDS_LBN 0
312#define MCDI_EVENT_PTP_SECONDS_WIDTH 32
313#define MCDI_EVENT_PTP_NANOSECONDS_OFST 0
314#define MCDI_EVENT_PTP_NANOSECONDS_LBN 0
315#define MCDI_EVENT_PTP_NANOSECONDS_WIDTH 32
316#define MCDI_EVENT_PTP_UUID_OFST 0
317#define MCDI_EVENT_PTP_UUID_LBN 0
318#define MCDI_EVENT_PTP_UUID_WIDTH 32
319
320
321/***********************************/
322/* MC_CMD_READ32
323 * Read multiple 32byte words from MC memory.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000324 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000325#define MC_CMD_READ32 0x1
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000326
Ben Hutchings05a93202011-12-20 00:44:06 +0000327/* MC_CMD_READ32_IN msgrequest */
328#define MC_CMD_READ32_IN_LEN 8
329#define MC_CMD_READ32_IN_ADDR_OFST 0
330#define MC_CMD_READ32_IN_NUMWORDS_OFST 4
331
332/* MC_CMD_READ32_OUT msgresponse */
333#define MC_CMD_READ32_OUT_LENMIN 4
334#define MC_CMD_READ32_OUT_LENMAX 252
335#define MC_CMD_READ32_OUT_LEN(num) (0+4*(num))
336#define MC_CMD_READ32_OUT_BUFFER_OFST 0
337#define MC_CMD_READ32_OUT_BUFFER_LEN 4
338#define MC_CMD_READ32_OUT_BUFFER_MINNUM 1
339#define MC_CMD_READ32_OUT_BUFFER_MAXNUM 63
340
341
342/***********************************/
343/* MC_CMD_WRITE32
344 * Write multiple 32byte words to MC memory.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000345 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000346#define MC_CMD_WRITE32 0x2
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000347
Ben Hutchings05a93202011-12-20 00:44:06 +0000348/* MC_CMD_WRITE32_IN msgrequest */
349#define MC_CMD_WRITE32_IN_LENMIN 8
350#define MC_CMD_WRITE32_IN_LENMAX 252
351#define MC_CMD_WRITE32_IN_LEN(num) (4+4*(num))
352#define MC_CMD_WRITE32_IN_ADDR_OFST 0
353#define MC_CMD_WRITE32_IN_BUFFER_OFST 4
354#define MC_CMD_WRITE32_IN_BUFFER_LEN 4
355#define MC_CMD_WRITE32_IN_BUFFER_MINNUM 1
356#define MC_CMD_WRITE32_IN_BUFFER_MAXNUM 62
357
358/* MC_CMD_WRITE32_OUT msgresponse */
359#define MC_CMD_WRITE32_OUT_LEN 0
360
361
362/***********************************/
363/* MC_CMD_COPYCODE
364 * Copy MC code between two locations and jump.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000365 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000366#define MC_CMD_COPYCODE 0x3
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000367
Ben Hutchings05a93202011-12-20 00:44:06 +0000368/* MC_CMD_COPYCODE_IN msgrequest */
369#define MC_CMD_COPYCODE_IN_LEN 16
370#define MC_CMD_COPYCODE_IN_SRC_ADDR_OFST 0
371#define MC_CMD_COPYCODE_IN_DEST_ADDR_OFST 4
372#define MC_CMD_COPYCODE_IN_NUMWORDS_OFST 8
373#define MC_CMD_COPYCODE_IN_JUMP_OFST 12
374#define MC_CMD_COPYCODE_JUMP_NONE 0x1 /* enum */
375
376/* MC_CMD_COPYCODE_OUT msgresponse */
377#define MC_CMD_COPYCODE_OUT_LEN 0
378
379
380/***********************************/
381/* MC_CMD_SET_FUNC
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000382 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000383#define MC_CMD_SET_FUNC 0x4
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000384
Ben Hutchings05a93202011-12-20 00:44:06 +0000385/* MC_CMD_SET_FUNC_IN msgrequest */
386#define MC_CMD_SET_FUNC_IN_LEN 4
387#define MC_CMD_SET_FUNC_IN_FUNC_OFST 0
388
389/* MC_CMD_SET_FUNC_OUT msgresponse */
390#define MC_CMD_SET_FUNC_OUT_LEN 0
391
392
393/***********************************/
394/* MC_CMD_GET_BOOT_STATUS
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000395 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000396#define MC_CMD_GET_BOOT_STATUS 0x5
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000397
Ben Hutchings05a93202011-12-20 00:44:06 +0000398/* MC_CMD_GET_BOOT_STATUS_IN msgrequest */
399#define MC_CMD_GET_BOOT_STATUS_IN_LEN 0
400
401/* MC_CMD_GET_BOOT_STATUS_OUT msgresponse */
402#define MC_CMD_GET_BOOT_STATUS_OUT_LEN 8
403#define MC_CMD_GET_BOOT_STATUS_OUT_BOOT_OFFSET_OFST 0
404#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_OFST 4
405#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_WATCHDOG_LBN 0
406#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_WATCHDOG_WIDTH 1
407#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_PRIMARY_LBN 1
408#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_PRIMARY_WIDTH 1
409#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_BACKUP_LBN 2
410#define MC_CMD_GET_BOOT_STATUS_OUT_FLAGS_BACKUP_WIDTH 1
411
412
413/***********************************/
414/* MC_CMD_GET_ASSERTS
415 * Get and clear any assertion status.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000416 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000417#define MC_CMD_GET_ASSERTS 0x6
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000418
Ben Hutchings05a93202011-12-20 00:44:06 +0000419/* MC_CMD_GET_ASSERTS_IN msgrequest */
420#define MC_CMD_GET_ASSERTS_IN_LEN 4
421#define MC_CMD_GET_ASSERTS_IN_CLEAR_OFST 0
422
423/* MC_CMD_GET_ASSERTS_OUT msgresponse */
424#define MC_CMD_GET_ASSERTS_OUT_LEN 140
425#define MC_CMD_GET_ASSERTS_OUT_GLOBAL_FLAGS_OFST 0
426#define MC_CMD_GET_ASSERTS_FLAGS_NO_FAILS 0x1 /* enum */
427#define MC_CMD_GET_ASSERTS_FLAGS_SYS_FAIL 0x2 /* enum */
428#define MC_CMD_GET_ASSERTS_FLAGS_THR_FAIL 0x3 /* enum */
429#define MC_CMD_GET_ASSERTS_FLAGS_WDOG_FIRED 0x4 /* enum */
430#define MC_CMD_GET_ASSERTS_OUT_SAVED_PC_OFFS_OFST 4
431#define MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_OFST 8
432#define MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_LEN 4
433#define MC_CMD_GET_ASSERTS_OUT_GP_REGS_OFFS_NUM 31
434#define MC_CMD_GET_ASSERTS_OUT_THREAD_OFFS_OFST 132
435#define MC_CMD_GET_ASSERTS_OUT_RESERVED_OFST 136
436
437
438/***********************************/
439/* MC_CMD_LOG_CTRL
440 * Configure the output stream for various events and messages.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000441 */
Ben Hutchings05a93202011-12-20 00:44:06 +0000442#define MC_CMD_LOG_CTRL 0x7
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000443
Ben Hutchings05a93202011-12-20 00:44:06 +0000444/* MC_CMD_LOG_CTRL_IN msgrequest */
445#define MC_CMD_LOG_CTRL_IN_LEN 8
446#define MC_CMD_LOG_CTRL_IN_LOG_DEST_OFST 0
447#define MC_CMD_LOG_CTRL_IN_LOG_DEST_UART 0x1 /* enum */
448#define MC_CMD_LOG_CTRL_IN_LOG_DEST_EVQ 0x2 /* enum */
449#define MC_CMD_LOG_CTRL_IN_LOG_DEST_EVQ_OFST 4
450
451/* MC_CMD_LOG_CTRL_OUT msgresponse */
452#define MC_CMD_LOG_CTRL_OUT_LEN 0
453
454
455/***********************************/
456/* MC_CMD_GET_VERSION
457 * Get version information about the MC firmware.
458 */
459#define MC_CMD_GET_VERSION 0x8
460
461/* MC_CMD_GET_VERSION_IN msgrequest */
462#define MC_CMD_GET_VERSION_IN_LEN 0
463
464/* MC_CMD_GET_VERSION_V0_OUT msgresponse */
465#define MC_CMD_GET_VERSION_V0_OUT_LEN 4
466#define MC_CMD_GET_VERSION_OUT_FIRMWARE_OFST 0
467#define MC_CMD_GET_VERSION_OUT_FIRMWARE_ANY 0xffffffff /* enum */
468#define MC_CMD_GET_VERSION_OUT_FIRMWARE_BOOTROM 0xb0070000 /* enum */
469
470/* MC_CMD_GET_VERSION_OUT msgresponse */
471#define MC_CMD_GET_VERSION_OUT_LEN 32
472/* MC_CMD_GET_VERSION_OUT_FIRMWARE_OFST 0 */
473/* Enum values, see field(s): */
474/* MC_CMD_GET_VERSION_V0_OUT/MC_CMD_GET_VERSION_OUT_FIRMWARE */
475#define MC_CMD_GET_VERSION_OUT_PCOL_OFST 4
476#define MC_CMD_GET_VERSION_OUT_SUPPORTED_FUNCS_OFST 8
477#define MC_CMD_GET_VERSION_OUT_SUPPORTED_FUNCS_LEN 16
478#define MC_CMD_GET_VERSION_OUT_VERSION_OFST 24
479#define MC_CMD_GET_VERSION_OUT_VERSION_LEN 8
480#define MC_CMD_GET_VERSION_OUT_VERSION_LO_OFST 24
481#define MC_CMD_GET_VERSION_OUT_VERSION_HI_OFST 28
482
483
484/***********************************/
485/* MC_CMD_GET_FPGAREG
486 * Read multiple bytes from PTP FPGA.
487 */
488#define MC_CMD_GET_FPGAREG 0x9
489
490/* MC_CMD_GET_FPGAREG_IN msgrequest */
491#define MC_CMD_GET_FPGAREG_IN_LEN 8
492#define MC_CMD_GET_FPGAREG_IN_ADDR_OFST 0
493#define MC_CMD_GET_FPGAREG_IN_NUMBYTES_OFST 4
494
495/* MC_CMD_GET_FPGAREG_OUT msgresponse */
496#define MC_CMD_GET_FPGAREG_OUT_LENMIN 1
Ben Hutchings576eda82012-09-19 02:46:37 +0100497#define MC_CMD_GET_FPGAREG_OUT_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +0000498#define MC_CMD_GET_FPGAREG_OUT_LEN(num) (0+1*(num))
499#define MC_CMD_GET_FPGAREG_OUT_BUFFER_OFST 0
500#define MC_CMD_GET_FPGAREG_OUT_BUFFER_LEN 1
501#define MC_CMD_GET_FPGAREG_OUT_BUFFER_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +0100502#define MC_CMD_GET_FPGAREG_OUT_BUFFER_MAXNUM 252
Ben Hutchings05a93202011-12-20 00:44:06 +0000503
504
505/***********************************/
506/* MC_CMD_PUT_FPGAREG
507 * Write multiple bytes to PTP FPGA.
508 */
509#define MC_CMD_PUT_FPGAREG 0xa
510
511/* MC_CMD_PUT_FPGAREG_IN msgrequest */
512#define MC_CMD_PUT_FPGAREG_IN_LENMIN 5
Ben Hutchings576eda82012-09-19 02:46:37 +0100513#define MC_CMD_PUT_FPGAREG_IN_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +0000514#define MC_CMD_PUT_FPGAREG_IN_LEN(num) (4+1*(num))
515#define MC_CMD_PUT_FPGAREG_IN_ADDR_OFST 0
516#define MC_CMD_PUT_FPGAREG_IN_BUFFER_OFST 4
517#define MC_CMD_PUT_FPGAREG_IN_BUFFER_LEN 1
518#define MC_CMD_PUT_FPGAREG_IN_BUFFER_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +0100519#define MC_CMD_PUT_FPGAREG_IN_BUFFER_MAXNUM 248
Ben Hutchings05a93202011-12-20 00:44:06 +0000520
521/* MC_CMD_PUT_FPGAREG_OUT msgresponse */
522#define MC_CMD_PUT_FPGAREG_OUT_LEN 0
523
524
525/***********************************/
526/* MC_CMD_PTP
527 * Perform PTP operation
528 */
529#define MC_CMD_PTP 0xb
530
531/* MC_CMD_PTP_IN msgrequest */
532#define MC_CMD_PTP_IN_LEN 1
533#define MC_CMD_PTP_IN_OP_OFST 0
534#define MC_CMD_PTP_IN_OP_LEN 1
535#define MC_CMD_PTP_OP_ENABLE 0x1 /* enum */
536#define MC_CMD_PTP_OP_DISABLE 0x2 /* enum */
537#define MC_CMD_PTP_OP_TRANSMIT 0x3 /* enum */
538#define MC_CMD_PTP_OP_READ_NIC_TIME 0x4 /* enum */
539#define MC_CMD_PTP_OP_STATUS 0x5 /* enum */
540#define MC_CMD_PTP_OP_ADJUST 0x6 /* enum */
541#define MC_CMD_PTP_OP_SYNCHRONIZE 0x7 /* enum */
542#define MC_CMD_PTP_OP_MANFTEST_BASIC 0x8 /* enum */
543#define MC_CMD_PTP_OP_MANFTEST_PACKET 0x9 /* enum */
544#define MC_CMD_PTP_OP_RESET_STATS 0xa /* enum */
545#define MC_CMD_PTP_OP_DEBUG 0xb /* enum */
546#define MC_CMD_PTP_OP_MAX 0xc /* enum */
547
548/* MC_CMD_PTP_IN_ENABLE msgrequest */
549#define MC_CMD_PTP_IN_ENABLE_LEN 16
550#define MC_CMD_PTP_IN_CMD_OFST 0
551#define MC_CMD_PTP_IN_PERIPH_ID_OFST 4
552#define MC_CMD_PTP_IN_ENABLE_QUEUE_OFST 8
553#define MC_CMD_PTP_IN_ENABLE_MODE_OFST 12
554#define MC_CMD_PTP_MODE_V1 0x0 /* enum */
555#define MC_CMD_PTP_MODE_V1_VLAN 0x1 /* enum */
556#define MC_CMD_PTP_MODE_V2 0x2 /* enum */
557#define MC_CMD_PTP_MODE_V2_VLAN 0x3 /* enum */
Laurence Evansc939a312012-11-15 10:56:07 +0000558#define MC_CMD_PTP_MODE_V2_ENHANCED 0x4 /* enum */
Ben Hutchings05a93202011-12-20 00:44:06 +0000559
560/* MC_CMD_PTP_IN_DISABLE msgrequest */
561#define MC_CMD_PTP_IN_DISABLE_LEN 8
562/* MC_CMD_PTP_IN_CMD_OFST 0 */
563/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
564
565/* MC_CMD_PTP_IN_TRANSMIT msgrequest */
566#define MC_CMD_PTP_IN_TRANSMIT_LENMIN 13
Ben Hutchings576eda82012-09-19 02:46:37 +0100567#define MC_CMD_PTP_IN_TRANSMIT_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +0000568#define MC_CMD_PTP_IN_TRANSMIT_LEN(num) (12+1*(num))
569/* MC_CMD_PTP_IN_CMD_OFST 0 */
570/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
571#define MC_CMD_PTP_IN_TRANSMIT_LENGTH_OFST 8
572#define MC_CMD_PTP_IN_TRANSMIT_PACKET_OFST 12
573#define MC_CMD_PTP_IN_TRANSMIT_PACKET_LEN 1
574#define MC_CMD_PTP_IN_TRANSMIT_PACKET_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +0100575#define MC_CMD_PTP_IN_TRANSMIT_PACKET_MAXNUM 240
Ben Hutchings05a93202011-12-20 00:44:06 +0000576
577/* MC_CMD_PTP_IN_READ_NIC_TIME msgrequest */
578#define MC_CMD_PTP_IN_READ_NIC_TIME_LEN 8
579/* MC_CMD_PTP_IN_CMD_OFST 0 */
580/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
581
582/* MC_CMD_PTP_IN_STATUS msgrequest */
583#define MC_CMD_PTP_IN_STATUS_LEN 8
584/* MC_CMD_PTP_IN_CMD_OFST 0 */
585/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
586
587/* MC_CMD_PTP_IN_ADJUST msgrequest */
588#define MC_CMD_PTP_IN_ADJUST_LEN 24
589/* MC_CMD_PTP_IN_CMD_OFST 0 */
590/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
591#define MC_CMD_PTP_IN_ADJUST_FREQ_OFST 8
592#define MC_CMD_PTP_IN_ADJUST_FREQ_LEN 8
593#define MC_CMD_PTP_IN_ADJUST_FREQ_LO_OFST 8
594#define MC_CMD_PTP_IN_ADJUST_FREQ_HI_OFST 12
595#define MC_CMD_PTP_IN_ADJUST_BITS 0x28 /* enum */
596#define MC_CMD_PTP_IN_ADJUST_SECONDS_OFST 16
597#define MC_CMD_PTP_IN_ADJUST_NANOSECONDS_OFST 20
598
599/* MC_CMD_PTP_IN_SYNCHRONIZE msgrequest */
600#define MC_CMD_PTP_IN_SYNCHRONIZE_LEN 20
601/* MC_CMD_PTP_IN_CMD_OFST 0 */
602/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
603#define MC_CMD_PTP_IN_SYNCHRONIZE_NUMTIMESETS_OFST 8
604#define MC_CMD_PTP_IN_SYNCHRONIZE_START_ADDR_OFST 12
605#define MC_CMD_PTP_IN_SYNCHRONIZE_START_ADDR_LEN 8
606#define MC_CMD_PTP_IN_SYNCHRONIZE_START_ADDR_LO_OFST 12
607#define MC_CMD_PTP_IN_SYNCHRONIZE_START_ADDR_HI_OFST 16
608
609/* MC_CMD_PTP_IN_MANFTEST_BASIC msgrequest */
610#define MC_CMD_PTP_IN_MANFTEST_BASIC_LEN 8
611/* MC_CMD_PTP_IN_CMD_OFST 0 */
612/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
613
614/* MC_CMD_PTP_IN_MANFTEST_PACKET msgrequest */
615#define MC_CMD_PTP_IN_MANFTEST_PACKET_LEN 12
616/* MC_CMD_PTP_IN_CMD_OFST 0 */
617/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
618#define MC_CMD_PTP_IN_MANFTEST_PACKET_TEST_ENABLE_OFST 8
619
620/* MC_CMD_PTP_IN_RESET_STATS msgrequest */
621#define MC_CMD_PTP_IN_RESET_STATS_LEN 8
622/* MC_CMD_PTP_IN_CMD_OFST 0 */
623/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
624
625/* MC_CMD_PTP_IN_DEBUG msgrequest */
626#define MC_CMD_PTP_IN_DEBUG_LEN 12
627/* MC_CMD_PTP_IN_CMD_OFST 0 */
628/* MC_CMD_PTP_IN_PERIPH_ID_OFST 4 */
629#define MC_CMD_PTP_IN_DEBUG_DEBUG_PARAM_OFST 8
630
631/* MC_CMD_PTP_OUT msgresponse */
632#define MC_CMD_PTP_OUT_LEN 0
633
634/* MC_CMD_PTP_OUT_TRANSMIT msgresponse */
635#define MC_CMD_PTP_OUT_TRANSMIT_LEN 8
636#define MC_CMD_PTP_OUT_TRANSMIT_SECONDS_OFST 0
637#define MC_CMD_PTP_OUT_TRANSMIT_NANOSECONDS_OFST 4
638
639/* MC_CMD_PTP_OUT_READ_NIC_TIME msgresponse */
640#define MC_CMD_PTP_OUT_READ_NIC_TIME_LEN 8
641#define MC_CMD_PTP_OUT_READ_NIC_TIME_SECONDS_OFST 0
642#define MC_CMD_PTP_OUT_READ_NIC_TIME_NANOSECONDS_OFST 4
643
644/* MC_CMD_PTP_OUT_STATUS msgresponse */
645#define MC_CMD_PTP_OUT_STATUS_LEN 64
646#define MC_CMD_PTP_OUT_STATUS_CLOCK_FREQ_OFST 0
647#define MC_CMD_PTP_OUT_STATUS_STATS_TX_OFST 4
648#define MC_CMD_PTP_OUT_STATUS_STATS_RX_OFST 8
649#define MC_CMD_PTP_OUT_STATUS_STATS_TS_OFST 12
650#define MC_CMD_PTP_OUT_STATUS_STATS_FM_OFST 16
651#define MC_CMD_PTP_OUT_STATUS_STATS_NFM_OFST 20
652#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_OFLOW_OFST 24
653#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_BAD_OFST 28
654#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_PER_MIN_OFST 32
655#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_PER_MAX_OFST 36
656#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_PER_LAST_OFST 40
657#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_PER_MEAN_OFST 44
658#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_OFF_MIN_OFST 48
659#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_OFF_MAX_OFST 52
660#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_OFF_LAST_OFST 56
661#define MC_CMD_PTP_OUT_STATUS_STATS_PPS_OFF_MEAN_OFST 60
662
663/* MC_CMD_PTP_OUT_SYNCHRONIZE msgresponse */
664#define MC_CMD_PTP_OUT_SYNCHRONIZE_LENMIN 20
665#define MC_CMD_PTP_OUT_SYNCHRONIZE_LENMAX 240
666#define MC_CMD_PTP_OUT_SYNCHRONIZE_LEN(num) (0+20*(num))
667#define MC_CMD_PTP_OUT_SYNCHRONIZE_TIMESET_OFST 0
668#define MC_CMD_PTP_OUT_SYNCHRONIZE_TIMESET_LEN 20
669#define MC_CMD_PTP_OUT_SYNCHRONIZE_TIMESET_MINNUM 1
670#define MC_CMD_PTP_OUT_SYNCHRONIZE_TIMESET_MAXNUM 12
671#define MC_CMD_PTP_OUT_SYNCHRONIZE_HOSTSTART_OFST 0
672#define MC_CMD_PTP_OUT_SYNCHRONIZE_SECONDS_OFST 4
673#define MC_CMD_PTP_OUT_SYNCHRONIZE_NANOSECONDS_OFST 8
674#define MC_CMD_PTP_OUT_SYNCHRONIZE_HOSTEND_OFST 12
675#define MC_CMD_PTP_OUT_SYNCHRONIZE_WAITNS_OFST 16
676
677/* MC_CMD_PTP_OUT_MANFTEST_BASIC msgresponse */
678#define MC_CMD_PTP_OUT_MANFTEST_BASIC_LEN 8
679#define MC_CMD_PTP_OUT_MANFTEST_BASIC_TEST_RESULT_OFST 0
680#define MC_CMD_PTP_MANF_SUCCESS 0x0 /* enum */
681#define MC_CMD_PTP_MANF_FPGA_LOAD 0x1 /* enum */
682#define MC_CMD_PTP_MANF_FPGA_VERSION 0x2 /* enum */
683#define MC_CMD_PTP_MANF_FPGA_REGISTERS 0x3 /* enum */
684#define MC_CMD_PTP_MANF_OSCILLATOR 0x4 /* enum */
685#define MC_CMD_PTP_MANF_TIMESTAMPS 0x5 /* enum */
686#define MC_CMD_PTP_MANF_PACKET_COUNT 0x6 /* enum */
687#define MC_CMD_PTP_MANF_FILTER_COUNT 0x7 /* enum */
688#define MC_CMD_PTP_MANF_PACKET_ENOUGH 0x8 /* enum */
689#define MC_CMD_PTP_MANF_GPIO_TRIGGER 0x9 /* enum */
690#define MC_CMD_PTP_OUT_MANFTEST_BASIC_TEST_EXTOSC_OFST 4
691
692/* MC_CMD_PTP_OUT_MANFTEST_PACKET msgresponse */
693#define MC_CMD_PTP_OUT_MANFTEST_PACKET_LEN 12
694#define MC_CMD_PTP_OUT_MANFTEST_PACKET_TEST_RESULT_OFST 0
695#define MC_CMD_PTP_OUT_MANFTEST_PACKET_TEST_FPGACOUNT_OFST 4
696#define MC_CMD_PTP_OUT_MANFTEST_PACKET_TEST_FILTERCOUNT_OFST 8
697
698
699/***********************************/
700/* MC_CMD_CSR_READ32
701 * Read 32bit words from the indirect memory map.
702 */
703#define MC_CMD_CSR_READ32 0xc
704
705/* MC_CMD_CSR_READ32_IN msgrequest */
706#define MC_CMD_CSR_READ32_IN_LEN 12
707#define MC_CMD_CSR_READ32_IN_ADDR_OFST 0
708#define MC_CMD_CSR_READ32_IN_STEP_OFST 4
709#define MC_CMD_CSR_READ32_IN_NUMWORDS_OFST 8
710
711/* MC_CMD_CSR_READ32_OUT msgresponse */
712#define MC_CMD_CSR_READ32_OUT_LENMIN 4
713#define MC_CMD_CSR_READ32_OUT_LENMAX 252
714#define MC_CMD_CSR_READ32_OUT_LEN(num) (0+4*(num))
715#define MC_CMD_CSR_READ32_OUT_BUFFER_OFST 0
716#define MC_CMD_CSR_READ32_OUT_BUFFER_LEN 4
717#define MC_CMD_CSR_READ32_OUT_BUFFER_MINNUM 1
718#define MC_CMD_CSR_READ32_OUT_BUFFER_MAXNUM 63
719
720
721/***********************************/
722/* MC_CMD_CSR_WRITE32
723 * Write 32bit dwords to the indirect memory map.
724 */
725#define MC_CMD_CSR_WRITE32 0xd
726
727/* MC_CMD_CSR_WRITE32_IN msgrequest */
728#define MC_CMD_CSR_WRITE32_IN_LENMIN 12
729#define MC_CMD_CSR_WRITE32_IN_LENMAX 252
730#define MC_CMD_CSR_WRITE32_IN_LEN(num) (8+4*(num))
731#define MC_CMD_CSR_WRITE32_IN_ADDR_OFST 0
732#define MC_CMD_CSR_WRITE32_IN_STEP_OFST 4
733#define MC_CMD_CSR_WRITE32_IN_BUFFER_OFST 8
734#define MC_CMD_CSR_WRITE32_IN_BUFFER_LEN 4
735#define MC_CMD_CSR_WRITE32_IN_BUFFER_MINNUM 1
736#define MC_CMD_CSR_WRITE32_IN_BUFFER_MAXNUM 61
737
738/* MC_CMD_CSR_WRITE32_OUT msgresponse */
739#define MC_CMD_CSR_WRITE32_OUT_LEN 4
740#define MC_CMD_CSR_WRITE32_OUT_STATUS_OFST 0
741
742
743/***********************************/
744/* MC_CMD_STACKINFO
745 * Get stack information.
746 */
747#define MC_CMD_STACKINFO 0xf
748
749/* MC_CMD_STACKINFO_IN msgrequest */
750#define MC_CMD_STACKINFO_IN_LEN 0
751
752/* MC_CMD_STACKINFO_OUT msgresponse */
753#define MC_CMD_STACKINFO_OUT_LENMIN 12
754#define MC_CMD_STACKINFO_OUT_LENMAX 252
755#define MC_CMD_STACKINFO_OUT_LEN(num) (0+12*(num))
756#define MC_CMD_STACKINFO_OUT_THREAD_INFO_OFST 0
757#define MC_CMD_STACKINFO_OUT_THREAD_INFO_LEN 12
758#define MC_CMD_STACKINFO_OUT_THREAD_INFO_MINNUM 1
759#define MC_CMD_STACKINFO_OUT_THREAD_INFO_MAXNUM 21
760
761
762/***********************************/
763/* MC_CMD_MDIO_READ
764 * MDIO register read.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000765 */
766#define MC_CMD_MDIO_READ 0x10
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000767
Ben Hutchings05a93202011-12-20 00:44:06 +0000768/* MC_CMD_MDIO_READ_IN msgrequest */
769#define MC_CMD_MDIO_READ_IN_LEN 16
770#define MC_CMD_MDIO_READ_IN_BUS_OFST 0
771#define MC_CMD_MDIO_BUS_INTERNAL 0x0 /* enum */
772#define MC_CMD_MDIO_BUS_EXTERNAL 0x1 /* enum */
773#define MC_CMD_MDIO_READ_IN_PRTAD_OFST 4
774#define MC_CMD_MDIO_READ_IN_DEVAD_OFST 8
775#define MC_CMD_MDIO_CLAUSE22 0x20 /* enum */
776#define MC_CMD_MDIO_READ_IN_ADDR_OFST 12
777
778/* MC_CMD_MDIO_READ_OUT msgresponse */
779#define MC_CMD_MDIO_READ_OUT_LEN 8
780#define MC_CMD_MDIO_READ_OUT_VALUE_OFST 0
781#define MC_CMD_MDIO_READ_OUT_STATUS_OFST 4
782#define MC_CMD_MDIO_STATUS_GOOD 0x8 /* enum */
783
784
785/***********************************/
786/* MC_CMD_MDIO_WRITE
787 * MDIO register write.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000788 */
789#define MC_CMD_MDIO_WRITE 0x11
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000790
Ben Hutchings05a93202011-12-20 00:44:06 +0000791/* MC_CMD_MDIO_WRITE_IN msgrequest */
792#define MC_CMD_MDIO_WRITE_IN_LEN 20
793#define MC_CMD_MDIO_WRITE_IN_BUS_OFST 0
794/* MC_CMD_MDIO_BUS_INTERNAL 0x0 */
795/* MC_CMD_MDIO_BUS_EXTERNAL 0x1 */
796#define MC_CMD_MDIO_WRITE_IN_PRTAD_OFST 4
797#define MC_CMD_MDIO_WRITE_IN_DEVAD_OFST 8
798/* MC_CMD_MDIO_CLAUSE22 0x20 */
799#define MC_CMD_MDIO_WRITE_IN_ADDR_OFST 12
800#define MC_CMD_MDIO_WRITE_IN_VALUE_OFST 16
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000801
Ben Hutchings05a93202011-12-20 00:44:06 +0000802/* MC_CMD_MDIO_WRITE_OUT msgresponse */
803#define MC_CMD_MDIO_WRITE_OUT_LEN 4
804#define MC_CMD_MDIO_WRITE_OUT_STATUS_OFST 0
805/* MC_CMD_MDIO_STATUS_GOOD 0x8 */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000806
807
Ben Hutchings05a93202011-12-20 00:44:06 +0000808/***********************************/
809/* MC_CMD_DBI_WRITE
810 * Write DBI register(s).
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000811 */
812#define MC_CMD_DBI_WRITE 0x12
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000813
Ben Hutchings05a93202011-12-20 00:44:06 +0000814/* MC_CMD_DBI_WRITE_IN msgrequest */
815#define MC_CMD_DBI_WRITE_IN_LENMIN 12
816#define MC_CMD_DBI_WRITE_IN_LENMAX 252
817#define MC_CMD_DBI_WRITE_IN_LEN(num) (0+12*(num))
818#define MC_CMD_DBI_WRITE_IN_DBIWROP_OFST 0
819#define MC_CMD_DBI_WRITE_IN_DBIWROP_LEN 12
820#define MC_CMD_DBI_WRITE_IN_DBIWROP_MINNUM 1
821#define MC_CMD_DBI_WRITE_IN_DBIWROP_MAXNUM 21
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000822
Ben Hutchings05a93202011-12-20 00:44:06 +0000823/* MC_CMD_DBI_WRITE_OUT msgresponse */
824#define MC_CMD_DBI_WRITE_OUT_LEN 0
825
826/* MC_CMD_DBIWROP_TYPEDEF structuredef */
827#define MC_CMD_DBIWROP_TYPEDEF_LEN 12
828#define MC_CMD_DBIWROP_TYPEDEF_ADDRESS_OFST 0
829#define MC_CMD_DBIWROP_TYPEDEF_ADDRESS_LBN 0
830#define MC_CMD_DBIWROP_TYPEDEF_ADDRESS_WIDTH 32
831#define MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_OFST 4
832#define MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_LBN 32
833#define MC_CMD_DBIWROP_TYPEDEF_BYTE_MASK_WIDTH 32
834#define MC_CMD_DBIWROP_TYPEDEF_VALUE_OFST 8
835#define MC_CMD_DBIWROP_TYPEDEF_VALUE_LBN 64
836#define MC_CMD_DBIWROP_TYPEDEF_VALUE_WIDTH 32
837
838
839/***********************************/
840/* MC_CMD_PORT_READ32
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000841 * Read a 32-bit register from the indirect port register map.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000842 */
843#define MC_CMD_PORT_READ32 0x14
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000844
Ben Hutchings05a93202011-12-20 00:44:06 +0000845/* MC_CMD_PORT_READ32_IN msgrequest */
846#define MC_CMD_PORT_READ32_IN_LEN 4
847#define MC_CMD_PORT_READ32_IN_ADDR_OFST 0
848
849/* MC_CMD_PORT_READ32_OUT msgresponse */
850#define MC_CMD_PORT_READ32_OUT_LEN 8
851#define MC_CMD_PORT_READ32_OUT_VALUE_OFST 0
852#define MC_CMD_PORT_READ32_OUT_STATUS_OFST 4
853
854
855/***********************************/
856/* MC_CMD_PORT_WRITE32
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000857 * Write a 32-bit register to the indirect port register map.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000858 */
859#define MC_CMD_PORT_WRITE32 0x15
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000860
Ben Hutchings05a93202011-12-20 00:44:06 +0000861/* MC_CMD_PORT_WRITE32_IN msgrequest */
862#define MC_CMD_PORT_WRITE32_IN_LEN 8
863#define MC_CMD_PORT_WRITE32_IN_ADDR_OFST 0
864#define MC_CMD_PORT_WRITE32_IN_VALUE_OFST 4
865
866/* MC_CMD_PORT_WRITE32_OUT msgresponse */
867#define MC_CMD_PORT_WRITE32_OUT_LEN 4
868#define MC_CMD_PORT_WRITE32_OUT_STATUS_OFST 0
869
870
871/***********************************/
872/* MC_CMD_PORT_READ128
873 * Read a 128-bit register from the indirect port register map.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000874 */
875#define MC_CMD_PORT_READ128 0x16
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000876
Ben Hutchings05a93202011-12-20 00:44:06 +0000877/* MC_CMD_PORT_READ128_IN msgrequest */
878#define MC_CMD_PORT_READ128_IN_LEN 4
879#define MC_CMD_PORT_READ128_IN_ADDR_OFST 0
880
881/* MC_CMD_PORT_READ128_OUT msgresponse */
882#define MC_CMD_PORT_READ128_OUT_LEN 20
883#define MC_CMD_PORT_READ128_OUT_VALUE_OFST 0
884#define MC_CMD_PORT_READ128_OUT_VALUE_LEN 16
885#define MC_CMD_PORT_READ128_OUT_STATUS_OFST 16
886
887
888/***********************************/
889/* MC_CMD_PORT_WRITE128
890 * Write a 128-bit register to the indirect port register map.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000891 */
892#define MC_CMD_PORT_WRITE128 0x17
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000893
Ben Hutchings05a93202011-12-20 00:44:06 +0000894/* MC_CMD_PORT_WRITE128_IN msgrequest */
895#define MC_CMD_PORT_WRITE128_IN_LEN 20
896#define MC_CMD_PORT_WRITE128_IN_ADDR_OFST 0
897#define MC_CMD_PORT_WRITE128_IN_VALUE_OFST 4
898#define MC_CMD_PORT_WRITE128_IN_VALUE_LEN 16
899
900/* MC_CMD_PORT_WRITE128_OUT msgresponse */
901#define MC_CMD_PORT_WRITE128_OUT_LEN 4
902#define MC_CMD_PORT_WRITE128_OUT_STATUS_OFST 0
903
904
905/***********************************/
906/* MC_CMD_GET_BOARD_CFG
907 * Returns the MC firmware configuration structure.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000908 */
909#define MC_CMD_GET_BOARD_CFG 0x18
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000910
Ben Hutchings05a93202011-12-20 00:44:06 +0000911/* MC_CMD_GET_BOARD_CFG_IN msgrequest */
912#define MC_CMD_GET_BOARD_CFG_IN_LEN 0
913
914/* MC_CMD_GET_BOARD_CFG_OUT msgresponse */
915#define MC_CMD_GET_BOARD_CFG_OUT_LENMIN 96
916#define MC_CMD_GET_BOARD_CFG_OUT_LENMAX 136
917#define MC_CMD_GET_BOARD_CFG_OUT_LEN(num) (72+2*(num))
918#define MC_CMD_GET_BOARD_CFG_OUT_BOARD_TYPE_OFST 0
919#define MC_CMD_GET_BOARD_CFG_OUT_BOARD_NAME_OFST 4
920#define MC_CMD_GET_BOARD_CFG_OUT_BOARD_NAME_LEN 32
921#define MC_CMD_GET_BOARD_CFG_OUT_CAPABILITIES_PORT0_OFST 36
922#define MC_CMD_CAPABILITIES_SMALL_BUF_TBL_LBN 0x0 /* enum */
923#define MC_CMD_CAPABILITIES_SMALL_BUF_TBL_WIDTH 0x1 /* enum */
924#define MC_CMD_CAPABILITIES_TURBO_LBN 0x1 /* enum */
925#define MC_CMD_CAPABILITIES_TURBO_WIDTH 0x1 /* enum */
926#define MC_CMD_CAPABILITIES_TURBO_ACTIVE_LBN 0x2 /* enum */
927#define MC_CMD_CAPABILITIES_TURBO_ACTIVE_WIDTH 0x1 /* enum */
928#define MC_CMD_CAPABILITIES_PTP_LBN 0x3 /* enum */
929#define MC_CMD_CAPABILITIES_PTP_WIDTH 0x1 /* enum */
930#define MC_CMD_GET_BOARD_CFG_OUT_CAPABILITIES_PORT1_OFST 40
931/* Enum values, see field(s): */
932/* CAPABILITIES_PORT0 */
933#define MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT0_OFST 44
934#define MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT0_LEN 6
935#define MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT1_OFST 50
936#define MC_CMD_GET_BOARD_CFG_OUT_MAC_ADDR_BASE_PORT1_LEN 6
937#define MC_CMD_GET_BOARD_CFG_OUT_MAC_COUNT_PORT0_OFST 56
938#define MC_CMD_GET_BOARD_CFG_OUT_MAC_COUNT_PORT1_OFST 60
939#define MC_CMD_GET_BOARD_CFG_OUT_MAC_STRIDE_PORT0_OFST 64
940#define MC_CMD_GET_BOARD_CFG_OUT_MAC_STRIDE_PORT1_OFST 68
941#define MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_OFST 72
942#define MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_LEN 2
943#define MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_MINNUM 12
944#define MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_MAXNUM 32
945
946
947/***********************************/
948/* MC_CMD_DBI_READX
949 * Read DBI register(s).
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000950 */
951#define MC_CMD_DBI_READX 0x19
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000952
Ben Hutchings05a93202011-12-20 00:44:06 +0000953/* MC_CMD_DBI_READX_IN msgrequest */
954#define MC_CMD_DBI_READX_IN_LENMIN 8
955#define MC_CMD_DBI_READX_IN_LENMAX 248
956#define MC_CMD_DBI_READX_IN_LEN(num) (0+8*(num))
957#define MC_CMD_DBI_READX_IN_DBIRDOP_OFST 0
958#define MC_CMD_DBI_READX_IN_DBIRDOP_LEN 8
959#define MC_CMD_DBI_READX_IN_DBIRDOP_LO_OFST 0
960#define MC_CMD_DBI_READX_IN_DBIRDOP_HI_OFST 4
961#define MC_CMD_DBI_READX_IN_DBIRDOP_MINNUM 1
962#define MC_CMD_DBI_READX_IN_DBIRDOP_MAXNUM 31
963
964/* MC_CMD_DBI_READX_OUT msgresponse */
965#define MC_CMD_DBI_READX_OUT_LENMIN 4
966#define MC_CMD_DBI_READX_OUT_LENMAX 252
967#define MC_CMD_DBI_READX_OUT_LEN(num) (0+4*(num))
968#define MC_CMD_DBI_READX_OUT_VALUE_OFST 0
969#define MC_CMD_DBI_READX_OUT_VALUE_LEN 4
970#define MC_CMD_DBI_READX_OUT_VALUE_MINNUM 1
971#define MC_CMD_DBI_READX_OUT_VALUE_MAXNUM 63
972
973
974/***********************************/
975/* MC_CMD_SET_RAND_SEED
976 * Set the 16byte seed for the MC pseudo-random generator.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000977 */
978#define MC_CMD_SET_RAND_SEED 0x1a
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000979
Ben Hutchings05a93202011-12-20 00:44:06 +0000980/* MC_CMD_SET_RAND_SEED_IN msgrequest */
981#define MC_CMD_SET_RAND_SEED_IN_LEN 16
982#define MC_CMD_SET_RAND_SEED_IN_SEED_OFST 0
983#define MC_CMD_SET_RAND_SEED_IN_SEED_LEN 16
984
985/* MC_CMD_SET_RAND_SEED_OUT msgresponse */
986#define MC_CMD_SET_RAND_SEED_OUT_LEN 0
987
988
989/***********************************/
990/* MC_CMD_LTSSM_HIST
991 * Retrieve the history of the PCIE LTSSM.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +0000992 */
993#define MC_CMD_LTSSM_HIST 0x1b
994
Ben Hutchings05a93202011-12-20 00:44:06 +0000995/* MC_CMD_LTSSM_HIST_IN msgrequest */
996#define MC_CMD_LTSSM_HIST_IN_LEN 0
997
998/* MC_CMD_LTSSM_HIST_OUT msgresponse */
999#define MC_CMD_LTSSM_HIST_OUT_LENMIN 0
1000#define MC_CMD_LTSSM_HIST_OUT_LENMAX 252
1001#define MC_CMD_LTSSM_HIST_OUT_LEN(num) (0+4*(num))
1002#define MC_CMD_LTSSM_HIST_OUT_DATA_OFST 0
1003#define MC_CMD_LTSSM_HIST_OUT_DATA_LEN 4
1004#define MC_CMD_LTSSM_HIST_OUT_DATA_MINNUM 0
1005#define MC_CMD_LTSSM_HIST_OUT_DATA_MAXNUM 63
1006
1007
1008/***********************************/
1009/* MC_CMD_DRV_ATTACH
1010 * Inform MCPU that this port is managed on the host.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001011 */
1012#define MC_CMD_DRV_ATTACH 0x1c
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001013
Ben Hutchings05a93202011-12-20 00:44:06 +00001014/* MC_CMD_DRV_ATTACH_IN msgrequest */
1015#define MC_CMD_DRV_ATTACH_IN_LEN 8
1016#define MC_CMD_DRV_ATTACH_IN_NEW_STATE_OFST 0
1017#define MC_CMD_DRV_ATTACH_IN_UPDATE_OFST 4
1018
1019/* MC_CMD_DRV_ATTACH_OUT msgresponse */
1020#define MC_CMD_DRV_ATTACH_OUT_LEN 4
1021#define MC_CMD_DRV_ATTACH_OUT_OLD_STATE_OFST 0
1022
1023
1024/***********************************/
1025/* MC_CMD_NCSI_PROD
1026 * Trigger an NC-SI event.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001027 */
1028#define MC_CMD_NCSI_PROD 0x1d
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001029
Ben Hutchings05a93202011-12-20 00:44:06 +00001030/* MC_CMD_NCSI_PROD_IN msgrequest */
1031#define MC_CMD_NCSI_PROD_IN_LEN 4
1032#define MC_CMD_NCSI_PROD_IN_EVENTS_OFST 0
1033#define MC_CMD_NCSI_PROD_LINKCHANGE 0x0 /* enum */
1034#define MC_CMD_NCSI_PROD_RESET 0x1 /* enum */
1035#define MC_CMD_NCSI_PROD_DRVATTACH 0x2 /* enum */
1036#define MC_CMD_NCSI_PROD_IN_LINKCHANGE_LBN 0
1037#define MC_CMD_NCSI_PROD_IN_LINKCHANGE_WIDTH 1
1038#define MC_CMD_NCSI_PROD_IN_RESET_LBN 1
1039#define MC_CMD_NCSI_PROD_IN_RESET_WIDTH 1
1040#define MC_CMD_NCSI_PROD_IN_DRVATTACH_LBN 2
1041#define MC_CMD_NCSI_PROD_IN_DRVATTACH_WIDTH 1
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001042
Ben Hutchings05a93202011-12-20 00:44:06 +00001043/* MC_CMD_NCSI_PROD_OUT msgresponse */
1044#define MC_CMD_NCSI_PROD_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001045
Ben Hutchings05a93202011-12-20 00:44:06 +00001046
1047/***********************************/
1048/* MC_CMD_SHMUART
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001049 * Route UART output to circular buffer in shared memory instead.
1050 */
1051#define MC_CMD_SHMUART 0x1f
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001052
Ben Hutchings05a93202011-12-20 00:44:06 +00001053/* MC_CMD_SHMUART_IN msgrequest */
1054#define MC_CMD_SHMUART_IN_LEN 4
1055#define MC_CMD_SHMUART_IN_FLAG_OFST 0
1056
1057/* MC_CMD_SHMUART_OUT msgresponse */
1058#define MC_CMD_SHMUART_OUT_LEN 0
1059
1060
1061/***********************************/
1062/* MC_CMD_ENTITY_RESET
1063 * Generic per-port reset.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001064 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001065#define MC_CMD_ENTITY_RESET 0x20
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001066
Ben Hutchings05a93202011-12-20 00:44:06 +00001067/* MC_CMD_ENTITY_RESET_IN msgrequest */
1068#define MC_CMD_ENTITY_RESET_IN_LEN 4
1069#define MC_CMD_ENTITY_RESET_IN_FLAG_OFST 0
1070#define MC_CMD_ENTITY_RESET_IN_FUNCTION_RESOURCE_RESET_LBN 0
1071#define MC_CMD_ENTITY_RESET_IN_FUNCTION_RESOURCE_RESET_WIDTH 1
1072
1073/* MC_CMD_ENTITY_RESET_OUT msgresponse */
1074#define MC_CMD_ENTITY_RESET_OUT_LEN 0
1075
1076
1077/***********************************/
1078/* MC_CMD_PCIE_CREDITS
1079 * Read instantaneous and minimum flow control thresholds.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001080 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001081#define MC_CMD_PCIE_CREDITS 0x21
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001082
Ben Hutchings05a93202011-12-20 00:44:06 +00001083/* MC_CMD_PCIE_CREDITS_IN msgrequest */
1084#define MC_CMD_PCIE_CREDITS_IN_LEN 8
1085#define MC_CMD_PCIE_CREDITS_IN_POLL_PERIOD_OFST 0
1086#define MC_CMD_PCIE_CREDITS_IN_WIPE_OFST 4
1087
1088/* MC_CMD_PCIE_CREDITS_OUT msgresponse */
1089#define MC_CMD_PCIE_CREDITS_OUT_LEN 16
1090#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_HDR_OFST 0
1091#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_HDR_LEN 2
1092#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_DATA_OFST 2
1093#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_P_DATA_LEN 2
1094#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_HDR_OFST 4
1095#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_HDR_LEN 2
1096#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_DATA_OFST 6
1097#define MC_CMD_PCIE_CREDITS_OUT_CURRENT_NP_DATA_LEN 2
1098#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_HDR_OFST 8
1099#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_HDR_LEN 2
1100#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_DATA_OFST 10
1101#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_P_DATA_LEN 2
1102#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_HDR_OFST 12
1103#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_HDR_LEN 2
1104#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_DATA_OFST 14
1105#define MC_CMD_PCIE_CREDITS_OUT_MINIMUM_NP_DATA_LEN 2
1106
1107
1108/***********************************/
1109/* MC_CMD_RXD_MONITOR
1110 * Get histogram of RX queue fill level.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001111 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001112#define MC_CMD_RXD_MONITOR 0x22
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001113
Ben Hutchings05a93202011-12-20 00:44:06 +00001114/* MC_CMD_RXD_MONITOR_IN msgrequest */
1115#define MC_CMD_RXD_MONITOR_IN_LEN 12
1116#define MC_CMD_RXD_MONITOR_IN_QID_OFST 0
1117#define MC_CMD_RXD_MONITOR_IN_POLL_PERIOD_OFST 4
1118#define MC_CMD_RXD_MONITOR_IN_WIPE_OFST 8
1119
1120/* MC_CMD_RXD_MONITOR_OUT msgresponse */
1121#define MC_CMD_RXD_MONITOR_OUT_LEN 80
1122#define MC_CMD_RXD_MONITOR_OUT_QID_OFST 0
1123#define MC_CMD_RXD_MONITOR_OUT_RING_FILL_OFST 4
1124#define MC_CMD_RXD_MONITOR_OUT_CACHE_FILL_OFST 8
1125#define MC_CMD_RXD_MONITOR_OUT_RING_LT_1_OFST 12
1126#define MC_CMD_RXD_MONITOR_OUT_RING_LT_2_OFST 16
1127#define MC_CMD_RXD_MONITOR_OUT_RING_LT_4_OFST 20
1128#define MC_CMD_RXD_MONITOR_OUT_RING_LT_8_OFST 24
1129#define MC_CMD_RXD_MONITOR_OUT_RING_LT_16_OFST 28
1130#define MC_CMD_RXD_MONITOR_OUT_RING_LT_32_OFST 32
1131#define MC_CMD_RXD_MONITOR_OUT_RING_LT_64_OFST 36
1132#define MC_CMD_RXD_MONITOR_OUT_RING_LT_128_OFST 40
1133#define MC_CMD_RXD_MONITOR_OUT_RING_LT_256_OFST 44
1134#define MC_CMD_RXD_MONITOR_OUT_RING_GE_256_OFST 48
1135#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_1_OFST 52
1136#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_2_OFST 56
1137#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_4_OFST 60
1138#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_8_OFST 64
1139#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_16_OFST 68
1140#define MC_CMD_RXD_MONITOR_OUT_CACHE_LT_32_OFST 72
1141#define MC_CMD_RXD_MONITOR_OUT_CACHE_GE_32_OFST 76
1142
1143
1144/***********************************/
1145/* MC_CMD_PUTS
1146 * puts(3) implementation over MCDI
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001147 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001148#define MC_CMD_PUTS 0x23
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001149
Ben Hutchings05a93202011-12-20 00:44:06 +00001150/* MC_CMD_PUTS_IN msgrequest */
1151#define MC_CMD_PUTS_IN_LENMIN 13
Ben Hutchings576eda82012-09-19 02:46:37 +01001152#define MC_CMD_PUTS_IN_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +00001153#define MC_CMD_PUTS_IN_LEN(num) (12+1*(num))
1154#define MC_CMD_PUTS_IN_DEST_OFST 0
1155#define MC_CMD_PUTS_IN_UART_LBN 0
1156#define MC_CMD_PUTS_IN_UART_WIDTH 1
1157#define MC_CMD_PUTS_IN_PORT_LBN 1
1158#define MC_CMD_PUTS_IN_PORT_WIDTH 1
1159#define MC_CMD_PUTS_IN_DHOST_OFST 4
1160#define MC_CMD_PUTS_IN_DHOST_LEN 6
1161#define MC_CMD_PUTS_IN_STRING_OFST 12
1162#define MC_CMD_PUTS_IN_STRING_LEN 1
1163#define MC_CMD_PUTS_IN_STRING_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +01001164#define MC_CMD_PUTS_IN_STRING_MAXNUM 240
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001165
Ben Hutchings05a93202011-12-20 00:44:06 +00001166/* MC_CMD_PUTS_OUT msgresponse */
1167#define MC_CMD_PUTS_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001168
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001169
Ben Hutchings05a93202011-12-20 00:44:06 +00001170/***********************************/
1171/* MC_CMD_GET_PHY_CFG
1172 * Report PHY configuration.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001173 */
1174#define MC_CMD_GET_PHY_CFG 0x24
1175
Ben Hutchings05a93202011-12-20 00:44:06 +00001176/* MC_CMD_GET_PHY_CFG_IN msgrequest */
1177#define MC_CMD_GET_PHY_CFG_IN_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001178
Ben Hutchings05a93202011-12-20 00:44:06 +00001179/* MC_CMD_GET_PHY_CFG_OUT msgresponse */
1180#define MC_CMD_GET_PHY_CFG_OUT_LEN 72
1181#define MC_CMD_GET_PHY_CFG_OUT_FLAGS_OFST 0
1182#define MC_CMD_GET_PHY_CFG_OUT_PRESENT_LBN 0
1183#define MC_CMD_GET_PHY_CFG_OUT_PRESENT_WIDTH 1
1184#define MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_SHORT_LBN 1
1185#define MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_SHORT_WIDTH 1
1186#define MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_LONG_LBN 2
1187#define MC_CMD_GET_PHY_CFG_OUT_BIST_CABLE_LONG_WIDTH 1
1188#define MC_CMD_GET_PHY_CFG_OUT_LOWPOWER_LBN 3
1189#define MC_CMD_GET_PHY_CFG_OUT_LOWPOWER_WIDTH 1
1190#define MC_CMD_GET_PHY_CFG_OUT_POWEROFF_LBN 4
1191#define MC_CMD_GET_PHY_CFG_OUT_POWEROFF_WIDTH 1
1192#define MC_CMD_GET_PHY_CFG_OUT_TXDIS_LBN 5
1193#define MC_CMD_GET_PHY_CFG_OUT_TXDIS_WIDTH 1
1194#define MC_CMD_GET_PHY_CFG_OUT_BIST_LBN 6
1195#define MC_CMD_GET_PHY_CFG_OUT_BIST_WIDTH 1
1196#define MC_CMD_GET_PHY_CFG_OUT_TYPE_OFST 4
1197#define MC_CMD_GET_PHY_CFG_OUT_SUPPORTED_CAP_OFST 8
1198#define MC_CMD_PHY_CAP_10HDX_LBN 1
1199#define MC_CMD_PHY_CAP_10HDX_WIDTH 1
1200#define MC_CMD_PHY_CAP_10FDX_LBN 2
1201#define MC_CMD_PHY_CAP_10FDX_WIDTH 1
1202#define MC_CMD_PHY_CAP_100HDX_LBN 3
1203#define MC_CMD_PHY_CAP_100HDX_WIDTH 1
1204#define MC_CMD_PHY_CAP_100FDX_LBN 4
1205#define MC_CMD_PHY_CAP_100FDX_WIDTH 1
1206#define MC_CMD_PHY_CAP_1000HDX_LBN 5
1207#define MC_CMD_PHY_CAP_1000HDX_WIDTH 1
1208#define MC_CMD_PHY_CAP_1000FDX_LBN 6
1209#define MC_CMD_PHY_CAP_1000FDX_WIDTH 1
1210#define MC_CMD_PHY_CAP_10000FDX_LBN 7
1211#define MC_CMD_PHY_CAP_10000FDX_WIDTH 1
1212#define MC_CMD_PHY_CAP_PAUSE_LBN 8
1213#define MC_CMD_PHY_CAP_PAUSE_WIDTH 1
1214#define MC_CMD_PHY_CAP_ASYM_LBN 9
1215#define MC_CMD_PHY_CAP_ASYM_WIDTH 1
1216#define MC_CMD_PHY_CAP_AN_LBN 10
1217#define MC_CMD_PHY_CAP_AN_WIDTH 1
1218#define MC_CMD_GET_PHY_CFG_OUT_CHANNEL_OFST 12
1219#define MC_CMD_GET_PHY_CFG_OUT_PRT_OFST 16
1220#define MC_CMD_GET_PHY_CFG_OUT_STATS_MASK_OFST 20
1221#define MC_CMD_GET_PHY_CFG_OUT_NAME_OFST 24
1222#define MC_CMD_GET_PHY_CFG_OUT_NAME_LEN 20
1223#define MC_CMD_GET_PHY_CFG_OUT_MEDIA_TYPE_OFST 44
1224#define MC_CMD_MEDIA_XAUI 0x1 /* enum */
1225#define MC_CMD_MEDIA_CX4 0x2 /* enum */
1226#define MC_CMD_MEDIA_KX4 0x3 /* enum */
1227#define MC_CMD_MEDIA_XFP 0x4 /* enum */
1228#define MC_CMD_MEDIA_SFP_PLUS 0x5 /* enum */
1229#define MC_CMD_MEDIA_BASE_T 0x6 /* enum */
1230#define MC_CMD_GET_PHY_CFG_OUT_MMD_MASK_OFST 48
1231#define MC_CMD_MMD_CLAUSE22 0x0 /* enum */
1232#define MC_CMD_MMD_CLAUSE45_PMAPMD 0x1 /* enum */
1233#define MC_CMD_MMD_CLAUSE45_WIS 0x2 /* enum */
1234#define MC_CMD_MMD_CLAUSE45_PCS 0x3 /* enum */
1235#define MC_CMD_MMD_CLAUSE45_PHYXS 0x4 /* enum */
1236#define MC_CMD_MMD_CLAUSE45_DTEXS 0x5 /* enum */
1237#define MC_CMD_MMD_CLAUSE45_TC 0x6 /* enum */
1238#define MC_CMD_MMD_CLAUSE45_AN 0x7 /* enum */
1239#define MC_CMD_MMD_CLAUSE45_C22EXT 0x1d /* enum */
1240#define MC_CMD_MMD_CLAUSE45_VEND1 0x1e /* enum */
1241#define MC_CMD_MMD_CLAUSE45_VEND2 0x1f /* enum */
1242#define MC_CMD_GET_PHY_CFG_OUT_REVISION_OFST 52
1243#define MC_CMD_GET_PHY_CFG_OUT_REVISION_LEN 20
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001244
Ben Hutchings05a93202011-12-20 00:44:06 +00001245
1246/***********************************/
1247/* MC_CMD_START_BIST
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001248 * Start a BIST test on the PHY.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001249 */
1250#define MC_CMD_START_BIST 0x25
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001251
Ben Hutchings05a93202011-12-20 00:44:06 +00001252/* MC_CMD_START_BIST_IN msgrequest */
1253#define MC_CMD_START_BIST_IN_LEN 4
1254#define MC_CMD_START_BIST_IN_TYPE_OFST 0
1255#define MC_CMD_PHY_BIST_CABLE_SHORT 0x1 /* enum */
1256#define MC_CMD_PHY_BIST_CABLE_LONG 0x2 /* enum */
1257#define MC_CMD_BPX_SERDES_BIST 0x3 /* enum */
1258#define MC_CMD_MC_LOOPBACK_BIST 0x4 /* enum */
1259#define MC_CMD_PHY_BIST 0x5 /* enum */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001260
Ben Hutchings05a93202011-12-20 00:44:06 +00001261/* MC_CMD_START_BIST_OUT msgresponse */
1262#define MC_CMD_START_BIST_OUT_LEN 0
1263
1264
1265/***********************************/
1266/* MC_CMD_POLL_BIST
1267 * Poll for BIST completion.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001268 */
1269#define MC_CMD_POLL_BIST 0x26
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001270
Ben Hutchings05a93202011-12-20 00:44:06 +00001271/* MC_CMD_POLL_BIST_IN msgrequest */
1272#define MC_CMD_POLL_BIST_IN_LEN 0
1273
1274/* MC_CMD_POLL_BIST_OUT msgresponse */
1275#define MC_CMD_POLL_BIST_OUT_LEN 8
1276#define MC_CMD_POLL_BIST_OUT_RESULT_OFST 0
1277#define MC_CMD_POLL_BIST_RUNNING 0x1 /* enum */
1278#define MC_CMD_POLL_BIST_PASSED 0x2 /* enum */
1279#define MC_CMD_POLL_BIST_FAILED 0x3 /* enum */
1280#define MC_CMD_POLL_BIST_TIMEOUT 0x4 /* enum */
1281#define MC_CMD_POLL_BIST_OUT_PRIVATE_OFST 4
1282
1283/* MC_CMD_POLL_BIST_OUT_SFT9001 msgresponse */
1284#define MC_CMD_POLL_BIST_OUT_SFT9001_LEN 36
1285/* MC_CMD_POLL_BIST_OUT_RESULT_OFST 0 */
1286/* Enum values, see field(s): */
1287/* MC_CMD_POLL_BIST_OUT/MC_CMD_POLL_BIST_OUT_RESULT */
1288#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_A_OFST 4
1289#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_B_OFST 8
1290#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_C_OFST 12
1291#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_LENGTH_D_OFST 16
1292#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_A_OFST 20
1293#define MC_CMD_POLL_BIST_SFT9001_PAIR_OK 0x1 /* enum */
1294#define MC_CMD_POLL_BIST_SFT9001_PAIR_OPEN 0x2 /* enum */
1295#define MC_CMD_POLL_BIST_SFT9001_INTRA_PAIR_SHORT 0x3 /* enum */
1296#define MC_CMD_POLL_BIST_SFT9001_INTER_PAIR_SHORT 0x4 /* enum */
1297#define MC_CMD_POLL_BIST_SFT9001_PAIR_BUSY 0x9 /* enum */
1298#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_B_OFST 24
1299/* Enum values, see field(s): */
1300/* CABLE_STATUS_A */
1301#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_C_OFST 28
1302/* Enum values, see field(s): */
1303/* CABLE_STATUS_A */
1304#define MC_CMD_POLL_BIST_OUT_SFT9001_CABLE_STATUS_D_OFST 32
1305/* Enum values, see field(s): */
1306/* CABLE_STATUS_A */
1307
1308/* MC_CMD_POLL_BIST_OUT_MRSFP msgresponse */
1309#define MC_CMD_POLL_BIST_OUT_MRSFP_LEN 8
1310/* MC_CMD_POLL_BIST_OUT_RESULT_OFST 0 */
1311/* Enum values, see field(s): */
1312/* MC_CMD_POLL_BIST_OUT/MC_CMD_POLL_BIST_OUT_RESULT */
1313#define MC_CMD_POLL_BIST_OUT_MRSFP_TEST_OFST 4
1314#define MC_CMD_POLL_BIST_MRSFP_TEST_COMPLETE 0x0 /* enum */
1315#define MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_WRITE 0x1 /* enum */
1316#define MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_NO_ACCESS_IO_EXP 0x2 /* enum */
1317#define MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_OFF_I2C_NO_ACCESS_MODULE 0x3 /* enum */
1318#define MC_CMD_POLL_BIST_MRSFP_TEST_IO_EXP_I2C_CONFIGURE 0x4 /* enum */
1319#define MC_CMD_POLL_BIST_MRSFP_TEST_BUS_SWITCH_I2C_NO_CROSSTALK 0x5 /* enum */
1320#define MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_PRESENCE 0x6 /* enum */
1321#define MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_ID_I2C_ACCESS 0x7 /* enum */
1322#define MC_CMD_POLL_BIST_MRSFP_TEST_MODULE_ID_SANE_VALUE 0x8 /* enum */
1323
1324
1325/***********************************/
1326/* MC_CMD_FLUSH_RX_QUEUES
1327 * Flush receive queue(s).
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001328 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001329#define MC_CMD_FLUSH_RX_QUEUES 0x27
1330
1331/* MC_CMD_FLUSH_RX_QUEUES_IN msgrequest */
1332#define MC_CMD_FLUSH_RX_QUEUES_IN_LENMIN 4
1333#define MC_CMD_FLUSH_RX_QUEUES_IN_LENMAX 252
1334#define MC_CMD_FLUSH_RX_QUEUES_IN_LEN(num) (0+4*(num))
1335#define MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_OFST 0
1336#define MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_LEN 4
1337#define MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_MINNUM 1
1338#define MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_MAXNUM 63
1339
1340/* MC_CMD_FLUSH_RX_QUEUES_OUT msgresponse */
1341#define MC_CMD_FLUSH_RX_QUEUES_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001342
1343
Ben Hutchings05a93202011-12-20 00:44:06 +00001344/***********************************/
1345/* MC_CMD_GET_LOOPBACK_MODES
1346 * Get port's loopback modes.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001347 */
1348#define MC_CMD_GET_LOOPBACK_MODES 0x28
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001349
Ben Hutchings05a93202011-12-20 00:44:06 +00001350/* MC_CMD_GET_LOOPBACK_MODES_IN msgrequest */
1351#define MC_CMD_GET_LOOPBACK_MODES_IN_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001352
Ben Hutchings05a93202011-12-20 00:44:06 +00001353/* MC_CMD_GET_LOOPBACK_MODES_OUT msgresponse */
1354#define MC_CMD_GET_LOOPBACK_MODES_OUT_LEN 32
1355#define MC_CMD_GET_LOOPBACK_MODES_OUT_100M_OFST 0
1356#define MC_CMD_GET_LOOPBACK_MODES_OUT_100M_LEN 8
1357#define MC_CMD_GET_LOOPBACK_MODES_OUT_100M_LO_OFST 0
1358#define MC_CMD_GET_LOOPBACK_MODES_OUT_100M_HI_OFST 4
1359#define MC_CMD_LOOPBACK_NONE 0x0 /* enum */
1360#define MC_CMD_LOOPBACK_DATA 0x1 /* enum */
1361#define MC_CMD_LOOPBACK_GMAC 0x2 /* enum */
1362#define MC_CMD_LOOPBACK_XGMII 0x3 /* enum */
1363#define MC_CMD_LOOPBACK_XGXS 0x4 /* enum */
1364#define MC_CMD_LOOPBACK_XAUI 0x5 /* enum */
1365#define MC_CMD_LOOPBACK_GMII 0x6 /* enum */
1366#define MC_CMD_LOOPBACK_SGMII 0x7 /* enum */
1367#define MC_CMD_LOOPBACK_XGBR 0x8 /* enum */
1368#define MC_CMD_LOOPBACK_XFI 0x9 /* enum */
1369#define MC_CMD_LOOPBACK_XAUI_FAR 0xa /* enum */
1370#define MC_CMD_LOOPBACK_GMII_FAR 0xb /* enum */
1371#define MC_CMD_LOOPBACK_SGMII_FAR 0xc /* enum */
1372#define MC_CMD_LOOPBACK_XFI_FAR 0xd /* enum */
1373#define MC_CMD_LOOPBACK_GPHY 0xe /* enum */
1374#define MC_CMD_LOOPBACK_PHYXS 0xf /* enum */
1375#define MC_CMD_LOOPBACK_PCS 0x10 /* enum */
1376#define MC_CMD_LOOPBACK_PMAPMD 0x11 /* enum */
1377#define MC_CMD_LOOPBACK_XPORT 0x12 /* enum */
1378#define MC_CMD_LOOPBACK_XGMII_WS 0x13 /* enum */
1379#define MC_CMD_LOOPBACK_XAUI_WS 0x14 /* enum */
1380#define MC_CMD_LOOPBACK_XAUI_WS_FAR 0x15 /* enum */
1381#define MC_CMD_LOOPBACK_XAUI_WS_NEAR 0x16 /* enum */
1382#define MC_CMD_LOOPBACK_GMII_WS 0x17 /* enum */
1383#define MC_CMD_LOOPBACK_XFI_WS 0x18 /* enum */
1384#define MC_CMD_LOOPBACK_XFI_WS_FAR 0x19 /* enum */
1385#define MC_CMD_LOOPBACK_PHYXS_WS 0x1a /* enum */
1386#define MC_CMD_GET_LOOPBACK_MODES_OUT_1G_OFST 8
1387#define MC_CMD_GET_LOOPBACK_MODES_OUT_1G_LEN 8
1388#define MC_CMD_GET_LOOPBACK_MODES_OUT_1G_LO_OFST 8
1389#define MC_CMD_GET_LOOPBACK_MODES_OUT_1G_HI_OFST 12
1390/* Enum values, see field(s): */
1391/* 100M */
1392#define MC_CMD_GET_LOOPBACK_MODES_OUT_10G_OFST 16
1393#define MC_CMD_GET_LOOPBACK_MODES_OUT_10G_LEN 8
1394#define MC_CMD_GET_LOOPBACK_MODES_OUT_10G_LO_OFST 16
1395#define MC_CMD_GET_LOOPBACK_MODES_OUT_10G_HI_OFST 20
1396/* Enum values, see field(s): */
1397/* 100M */
1398#define MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_OFST 24
1399#define MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_LEN 8
1400#define MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_LO_OFST 24
1401#define MC_CMD_GET_LOOPBACK_MODES_OUT_SUGGESTED_HI_OFST 28
1402/* Enum values, see field(s): */
1403/* 100M */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001404
Ben Hutchings05a93202011-12-20 00:44:06 +00001405
1406/***********************************/
1407/* MC_CMD_GET_LINK
1408 * Read the unified MAC/PHY link state.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001409 */
1410#define MC_CMD_GET_LINK 0x29
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001411
Ben Hutchings05a93202011-12-20 00:44:06 +00001412/* MC_CMD_GET_LINK_IN msgrequest */
1413#define MC_CMD_GET_LINK_IN_LEN 0
1414
1415/* MC_CMD_GET_LINK_OUT msgresponse */
1416#define MC_CMD_GET_LINK_OUT_LEN 28
1417#define MC_CMD_GET_LINK_OUT_CAP_OFST 0
1418#define MC_CMD_GET_LINK_OUT_LP_CAP_OFST 4
1419#define MC_CMD_GET_LINK_OUT_LINK_SPEED_OFST 8
1420#define MC_CMD_GET_LINK_OUT_LOOPBACK_MODE_OFST 12
1421/* Enum values, see field(s): */
1422/* MC_CMD_GET_LOOPBACK_MODES/MC_CMD_GET_LOOPBACK_MODES_OUT/100M */
1423#define MC_CMD_GET_LINK_OUT_FLAGS_OFST 16
1424#define MC_CMD_GET_LINK_OUT_LINK_UP_LBN 0
1425#define MC_CMD_GET_LINK_OUT_LINK_UP_WIDTH 1
1426#define MC_CMD_GET_LINK_OUT_FULL_DUPLEX_LBN 1
1427#define MC_CMD_GET_LINK_OUT_FULL_DUPLEX_WIDTH 1
1428#define MC_CMD_GET_LINK_OUT_BPX_LINK_LBN 2
1429#define MC_CMD_GET_LINK_OUT_BPX_LINK_WIDTH 1
1430#define MC_CMD_GET_LINK_OUT_PHY_LINK_LBN 3
1431#define MC_CMD_GET_LINK_OUT_PHY_LINK_WIDTH 1
1432#define MC_CMD_GET_LINK_OUT_FCNTL_OFST 20
1433#define MC_CMD_FCNTL_OFF 0x0 /* enum */
1434#define MC_CMD_FCNTL_RESPOND 0x1 /* enum */
1435#define MC_CMD_FCNTL_BIDIR 0x2 /* enum */
1436#define MC_CMD_GET_LINK_OUT_MAC_FAULT_OFST 24
1437#define MC_CMD_MAC_FAULT_XGMII_LOCAL_LBN 0
1438#define MC_CMD_MAC_FAULT_XGMII_LOCAL_WIDTH 1
1439#define MC_CMD_MAC_FAULT_XGMII_REMOTE_LBN 1
1440#define MC_CMD_MAC_FAULT_XGMII_REMOTE_WIDTH 1
1441#define MC_CMD_MAC_FAULT_SGMII_REMOTE_LBN 2
1442#define MC_CMD_MAC_FAULT_SGMII_REMOTE_WIDTH 1
1443#define MC_CMD_MAC_FAULT_PENDING_RECONFIG_LBN 3
1444#define MC_CMD_MAC_FAULT_PENDING_RECONFIG_WIDTH 1
1445
1446
1447/***********************************/
1448/* MC_CMD_SET_LINK
1449 * Write the unified MAC/PHY link configuration.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001450 */
1451#define MC_CMD_SET_LINK 0x2a
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001452
Ben Hutchings05a93202011-12-20 00:44:06 +00001453/* MC_CMD_SET_LINK_IN msgrequest */
1454#define MC_CMD_SET_LINK_IN_LEN 16
1455#define MC_CMD_SET_LINK_IN_CAP_OFST 0
1456#define MC_CMD_SET_LINK_IN_FLAGS_OFST 4
1457#define MC_CMD_SET_LINK_IN_LOWPOWER_LBN 0
1458#define MC_CMD_SET_LINK_IN_LOWPOWER_WIDTH 1
1459#define MC_CMD_SET_LINK_IN_POWEROFF_LBN 1
1460#define MC_CMD_SET_LINK_IN_POWEROFF_WIDTH 1
1461#define MC_CMD_SET_LINK_IN_TXDIS_LBN 2
1462#define MC_CMD_SET_LINK_IN_TXDIS_WIDTH 1
1463#define MC_CMD_SET_LINK_IN_LOOPBACK_MODE_OFST 8
1464/* Enum values, see field(s): */
1465/* MC_CMD_GET_LOOPBACK_MODES/MC_CMD_GET_LOOPBACK_MODES_OUT/100M */
1466#define MC_CMD_SET_LINK_IN_LOOPBACK_SPEED_OFST 12
1467
1468/* MC_CMD_SET_LINK_OUT msgresponse */
1469#define MC_CMD_SET_LINK_OUT_LEN 0
1470
1471
1472/***********************************/
1473/* MC_CMD_SET_ID_LED
1474 * Set indentification LED state.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001475 */
1476#define MC_CMD_SET_ID_LED 0x2b
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001477
Ben Hutchings05a93202011-12-20 00:44:06 +00001478/* MC_CMD_SET_ID_LED_IN msgrequest */
1479#define MC_CMD_SET_ID_LED_IN_LEN 4
1480#define MC_CMD_SET_ID_LED_IN_STATE_OFST 0
1481#define MC_CMD_LED_OFF 0x0 /* enum */
1482#define MC_CMD_LED_ON 0x1 /* enum */
1483#define MC_CMD_LED_DEFAULT 0x2 /* enum */
1484
1485/* MC_CMD_SET_ID_LED_OUT msgresponse */
1486#define MC_CMD_SET_ID_LED_OUT_LEN 0
1487
1488
1489/***********************************/
1490/* MC_CMD_SET_MAC
1491 * Set MAC configuration.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001492 */
1493#define MC_CMD_SET_MAC 0x2c
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001494
Ben Hutchings05a93202011-12-20 00:44:06 +00001495/* MC_CMD_SET_MAC_IN msgrequest */
1496#define MC_CMD_SET_MAC_IN_LEN 24
1497#define MC_CMD_SET_MAC_IN_MTU_OFST 0
1498#define MC_CMD_SET_MAC_IN_DRAIN_OFST 4
1499#define MC_CMD_SET_MAC_IN_ADDR_OFST 8
1500#define MC_CMD_SET_MAC_IN_ADDR_LEN 8
1501#define MC_CMD_SET_MAC_IN_ADDR_LO_OFST 8
1502#define MC_CMD_SET_MAC_IN_ADDR_HI_OFST 12
1503#define MC_CMD_SET_MAC_IN_REJECT_OFST 16
1504#define MC_CMD_SET_MAC_IN_REJECT_UNCST_LBN 0
1505#define MC_CMD_SET_MAC_IN_REJECT_UNCST_WIDTH 1
1506#define MC_CMD_SET_MAC_IN_REJECT_BRDCST_LBN 1
1507#define MC_CMD_SET_MAC_IN_REJECT_BRDCST_WIDTH 1
1508#define MC_CMD_SET_MAC_IN_FCNTL_OFST 20
1509/* MC_CMD_FCNTL_OFF 0x0 */
1510/* MC_CMD_FCNTL_RESPOND 0x1 */
1511/* MC_CMD_FCNTL_BIDIR 0x2 */
1512#define MC_CMD_FCNTL_AUTO 0x3 /* enum */
1513
1514/* MC_CMD_SET_MAC_OUT msgresponse */
1515#define MC_CMD_SET_MAC_OUT_LEN 0
1516
1517
1518/***********************************/
1519/* MC_CMD_PHY_STATS
1520 * Get generic PHY statistics.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001521 */
1522#define MC_CMD_PHY_STATS 0x2d
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001523
Ben Hutchings05a93202011-12-20 00:44:06 +00001524/* MC_CMD_PHY_STATS_IN msgrequest */
1525#define MC_CMD_PHY_STATS_IN_LEN 8
1526#define MC_CMD_PHY_STATS_IN_DMA_ADDR_OFST 0
1527#define MC_CMD_PHY_STATS_IN_DMA_ADDR_LEN 8
1528#define MC_CMD_PHY_STATS_IN_DMA_ADDR_LO_OFST 0
1529#define MC_CMD_PHY_STATS_IN_DMA_ADDR_HI_OFST 4
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001530
Ben Hutchings05a93202011-12-20 00:44:06 +00001531/* MC_CMD_PHY_STATS_OUT_DMA msgresponse */
1532#define MC_CMD_PHY_STATS_OUT_DMA_LEN 0
1533
1534/* MC_CMD_PHY_STATS_OUT_NO_DMA msgresponse */
1535#define MC_CMD_PHY_STATS_OUT_NO_DMA_LEN (((MC_CMD_PHY_NSTATS*32))>>3)
1536#define MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_OFST 0
1537#define MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_LEN 4
1538#define MC_CMD_PHY_STATS_OUT_NO_DMA_STATISTICS_NUM MC_CMD_PHY_NSTATS
1539#define MC_CMD_OUI 0x0 /* enum */
1540#define MC_CMD_PMA_PMD_LINK_UP 0x1 /* enum */
1541#define MC_CMD_PMA_PMD_RX_FAULT 0x2 /* enum */
1542#define MC_CMD_PMA_PMD_TX_FAULT 0x3 /* enum */
1543#define MC_CMD_PMA_PMD_SIGNAL 0x4 /* enum */
1544#define MC_CMD_PMA_PMD_SNR_A 0x5 /* enum */
1545#define MC_CMD_PMA_PMD_SNR_B 0x6 /* enum */
1546#define MC_CMD_PMA_PMD_SNR_C 0x7 /* enum */
1547#define MC_CMD_PMA_PMD_SNR_D 0x8 /* enum */
1548#define MC_CMD_PCS_LINK_UP 0x9 /* enum */
1549#define MC_CMD_PCS_RX_FAULT 0xa /* enum */
1550#define MC_CMD_PCS_TX_FAULT 0xb /* enum */
1551#define MC_CMD_PCS_BER 0xc /* enum */
1552#define MC_CMD_PCS_BLOCK_ERRORS 0xd /* enum */
1553#define MC_CMD_PHYXS_LINK_UP 0xe /* enum */
1554#define MC_CMD_PHYXS_RX_FAULT 0xf /* enum */
1555#define MC_CMD_PHYXS_TX_FAULT 0x10 /* enum */
1556#define MC_CMD_PHYXS_ALIGN 0x11 /* enum */
1557#define MC_CMD_PHYXS_SYNC 0x12 /* enum */
1558#define MC_CMD_AN_LINK_UP 0x13 /* enum */
1559#define MC_CMD_AN_COMPLETE 0x14 /* enum */
1560#define MC_CMD_AN_10GBT_STATUS 0x15 /* enum */
1561#define MC_CMD_CL22_LINK_UP 0x16 /* enum */
1562#define MC_CMD_PHY_NSTATS 0x17 /* enum */
1563
1564
1565/***********************************/
1566/* MC_CMD_MAC_STATS
1567 * Get generic MAC statistics.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001568 */
1569#define MC_CMD_MAC_STATS 0x2e
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001570
Ben Hutchings05a93202011-12-20 00:44:06 +00001571/* MC_CMD_MAC_STATS_IN msgrequest */
1572#define MC_CMD_MAC_STATS_IN_LEN 16
1573#define MC_CMD_MAC_STATS_IN_DMA_ADDR_OFST 0
1574#define MC_CMD_MAC_STATS_IN_DMA_ADDR_LEN 8
1575#define MC_CMD_MAC_STATS_IN_DMA_ADDR_LO_OFST 0
1576#define MC_CMD_MAC_STATS_IN_DMA_ADDR_HI_OFST 4
1577#define MC_CMD_MAC_STATS_IN_CMD_OFST 8
1578#define MC_CMD_MAC_STATS_IN_DMA_LBN 0
1579#define MC_CMD_MAC_STATS_IN_DMA_WIDTH 1
1580#define MC_CMD_MAC_STATS_IN_CLEAR_LBN 1
1581#define MC_CMD_MAC_STATS_IN_CLEAR_WIDTH 1
1582#define MC_CMD_MAC_STATS_IN_PERIODIC_CHANGE_LBN 2
1583#define MC_CMD_MAC_STATS_IN_PERIODIC_CHANGE_WIDTH 1
1584#define MC_CMD_MAC_STATS_IN_PERIODIC_ENABLE_LBN 3
1585#define MC_CMD_MAC_STATS_IN_PERIODIC_ENABLE_WIDTH 1
1586#define MC_CMD_MAC_STATS_IN_PERIODIC_CLEAR_LBN 4
1587#define MC_CMD_MAC_STATS_IN_PERIODIC_CLEAR_WIDTH 1
1588#define MC_CMD_MAC_STATS_IN_PERIODIC_NOEVENT_LBN 5
1589#define MC_CMD_MAC_STATS_IN_PERIODIC_NOEVENT_WIDTH 1
1590#define MC_CMD_MAC_STATS_IN_PERIOD_MS_LBN 16
1591#define MC_CMD_MAC_STATS_IN_PERIOD_MS_WIDTH 16
1592#define MC_CMD_MAC_STATS_IN_DMA_LEN_OFST 12
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001593
Ben Hutchings05a93202011-12-20 00:44:06 +00001594/* MC_CMD_MAC_STATS_OUT_DMA msgresponse */
1595#define MC_CMD_MAC_STATS_OUT_DMA_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001596
Ben Hutchings05a93202011-12-20 00:44:06 +00001597/* MC_CMD_MAC_STATS_OUT_NO_DMA msgresponse */
1598#define MC_CMD_MAC_STATS_OUT_NO_DMA_LEN (((MC_CMD_MAC_NSTATS*64))>>3)
1599#define MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_OFST 0
1600#define MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_LEN 8
1601#define MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_LO_OFST 0
1602#define MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_HI_OFST 4
1603#define MC_CMD_MAC_STATS_OUT_NO_DMA_STATISTICS_NUM MC_CMD_MAC_NSTATS
1604#define MC_CMD_MAC_GENERATION_START 0x0 /* enum */
1605#define MC_CMD_MAC_TX_PKTS 0x1 /* enum */
1606#define MC_CMD_MAC_TX_PAUSE_PKTS 0x2 /* enum */
1607#define MC_CMD_MAC_TX_CONTROL_PKTS 0x3 /* enum */
1608#define MC_CMD_MAC_TX_UNICAST_PKTS 0x4 /* enum */
1609#define MC_CMD_MAC_TX_MULTICAST_PKTS 0x5 /* enum */
1610#define MC_CMD_MAC_TX_BROADCAST_PKTS 0x6 /* enum */
1611#define MC_CMD_MAC_TX_BYTES 0x7 /* enum */
1612#define MC_CMD_MAC_TX_BAD_BYTES 0x8 /* enum */
1613#define MC_CMD_MAC_TX_LT64_PKTS 0x9 /* enum */
1614#define MC_CMD_MAC_TX_64_PKTS 0xa /* enum */
1615#define MC_CMD_MAC_TX_65_TO_127_PKTS 0xb /* enum */
1616#define MC_CMD_MAC_TX_128_TO_255_PKTS 0xc /* enum */
1617#define MC_CMD_MAC_TX_256_TO_511_PKTS 0xd /* enum */
1618#define MC_CMD_MAC_TX_512_TO_1023_PKTS 0xe /* enum */
1619#define MC_CMD_MAC_TX_1024_TO_15XX_PKTS 0xf /* enum */
1620#define MC_CMD_MAC_TX_15XX_TO_JUMBO_PKTS 0x10 /* enum */
1621#define MC_CMD_MAC_TX_GTJUMBO_PKTS 0x11 /* enum */
1622#define MC_CMD_MAC_TX_BAD_FCS_PKTS 0x12 /* enum */
1623#define MC_CMD_MAC_TX_SINGLE_COLLISION_PKTS 0x13 /* enum */
1624#define MC_CMD_MAC_TX_MULTIPLE_COLLISION_PKTS 0x14 /* enum */
1625#define MC_CMD_MAC_TX_EXCESSIVE_COLLISION_PKTS 0x15 /* enum */
1626#define MC_CMD_MAC_TX_LATE_COLLISION_PKTS 0x16 /* enum */
1627#define MC_CMD_MAC_TX_DEFERRED_PKTS 0x17 /* enum */
1628#define MC_CMD_MAC_TX_EXCESSIVE_DEFERRED_PKTS 0x18 /* enum */
1629#define MC_CMD_MAC_TX_NON_TCPUDP_PKTS 0x19 /* enum */
1630#define MC_CMD_MAC_TX_MAC_SRC_ERR_PKTS 0x1a /* enum */
1631#define MC_CMD_MAC_TX_IP_SRC_ERR_PKTS 0x1b /* enum */
1632#define MC_CMD_MAC_RX_PKTS 0x1c /* enum */
1633#define MC_CMD_MAC_RX_PAUSE_PKTS 0x1d /* enum */
1634#define MC_CMD_MAC_RX_GOOD_PKTS 0x1e /* enum */
1635#define MC_CMD_MAC_RX_CONTROL_PKTS 0x1f /* enum */
1636#define MC_CMD_MAC_RX_UNICAST_PKTS 0x20 /* enum */
1637#define MC_CMD_MAC_RX_MULTICAST_PKTS 0x21 /* enum */
1638#define MC_CMD_MAC_RX_BROADCAST_PKTS 0x22 /* enum */
1639#define MC_CMD_MAC_RX_BYTES 0x23 /* enum */
1640#define MC_CMD_MAC_RX_BAD_BYTES 0x24 /* enum */
1641#define MC_CMD_MAC_RX_64_PKTS 0x25 /* enum */
1642#define MC_CMD_MAC_RX_65_TO_127_PKTS 0x26 /* enum */
1643#define MC_CMD_MAC_RX_128_TO_255_PKTS 0x27 /* enum */
1644#define MC_CMD_MAC_RX_256_TO_511_PKTS 0x28 /* enum */
1645#define MC_CMD_MAC_RX_512_TO_1023_PKTS 0x29 /* enum */
1646#define MC_CMD_MAC_RX_1024_TO_15XX_PKTS 0x2a /* enum */
1647#define MC_CMD_MAC_RX_15XX_TO_JUMBO_PKTS 0x2b /* enum */
1648#define MC_CMD_MAC_RX_GTJUMBO_PKTS 0x2c /* enum */
1649#define MC_CMD_MAC_RX_UNDERSIZE_PKTS 0x2d /* enum */
1650#define MC_CMD_MAC_RX_BAD_FCS_PKTS 0x2e /* enum */
1651#define MC_CMD_MAC_RX_OVERFLOW_PKTS 0x2f /* enum */
1652#define MC_CMD_MAC_RX_FALSE_CARRIER_PKTS 0x30 /* enum */
1653#define MC_CMD_MAC_RX_SYMBOL_ERROR_PKTS 0x31 /* enum */
1654#define MC_CMD_MAC_RX_ALIGN_ERROR_PKTS 0x32 /* enum */
1655#define MC_CMD_MAC_RX_LENGTH_ERROR_PKTS 0x33 /* enum */
1656#define MC_CMD_MAC_RX_INTERNAL_ERROR_PKTS 0x34 /* enum */
1657#define MC_CMD_MAC_RX_JABBER_PKTS 0x35 /* enum */
1658#define MC_CMD_MAC_RX_NODESC_DROPS 0x36 /* enum */
1659#define MC_CMD_MAC_RX_LANES01_CHAR_ERR 0x37 /* enum */
1660#define MC_CMD_MAC_RX_LANES23_CHAR_ERR 0x38 /* enum */
1661#define MC_CMD_MAC_RX_LANES01_DISP_ERR 0x39 /* enum */
1662#define MC_CMD_MAC_RX_LANES23_DISP_ERR 0x3a /* enum */
1663#define MC_CMD_MAC_RX_MATCH_FAULT 0x3b /* enum */
1664#define MC_CMD_GMAC_DMABUF_START 0x40 /* enum */
1665#define MC_CMD_GMAC_DMABUF_END 0x5f /* enum */
1666#define MC_CMD_MAC_GENERATION_END 0x60 /* enum */
1667#define MC_CMD_MAC_NSTATS 0x61 /* enum */
1668
1669
1670/***********************************/
1671/* MC_CMD_SRIOV
1672 * to be documented
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001673 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001674#define MC_CMD_SRIOV 0x30
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001675
Ben Hutchings05a93202011-12-20 00:44:06 +00001676/* MC_CMD_SRIOV_IN msgrequest */
1677#define MC_CMD_SRIOV_IN_LEN 12
1678#define MC_CMD_SRIOV_IN_ENABLE_OFST 0
1679#define MC_CMD_SRIOV_IN_VI_BASE_OFST 4
1680#define MC_CMD_SRIOV_IN_VF_COUNT_OFST 8
1681
1682/* MC_CMD_SRIOV_OUT msgresponse */
1683#define MC_CMD_SRIOV_OUT_LEN 8
1684#define MC_CMD_SRIOV_OUT_VI_SCALE_OFST 0
1685#define MC_CMD_SRIOV_OUT_VF_TOTAL_OFST 4
1686
1687/* MC_CMD_MEMCPY_RECORD_TYPEDEF structuredef */
1688#define MC_CMD_MEMCPY_RECORD_TYPEDEF_LEN 32
1689#define MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_OFST 0
1690#define MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_LBN 0
1691#define MC_CMD_MEMCPY_RECORD_TYPEDEF_NUM_RECORDS_WIDTH 32
1692#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_OFST 4
1693#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_LBN 32
1694#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_RID_WIDTH 32
1695#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_OFST 8
1696#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LEN 8
1697#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LO_OFST 8
1698#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_HI_OFST 12
1699#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_LBN 64
1700#define MC_CMD_MEMCPY_RECORD_TYPEDEF_TO_ADDR_WIDTH 64
1701#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_OFST 16
1702#define MC_CMD_MEMCPY_RECORD_TYPEDEF_RID_INLINE 0x100 /* enum */
1703#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_LBN 128
1704#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_RID_WIDTH 32
1705#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_OFST 20
1706#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LEN 8
1707#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LO_OFST 20
1708#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_HI_OFST 24
1709#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_LBN 160
1710#define MC_CMD_MEMCPY_RECORD_TYPEDEF_FROM_ADDR_WIDTH 64
1711#define MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_OFST 28
1712#define MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_LBN 224
1713#define MC_CMD_MEMCPY_RECORD_TYPEDEF_LENGTH_WIDTH 32
1714
1715
1716/***********************************/
1717/* MC_CMD_MEMCPY
1718 * Perform memory copy operation.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001719 */
Ben Hutchings05a93202011-12-20 00:44:06 +00001720#define MC_CMD_MEMCPY 0x31
1721
1722/* MC_CMD_MEMCPY_IN msgrequest */
1723#define MC_CMD_MEMCPY_IN_LENMIN 32
1724#define MC_CMD_MEMCPY_IN_LENMAX 224
1725#define MC_CMD_MEMCPY_IN_LEN(num) (0+32*(num))
1726#define MC_CMD_MEMCPY_IN_RECORD_OFST 0
1727#define MC_CMD_MEMCPY_IN_RECORD_LEN 32
1728#define MC_CMD_MEMCPY_IN_RECORD_MINNUM 1
1729#define MC_CMD_MEMCPY_IN_RECORD_MAXNUM 7
1730
1731/* MC_CMD_MEMCPY_OUT msgresponse */
1732#define MC_CMD_MEMCPY_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001733
1734
Ben Hutchings05a93202011-12-20 00:44:06 +00001735/***********************************/
1736/* MC_CMD_WOL_FILTER_SET
1737 * Set a WoL filter.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001738 */
1739#define MC_CMD_WOL_FILTER_SET 0x32
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001740
Ben Hutchings05a93202011-12-20 00:44:06 +00001741/* MC_CMD_WOL_FILTER_SET_IN msgrequest */
1742#define MC_CMD_WOL_FILTER_SET_IN_LEN 192
1743#define MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0
1744#define MC_CMD_FILTER_MODE_SIMPLE 0x0 /* enum */
1745#define MC_CMD_FILTER_MODE_STRUCTURED 0xffffffff /* enum */
1746#define MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4
1747#define MC_CMD_WOL_TYPE_MAGIC 0x0 /* enum */
1748#define MC_CMD_WOL_TYPE_WIN_MAGIC 0x2 /* enum */
1749#define MC_CMD_WOL_TYPE_IPV4_SYN 0x3 /* enum */
1750#define MC_CMD_WOL_TYPE_IPV6_SYN 0x4 /* enum */
1751#define MC_CMD_WOL_TYPE_BITMAP 0x5 /* enum */
1752#define MC_CMD_WOL_TYPE_LINK 0x6 /* enum */
1753#define MC_CMD_WOL_TYPE_MAX 0x7 /* enum */
1754#define MC_CMD_WOL_FILTER_SET_IN_DATA_OFST 8
1755#define MC_CMD_WOL_FILTER_SET_IN_DATA_LEN 4
1756#define MC_CMD_WOL_FILTER_SET_IN_DATA_NUM 46
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001757
Ben Hutchings05a93202011-12-20 00:44:06 +00001758/* MC_CMD_WOL_FILTER_SET_IN_MAGIC msgrequest */
1759#define MC_CMD_WOL_FILTER_SET_IN_MAGIC_LEN 16
1760/* MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1761/* MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1762#define MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_OFST 8
1763#define MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_LEN 8
1764#define MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_LO_OFST 8
1765#define MC_CMD_WOL_FILTER_SET_IN_MAGIC_MAC_HI_OFST 12
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001766
Ben Hutchings05a93202011-12-20 00:44:06 +00001767/* MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN msgrequest */
1768#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_LEN 20
1769/* MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1770/* MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1771#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_IP_OFST 8
1772#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_IP_OFST 12
1773#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_PORT_OFST 16
1774#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_SRC_PORT_LEN 2
1775#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_PORT_OFST 18
1776#define MC_CMD_WOL_FILTER_SET_IN_IPV4_SYN_DST_PORT_LEN 2
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001777
Ben Hutchings05a93202011-12-20 00:44:06 +00001778/* MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN msgrequest */
1779#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_LEN 44
1780/* MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1781/* MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1782#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_IP_OFST 8
1783#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_IP_LEN 16
1784#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_IP_OFST 24
1785#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_IP_LEN 16
1786#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_PORT_OFST 40
1787#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_SRC_PORT_LEN 2
1788#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_PORT_OFST 42
1789#define MC_CMD_WOL_FILTER_SET_IN_IPV6_SYN_DST_PORT_LEN 2
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001790
Ben Hutchings05a93202011-12-20 00:44:06 +00001791/* MC_CMD_WOL_FILTER_SET_IN_BITMAP msgrequest */
1792#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN 187
1793/* MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1794/* MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1795#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_MASK_OFST 8
1796#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_MASK_LEN 48
1797#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_BITMAP_OFST 56
1798#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_BITMAP_LEN 128
1799#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN_OFST 184
1800#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LEN_LEN 1
1801#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER3_OFST 185
1802#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER3_LEN 1
1803#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER4_OFST 186
1804#define MC_CMD_WOL_FILTER_SET_IN_BITMAP_LAYER4_LEN 1
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001805
Ben Hutchings05a93202011-12-20 00:44:06 +00001806/* MC_CMD_WOL_FILTER_SET_IN_LINK msgrequest */
1807#define MC_CMD_WOL_FILTER_SET_IN_LINK_LEN 12
1808/* MC_CMD_WOL_FILTER_SET_IN_FILTER_MODE_OFST 0 */
1809/* MC_CMD_WOL_FILTER_SET_IN_WOL_TYPE_OFST 4 */
1810#define MC_CMD_WOL_FILTER_SET_IN_LINK_MASK_OFST 8
1811#define MC_CMD_WOL_FILTER_SET_IN_LINK_UP_LBN 0
1812#define MC_CMD_WOL_FILTER_SET_IN_LINK_UP_WIDTH 1
1813#define MC_CMD_WOL_FILTER_SET_IN_LINK_DOWN_LBN 1
1814#define MC_CMD_WOL_FILTER_SET_IN_LINK_DOWN_WIDTH 1
Ben Hutchings5297a982010-02-03 09:28:14 +00001815
Ben Hutchings05a93202011-12-20 00:44:06 +00001816/* MC_CMD_WOL_FILTER_SET_OUT msgresponse */
1817#define MC_CMD_WOL_FILTER_SET_OUT_LEN 4
1818#define MC_CMD_WOL_FILTER_SET_OUT_FILTER_ID_OFST 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001819
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001820
Ben Hutchings05a93202011-12-20 00:44:06 +00001821/***********************************/
1822/* MC_CMD_WOL_FILTER_REMOVE
1823 * Remove a WoL filter.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001824 */
1825#define MC_CMD_WOL_FILTER_REMOVE 0x33
Ben Hutchings05a93202011-12-20 00:44:06 +00001826
1827/* MC_CMD_WOL_FILTER_REMOVE_IN msgrequest */
1828#define MC_CMD_WOL_FILTER_REMOVE_IN_LEN 4
1829#define MC_CMD_WOL_FILTER_REMOVE_IN_FILTER_ID_OFST 0
1830
1831/* MC_CMD_WOL_FILTER_REMOVE_OUT msgresponse */
1832#define MC_CMD_WOL_FILTER_REMOVE_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001833
1834
Ben Hutchings05a93202011-12-20 00:44:06 +00001835/***********************************/
1836/* MC_CMD_WOL_FILTER_RESET
1837 * Reset (i.e. remove all) WoL filters.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001838 */
1839#define MC_CMD_WOL_FILTER_RESET 0x34
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001840
Ben Hutchings05a93202011-12-20 00:44:06 +00001841/* MC_CMD_WOL_FILTER_RESET_IN msgrequest */
1842#define MC_CMD_WOL_FILTER_RESET_IN_LEN 4
1843#define MC_CMD_WOL_FILTER_RESET_IN_MASK_OFST 0
1844#define MC_CMD_WOL_FILTER_RESET_IN_WAKE_FILTERS 0x1 /* enum */
1845#define MC_CMD_WOL_FILTER_RESET_IN_LIGHTSOUT_OFFLOADS 0x2 /* enum */
1846
1847/* MC_CMD_WOL_FILTER_RESET_OUT msgresponse */
1848#define MC_CMD_WOL_FILTER_RESET_OUT_LEN 0
1849
1850
1851/***********************************/
1852/* MC_CMD_SET_MCAST_HASH
1853 * Set the MCASH hash value.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001854 */
1855#define MC_CMD_SET_MCAST_HASH 0x35
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001856
Ben Hutchings05a93202011-12-20 00:44:06 +00001857/* MC_CMD_SET_MCAST_HASH_IN msgrequest */
1858#define MC_CMD_SET_MCAST_HASH_IN_LEN 32
1859#define MC_CMD_SET_MCAST_HASH_IN_HASH0_OFST 0
1860#define MC_CMD_SET_MCAST_HASH_IN_HASH0_LEN 16
1861#define MC_CMD_SET_MCAST_HASH_IN_HASH1_OFST 16
1862#define MC_CMD_SET_MCAST_HASH_IN_HASH1_LEN 16
1863
1864/* MC_CMD_SET_MCAST_HASH_OUT msgresponse */
1865#define MC_CMD_SET_MCAST_HASH_OUT_LEN 0
1866
1867
1868/***********************************/
1869/* MC_CMD_NVRAM_TYPES
1870 * Get virtual NVRAM partitions information.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001871 */
1872#define MC_CMD_NVRAM_TYPES 0x36
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001873
Ben Hutchings05a93202011-12-20 00:44:06 +00001874/* MC_CMD_NVRAM_TYPES_IN msgrequest */
1875#define MC_CMD_NVRAM_TYPES_IN_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001876
Ben Hutchings05a93202011-12-20 00:44:06 +00001877/* MC_CMD_NVRAM_TYPES_OUT msgresponse */
1878#define MC_CMD_NVRAM_TYPES_OUT_LEN 4
1879#define MC_CMD_NVRAM_TYPES_OUT_TYPES_OFST 0
1880#define MC_CMD_NVRAM_TYPE_DISABLED_CALLISTO 0x0 /* enum */
1881#define MC_CMD_NVRAM_TYPE_MC_FW 0x1 /* enum */
1882#define MC_CMD_NVRAM_TYPE_MC_FW_BACKUP 0x2 /* enum */
1883#define MC_CMD_NVRAM_TYPE_STATIC_CFG_PORT0 0x3 /* enum */
1884#define MC_CMD_NVRAM_TYPE_STATIC_CFG_PORT1 0x4 /* enum */
1885#define MC_CMD_NVRAM_TYPE_DYNAMIC_CFG_PORT0 0x5 /* enum */
1886#define MC_CMD_NVRAM_TYPE_DYNAMIC_CFG_PORT1 0x6 /* enum */
1887#define MC_CMD_NVRAM_TYPE_EXP_ROM 0x7 /* enum */
1888#define MC_CMD_NVRAM_TYPE_EXP_ROM_CFG_PORT0 0x8 /* enum */
1889#define MC_CMD_NVRAM_TYPE_EXP_ROM_CFG_PORT1 0x9 /* enum */
1890#define MC_CMD_NVRAM_TYPE_PHY_PORT0 0xa /* enum */
1891#define MC_CMD_NVRAM_TYPE_PHY_PORT1 0xb /* enum */
1892#define MC_CMD_NVRAM_TYPE_LOG 0xc /* enum */
1893#define MC_CMD_NVRAM_TYPE_FPGA 0xd /* enum */
1894
1895
1896/***********************************/
1897/* MC_CMD_NVRAM_INFO
1898 * Read info about a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001899 */
1900#define MC_CMD_NVRAM_INFO 0x37
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001901
Ben Hutchings05a93202011-12-20 00:44:06 +00001902/* MC_CMD_NVRAM_INFO_IN msgrequest */
1903#define MC_CMD_NVRAM_INFO_IN_LEN 4
1904#define MC_CMD_NVRAM_INFO_IN_TYPE_OFST 0
1905/* Enum values, see field(s): */
1906/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1907
1908/* MC_CMD_NVRAM_INFO_OUT msgresponse */
1909#define MC_CMD_NVRAM_INFO_OUT_LEN 24
1910#define MC_CMD_NVRAM_INFO_OUT_TYPE_OFST 0
1911/* Enum values, see field(s): */
1912/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1913#define MC_CMD_NVRAM_INFO_OUT_SIZE_OFST 4
1914#define MC_CMD_NVRAM_INFO_OUT_ERASESIZE_OFST 8
1915#define MC_CMD_NVRAM_INFO_OUT_FLAGS_OFST 12
1916#define MC_CMD_NVRAM_INFO_OUT_PROTECTED_LBN 0
1917#define MC_CMD_NVRAM_INFO_OUT_PROTECTED_WIDTH 1
1918#define MC_CMD_NVRAM_INFO_OUT_PHYSDEV_OFST 16
1919#define MC_CMD_NVRAM_INFO_OUT_PHYSADDR_OFST 20
1920
1921
1922/***********************************/
1923/* MC_CMD_NVRAM_UPDATE_START
1924 * Start a group of update operations on a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001925 */
1926#define MC_CMD_NVRAM_UPDATE_START 0x38
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001927
Ben Hutchings05a93202011-12-20 00:44:06 +00001928/* MC_CMD_NVRAM_UPDATE_START_IN msgrequest */
1929#define MC_CMD_NVRAM_UPDATE_START_IN_LEN 4
1930#define MC_CMD_NVRAM_UPDATE_START_IN_TYPE_OFST 0
1931/* Enum values, see field(s): */
1932/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1933
1934/* MC_CMD_NVRAM_UPDATE_START_OUT msgresponse */
1935#define MC_CMD_NVRAM_UPDATE_START_OUT_LEN 0
1936
1937
1938/***********************************/
1939/* MC_CMD_NVRAM_READ
1940 * Read data from a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001941 */
1942#define MC_CMD_NVRAM_READ 0x39
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001943
Ben Hutchings05a93202011-12-20 00:44:06 +00001944/* MC_CMD_NVRAM_READ_IN msgrequest */
1945#define MC_CMD_NVRAM_READ_IN_LEN 12
1946#define MC_CMD_NVRAM_READ_IN_TYPE_OFST 0
1947/* Enum values, see field(s): */
1948/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1949#define MC_CMD_NVRAM_READ_IN_OFFSET_OFST 4
1950#define MC_CMD_NVRAM_READ_IN_LENGTH_OFST 8
1951
1952/* MC_CMD_NVRAM_READ_OUT msgresponse */
1953#define MC_CMD_NVRAM_READ_OUT_LENMIN 1
Ben Hutchings576eda82012-09-19 02:46:37 +01001954#define MC_CMD_NVRAM_READ_OUT_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +00001955#define MC_CMD_NVRAM_READ_OUT_LEN(num) (0+1*(num))
1956#define MC_CMD_NVRAM_READ_OUT_READ_BUFFER_OFST 0
1957#define MC_CMD_NVRAM_READ_OUT_READ_BUFFER_LEN 1
1958#define MC_CMD_NVRAM_READ_OUT_READ_BUFFER_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +01001959#define MC_CMD_NVRAM_READ_OUT_READ_BUFFER_MAXNUM 252
Ben Hutchings05a93202011-12-20 00:44:06 +00001960
1961
1962/***********************************/
1963/* MC_CMD_NVRAM_WRITE
1964 * Write data to a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001965 */
1966#define MC_CMD_NVRAM_WRITE 0x3a
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001967
Ben Hutchings05a93202011-12-20 00:44:06 +00001968/* MC_CMD_NVRAM_WRITE_IN msgrequest */
1969#define MC_CMD_NVRAM_WRITE_IN_LENMIN 13
Ben Hutchings576eda82012-09-19 02:46:37 +01001970#define MC_CMD_NVRAM_WRITE_IN_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +00001971#define MC_CMD_NVRAM_WRITE_IN_LEN(num) (12+1*(num))
1972#define MC_CMD_NVRAM_WRITE_IN_TYPE_OFST 0
1973/* Enum values, see field(s): */
1974/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1975#define MC_CMD_NVRAM_WRITE_IN_OFFSET_OFST 4
1976#define MC_CMD_NVRAM_WRITE_IN_LENGTH_OFST 8
1977#define MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_OFST 12
1978#define MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_LEN 1
1979#define MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +01001980#define MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_MAXNUM 240
Ben Hutchings05a93202011-12-20 00:44:06 +00001981
1982/* MC_CMD_NVRAM_WRITE_OUT msgresponse */
1983#define MC_CMD_NVRAM_WRITE_OUT_LEN 0
1984
1985
1986/***********************************/
1987/* MC_CMD_NVRAM_ERASE
1988 * Erase sector(s) from a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001989 */
1990#define MC_CMD_NVRAM_ERASE 0x3b
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00001991
Ben Hutchings05a93202011-12-20 00:44:06 +00001992/* MC_CMD_NVRAM_ERASE_IN msgrequest */
1993#define MC_CMD_NVRAM_ERASE_IN_LEN 12
1994#define MC_CMD_NVRAM_ERASE_IN_TYPE_OFST 0
1995/* Enum values, see field(s): */
1996/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
1997#define MC_CMD_NVRAM_ERASE_IN_OFFSET_OFST 4
1998#define MC_CMD_NVRAM_ERASE_IN_LENGTH_OFST 8
1999
2000/* MC_CMD_NVRAM_ERASE_OUT msgresponse */
2001#define MC_CMD_NVRAM_ERASE_OUT_LEN 0
2002
2003
2004/***********************************/
2005/* MC_CMD_NVRAM_UPDATE_FINISH
2006 * Finish a group of update operations on a virtual NVRAM partition.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002007 */
2008#define MC_CMD_NVRAM_UPDATE_FINISH 0x3c
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002009
Ben Hutchings05a93202011-12-20 00:44:06 +00002010/* MC_CMD_NVRAM_UPDATE_FINISH_IN msgrequest */
2011#define MC_CMD_NVRAM_UPDATE_FINISH_IN_LEN 8
2012#define MC_CMD_NVRAM_UPDATE_FINISH_IN_TYPE_OFST 0
2013/* Enum values, see field(s): */
2014/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
2015#define MC_CMD_NVRAM_UPDATE_FINISH_IN_REBOOT_OFST 4
2016
2017/* MC_CMD_NVRAM_UPDATE_FINISH_OUT msgresponse */
2018#define MC_CMD_NVRAM_UPDATE_FINISH_OUT_LEN 0
2019
2020
2021/***********************************/
2022/* MC_CMD_REBOOT
Ben Hutchings5297a982010-02-03 09:28:14 +00002023 * Reboot the MC.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002024 */
2025#define MC_CMD_REBOOT 0x3d
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002026
Ben Hutchings05a93202011-12-20 00:44:06 +00002027/* MC_CMD_REBOOT_IN msgrequest */
2028#define MC_CMD_REBOOT_IN_LEN 4
2029#define MC_CMD_REBOOT_IN_FLAGS_OFST 0
2030#define MC_CMD_REBOOT_FLAGS_AFTER_ASSERTION 0x1 /* enum */
2031
2032/* MC_CMD_REBOOT_OUT msgresponse */
2033#define MC_CMD_REBOOT_OUT_LEN 0
2034
2035
2036/***********************************/
2037/* MC_CMD_SCHEDINFO
2038 * Request scheduler info.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002039 */
2040#define MC_CMD_SCHEDINFO 0x3e
Ben Hutchings05a93202011-12-20 00:44:06 +00002041
2042/* MC_CMD_SCHEDINFO_IN msgrequest */
2043#define MC_CMD_SCHEDINFO_IN_LEN 0
2044
2045/* MC_CMD_SCHEDINFO_OUT msgresponse */
2046#define MC_CMD_SCHEDINFO_OUT_LENMIN 4
2047#define MC_CMD_SCHEDINFO_OUT_LENMAX 252
2048#define MC_CMD_SCHEDINFO_OUT_LEN(num) (0+4*(num))
2049#define MC_CMD_SCHEDINFO_OUT_DATA_OFST 0
2050#define MC_CMD_SCHEDINFO_OUT_DATA_LEN 4
2051#define MC_CMD_SCHEDINFO_OUT_DATA_MINNUM 1
2052#define MC_CMD_SCHEDINFO_OUT_DATA_MAXNUM 63
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002053
2054
Ben Hutchings05a93202011-12-20 00:44:06 +00002055/***********************************/
2056/* MC_CMD_REBOOT_MODE
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002057 */
2058#define MC_CMD_REBOOT_MODE 0x3f
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002059
Ben Hutchings05a93202011-12-20 00:44:06 +00002060/* MC_CMD_REBOOT_MODE_IN msgrequest */
2061#define MC_CMD_REBOOT_MODE_IN_LEN 4
2062#define MC_CMD_REBOOT_MODE_IN_VALUE_OFST 0
2063#define MC_CMD_REBOOT_MODE_NORMAL 0x0 /* enum */
2064#define MC_CMD_REBOOT_MODE_SNAPPER 0x3 /* enum */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002065
Ben Hutchings05a93202011-12-20 00:44:06 +00002066/* MC_CMD_REBOOT_MODE_OUT msgresponse */
2067#define MC_CMD_REBOOT_MODE_OUT_LEN 4
2068#define MC_CMD_REBOOT_MODE_OUT_VALUE_OFST 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002069
2070
Ben Hutchings05a93202011-12-20 00:44:06 +00002071/***********************************/
2072/* MC_CMD_SENSOR_INFO
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002073 * Returns information about every available sensor.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002074 */
2075#define MC_CMD_SENSOR_INFO 0x41
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002076
Ben Hutchings05a93202011-12-20 00:44:06 +00002077/* MC_CMD_SENSOR_INFO_IN msgrequest */
2078#define MC_CMD_SENSOR_INFO_IN_LEN 0
2079
2080/* MC_CMD_SENSOR_INFO_OUT msgresponse */
2081#define MC_CMD_SENSOR_INFO_OUT_LENMIN 12
2082#define MC_CMD_SENSOR_INFO_OUT_LENMAX 252
2083#define MC_CMD_SENSOR_INFO_OUT_LEN(num) (4+8*(num))
2084#define MC_CMD_SENSOR_INFO_OUT_MASK_OFST 0
2085#define MC_CMD_SENSOR_CONTROLLER_TEMP 0x0 /* enum */
2086#define MC_CMD_SENSOR_PHY_COMMON_TEMP 0x1 /* enum */
2087#define MC_CMD_SENSOR_CONTROLLER_COOLING 0x2 /* enum */
2088#define MC_CMD_SENSOR_PHY0_TEMP 0x3 /* enum */
2089#define MC_CMD_SENSOR_PHY0_COOLING 0x4 /* enum */
2090#define MC_CMD_SENSOR_PHY1_TEMP 0x5 /* enum */
2091#define MC_CMD_SENSOR_PHY1_COOLING 0x6 /* enum */
2092#define MC_CMD_SENSOR_IN_1V0 0x7 /* enum */
2093#define MC_CMD_SENSOR_IN_1V2 0x8 /* enum */
2094#define MC_CMD_SENSOR_IN_1V8 0x9 /* enum */
2095#define MC_CMD_SENSOR_IN_2V5 0xa /* enum */
2096#define MC_CMD_SENSOR_IN_3V3 0xb /* enum */
2097#define MC_CMD_SENSOR_IN_12V0 0xc /* enum */
2098#define MC_CMD_SENSOR_IN_1V2A 0xd /* enum */
2099#define MC_CMD_SENSOR_IN_VREF 0xe /* enum */
2100#define MC_CMD_SENSOR_ENTRY_OFST 4
2101#define MC_CMD_SENSOR_ENTRY_LEN 8
2102#define MC_CMD_SENSOR_ENTRY_LO_OFST 4
2103#define MC_CMD_SENSOR_ENTRY_HI_OFST 8
2104#define MC_CMD_SENSOR_ENTRY_MINNUM 1
2105#define MC_CMD_SENSOR_ENTRY_MAXNUM 31
2106
2107/* MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF structuredef */
2108#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_LEN 8
2109#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_OFST 0
2110#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_LEN 2
2111#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_LBN 0
2112#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN1_WIDTH 16
2113#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_OFST 2
2114#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_LEN 2
2115#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_LBN 16
2116#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX1_WIDTH 16
2117#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_OFST 4
2118#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_LEN 2
2119#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_LBN 32
2120#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MIN2_WIDTH 16
2121#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_OFST 6
2122#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_LEN 2
2123#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_LBN 48
2124#define MC_CMD_SENSOR_INFO_ENTRY_TYPEDEF_MAX2_WIDTH 16
2125
2126
2127/***********************************/
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002128/* MC_CMD_READ_SENSORS
Ben Hutchings05a93202011-12-20 00:44:06 +00002129 * Returns the current reading from each sensor.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002130 */
2131#define MC_CMD_READ_SENSORS 0x42
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002132
Ben Hutchings05a93202011-12-20 00:44:06 +00002133/* MC_CMD_READ_SENSORS_IN msgrequest */
2134#define MC_CMD_READ_SENSORS_IN_LEN 8
2135#define MC_CMD_READ_SENSORS_IN_DMA_ADDR_OFST 0
2136#define MC_CMD_READ_SENSORS_IN_DMA_ADDR_LEN 8
2137#define MC_CMD_READ_SENSORS_IN_DMA_ADDR_LO_OFST 0
2138#define MC_CMD_READ_SENSORS_IN_DMA_ADDR_HI_OFST 4
2139
2140/* MC_CMD_READ_SENSORS_OUT msgresponse */
2141#define MC_CMD_READ_SENSORS_OUT_LEN 0
2142
2143/* MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF structuredef */
2144#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_LEN 3
2145#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_OFST 0
2146#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_LEN 2
2147#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_LBN 0
2148#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_VALUE_WIDTH 16
2149#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_OFST 2
2150#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_LEN 1
2151#define MC_CMD_SENSOR_STATE_OK 0x0 /* enum */
2152#define MC_CMD_SENSOR_STATE_WARNING 0x1 /* enum */
2153#define MC_CMD_SENSOR_STATE_FATAL 0x2 /* enum */
2154#define MC_CMD_SENSOR_STATE_BROKEN 0x3 /* enum */
2155#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_LBN 16
2156#define MC_CMD_SENSOR_VALUE_ENTRY_TYPEDEF_STATE_WIDTH 8
Ben Hutchings5297a982010-02-03 09:28:14 +00002157
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002158
Ben Hutchings05a93202011-12-20 00:44:06 +00002159/***********************************/
2160/* MC_CMD_GET_PHY_STATE
2161 * Report current state of PHY.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002162 */
2163#define MC_CMD_GET_PHY_STATE 0x43
2164
Ben Hutchings05a93202011-12-20 00:44:06 +00002165/* MC_CMD_GET_PHY_STATE_IN msgrequest */
2166#define MC_CMD_GET_PHY_STATE_IN_LEN 0
2167
2168/* MC_CMD_GET_PHY_STATE_OUT msgresponse */
2169#define MC_CMD_GET_PHY_STATE_OUT_LEN 4
2170#define MC_CMD_GET_PHY_STATE_OUT_STATE_OFST 0
2171#define MC_CMD_PHY_STATE_OK 0x1 /* enum */
2172#define MC_CMD_PHY_STATE_ZOMBIE 0x2 /* enum */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002173
2174
Ben Hutchings05a93202011-12-20 00:44:06 +00002175/***********************************/
2176/* MC_CMD_SETUP_8021QBB
2177 * 802.1Qbb control.
2178 */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002179#define MC_CMD_SETUP_8021QBB 0x44
Ben Hutchings05a93202011-12-20 00:44:06 +00002180
2181/* MC_CMD_SETUP_8021QBB_IN msgrequest */
2182#define MC_CMD_SETUP_8021QBB_IN_LEN 32
2183#define MC_CMD_SETUP_8021QBB_IN_TXQS_OFST 0
2184#define MC_CMD_SETUP_8021QBB_IN_TXQS_LEN 32
2185
2186/* MC_CMD_SETUP_8021QBB_OUT msgresponse */
2187#define MC_CMD_SETUP_8021QBB_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002188
2189
Ben Hutchings05a93202011-12-20 00:44:06 +00002190/***********************************/
2191/* MC_CMD_WOL_FILTER_GET
2192 * Retrieve ID of any WoL filters.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002193 */
2194#define MC_CMD_WOL_FILTER_GET 0x45
Ben Hutchings05a93202011-12-20 00:44:06 +00002195
2196/* MC_CMD_WOL_FILTER_GET_IN msgrequest */
2197#define MC_CMD_WOL_FILTER_GET_IN_LEN 0
2198
2199/* MC_CMD_WOL_FILTER_GET_OUT msgresponse */
2200#define MC_CMD_WOL_FILTER_GET_OUT_LEN 4
2201#define MC_CMD_WOL_FILTER_GET_OUT_FILTER_ID_OFST 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002202
2203
Ben Hutchings05a93202011-12-20 00:44:06 +00002204/***********************************/
2205/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD
2206 * Add a protocol offload to NIC for lights-out state.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002207 */
2208#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD 0x46
2209
Ben Hutchings05a93202011-12-20 00:44:06 +00002210/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN msgrequest */
2211#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LENMIN 8
2212#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LENMAX 252
2213#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_LEN(num) (4+4*(num))
2214#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0
2215#define MC_CMD_LIGHTSOUT_OFFLOAD_PROTOCOL_ARP 0x1 /* enum */
2216#define MC_CMD_LIGHTSOUT_OFFLOAD_PROTOCOL_NS 0x2 /* enum */
2217#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_OFST 4
2218#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_LEN 4
2219#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_MINNUM 1
2220#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_MAXNUM 62
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002221
Ben Hutchings05a93202011-12-20 00:44:06 +00002222/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP msgrequest */
2223#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_LEN 14
2224/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0 */
2225#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_MAC_OFST 4
2226#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_MAC_LEN 6
2227#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_ARP_IP_OFST 10
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002228
Ben Hutchings05a93202011-12-20 00:44:06 +00002229/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS msgrequest */
2230#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_LEN 42
2231/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0 */
2232#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_MAC_OFST 4
2233#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_MAC_LEN 6
2234#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_SNIPV6_OFST 10
2235#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_SNIPV6_LEN 16
2236#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_IPV6_OFST 26
2237#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_NS_IPV6_LEN 16
2238
2239/* MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT msgresponse */
2240#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT_LEN 4
2241#define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_OUT_FILTER_ID_OFST 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002242
2243
Ben Hutchings05a93202011-12-20 00:44:06 +00002244/***********************************/
2245/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD
2246 * Remove a protocol offload from NIC for lights-out state.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002247 */
2248#define MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD 0x47
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002249
Ben Hutchings05a93202011-12-20 00:44:06 +00002250/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN msgrequest */
2251#define MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_LEN 8
2252#define MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_PROTOCOL_OFST 0
2253#define MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_IN_FILTER_ID_OFST 4
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002254
Ben Hutchings05a93202011-12-20 00:44:06 +00002255/* MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_OUT msgresponse */
2256#define MC_CMD_REMOVE_LIGHTSOUT_OFFLOAD_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002257
2258
Ben Hutchings05a93202011-12-20 00:44:06 +00002259/***********************************/
2260/* MC_CMD_MAC_RESET_RESTORE
2261 * Restore MAC after block reset.
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002262 */
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002263#define MC_CMD_MAC_RESET_RESTORE 0x48
Ben Hutchings05a93202011-12-20 00:44:06 +00002264
2265/* MC_CMD_MAC_RESET_RESTORE_IN msgrequest */
2266#define MC_CMD_MAC_RESET_RESTORE_IN_LEN 0
2267
2268/* MC_CMD_MAC_RESET_RESTORE_OUT msgresponse */
2269#define MC_CMD_MAC_RESET_RESTORE_OUT_LEN 0
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002270
Ben Hutchings5297a982010-02-03 09:28:14 +00002271
Ben Hutchings05a93202011-12-20 00:44:06 +00002272/***********************************/
2273/* MC_CMD_TESTASSERT
Ben Hutchings5297a982010-02-03 09:28:14 +00002274 */
Ben Hutchings5297a982010-02-03 09:28:14 +00002275#define MC_CMD_TESTASSERT 0x49
Ben Hutchings5297a982010-02-03 09:28:14 +00002276
Ben Hutchings05a93202011-12-20 00:44:06 +00002277/* MC_CMD_TESTASSERT_IN msgrequest */
2278#define MC_CMD_TESTASSERT_IN_LEN 0
2279
2280/* MC_CMD_TESTASSERT_OUT msgresponse */
2281#define MC_CMD_TESTASSERT_OUT_LEN 0
2282
2283
2284/***********************************/
2285/* MC_CMD_WORKAROUND
2286 * Enable/Disable a given workaround.
Ben Hutchings5297a982010-02-03 09:28:14 +00002287 */
2288#define MC_CMD_WORKAROUND 0x4a
Ben Hutchings5297a982010-02-03 09:28:14 +00002289
Ben Hutchings05a93202011-12-20 00:44:06 +00002290/* MC_CMD_WORKAROUND_IN msgrequest */
2291#define MC_CMD_WORKAROUND_IN_LEN 8
2292#define MC_CMD_WORKAROUND_IN_TYPE_OFST 0
2293#define MC_CMD_WORKAROUND_BUG17230 0x1 /* enum */
2294#define MC_CMD_WORKAROUND_IN_ENABLED_OFST 4
2295
2296/* MC_CMD_WORKAROUND_OUT msgresponse */
2297#define MC_CMD_WORKAROUND_OUT_LEN 0
2298
2299
2300/***********************************/
2301/* MC_CMD_GET_PHY_MEDIA_INFO
2302 * Read media-specific data from PHY.
Ben Hutchings5297a982010-02-03 09:28:14 +00002303 */
2304#define MC_CMD_GET_PHY_MEDIA_INFO 0x4b
Ben Hutchings5297a982010-02-03 09:28:14 +00002305
Ben Hutchings05a93202011-12-20 00:44:06 +00002306/* MC_CMD_GET_PHY_MEDIA_INFO_IN msgrequest */
2307#define MC_CMD_GET_PHY_MEDIA_INFO_IN_LEN 4
2308#define MC_CMD_GET_PHY_MEDIA_INFO_IN_PAGE_OFST 0
2309
2310/* MC_CMD_GET_PHY_MEDIA_INFO_OUT msgresponse */
2311#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_LENMIN 5
Ben Hutchings576eda82012-09-19 02:46:37 +01002312#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_LENMAX 252
Ben Hutchings05a93202011-12-20 00:44:06 +00002313#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_LEN(num) (4+1*(num))
2314#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATALEN_OFST 0
2315#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_OFST 4
2316#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_LEN 1
2317#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_MINNUM 1
Ben Hutchings576eda82012-09-19 02:46:37 +01002318#define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_MAXNUM 248
Ben Hutchings05a93202011-12-20 00:44:06 +00002319
2320
2321/***********************************/
2322/* MC_CMD_NVRAM_TEST
2323 * Test a particular NVRAM partition.
Ben Hutchings5297a982010-02-03 09:28:14 +00002324 */
2325#define MC_CMD_NVRAM_TEST 0x4c
Ben Hutchings5297a982010-02-03 09:28:14 +00002326
Ben Hutchings05a93202011-12-20 00:44:06 +00002327/* MC_CMD_NVRAM_TEST_IN msgrequest */
2328#define MC_CMD_NVRAM_TEST_IN_LEN 4
2329#define MC_CMD_NVRAM_TEST_IN_TYPE_OFST 0
2330/* Enum values, see field(s): */
2331/* MC_CMD_NVRAM_TYPES/MC_CMD_NVRAM_TYPES_OUT/TYPES */
2332
2333/* MC_CMD_NVRAM_TEST_OUT msgresponse */
2334#define MC_CMD_NVRAM_TEST_OUT_LEN 4
2335#define MC_CMD_NVRAM_TEST_OUT_RESULT_OFST 0
2336#define MC_CMD_NVRAM_TEST_PASS 0x0 /* enum */
2337#define MC_CMD_NVRAM_TEST_FAIL 0x1 /* enum */
2338#define MC_CMD_NVRAM_TEST_NOTSUPP 0x2 /* enum */
2339
2340
2341/***********************************/
2342/* MC_CMD_MRSFP_TWEAK
2343 * Read status and/or set parameters for the 'mrsfp' driver.
Ben Hutchings5297a982010-02-03 09:28:14 +00002344 */
2345#define MC_CMD_MRSFP_TWEAK 0x4d
Ben Hutchings5297a982010-02-03 09:28:14 +00002346
Ben Hutchings05a93202011-12-20 00:44:06 +00002347/* MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG msgrequest */
2348#define MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_LEN 16
2349#define MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_TXEQ_LEVEL_OFST 0
2350#define MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_TXEQ_DT_CFG_OFST 4
2351#define MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_RXEQ_BOOST_OFST 8
2352#define MC_CMD_MRSFP_TWEAK_IN_EQ_CONFIG_RXEQ_DT_CFG_OFST 12
Ben Hutchingsfbcfe8e2010-04-28 09:29:14 +00002353
Ben Hutchings05a93202011-12-20 00:44:06 +00002354/* MC_CMD_MRSFP_TWEAK_IN_READ_ONLY msgrequest */
2355#define MC_CMD_MRSFP_TWEAK_IN_READ_ONLY_LEN 0
2356
2357/* MC_CMD_MRSFP_TWEAK_OUT msgresponse */
2358#define MC_CMD_MRSFP_TWEAK_OUT_LEN 12
2359#define MC_CMD_MRSFP_TWEAK_OUT_IOEXP_INPUTS_OFST 0
2360#define MC_CMD_MRSFP_TWEAK_OUT_IOEXP_OUTPUTS_OFST 4
2361#define MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_OFST 8
2362#define MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_OUT 0x0 /* enum */
2363#define MC_CMD_MRSFP_TWEAK_OUT_IOEXP_DIRECTION_IN 0x1 /* enum */
2364
2365
2366/***********************************/
2367/* MC_CMD_SENSOR_SET_LIMS
2368 * Adjusts the sensor limits.
Ben Hutchingsfbcfe8e2010-04-28 09:29:14 +00002369 */
2370#define MC_CMD_SENSOR_SET_LIMS 0x4e
Ben Hutchingsfbcfe8e2010-04-28 09:29:14 +00002371
Ben Hutchings05a93202011-12-20 00:44:06 +00002372/* MC_CMD_SENSOR_SET_LIMS_IN msgrequest */
2373#define MC_CMD_SENSOR_SET_LIMS_IN_LEN 20
2374#define MC_CMD_SENSOR_SET_LIMS_IN_SENSOR_OFST 0
2375/* Enum values, see field(s): */
2376/* MC_CMD_SENSOR_INFO/MC_CMD_SENSOR_INFO_OUT/MASK */
2377#define MC_CMD_SENSOR_SET_LIMS_IN_LOW0_OFST 4
2378#define MC_CMD_SENSOR_SET_LIMS_IN_HI0_OFST 8
2379#define MC_CMD_SENSOR_SET_LIMS_IN_LOW1_OFST 12
2380#define MC_CMD_SENSOR_SET_LIMS_IN_HI1_OFST 16
2381
2382/* MC_CMD_SENSOR_SET_LIMS_OUT msgresponse */
2383#define MC_CMD_SENSOR_SET_LIMS_OUT_LEN 0
2384
2385
2386/***********************************/
2387/* MC_CMD_GET_RESOURCE_LIMITS
2388 */
2389#define MC_CMD_GET_RESOURCE_LIMITS 0x4f
2390
2391/* MC_CMD_GET_RESOURCE_LIMITS_IN msgrequest */
2392#define MC_CMD_GET_RESOURCE_LIMITS_IN_LEN 0
2393
2394/* MC_CMD_GET_RESOURCE_LIMITS_OUT msgresponse */
2395#define MC_CMD_GET_RESOURCE_LIMITS_OUT_LEN 16
2396#define MC_CMD_GET_RESOURCE_LIMITS_OUT_BUFTBL_OFST 0
2397#define MC_CMD_GET_RESOURCE_LIMITS_OUT_EVQ_OFST 4
2398#define MC_CMD_GET_RESOURCE_LIMITS_OUT_RXQ_OFST 8
2399#define MC_CMD_GET_RESOURCE_LIMITS_OUT_TXQ_OFST 12
2400
2401/* MC_CMD_RESOURCE_SPECIFIER enum */
2402#define MC_CMD_RESOURCE_INSTANCE_ANY 0xffffffff /* enum */
2403#define MC_CMD_RESOURCE_INSTANCE_NONE 0xfffffffe /* enum */
2404
Ben Hutchings5297a982010-02-03 09:28:14 +00002405
Steve Hodgsonf0d37f42009-11-29 15:15:07 +00002406#endif /* MCDI_PCOL_H */