mirror of
https://github.com/genodelabs/genode.git
synced 2025-06-18 23:28:29 +00:00
Consolidate RM service into PD session
This patch integrates three region maps into each PD session to reduce the session overhead and to simplify the PD creation procedure. Please refer to the issue cited below for an elaborative discussion. Note the API change: With this patch, the semantics of core's RM service have changed. Now, the service is merely a tool for creating and destroying managed dataspaces, which are rarely needed. Regular components no longer need a RM session. For this reason, the corresponding argument for the 'Process' and 'Child' constructors has been removed. The former interface of the 'Rm_session' is not named 'Region_map'. As a minor refinement, the 'Fault_type' enum values are now part of the 'Region_map::State' struct. Issue #1938
This commit is contained in:
committed by
Christian Helmuth
parent
e20bbe7002
commit
511acad507
@ -1,12 +1,11 @@
|
||||
/*
|
||||
* \brief Client-side region manager session interface
|
||||
* \author Christian Helmuth
|
||||
* \author Norman Feske
|
||||
* \date 2006-07-11
|
||||
* \date 2016-04-15
|
||||
*/
|
||||
|
||||
/*
|
||||
* Copyright (C) 2006-2016 Genode Labs GmbH
|
||||
* Copyright (C) 2016 Genode Labs GmbH
|
||||
*
|
||||
* This file is part of the Genode OS framework, which is distributed
|
||||
* under the terms of the GNU General Public License version 2.
|
||||
@ -18,40 +17,15 @@
|
||||
#include <rm_session/capability.h>
|
||||
#include <base/rpc_client.h>
|
||||
|
||||
namespace Genode { class Rm_session_client; }
|
||||
namespace Genode { struct Rm_session_client; }
|
||||
|
||||
|
||||
class Genode::Rm_session_client : public Rpc_client<Rm_session>
|
||||
struct Genode::Rm_session_client : Rpc_client<Rm_session>
|
||||
{
|
||||
private:
|
||||
explicit Rm_session_client(Rm_session_capability);
|
||||
|
||||
/*
|
||||
* Multiple calls to get the dataspace capability on NOVA lead to the
|
||||
* situation that the caller gets each time a new mapping of the same
|
||||
* capability at different indices. But the client/caller assumes to
|
||||
* get every time the very same index, e.g., in Noux the index is used
|
||||
* to look up data structures attached to the capability. Therefore, we
|
||||
* cache the dataspace capability on the first request.
|
||||
*
|
||||
* On all other base platforms, this member variable remains unused.
|
||||
*/
|
||||
Dataspace_capability _rm_ds_cap;
|
||||
|
||||
public:
|
||||
|
||||
explicit Rm_session_client(Rm_session_capability session);
|
||||
|
||||
Local_addr attach(Dataspace_capability ds, size_t size = 0,
|
||||
off_t offset = 0, bool use_local_addr = false,
|
||||
Local_addr local_addr = (void *)0,
|
||||
bool executable = false) override;
|
||||
|
||||
void detach(Local_addr) override;
|
||||
Pager_capability add_client(Thread_capability) override;
|
||||
void remove_client(Pager_capability) override;
|
||||
void fault_handler(Signal_context_capability) override;
|
||||
State state() override;
|
||||
Dataspace_capability dataspace() override;
|
||||
Capability<Region_map> create(size_t) override;
|
||||
void destroy(Capability<Region_map>) override;
|
||||
};
|
||||
|
||||
#endif /* _INCLUDE__RM_SESSION__CLIENT_H_ */
|
||||
|
Reference in New Issue
Block a user