2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Client-side cpu session Fiasco.OC extension
|
|
|
|
* \author Stefan Kalkowski
|
|
|
|
* \date 2011-04-04
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2013-01-10 21:44:47 +01:00
|
|
|
* Copyright (C) 2011-2013 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* 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__FOC_CPU_SESSION__CLIENT_H_
|
|
|
|
#define _INCLUDE__FOC_CPU_SESSION__CLIENT_H_
|
|
|
|
|
|
|
|
#include <cpu_session/client.h>
|
|
|
|
#include <foc_cpu_session/foc_cpu_session.h>
|
|
|
|
#include <base/printf.h>
|
|
|
|
|
|
|
|
namespace Genode {
|
|
|
|
|
|
|
|
struct Foc_cpu_session_client : Rpc_client<Foc_cpu_session>
|
|
|
|
{
|
|
|
|
explicit Foc_cpu_session_client(Cpu_session_capability session)
|
|
|
|
: Rpc_client<Foc_cpu_session>(static_cap_cast<Foc_cpu_session>(session)) { }
|
|
|
|
|
2012-08-02 17:10:46 +02:00
|
|
|
Thread_capability create_thread(Name const &name, addr_t utcb = 0) {
|
|
|
|
return call<Rpc_create_thread>(name, utcb); }
|
|
|
|
|
|
|
|
Ram_dataspace_capability utcb(Thread_capability thread) {
|
|
|
|
return call<Rpc_utcb>(thread); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
void kill_thread(Thread_capability thread) {
|
|
|
|
call<Rpc_kill_thread>(thread); }
|
|
|
|
|
|
|
|
int set_pager(Thread_capability thread, Pager_capability pager) {
|
|
|
|
return call<Rpc_set_pager>(thread, pager); }
|
|
|
|
|
|
|
|
int start(Thread_capability thread, addr_t ip, addr_t sp) {
|
|
|
|
return call<Rpc_start>(thread, ip, sp); }
|
|
|
|
|
|
|
|
void pause(Thread_capability thread) {
|
|
|
|
call<Rpc_pause>(thread); }
|
|
|
|
|
|
|
|
void resume(Thread_capability thread) {
|
|
|
|
call<Rpc_resume>(thread); }
|
|
|
|
|
|
|
|
void cancel_blocking(Thread_capability thread) {
|
|
|
|
call<Rpc_cancel_blocking>(thread); }
|
|
|
|
|
|
|
|
int name(Thread_capability thread, char *name_dst, size_t name_len)
|
|
|
|
{
|
|
|
|
PWRN("name called, this function is deprecated");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2012-11-12 17:48:18 +01:00
|
|
|
Thread_state state(Thread_capability thread) {
|
|
|
|
return call<Rpc_get_state>(thread); }
|
|
|
|
|
|
|
|
void state(Thread_capability thread, Thread_state const &state) {
|
|
|
|
call<Rpc_set_state>(thread, state); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
void exception_handler(Thread_capability thread, Signal_context_capability handler) {
|
|
|
|
call<Rpc_exception_handler>(thread, handler); }
|
|
|
|
|
2012-09-04 17:32:55 +02:00
|
|
|
void single_step(Thread_capability thread, bool enable) {
|
|
|
|
call<Rpc_single_step>(thread, enable); }
|
|
|
|
|
2013-08-07 22:16:58 +02:00
|
|
|
Affinity::Space affinity_space() const {
|
|
|
|
return call<Rpc_affinity_space>(); }
|
2012-09-04 17:32:55 +02:00
|
|
|
|
2013-08-07 22:16:58 +02:00
|
|
|
void affinity(Thread_capability thread, Affinity::Location location) {
|
|
|
|
call<Rpc_affinity>(thread, location); }
|
2012-09-04 17:32:55 +02:00
|
|
|
|
2013-08-09 11:11:03 +02:00
|
|
|
Dataspace_capability trace_control() {
|
|
|
|
return call<Rpc_trace_control>(); }
|
|
|
|
|
|
|
|
unsigned trace_control_index(Thread_capability thread) {
|
|
|
|
return call<Rpc_trace_control_index>(thread); }
|
|
|
|
|
|
|
|
Dataspace_capability trace_buffer(Thread_capability thread) {
|
|
|
|
return call<Rpc_trace_buffer>(thread); }
|
|
|
|
|
|
|
|
Dataspace_capability trace_policy(Thread_capability thread) {
|
|
|
|
return call<Rpc_trace_policy>(thread); }
|
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
void enable_vcpu(Thread_capability cap, addr_t vcpu_state) {
|
|
|
|
call<Rpc_enable_vcpu>(cap, vcpu_state); }
|
|
|
|
|
|
|
|
Native_capability native_cap(Thread_capability cap) {
|
|
|
|
return call<Rpc_native_cap>(cap); }
|
|
|
|
|
|
|
|
Native_capability alloc_irq() {
|
|
|
|
return call<Rpc_alloc_irq>(); }
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__FOC_CPU_SESSION__CLIENT_H_ */
|