2011-12-22 15:19:25 +00:00
|
|
|
/*
|
|
|
|
* \brief PCI session interface
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2008-01-28
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2013-01-10 20:44:47 +00:00
|
|
|
* Copyright (C) 2008-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__PCI_SESSION__PCI_SESSION_H_
|
|
|
|
#define _INCLUDE__PCI_SESSION__PCI_SESSION_H_
|
|
|
|
|
|
|
|
#include <pci_device/pci_device.h>
|
|
|
|
#include <session/session.h>
|
2013-02-18 09:30:29 +00:00
|
|
|
#include <ram_session/ram_session.h>
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
namespace Pci {
|
|
|
|
|
|
|
|
typedef Genode::Capability<Device> Device_capability;
|
|
|
|
|
|
|
|
struct Session : Genode::Session
|
|
|
|
{
|
|
|
|
static const char *service_name() { return "PCI"; }
|
|
|
|
|
|
|
|
virtual ~Session() { }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find first accessible device
|
|
|
|
*/
|
2013-02-18 10:20:15 +00:00
|
|
|
virtual Device_capability first_device(unsigned, unsigned) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Find next accessible device
|
|
|
|
*
|
|
|
|
* \param prev_device previous device
|
|
|
|
*
|
|
|
|
* The 'prev_device' argument is used to iterate through all
|
|
|
|
* devices.
|
|
|
|
*/
|
2013-02-18 10:20:15 +00:00
|
|
|
virtual Device_capability next_device(Device_capability prev_device,
|
|
|
|
unsigned, unsigned) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Free server-internal data structures representing the device
|
|
|
|
*
|
|
|
|
* Use this function to relax the heap partition of your PCI session.
|
|
|
|
*/
|
|
|
|
virtual void release_device(Device_capability device) = 0;
|
|
|
|
|
2013-02-18 09:06:34 +00:00
|
|
|
/**
|
|
|
|
* Provide mapping to device configuration space of 4k, known as
|
|
|
|
* "Enhanced Configuration Access Mechanism (ECAM) for PCI Express
|
|
|
|
*/
|
|
|
|
virtual Genode::Io_mem_dataspace_capability config_extended(Device_capability) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2013-02-18 09:30:29 +00:00
|
|
|
/**
|
|
|
|
* Allocate memory suitable for DMA.
|
|
|
|
*/
|
|
|
|
virtual Genode::Ram_dataspace_capability alloc_dma_buffer(Device_capability,
|
|
|
|
Genode::size_t) = 0;
|
2014-01-24 09:11:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Free previously allocated DMA memory
|
|
|
|
*/
|
|
|
|
virtual void free_dma_buffer(Device_capability,
|
|
|
|
Genode::Ram_dataspace_capability) = 0;
|
|
|
|
|
2011-12-22 15:19:25 +00:00
|
|
|
/*********************
|
|
|
|
** RPC declaration **
|
|
|
|
*********************/
|
|
|
|
|
2013-02-18 10:20:15 +00:00
|
|
|
GENODE_RPC(Rpc_first_device, Device_capability, first_device,
|
|
|
|
unsigned, unsigned);
|
2013-02-18 09:06:34 +00:00
|
|
|
GENODE_RPC(Rpc_next_device, Device_capability, next_device,
|
2013-02-18 10:20:15 +00:00
|
|
|
Device_capability, unsigned, unsigned);
|
2011-12-22 15:19:25 +00:00
|
|
|
GENODE_RPC(Rpc_release_device, void, release_device, Device_capability);
|
2013-02-18 09:06:34 +00:00
|
|
|
GENODE_RPC(Rpc_config_extended, Genode::Io_mem_dataspace_capability,
|
|
|
|
config_extended, Device_capability);
|
2013-02-18 09:30:29 +00:00
|
|
|
GENODE_RPC_THROW(Rpc_alloc_dma_buffer, Genode::Ram_dataspace_capability,
|
|
|
|
alloc_dma_buffer,
|
|
|
|
GENODE_TYPE_LIST(Genode::Ram_session::Quota_exceeded),
|
|
|
|
Device_capability, Genode::size_t);
|
2014-01-24 09:11:25 +00:00
|
|
|
GENODE_RPC(Rpc_free_dma_buffer, void, free_dma_buffer,
|
|
|
|
Device_capability, Genode::Ram_dataspace_capability);
|
2011-12-22 15:19:25 +00:00
|
|
|
|
2013-02-18 09:06:34 +00:00
|
|
|
GENODE_RPC_INTERFACE(Rpc_first_device, Rpc_next_device,
|
2013-02-18 09:30:29 +00:00
|
|
|
Rpc_release_device, Rpc_config_extended,
|
2014-01-24 09:11:25 +00:00
|
|
|
Rpc_alloc_dma_buffer, Rpc_free_dma_buffer);
|
2011-12-22 15:19:25 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__PCI_SESSION__PCI_SESSION_H_ */
|