ed13a0a262
Each supported protocol now has an attribute with the name of the protocol in the config tag. Each of these attributes accepts one of four possible values: * no - do not print out this protocol * name - print only the protocol name * default - print a short summary of the most important header values * all - print all available header values Example: ! <config eth="name" ! arp="all" ! ipv4="default" ! dhcp="no" ! icmp="all" ! udp="no" ! tcp="default" ! ... /> Corresponding output example: ! ETH IPV4 10.0.2.212 > 10.0.2.55 time 7158 ms (Δ 11 ms) ! ETH IPV4 10.0.2.55 > 10.0.2.201 TCP 80 > 49154 flags ' time 6976 ms (Δ 5 ms) ! ETH ARP hw 1 prot 2048 hwsz 6 protsz 4 op 1 srcmac 02:02:02:02:02:01 srcip 10.0.2.212 dstmac 00:00:00:00:00:00 dstip 10.0.2.55 time 7074 ms (Δ 98 ms) Issue #2738
42 lines
1.2 KiB
C++
42 lines
1.2 KiB
C++
/*
|
|
* \brief Uplink interface in form of a NIC session component
|
|
* \author Martin Stein
|
|
* \date 2017-03-08
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2016-2017 Genode Labs GmbH
|
|
*
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
* under the terms of the GNU Affero General Public License version 3.
|
|
*/
|
|
|
|
/* Genode includes */
|
|
#include <base/env.h>
|
|
#include <net/ethernet.h>
|
|
|
|
/* local includes */
|
|
#include <uplink.h>
|
|
|
|
using namespace Net;
|
|
using namespace Genode;
|
|
|
|
|
|
Net::Uplink::Uplink(Env &env,
|
|
Xml_node config,
|
|
Timer::Connection &timer,
|
|
Duration &curr_time,
|
|
Allocator &alloc)
|
|
:
|
|
Nic::Packet_allocator { &alloc },
|
|
Nic::Connection { env, this, BUF_SIZE, BUF_SIZE },
|
|
Net::Interface { env.ep(), config.attribute_value("uplink", Interface_label()),
|
|
timer, curr_time, config.attribute_value("time", false),
|
|
alloc, config }
|
|
{
|
|
rx_channel()->sigh_ready_to_ack(_sink_ack);
|
|
rx_channel()->sigh_packet_avail(_sink_submit);
|
|
tx_channel()->sigh_ack_avail(_source_ack);
|
|
tx_channel()->sigh_ready_to_submit(_source_submit);
|
|
}
|