/*
* \brief Server::Entrypoint based NIC session component
* \author Norman Feske
* \author Sebastian Sumpf
* \date 2015-06-22
*/
/*
* Copyright (C) 2015-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.
*/
#ifndef _INCLUDE__NIC__COMPONENT_H_
#define _INCLUDE__NIC__COMPONENT_H_
#include
#include
#include
#include
namespace Nic {
class Communication_buffers;
class Session_component;
}
class Nic::Communication_buffers
{
protected:
Nic::Packet_allocator _rx_packet_alloc;
Genode::Attached_ram_dataspace _tx_ds, _rx_ds;
Communication_buffers(Genode::Allocator &rx_block_md_alloc,
Genode::Ram_allocator &ram,
Genode::Region_map ®ion_map,
Genode::size_t tx_size,
Genode::size_t rx_size,
Genode::Cache cache_policy)
:
_rx_packet_alloc(&rx_block_md_alloc),
_tx_ds(ram, region_map, tx_size, cache_policy),
_rx_ds(ram, region_map, rx_size, cache_policy)
{ }
};
class Nic::Session_component : Communication_buffers, public Session_rpc_object
{
protected:
Genode::Entrypoint &_ep;
Genode::Signal_context_capability _link_state_sigh { };
/**
* Signal link-state change to client
*/
void _link_state_changed()
{
if (_link_state_sigh.valid())
Genode::Signal_transmitter(_link_state_sigh).submit();
}
/**
* Sub-classes must implement this function, it is called upon all
* packet-stream signals.
*/
virtual void _handle_packet_stream() = 0;
void _dispatch() { _handle_packet_stream(); }
Genode::Signal_handler _packet_stream_dispatcher {
_ep, *this, &Session_component::_dispatch };
using Communication_buffers::_tx_ds;
using Communication_buffers::_rx_ds;
public:
/**
* Constructor
*
* \param tx_buf_size buffer size for tx channel
* \param rx_buf_size buffer size for rx channel
* \param rx_block_md_alloc backing store of the meta data of the
* rx block allocator
* \param env Genode environment needed to access
* resources and open connections from
* within the Session_component
*/
Session_component(Genode::size_t const tx_buf_size,
Genode::size_t const rx_buf_size,
Genode::Cache cache_policy,
Genode::Allocator &rx_block_md_alloc,
Genode::Env &env)
:
Communication_buffers(rx_block_md_alloc, env.ram(), env.rm(),
tx_buf_size, rx_buf_size, cache_policy),
Session_rpc_object(env.rm(),
_tx_ds.cap(),
_rx_ds.cap(),
&_rx_packet_alloc, env.ep().rpc_ep()),
_ep(env.ep())
{
/* install data-flow signal handlers for both packet streams */
_tx.sigh_ready_to_ack(_packet_stream_dispatcher);
_tx.sigh_packet_avail(_packet_stream_dispatcher);
_rx.sigh_ready_to_submit(_packet_stream_dispatcher);
_rx.sigh_ack_avail(_packet_stream_dispatcher);
}
/**
* Constructor
*
* \param tx_buf_size buffer size for tx channel
* \param rx_buf_size buffer size for rx channel
* \param rx_block_md_alloc backing store of the meta data of the
* rx block allocator
* \param env Genode environment needed to access
* resources and open connections from
* within the Session_component
* \param ep entrypoint for RPC
*/
Session_component(Genode::size_t const tx_buf_size,
Genode::size_t const rx_buf_size,
Genode::Cache cache_policy,
Genode::Allocator &rx_block_md_alloc,
Genode::Env &env,
Genode::Entrypoint &ep)
:
Communication_buffers(rx_block_md_alloc, env.ram(), env.rm(),
tx_buf_size, rx_buf_size, cache_policy),
Session_rpc_object(env.rm(),
_tx_ds.cap(),
_rx_ds.cap(),
&_rx_packet_alloc, ep.rpc_ep()),
_ep(ep)
{
/* install data-flow signal handlers for both packet streams */
_tx.sigh_ready_to_ack(_packet_stream_dispatcher);
_tx.sigh_packet_avail(_packet_stream_dispatcher);
_rx.sigh_ready_to_submit(_packet_stream_dispatcher);
_rx.sigh_ack_avail(_packet_stream_dispatcher);
}
void link_state_sigh(Genode::Signal_context_capability sigh) override
{
_link_state_sigh = sigh;
}
/**
* Return the current link state
*/
bool link_state() override = 0;
/**
* Return the MAC address of the device
*/
Mac_address mac_address() override = 0;
};
#endif /* _INCLUDE__NIC__COMPONENT_H_ */