40 #ifndef included_vlib_buffer_h 41 #define included_vlib_buffer_h 49 #include <vlib/config.h> 50 #define VLIB_BUFFER_DATA_SIZE (2048) 51 #define VLIB_BUFFER_PRE_DATA_SIZE __PRE_DATA_SIZE 85 #define VLIB_BUFFER_IS_TRACED (1 << 0) 86 #define VLIB_BUFFER_LOG2_NEXT_PRESENT (1) 87 #define VLIB_BUFFER_NEXT_PRESENT (1 << VLIB_BUFFER_LOG2_NEXT_PRESENT) 88 #define VLIB_BUFFER_IS_RECYCLED (1 << 2) 89 #define VLIB_BUFFER_TOTAL_LENGTH_VALID (1 << 3) 90 #define VLIB_BUFFER_REPL_FAIL (1 << 4) 91 #define VLIB_BUFFER_RECYCLE (1 << 5) 92 #define VLIB_BUFFER_FLOW_REPORT (1 << 6) 93 #define VLIB_BUFFER_EXT_HDR_VALID (1 << 7) 96 #define LOG2_VLIB_BUFFER_FLAG_USER(n) (32 - (n)) 97 #define VLIB_BUFFER_FLAG_USER(n) (1 << LOG2_VLIB_BUFFER_FLAG_USER(n)) 155 #define VLIB_BUFFER_HDR_SIZE (sizeof(vlib_buffer_t) - VLIB_BUFFER_PRE_DATA_SIZE) 164 #define vlib_prefetch_buffer_header(b,type) CLIB_PREFETCH (b, 64, type) 169 return (
void *) (b + 1) + buffer_bytes;
175 ASSERT (
sizeof (b[0]) % 64 == 0);
241 return (
void *) b->
opaque;
376 u32 free_list_index);
381 void (*vlib_packet_template_init_cb) (
struct vlib_main_t * vm,
void *t,
383 uword n_packet_data_bytes,
388 u32 free_list_index);
396 u32 n_buffers,
u32 follow_buffer_next);
402 #define VLIB_BUFFER_DEFAULT_FREE_LIST_INDEX (0) 403 #define VLIB_BUFFER_DEFAULT_FREE_LIST_BYTES VLIB_BUFFER_DATA_SIZE 491 #define VLIB_BUFFER_TRACE_TRAJECTORY 0 493 #if VLIB_BUFFER_TRACE_TRAJECTORY > 0 494 #define VLIB_BUFFER_TRACE_TRAJECTORY_INIT(b) (b)->pre_data[0]=0 496 #define VLIB_BUFFER_TRACE_TRAJECTORY_INIT(b)
#define CLIB_CACHE_LINE_ALIGN_MARK(mark)
static u8 * vlib_buffer_get_tail(vlib_buffer_t *b)
Get pointer to the end of buffer's data.
u32 max_n_data_bytes_per_chain
static void vlib_buffer_reset(vlib_buffer_t *b)
Reset current header & length to state they were in when packet was received.
u32 current_config_index
Used by feature subgraph arcs to visit enabled feature nodes.
u32 free_list_index
Buffer free list that this buffer was allocated from and will be freed to.
vlib_buffer_callbacks_t cb
vlib_buffer_t buffer_init_template
struct vlib_main_t * vlib_main
#define VLIB_BUFFER_PRE_DATA_SIZE
#define STRUCT_MARK(mark)
void ** buffer_memory_allocated
u32 recycle_count
Used by L2 path recycle code.
void unserialize_open_vlib_buffer(serialize_main_t *m, struct vlib_main_t *vm, vlib_serialize_buffer_main_t *sm)
void unserialize_close_vlib_buffer(serialize_main_t *m)
u32 min_n_buffers_each_physmem_alloc
u32 serialize_close_vlib_buffer(serialize_main_t *m)
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
void(* buffer_init_function)(struct vlib_main_t *vm, struct vlib_buffer_free_list_t *fl, u32 *buffers, u32 n_buffers)
void serialize_open_vlib_buffer(serialize_main_t *m, struct vlib_main_t *vm, vlib_serialize_buffer_main_t *sm)
void * vlib_set_buffer_free_callback(struct vlib_main_t *vm, void *fp)
u8 feature_arc_index
Used to identify feature arcs by intermediate feature node.
u8 pre_data[VLIB_BUFFER_PRE_DATA_SIZE]
Space for inserting data before buffer start.
static vlib_buffer_t * vlib_buffer_next_contiguous(vlib_buffer_t *b, u32 buffer_bytes)
static u32 serialize_vlib_buffer_n_bytes(serialize_main_t *m)
vlib_buffer_free_list_t ** announce_list
u16 current_length
Nbytes between current data and the end of this buffer.
static void * vlib_buffer_make_headroom(vlib_buffer_t *b, u8 size)
Make head room, typically for packet headers.
static void * vlib_buffer_put_uninit(vlib_buffer_t *b, u8 size)
Append uninitialized data to buffer.
uword ready_one_time_event
static void * vlib_buffer_get_current(vlib_buffer_t *b)
Get pointer to current data to process.
vlib_error_t error
Error code for buffers to be enqueued to error handler.
#define uword_to_pointer(u, type)
serialize_stream_t stream
static void * vlib_get_buffer_opaque2(vlib_buffer_t *b)
Get pointer to buffer's opaque2 data array.
void(* buffers_added_to_freelist_function)(struct vlib_main_t *vm, struct vlib_buffer_free_list_t *fl)
uword data_function_opaque
int vlib_buffer_cb_register(struct vlib_main_t *vm, vlib_buffer_callbacks_t *cb)
u32 next_buffer
Next buffer for this linked-list of buffers.
static void vlib_buffer_advance(vlib_buffer_t *b, word l)
Advance current data pointer by the supplied (signed!) amount.
u8 n_add_refs
Number of additional references to this buffer.
u32 total_length_not_including_first_buffer
Only valid for first buffer in chain.
static void * vlib_buffer_push_uninit(vlib_buffer_t *b, u8 size)
Prepend uninitialized data to buffer.
static u8 vlib_buffer_has_space(vlib_buffer_t *b, word l)
Check if there is enough space in buffer to advance.
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
static void * vlib_get_buffer_opaque(vlib_buffer_t *b)
Get pointer to buffer's opaque data array.
void vlib_buffer_cb_init(struct vlib_main_t *vm)
struct vlib_serialize_buffer_main_t::@26::@28 tx
vlib_buffer_free_list_t * buffer_free_list_pool
uword * buffer_known_hash
u32 opaque[8]
Opaque data used by sub-graphs for their own purposes.
static void * vlib_buffer_pull(vlib_buffer_t *b, u8 size)
Retrieve bytes from buffer head.
uword buffer_init_function_opaque
u32 flags
buffer flags: VLIB_BUFFER_IS_TRACED: trace this buffer.
static void vlib_buffer_struct_is_sane(vlib_buffer_t *b)
u32 trace_index
Specifies index into trace buffer if VLIB_PACKET_IS_TRACED flag is set.
uword * free_list_by_size
u32 opaque2[14]
More opaque data, currently unused.