blob: b5ee157b4c675b38ce86e778438490ab2475d71b [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
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
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010040#include <vppinfra/string.h>
Ed Warnickecb9cada2015-12-08 15:45:58 -070041#include <vlib/vlib.h>
Damjan Marion3d9c86e2016-07-04 21:04:40 +020042#include <vnet/vnet.h>
Ed Warnickecb9cada2015-12-08 15:45:58 -070043#include <vnet/pg/pg.h>
Damjan Marion3d9c86e2016-07-04 21:04:40 +020044#include <vnet/ethernet/ethernet.h>
Ed Warnickecb9cada2015-12-08 15:45:58 -070045
46uword
Calvin71e97c62016-08-19 16:23:14 -040047pg_output (vlib_main_t * vm, vlib_node_runtime_t * node, vlib_frame_t * frame)
Ed Warnickecb9cada2015-12-08 15:45:58 -070048{
Calvin71e97c62016-08-19 16:23:14 -040049 pg_main_t *pg = &pg_main;
Damjan Mariona3d59862018-11-10 10:23:00 +010050 u32 *buffers = vlib_frame_vector_args (frame);
Ed Warnickecb9cada2015-12-08 15:45:58 -070051 uword n_buffers = frame->n_vectors;
Damjan Marion3d9c86e2016-07-04 21:04:40 +020052 uword n_left = n_buffers;
Calvin71e97c62016-08-19 16:23:14 -040053 vnet_interface_output_runtime_t *rd = (void *) node->runtime_data;
54 pg_interface_t *pif = pool_elt_at_index (pg->interfaces, rd->dev_instance);
Damjan Marion3d9c86e2016-07-04 21:04:40 +020055
Damjan Marion64034362016-11-07 22:19:55 +010056 if (PREDICT_FALSE (pif->lockp != 0))
Sirshak Das2f6d7bb2018-10-03 22:53:51 +000057 while (clib_atomic_test_and_set (pif->lockp))
Damjan Marion64034362016-11-07 22:19:55 +010058 ;
59
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010060 while (n_left > 0)
Damjan Marion3d9c86e2016-07-04 21:04:40 +020061 {
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010062 n_left--;
63 u32 bi0 = buffers[0];
64 vlib_buffer_t *b = vlib_get_buffer (vm, bi0);
65 buffers++;
Damjan Marion3d9c86e2016-07-04 21:04:40 +020066
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010067 if (b->flags & VLIB_BUFFER_IS_TRACED)
68 {
69 pg_output_trace_t *t = vlib_add_trace (vm, node, b, sizeof (*t));
70 t->buffer_index = bi0;
Dave Barach178cf492018-11-13 16:34:13 -050071 clib_memcpy_fast (&t->buffer, b,
72 sizeof (b[0]) - sizeof (b->pre_data));
73 clib_memcpy_fast (t->buffer.pre_data, b->data + b->current_data,
74 sizeof (t->buffer.pre_data));
Damjan Marion3d9c86e2016-07-04 21:04:40 +020075 }
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010076
77 if (pif->pcap_file_name != 0)
78 pcap_add_buffer (&pif->pcap_main, vm, bi0, ETHERNET_MAX_PACKET_BYTES);
Damjan Marion3d9c86e2016-07-04 21:04:40 +020079 }
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010080 if (pif->pcap_file_name != 0)
81 pcap_write (&pif->pcap_main);
Jack Xu9af7e2e2019-03-27 11:51:32 -040082 if (pif->pcap_main.file_descriptor >= 0
83 && pif->pcap_main.n_packets_captured >=
84 pif->pcap_main.n_packets_to_capture)
85 pcap_close (&pif->pcap_main);
Damjan Marion3d9c86e2016-07-04 21:04:40 +020086
Damjan Mariona3d59862018-11-10 10:23:00 +010087 vlib_buffer_free (vm, vlib_frame_vector_args (frame), n_buffers);
Damjan Marion64034362016-11-07 22:19:55 +010088 if (PREDICT_FALSE (pif->lockp != 0))
Sirshak Das2f6d7bb2018-10-03 22:53:51 +000089 clib_atomic_release (pif->lockp);
90
Ed Warnickecb9cada2015-12-08 15:45:58 -070091 return n_buffers;
92}
Calvin71e97c62016-08-19 16:23:14 -040093
94/*
95 * fd.io coding-style-patch-verification: ON
96 *
97 * Local Variables:
98 * eval: (c-set-style "gnu")
99 * End:
100 */