2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Protection domain (PD) session interface
|
|
|
|
* \author Christian Helmuth
|
|
|
|
* \date 2006-06-27
|
|
|
|
*
|
|
|
|
* A pd session represents the protection domain of a program.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2012-01-03 15:35:05 +01:00
|
|
|
* Copyright (C) 2006-2012 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__PD_SESSION__PD_SESSION_H_
|
|
|
|
#define _INCLUDE__PD_SESSION__PD_SESSION_H_
|
|
|
|
|
|
|
|
#include <thread/capability.h>
|
|
|
|
#include <parent/capability.h>
|
|
|
|
#include <session/session.h>
|
|
|
|
|
|
|
|
namespace Genode {
|
|
|
|
|
|
|
|
struct Pd_session : Session
|
|
|
|
{
|
|
|
|
static const char *service_name() { return "PD"; }
|
|
|
|
|
|
|
|
virtual ~Pd_session() { }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bind thread to protection domain
|
|
|
|
*
|
|
|
|
* \param thread capability of thread to bind
|
|
|
|
*
|
|
|
|
* \return 0 on success or negative error code
|
|
|
|
*
|
|
|
|
* After successful bind, the thread will execute inside this
|
|
|
|
* protection domain when started.
|
|
|
|
*/
|
|
|
|
virtual int bind_thread(Thread_capability thread) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assign parent to protection domain
|
|
|
|
*
|
|
|
|
* \param parent capability of parent interface
|
|
|
|
* \return 0 on success, or negative error code
|
|
|
|
*/
|
|
|
|
virtual int assign_parent(Parent_capability parent) = 0;
|
|
|
|
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
** RPC declaration **
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
GENODE_RPC(Rpc_bind_thread, int, bind_thread, Thread_capability);
|
|
|
|
GENODE_RPC(Rpc_assign_parent, int, assign_parent, Parent_capability);
|
|
|
|
|
|
|
|
GENODE_RPC_INTERFACE(Rpc_bind_thread, Rpc_assign_parent);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__PD_SESSION__PD_SESSION_H_ */
|