blob: f62901d4cae0e033d9b4e9849cf0d54c378b5be0 [file] [log] [blame]
Ben Hutchingscd2d5b52012-02-14 00:48:07 +00001/****************************************************************************
Ben Hutchingsf7a6d2c2013-08-29 23:32:48 +01002 * Driver for Solarflare network controllers and boards
Ben Hutchingscd2d5b52012-02-14 00:48:07 +00003 * Copyright 2010-2012 Solarflare Communications Inc.
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 as published
7 * by the Free Software Foundation, incorporated herein by reference.
8 */
9#ifndef _VFDI_H
10#define _VFDI_H
11
12/**
13 * DOC: Virtual Function Driver Interface
14 *
15 * This file contains software structures used to form a two way
16 * communication channel between the VF driver and the PF driver,
17 * named Virtual Function Driver Interface (VFDI).
18 *
19 * For the purposes of VFDI, a page is a memory region with size and
20 * alignment of 4K. All addresses are DMA addresses to be used within
21 * the domain of the relevant VF.
22 *
23 * The only hardware-defined channels for a VF driver to communicate
24 * with the PF driver are the event mailboxes (%FR_CZ_USR_EV
25 * registers). Writing to these registers generates an event with
26 * EV_CODE = EV_CODE_USR_EV, USER_QID set to the index of the mailbox
27 * and USER_EV_REG_VALUE set to the value written. The PF driver may
28 * direct or disable delivery of these events by setting
29 * %FR_CZ_USR_EV_CFG.
30 *
31 * The PF driver can send arbitrary events to arbitrary event queues.
32 * However, for consistency, VFDI events from the PF are defined to
33 * follow the same form and be sent to the first event queue assigned
34 * to the VF while that queue is enabled by the VF driver.
35 *
36 * The general form of the variable bits of VFDI events is:
37 *
38 * 0 16 24 31
39 * | DATA | TYPE | SEQ |
40 *
41 * SEQ is a sequence number which should be incremented by 1 (modulo
42 * 256) for each event. The sequence numbers used in each direction
43 * are independent.
44 *
45 * The VF submits requests of type &struct vfdi_req by sending the
46 * address of the request (ADDR) in a series of 4 events:
47 *
48 * 0 16 24 31
49 * | ADDR[0:15] | VFDI_EV_TYPE_REQ_WORD0 | SEQ |
50 * | ADDR[16:31] | VFDI_EV_TYPE_REQ_WORD1 | SEQ+1 |
51 * | ADDR[32:47] | VFDI_EV_TYPE_REQ_WORD2 | SEQ+2 |
52 * | ADDR[48:63] | VFDI_EV_TYPE_REQ_WORD3 | SEQ+3 |
53 *
54 * The address must be page-aligned. After receiving such a valid
55 * series of events, the PF driver will attempt to read the request
56 * and write a response to the same address. In case of an invalid
57 * sequence of events or a DMA error, there will be no response.
58 *
59 * The VF driver may request that the PF driver writes status
60 * information into its domain asynchronously. After writing the
61 * status, the PF driver will send an event of the form:
62 *
63 * 0 16 24 31
64 * | reserved | VFDI_EV_TYPE_STATUS | SEQ |
65 *
66 * In case the VF must be reset for any reason, the PF driver will
67 * send an event of the form:
68 *
69 * 0 16 24 31
70 * | reserved | VFDI_EV_TYPE_RESET | SEQ |
71 *
72 * It is then the responsibility of the VF driver to request
73 * reinitialisation of its queues.
74 */
75#define VFDI_EV_SEQ_LBN 24
76#define VFDI_EV_SEQ_WIDTH 8
77#define VFDI_EV_TYPE_LBN 16
78#define VFDI_EV_TYPE_WIDTH 8
79#define VFDI_EV_TYPE_REQ_WORD0 0
80#define VFDI_EV_TYPE_REQ_WORD1 1
81#define VFDI_EV_TYPE_REQ_WORD2 2
82#define VFDI_EV_TYPE_REQ_WORD3 3
83#define VFDI_EV_TYPE_STATUS 4
84#define VFDI_EV_TYPE_RESET 5
85#define VFDI_EV_DATA_LBN 0
86#define VFDI_EV_DATA_WIDTH 16
87
88struct vfdi_endpoint {
89 u8 mac_addr[ETH_ALEN];
90 __be16 tci;
91};
92
93/**
94 * enum vfdi_op - VFDI operation enumeration
95 * @VFDI_OP_RESPONSE: Indicates a response to the request.
96 * @VFDI_OP_INIT_EVQ: Initialize SRAM entries and initialize an EVQ.
97 * @VFDI_OP_INIT_RXQ: Initialize SRAM entries and initialize an RXQ.
98 * @VFDI_OP_INIT_TXQ: Initialize SRAM entries and initialize a TXQ.
99 * @VFDI_OP_FINI_ALL_QUEUES: Flush all queues, finalize all queues, then
100 * finalize the SRAM entries.
Joe Perchesdbedd442015-03-06 20:49:12 -0800101 * @VFDI_OP_INSERT_FILTER: Insert a MAC filter targeting the given RXQ.
Ben Hutchingscd2d5b52012-02-14 00:48:07 +0000102 * @VFDI_OP_REMOVE_ALL_FILTERS: Remove all filters.
103 * @VFDI_OP_SET_STATUS_PAGE: Set the DMA page(s) used for status updates
104 * from PF and write the initial status.
105 * @VFDI_OP_CLEAR_STATUS_PAGE: Clear the DMA page(s) used for status
106 * updates from PF.
107 */
108enum vfdi_op {
109 VFDI_OP_RESPONSE = 0,
110 VFDI_OP_INIT_EVQ = 1,
111 VFDI_OP_INIT_RXQ = 2,
112 VFDI_OP_INIT_TXQ = 3,
113 VFDI_OP_FINI_ALL_QUEUES = 4,
114 VFDI_OP_INSERT_FILTER = 5,
115 VFDI_OP_REMOVE_ALL_FILTERS = 6,
116 VFDI_OP_SET_STATUS_PAGE = 7,
117 VFDI_OP_CLEAR_STATUS_PAGE = 8,
118 VFDI_OP_LIMIT,
119};
120
121/* Response codes for VFDI operations. Other values may be used in future. */
122#define VFDI_RC_SUCCESS 0
123#define VFDI_RC_ENOMEM (-12)
124#define VFDI_RC_EINVAL (-22)
125#define VFDI_RC_EOPNOTSUPP (-95)
126#define VFDI_RC_ETIMEDOUT (-110)
127
128/**
129 * struct vfdi_req - Request from VF driver to PF driver
130 * @op: Operation code or response indicator, taken from &enum vfdi_op.
131 * @rc: Response code. Set to 0 on success or a negative error code on failure.
132 * @u.init_evq.index: Index of event queue to create.
133 * @u.init_evq.buf_count: Number of 4k buffers backing event queue.
134 * @u.init_evq.addr: Array of length %u.init_evq.buf_count containing DMA
135 * address of each page backing the event queue.
136 * @u.init_rxq.index: Index of receive queue to create.
137 * @u.init_rxq.buf_count: Number of 4k buffers backing receive queue.
138 * @u.init_rxq.evq: Instance of event queue to target receive events at.
139 * @u.init_rxq.label: Label used in receive events.
140 * @u.init_rxq.flags: Unused.
141 * @u.init_rxq.addr: Array of length %u.init_rxq.buf_count containing DMA
142 * address of each page backing the receive queue.
143 * @u.init_txq.index: Index of transmit queue to create.
144 * @u.init_txq.buf_count: Number of 4k buffers backing transmit queue.
145 * @u.init_txq.evq: Instance of event queue to target transmit completion
146 * events at.
147 * @u.init_txq.label: Label used in transmit completion events.
148 * @u.init_txq.flags: Checksum offload flags.
149 * @u.init_txq.addr: Array of length %u.init_txq.buf_count containing DMA
150 * address of each page backing the transmit queue.
Joe Perchesdbedd442015-03-06 20:49:12 -0800151 * @u.mac_filter.rxq: Insert MAC filter at VF local address/VLAN targeting
Ben Hutchingscd2d5b52012-02-14 00:48:07 +0000152 * all traffic at this receive queue.
153 * @u.mac_filter.flags: MAC filter flags.
154 * @u.set_status_page.dma_addr: Base address for the &struct vfdi_status.
Ben Hutchingsc3cb2a82012-02-20 23:22:02 +0000155 * This address must be page-aligned and the PF may write up to a
156 * whole page (allowing for extension of the structure).
Ben Hutchingscd2d5b52012-02-14 00:48:07 +0000157 * @u.set_status_page.peer_page_count: Number of additional pages the VF
158 * has provided into which peer addresses may be DMAd.
159 * @u.set_status_page.peer_page_addr: Array of DMA addresses of pages.
160 * If the number of peers exceeds 256, then the VF must provide
161 * additional pages in this array. The PF will then DMA up to
162 * 512 vfdi_endpoint structures into each page. These addresses
163 * must be page-aligned.
164 */
165struct vfdi_req {
166 u32 op;
167 u32 reserved1;
168 s32 rc;
169 u32 reserved2;
170 union {
171 struct {
172 u32 index;
173 u32 buf_count;
174 u64 addr[];
175 } init_evq;
176 struct {
177 u32 index;
178 u32 buf_count;
179 u32 evq;
180 u32 label;
181 u32 flags;
182#define VFDI_RXQ_FLAG_SCATTER_EN 1
183 u32 reserved;
184 u64 addr[];
185 } init_rxq;
186 struct {
187 u32 index;
188 u32 buf_count;
189 u32 evq;
190 u32 label;
191 u32 flags;
192#define VFDI_TXQ_FLAG_IP_CSUM_DIS 1
193#define VFDI_TXQ_FLAG_TCPUDP_CSUM_DIS 2
194 u32 reserved;
195 u64 addr[];
196 } init_txq;
197 struct {
198 u32 rxq;
199 u32 flags;
200#define VFDI_MAC_FILTER_FLAG_RSS 1
201#define VFDI_MAC_FILTER_FLAG_SCATTER 2
202 } mac_filter;
203 struct {
204 u64 dma_addr;
205 u64 peer_page_count;
206 u64 peer_page_addr[];
207 } set_status_page;
208 } u;
209};
210
211/**
212 * struct vfdi_status - Status provided by PF driver to VF driver
213 * @generation_start: A generation count DMA'd to VF *before* the
214 * rest of the structure.
215 * @generation_end: A generation count DMA'd to VF *after* the
216 * rest of the structure.
217 * @version: Version of this structure; currently set to 1. Later
218 * versions must either be layout-compatible or only be sent to VFs
219 * that specifically request them.
220 * @length: Total length of this structure including embedded tables
221 * @vi_scale: log2 the number of VIs available on this VF. This quantity
222 * is used by the hardware for register decoding.
223 * @max_tx_channels: The maximum number of transmit queues the VF can use.
224 * @rss_rxq_count: The number of receive queues present in the shared RSS
225 * indirection table.
226 * @peer_count: Total number of peers in the complete peer list. If larger
227 * than ARRAY_SIZE(%peers), then the VF must provide sufficient
228 * additional pages each of which is filled with vfdi_endpoint structures.
229 * @local: The MAC address and outer VLAN tag of *this* VF
230 * @peers: Table of peer addresses. The @tci fields in these structures
231 * are currently unused and must be ignored. Additional peers are
232 * written into any additional pages provided by the VF.
233 * @timer_quantum_ns: Timer quantum (nominal period between timer ticks)
234 * for interrupt moderation timers, in nanoseconds. This member is only
235 * present if @length is sufficiently large.
236 */
237struct vfdi_status {
238 u32 generation_start;
239 u32 generation_end;
240 u32 version;
241 u32 length;
242 u8 vi_scale;
243 u8 max_tx_channels;
244 u8 rss_rxq_count;
245 u8 reserved1;
246 u16 peer_count;
247 u16 reserved2;
248 struct vfdi_endpoint local;
249 struct vfdi_endpoint peers[256];
250
251 /* Members below here extend version 1 of this structure */
252 u32 timer_quantum_ns;
253};
254
255#endif