FD.io VPP  v19.04.4-rc0-5-ge88582fac
Vector Packet Processing
device.c File Reference
+ Include dependency graph for device.c:

Go to the source code of this file.

Data Structures

struct  virtchnl_promisc_info_t
 

Macros

#define AVF_MBOX_LEN   64
 
#define AVF_MBOX_BUF_SZ   512
 
#define AVF_RXQ_SZ   512
 
#define AVF_TXQ_SZ   512
 
#define AVF_ITR_INT   8160
 
#define PCI_VENDOR_ID_INTEL   0x8086
 
#define PCI_DEVICE_ID_INTEL_AVF   0x1889
 
#define PCI_DEVICE_ID_INTEL_X710_VF   0x154c
 
#define PCI_DEVICE_ID_INTEL_X722_VF   0x37cd
 

Functions

static void avf_irq_0_disable (avf_device_t *ad)
 
static void avf_irq_0_enable (avf_device_t *ad)
 
static void avf_irq_n_disable (avf_device_t *ad, u8 line)
 
static void avf_irq_n_enable (avf_device_t *ad, u8 line)
 
clib_error_tavf_aq_desc_enq (vlib_main_t *vm, avf_device_t *ad, avf_aq_desc_t *dt, void *data, int len)
 
clib_error_tavf_cmd_rx_ctl_reg_write (vlib_main_t *vm, avf_device_t *ad, u32 reg, u32 val)
 
clib_error_tavf_rxq_init (vlib_main_t *vm, avf_device_t *ad, u16 qid, u16 rxq_size)
 
clib_error_tavf_txq_init (vlib_main_t *vm, avf_device_t *ad, u16 qid, u16 txq_size)
 
void avf_arq_slot_init (avf_device_t *ad, u16 slot)
 
static uword avf_dma_addr (vlib_main_t *vm, avf_device_t *ad, void *p)
 
