111 lines
2.4 KiB
C++
111 lines
2.4 KiB
C++
/*
|
|
* \brief RM session interface
|
|
* \author Norman Feske
|
|
* \date 2016-04-15
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2016-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 _CORE__INCLUDE__RM_SESSION_COMPONENT_H_
|
|
#define _CORE__INCLUDE__RM_SESSION_COMPONENT_H_
|
|
|
|
/* Genode includes */
|
|
#include <base/allocator_guard.h>
|
|
#include <base/rpc_server.h>
|
|
#include <rm_session/rm_session.h>
|
|
|
|
/* core includes */
|
|
#include <region_map_component.h>
|
|
|
|
namespace Genode { class Rm_session_component; }
|
|
|
|
|
|
class Genode::Rm_session_component : public Rpc_object<Rm_session>
|
|
{
|
|
private:
|
|
|
|
Rpc_entrypoint &_ep;
|
|
Allocator_guard _md_alloc;
|
|
Pager_entrypoint &_pager_ep;
|
|
|
|
Lock _region_maps_lock { };
|
|
List<Region_map_component> _region_maps { };
|
|
|
|
public:
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
Rm_session_component(Rpc_entrypoint &ep,
|
|
Allocator &md_alloc,
|
|
Pager_entrypoint &pager_ep,
|
|
size_t ram_quota)
|
|
:
|
|
_ep(ep), _md_alloc(&md_alloc, ram_quota), _pager_ep(pager_ep)
|
|
{ }
|
|
|
|
~Rm_session_component()
|
|
{
|
|
Lock::Guard guard(_region_maps_lock);
|
|
|
|
while (Region_map_component *rmc = _region_maps.first()) {
|
|
_region_maps.remove(rmc);
|
|
Genode::destroy(_md_alloc, rmc);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Register quota donation at allocator guard
|
|
*/
|
|
void upgrade_ram_quota(size_t ram_quota) { _md_alloc.upgrade(ram_quota); }
|
|
|
|
|
|
/**************************
|
|
** Rm_session interface **
|
|
**************************/
|
|
|
|
Capability<Region_map> create(size_t size) override
|
|
{
|
|
Lock::Guard guard(_region_maps_lock);
|
|
|
|
try {
|
|
Region_map_component *rm =
|
|
new (_md_alloc)
|
|
Region_map_component(_ep, _md_alloc, &_pager_ep, 0, size,
|
|
Diag{false});
|
|
|
|
_region_maps.insert(rm);
|
|
|
|
return rm->cap();
|
|
}
|
|
catch (Allocator::Out_of_memory) { throw Out_of_ram(); }
|
|
}
|
|
|
|
void destroy(Capability<Region_map> cap) override
|
|
{
|
|
Lock::Guard guard(_region_maps_lock);
|
|
|
|
Region_map_component *rm = nullptr;
|
|
|
|
_ep.apply(cap, [&] (Region_map_component *rmc) {
|
|
if (!rmc) {
|
|
warning("could not look up region map to destruct");
|
|
return;
|
|
}
|
|
|
|
_region_maps.remove(rmc);
|
|
rm = rmc;
|
|
});
|
|
|
|
if (rm)
|
|
Genode::destroy(_md_alloc, rm);
|
|
}
|
|
};
|
|
|
|
#endif /* _CORE__INCLUDE__RM_SESSION_COMPONENT_H_ */
|