Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / drivers / net / ethernet / sfc / vfdi.h
1 /****************************************************************************
2  * Driver for Solarflare network controllers and boards
3  * 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
88 struct 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.
101  * @VFDI_OP_INSERT_FILTER: Insert a MAC filter targeting the given RXQ.
102  * @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  */
108 enum 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.
151  * @u.mac_filter.rxq: Insert MAC filter at VF local address/VLAN targeting
152  *      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.
155  *      This address must be page-aligned and the PF may write up to a
156  *      whole page (allowing for extension of the structure).
157  * @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  */
165 struct 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  */
237 struct 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