static void avf_adminq_init (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_send_to_pf (vlib_main_t *vm, avf_device_t *ad, virtchnl_ops_t op, void *in, int in_len, void *out, int out_len)
 
clib_error_tavf_op_version (vlib_main_t *vm, avf_device_t *ad, virtchnl_version_info_t *ver)
 
clib_error_tavf_op_get_vf_resources (vlib_main_t *vm, avf_device_t *ad, virtchnl_vf_resource_t *res)
 
clib_error_tavf_op_config_rss_lut (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_op_config_rss_key (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_op_disable_vlan_stripping (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_config_promisc_mode (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_op_config_vsi_queues (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_op_config_irq_map (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_op_add_eth_addr (vlib_main_t *vm, avf_device_t *ad, u8 count, u8 *macs)
 
clib_error_tavf_op_enable_queues (vlib_main_t *vm, avf_device_t *ad, u32 rx, u32 tx)
 
clib_error_tavf_op_get_stats (vlib_main_t *vm, avf_device_t *ad, virtchnl_eth_stats_t *es)
 
clib_error_tavf_device_reset (vlib_main_t *vm, avf_device_t *ad)
 
clib_error_tavf_request_queues (vlib_main_t *vm, avf_device_t *ad, u16 num_queue_pairs)
 
clib_error_tavf_device_init (vlib_main_t *vm, avf_main_t *am, avf_device_t *ad, avf_create_if_args_t *args)
 
void avf_process_one_device (vlib_main_t *vm, avf_device_t *ad, int is_irq)
 
static u32 avf_flag_change (vnet_main_t *vnm, vnet_hw_interface_t *hw, u32 flags)
 
static uword avf_process (vlib_main_t *vm, vlib_node_runtime_t *rt, vlib_frame_t *f)
 
static void avf_irq_0_handler (vlib_main_t *vm, vlib_pci_dev_handle_t h, u16 line)
 
static void avf_irq_n_handler (vlib_main_t *vm, vlib_pci_dev_handle_t h, u16 line)
 
void avf_delete_if (vlib_main_t *vm, avf_device_t *ad)
 
void avf_create_if (vlib_main_t *vm, avf_create_if_args_t *args)
 
static clib_error_tavf_interface_admin_up_down (vnet_main_t *vnm, u32 hw_if_index, u32 flags)
 
static clib_error_tavf_interface_rx_mode_change (vnet_main_t *vnm, u32 hw_if_index, u32 qid, vnet_hw_interface_rx_mode mode)
 
static void avf_set_interface_next_node (vnet_main_t *vnm, u32 hw_if_index, u32 node_index)
 
static void avf_clear_hw_interface_counters (u32 instance)
 
 VNET_DEVICE_CLASS (avf_device_class,)
 
clib_error_tavf_init (vlib_main_t *vm)
 

Variables

avf_main_t avf_main
 
static pci_device_id_t avf_pci_device_ids []
 
static vlib_node_registration_t avf_process_node
 (constructor) VLIB_REGISTER_NODE (avf_process_node) More...
 
static char * avf_tx_func_error_strings []
 

Macro Definition Documentation

◆ AVF_ITR_INT

#define AVF_ITR_INT   8160

Definition at line 30 of file device.c.

◆ AVF_MBOX_BUF_SZ

#define AVF_MBOX_BUF_SZ   512

Definition at line 27 of file device.c.

◆ AVF_MBOX_LEN

#define AVF_MBOX_LEN   64

Definition at line 26 of file device.c.

◆ AVF_RXQ_SZ

#define AVF_RXQ_SZ   512

Definition at line 28 of file device.c.

◆ AVF_TXQ_SZ

#define AVF_TXQ_SZ   512

Definition at line 29 of file device.c.

◆ PCI_DEVICE_ID_INTEL_AVF

#define PCI_DEVICE_ID_INTEL_AVF   0x1889

Definition at line 33 of file device.c.

◆ PCI_DEVICE_ID_INTEL_X710_VF

#define PCI_DEVICE_ID_INTEL_X710_VF   0x154c

Definition at line 34 of file device.c.

◆ PCI_DEVICE_ID_INTEL_X722_VF

#define PCI_DEVICE_ID_INTEL_X722_VF   0x37cd

Definition at line 35 of file device.c.

◆ PCI_VENDOR_ID_INTEL

#define PCI_VENDOR_ID_INTEL   0x8086

Definition at line 32 of file device.c.

Function Documentation

◆ avf_adminq_init()

static void avf_adminq_init ( vlib_main_t vm,
avf_device_t ad 
)
static

Definition at line 335 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_aq_desc_enq()

clib_error_t* avf_aq_desc_enq ( vlib_main_t vm,
avf_device_t ad,
avf_aq_desc_t dt,
void *  data,
int  len 
)

Definition at line 101 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_arq_slot_init()

void avf_arq_slot_init ( avf_device_t ad,
u16  slot 
)

Definition at line 315 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_clear_hw_interface_counters()

static void avf_clear_hw_interface_counters ( u32  instance)
static

Definition at line 1421 of file device.c.

+ Here is the call graph for this function:

◆ avf_cmd_rx_ctl_reg_write()

clib_error_t* avf_cmd_rx_ctl_reg_write ( vlib_main_t vm,
avf_device_t ad,
u32  reg,
u32  val 
)

Definition at line 187 of file device.c.

+ Here is the call graph for this function:

◆ avf_config_promisc_mode()

clib_error_t* avf_config_promisc_mode ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 560 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_create_if()

void avf_create_if ( vlib_main_t vm,
avf_create_if_args_t args 
)

Definition at line 1197 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_delete_if()

void avf_delete_if ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 1140 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_device_init()

clib_error_t* avf_device_init ( vlib_main_t vm,
avf_main_t am,
avf_device_t ad,
avf_create_if_args_t args 
)

Definition at line 758 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_device_reset()

clib_error_t* avf_device_reset ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 692 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_dma_addr()

static uword avf_dma_addr ( vlib_main_t vm,
avf_device_t ad,
void *  p 
)
inlinestatic

Definition at line 328 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_flag_change()

static u32 avf_flag_change ( vnet_main_t vnm,
vnet_hw_interface_t hw,
u32  flags 
)
static

Definition at line 999 of file device.c.

+ Here is the caller graph for this function:

◆ avf_init()

clib_error_t* avf_init ( vlib_main_t vm)

Definition at line 1445 of file device.c.

+ Here is the call graph for this function:

◆ avf_interface_admin_up_down()

static clib_error_t* avf_interface_admin_up_down ( vnet_main_t vnm,
u32  hw_if_index,
u32  flags 
)
static

Definition at line 1354 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_interface_rx_mode_change()

static clib_error_t* avf_interface_rx_mode_change ( vnet_main_t vnm,
u32  hw_if_index,
u32  qid,
vnet_hw_interface_rx_mode  mode 
)
static

Definition at line 1379 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_0_disable()

static void avf_irq_0_disable ( avf_device_t ad)
inlinestatic

Definition at line 47 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_0_enable()

static void avf_irq_0_enable ( avf_device_t ad)
inlinestatic

Definition at line 59 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_0_handler()

static void avf_irq_0_handler ( vlib_main_t vm,
vlib_pci_dev_handle_t  h,
u16  line 
)
static

Definition at line 1065 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_n_disable()

static void avf_irq_n_disable ( avf_device_t ad,
u8  line 
)
inlinestatic

Definition at line 77 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_n_enable()

static void avf_irq_n_enable ( avf_device_t ad,
u8  line 
)
inlinestatic

Definition at line 86 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_irq_n_handler()

static void avf_irq_n_handler ( vlib_main_t vm,
vlib_pci_dev_handle_t  h,
u16  line 
)
static

Definition at line 1103 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_add_eth_addr()

clib_error_t* avf_op_add_eth_addr ( vlib_main_t vm,
avf_device_t ad,
u8  count,
u8 macs 
)

Definition at line 639 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_config_irq_map()

clib_error_t* avf_op_config_irq_map ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 618 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_config_rss_key()

clib_error_t* avf_op_config_rss_key ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 533 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_config_rss_lut()

clib_error_t* avf_op_config_rss_lut ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 514 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_config_vsi_queues()

clib_error_t* avf_op_config_vsi_queues ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 572 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_disable_vlan_stripping()

clib_error_t* avf_op_disable_vlan_stripping ( vlib_main_t vm,
avf_device_t ad 
)

Definition at line 553 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_enable_queues()

clib_error_t* avf_op_enable_queues ( vlib_main_t vm,
avf_device_t ad,
u32  rx,
u32  tx 
)

Definition at line 659 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_get_stats()

clib_error_t* avf_op_get_stats ( vlib_main_t vm,
avf_device_t ad,
virtchnl_eth_stats_t es 
)

Definition at line 681 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_get_vf_resources()

clib_error_t* avf_op_get_vf_resources ( vlib_main_t vm,
avf_device_t ad,
virtchnl_vf_resource_t res 
)

Definition at line 502 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_op_version()

clib_error_t* avf_op_version ( vlib_main_t vm,
avf_device_t ad,
virtchnl_version_info_t ver 
)

Definition at line 482 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_process()

static uword avf_process ( vlib_main_t vm,
vlib_node_runtime_t rt,
vlib_frame_t f 
)
static

Definition at line 1007 of file device.c.

+ Here is the call graph for this function:

◆ avf_process_one_device()

void avf_process_one_device ( vlib_main_t vm,
avf_device_t ad,
int  is_irq 
)

Definition at line 873 of file device.c.

+ Here is the call graph for this function:

◆ avf_request_queues()

clib_error_t* avf_request_queues ( vlib_main_t vm,
avf_device_t ad,
u16  num_queue_pairs 
)

Definition at line 718 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_rxq_init()

clib_error_t* avf_rxq_init ( vlib_main_t vm,
avf_device_t ad,
u16  qid,
u16  rxq_size 
)

Definition at line 218 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_send_to_pf()

clib_error_t* avf_send_to_pf ( vlib_main_t vm,
avf_device_t ad,
virtchnl_ops_t  op,
void *  in,
int  in_len,
void *  out,
int  out_len 
)

Definition at line 372 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_set_interface_next_node()

static void avf_set_interface_next_node ( vnet_main_t vnm,
u32  hw_if_index,
u32  node_index 
)
static

Definition at line 1396 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ avf_txq_init()

clib_error_t* avf_txq_init ( vlib_main_t vm,
avf_device_t ad,
u16  qid,
u16  txq_size 
)

Definition at line 269 of file device.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ VNET_DEVICE_CLASS()

VNET_DEVICE_CLASS ( avf_device_class  )

Variable Documentation

◆ avf_main

avf_main_t avf_main

Definition at line 37 of file device.c.

◆ avf_pci_device_ids

pci_device_id_t avf_pci_device_ids[]
static
Initial value:
= {
{.vendor_id = PCI_VENDOR_ID_INTEL,.device_id = PCI_DEVICE_ID_INTEL_AVF},
{.vendor_id = PCI_VENDOR_ID_INTEL,.device_id = PCI_DEVICE_ID_INTEL_X710_VF},
{.vendor_id = PCI_VENDOR_ID_INTEL,.device_id = PCI_DEVICE_ID_INTEL_X722_VF},
{0},
}
#define PCI_DEVICE_ID_INTEL_AVF
Definition: device.c:33
#define PCI_DEVICE_ID_INTEL_X722_VF
Definition: device.c:35
#define PCI_DEVICE_ID_INTEL_X710_VF
Definition: device.c:34
#define PCI_VENDOR_ID_INTEL
Definition: device.c:32

Definition at line 39 of file device.c.

◆ avf_process_node

vlib_node_registration_t avf_process_node
static
Initial value:
= {
.function = avf_process,
.name = "avf-process",
}
static uword avf_process(vlib_main_t *vm, vlib_node_runtime_t *rt, vlib_frame_t *f)
Definition: device.c:1007

(constructor) VLIB_REGISTER_NODE (avf_process_node)

Definition at line 1057 of file device.c.

◆ avf_tx_func_error_strings

char* avf_tx_func_error_strings[]
static
Initial value:
= {
#define _(n,s)
}
#define foreach_avf_tx_func_error
Definition: avf.h:312

Definition at line 1414 of file device.c.