aboutsummaryrefslogtreecommitdiffstats
path: root/docs/cpta/trending/l2-3n-hsw-vic1385-64b-base-scale.rst
blob: 9bb21d80440929982b748503b5919cbe1b79fb72 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
3n-hsw-vic1385-64b-base
-----------------------

1t1c
````

.. raw:: html

    <a name="vic1385-64b-1t1c-base-scale"></a>
    <center>
    Links to builds:
    <a href="https://nexus.fd.io/content/repositories/fd.io.master.ubuntu.xenial.main/io/fd/vpp/vpp/" target="_blank">vpp-ref</a>,
    <a href="https://jenkins.fd.io/view/csit/job/csit-vpp-perf-mrr-daily-master" target="_blank">csit-ref</a>
    <iframe width="1100" height="800" frameborder="0" scrolling="no" src="../_static/vpp/cpta-l2-1t1c-vic1385-3n-hsw.html"></iframe>
    <p><br></p>
    </center>

2t2c
````

.. raw:: html

    <a name="vic1385-64b-2t2c-base-scale"></a>
    <center>
    Links to builds:
    <a href="https://nexus.fd.io/content/repositories/fd.io.master.ubuntu.xenial.main/io/fd/vpp/vpp/" target="_blank">vpp-ref</a>,
    <a href="https://jenkins.fd.io/view/csit/job/csit-vpp-perf-mrr-daily-master" target="_blank">csit-ref</a>
    <iframe width="1100" height="800" frameborder="0" scrolling="no" src="../_static/vpp/cpta-l2-2t2c-vic1385-3n-hsw.html"></iframe>
    <p><br></p>
    </center>

4t4c
````

.. raw:: html

    <a name="vic1385-64b-4t4c-base-scale"></a>
    <center>
    Links to builds:
    <a href="https://nexus.fd.io/content/repositories/fd.io.master.ubuntu.xenial.main/io/fd/vpp/vpp/" target="_blank">vpp-ref</a>,
    <a href="https://jenkins.fd.io/view/csit/job/csit-vpp-perf-mrr-daily-master" target="_blank">csit-ref</a>
    <iframe width="1100" height="800" frameborder="0" scrolling="no" src="../_static/vpp/cpta-l2-4t4c-vic1385-3n-hsw.html"></iframe>
    <p><br></p>
    </center>
