Norman Feske 784206c85c block_session: new client-side API
This patch equips the 'Block::Connection' with a framework API for the
implementation of robust block-session clients that perform block I/O in
an asynchronous fashion.

An application-defined 'JOB' type, inherited from 'Connection::Job',
encapsulates the application's context information associated with a
block operation.

The lifecycle of the jobs is implemented by the 'Connection' and driven
by the application's invokation of 'Connection::update_jobs'. The
'update_jobs' mechanism takes three hook functions as arguments, which
implement the applications-defined policy for producing and consuming
data, and for the completion of jobs.

Issue #3283
2019-05-06 16:15:25 +02:00

72 lines
1.7 KiB
C++

/*
* \brief Client-side block session interface
* \author Stefan Kalkowski
* \date 2010-07-06
*/
/*
* Copyright (C) 2010-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__BLOCK_SESSION__CLIENT_H_
#define _INCLUDE__BLOCK_SESSION__CLIENT_H_
#include <base/rpc_client.h>
#include <block_session/capability.h>
#include <packet_stream_tx/client.h>
namespace Block { class Session_client; }
class Block::Session_client : public Genode::Rpc_client<Session>
{
protected:
Packet_stream_tx::Client<Tx> _tx;
Info const _info = info();
public:
/**
* Constructor
*
* \param session session capability
* \param tx_buffer_alloc allocator used for managing the
* transmission buffer
*/
Session_client(Session_capability session,
Genode::Range_allocator &tx_buffer_alloc,
Genode::Region_map &rm)
:
Genode::Rpc_client<Session>(session),
_tx(tx_cap(), rm, tx_buffer_alloc)
{ }
/*****************************
** Block session interface **
*****************************/
Info info() const override { return call<Rpc_info>(); }
Tx *tx_channel() override { return &_tx; }
Tx::Source *tx() override { return _tx.source(); }
Genode::Capability<Tx> tx_cap() override { return call<Rpc_tx_cap>(); }
/**
* Allocate packet respecting the server's alignment constraints
*/
Packet_descriptor alloc_packet(Genode::size_t size)
{
return tx()->alloc_packet(size, _info.align_log2);
}
};
#endif /* _INCLUDE__BLOCK_SESSION__CLIENT_H_ */