mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-13 22:14:20 +08:00
e3cfd49cb9
CDX bus needs to be disabled before updating/writing devices in the FPGA. Once the devices are written, the bus shall be rescanned. This change provides sysfs entry to enable/disable the CDX bus. Co-developed-by: Nipun Gupta <nipun.gupta@amd.com> Signed-off-by: Nipun Gupta <nipun.gupta@amd.com> Signed-off-by: Abhijit Gangurde <abhijit.gangurde@amd.com> Link: https://lore.kernel.org/r/20231017160505.10640-6-abhijit.gangurde@amd.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
645 lines
28 KiB
C
645 lines
28 KiB
C
/* SPDX-License-Identifier: GPL-2.0
|
|
*
|
|
* Driver for AMD network controllers and boards
|
|
*
|
|
* Copyright (C) 2021, Xilinx, Inc.
|
|
* Copyright (C) 2022-2023, Advanced Micro Devices, Inc.
|
|
*/
|
|
|
|
#ifndef MC_CDX_PCOL_H
|
|
#define MC_CDX_PCOL_H
|
|
|
|
/* The current version of the MCDI protocol. */
|
|
#define MCDI_PCOL_VERSION 2
|
|
|
|
/*
|
|
* Each MCDI request starts with an MCDI_HEADER, which is a 32bit
|
|
* structure, filled in by the client.
|
|
*
|
|
* 0 7 8 16 20 22 23 24 31
|
|
* | CODE | R | LEN | SEQ | Rsvd | E | R | XFLAGS |
|
|
* | | |
|
|
* | | \--- Response
|
|
* | \------- Error
|
|
* \------------------------------ Resync (always set)
|
|
*
|
|
* The client writes its request into MC shared memory, and rings the
|
|
* doorbell. Each request is completed either by the MC writing
|
|
* back into shared memory, or by writing out an event.
|
|
*
|
|
* All MCDI commands support completion by shared memory response. Each
|
|
* request may also contain additional data (accounted for by HEADER.LEN),
|
|
* and some responses may also contain additional data (again, accounted
|
|
* for by HEADER.LEN).
|
|
*
|
|
* Some MCDI commands support completion by event, in which any associated
|
|
* response data is included in the event.
|
|
*
|
|
* The protocol requires one response to be delivered for every request; a
|
|
* request should not be sent unless the response for the previous request
|
|
* has been received (either by polling shared memory, or by receiving
|
|
* an event).
|
|
*/
|
|
|
|
/** Request/Response structure */
|
|
#define MCDI_HEADER_OFST 0
|
|
#define MCDI_HEADER_CODE_LBN 0
|
|
#define MCDI_HEADER_CODE_WIDTH 7
|
|
#define MCDI_HEADER_RESYNC_LBN 7
|
|
#define MCDI_HEADER_RESYNC_WIDTH 1
|
|
#define MCDI_HEADER_DATALEN_LBN 8
|
|
#define MCDI_HEADER_DATALEN_WIDTH 8
|
|
#define MCDI_HEADER_SEQ_LBN 16
|
|
#define MCDI_HEADER_SEQ_WIDTH 4
|
|
#define MCDI_HEADER_RSVD_LBN 20
|
|
#define MCDI_HEADER_RSVD_WIDTH 1
|
|
#define MCDI_HEADER_NOT_EPOCH_LBN 21
|
|
#define MCDI_HEADER_NOT_EPOCH_WIDTH 1
|
|
#define MCDI_HEADER_ERROR_LBN 22
|
|
#define MCDI_HEADER_ERROR_WIDTH 1
|
|
#define MCDI_HEADER_RESPONSE_LBN 23
|
|
#define MCDI_HEADER_RESPONSE_WIDTH 1
|
|
#define MCDI_HEADER_XFLAGS_LBN 24
|
|
#define MCDI_HEADER_XFLAGS_WIDTH 8
|
|
/* Request response using event */
|
|
#define MCDI_HEADER_XFLAGS_EVREQ 0x01
|
|
/* Request (and signal) early doorbell return */
|
|
#define MCDI_HEADER_XFLAGS_DBRET 0x02
|
|
|
|
/* Maximum number of payload bytes */
|
|
#define MCDI_CTL_SDU_LEN_MAX_V2 0x400
|
|
|
|
#define MCDI_CTL_SDU_LEN_MAX MCDI_CTL_SDU_LEN_MAX_V2
|
|
|
|
/*
|
|
* The MC can generate events for two reasons:
|
|
* - To advance a shared memory request if XFLAGS_EVREQ was set
|
|
* - As a notification (link state, i2c event), controlled
|
|
* via MC_CMD_LOG_CTRL
|
|
*
|
|
* Both events share a common structure:
|
|
*
|
|
* 0 32 33 36 44 52 60
|
|
* | Data | Cont | Level | Src | Code | Rsvd |
|
|
* |
|
|
* \ There is another event pending in this notification
|
|
*
|
|
* If Code==CMDDONE, then the fields are further interpreted as:
|
|
*
|
|
* - LEVEL==INFO Command succeeded
|
|
* - LEVEL==ERR Command failed
|
|
*
|
|
* 0 8 16 24 32
|
|
* | Seq | Datalen | Errno | Rsvd |
|
|
*
|
|
* These fields are taken directly out of the standard MCDI header, i.e.,
|
|
* LEVEL==ERR, Datalen == 0 => Reboot
|
|
*
|
|
* Events can be squirted out of the UART (using LOG_CTRL) without a
|
|
* MCDI header. An event can be distinguished from a MCDI response by
|
|
* examining the first byte which is 0xc0. This corresponds to the
|
|
* non-existent MCDI command MC_CMD_DEBUG_LOG.
|
|
*
|
|
* 0 7 8
|
|
* | command | Resync | = 0xc0
|
|
*
|
|
* Since the event is written in big-endian byte order, this works
|
|
* providing bits 56-63 of the event are 0xc0.
|
|
*
|
|
* 56 60 63
|
|
* | Rsvd | Code | = 0xc0
|
|
*
|
|
* Which means for convenience the event code is 0xc for all MC
|
|
* generated events.
|
|
*/
|
|
|
|
/*
|
|
* the errno value may be followed by the (0-based) number of the
|
|
* first argument that could not be processed.
|
|
*/
|
|
#define MC_CMD_ERR_ARG_OFST 4
|
|
|
|
/* MC_CMD_ERR MCDI error codes. */
|
|
/* Operation not permitted. */
|
|
#define MC_CMD_ERR_EPERM 0x1
|
|
/* Non-existent command target */
|
|
#define MC_CMD_ERR_ENOENT 0x2
|
|
/* assert() has killed the MC */
|
|
#define MC_CMD_ERR_EINTR 0x4
|
|
/* I/O failure */
|
|
#define MC_CMD_ERR_EIO 0x5
|
|
/* Already exists */
|
|
#define MC_CMD_ERR_EEXIST 0x6
|
|
/* Try again */
|
|
#define MC_CMD_ERR_EAGAIN 0xb
|
|
/* Out of memory */
|
|
#define MC_CMD_ERR_ENOMEM 0xc
|
|
/* Caller does not hold required locks */
|
|
#define MC_CMD_ERR_EACCES 0xd
|
|
/* Resource is currently unavailable (e.g. lock contention) */
|
|
#define MC_CMD_ERR_EBUSY 0x10
|
|
/* No such device */
|
|
#define MC_CMD_ERR_ENODEV 0x13
|
|
/* Invalid argument to target */
|
|
#define MC_CMD_ERR_EINVAL 0x16
|
|
/* No space */
|
|
#define MC_CMD_ERR_ENOSPC 0x1c
|
|
/* Read-only */
|
|
#define MC_CMD_ERR_EROFS 0x1e
|
|
/* Broken pipe */
|
|
#define MC_CMD_ERR_EPIPE 0x20
|
|
/* Out of range */
|
|
#define MC_CMD_ERR_ERANGE 0x22
|
|
/* Non-recursive resource is already acquired */
|
|
#define MC_CMD_ERR_EDEADLK 0x23
|
|
/* Operation not implemented */
|
|
#define MC_CMD_ERR_ENOSYS 0x26
|
|
/* Operation timed out */
|
|
#define MC_CMD_ERR_ETIME 0x3e
|
|
/* Link has been severed */
|
|
#define MC_CMD_ERR_ENOLINK 0x43
|
|
/* Protocol error */
|
|
#define MC_CMD_ERR_EPROTO 0x47
|
|
/* Bad message */
|
|
#define MC_CMD_ERR_EBADMSG 0x4a
|
|
/* Operation not supported */
|
|
#define MC_CMD_ERR_ENOTSUP 0x5f
|
|
/* Address not available */
|
|
#define MC_CMD_ERR_EADDRNOTAVAIL 0x63
|
|
/* Not connected */
|
|
#define MC_CMD_ERR_ENOTCONN 0x6b
|
|
/* Operation already in progress */
|
|
#define MC_CMD_ERR_EALREADY 0x72
|
|
/* Stale handle. The handle references resource that no longer exists */
|
|
#define MC_CMD_ERR_ESTALE 0x74
|
|
/* Resource allocation failed. */
|
|
#define MC_CMD_ERR_ALLOC_FAIL 0x1000
|
|
/* V-adaptor not found. */
|
|
#define MC_CMD_ERR_NO_VADAPTOR 0x1001
|
|
/* EVB port not found. */
|
|
#define MC_CMD_ERR_NO_EVB_PORT 0x1002
|
|
/* V-switch not found. */
|
|
#define MC_CMD_ERR_NO_VSWITCH 0x1003
|
|
/* Too many VLAN tags. */
|
|
#define MC_CMD_ERR_VLAN_LIMIT 0x1004
|
|
/* Bad PCI function number. */
|
|
#define MC_CMD_ERR_BAD_PCI_FUNC 0x1005
|
|
/* Invalid VLAN mode. */
|
|
#define MC_CMD_ERR_BAD_VLAN_MODE 0x1006
|
|
/* Invalid v-switch type. */
|
|
#define MC_CMD_ERR_BAD_VSWITCH_TYPE 0x1007
|
|
/* Invalid v-port type. */
|
|
#define MC_CMD_ERR_BAD_VPORT_TYPE 0x1008
|
|
/* MAC address exists. */
|
|
#define MC_CMD_ERR_MAC_EXIST 0x1009
|
|
/* Slave core not present */
|
|
#define MC_CMD_ERR_SLAVE_NOT_PRESENT 0x100a
|
|
/* The datapath is disabled. */
|
|
#define MC_CMD_ERR_DATAPATH_DISABLED 0x100b
|
|
/* The requesting client is not a function */
|
|
#define MC_CMD_ERR_CLIENT_NOT_FN 0x100c
|
|
/*
|
|
* The requested operation might require the command to be passed between
|
|
* MCs, and the transport doesn't support that. Should only ever been seen over
|
|
* the UART.
|
|
*/
|
|
#define MC_CMD_ERR_NO_PRIVILEGE 0x1013
|
|
/*
|
|
* Workaround 26807 could not be turned on/off because some functions
|
|
* have already installed filters. See the comment at
|
|
* MC_CMD_WORKAROUND_BUG26807. May also returned for other operations such as
|
|
* sub-variant switching.
|
|
*/
|
|
#define MC_CMD_ERR_FILTERS_PRESENT 0x1014
|
|
/* The clock whose frequency you've attempted to set doesn't exist */
|
|
#define MC_CMD_ERR_NO_CLOCK 0x1015
|
|
/*
|
|
* Returned by MC_CMD_TESTASSERT if the action that should have caused an
|
|
* assertion failed to do so.
|
|
*/
|
|
#define MC_CMD_ERR_UNREACHABLE 0x1016
|
|
/*
|
|
* This command needs to be processed in the background but there were no
|
|
* resources to do so. Send it again after a command has completed.
|
|
*/
|
|
#define MC_CMD_ERR_QUEUE_FULL 0x1017
|
|
/*
|
|
* The operation could not be completed because the PCIe link has gone
|
|
* away. This error code is never expected to be returned over the TLP
|
|
* transport.
|
|
*/
|
|
#define MC_CMD_ERR_NO_PCIE 0x1018
|
|
/*
|
|
* The operation could not be completed because the datapath has gone
|
|
* away. This is distinct from MC_CMD_ERR_DATAPATH_DISABLED in that the
|
|
* datapath absence may be temporary
|
|
*/
|
|
#define MC_CMD_ERR_NO_DATAPATH 0x1019
|
|
/* The operation could not complete because some VIs are allocated */
|
|
#define MC_CMD_ERR_VIS_PRESENT 0x101a
|
|
/*
|
|
* The operation could not complete because some PIO buffers are
|
|
* allocated
|
|
*/
|
|
#define MC_CMD_ERR_PIOBUFS_PRESENT 0x101b
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_BUS_ENUM_BUSES
|
|
* CDX bus hosts devices (functions) that are implemented using the Composable
|
|
* DMA subsystem and directly mapped into the memory space of the FGPA PSX
|
|
* Application Processors (APUs). As such, they only apply to the PSX APU side,
|
|
* not the host (PCIe). Unlike PCIe, these devices have no native configuration
|
|
* space or enumeration mechanism, so this message set provides a minimal
|
|
* interface for discovery and management (bus reset, FLR, BME) of such
|
|
* devices. This command returns the number of CDX buses present in the system.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES 0x1
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES_MSGSET 0x1
|
|
#undef MC_CMD_0x1_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x1_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_BUS_ENUM_BUSES_IN msgrequest */
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES_IN_LEN 0
|
|
|
|
/* MC_CMD_CDX_BUS_ENUM_BUSES_OUT msgresponse */
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES_OUT_LEN 4
|
|
/*
|
|
* Number of CDX buses present in the system. Buses are numbered 0 to
|
|
* BUS_COUNT-1
|
|
*/
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES_OUT_BUS_COUNT_OFST 0
|
|
#define MC_CMD_CDX_BUS_ENUM_BUSES_OUT_BUS_COUNT_LEN 4
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_BUS_ENUM_DEVICES
|
|
* Enumerate CDX bus devices on a given bus
|
|
*/
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES 0x2
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_MSGSET 0x2
|
|
#undef MC_CMD_0x2_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x2_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_BUS_ENUM_DEVICES_IN msgrequest */
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_IN_LEN 4
|
|
/*
|
|
* Bus number to enumerate, in range 0 to BUS_COUNT-1, as returned by
|
|
* MC_CMD_CDX_BUS_ENUM_BUSES_OUT
|
|
*/
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_IN_BUS_LEN 4
|
|
|
|
/* MC_CMD_CDX_BUS_ENUM_DEVICES_OUT msgresponse */
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_OUT_LEN 4
|
|
/*
|
|
* Number of devices present on the bus. Devices on the bus are numbered 0 to
|
|
* DEVICE_COUNT-1. Returns EAGAIN if number of devices unknown or if the target
|
|
* devices are not ready (e.g. undergoing a bus reset)
|
|
*/
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_OUT_DEVICE_COUNT_OFST 0
|
|
#define MC_CMD_CDX_BUS_ENUM_DEVICES_OUT_DEVICE_COUNT_LEN 4
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_BUS_GET_DEVICE_CONFIG
|
|
* Returns device identification and MMIO/MSI resource data for a CDX device.
|
|
* The expected usage is for the caller to first retrieve the number of devices
|
|
* on the bus using MC_CMD_BUS_ENUM_DEVICES, then loop through the range (0,
|
|
* DEVICE_COUNT - 1), retrieving device resource data. May return EAGAIN if the
|
|
* number of exposed devices or device resources change during enumeration (due
|
|
* to e.g. a PL reload / bus reset), in which case the caller is expected to
|
|
* restart the enumeration loop. MMIO addresses are specified in terms of bus
|
|
* addresses (prior to any potential IOMMU translation). For versal-net, these
|
|
* are equivalent to APU physical addresses. Implementation note - for this to
|
|
* work, the implementation needs to keep state (generation count) per client.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG 0x3
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_MSGSET 0x3
|
|
#undef MC_CMD_0x3_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x3_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN msgrequest */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN_LEN 8
|
|
/* Device bus number, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN_BUS_LEN 4
|
|
/* Device number relative to the bus, in range 0 to DEVICE_COUNT-1 for that bus */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN_DEVICE_OFST 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_IN_DEVICE_LEN 4
|
|
|
|
/* MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT msgresponse */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_LEN 88
|
|
/* 16-bit Vendor identifier, compliant with PCI-SIG VendorID assignment. */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_VENDOR_ID_OFST 0
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_VENDOR_ID_LEN 2
|
|
/* 16-bit Device ID assigned by the vendor */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_ID_OFST 2
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_ID_LEN 2
|
|
/*
|
|
* 16-bit Subsystem Vendor ID, , compliant with PCI-SIG VendorID assignment.
|
|
* For further device differentiation, as required. 0 if unused.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_SUBSYS_VENDOR_ID_OFST 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_SUBSYS_VENDOR_ID_LEN 2
|
|
/*
|
|
* 16-bit Subsystem Device ID assigned by the vendor. For further device
|
|
* differentiation, as required. 0 if unused.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_SUBSYS_DEVICE_ID_OFST 6
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_SUBSYS_DEVICE_ID_LEN 2
|
|
/* 24-bit Device Class code, compliant with PCI-SIG Device Class codes */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_CLASS_OFST 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_CLASS_LEN 3
|
|
/* 8-bit vendor-assigned revision */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_REVISION_OFST 11
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_DEVICE_REVISION_LEN 1
|
|
/* Reserved (alignment) */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_RESERVED_OFST 12
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_RESERVED_LEN 4
|
|
/* MMIO region 0 base address (bus address), 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_OFST 16
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_LO_OFST 16
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_LO_LBN 128
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_HI_OFST 20
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_HI_LBN 160
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_BASE_HI_WIDTH 32
|
|
/* MMIO region 0 size, 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_OFST 24
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_LO_OFST 24
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_LO_LBN 192
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_HI_OFST 28
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_HI_LBN 224
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION0_SIZE_HI_WIDTH 32
|
|
/* MMIO region 1 base address (bus address), 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_OFST 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_LO_OFST 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_LO_LBN 256
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_HI_OFST 36
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_HI_LBN 288
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_BASE_HI_WIDTH 32
|
|
/* MMIO region 1 size, 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_OFST 40
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_LO_OFST 40
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_LO_LBN 320
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_HI_OFST 44
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_HI_LBN 352
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION1_SIZE_HI_WIDTH 32
|
|
/* MMIO region 2 base address (bus address), 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_OFST 48
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_LO_OFST 48
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_LO_LBN 384
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_HI_OFST 52
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_HI_LBN 416
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_BASE_HI_WIDTH 32
|
|
/* MMIO region 2 size, 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_OFST 56
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_LO_OFST 56
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_LO_LBN 448
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_HI_OFST 60
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_HI_LBN 480
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION2_SIZE_HI_WIDTH 32
|
|
/* MMIO region 3 base address (bus address), 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_OFST 64
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_LO_OFST 64
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_LO_LBN 512
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_HI_OFST 68
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_HI_LBN 544
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_BASE_HI_WIDTH 32
|
|
/* MMIO region 3 size, 0 if unused */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_OFST 72
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_LEN 8
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_LO_OFST 72
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_LO_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_LO_LBN 576
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_LO_WIDTH 32
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_HI_OFST 76
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_HI_LEN 4
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_HI_LBN 608
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MMIO_REGION3_SIZE_HI_WIDTH 32
|
|
/* MSI vector count */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MSI_COUNT_OFST 80
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_MSI_COUNT_LEN 4
|
|
/* Requester ID used by device (SMMU StreamID, GIC ITS DeviceID) */
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_REQUESTER_ID_OFST 84
|
|
#define MC_CMD_CDX_BUS_GET_DEVICE_CONFIG_OUT_REQUESTER_ID_LEN 4
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_BUS_DOWN
|
|
* Asserting reset on the CDX bus causes all devices on the bus to be quiesced.
|
|
* DMA bus mastering is disabled and any pending DMA request are flushed. Once
|
|
* the response is returned, the devices are guaranteed to no longer issue DMA
|
|
* requests or raise MSI interrupts. Further device MMIO accesses may have
|
|
* undefined results. While the bus reset is asserted, any of the enumeration
|
|
* or device configuration MCDIs will fail with EAGAIN. It is only legal to
|
|
* reload the relevant PL region containing CDX devices if the corresponding CDX
|
|
* bus is in reset. Depending on the implementation, the firmware may or may
|
|
* not enforce this restriction and it is up to the caller to make sure this
|
|
* requirement is satisfied.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_DOWN 0x4
|
|
#define MC_CMD_CDX_BUS_DOWN_MSGSET 0x4
|
|
|
|
/* MC_CMD_CDX_BUS_DOWN_IN msgrequest */
|
|
#define MC_CMD_CDX_BUS_DOWN_IN_LEN 4
|
|
/* Bus number to put in reset, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_BUS_DOWN_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_BUS_DOWN_IN_BUS_LEN 4
|
|
|
|
/*
|
|
* MC_CMD_CDX_BUS_DOWN_OUT msgresponse: The bus is quiesced, no further
|
|
* upstream traffic for devices on this bus.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_DOWN_OUT_LEN 0
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_BUS_UP
|
|
* After bus reset is de-asserted, devices are in a state which is functionally
|
|
* equivalent to each device having been reset with MC_CMD_CDX_DEVICE_RESET. In
|
|
* other words, device logic is reset in a hardware-specific way, MMIO accesses
|
|
* are forwarded to the device, DMA bus mastering is disabled and needs to be
|
|
* re-enabled with MC_CMD_CDX_DEVICE_DMA_ENABLE once the driver is ready to
|
|
* start servicing DMA. If the underlying number of devices or device resources
|
|
* changed (e.g. if PL was reloaded) while the bus was in reset, the bus driver
|
|
* is expected to re-enumerate the bus. Returns EALREADY if the bus was already
|
|
* up before the call.
|
|
*/
|
|
#define MC_CMD_CDX_BUS_UP 0x5
|
|
#define MC_CMD_CDX_BUS_UP_MSGSET 0x5
|
|
|
|
/* MC_CMD_CDX_BUS_UP_IN msgrequest */
|
|
#define MC_CMD_CDX_BUS_UP_IN_LEN 4
|
|
/* Bus number to take out of reset, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_BUS_UP_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_BUS_UP_IN_BUS_LEN 4
|
|
|
|
/* MC_CMD_CDX_BUS_UP_OUT msgresponse: The bus can now be enumerated. */
|
|
#define MC_CMD_CDX_BUS_UP_OUT_LEN 0
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_DEVICE_RESET
|
|
* After this call completes, device DMA and interrupts are quiesced, devices
|
|
* logic is reset in a hardware-specific way and DMA bus mastering is disabled.
|
|
*/
|
|
#define MC_CMD_CDX_DEVICE_RESET 0x6
|
|
#define MC_CMD_CDX_DEVICE_RESET_MSGSET 0x6
|
|
#undef MC_CMD_0x6_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x6_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_DEVICE_RESET_IN msgrequest */
|
|
#define MC_CMD_CDX_DEVICE_RESET_IN_LEN 8
|
|
/* Device bus number, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_DEVICE_RESET_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_RESET_IN_BUS_LEN 4
|
|
/* Device number relative to the bus, in range 0 to DEVICE_COUNT-1 for that bus */
|
|
#define MC_CMD_CDX_DEVICE_RESET_IN_DEVICE_OFST 4
|
|
#define MC_CMD_CDX_DEVICE_RESET_IN_DEVICE_LEN 4
|
|
|
|
/*
|
|
* MC_CMD_CDX_DEVICE_RESET_OUT msgresponse: The device is quiesced and all
|
|
* pending device initiated DMA has completed.
|
|
*/
|
|
#define MC_CMD_CDX_DEVICE_RESET_OUT_LEN 0
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_DEVICE_CONTROL_SET
|
|
* If BUS_MASTER is set to disabled, device DMA and interrupts are quiesced.
|
|
* Pending DMA requests and MSI interrupts are flushed and no further DMA or
|
|
* interrupts are issued after this command returns. If BUS_MASTER is set to
|
|
* enabled, device is allowed to initiate DMA. Whether interrupts are enabled
|
|
* also depends on the value of MSI_ENABLE bit. Note that, in this case, the
|
|
* device may start DMA before the host receives and processes the MCDI
|
|
* response. MSI_ENABLE masks or unmasks device interrupts only. Note that for
|
|
* interrupts to be delivered to the host, both BUS_MASTER and MSI_ENABLE needs
|
|
* to be set. MMIO_REGIONS_ENABLE enables or disables host accesses to device
|
|
* MMIO regions. Note that an implementation is allowed to permanently set this
|
|
* bit to 1, in which case MC_CMD_CDX_DEVICE_CONTROL_GET will always return 1
|
|
* for this bit, regardless of the value set here.
|
|
*/
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET 0x7
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_MSGSET 0x7
|
|
#undef MC_CMD_0x7_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x7_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_DEVICE_CONTROL_SET_IN msgrequest */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_LEN 12
|
|
/* Device bus number, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_BUS_LEN 4
|
|
/* Device number relative to the bus, in range 0 to DEVICE_COUNT-1 for that bus */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_DEVICE_OFST 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_DEVICE_LEN 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_FLAGS_OFST 8
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_FLAGS_LEN 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_BUS_MASTER_ENABLE_OFST 8
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_BUS_MASTER_ENABLE_LBN 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_BUS_MASTER_ENABLE_WIDTH 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MSI_ENABLE_OFST 8
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MSI_ENABLE_LBN 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MSI_ENABLE_WIDTH 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MMIO_REGIONS_ENABLE_OFST 8
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MMIO_REGIONS_ENABLE_LBN 2
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_IN_MMIO_REGIONS_ENABLE_WIDTH 1
|
|
|
|
/* MC_CMD_CDX_DEVICE_CONTROL_SET_OUT msgresponse */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_SET_OUT_LEN 0
|
|
|
|
/***********************************/
|
|
/*
|
|
* MC_CMD_CDX_DEVICE_CONTROL_GET
|
|
* Returns device DMA, interrupt and MMIO region access control bits. See
|
|
* MC_CMD_CDX_DEVICE_CONTROL_SET for definition of the available control bits.
|
|
*/
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET 0x8
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_MSGSET 0x8
|
|
#undef MC_CMD_0x8_PRIVILEGE_CTG
|
|
|
|
#define MC_CMD_0x8_PRIVILEGE_CTG SRIOV_CTG_ADMIN
|
|
|
|
/* MC_CMD_CDX_DEVICE_CONTROL_GET_IN msgrequest */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_IN_LEN 8
|
|
/* Device bus number, in range 0 to BUS_COUNT-1 */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_IN_BUS_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_IN_BUS_LEN 4
|
|
/* Device number relative to the bus, in range 0 to DEVICE_COUNT-1 for that bus */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_IN_DEVICE_OFST 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_IN_DEVICE_LEN 4
|
|
|
|
/* MC_CMD_CDX_DEVICE_CONTROL_GET_OUT msgresponse */
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_LEN 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_FLAGS_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_FLAGS_LEN 4
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_BUS_MASTER_ENABLE_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_BUS_MASTER_ENABLE_LBN 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_BUS_MASTER_ENABLE_WIDTH 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MSI_ENABLE_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MSI_ENABLE_LBN 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MSI_ENABLE_WIDTH 1
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MMIO_REGIONS_ENABLE_OFST 0
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MMIO_REGIONS_ENABLE_LBN 2
|
|
#define MC_CMD_CDX_DEVICE_CONTROL_GET_OUT_MMIO_REGIONS_ENABLE_WIDTH 1
|
|
|
|
/***********************************/
|
|
/* MC_CMD_V2_EXTN - Encapsulation for a v2 extended command */
|
|
#define MC_CMD_V2_EXTN 0x7f
|
|
|
|
/* MC_CMD_V2_EXTN_IN msgrequest */
|
|
#define MC_CMD_V2_EXTN_IN_LEN 4
|
|
/* the extended command number */
|
|
#define MC_CMD_V2_EXTN_IN_EXTENDED_CMD_LBN 0
|
|
#define MC_CMD_V2_EXTN_IN_EXTENDED_CMD_WIDTH 15
|
|
#define MC_CMD_V2_EXTN_IN_UNUSED_LBN 15
|
|
#define MC_CMD_V2_EXTN_IN_UNUSED_WIDTH 1
|
|
/* the actual length of the encapsulated command */
|
|
#define MC_CMD_V2_EXTN_IN_ACTUAL_LEN_LBN 16
|
|
#define MC_CMD_V2_EXTN_IN_ACTUAL_LEN_WIDTH 10
|
|
#define MC_CMD_V2_EXTN_IN_UNUSED2_LBN 26
|
|
#define MC_CMD_V2_EXTN_IN_UNUSED2_WIDTH 2
|
|
/* Type of command/response */
|
|
#define MC_CMD_V2_EXTN_IN_MESSAGE_TYPE_LBN 28
|
|
#define MC_CMD_V2_EXTN_IN_MESSAGE_TYPE_WIDTH 4
|
|
/*
|
|
* enum: MCDI command directed to versal-net. MCDI responses of this type
|
|
* are not defined.
|
|
*/
|
|
#define MC_CMD_V2_EXTN_IN_MCDI_MESSAGE_TYPE_PLATFORM 0x2
|
|
|
|
#endif /* MC_CDX_PCOL_H */
|