;) \ _(1, ERROR, "error") \ _(2, ADMIN_UP, "admin-up") \ _(3, IOVA, "iova") \ _(4, LINK_UP, "link-up") \ _(5, SHARED_TXQ_LOCK, "shared-txq-lock") \ _(6, ELOG, "elog") enum { #define _(a, b, c) AVF_DEVICE_F_##b = (1 << a), foreach_avf_device_flags #undef _ }; typedef volatile struct { union { struct { u64 mirr:13; u64 rsv1:3; u64 l2tag1:16; u64 filter_status:32; u64 status:19; u64 error:8; u64 rsv2:3; u64 ptype:8; u64 length:26; }; u64 qword[4]; #ifdef CLIB_HAVE_VEC256 u64x4 as_u64x4; #endif }; } avf_rx_desc_t; STATIC_ASSERT_SIZEOF (avf_rx_desc_t, 32); typedef volatile struct { union { u64 qword[2]; #ifdef CLIB_HAVE_VEC128 u64x2 as_u64x2; #endif }; } avf_tx_desc_t; STATIC_ASSERT_SIZEOF (avf_tx_desc_t, 16); typedef struct { CLIB_CACHE_LINE_ALIGN_MARK (cacheline0); volatile u32 *qrx_tail; u16 next; u16 size; avf_rx_desc_t *descs; u32 *bufs; u16 n_enqueued; u8 int_mode; } avf_rxq_t; typedef struct { CLIB_CACHE_LINE_ALIGN_MARK (cacheline0); volatile u32 *qtx_tail; u16 next; u16 size; clib_spinlock_t lock; avf_tx_desc_t *descs; u32 *bufs; u16 n_enqueued; } avf_txq_t; typedef struct { CLIB_CACHE_LINE_ALIGN_MARK (cacheline0); u32 flags; u32 per_interface_next_index; u32 dev_instance; u32 sw_if_index; u32 hw_if_index; vlib_pci_dev_handle_t pci_dev_handle; void *bar0; /* queues */ avf_rxq_t *rxqs; avf_txq_t *txqs; u16 n_tx_queues; u16 n_rx_queues; /* Admin queues */ avf_aq_desc_t *atq; avf_aq_desc_t *arq; void *atq_bufs; void *arq_bufs; u64 atq_bufs_pa; u64 arq_bufs_pa; u16 atq_next_slot; u16 arq_next_slot; virtchnl_pf_event_t *events; u16 vsi_id; u32 feature_bitmap; u8 hwaddr[6]; u16 num_queue_pairs; u16 max_vectors; u16 max_mtu; u32 rss_key_size; u32 rss_lut_size; virtchnl_link_speed_t link_speed; /* stats */ virtchnl_eth_stats_t eth_stats; /* error */ clib_error_t *error; } avf_device_t; typedef struct { u32 status; u16 length; u8 ptype; u8 error; } avf_rx_vector_entry_t; STATIC_ASSERT_SIZEOF (avf_rx_vector_entry_t, 8); #define AVF_RX_VECTOR_SZ VLIB_FRAME_SIZE enum { AVF_PROCESS_EVENT_START = 1, AVF_PROCESS_EVENT_STOP = 2, AVF_PROCESS_EVENT_AQ_INT = 3, } avf_process_event_t; typedef struct { CLIB_CACHE_LINE_ALIGN_MARK (cacheline0); avf_rx_vector_entry_t rx_vector[AVF_RX_VECTOR_SZ]; u32 *to_free; vlib_buffer_t buffer_template; } avf_per_thread_data_t; typedef struct { u8 next_node; i8 buffer_advance; u32 flags; } avf_ptype_t; STATIC_ASSERT (VNET_DEVICE_INPUT_N_NEXT_NODES < 256, "too many next nodes"); typedef struct { u16 msg_id_base; avf_device_t *devices; avf_per_thread_data_t *per_thread_data; vlib_physmem_region_index_t physmem_region; int physmem_region_alloc; vlib_log_class_t log_class; /* 256 element array for ptype based lookup */ avf_ptype_t *ptypes; } avf_main_t; extern avf_main_t avf_main; typedef struct { vlib_pci_addr_t addr; int enable_elog; u16 rxq_num; u16 rxq_size; u16 txq_size; /* return */ int rv; u32 sw_if_index; clib_error_t *error; } avf_create_if_args_t; void avf_create_if (vlib_main_t * vm, avf_create_if_args_t * args); void avf_delete_if (vlib_main_t * vm, avf_device_t * ad); extern vlib_node_registration_t avf_input_node; extern vnet_device_class_t avf_device_class; /* format.c */ format_function_t format_avf_device; format_function_t format_avf_device_name; format_function_t format_avf_input_trace; static inline u32 avf_get_u32 (void *start, int offset) { return *(u32 *) (((u8 *) start) + offset); } static inline u64 avf_get_u64 (void *start, int offset) { return *(u64 *) (((u8 *) start) + offset); } static inline u32 avf_get_u32_bits (void *start, int offset, int first, int last) { u32 value = avf_get_u32 (start, offset); if ((last == 0) && (first == 31)) return value; value >>= last; value &= (1 << (first - last + 1)) - 1; return value; } static inline u64 avf_get_u64_bits (void *start, int offset, int first, int last) { u64 value = avf_get_u64 (start, offset); if ((last == 0) && (first == 63)) return value; value >>= last; value &= (1 << (first - last + 1)) - 1; return value; } static inline void avf_set_u32 (void *start, int offset, u32 value) { (*(u32 *) (((u8 *) start) + offset)) = value; } static inline void avf_reg_write (avf_device_t * ad, u32 addr, u32 val) { *(volatile u32 *) ((u8 *) ad->bar0 + addr) = val; } static inline u32 avf_reg_read (avf_device_t * ad, u32 addr) { return *(volatile u32 *) (ad->bar0 + addr); } static inline void avf_reg_flush (avf_device_t * ad) { avf_reg_read (ad, AVFGEN_RSTAT); asm volatile ("":::"memory"); } typedef struct { u32 next_index; u32 hw_if_index; avf_rx_vector_entry_t rxve; } avf_input_trace_t; #define foreach_avf_tx_func_error \ _(NO_FREE_SLOTS, "no free tx slots") typedef enum { #define _(f,s) AVF_TX_ERROR_##f, foreach_avf_tx_func_error #undef _ AVF_TX_N_ERROR, } avf_tx_func_error_t; #endif /* AVF_H */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */