mirror of
https://github.com/genodelabs/genode.git
synced 2024-12-27 09:12:32 +00:00
c767f6ccf1
To enable the use of uncached DMA buffers as RX and TX communication buffers in between driver (service) and client, introduce a cache attribute in the constructor of Nic::Session_component Ref #3291
168 lines
5.1 KiB
C++
168 lines
5.1 KiB
C++
/*
|
|
* \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 <base/attached_ram_dataspace.h>
|
|
#include <base/env.h>
|
|
#include <nic/packet_allocator.h>
|
|
#include <nic_session/rpc_object.h>
|
|
|
|
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_attribute 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<Session_component> _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_attribute 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_attribute 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_ */
|