2011-12-22 15:19:25 +00:00
|
|
|
/*
|
|
|
|
* \brief Interfaces used internally in NIC drivers
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2011-05-21
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2013-01-10 20:44:47 +00:00
|
|
|
* Copyright (C) 2011-2013 Genode Labs GmbH
|
2011-12-22 15:19:25 +00:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
|
|
|
* under the terms of the GNU General Public License version 2.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__NIC__DRIVER_H_
|
|
|
|
#define _INCLUDE__NIC__DRIVER_H_
|
|
|
|
|
|
|
|
#include <os/irq_activation.h> /* for 'Genode::Irq_handler' type */
|
|
|
|
#include <nic_session/nic_session.h> /* for 'Nic::Mac_address' type */
|
|
|
|
|
|
|
|
namespace Nic {
|
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
struct Rx_buffer_alloc;
|
|
|
|
struct Driver;
|
|
|
|
struct Driver_factory;
|
2015-03-11 10:33:03 +00:00
|
|
|
struct Driver_notification;
|
2015-03-04 20:12:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for allocating the backing store for incoming packets
|
|
|
|
*/
|
|
|
|
struct Nic::Rx_buffer_alloc
|
|
|
|
{
|
2011-12-22 15:19:25 +00:00
|
|
|
/**
|
2015-03-04 20:12:14 +00:00
|
|
|
* Allocate packet buffer
|
2011-12-22 15:19:25 +00:00
|
|
|
*/
|
2015-03-04 20:12:14 +00:00
|
|
|
virtual void *alloc(Genode::size_t) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
/**
|
|
|
|
* Submit packet to client
|
|
|
|
*/
|
|
|
|
virtual void submit() = 0;
|
|
|
|
};
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
|
2015-03-11 10:33:03 +00:00
|
|
|
/**
|
|
|
|
* Interface for driver-to-component notifications
|
|
|
|
*/
|
|
|
|
struct Nic::Driver_notification { virtual void link_state_changed() = 0; };
|
|
|
|
|
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
/**
|
|
|
|
* Interface to be implemented by the device-specific driver code
|
|
|
|
*/
|
|
|
|
struct Nic::Driver : Genode::Irq_handler
|
|
|
|
{
|
2011-12-22 15:19:25 +00:00
|
|
|
/**
|
2015-03-04 20:12:14 +00:00
|
|
|
* Return MAC address of the network interface
|
2011-12-22 15:19:25 +00:00
|
|
|
*/
|
2015-03-04 20:12:14 +00:00
|
|
|
virtual Mac_address mac_address() = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2015-03-11 10:33:03 +00:00
|
|
|
/**
|
|
|
|
* Return link state (true if link detected)
|
|
|
|
*/
|
|
|
|
virtual bool link_state() = 0;
|
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
/**
|
|
|
|
* Transmit packet
|
|
|
|
*
|
|
|
|
* \param packet start of packet
|
|
|
|
* \param size packet size
|
|
|
|
*
|
2015-03-20 16:50:41 +00:00
|
|
|
* If the packet size is not a multiple of 4 bytes, this method
|
2015-03-04 20:12:14 +00:00
|
|
|
* accesses the bytes after the packet buffer up to the next 4-byte
|
|
|
|
* length (in the worst case, 3 bytes after the packet end).
|
|
|
|
*/
|
|
|
|
virtual void tx(char const *packet, Genode::size_t size) = 0;
|
|
|
|
};
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
/**
|
|
|
|
* Interface for constructing the driver object
|
|
|
|
*
|
|
|
|
* The driver object requires an rx-packet allocator at construction time.
|
|
|
|
* This allocator, however, exists not before the creation of a NIC session
|
|
|
|
* because the client pays for it. Therefore, the driver must be created at
|
|
|
|
* session-construction time. Because drivers may differ with regard to
|
|
|
|
* their constructor arguments, the 'Driver_factory' interface allows for
|
|
|
|
* unifying the session-creation among these drivers.
|
|
|
|
*/
|
|
|
|
struct Nic::Driver_factory
|
|
|
|
{
|
2011-12-22 15:19:25 +00:00
|
|
|
/**
|
2015-03-04 20:12:14 +00:00
|
|
|
* Construct new driver
|
2011-12-22 15:19:25 +00:00
|
|
|
*
|
2015-03-04 20:12:14 +00:00
|
|
|
* \param rx_buffer_alloc buffer allocator used for storing incoming
|
|
|
|
* packets
|
2015-03-11 10:33:03 +00:00
|
|
|
* \param notifier callback for notifications
|
2011-12-22 15:19:25 +00:00
|
|
|
*/
|
2015-03-11 10:33:03 +00:00
|
|
|
virtual Driver *create(Rx_buffer_alloc &rx_buffer_alloc,
|
|
|
|
Driver_notification ¬ify) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2015-03-04 20:12:14 +00:00
|
|
|
/**
|
|
|
|
* Destroy driver
|
|
|
|
*/
|
|
|
|
virtual void destroy(Driver *driver) = 0;
|
|
|
|
};
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
#endif /* _INCLUDE__NIC__DRIVER_H_ */
|