Lines Matching +full:route +full:- +full:ptp

1 /* SPDX-License-Identifier: GPL-2.0-only */
4 * Copyright 2009-2018 Solarflare Communications Inc.
5 * Copyright 2019-2020 Xilinx Inc.
13 /* Power-on reset state */
35 /* The 'doorbell' addresses are hard-wired to alert the MC when written */
38 /* The rest of these are firmware-defined */
46 /* Values to be written to the per-port status dword in shared
71 * | | \--- Response
72 * | \------- Error
73 * \------------------------------ Resync (always set)
126 * - To advance a shared memory request if XFLAGS_EVREQ was set
127 * - As a notification (link state, i2c event), controlled
139 * - LEVEL==INFO Command succeeded
140 * - LEVEL==ERR Command failed
151 * non-existent MCDI command MC_CMD_DEBUG_LOG.
156 * Since the event is written in big-endian byte order, this works
157 * providing bits 56-63 of the event are 0xc0.
170 /* Non-existent command target */
192 /* Read-only */
196 /* Non-recursive resource is already acquired */
217 /* V-adaptor not found. */
221 /* V-switch not found. */
229 /* Invalid v-switch type. */
231 /* Invalid v-port type. */
253 * This error code is followed by a 32-bit handle that
266 * an operation failed due to lack of SR-IOV privilege.
275 * May also returned for other operations such as sub-variant switching. */
315 #define SIENA_MC_BOOTROM_COPYCODE_VEC (0x800 - 3 * 0x4)
316 #define HUNT_MC_BOOTROM_COPYCODE_VEC (0x8000 - 3 * 0x4)
317 #define MEDFORD_MC_BOOTROM_COPYCODE_VEC (0x10000 - 3 * 0x4)
319 #define SIENA_MC_BOOTROM_NOFLASH_VEC (0x800 - 2 * 0x4)
320 #define HUNT_MC_BOOTROM_NOFLASH_VEC (0x8000 - 2 * 0x4)
321 #define MEDFORD_MC_BOOTROM_NOFLASH_VEC (0x10000 - 2 * 0x4)
323 #define SIENA_MC_BOOTROM_RECOVERY_VEC (0x800 - 2 * 0x4)
324 #define HUNT_MC_BOOTROM_RECOVERY_VEC (0x8000 - 2 * 0x4)
325 #define MEDFORD_MC_BOOTROM_RECOVERY_VEC (0x10000 - 2 * 0x4)
328 #define MEDFORD_MC_BOOTROM_REAL_NOFLASH_VEC (0x10000 - 4 * 0x4)
356 /* This may be ORed with an EVB_PORT_ID_xxx constant to pass a non-default
357 * stack ID (which must be in the range 1-255) along with an EVB port ID.
363 * may be followed by the (0-based) number of the first argument that
485 /* enum: AOE failed to load - no valid image? */
493 /* enum: Generic AOE fault - likely to have been reported via other means too
509 /* enum: PTP status update */
523 /* enum: FPGA boot-flash contains an invalid image header */
595 /* enum: MUM failed to load - no valid image? */
651 /* Data associated with PTP events which doesn't fit into the main DATA field
690 /* enum: PTP packet received timestamp */
692 /* enum: PTP NIC failure */
694 /* enum: PTP PPS event */
718 /* enum: PTP tick event providing current NIC time */
759 * MC_CMD_DESC_PROXY_FUNC_CONFIG_COMMIT and SF-122927-TC for details.
764 * SF-122927-TC for details.
773 * SF-122927-TC for details.
828 /* For CODE_PTP_RX events, the lowest four bytes of sourceUUID from PTP packet
850 /* For CODE_PTP_TIME events, the major value of the PTP clock */
855 /* For CODE_PTP_TIME events, bits 19-26 of the minor value of the PTP clock */
859 * PTP clock. This is a more generic equivalent of PTP_TIME_MINOR_26_19.
873 /* For CODE_PTP_TIME events where report sync status is enabled, bits 21-26 of
874 * the minor value of the PTP clock
879 * PTP clock. This is a more generic equivalent of PTP_TIME_MINOR_26_21.
892 * should resend it. A non-zero value means that the authorization has been
985 /* enum: Tick event from PTP clock */
989 /* enum: Current status of PTP */
991 /* enum: Port id config to map MC-FC port idx */
1045 * such that bits 32-63 containing | event code, level, source etc remain the
1053 #define FCDI_EXTENDED_EVENT_PPS_TIMESTAMPS_NUM(len) (((len)-8)/8)
1182 * Read multiple 32byte words from MC memory. Note - this command really
1203 #define MC_CMD_READ32_OUT_BUFFER_NUM(len) (((len)-0)/4)
1225 #define MC_CMD_WRITE32_IN_BUFFER_NUM(len) (((len)-4)/4)
1240 * Copy MC code between two locations and jump. Note - this command really
1305 * Select function for function-specific commands.
1378 /* enum: A system-level assertion has failed. */
1380 /* enum: A thread-level assertion has failed. */
1412 /* enum: A system-level assertion has failed. */
1414 /* enum: A thread-level assertion has failed. */
1450 /* enum: A system-level assertion has failed. */
1452 /* enum: A thread-level assertion has failed. */
1478 /* MC firmware unique build ID (as binary SHA-1 value) */
1494 /* MC firmware extra version info (as null-terminated US-ASCII string) */
1497 /* MC firmware build name (as null-terminated US-ASCII string) */
1636 /* MC firmware unique build ID (as binary SHA-1 value) */
1642 /* MC firmware build name (as null-terminated US-ASCII string) */
1645 /* The SUC firmware version as four numbers - a.b.c.d */
1649 /* SUC firmware build date (as 64-bit Unix timestamp) */
1655 * indicates family, memory sizes etc. See SF-116728-SW for further details.
1659 /* The CMC firmware version as four numbers - a.b.c.d */
1663 /* CMC firmware build date (as 64-bit Unix timestamp) */
1671 * => B, ...) FPGA_VERSION[2]: Sub-revision number
1676 /* Extra FPGA revision information (as null-terminated US-ASCII string) */
1679 /* Board name / adapter model (as null-terminated US-ASCII string) */
1685 /* Board serial number (as null-terminated US-ASCII string) */
1692 * Perform PTP operation
1701 /* PTP operation code */
1704 /* enum: Enable PTP packet timestamping operation. */
1706 /* enum: Disable PTP packet timestamping operation. */
1708 /* enum: Send a PTP packet. This operation is used on Siena and Huntington.
1709 * From Medford onwards it is not supported: on those platforms PTP transmit
1715 /* enum: Get the current PTP status. Note that the clock frequency returned (in
1719 /* enum: Adjust the PTP NIC's time. */
1723 /* enum: Basic manufacturing tests. Siena PTP adapters only. */
1725 /* enum: Packet based manufacturing tests. Siena PTP adapters only. */
1727 /* enum: Reset some of the PTP related statistics */
1731 /* enum: Read an FPGA register. Siena PTP adapters only. */
1733 /* enum: Write an FPGA register. Siena PTP adapters only. */
1739 /* enum: Set the MC packet filter VLAN tags for received PTP packets.
1743 /* enum: Set the MC packet filter UUID for received PTP packets. Deprecated for
1747 /* enum: Set the MC packet filter Domain for received PTP packets. Deprecated
1759 /* enum: Get the time format used by this NIC for PTP operations */
1761 /* enum: Get the clock attributes. NOTE- extended version of
1776 * input on the same NIC. Siena PTP adapters only.
1779 /* enum: Set the PTP sync status. Status is used by firmware to report to event
1795 /* PTP timestamping mode. Not used from Huntington onwards. */
1798 /* enum: PTP, version 1 */
1800 /* enum: PTP, version 1, with VLAN headers - deprecated */
1802 /* enum: PTP, version 2 */
1804 /* enum: PTP, version 2, with VLAN headers - deprecated */
1806 /* enum: PTP, version 2, with improved UUID filtering */
1823 #define MC_CMD_PTP_IN_TRANSMIT_PACKET_NUM(len) (((len)-12)/1)
1958 /* MC_CMD_PTP_IN_RESET_STATS msgrequest: Reset PTP statistics */
1991 #define MC_CMD_PTP_IN_FPGAWRITE_BUFFER_NUM(len) (((len)-12)/1)
2207 /* NIC - Host System Clock Synchronization status */
2337 #define MC_CMD_PTP_OUT_SYNCHRONIZE_TIMESET_NUM(len) (((len)-0)/20)
2397 /* enum: PTP peripheral registers incorrect */
2399 /* enum: Failed to read time from PTP peripheral */
2422 #define MC_CMD_PTP_OUT_FPGAREAD_BUFFER_NUM(len) (((len)-0)/1)
2431 /* Time format required/used by for this NIC. Applies to all PTP MCDI
2434 * be assumed. Note this enum is deprecated. Do not add to it- use the
2443 /* enum: Major register has units of seconds, minor 2^-27s per tick */
2448 /* Time format required/used by for this NIC. Applies to all PTP MCDI
2459 /* enum: Major register has units of seconds, minor 2^-27s per tick */
2473 /* Various PTP capabilities */
2497 /* Uncorrected error on PTP transmit timestamps in NIC clock format */
2500 /* Uncorrected error on PTP receive timestamps in NIC clock format */
2512 /* Uncorrected error on PTP transmit timestamps in NIC clock format */
2515 /* Uncorrected error on PTP receive timestamps in NIC clock format */
2524 /* Uncorrected error on non-PTP transmit timestamps in NIC clock format */
2527 /* Uncorrected error on non-PTP receive timestamps in NIC clock format */
2567 #define MC_CMD_CSR_READ32_OUT_BUFFER_NUM(len) (((len)-0)/4)
2590 #define MC_CMD_CSR_WRITE32_IN_BUFFER_NUM(len) (((len)-8)/4)
2620 /* HP OCSD sub-command. When address is not NULL, request activation of OCSD at
2628 /* enum: OCSD (Option Card Sensor Data) sub-command. */
2630 /* enum: Last known valid HP sub-command. */
2632 /* The address to the array of sensor fields. (Or NULL to use a sub-command.)
2638 /* The requested update interval, in seconds. (Or the sub-command if ADDR is
2673 #define MC_CMD_STACKINFO_OUT_THREAD_INFO_NUM(len) (((len)-0)/12)
2792 #define MC_CMD_DBI_WRITE_IN_DBIWROP_NUM(len) (((len)-0)/12)
2832 * Read a 32-bit register from the indirect port register map. The port to
2855 * Write a 32-bit register to the indirect port register map. The port to
2878 * Read a 128-bit register from the indirect port register map. The port to
2901 * Write a 128-bit register to the indirect port register map. The port to
2932 /* PTP offload. */
2965 #define MC_CMD_GET_BOARD_CFG_OUT_FW_SUBTYPE_LIST_NUM(len) (((len)-72)/2)
3010 /* Siena only. This field contains a 16-bit value for each of the types of
3025 * Read DBI register(s) -- extended functionality
3037 #define MC_CMD_DBI_READX_IN_DBIRDOP_NUM(len) (((len)-0)/8)
3052 #define MC_CMD_DBI_READX_OUT_VALUE_NUM(len) (((len)-0)/4)
3083 * Set the 16byte seed for the MC pseudo-random generator.
3114 #define MC_CMD_LTSSM_HIST_OUT_DATA_NUM(len) (((len)-0)/4)
3115 /* variable number of LTSSM values, as bytes. The history is read-to-clear. */
3193 /* enum: Prefer to use "l3xudp" custom datapath firmware (see SF-119495-PD and
3200 * (i.e. non-production) builds.
3203 /* enum: Only this option is allowed for non-admin functions */
3264 /* enum: Prefer to use "l3xudp" custom datapath firmware (see SF-119495-PD and
3271 * (i.e. non-production) builds.
3274 /* enum: Only this option is allowed for non-admin functions */
3276 /* Version of the driver to be reported by management protocols (e.g. NC-SI)
3277 * handled by the NIC. This is a zero-terminated ASCII string.
3296 /* enum: Labels the lowest-numbered function visible to the OS */
3315 /* enum: If set, indicates that TX only spreading is enabled. Even-numbered
3316 * TXQs will use one engine, and odd-numbered TXQs will use the other. This
3317 * also has the effect that only even-numbered RXQs will receive traffic.
3324 * Route UART output to circular buffer in shared memory instead.
3340 * Generic per-port reset. There is no equivalent for per-board reset. Locks
3341 * required: None; Return code: 0, ETIME. NOTE: This command is deprecated -
3358 * Generic per-resource reset. There is no equivalent for per-board reset.
3488 #define MC_CMD_PUTS_IN_STRING_NUM(len) (((len)-12)/1)
3729 /* enum: Timed-out. */
3756 /* enum: Intra-pair short. */
3758 /* enum: Inter-pair short. */
3817 /* enum: RAM test - walk ones. */
3819 /* enum: RAM test - walk zeros. */
3821 /* enum: RAM test - walking inversions zeros/ones. */
3823 /* enum: RAM test - walking inversions checkerboard. */
3825 /* enum: Register test - set / clear individual bits. */
3886 #define MC_CMD_FLUSH_RX_QUEUES_IN_QID_OFST_NUM(len) (((len)-0)/4)
3950 /* enum: PMA-PMD. */
3952 /* enum: Cross-Port. */
3954 /* enum: XGMII-Wireside. */
3970 /* enum: PMA lanes MAC-Serdes. */
3976 /* enum: PMA lanes MAC-Serdes Wireside. */
4066 /* enum: PMA-PMD. */
4068 /* enum: Cross-Port. */
4070 /* enum: XGMII-Wireside. */
4086 /* enum: PMA lanes MAC-Serdes. */
4092 /* enum: PMA lanes MAC-Serdes Wireside. */
4160 /* AN_TYPE structuredef: Auto-negotiation types defined in IEEE802.3 */
4166 /* enum: Clause 28 - BASE-T */
4168 /* enum: Clause 37 - BASE-X */
4170 /* enum: Clause 73 - BASE-R startup protocol for backplane and copper cable
4171 * assemblies. Includes Clause 72/Clause 92 link-training.
4184 /* enum: Clause 74 BASE-R FEC (a.k.a Firecode) */
4186 /* enum: Clause 91/Clause 108 Reed-Solomon FEC */
4207 /* Near-side advertised capabilities. Refer to
4212 /* Link-partner advertised capabilities. Refer to
4218 * reads non-zero.
4275 /* Near-side advertised capabilities. Refer to
4280 /* Link-partner advertised capabilities. Refer to
4286 * reads non-zero.
4341 * e.g. plugged-in module). In general, subset of
4344 * to SUPPORTED_CAP for non-pluggable PMDs. Refer to
4349 /* Auto-negotiation type used on the link */
4405 /* Near-side advertised capabilities. Refer to
4441 /* Near-side advertised capabilities. Refer to
4638 * statistics are dmad to that (page-aligned location). Locks required: None.
4664 /* enum: PMA-PMD Link Up. */
4666 /* enum: PMA-PMD RX Fault. */
4668 /* enum: PMA-PMD TX Fault. */
4670 /* enum: PMA-PMD Signal */
4672 /* enum: PMA-PMD SNR A. */
4674 /* enum: PMA-PMD SNR B. */
4676 /* enum: PMA-PMD SNR C. */
4678 /* enum: PMA-PMD SNR D. */
4700 /* enum: AN link-up. */
4706 /* enum: Clause 22 Link-Up. */
4719 * DMA_ADDR != 0, then the statistics are dmad to that (page-aligned location).
4876 /* enum: RXDP counter: Number of non-host packets. Valid for EF10 with
4917 * 64-bit word of the DMA buffer (at DMA_LEN - sizeof(uint64_t)). Note that
4919 * the last 64-bit word in the buffer when DMA_LEN == MC_CMD_MAC_NSTATS *
4920 * sizeof(uint64_t). See SF-109306-TC, Section 9.2 for details.
4937 /* enum: Number of uncorrected FEC codewords on link (RS-FEC only for Medford2)
4940 /* enum: Number of corrected FEC codewords on link (RS-FEC only for Medford2)
4943 /* enum: Number of corrected 10-bit symbol errors, lane 0 (RS-FEC only) */
4945 /* enum: Number of corrected 10-bit symbol errors, lane 1 (RS-FEC only) */
4947 /* enum: Number of corrected 10-bit symbol errors, lane 2 (RS-FEC only) */
4949 /* enum: Number of corrected 10-bit symbol errors, lane 3 (RS-FEC only) */
5001 * or not 32-bit aligned
5147 #define MC_CMD_MEMCPY_IN_RECORD_NUM(len) (((len)-0)/32)
5565 * from. This allows it to perform a read-modify-write-verify with the write
5581 /* enum: Read from the non-current (i.e. to be updated) partition of an A/B
5591 #define MC_CMD_NVRAM_READ_OUT_READ_BUFFER_NUM(len) (((len)-0)/1)
5615 #define MC_CMD_NVRAM_WRITE_IN_WRITE_BUFFER_NUM(len) (((len)-12)/1)
5727 * per-partition nvram lock in firmware is only released after the verification
5733 * the field are marked with a prefix 'Internal-error'.
5737 /* enum: Invalid return code; only non-zero values are defined. Defined as
5749 /* enum: Error in message digest calculated over the reflash-header, payload
5750 * and reflash-trailer.
5767 /* enum: The image contains a test-signed certificate, but the adapter accepts
5773 /* enum: Internal-error. The signed image is missing the 'contents' section,
5777 /* enum: Internal-error. The bundle header is invalid. */
5779 /* enum: Internal-error. The bundle does not have a valid reflash image layout.
5782 /* enum: Internal-error. The bundle has an inconsistent layout of components or
5786 /* enum: Internal-error. The bundle manifest is inconsistent with components in
5790 /* enum: Internal-error. The number of components in a bundle do not match the
5794 /* enum: Internal-error. The bundle contains too many components for the MC
5798 /* enum: Internal-error. The bundle manifest has an invalid/inconsistent
5802 /* enum: Internal-error. The hash of a component does not match the hash stored
5806 /* enum: Internal-error. Component hash calculation failed. */
5808 /* enum: Internal-error. The component does not have a valid reflash image
5816 /* enum: The update operation is in-progress. */
5872 #define MC_CMD_SCHEDINFO_OUT_DATA_NUM(len) (((len)-0)/4)
5896 /* enum: Power-on Reset. */
5984 #define MC_CMD_SENSOR_INFO_OUT_MC_CMD_SENSOR_ENTRY_NUM(len) (((len)-4)/8)
6079 /* enum: Port 0 PHY power switch over-current: bool */
6081 /* enum: Port 1 PHY power switch over-current: bool */
6083 /* enum: Mop-up microcontroller reference voltage: mV */
6193 #define MC_CMD_SENSOR_INFO_EXT_OUT_MC_CMD_SENSOR_ENTRY_NUM(len) (((len)-4)/8)
6362 * 802.1Qbb control. 8 Tx queues that map to priorities 0 - 7. Use all 1s to
6396 * Add a protocol offload to NIC for lights-out state. Locks required: None.
6409 #define MC_CMD_ADD_LIGHTSOUT_OFFLOAD_IN_DATA_NUM(len) (((len)-4)/4)
6448 * Remove a protocol offload from NIC for lights-out state. Locks required:
6482 * Deliberately trigger an assert-detonation in the firmware for testing
6524 * understand the given workaround number - which should not be treated as a
6526 * workaround, that's between the driver and the mcfw on a per-workaround
6548 * - before adding code that queries this workaround, remember that there's
6563 /* 0 = disable the workaround indicated by TYPE; any non-zero value = enable
6585 * Read media-specific data from PHY (e.g. SFP/SFP+ module ID information for
6588 * output data, are interpreted on a per-type basis. For SFP+: PAGE=0 or 1
6589 * returns a 128-byte block read from module I2C address 0xA0 offset 0 or 0x80.
6607 #define MC_CMD_GET_PHY_MEDIA_INFO_OUT_DATA_NUM(len) (((len)-4)/1)
6657 /* 0-6 low->high de-emph. */
6660 /* 0-8 low->high ref.V */
6663 /* 0-8 0-8 low->high boost */
6666 /* 0-8 low->high ref.V */
6692 * Adjusts the sensor limits. This is a warranty-voiding operation. Returns:
6707 /* interpretation is is sensor-specific. */
6710 /* interpretation is is sensor-specific. */
6713 /* interpretation is is sensor-specific. */
6716 /* interpretation is is sensor-specific. */
6762 #define MC_CMD_NVRAM_PARTITIONS_OUT_TYPE_ID_NUM(len) (((len)-4)/4)
6795 #define MC_CMD_NVRAM_METADATA_OUT_DESCRIPTION_NUM(len) (((len)-20)/1)
6825 /* Zero-terminated string describing the content of this partition */
6863 * Perform a CLP related operation, see SF-110495-PS for details of CLP
6865 * different manufacturers which are to be found in SF-119187-TC, SF-119186-TC,
6866 * SF-120509-TC and SF-117282-PS.
6905 * restores the permanent (factory-programmed) MAC address associated with the
6906 * port. A non-zero MAC address persists until a PCIe reset or a power cycle.
6922 * restores the permanent (factory-programmed) MAC address associated with the
6923 * port. A non-zero MAC address persists until a PCIe reset or a power cycle.
7057 /* enum: Hittite HMC1035 clock generator for NIC-side on Sorrento board */
7059 /* 32-bit address to read from */
7071 #define MC_CMD_MUM_IN_WRITE_BUFFER_NUM(len) (((len)-12)/4)
7080 /* 32-bit address to write to */
7095 #define MC_CMD_MUM_IN_RAW_CMD_WRITE_DATA_NUM(len) (((len)-16)/1)
7164 /* The first 32-bit word to be written to the GPIO OUT register. */
7167 /* The second 32-bit word to be written to the GPIO OUT register. */
7184 /* The first 32-bit word to be written to the GPIO OUT ENABLE register. */
7187 /* The second 32-bit word to be written to the GPIO OUT ENABLE register. */
7271 /* Bit-mask of clocks to be programmed */
7414 #define MC_CMD_MUM_OUT_RAW_CMD_DATA_NUM(len) (((len)-0)/1)
7427 #define MC_CMD_MUM_OUT_READ_BUFFER_NUM(len) (((len)-0)/4)
7445 /* The first 32-bit word read from the GPIO IN register. */
7448 /* The second 32-bit word read from the GPIO IN register. */
7457 /* The first 32-bit word read from the GPIO OUT register. */
7460 /* The second 32-bit word read from the GPIO OUT register. */
7493 #define MC_CMD_MUM_OUT_READ_SENSORS_DATA_NUM(len) (((len)-0)/4)
7548 #define MC_CMD_MUM_OUT_QSFP_GET_MEDIA_INFO_DATA_NUM(len) (((len)-4)/1)
7575 #define MC_CMD_MUM_OUT_READ_DDR_INFO_SODIMM_INFO_RECORD_NUM(len) (((len)-8)/8)
7618 /* enum: Values 5-15 are reserved for future usage */
7695 /* A human-readable name for the sensor (zero terminated string, max 32 bytes)
7765 * MC_CMD_READ_SENSORS command. On multi-MC systems this may include sensors
7801 #define MC_CMD_DYNAMIC_SENSORS_LIST_OUT_HANDLES_NUM(len) (((len)-8)/4)
7843 #define MC_CMD_DYNAMIC_SENSORS_GET_DESCRIPTIONS_IN_HANDLES_NUM(len) (((len)-0)/4)
7856 #define MC_CMD_DYNAMIC_SENSORS_GET_DESCRIPTIONS_OUT_SENSORS_NUM(len) (((len)-0)/64)
7892 #define MC_CMD_DYNAMIC_SENSORS_GET_READINGS_IN_HANDLES_NUM(len) (((len)-0)/4)
7905 #define MC_CMD_DYNAMIC_SENSORS_GET_READINGS_OUT_VALUES_NUM(len) (((len)-0)/12)
7929 #define MC_CMD_EVENT_CTRL_IN_EVENT_TYPE_NUM(len) (((len)-0)/4)
7996 /* the raw 64-bit address field from the SMC, not adjusted for page size */
8028 /* enum: Non-volatile log output partition */
8030 /* enum: Non-volatile log output of second core on dual-core device */
8048 /* enum: Non-volatile log output partition for FC */
8056 /* enum: MUM Non-volatile log output partition. */
8101 * platforms. See SF-119124-PS. The STATIC_CONFIG partition may contain a
8111 /* enum: Bundle update non-volatile log output partition */
8132 /* enum: PTP timestamping */
8342 /* The RSS mode for a particular packet type is a value from 0 - 15 which can
8396 /* Same order as MIPS GDB (r0-r31, sr, lo, hi, bad, cause, 32 x float, fsr,
8419 #define MC_CMD_INIT_EVQ_IN_DMA_ADDR_NUM(len) (((len)-36)/8)
8432 /* The reload value is ignored in one-shot modes */
8467 /* enum: Hold-off */
8492 /* 64-bit address of 4k of 4k-aligned host memory buffer */
8512 #define MC_CMD_INIT_EVQ_V2_IN_DMA_ADDR_NUM(len) (((len)-36)/8)
8525 /* The reload value is ignored in one-shot modes */
8558 * over-ridden by firmware based on licenses and firmware variant in order to
8564 * over-ridden by firmware based on licenses and firmware variant in order to
8569 /* enum: MEDFORD only. Certain initialisation flags may be over-ridden by
8585 /* enum: Hold-off */
8610 /* 64-bit address of 4k of 4k-aligned host memory buffer */
8678 #define MC_CMD_INIT_RXQ_IN_DMA_ADDR_NUM(len) (((len)-28)/8)
8724 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
8727 /* 64-bit address of 4k of 4k-aligned host memory buffer */
8792 * multiple fixed-size packet buffers within each bucket. For a full
8793 * description see SF-119419-TC. This mode is only supported by "dpdk" datapath
8822 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
8825 /* 64-bit address of 4k of 4k-aligned host memory buffer */
8889 * multiple fixed-size packet buffers within each bucket. For a full
8890 * description see SF-119419-TC. This mode is only supported by "dpdk" datapath
8919 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
8922 /* 64-bit address of 4k of 4k-aligned host memory buffer */
9015 * multiple fixed-size packet buffers within each bucket. For a full
9016 * description see SF-119419-TC. This mode is only supported by "dpdk" datapath
9045 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
9048 /* 64-bit address of 4k of 4k-aligned host memory buffer */
9088 * to zero if using this message on non-QDMA based platforms. Currently in
9154 * multiple fixed-size packet buffers within each bucket. For a full
9155 * description see SF-119419-TC. This mode is only supported by "dpdk" datapath
9184 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
9187 /* 64-bit address of 4k of 4k-aligned host memory buffer */
9227 * to zero if using this message on non-QDMA based platforms. Currently in
9275 #define MC_CMD_INIT_TXQ_IN_DMA_ADDR_NUM(len) (((len)-28)/8)
9325 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
9328 /* 64-bit address of 4k of 4k-aligned host memory buffer */
9405 /* The port ID associated with the v-adaptor which should contain this DMAQ. */
9408 /* 64-bit address of 4k of 4k-aligned host memory buffer */
9506 /* Bits 0 - 63 of event */
9778 #define MC_CMD_PROGRAM_BUFTBL_ENTRIES_IN_ENTRY_NUM(len) (((len)-12)/8)
9831 /* enum: single-recipient filter insert */
9833 /* enum: single-recipient filter remove */
9835 /* enum: multi-recipient filter subscribe */
9837 /* enum: multi-recipient filter unsubscribe */
9839 /* enum: replace one recipient with another (warning - the filter handle may
9848 /* The port ID associated with the v-adaptor which should contain this filter.
10004 /* The port ID associated with the v-adaptor which should contain this filter.
10282 /* The port ID associated with the v-adaptor which should contain this filter.
10544 * in the DPDK Firmware Driver Interface (SF-119419-TC). Requesting anything
10610 * Get information related to the parser-dispatcher subsystem
10628 /* enum: read properties relating to security rules (Medford-only; for use by
10629 * SolarSecure apps, not directly by drivers. See SF-114946-SW.)
10647 #define MC_CMD_GET_PARSER_DISP_INFO_OUT_SUPPORTED_MATCHES_NUM(len) (((len)-8)/4)
10689 #define MC_CMD_GET_PARSER_DISP_VNIC_ENCAP_MATCHES_OUT_SUPPORTED_MATCHES_NUM(len) (((len)-8)/4)
10710 * Direct read/write of parser-dispatcher state (DICPUs and LUE) for debugging.
10754 /* enum: Read-modify-write a word of DICPU DMEM (not valid for LUE). Not
10769 /* XOR value (for DMEM read-modify-writes: new = (old & mask) ^ value) */
10772 /* AND mask (for DMEM read-modify-writes: new = (old & mask) ^ value) */
10790 /* up to 8 32-bit words of additional soft state from the LUE manager (the
10791 * exact content is firmware-dependent and intended only for debug use)
10894 /* MC_CMD_ALLOC_VIS_OUT msgresponse: Huntington-compatible VI_ALLOC request.
11442 * 2) PHASE_IMEMS for each of the IMEM targets (target IDs 0-11). Each download
11444 * be a checksum (a simple 32-bit sum) of the transferred data. An individual
11447 * 3) PHASE_VECTORS for each of the vector table targets (target IDs 12-15),
11459 #define MC_CMD_SATELLITE_DOWNLOAD_IN_CHUNK_DATA_NUM(len) (((len)-16)/4)
11723 /* enum: reserved value - do not use (may indicate alternative interpretation
11734 /* enum: RX PD firmware with approximately Siena-compatible behaviour
11756 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
11774 /* enum: reserved value - do not use (may indicate alternative interpretation
11785 /* enum: TX PD firmware with approximately Siena-compatible behaviour
11804 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
11976 /* enum: reserved value - do not use (may indicate alternative interpretation
11987 /* enum: RX PD firmware with approximately Siena-compatible behaviour
12009 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
12027 /* enum: reserved value - do not use (may indicate alternative interpretation
12038 /* enum: TX PD firmware with approximately Siena-compatible behaviour
12057 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
12386 /* enum: reserved value - do not use (may indicate alternative interpretation
12397 /* enum: RX PD firmware with approximately Siena-compatible behaviour
12419 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
12437 /* enum: reserved value - do not use (may indicate alternative interpretation
12448 /* enum: TX PD firmware with approximately Siena-compatible behaviour
12467 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
12641 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
12655 * (SF-115995-SW) in the present configuration of firmware and port mode.
12660 * (SF-115995-SW) in the present configuration of firmware and port mode.
12821 /* enum: reserved value - do not use (may indicate alternative interpretation
12832 /* enum: RX PD firmware with approximately Siena-compatible behaviour
12854 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
12872 /* enum: reserved value - do not use (may indicate alternative interpretation
12883 /* enum: TX PD firmware with approximately Siena-compatible behaviour
12902 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
13076 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
13090 * (SF-115995-SW) in the present configuration of firmware and port mode.
13095 * (SF-115995-SW) in the present configuration of firmware and port mode.
13101 * hold at least this many 64-bit stats values, if they wish to receive all
13264 /* enum: reserved value - do not use (may indicate alternative interpretation
13275 /* enum: RX PD firmware with approximately Siena-compatible behaviour
13297 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
13315 /* enum: reserved value - do not use (may indicate alternative interpretation
13326 /* enum: TX PD firmware with approximately Siena-compatible behaviour
13345 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
13519 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
13533 * (SF-115995-SW) in the present configuration of firmware and port mode.
13538 * (SF-115995-SW) in the present configuration of firmware and port mode.
13544 * hold at least this many 64-bit stats values, if they wish to receive all
13551 * will only be non-zero if MC_CMD_GET_CAPABILITIES/FILTER_ACTION_MARK is set.
13712 /* enum: reserved value - do not use (may indicate alternative interpretation
13723 /* enum: RX PD firmware with approximately Siena-compatible behaviour
13745 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
13763 /* enum: reserved value - do not use (may indicate alternative interpretation
13774 /* enum: TX PD firmware with approximately Siena-compatible behaviour
13793 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
13967 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
13981 * (SF-115995-SW) in the present configuration of firmware and port mode.
13986 * (SF-115995-SW) in the present configuration of firmware and port mode.
13992 * hold at least this many 64-bit stats values, if they wish to receive all
13999 * will only be non-zero if MC_CMD_GET_CAPABILITIES/FILTER_ACTION_MARK is set.
14171 /* enum: reserved value - do not use (may indicate alternative interpretation
14182 /* enum: RX PD firmware with approximately Siena-compatible behaviour
14204 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
14222 /* enum: reserved value - do not use (may indicate alternative interpretation
14233 /* enum: TX PD firmware with approximately Siena-compatible behaviour
14252 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
14426 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
14440 * (SF-115995-SW) in the present configuration of firmware and port mode.
14445 * (SF-115995-SW) in the present configuration of firmware and port mode.
14451 * hold at least this many 64-bit stats values, if they wish to receive all
14458 * will only be non-zero if MC_CMD_GET_CAPABILITIES/FILTER_ACTION_MARK is set.
14657 /* enum: reserved value - do not use (may indicate alternative interpretation
14668 /* enum: RX PD firmware with approximately Siena-compatible behaviour
14690 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
14708 /* enum: reserved value - do not use (may indicate alternative interpretation
14719 /* enum: TX PD firmware with approximately Siena-compatible behaviour
14738 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
14912 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
14926 * (SF-115995-SW) in the present configuration of firmware and port mode.
14931 * (SF-115995-SW) in the present configuration of firmware and port mode.
14937 * hold at least this many 64-bit stats values, if they wish to receive all
14944 * will only be non-zero if MC_CMD_GET_CAPABILITIES/FILTER_ACTION_MARK is set.
14986 /* These bits are reserved for communicating test-specific capabilities to
14987 * host-side test software. All production drivers should treat this field as
15151 /* enum: reserved value - do not use (may indicate alternative interpretation
15162 /* enum: RX PD firmware with approximately Siena-compatible behaviour
15184 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
15202 /* enum: reserved value - do not use (may indicate alternative interpretation
15213 /* enum: TX PD firmware with approximately Siena-compatible behaviour
15232 /* enum: Custom firmware variant (see SF-119495-PD and bug69716) */
15406 * discover the VI to address mapping. Cut-through PIO (CTPIO) is not available
15420 * (SF-115995-SW) in the present configuration of firmware and port mode.
15425 * (SF-115995-SW) in the present configuration of firmware and port mode.
15431 * hold at least this many 64-bit stats values, if they wish to receive all
15438 * will only be non-zero if MC_CMD_GET_CAPABILITIES/FILTER_ACTION_MARK is set.
15480 /* These bits are reserved for communicating test-specific capabilities to
15481 * host-side test software. All production drivers should treat this field as
15506 /* The maximum number of queues that can be used by an RSS context in even-
15507 * spreading mode. In even-spreading mode the context has no indirection table
15761 * allocate and initialise a v-switch.
15770 /* The port to connect to the v-switch's upstream port. */
15773 /* The type of v-switch to create. */
15786 /* Flags controlling v-port creation */
15792 /* The number of VLAN tags to allow for attached v-ports. For VLAN aggregators,
15793 * this must be one or greated, and the attached v-ports must have exactly this
15794 * number of tags. For other v-switch types, this must be zero of greater, and
15795 * is an upper limit on the number of VLAN tags for attached v-ports. An error
15797 * v-ports with this number of tags.
15808 * de-allocate a v-switch.
15817 /* The port to which the v-switch is connected. */
15827 * read some config of v-switch. For now this command is an empty placeholder.
15828 * It may be used to check if a v-switch is connected to a given EVB port (if
15838 /* The port to which the v-switch is connected. */
15848 * allocate a v-port.
15857 /* The port to which the v-switch is connected. */
15860 /* The type of the new v-port. */
15869 /* enum: A normal v-port receives packets which match a specified MAC and/or
15873 /* enum: An expansion v-port packets traffic which don't match any other
15874 * v-port.
15877 /* enum: An test v-port receives packets which match any filters installed by
15881 /* Flags controlling v-port creation */
15892 * v-switch.
15908 /* The handle of the new v-port */
15915 * de-allocate a v-port.
15924 /* The handle of the v-port */
15934 * allocate a v-adaptor.
15943 /* The port to connect to the v-adaptor's port. */
15946 /* Flags controlling v-adaptor creation */
15970 /* The MAC address to assign to this v-adaptor */
15982 * de-allocate a v-adaptor.
15991 /* The port to which the v-adaptor is connected. */
16001 * assign a new MAC address to a v-adaptor.
16010 /* The port to which the v-adaptor is connected. */
16013 /* The new MAC address to assign to this v-adaptor */
16023 * read the MAC address assigned to a v-adaptor.
16032 /* The port to which the v-adaptor is connected. */
16038 /* The MAC address assigned to this v-adaptor */
16045 * read some config of v-adaptor.
16054 /* The port to which the v-adaptor is connected. */
16063 /* The v-adaptor flags as defined at MC_CMD_VADAPTOR_ALLOC. */
16118 /* Write enable bits 0-3, set to write, clear to read. */
16201 * queues, but the key and indirection table are pre-configured and may not be
16214 * the indirection table will be in the range 0 to NUM_QUEUES-1. For even-
16236 * queues, but the key and indirection table are pre-configured and may not be
16249 * the indirection table will be in the range 0 to NUM_QUEUES-1. For even-
16312 /* The 40-byte Toeplitz hash key (TBD endianness issues?) */
16337 /* The 40-byte Toeplitz hash key (TBD endianness issues?) */
16358 /* The 128-byte indirection table (1 byte per entry) */
16385 /* The 128-byte indirection table (1 byte per entry) */
16392 * Write a portion of a selectable-size indirection table for an RSS context.
16406 #define MC_CMD_RSS_CONTEXT_WRITE_TABLE_IN_ENTRIES_NUM(len) (((len)-4)/4)
16410 /* An array of index-value pairs to be written to the table. Structure is
16438 * Read a portion of a selectable-size indirection table for an RSS context.
16452 #define MC_CMD_RSS_CONTEXT_READ_TABLE_IN_INDICES_NUM(len) (((len)-4)/2)
16468 #define MC_CMD_RSS_CONTEXT_READ_TABLE_OUT_DATA_NUM(len) (((len)-0)/2)
16493 * in this case, the MODE fields may be set to non-zero values, and will take
16562 * capability), the _EN bits report the state. If any _MODE bits are non-zero
16565 * guaranteed to be consistent with the _EN flags for a freshly-allocated RSS
16624 /* Number of queues spanned by this mapping, in the range 1-64; valid fixed
16625 * offsets in the mapping table will be in the range 0 to NUM_QUEUES-1, and
16676 /* Per-priority mappings (1 32-bit word per entry - an offset or RSS context
16703 /* Per-priority mappings (1 32-bit word per entry - an offset or RSS context
16764 * Add a MAC address to a v-port
16773 /* The handle of the v-port */
16786 * Delete a MAC address from a v-port
16795 /* The handle of the v-port */
16808 * Delete a MAC address from a v-port
16817 /* The handle of the v-port */
16826 #define MC_CMD_VPORT_GET_MAC_ADDRESSES_OUT_MACADDR_NUM(len) (((len)-4)/6)
16840 * Replace VLAN tags and/or MAC addresses of an existing v-port. If the v-port
16841 * has already been passed to another function (v-port's user), then that
16851 /* The handle of the v-port */
16865 * v-switch.
16897 * read some config of v-port.
16906 /* The handle of the v-port */
16915 /* The number of VLAN tags that may be used on a v-adaptor connected to this
16948 #define MC_CMD_DUMP_BUFTBL_ENTRIES_OUT_ENTRY_NUM(len) (((len)-0)/12)
17051 /* Requested frequency in MHz for inter-core clock domain */
17054 /* enum: Leave the inter-core clock domain frequency unchanged */
17089 /* Resulting inter-core frequency in MHz */
17092 /* enum: The inter-core clock domain doesn't exist / isn't used */
17150 /* First 8 bits [39:32] of DATA are consumed by MC-DPCPU protocol and must be
17207 /* Register data to write. Only valid in write/write-read. */
17302 #define MC_CMD_CAP_BLK_READ_OUT_BUFFER_NUM(len) (((len)-0)/8)
17461 * Adjusts power supply parameters. This is a warranty-voiding operation.
17528 * should we wish to make this reliable; currently requests are fire-and-
17541 #define MC_CMD_UART_SEND_DATA_OUT_DATA_NUM(len) (((len)-16)/1)
17594 #define MC_CMD_UART_RECV_DATA_IN_DATA_NUM(len) (((len)-16)/1)
17616 * Read data programmed into the device One-Time-Programmable (OTP) Fuses
17637 #define MC_CMD_READ_FUSES_OUT_DATA_NUM(len) (((len)-4)/1)
17663 #define MC_CMD_KR_TUNE_IN_KR_TUNE_ARGS_NUM(len) (((len)-4)/4)
17719 #define MC_CMD_KR_TUNE_RXEQ_GET_OUT_PARAM_NUM(len) (((len)-0)/4)
17729 /* enum: Attenuation (0-15, Huntington) */
17731 /* enum: CTLE Boost (0-15, Huntington) */
17733 /* enum: Edge DFE Tap1 (Huntington - 0 - max negative, 64 - zero, 127 - max
17734 * positive, Medford - 0-31)
17737 /* enum: Edge DFE Tap2 (Huntington - 0 - max negative, 32 - zero, 63 - max
17738 * positive, Medford - 0-31)
17741 /* enum: Edge DFE Tap3 (Huntington - 0 - max negative, 32 - zero, 63 - max
17742 * positive, Medford - 0-16)
17745 /* enum: Edge DFE Tap4 (Huntington - 0 - max negative, 32 - zero, 63 - max
17746 * positive, Medford - 0-16)
17749 /* enum: Edge DFE Tap5 (Huntington - 0 - max negative, 32 - zero, 63 - max
17750 * positive, Medford - 0-16)
17753 /* enum: Edge DFE DLEV (0-128 for Medford) */
17755 /* enum: Variable Gain Amplifier (0-15, Medford) */
17757 /* enum: CTLE EQ Capacitor (0-15, Medford) */
17759 /* enum: CTLE EQ Resistor (0-7, Medford) */
17761 /* enum: CTLE gain (0-31, Medford2) */
17763 /* enum: CTLE pole (0-31, Medford2) */
17765 /* enum: CTLE peaking (0-31, Medford2) */
17767 /* enum: DFE Tap1 - even path (Medford2 - 6 bit signed (-29 - +29)) */
17769 /* enum: DFE Tap1 - odd path (Medford2 - 6 bit signed (-29 - +29)) */
17771 /* enum: DFE Tap2 (Medford2 - 6 bit signed (-20 - +20)) */
17773 /* enum: DFE Tap3 (Medford2 - 6 bit signed (-20 - +20)) */
17775 /* enum: DFE Tap4 (Medford2 - 6 bit signed (-20 - +20)) */
17777 /* enum: DFE Tap5 (Medford2 - 6 bit signed (-24 - +24)) */
17779 /* enum: DFE Tap6 (Medford2 - 6 bit signed (-24 - +24)) */
17781 /* enum: DFE Tap7 (Medford2 - 6 bit signed (-24 - +24)) */
17783 /* enum: DFE Tap8 (Medford2 - 6 bit signed (-24 - +24)) */
17785 /* enum: DFE Tap9 (Medford2 - 6 bit signed (-24 - +24)) */
17787 /* enum: DFE Tap10 (Medford2 - 6 bit signed (-24 - +24)) */
17789 /* enum: DFE Tap11 (Medford2 - 6 bit signed (-24 - +24)) */
17791 /* enum: DFE Tap12 (Medford2 - 6 bit signed (-24 - +24)) */
17793 /* enum: I/Q clk offset (Medford2 - 4 bit signed (-5 - +5))) */
17796 * (Medford2 - 6 bit signed (-29 - +29)))
17800 * (Medford2 - 6 bit signed (-29 - +29)))
17804 * (Medford2 - 6 bit signed (-29 - +29)))
17808 * (Medford2 - 6 bit signed (-29 - +29)))
17815 /* enum: CTLE Boost stages - retimer lineside (Medford2 with DS250x retimer - 4
17819 /* enum: DFE Tap1 - retimer lineside (Medford2 with DS250x retimer (-31 - 31))
17822 /* enum: DFE Tap2 - retimer lineside (Medford2 with DS250x retimer (-15 - 15))
17825 /* enum: DFE Tap3 - retimer lineside (Medford2 with DS250x retimer (-15 - 15))
17828 /* enum: DFE Tap4 - retimer lineside (Medford2 with DS250x retimer (-15 - 15))
17831 /* enum: DFE Tap5 - retimer lineside (Medford2 with DS250x retimer (-15 - 15))
17834 /* enum: CTLE Boost stages - retimer hostside (Medford2 with DS250x retimer - 4
17838 /* enum: DFE Tap1 - retimer hostside (Medford2 with DS250x retimer (-31 - 31))
17841 /* enum: DFE Tap2 - retimer hostside (Medford2 with DS250x retimer (-15 - 15))
17844 /* enum: DFE Tap3 - retimer hostside (Medford2 with DS250x retimer (-15 - 15))
17847 /* enum: DFE Tap4 - retimer hostside (Medford2 with DS250x retimer (-15 - 15))
17850 /* enum: DFE Tap5 - retimer hostside (Medford2 with DS250x retimer (-15 - 15))
17879 #define MC_CMD_KR_TUNE_RXEQ_SET_IN_PARAM_NUM(len) (((len)-4)/4)
17932 #define MC_CMD_KR_TUNE_TXEQ_GET_OUT_PARAM_NUM(len) (((len)-0)/4)
17944 /* enum: De-Emphasis Tap1 Magnitude (0-7) (Huntington) */
17946 /* enum: De-Emphasis Tap1 Fine */
17948 /* enum: De-Emphasis Tap2 Magnitude (0-6) (Huntington) */
17950 /* enum: De-Emphasis Tap2 Fine (Huntington) */
17952 /* enum: Pre-Emphasis Magnitude (Huntington) */
17954 /* enum: Pre-Emphasis Fine (Huntington) */
17964 /* enum: Pre-cursor Tap (Medford, Medford2) */
17966 /* enum: Post-cursor Tap (Medford, Medford2) */
17970 /* enum: Pre-cursor Tap (Retimer Lineside) */
17972 /* enum: Post-cursor Tap (Retimer Lineside) */
17976 /* enum: Pre-cursor Tap (Retimer Hostside) */
17978 /* enum: Post-cursor Tap (Retimer Hostside) */
18003 #define MC_CMD_KR_TUNE_TXEQ_SET_IN_PARAM_NUM(len) (((len)-4)/4)
18059 /* Port-relative lane to scan eye on */
18100 #define MC_CMD_KR_TUNE_POLL_EYE_PLOT_OUT_SAMPLES_NUM(len) (((len)-0)/2)
18158 /* C(-1) request */
18177 /* C(-1) status */
18194 /* C(-1) value */
18219 #define MC_CMD_PCIE_TUNE_IN_PCIE_TUNE_ARGS_NUM(len) (((len)-4)/4)
18267 #define MC_CMD_PCIE_TUNE_RXEQ_GET_OUT_PARAM_NUM(len) (((len)-0)/4)
18277 /* enum: Attenuation (0-15) */
18279 /* enum: CTLE Boost (0-15) */
18281 /* enum: DFE Tap1 (0 - max negative, 64 - zero, 127 - max positive) */
18283 /* enum: DFE Tap2 (0 - max negative, 32 - zero, 63 - max positive) */
18285 /* enum: DFE Tap3 (0 - max negative, 32 - zero, 63 - max positive) */
18287 /* enum: DFE Tap4 (0 - max negative, 32 - zero, 63 - max positive) */
18289 /* enum: DFE Tap5 (0 - max negative, 32 - zero, 63 - max positive) */
18334 #define MC_CMD_PCIE_TUNE_RXEQ_SET_IN_PARAM_NUM(len) (((len)-4)/4)
18387 #define MC_CMD_PCIE_TUNE_TXEQ_GET_OUT_PARAM_NUM(len) (((len)-0)/4)
18401 /* enum: De-emphasis coefficient C(-1) (PIPE) */
18403 /* enum: De-emphasis coefficient C(0) (PIPE) */
18405 /* enum: De-emphasis coefficient C(+1) (PIPE) */
18447 #define MC_CMD_PCIE_TUNE_POLL_EYE_PLOT_OUT_SAMPLES_NUM(len) (((len)-0)/2)
18464 * - not used for V3 licensing
18476 /* enum: re-read and apply licenses after a license key partition update; note
18477 * that this operation returns a zero-length response
18508 /* licensing subsystem self-test report (for manftest) */
18511 /* enum: licensing subsystem self-test failed */
18513 /* enum: licensing subsystem self-test passed */
18520 * - V3 licensing (Medford)
18532 /* enum: re-read and apply licenses after a license key partition update; note
18533 * that this operation returns a zero-length response
18562 /* licensing subsystem self-test report (for manftest) */
18565 /* enum: licensing subsystem self-test failed */
18567 /* enum: licensing subsystem self-test passed */
18590 * partition - V3 licensing (Medford)
18605 #define MC_CMD_LICENSING_GET_ID_V3_OUT_LICENSE_ID_NUM(len) (((len)-8)/1)
18622 * Execute an arbitrary MCDI command on the slave MC of a dual-core device.
18623 * This will fail on a single-core system.
18720 /* states of these features - bit set for licensed, clear for not licensed */
18729 * Perform an action for an individual licensed application - not used for V3
18742 #define MC_CMD_LICENSED_APP_OP_IN_ARGS_NUM(len) (((len)-8)/4)
18765 #define MC_CMD_LICENSED_APP_OP_OUT_RESULT_NUM(len) (((len)-0)/4)
18812 * Perform validation for an individual licensed application - V3 licensing
18834 * of two 384-bit integers, r and s, in big-endian order. The signature signs a
18835 * SHA-384 digest of a message constructed from the concatenation of the input
18857 /* MAC address of v-adaptor associated with the client. If no such v-adapator
18866 * Mask features - V3 licensing (Medford)
18896 * SF-116124-SW for an overview of how this could be used. The license is
18966 * configuration. A copy of all traffic delivered to the host (non-promiscuous
19049 * Change configuration related to the parser-dispatcher subsystem.
19061 #define MC_CMD_SET_PARSER_DISP_CONFIG_IN_VALUE_NUM(len) (((len)-8)/4)
19065 /* enum: Per-TXQ enable for multicast UDP destination lookup for possible
19069 /* enum: Per-v-adaptor enable for suppression of self-transmissions on the
19094 * Read configuration related to the parser-dispatcher subsystem.
19119 #define MC_CMD_GET_PARSER_DISP_CONFIG_OUT_VALUE_NUM(len) (((len)-0)/4)
19263 /* The maximum number of MSI-X vectors the device can provide in total */
19266 /* the number of MSI-X vectors the device will allocate by default to each PF
19270 /* the number of MSI-X vectors the device will allocate by default to each VF
19274 /* the maximum number of MSI-X vectors the device can allocate to any one PF */
19277 /* the maximum number of MSI-X vectors the device can allocate to any one VF */
19418 * - before adding code that queries this workaround, remember that there's
19488 * administrator-level operations that are not allowed from the local host once
19490 * SF-117064-DG for background).
19621 * only effects non-admin functions unless the admin privilege itself is
19687 #define MC_CMD_XPM_READ_BYTES_OUT_DATA_NUM(len) (((len)-0)/1)
19710 #define MC_CMD_XPM_WRITE_BYTES_IN_DATA_NUM(len) (((len)-8)/1)
19751 #define MC_CMD_XPM_READ_SECTOR_OUT_DATA_NUM(len) (((len)-4)/1)
19782 #define MC_CMD_XPM_WRITE_SECTOR_IN_DATA_NUM(len) (((len)-12)/1)
19785 * made. Note that uncorrectable errors are unlikely, thanks to XPM self-repair
19835 * Blank-check XPM memory and report bad locations
19856 #define MC_CMD_XPM_BLANK_CHECK_OUT_BAD_ADDR_NUM(len) (((len)-4)/2)
19857 /* Total number of bad (non-blank) locations */
19872 * Blank-check and repair XPM memory
20008 * parser-dispatcher will attempt to parse traffic on these ports as tunnel
20023 #define MC_CMD_SET_TUNNEL_ENCAP_UDP_PORTS_IN_ENTRIES_NUM(len) (((len)-4)/4)
20098 #define MC_CMD_NVRAM_PRIVATE_APPEND_IN_DATA_BUFFER_NUM(len) (((len)-8)/1)
20138 #define MC_CMD_XPM_VERIFY_CONTENTS_OUT_SIGNATURE_NUM(len) (((len)-12)/1)
20172 /* Function-relative queue instance */
20297 #define MC_CMD_ALLOCATE_TX_VFIFO_CP_IN_USE_FUNCTION_VALUE -0x1
20302 /* MC_CMD_ALLOCATE_TX_VFIFO_CP_IN_USE_FUNCTION_VALUE -0x1 */
20339 #define MC_CMD_ALLOCATE_TX_VFIFO_VFIFO_IN_USE_CP_VALUE -0x1
20360 #define MC_CMD_ALLOCATE_TX_VFIFO_VFIFO_IN_LOWEST_AVAILABLE -0x1
20375 * ready to be re-used.
20395 * it ready to be re-used.
20449 /* The SUC firmware version as four numbers - a.b.c.d */
20459 * indicates family, memory sizes etc. See SF-116728-SW for further details.
20485 * combination of fields, then this command returns a list of prefix-ids,
20488 * supported, returns ENOTSUP. If the firmware can't create any new prefix-ids
20539 #define MC_CMD_GET_RX_PREFIX_ID_OUT_RX_PREFIX_ID_NUM(len) (((len)-4)/4)
20540 /* Number of prefix-ids returned */
20591 #define RX_PREFIX_FIXED_RESPONSE_FIELDS_NUM(len) (((len)-4)/4)
20638 #define MC_CMD_QUERY_RX_PREFIX_ID_OUT_RESPONSE_NUM(len) (((len)-4)/1)
20656 * A command to perform various bundle-related operations on insecure cards.
20665 /* Sub-command code */
20679 /* Sub-command code. Must be OP_COMPONENT_ACCESS_GET. */
20690 /* enum: Component partitions are read-only from the host. */
20692 /* enum: Component partitions can read read-from written-to by the host. */
20697 * read-only on firmware built with bundle support. This command marks these
20703 /* Sub-command code. Must be OP_COMPONENT_ACCESS_SET. */
20738 #define MC_CMD_GET_VPD_OUT_DATA_NUM(len) (((len)-0)/1)
20749 * Provide information about the NC-SI stack
20765 /* The NC-SI channel on which the operation is to be performed */
20795 /* The number of NC-SI commands received. */
20798 /* The number of NC-SI commands dropped. */
20801 /* The number of invalid NC-SI commands received. */
20807 /* The number of NC-SI requests received. */
20810 /* The number of NC-SI responses sent (includes AENs) */
20813 /* The number of NC-SI AENs sent */
20854 /* Human-readable ASCII name for clock, with NUL termination */
20879 #define MC_CMD_GET_CLOCKS_INFO_OUT_INFOS_NUM(len) (((len)-0)/28)
20890- on TX the send descriptor explicitly specifies encapsulation. These rules are per-VNIC, i.e. onl…
20902 /* Any non-zero bits other than the ones named below or an unsupported
20987 * defined in SF-120734-TC with more information in SF-122717-TC.
20994 /* enum: Function has an EF100-style function control window and VI windows
21006 /* enum: Function is a Xilinx acceleration device - management function */
21008 /* enum: Function is a Xilinx acceleration device - user function */
21041 * specification ( https://docs.oasis-
21042 * open.org/virtio/virtio/v1.1/csprd01/virtio-v1.1-csprd01.pdf )
21118 /* Desired instance. This is the function-local index of the associated VI, not
21163 * the features returned from MC_CMD_VIRTIO_GET_FEATURES. Features are per-
21328 * embedded Application Processor), via EF100 descriptor proxy, memory-to-
21329 * memory and descriptor-to-completion mechanisms. Primary user is Virtio-blk
21330 * subsystem, see SF-122927-TC. This function allocates a new descriptor proxy
21331 * function on the host and assigns a user-defined label. The actual function
21352 * SF-120734-TC with more information in SF-122717-TC. At present, we only
21359 /* User-defined label (zero-terminated ASCII string) to uniquely identify the
21391 /* User-defined label (zero-terminated ASCII string) to uniquely identify the
21484 /* The capacity of the device (expressed in 512-byte sectors) */
21505 /* Disk-style geometry - cylinders. Only valid when VIRTIO_BLK_F_GEOMETRY is
21512 /* Disk-style geometry - heads. Only valid when VIRTIO_BLK_F_GEOMETRY is set.
21518 /* Disk-style geometry - sectors. Only valid when VIRTIO_BLK_F_GEOMETRY is set.
21529 /* Block topology - number of logical blocks per physical block (log2). Only
21536 /* Block topology - offset of first aligned logical block. Only valid when
21543 /* Block topology - suggested minimum I/O size in blocks. Only valid when
21550 /* Block topology - optimal (suggested maximum) I/O size in blocks. Only valid
21570 /* Maximum discard sectors size, in 512-byte units. Only valid if
21583 /* Discard sector alignment, in 512-byte units. Only valid if
21590 /* Maximum write zeroes sectors size, in 512-byte units. Only valid if
21634 #define MC_CMD_DESC_PROXY_FUNC_CONFIG_SET_IN_CONFIG_NUM(len) (((len)-20)/1)
21659 * Commit function configuration to non-volatile or volatile store. Once
21678 /* enum: Store into non-volatile (dynamic) config */
21694 * integer handle, valid until function is deallocated, MC rebooted or power-
21704 /* User-defined label (zero-terminated ASCII string) to uniquely identify the
21715 #define MC_CMD_DESC_PROXY_FUNC_OPEN_OUT_CONFIG_NUM(len) (((len)-40)/1)
21793 /* User-defined label (zero-terminated ASCII string) to uniquely identify the
21824 #define MC_CMD_DESC_PROXY_FUNC_ENUM_OUT_FUNC_MAP_NUM(len) (((len)-4)/52)
21897 * target. See SF-120734-TC for details on ADDR_SPC_IDs and mem2mem
21936 /* enum: Address space ID for DMA to/from other SmartNIC memory (on-chip, DDR)