/*
* \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(Name const &name, addr_t utcb = 0) {
return call(name, utcb); }
Ram_dataspace_capability utcb(Thread_capability thread) {
return call(thread); }
void kill_thread(Thread_capability thread) {
call(thread); }
int set_pager(Thread_capability thread, Pager_capability pager) {
return call(thread, pager); }
int start(Thread_capability thread, addr_t ip, addr_t sp) {
return call(thread, ip, sp); }
void pause(Thread_capability thread)
{
Native_capability block = call(thread);
if (!block.valid())
return;
Nova::sm_ctrl(block.local_name(), Nova::SEMAPHORE_DOWN);
Nova::revoke(Nova::Obj_crd(block.local_name(), 0));
cap_selector_allocator()->free(block.local_name(), 0);
}
void resume(Thread_capability thread) {
call(thread); }
void cancel_blocking(Thread_capability thread) {
call(thread); }
Thread_state state(Thread_capability thread) {
return call(thread); }
void state(Thread_capability thread, Thread_state const &state) {
call(thread, state); }
void exception_handler(Thread_capability thread, Signal_context_capability handler) {
call(thread, handler); }
void single_step(Thread_capability thread, bool enable) {
call(thread, enable); }
Affinity::Space affinity_space() const {
return call(); }
void affinity(Thread_capability thread, Affinity::Location location) {
call(thread, location); }
Dataspace_capability trace_control() {
return call(); }
unsigned trace_control_index(Thread_capability thread) {
return call(thread); }
Dataspace_capability trace_buffer(Thread_capability thread) {
return call(thread); }
Dataspace_capability trace_policy(Thread_capability thread) {
return call(thread); }
private:
Native_capability pause_sync(Thread_capability target) {
return Native_capability::invalid_cap(); }
};
}
#endif /* _INCLUDE__CPU_SESSION__CLIENT_H_ */