1 /*******************************************************************************
3 Copyright (c) 2013 - 2015, Intel Corporation
6 Redistribution and use in source and binary forms, with or without
7 modification, are permitted provided that the following conditions are met:
9 1. Redistributions of source code must retain the above copyright notice,
10 this list of conditions and the following disclaimer.
12 2. Redistributions in binary form must reproduce the above copyright
13 notice, this list of conditions and the following disclaimer in the
14 documentation and/or other materials provided with the distribution.
16 3. Neither the name of the Intel Corporation nor the names of its
17 contributors may be used to endorse or promote products derived from
18 this software without specific prior written permission.
20 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 POSSIBILITY OF SUCH DAMAGE.
32 ***************************************************************************/
38 * This header file describes the VF-PF communication protocol used
39 * by the drivers for all devices starting from our 40G product line
41 * Admin queue buffer usage:
42 * desc->opcode is always aqc_opc_send_msg_to_pf
43 * flags, retval, datalen, and data addr are all used normally.
44 * The Firmware copies the cookie fields when sending messages between the
45 * PF and VF, but uses all other fields internally. Due to this limitation,
46 * we must send all messages as "indirect", i.e. using an external buffer.
48 * All the VSI indexes are relative to the VF. Each VF can have maximum of
49 * three VSIs. All the queue indexes are relative to the VSI. Each VF can
50 * have a maximum of sixteen queues for all of its VSIs.
52 * The PF is required to return a status code in v_retval for all messages
53 * except RESET_VF, which does not require any response. The return value
54 * is of status_code type, defined in the shared type.h.
56 * In general, VF driver initialization should roughly follow the order of
57 * these opcodes. The VF driver must first validate the API version of the
58 * PF driver, then request a reset, then get resources, then configure
59 * queues and interrupts. After these operations are complete, the VF
60 * driver may start its queues, optionally add MAC and VLAN filters, and
64 /* START GENERIC DEFINES
65 * Need to ensure the following enums and defines hold the same meaning and
66 * value in current and future projects
70 enum virtchnl_status_code {
71 VIRTCHNL_STATUS_SUCCESS = 0,
72 VIRTCHNL_ERR_PARAM = -5,
73 VIRTCHNL_STATUS_ERR_OPCODE_MISMATCH = -38,
74 VIRTCHNL_STATUS_ERR_CQP_COMPL_ERROR = -39,
75 VIRTCHNL_STATUS_ERR_INVALID_VF_ID = -40,
76 VIRTCHNL_STATUS_NOT_SUPPORTED = -64,
79 #define VIRTCHNL_LINK_SPEED_100MB_SHIFT 0x1
80 #define VIRTCHNL_LINK_SPEED_1000MB_SHIFT 0x2
81 #define VIRTCHNL_LINK_SPEED_10GB_SHIFT 0x3
82 #define VIRTCHNL_LINK_SPEED_40GB_SHIFT 0x4
83 #define VIRTCHNL_LINK_SPEED_20GB_SHIFT 0x5
84 #define VIRTCHNL_LINK_SPEED_25GB_SHIFT 0x6
86 enum virtchnl_link_speed {
87 VIRTCHNL_LINK_SPEED_UNKNOWN = 0,
88 VIRTCHNL_LINK_SPEED_100MB = BIT(VIRTCHNL_LINK_SPEED_100MB_SHIFT),
89 VIRTCHNL_LINK_SPEED_1GB = BIT(VIRTCHNL_LINK_SPEED_1000MB_SHIFT),
90 VIRTCHNL_LINK_SPEED_10GB = BIT(VIRTCHNL_LINK_SPEED_10GB_SHIFT),
91 VIRTCHNL_LINK_SPEED_40GB = BIT(VIRTCHNL_LINK_SPEED_40GB_SHIFT),
92 VIRTCHNL_LINK_SPEED_20GB = BIT(VIRTCHNL_LINK_SPEED_20GB_SHIFT),
93 VIRTCHNL_LINK_SPEED_25GB = BIT(VIRTCHNL_LINK_SPEED_25GB_SHIFT),
96 /* for hsplit_0 field of Rx HMC context */
97 /* deprecated with AVF 1.0 */
98 enum virtchnl_rx_hsplit {
99 VIRTCHNL_RX_HSPLIT_NO_SPLIT = 0,
100 VIRTCHNL_RX_HSPLIT_SPLIT_L2 = 1,
101 VIRTCHNL_RX_HSPLIT_SPLIT_IP = 2,
102 VIRTCHNL_RX_HSPLIT_SPLIT_TCP_UDP = 4,
103 VIRTCHNL_RX_HSPLIT_SPLIT_SCTP = 8,
106 #define VIRTCHNL_ETH_LENGTH_OF_ADDRESS 6
107 /* END GENERIC DEFINES */
109 /* Opcodes for VF-PF communication. These are placed in the v_opcode field
110 * of the virtchnl_msg structure.
113 /* The PF sends status change events to VFs using
114 * the VIRTCHNL_OP_EVENT opcode.
115 * VFs send requests to the PF using the other ops.
116 * Use of "advanced opcode" features must be negotiated as part of capabilities
117 * exchange and are not considered part of base mode feature set.
119 VIRTCHNL_OP_UNKNOWN = 0,
120 VIRTCHNL_OP_VERSION = 1, /* must ALWAYS be 1 */
121 VIRTCHNL_OP_RESET_VF = 2,
122 VIRTCHNL_OP_GET_VF_RESOURCES = 3,
123 VIRTCHNL_OP_CONFIG_TX_QUEUE = 4,
124 VIRTCHNL_OP_CONFIG_RX_QUEUE = 5,
125 VIRTCHNL_OP_CONFIG_VSI_QUEUES = 6,
126 VIRTCHNL_OP_CONFIG_IRQ_MAP = 7,
127 VIRTCHNL_OP_ENABLE_QUEUES = 8,
128 VIRTCHNL_OP_DISABLE_QUEUES = 9,
129 VIRTCHNL_OP_ADD_ETH_ADDR = 10,
130 VIRTCHNL_OP_DEL_ETH_ADDR = 11,
131 VIRTCHNL_OP_ADD_VLAN = 12,
132 VIRTCHNL_OP_DEL_VLAN = 13,
133 VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE = 14,
134 VIRTCHNL_OP_GET_STATS = 15,
135 VIRTCHNL_OP_RSVD = 16,
136 VIRTCHNL_OP_EVENT = 17, /* must ALWAYS be 17 */
137 #ifdef VIRTCHNL_SOL_VF_SUPPORT
138 VIRTCHNL_OP_GET_ADDNL_SOL_CONFIG = 19,
140 #ifdef VIRTCHNL_IWARP
141 VIRTCHNL_OP_IWARP = 20, /* advanced opcode */
142 VIRTCHNL_OP_CONFIG_IWARP_IRQ_MAP = 21, /* advanced opcode */
143 VIRTCHNL_OP_RELEASE_IWARP_IRQ_MAP = 22, /* advanced opcode */
145 VIRTCHNL_OP_CONFIG_RSS_KEY = 23,
146 VIRTCHNL_OP_CONFIG_RSS_LUT = 24,
147 VIRTCHNL_OP_GET_RSS_HENA_CAPS = 25,
148 VIRTCHNL_OP_SET_RSS_HENA = 26,
149 VIRTCHNL_OP_ENABLE_VLAN_STRIPPING = 27,
150 VIRTCHNL_OP_DISABLE_VLAN_STRIPPING = 28,
151 VIRTCHNL_OP_REQUEST_QUEUES = 29,
155 /* This macro is used to generate a compilation error if a structure
156 * is not exactly the correct length. It gives a divide by zero error if the
157 * structure is not of the correct size, otherwise it creates an enum that is
160 #define VIRTCHNL_CHECK_STRUCT_LEN(n, X) enum virtchnl_static_assert_enum_##X \
161 {virtchnl_static_assert_##X = (n) / ((sizeof(struct X) == (n)) ? 1 : 0)}
163 /* Virtual channel message descriptor. This overlays the admin queue
164 * descriptor. All other data is passed in external buffers.
167 struct virtchnl_msg {
168 u8 pad[8]; /* AQ flags/opcode/len/retval fields */
169 enum virtchnl_ops v_opcode; /* avoid confusion with desc->opcode */
170 enum virtchnl_status_code v_retval; /* ditto for desc->retval */
171 u32 vfid; /* used by PF when sending to VF */
174 VIRTCHNL_CHECK_STRUCT_LEN(20, virtchnl_msg);
176 /* Message descriptions and data structures.*/
178 /* VIRTCHNL_OP_VERSION
179 * VF posts its version number to the PF. PF responds with its version number
180 * in the same format, along with a return code.
181 * Reply from PF has its major/minor versions also in param0 and param1.
182 * If there is a major version mismatch, then the VF cannot operate.
183 * If there is a minor version mismatch, then the VF can operate but should
184 * add a warning to the system log.
186 * This enum element MUST always be specified as == 1, regardless of other
187 * changes in the API. The PF must always respond to this message without
188 * error regardless of version mismatch.
190 #define VIRTCHNL_VERSION_MAJOR 1
191 #define VIRTCHNL_VERSION_MINOR 1
192 #define VIRTCHNL_VERSION_MINOR_NO_VF_CAPS 0
194 struct virtchnl_version_info {
199 VIRTCHNL_CHECK_STRUCT_LEN(8, virtchnl_version_info);
201 #define VF_IS_V10(_v) (((_v)->major == 1) && ((_v)->minor == 0))
202 #define VF_IS_V11(_ver) (((_ver)->major == 1) && ((_ver)->minor == 1))
204 /* VIRTCHNL_OP_RESET_VF
205 * VF sends this request to PF with no parameters
206 * PF does NOT respond! VF driver must delay then poll VFGEN_RSTAT register
207 * until reset completion is indicated. The admin queue must be reinitialized
208 * after this operation.
210 * When reset is complete, PF must ensure that all queues in all VSIs associated
211 * with the VF are stopped, all queue configurations in the HMC are set to 0,
212 * and all MAC and VLAN filters (except the default MAC address) on all VSIs
216 /* VSI types that use VIRTCHNL interface for VF-PF communication. VSI_SRIOV
217 * vsi_type should always be 6 for backward compatibility. Add other fields
220 enum virtchnl_vsi_type {
221 VIRTCHNL_VSI_TYPE_INVALID = 0,
222 VIRTCHNL_VSI_SRIOV = 6,
225 /* VIRTCHNL_OP_GET_VF_RESOURCES
226 * Version 1.0 VF sends this request to PF with no parameters
227 * Version 1.1 VF sends this request to PF with u32 bitmap of its capabilities
228 * PF responds with an indirect message containing
229 * virtchnl_vf_resource and one or more
230 * virtchnl_vsi_resource structures.
233 struct virtchnl_vsi_resource {
236 enum virtchnl_vsi_type vsi_type;
238 u8 default_mac_addr[VIRTCHNL_ETH_LENGTH_OF_ADDRESS];
241 VIRTCHNL_CHECK_STRUCT_LEN(16, virtchnl_vsi_resource);
243 /* VF capability flags
244 * VIRTCHNL_VF_OFFLOAD_L2 flag is inclusive of base mode L2 offloads including
245 * TX/RX Checksum offloading and TSO for non-tunnelled packets.
247 #define VIRTCHNL_VF_OFFLOAD_L2 0x00000001
248 #define VIRTCHNL_VF_OFFLOAD_IWARP 0x00000002
249 #define VIRTCHNL_VF_OFFLOAD_RSVD 0x00000004
250 #define VIRTCHNL_VF_OFFLOAD_RSS_AQ 0x00000008
251 #define VIRTCHNL_VF_OFFLOAD_RSS_REG 0x00000010
252 #define VIRTCHNL_VF_OFFLOAD_WB_ON_ITR 0x00000020
253 #define VIRTCHNL_VF_OFFLOAD_REQ_QUEUES 0x00000040
254 #define VIRTCHNL_VF_OFFLOAD_VLAN 0x00010000
255 #define VIRTCHNL_VF_OFFLOAD_RX_POLLING 0x00020000
256 #define VIRTCHNL_VF_OFFLOAD_RSS_PCTYPE_V2 0x00040000
257 #define VIRTCHNL_VF_OFFLOAD_RSS_PF 0X00080000
258 #define VIRTCHNL_VF_OFFLOAD_ENCAP 0X00100000
259 #define VIRTCHNL_VF_OFFLOAD_ENCAP_CSUM 0X00200000
260 #define VIRTCHNL_VF_OFFLOAD_RX_ENCAP_CSUM 0X00400000
262 #define VF_BASE_MODE_OFFLOADS (VIRTCHNL_VF_OFFLOAD_L2 | \
263 VIRTCHNL_VF_OFFLOAD_VLAN | \
264 VIRTCHNL_VF_OFFLOAD_RSS_PF)
266 struct virtchnl_vf_resource {
276 struct virtchnl_vsi_resource vsi_res[1];
279 VIRTCHNL_CHECK_STRUCT_LEN(36, virtchnl_vf_resource);
281 /* VIRTCHNL_OP_CONFIG_TX_QUEUE
282 * VF sends this message to set up parameters for one TX queue.
283 * External data buffer contains one instance of virtchnl_txq_info.
284 * PF configures requested queue and returns a status code.
287 /* Tx queue config info */
288 struct virtchnl_txq_info {
291 u16 ring_len; /* number of descriptors, multiple of 8 */
292 u16 headwb_enabled; /* deprecated with AVF 1.0 */
294 u64 dma_headwb_addr; /* deprecated with AVF 1.0 */
297 VIRTCHNL_CHECK_STRUCT_LEN(24, virtchnl_txq_info);
299 /* VIRTCHNL_OP_CONFIG_RX_QUEUE
300 * VF sends this message to set up parameters for one RX queue.
301 * External data buffer contains one instance of virtchnl_rxq_info.
302 * PF configures requested queue and returns a status code.
305 /* Rx queue config info */
306 struct virtchnl_rxq_info {
309 u32 ring_len; /* number of descriptors, multiple of 32 */
311 u16 splithdr_enabled; /* deprecated with AVF 1.0 */
316 enum virtchnl_rx_hsplit rx_split_pos; /* deprecated with AVF 1.0 */
320 VIRTCHNL_CHECK_STRUCT_LEN(40, virtchnl_rxq_info);
322 /* VIRTCHNL_OP_CONFIG_VSI_QUEUES
323 * VF sends this message to set parameters for all active TX and RX queues
324 * associated with the specified VSI.
325 * PF configures queues and returns status.
326 * If the number of queues specified is greater than the number of queues
327 * associated with the VSI, an error is returned and no queues are configured.
329 struct virtchnl_queue_pair_info {
330 /* NOTE: vsi_id and queue_id should be identical for both queues. */
331 struct virtchnl_txq_info txq;
332 struct virtchnl_rxq_info rxq;
335 VIRTCHNL_CHECK_STRUCT_LEN(64, virtchnl_queue_pair_info);
337 struct virtchnl_vsi_queue_config_info {
341 struct virtchnl_queue_pair_info qpair[1];
344 VIRTCHNL_CHECK_STRUCT_LEN(72, virtchnl_vsi_queue_config_info);
346 /* VIRTCHNL_OP_REQUEST_QUEUES
347 * VF sends this message to request the PF to allocate additional queues to
348 * this VF. Each VF gets a guaranteed number of queues on init but asking for
349 * additional queues must be negotiated. This is a best effort request as it
350 * is possible the PF does not have enough queues left to support the request.
351 * If the PF cannot support the number requested it will respond with the
352 * maximum number it is able to support. If the request is successful, PF will
353 * then reset the VF to institute required changes.
356 /* VF resource request */
357 struct virtchnl_vf_res_request {
361 /* VIRTCHNL_OP_CONFIG_IRQ_MAP
362 * VF uses this message to map vectors to queues.
363 * The rxq_map and txq_map fields are bitmaps used to indicate which queues
364 * are to be associated with the specified vector.
365 * The "other" causes are always mapped to vector 0.
366 * PF configures interrupt mapping and returns status.
368 struct virtchnl_vector_map {
377 VIRTCHNL_CHECK_STRUCT_LEN(12, virtchnl_vector_map);
379 struct virtchnl_irq_map_info {
381 struct virtchnl_vector_map vecmap[1];
384 VIRTCHNL_CHECK_STRUCT_LEN(14, virtchnl_irq_map_info);
386 /* VIRTCHNL_OP_ENABLE_QUEUES
387 * VIRTCHNL_OP_DISABLE_QUEUES
388 * VF sends these message to enable or disable TX/RX queue pairs.
389 * The queues fields are bitmaps indicating which queues to act upon.
390 * (Currently, we only support 16 queues per VF, but we make the field
391 * u32 to allow for expansion.)
392 * PF performs requested action and returns status.
394 struct virtchnl_queue_select {
401 VIRTCHNL_CHECK_STRUCT_LEN(12, virtchnl_queue_select);
403 /* VIRTCHNL_OP_ADD_ETH_ADDR
404 * VF sends this message in order to add one or more unicast or multicast
405 * address filters for the specified VSI.
406 * PF adds the filters and returns status.
409 /* VIRTCHNL_OP_DEL_ETH_ADDR
410 * VF sends this message in order to remove one or more unicast or multicast
411 * filters for the specified VSI.
412 * PF removes the filters and returns status.
415 struct virtchnl_ether_addr {
416 u8 addr[VIRTCHNL_ETH_LENGTH_OF_ADDRESS];
420 VIRTCHNL_CHECK_STRUCT_LEN(8, virtchnl_ether_addr);
422 struct virtchnl_ether_addr_list {
425 struct virtchnl_ether_addr list[1];
428 VIRTCHNL_CHECK_STRUCT_LEN(12, virtchnl_ether_addr_list);
430 #ifdef VIRTCHNL_SOL_VF_SUPPORT
431 /* VIRTCHNL_OP_GET_ADDNL_SOL_CONFIG
432 * VF sends this message to get the default MTU and list of additional ethernet
433 * addresses it is allowed to use.
434 * PF responds with an indirect message containing
435 * virtchnl_addnl_solaris_config with zero or more
436 * virtchnl_ether_addr structures.
438 * It is expected that this operation will only ever be needed for Solaris VFs
439 * running under a Solaris PF.
441 struct virtchnl_addnl_solaris_config {
443 struct virtchnl_ether_addr_list al;
447 /* VIRTCHNL_OP_ADD_VLAN
448 * VF sends this message to add one or more VLAN tag filters for receives.
449 * PF adds the filters and returns status.
450 * If a port VLAN is configured by the PF, this operation will return an
454 /* VIRTCHNL_OP_DEL_VLAN
455 * VF sends this message to remove one or more VLAN tag filters for receives.
456 * PF removes the filters and returns status.
457 * If a port VLAN is configured by the PF, this operation will return an
461 struct virtchnl_vlan_filter_list {
467 VIRTCHNL_CHECK_STRUCT_LEN(6, virtchnl_vlan_filter_list);
469 /* VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE
470 * VF sends VSI id and flags.
471 * PF returns status code in retval.
472 * Note: we assume that broadcast accept mode is always enabled.
474 struct virtchnl_promisc_info {
479 VIRTCHNL_CHECK_STRUCT_LEN(4, virtchnl_promisc_info);
481 #define FLAG_VF_UNICAST_PROMISC 0x00000001
482 #define FLAG_VF_MULTICAST_PROMISC 0x00000002
484 /* VIRTCHNL_OP_GET_STATS
485 * VF sends this message to request stats for the selected VSI. VF uses
486 * the virtchnl_queue_select struct to specify the VSI. The queue_id
487 * field is ignored by the PF.
489 * PF replies with struct virtchnl_eth_stats in an external buffer.
492 struct virtchnl_eth_stats {
493 u64 rx_bytes; /* received bytes */
494 u64 rx_unicast; /* received unicast pkts */
495 u64 rx_multicast; /* received multicast pkts */
496 u64 rx_broadcast; /* received broadcast pkts */
498 u64 rx_unknown_protocol;
499 u64 tx_bytes; /* transmitted bytes*/
500 u64 tx_unicast; /* transmitted unicast pkts */
501 u64 tx_multicast; /* transmitted multicast pkts */
502 u64 tx_broadcast; /* transmitted broadcast pkts */
507 /* VIRTCHNL_OP_CONFIG_RSS_KEY
508 * VIRTCHNL_OP_CONFIG_RSS_LUT
509 * VF sends these messages to configure RSS. Only supported if both PF
510 * and VF drivers set the VIRTCHNL_VF_OFFLOAD_RSS_PF bit during
511 * configuration negotiation. If this is the case, then the RSS fields in
512 * the VF resource struct are valid.
513 * Both the key and LUT are initialized to 0 by the PF, meaning that
514 * RSS is effectively disabled until set up by the VF.
516 struct virtchnl_rss_key {
519 u8 key[1]; /* RSS hash key, packed bytes */
522 VIRTCHNL_CHECK_STRUCT_LEN(6, virtchnl_rss_key);
524 struct virtchnl_rss_lut {
527 u8 lut[1]; /* RSS lookup table */
530 VIRTCHNL_CHECK_STRUCT_LEN(6, virtchnl_rss_lut);
532 /* VIRTCHNL_OP_GET_RSS_HENA_CAPS
533 * VIRTCHNL_OP_SET_RSS_HENA
534 * VF sends these messages to get and set the hash filter enable bits for RSS.
535 * By default, the PF sets these to all possible traffic types that the
536 * hardware supports. The VF can query this value if it wants to change the
537 * traffic types that are hashed by the hardware.
539 struct virtchnl_rss_hena {
543 VIRTCHNL_CHECK_STRUCT_LEN(8, virtchnl_rss_hena);
546 * PF sends this message to inform the VF driver of events that may affect it.
547 * No direct response is expected from the VF, though it may generate other
548 * messages in response to this one.
550 enum virtchnl_event_codes {
551 VIRTCHNL_EVENT_UNKNOWN = 0,
552 VIRTCHNL_EVENT_LINK_CHANGE,
553 VIRTCHNL_EVENT_RESET_IMPENDING,
554 VIRTCHNL_EVENT_PF_DRIVER_CLOSE,
557 #define PF_EVENT_SEVERITY_INFO 0
558 #define PF_EVENT_SEVERITY_ATTENTION 1
559 #define PF_EVENT_SEVERITY_ACTION_REQUIRED 2
560 #define PF_EVENT_SEVERITY_CERTAIN_DOOM 255
562 struct virtchnl_pf_event {
563 enum virtchnl_event_codes event;
566 enum virtchnl_link_speed link_speed;
574 VIRTCHNL_CHECK_STRUCT_LEN(16, virtchnl_pf_event);
576 #ifdef VIRTCHNL_IWARP
578 /* VIRTCHNL_OP_CONFIG_IWARP_IRQ_MAP
579 * VF uses this message to request PF to map IWARP vectors to IWARP queues.
580 * The request for this originates from the VF IWARP driver through
581 * a client interface between VF LAN and VF IWARP driver.
582 * A vector could have an AEQ and CEQ attached to it although
583 * there is a single AEQ per VF IWARP instance in which case
584 * most vectors will have an INVALID_IDX for aeq and valid idx for ceq.
585 * There will never be a case where there will be multiple CEQs attached
586 * to a single vector.
587 * PF configures interrupt mapping and returns status.
590 /* HW does not define a type value for AEQ; only for RX/TX and CEQ.
591 * In order for us to keep the interface simple, SW will define a
592 * unique type value for AEQ.
594 #define QUEUE_TYPE_PE_AEQ 0x80
595 #define QUEUE_INVALID_IDX 0xFFFF
597 struct virtchnl_iwarp_qv_info {
598 u32 v_idx; /* msix_vector */
604 VIRTCHNL_CHECK_STRUCT_LEN(12, virtchnl_iwarp_qv_info);
606 struct virtchnl_iwarp_qvlist_info {
608 struct virtchnl_iwarp_qv_info qv_info[1];
611 VIRTCHNL_CHECK_STRUCT_LEN(16, virtchnl_iwarp_qvlist_info);
615 /* VF reset states - these are written into the RSTAT register:
616 * VFGEN_RSTAT on the VF
617 * When the PF initiates a reset, it writes 0
618 * When the reset is complete, it writes 1
619 * When the PF detects that the VF has recovered, it writes 2
620 * VF checks this register periodically to determine if a reset has occurred,
621 * then polls it to know when the reset is complete.
622 * If either the PF or VF reads the register while the hardware
623 * is in a reset state, it will return DEADBEEF, which, when masked
626 enum virtchnl_vfr_states {
627 VIRTCHNL_VFR_INPROGRESS = 0,
628 VIRTCHNL_VFR_COMPLETED,
629 VIRTCHNL_VFR_VFACTIVE,
633 * virtchnl_vc_validate_vf_msg
634 * @ver: Virtchnl version info
635 * @v_opcode: Opcode for the message
636 * @msg: pointer to the msg buffer
637 * @msglen: msg length
639 * validate msg format against struct for each opcode
642 virtchnl_vc_validate_vf_msg(struct virtchnl_version_info *ver, u32 v_opcode,
645 bool err_msg_format = false;
648 /* Validate message length. */
650 case VIRTCHNL_OP_VERSION:
651 valid_len = sizeof(struct virtchnl_version_info);
653 case VIRTCHNL_OP_RESET_VF:
655 case VIRTCHNL_OP_GET_VF_RESOURCES:
657 valid_len = sizeof(u32);
659 case VIRTCHNL_OP_CONFIG_TX_QUEUE:
660 valid_len = sizeof(struct virtchnl_txq_info);
662 case VIRTCHNL_OP_CONFIG_RX_QUEUE:
663 valid_len = sizeof(struct virtchnl_rxq_info);
665 case VIRTCHNL_OP_CONFIG_VSI_QUEUES:
666 valid_len = sizeof(struct virtchnl_vsi_queue_config_info);
667 if (msglen >= valid_len) {
668 struct virtchnl_vsi_queue_config_info *vqc =
669 (struct virtchnl_vsi_queue_config_info *)msg;
670 valid_len += (vqc->num_queue_pairs *
672 virtchnl_queue_pair_info));
673 if (vqc->num_queue_pairs == 0)
674 err_msg_format = true;
677 case VIRTCHNL_OP_CONFIG_IRQ_MAP:
678 valid_len = sizeof(struct virtchnl_irq_map_info);
679 if (msglen >= valid_len) {
680 struct virtchnl_irq_map_info *vimi =
681 (struct virtchnl_irq_map_info *)msg;
682 valid_len += (vimi->num_vectors *
683 sizeof(struct virtchnl_vector_map));
684 if (vimi->num_vectors == 0)
685 err_msg_format = true;
688 case VIRTCHNL_OP_ENABLE_QUEUES:
689 case VIRTCHNL_OP_DISABLE_QUEUES:
690 valid_len = sizeof(struct virtchnl_queue_select);
692 case VIRTCHNL_OP_ADD_ETH_ADDR:
693 case VIRTCHNL_OP_DEL_ETH_ADDR:
694 valid_len = sizeof(struct virtchnl_ether_addr_list);
695 if (msglen >= valid_len) {
696 struct virtchnl_ether_addr_list *veal =
697 (struct virtchnl_ether_addr_list *)msg;
698 valid_len += veal->num_elements *
699 sizeof(struct virtchnl_ether_addr);
700 if (veal->num_elements == 0)
701 err_msg_format = true;
704 case VIRTCHNL_OP_ADD_VLAN:
705 case VIRTCHNL_OP_DEL_VLAN:
706 valid_len = sizeof(struct virtchnl_vlan_filter_list);
707 if (msglen >= valid_len) {
708 struct virtchnl_vlan_filter_list *vfl =
709 (struct virtchnl_vlan_filter_list *)msg;
710 valid_len += vfl->num_elements * sizeof(u16);
711 if (vfl->num_elements == 0)
712 err_msg_format = true;
715 case VIRTCHNL_OP_CONFIG_PROMISCUOUS_MODE:
716 valid_len = sizeof(struct virtchnl_promisc_info);
718 case VIRTCHNL_OP_GET_STATS:
719 valid_len = sizeof(struct virtchnl_queue_select);
721 #ifdef VIRTCHNL_IWARP
722 case VIRTCHNL_OP_IWARP:
723 /* These messages are opaque to us and will be validated in
724 * the RDMA client code. We just need to check for nonzero
725 * length. The firmware will enforce max length restrictions.
730 err_msg_format = true;
732 case VIRTCHNL_OP_RELEASE_IWARP_IRQ_MAP:
734 case VIRTCHNL_OP_CONFIG_IWARP_IRQ_MAP:
735 valid_len = sizeof(struct virtchnl_iwarp_qvlist_info);
736 if (msglen >= valid_len) {
737 struct virtchnl_iwarp_qvlist_info *qv =
738 (struct virtchnl_iwarp_qvlist_info *)msg;
739 if (qv->num_vectors == 0) {
740 err_msg_format = true;
743 valid_len += ((qv->num_vectors - 1) *
744 sizeof(struct virtchnl_iwarp_qv_info));
748 case VIRTCHNL_OP_CONFIG_RSS_KEY:
749 valid_len = sizeof(struct virtchnl_rss_key);
750 if (msglen >= valid_len) {
751 struct virtchnl_rss_key *vrk =
752 (struct virtchnl_rss_key *)msg;
753 valid_len += vrk->key_len - 1;
756 case VIRTCHNL_OP_CONFIG_RSS_LUT:
757 valid_len = sizeof(struct virtchnl_rss_lut);
758 if (msglen >= valid_len) {
759 struct virtchnl_rss_lut *vrl =
760 (struct virtchnl_rss_lut *)msg;
761 valid_len += vrl->lut_entries - 1;
764 case VIRTCHNL_OP_GET_RSS_HENA_CAPS:
766 case VIRTCHNL_OP_SET_RSS_HENA:
767 valid_len = sizeof(struct virtchnl_rss_hena);
769 case VIRTCHNL_OP_ENABLE_VLAN_STRIPPING:
770 case VIRTCHNL_OP_DISABLE_VLAN_STRIPPING:
772 case VIRTCHNL_OP_REQUEST_QUEUES:
773 valid_len = sizeof(struct virtchnl_vf_res_request);
775 /* These are always errors coming from the VF. */
776 case VIRTCHNL_OP_EVENT:
777 case VIRTCHNL_OP_UNKNOWN:
779 return VIRTCHNL_ERR_PARAM;
781 /* few more checks */
782 if (err_msg_format || valid_len != msglen)
783 return VIRTCHNL_STATUS_ERR_OPCODE_MISMATCH;
787 #endif /* _VIRTCHNL_H_ */