1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /****************************************************************************
3 * Driver for Solarflare network controllers and boards
4 * Copyright 2010-2012 Solarflare Communications Inc.
10 * DOC: Virtual Function Driver Interface
12 * This file contains software structures used to form a two way
13 * communication channel between the VF driver and the PF driver,
14 * named Virtual Function Driver Interface (VFDI).
16 * For the purposes of VFDI, a page is a memory region with size and
17 * alignment of 4K. All addresses are DMA addresses to be used within
18 * the domain of the relevant VF.
20 * The only hardware-defined channels for a VF driver to communicate
21 * with the PF driver are the event mailboxes (%FR_CZ_USR_EV
22 * registers). Writing to these registers generates an event with
23 * EV_CODE = EV_CODE_USR_EV, USER_QID set to the index of the mailbox
24 * and USER_EV_REG_VALUE set to the value written. The PF driver may
25 * direct or disable delivery of these events by setting
28 * The PF driver can send arbitrary events to arbitrary event queues.
29 * However, for consistency, VFDI events from the PF are defined to
30 * follow the same form and be sent to the first event queue assigned
31 * to the VF while that queue is enabled by the VF driver.
33 * The general form of the variable bits of VFDI events is:
36 * | DATA | TYPE | SEQ |
38 * SEQ is a sequence number which should be incremented by 1 (modulo
39 * 256) for each event. The sequence numbers used in each direction
42 * The VF submits requests of type &struct vfdi_req by sending the
43 * address of the request (ADDR) in a series of 4 events:
46 * | ADDR[0:15] | VFDI_EV_TYPE_REQ_WORD0 | SEQ |
47 * | ADDR[16:31] | VFDI_EV_TYPE_REQ_WORD1 | SEQ+1 |
48 * | ADDR[32:47] | VFDI_EV_TYPE_REQ_WORD2 | SEQ+2 |
49 * | ADDR[48:63] | VFDI_EV_TYPE_REQ_WORD3 | SEQ+3 |
51 * The address must be page-aligned. After receiving such a valid
52 * series of events, the PF driver will attempt to read the request
53 * and write a response to the same address. In case of an invalid
54 * sequence of events or a DMA error, there will be no response.
56 * The VF driver may request that the PF driver writes status
57 * information into its domain asynchronously. After writing the
58 * status, the PF driver will send an event of the form:
61 * | reserved | VFDI_EV_TYPE_STATUS | SEQ |
63 * In case the VF must be reset for any reason, the PF driver will
64 * send an event of the form:
67 * | reserved | VFDI_EV_TYPE_RESET | SEQ |
69 * It is then the responsibility of the VF driver to request
70 * reinitialisation of its queues.
72 #define VFDI_EV_SEQ_LBN 24
73 #define VFDI_EV_SEQ_WIDTH 8
74 #define VFDI_EV_TYPE_LBN 16
75 #define VFDI_EV_TYPE_WIDTH 8
76 #define VFDI_EV_TYPE_REQ_WORD0 0
77 #define VFDI_EV_TYPE_REQ_WORD1 1
78 #define VFDI_EV_TYPE_REQ_WORD2 2
79 #define VFDI_EV_TYPE_REQ_WORD3 3
80 #define VFDI_EV_TYPE_STATUS 4
81 #define VFDI_EV_TYPE_RESET 5
82 #define VFDI_EV_DATA_LBN 0
83 #define VFDI_EV_DATA_WIDTH 16
85 struct vfdi_endpoint
{
86 u8 mac_addr
[ETH_ALEN
];
91 * enum vfdi_op - VFDI operation enumeration
92 * @VFDI_OP_RESPONSE: Indicates a response to the request.
93 * @VFDI_OP_INIT_EVQ: Initialize SRAM entries and initialize an EVQ.
94 * @VFDI_OP_INIT_RXQ: Initialize SRAM entries and initialize an RXQ.
95 * @VFDI_OP_INIT_TXQ: Initialize SRAM entries and initialize a TXQ.
96 * @VFDI_OP_FINI_ALL_QUEUES: Flush all queues, finalize all queues, then
97 * finalize the SRAM entries.
98 * @VFDI_OP_INSERT_FILTER: Insert a MAC filter targeting the given RXQ.
99 * @VFDI_OP_REMOVE_ALL_FILTERS: Remove all filters.
100 * @VFDI_OP_SET_STATUS_PAGE: Set the DMA page(s) used for status updates
101 * from PF and write the initial status.
102 * @VFDI_OP_CLEAR_STATUS_PAGE: Clear the DMA page(s) used for status
106 VFDI_OP_RESPONSE
= 0,
107 VFDI_OP_INIT_EVQ
= 1,
108 VFDI_OP_INIT_RXQ
= 2,
109 VFDI_OP_INIT_TXQ
= 3,
110 VFDI_OP_FINI_ALL_QUEUES
= 4,
111 VFDI_OP_INSERT_FILTER
= 5,
112 VFDI_OP_REMOVE_ALL_FILTERS
= 6,
113 VFDI_OP_SET_STATUS_PAGE
= 7,
114 VFDI_OP_CLEAR_STATUS_PAGE
= 8,
118 /* Response codes for VFDI operations. Other values may be used in future. */
119 #define VFDI_RC_SUCCESS 0
120 #define VFDI_RC_ENOMEM (-12)
121 #define VFDI_RC_EINVAL (-22)
122 #define VFDI_RC_EOPNOTSUPP (-95)
123 #define VFDI_RC_ETIMEDOUT (-110)
126 * struct vfdi_req - Request from VF driver to PF driver
127 * @op: Operation code or response indicator, taken from &enum vfdi_op.
128 * @rc: Response code. Set to 0 on success or a negative error code on failure.
129 * @u.init_evq.index: Index of event queue to create.
130 * @u.init_evq.buf_count: Number of 4k buffers backing event queue.
131 * @u.init_evq.addr: Array of length %u.init_evq.buf_count containing DMA
132 * address of each page backing the event queue.
133 * @u.init_rxq.index: Index of receive queue to create.
134 * @u.init_rxq.buf_count: Number of 4k buffers backing receive queue.
135 * @u.init_rxq.evq: Instance of event queue to target receive events at.
136 * @u.init_rxq.label: Label used in receive events.
137 * @u.init_rxq.flags: Unused.
138 * @u.init_rxq.addr: Array of length %u.init_rxq.buf_count containing DMA
139 * address of each page backing the receive queue.
140 * @u.init_txq.index: Index of transmit queue to create.
141 * @u.init_txq.buf_count: Number of 4k buffers backing transmit queue.
142 * @u.init_txq.evq: Instance of event queue to target transmit completion
144 * @u.init_txq.label: Label used in transmit completion events.
145 * @u.init_txq.flags: Checksum offload flags.
146 * @u.init_txq.addr: Array of length %u.init_txq.buf_count containing DMA
147 * address of each page backing the transmit queue.
148 * @u.mac_filter.rxq: Insert MAC filter at VF local address/VLAN targeting
149 * all traffic at this receive queue.
150 * @u.mac_filter.flags: MAC filter flags.
151 * @u.set_status_page.dma_addr: Base address for the &struct vfdi_status.
152 * This address must be page-aligned and the PF may write up to a
153 * whole page (allowing for extension of the structure).
154 * @u.set_status_page.peer_page_count: Number of additional pages the VF
155 * has provided into which peer addresses may be DMAd.
156 * @u.set_status_page.peer_page_addr: Array of DMA addresses of pages.
157 * If the number of peers exceeds 256, then the VF must provide
158 * additional pages in this array. The PF will then DMA up to
159 * 512 vfdi_endpoint structures into each page. These addresses
160 * must be page-aligned.
179 #define VFDI_RXQ_FLAG_SCATTER_EN 1
189 #define VFDI_TXQ_FLAG_IP_CSUM_DIS 1
190 #define VFDI_TXQ_FLAG_TCPUDP_CSUM_DIS 2
197 #define VFDI_MAC_FILTER_FLAG_RSS 1
198 #define VFDI_MAC_FILTER_FLAG_SCATTER 2
203 u64 peer_page_addr
[];
209 * struct vfdi_status - Status provided by PF driver to VF driver
210 * @generation_start: A generation count DMA'd to VF *before* the
211 * rest of the structure.
212 * @generation_end: A generation count DMA'd to VF *after* the
213 * rest of the structure.
214 * @version: Version of this structure; currently set to 1. Later
215 * versions must either be layout-compatible or only be sent to VFs
216 * that specifically request them.
217 * @length: Total length of this structure including embedded tables
218 * @vi_scale: log2 the number of VIs available on this VF. This quantity
219 * is used by the hardware for register decoding.
220 * @max_tx_channels: The maximum number of transmit queues the VF can use.
221 * @rss_rxq_count: The number of receive queues present in the shared RSS
223 * @peer_count: Total number of peers in the complete peer list. If larger
224 * than ARRAY_SIZE(%peers), then the VF must provide sufficient
225 * additional pages each of which is filled with vfdi_endpoint structures.
226 * @local: The MAC address and outer VLAN tag of *this* VF
227 * @peers: Table of peer addresses. The @tci fields in these structures
228 * are currently unused and must be ignored. Additional peers are
229 * written into any additional pages provided by the VF.
230 * @timer_quantum_ns: Timer quantum (nominal period between timer ticks)
231 * for interrupt moderation timers, in nanoseconds. This member is only
232 * present if @length is sufficiently large.
235 u32 generation_start
;
245 struct vfdi_endpoint local
;
246 struct vfdi_endpoint peers
[256];
248 /* Members below here extend version 1 of this structure */
249 u32 timer_quantum_ns
;