/* * \brief Back end of the RPC entrypoint * \author Norman Feske * \date 2016-01-19 */ /* * 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. */ /* Genode includes */ #include #include /* base-internal includes */ #include #include using namespace Genode; static Parent *_parent_ptr; static Parent &_parent() { if (_parent_ptr) return *_parent_ptr; error("missing call of init_rpc_cap_alloc"); for (;;); } void Genode::init_rpc_cap_alloc(Parent &parent) { _parent_ptr = &parent; } Native_capability Rpc_entrypoint::_alloc_rpc_cap(Pd_session& pd, Native_capability, addr_t) { /* first we allocate a cap from core, to allow accounting of caps. */ for (;;) { Ram_quota ram_upgrade { 0 }; Cap_quota cap_upgrade { 0 }; try { pd.alloc_rpc_cap(_cap); break; } catch (Out_of_ram) { ram_upgrade = Ram_quota { 2*1024*sizeof(long) }; } catch (Out_of_caps) { cap_upgrade = Cap_quota { 4 }; } _parent().upgrade(Parent::Env::pd(), String<100>("ram_quota=", ram_upgrade, ", " "cap_quota=", cap_upgrade).string()); } return Thread::native_thread().epoll.alloc_rpc_cap(); } void Rpc_entrypoint::_free_rpc_cap(Pd_session& pd, Native_capability cap) { Native_thread::Epoll &epoll = Thread::native_thread().epoll; /* * Flag RPC entrypoint as exited to prevent 'free_rpc_cap' from issuing * a remote control request. */ if (_exit_handler.exit) epoll.rpc_ep_exited(); /* * Perform the accounting of the PDs cap quota at core, to remain * consistent with other kernel platforms. */ pd.free_rpc_cap(Native_capability()); epoll.free_rpc_cap(cap); }