blob: ab57deefd24d21a61e8b228a4f373cb5707bc30e [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;
50 u32 *buffers = vlib_frame_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))
57 while (__sync_lock_test_and_set (pif->lockp, 1))
58 ;
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;
71 clib_memcpy (&t->buffer, b, sizeof (b[0]) - sizeof (b->pre_data));
72 clib_memcpy (t->buffer.pre_data, b->data + b->current_data,
73 sizeof (t->buffer.pre_data));
Damjan Marion3d9c86e2016-07-04 21:04:40 +020074 }
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010075
76 if (pif->pcap_file_name != 0)
77 pcap_add_buffer (&pif->pcap_main, vm, bi0, ETHERNET_MAX_PACKET_BYTES);
Damjan Marion3d9c86e2016-07-04 21:04:40 +020078 }
Damjan Marionbfe4dfa2017-02-03 21:16:16 +010079 if (pif->pcap_file_name != 0)
80 pcap_write (&pif->pcap_main);
81
Damjan Marion3d9c86e2016-07-04 21:04:40 +020082
Damjan Marionc008ee12016-11-18 14:43:10 +010083 vlib_buffer_free (vm, vlib_frame_args (frame), n_buffers);
Damjan Marion64034362016-11-07 22:19:55 +010084 if (PREDICT_FALSE (pif->lockp != 0))
85 *pif->lockp = 0;
Ed Warnickecb9cada2015-12-08 15:45:58 -070086 return n_buffers;
87}
Calvin71e97c62016-08-19 16:23:14 -040088
89/*
90 * fd.io coding-style-patch-verification: ON
91 *
92 * Local Variables:
93 * eval: (c-set-style "gnu")
94 * End:
95 */