2011-12-22 15:19:25 +00:00
|
|
|
/*
|
|
|
|
* \brief Block-driver interface
|
|
|
|
* \author Christian Helmuth
|
|
|
|
* \author Sebastian Sumpf
|
|
|
|
* \date 2011-05-23
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
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__BLOCK__DRIVER_H_
|
|
|
|
#define _INCLUDE__BLOCK__DRIVER_H_
|
|
|
|
|
|
|
|
#include <base/exception.h>
|
|
|
|
#include <base/stdint.h>
|
|
|
|
|
2013-02-18 09:30:29 +00:00
|
|
|
#include <ram_session/ram_session.h>
|
|
|
|
|
2011-12-22 15:19:25 +00:00
|
|
|
|
|
|
|
namespace Block {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface to be implemented by the device-specific driver code
|
|
|
|
*/
|
|
|
|
struct Driver
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Exceptions
|
|
|
|
*/
|
|
|
|
class Io_error : public ::Genode::Exception { };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request block size for driver and medium
|
|
|
|
*/
|
|
|
|
virtual Genode::size_t block_size() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request capacity of medium in blocks
|
|
|
|
*/
|
|
|
|
virtual Genode::size_t block_count() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Read from medium
|
|
|
|
*
|
|
|
|
* \param block_number number of first block to read
|
|
|
|
* \param block_count number of blocks to read
|
|
|
|
* \param out_buffer output buffer for read request
|
|
|
|
*/
|
|
|
|
virtual void read(Genode::size_t block_number,
|
|
|
|
Genode::size_t block_count,
|
|
|
|
char *out_buffer) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write to medium
|
|
|
|
*
|
|
|
|
* \param block_number number of first block to write
|
|
|
|
* \param block_count number of blocks to write
|
|
|
|
* \param buffer buffer for write request
|
|
|
|
*/
|
|
|
|
virtual void write(Genode::size_t block_number,
|
|
|
|
Genode::size_t block_count,
|
|
|
|
char const *buffer) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Read from medium using DMA
|
|
|
|
*
|
|
|
|
* \param block_number number of first block to read
|
|
|
|
* \param block_count number of blocks to read
|
|
|
|
* \param phys phyiscal address of read buffer
|
|
|
|
*/
|
|
|
|
virtual void read_dma(Genode::size_t block_number,
|
|
|
|
Genode::size_t block_count,
|
|
|
|
Genode::addr_t phys) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write to medium using DMA
|
|
|
|
*
|
|
|
|
* \param block_number number of first block to write
|
|
|
|
* \param block_count number of blocks to write
|
|
|
|
* \param phys physical address of write buffer
|
|
|
|
*/
|
|
|
|
virtual void write_dma(Genode::size_t block_number,
|
|
|
|
Genode::size_t block_count,
|
|
|
|
Genode::addr_t phys) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if DMA is enabled for driver
|
|
|
|
*
|
|
|
|
* \return true if DMA is enabled, false otherwise
|
|
|
|
*/
|
|
|
|
virtual bool dma_enabled() = 0;
|
2013-02-18 09:30:29 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate buffer which is suitable for DMA.
|
|
|
|
*/
|
|
|
|
virtual Genode::Ram_dataspace_capability alloc_dma_buffer(Genode::size_t) = 0;
|
2011-12-22 15:19:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for constructing the driver object
|
|
|
|
*/
|
|
|
|
struct Driver_factory
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Construct new driver
|
|
|
|
*/
|
|
|
|
virtual Driver *create() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroy driver
|
|
|
|
*/
|
|
|
|
virtual void destroy(Driver *driver) = 0;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _BLOCK__DRIVER_H_ */
|