aboutsummaryrefslogtreecommitdiffstats
path: root/src/vlib/linux
AgeCommit message (Expand)AuthorFilesLines
2023-08-07vppinfra: add clib_file_get_resolved_basenameDamjan Marion3-17/+8
2023-08-02vlib: remove dependency on libuuidDamjan Marion1-12/+53
2023-07-28vlib: pci cleanup and improvementsDamjan Marion1-58/+55
2023-01-18pci: fix musl crashBenoît Ganne1-8/+9
2023-01-11pci: add option to force uio bindingBenoît Ganne1-60/+64
2021-11-22vlib: fix coverity warningKlement Sekera1-1/+1
2021-11-08perfmon: fix iio-bw coverity issuesRay Kinsella1-1/+1
2021-11-05pci: remove dead codeDamjan Marion1-4/+0
2021-11-03pci: allocate and set length pci product nameRay Kinsella1-1/+1
2021-11-02vlib: retrieve the root bus of a given pci deviceRay Kinsella1-0/+59
2021-11-02vlib: allocate pci product_name with vec_allocRay Kinsella1-1/+1
2021-10-13vlib: fix vmbus error logBenoît Ganne1-3/+3
2021-01-11dpdk: allow configure individual VMBUS devicesVladimir Ratnikov1-8/+14
2020-12-06vlib: vlib_log for "linux device up" warningsDave Barach1-3/+4
2020-10-22pci: set PCI memory enable before mapping PCI BARMohammed Hawari1-0/+12
2020-10-08pci: add vlib_pci_get_msix_file_indexDamjan Marion1-0/+11
2020-09-17vppinfra: support main heap with different page sizesDamjan Marion1-3/+5
2020-07-24pci: fix non NULL-terminated vector used as C string overflowBenoît Ganne1-4/+5
2020-05-26pci: improve vfio loggingDamjan Marion3-20/+77
2020-05-06misc: fix coverity warningsDave Barach1-1/+1
2020-03-21vlib: fix error when creating avf interface on SMP systemJieqiang Wang1-1/+13
2019-11-20vlib: pci: fix non-NULL terminated C-stringBenoît Ganne1-2/+2
2019-10-20vlib: linux: fix wrong iommu_group value issue when using dpdk-pluginYulong Pei1-22/+19
2019-10-05vlib: pci: set pci driver name to none when no driver is loadedBenoît Ganne1-0/+2
2019-08-22vlib: fix null pointer crash on strncmpSteven Luong1-2/+2
2019-05-16init / exit function orderingDave Barach2-8/+14
2019-04-03pci: Fix the crash on deleting the pci deviceMohsin Kazmi1-2/+5
2019-03-13VPP-1576: fix a set of coverity warningsDave Barach1-1/+4
2019-03-13vmbus: not having uio_hv_generic is not an errorStephen Hemminger1-7/+20
2019-03-06vmbus: fix bug that breaks multiple netvsc vdevsMatthew Smith1-2/+2
2019-01-31pci: get the number of interruptsMohsin Kazmi1-0/+18
2019-01-20buffers: keep buffer_main in vlib_main_tDamjan Marion1-1/+1
2019-01-18Fix GCC 8 compiler warnings on strncpy's truncated copy on debian distroSteven Luong1-2/+2
2019-01-17vmbus: fix strncpy related warningsStephen Hemminger1-4/+4
2019-01-17pci: fix strncpy warningsStephen Hemminger1-4/+4
2019-01-07avf: allocate descriptor memory from local numaDamjan Marion1-0/+9
2018-12-19vlib: support Hyper-v/Azure VMBusStephen Hemminger1-0/+405
2018-11-14Remove c-11 memcpy checks from perf-critical codeDave Barach1-1/+1
2018-10-25pmalloc: support for 4K pagesDamjan Marion1-1/+1
2018-10-24vlib: Fix pci io bar read/write fd leakMohsin Kazmi1-0/+6
2018-10-23vlib: Add support for pci io read/writeMohsin Kazmi1-19/+79
2018-10-23Numa-aware, growable physical memory allocator (pmalloc)Damjan Marion4-345/+68
2018-10-23c11 safe string handling supportDave Barach2-9/+9
2018-10-22vlib: pci improvementsDamjan Marion3-106/+150
2018-10-16Fix coverity issue for potentially overflowing of page sizeHaiyang Tan2-3/+3
2018-10-05vfio: don't display error if no pci devices are assigned to containerDamjan Marion1-3/+4
2018-09-27Add logging to vfio codeDamjan Marion2-3/+23
2018-07-20physmem: fix alloc when dlmaloc is usedDamjan Marion1-1/+5
2018-07-18Add config option to use dlmalloc instead of mheapDave Barach1-1/+24
2018-06-27gcc8 and Wstringop-truncationMarco Varlese1-2/+4
"n">always_inline void vlib_trace_next_frame (vlib_main_t * vm, vlib_node_runtime_t * r, u32 next_index) { vlib_next_frame_t *nf; nf = vlib_node_runtime_get_next_frame (vm, r, next_index); nf->flags |= VLIB_FRAME_TRACE; } void trace_apply_filter (vlib_main_t * vm); int vnet_is_packet_traced (vlib_buffer_t * b, u32 classify_table_index, int func); /* * Mark buffer as traced and allocate trace buffer. * return 1 if the buffer is successfully traced, 0 if not * A buffer might not be traced if tracing is off or if the packet did not * match the filter. */ always_inline __clib_warn_unused_result int vlib_trace_buffer (vlib_main_t * vm, vlib_node_runtime_t * r, u32 next_index, vlib_buffer_t * b, int follow_chain) { vlib_trace_main_t *tm = &vm->trace_main; vlib_trace_header_t **h; if (PREDICT_FALSE (tm->trace_enable == 0)) return 0; /* Classifier filter in use? */ if (PREDICT_FALSE (vlib_global_main.trace_filter.trace_filter_enable)) { /* See if we're supposed to trace this packet... */ if (vnet_is_packet_traced (b, vlib_global_main.trace_filter.classify_table_index, 0 /* full classify */ ) != 1) return 0; } /* * Apply filter to existing traces to keep number of allocated traces low. * Performed each time around the main loop. */ if (tm->last_main_loop_count != vm->main_loop_count) { tm->last_main_loop_count = vm->main_loop_count; trace_apply_filter (vm); if (tm->trace_buffer_callback) (tm->trace_buffer_callback) ((struct vlib_main_t *) vm, (struct vlib_trace_main_t *) tm); } vlib_trace_next_frame (vm, r, next_index); pool_get (tm->trace_buffer_pool, h); do { b->flags |= VLIB_BUFFER_IS_TRACED; b->trace_handle = vlib_buffer_make_trace_handle (vm->thread_index, h - tm->trace_buffer_pool); } while (follow_chain && (b = vlib_get_next_buffer (vm, b))); return 1; } always_inline void vlib_buffer_copy_trace_flag (vlib_main_t * vm, vlib_buffer_t * b, u32 bi_target) { vlib_buffer_t *b_target = vlib_get_buffer (vm, bi_target); b_target->flags |= b->flags & VLIB_BUFFER_IS_TRACED; b_target->trace_handle = b->trace_handle; } always_inline u32 vlib_get_trace_count (vlib_main_t * vm, vlib_node_runtime_t * rt) { vlib_trace_main_t *tm = &vm->trace_main; vlib_trace_node_t *tn; if (rt->node_index >= vec_len (tm->nodes)) return 0; tn = tm->nodes + rt->node_index; ASSERT (tn->count <= tn->limit); return tn->limit - tn->count; } always_inline void vlib_set_trace_count (vlib_main_t * vm, vlib_node_runtime_t * rt, u32 count) { vlib_trace_main_t *tm = &vm->trace_main; vlib_trace_node_t *tn = vec_elt_at_index (tm->nodes, rt->node_index); ASSERT (count <= tn->limit); tn->count = tn->limit - count; } /* Helper function for nodes which only trace buffer data. */ void vlib_trace_frame_buffers_only (vlib_main_t * vm, vlib_node_runtime_t * node, u32 * buffers, uword n_buffers, uword next_buffer_stride, uword n_buffer_data_bytes_in_trace); #endif /* included_vlib_trace_funcs_h */ /* * fd.io coding-style-patch-verification: ON * * Local Variables: * eval: (c-set-style "gnu") * End: */