/* * \brief Client-side cpu session NOVA extension * \author Alexander Boettcher * \date 2012-07-27 */ /* * Copyright (C) 2012-2013 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. */ #ifndef _INCLUDE__CPU_SESSION__CLIENT_H_ #define _INCLUDE__CPU_SESSION__CLIENT_H_ #include #include #include #include namespace Genode { struct Cpu_session_client : Rpc_client { explicit Cpu_session_client(Cpu_session_capability session) : Rpc_client(static_cap_cast(session)) { } Thread_capability create_thread(Capability pd, Name const &name, Affinity::Location affinity, Weight weight, addr_t utcb = 0) override { return call(pd, name, affinity, weight, utcb); } Ram_dataspace_capability utcb(Thread_capability thread) override { return call(thread); } void kill_thread(Thread_capability thread) override { call(thread); } int start(Thread_capability thread, addr_t ip, addr_t sp) override { return call(thread, ip, sp); } void pause(Thread_capability thread) override { Native_capability block = call(thread); if (!block.valid()) return; Nova::sm_ctrl(block.local_name(), Nova::SEMAPHORE_DOWN); } void resume(Thread_capability thread) override { call(thread); } void cancel_blocking(Thread_capability thread) override { call(thread); } Thread_state state(Thread_capability thread) override { return call(thread); } void state(Thread_capability thread, Thread_state const &state) override { call(thread, state); } void exception_handler(Thread_capability thread, Signal_context_capability handler) override { call(thread, handler); } void single_step(Thread_capability thread, bool enable) override { Native_capability block = call(thread, enable); if (!block.valid()) return; Nova::sm_ctrl(block.local_name(), Nova::SEMAPHORE_DOWN); } Affinity::Space affinity_space() const override { return call(); } void affinity(Thread_capability thread, Affinity::Location location) override { call(thread, location); } Dataspace_capability trace_control() override { return call(); } unsigned trace_control_index(Thread_capability thread) override { return call(thread); } Dataspace_capability trace_buffer(Thread_capability thread) override { return call(thread); } Dataspace_capability trace_policy(Thread_capability thread) override { return call(thread); } int ref_account(Cpu_session_capability session) override { return call(session); } int transfer_quota(Cpu_session_capability session, size_t amount) override { return call(session, amount); } Quota quota() override { return call(); } Capability native_cpu() override { return call(); } private: Native_capability pause_sync(Thread_capability) { return Native_capability(); } Native_capability single_step_sync(Thread_capability, bool) { return Native_capability(); } }; } #endif /* _INCLUDE__CPU_SESSION__CLIENT_H_ */