FD.io VPP  v21.06-3-gbb25fbf28
Vector Packet Processing
output.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 Cisco and/or its affiliates.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at:
6  *
7  * http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 /*
16  * pg_output.c: packet generator output
17  *
18  * Copyright (c) 2008 Eliot Dresselhaus
19  *
20  * Permission is hereby granted, free of charge, to any person obtaining
21  * a copy of this software and associated documentation files (the
22  * "Software"), to deal in the Software without restriction, including
23  * without limitation the rights to use, copy, modify, merge, publish,
24  * distribute, sublicense, and/or sell copies of the Software, and to
25  * permit persons to whom the Software is furnished to do so, subject to
26  * the following conditions:
27  *
28  * The above copyright notice and this permission notice shall be
29  * included in all copies or substantial portions of the Software.
30  *
31  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
33  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
35  * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
36  * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
37  * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
38  */
39 
40 #include <vppinfra/string.h>
41 #include <vlib/vlib.h>
42 #include <vnet/vnet.h>
43 #include <vnet/pg/pg.h>
44 #include <vnet/ethernet/ethernet.h>
45 #include <vnet/gso/gro_func.h>
46 
47 uword
49 {
50  pg_main_t *pg = &pg_main;
51  u32 *buffers = vlib_frame_vector_args (frame);
52  uword n_buffers = frame->n_vectors;
55  uword n_to = 0;
56  vnet_interface_output_runtime_t *rd = (void *) node->runtime_data;
58 
59  if (PREDICT_FALSE (pif->lockp != 0))
60  while (clib_atomic_test_and_set (pif->lockp))
61  ;
62 
63  if (PREDICT_FALSE (pif->coalesce_enabled))
64  {
65  n_to = vnet_gro_inline (vm, pif->flow_table, buffers, n_left, to);
66  buffers = to;
67  n_left = n_to;
68  }
69 
70  while (n_left > 0)
71  {
72  n_left--;
73  u32 bi0 = buffers[0];
75  buffers++;
76 
77  if (b->flags & VLIB_BUFFER_IS_TRACED)
78  {
79  pg_output_trace_t *t = vlib_add_trace (vm, node, b, sizeof (*t));
80  t->buffer_index = bi0;
82  sizeof (b[0]) - sizeof (b->pre_data));
84  sizeof (t->buffer.pre_data));
85  }
86 
87  if (pif->pcap_file_name != 0)
88  pcap_add_buffer (&pif->pcap_main, vm, bi0, ETHERNET_MAX_PACKET_BYTES);
89  }
90  if (pif->pcap_file_name != 0)
91  pcap_write (&pif->pcap_main);
92  if ((pif->pcap_main.flags & PCAP_MAIN_INIT_DONE)
93  && pif->pcap_main.n_packets_captured >=
94  pif->pcap_main.n_packets_to_capture)
95  pcap_close (&pif->pcap_main);
96 
97  if (PREDICT_FALSE (pif->coalesce_enabled))
98  {
99  n_buffers = n_to;
100  vlib_buffer_free (vm, to, n_to);
101  }
102  else
104  if (PREDICT_FALSE (pif->lockp != 0))
105  clib_atomic_release (pif->lockp);
106 
107  return n_buffers;
108 }
109 
110 /*
111  * fd.io coding-style-patch-verification: ON
112  *
113  * Local Variables:
114  * eval: (c-set-style "gnu")
115  * End:
116  */
vlib.h
to
u32 * to
Definition: interface_output.c:1078
pg_output_trace_t
Definition: pg.h:406
vnet_gro_inline
static_always_inline u32 vnet_gro_inline(vlib_main_t *vm, gro_flow_table_t *flow_table, u32 *from, u16 n_left_from, u32 *to)
coalesce buffers with flow tables
Definition: gro_func.h:559
vlib_buffer_free
static void vlib_buffer_free(vlib_main_t *vm, u32 *buffers, u32 n_buffers)
Free buffers Frees the entire buffer chain for each buffer.
Definition: buffer_funcs.h:982
pg_output
uword pg_output(vlib_main_t *vm, vlib_node_runtime_t *node, vlib_frame_t *frame)
Definition: output.c:48
frame
vlib_main_t vlib_node_runtime_t vlib_frame_t * frame
Definition: nat44_ei.c:3048
n_buffers
u32 n_buffers
Definition: interface_output.c:401
pg.h
vlib_get_buffer
static vlib_buffer_t * vlib_get_buffer(vlib_main_t *vm, u32 buffer_index)
Translate buffer index into buffer pointer.
Definition: buffer_funcs.h:111
pool_elt_at_index
#define pool_elt_at_index(p, i)
Returns pointer to element at given index.
Definition: pool.h:553
string.h
pcap_close
__clib_export clib_error_t * pcap_close(pcap_main_t *pm)
Close PCAP file.
Definition: pcap.c:74
node
vlib_main_t vlib_node_runtime_t * node
Definition: nat44_ei.c:3047
vm
vlib_main_t * vm
X-connect all packets from the HOST to the PHY.
Definition: nat44_ei.c:3047
pcap_add_buffer
static void pcap_add_buffer(pcap_main_t *pm, struct vlib_main_t *vm, u32 buffer_index, u32 n_bytes_in_trace)
Add buffer (vlib_buffer_t) to the trace.
Definition: interface_funcs.h:525
vlib_frame_t
Definition: node.h:372
clib_memcpy_fast
static_always_inline void * clib_memcpy_fast(void *restrict dst, const void *restrict src, size_t n)
Definition: string.h:92
pg_output_trace_t::buffer_index
u32 buffer_index
Definition: pg.h:408
clib_atomic_release
#define clib_atomic_release(a)
Definition: atomics.h:46
ethernet.h
vlib_buffer_t::current_data
i16 current_data
signed offset in data[], pre_data[] that we are currently processing.
Definition: buffer.h:119
vnet_interface_output_runtime_t::dev_instance
u32 dev_instance
Definition: interface_funcs.h:476
PREDICT_FALSE
#define PREDICT_FALSE(x)
Definition: clib.h:124
vlib_frame_vector_args
static void * vlib_frame_vector_args(vlib_frame_t *f)
Get pointer to frame vector data.
Definition: node_funcs.h:301
clib_atomic_test_and_set
#define clib_atomic_test_and_set(a)
Definition: atomics.h:45
uword
u64 uword
Definition: types.h:112
GRO_TO_VECTOR_SIZE
#define GRO_TO_VECTOR_SIZE(X)
Definition: gro.h:27
pg_output_trace_t::buffer
vlib_buffer_t buffer
Definition: pg.h:409
pg_main_t::interfaces
pg_interface_t * interfaces
Definition: pg.h:342
pg_main_t
Definition: pg.h:330
u32
unsigned int u32
Definition: types.h:88
n_left
u32 n_left
Definition: interface_output.c:1078
pcap_write
__clib_export clib_error_t * pcap_write(pcap_main_t *pm)
Write PCAP file.
Definition: pcap.c:89
vlib_main_t
Definition: main.h:102
vlib_add_trace
void * vlib_add_trace(vlib_main_t *vm, vlib_node_runtime_t *r, vlib_buffer_t *b, u32 n_data_bytes)
Definition: trace.c:628
b
vlib_buffer_t ** b
Definition: nat44_ei_out2in.c:717
vlib_buffer_t::data
u8 data[]
Packet data.
Definition: buffer.h:204
PCAP_MAIN_INIT_DONE
#define PCAP_MAIN_INIT_DONE
Definition: pcap.h:174
ETHERNET_MAX_PACKET_BYTES
#define ETHERNET_MAX_PACKET_BYTES
Definition: ethernet.h:133
vlib_buffer_t::pre_data
u8 pre_data[VLIB_BUFFER_PRE_DATA_SIZE]
Space for inserting data before buffer start.
Definition: buffer.h:201
vnet.h
vlib_node_runtime_t
Definition: node.h:454
pg_interface_t
Definition: pg.h:302
vlib_buffer_t::flags
u32 flags
buffer flags: VLIB_BUFFER_FREE_LIST_INDEX_MASK: bits used to store free list index,...
Definition: buffer.h:133
vlib_buffer_t
VLIB buffer representation.
Definition: buffer.h:111
pg_main
pg_main_t pg_main
Definition: init.c:44
vnet_interface_output_runtime_t
Definition: interface_funcs.h:472
gro_func.h