2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* \brief Session
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2011-05-15
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2011-2017 Genode Labs GmbH
|
2011-12-22 16:19:25 +01:00
|
|
|
*
|
|
|
|
* This file is part of the Genode OS framework, which is distributed
|
2017-02-20 13:23:52 +01:00
|
|
|
* under the terms of the GNU Affero General Public License version 3.
|
2011-12-22 16:19:25 +01:00
|
|
|
*/
|
|
|
|
|
2016-01-20 20:52:51 +01:00
|
|
|
#ifndef _INCLUDE__SESSION__SESSION_H_
|
|
|
|
#define _INCLUDE__SESSION__SESSION_H_
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-05-07 23:44:48 +02:00
|
|
|
#include <base/quota_guard.h>
|
|
|
|
#include <base/session_label.h>
|
|
|
|
#include <util/arg_string.h>
|
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
/*
|
|
|
|
* Each session interface declares an RPC interface and, therefore, relies on
|
|
|
|
* the RPC framework. By including 'base/rpc.h' here, we relieve the interfaces
|
|
|
|
* from including 'base/rpc.h' in addition to 'session/session.h'.
|
|
|
|
*/
|
|
|
|
#include <base/rpc.h>
|
|
|
|
|
2017-05-07 23:44:48 +02:00
|
|
|
namespace Genode {
|
|
|
|
|
|
|
|
struct Session;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Exceptions that may occur during the session creation
|
|
|
|
*/
|
|
|
|
struct Insufficient_ram_quota : Exception { };
|
|
|
|
struct Insufficient_cap_quota : Exception { };
|
Streamline exception types
This patch reduces the number of exception types by facilitating
globally defined exceptions for common usage patterns shared by most
services. In particular, RPC functions that demand a session-resource
upgrade not longer reflect this condition via a session-specific
exception but via the 'Out_of_ram' or 'Out_of_caps' types.
Furthermore, the 'Parent::Service_denied', 'Parent::Unavailable',
'Root::Invalid_args', 'Root::Unavailable', 'Service::Invalid_args',
'Service::Unavailable', and 'Local_service::Factory::Denied' types have
been replaced by the single 'Service_denied' exception type defined in
'session/session.h'.
This consolidation eases the error handling (there are fewer exceptions
to handle), alleviates the need to convert exceptions along the
session-creation call chain, and avoids possible aliasing problems
(catching the wrong type with the same name but living in a different
scope).
2017-05-07 22:03:22 +02:00
|
|
|
struct Service_denied : Exception { };
|
2017-05-07 23:44:48 +02:00
|
|
|
}
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
|
|
|
* Base class of session interfaces
|
|
|
|
*/
|
2016-11-06 14:26:34 +01:00
|
|
|
struct Genode::Session
|
2015-03-20 17:50:41 +01:00
|
|
|
{
|
2017-05-07 23:44:48 +02:00
|
|
|
struct Resources
|
|
|
|
{
|
|
|
|
Ram_quota ram_quota;
|
|
|
|
Cap_quota cap_quota;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Diag { bool enabled; };
|
|
|
|
|
|
|
|
typedef Session_label Label;
|
|
|
|
|
2015-03-20 17:50:41 +01:00
|
|
|
/*
|
|
|
|
* Each session interface must implement the class function 'service_name'
|
|
|
|
* ! static const char *service_name();
|
|
|
|
* This function returns the name of the service provided via the session
|
|
|
|
* interface.
|
|
|
|
*/
|
2016-11-06 14:26:34 +01:00
|
|
|
|
|
|
|
virtual ~Session() { }
|
2015-03-20 17:50:41 +01:00
|
|
|
};
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-05-07 23:44:48 +02:00
|
|
|
|
|
|
|
namespace Genode {
|
|
|
|
|
|
|
|
static inline Ram_quota ram_quota_from_args(char const *args)
|
|
|
|
{
|
|
|
|
return { Arg_string::find_arg(args, "ram_quota").ulong_value(0) };
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline Cap_quota cap_quota_from_args(char const *args)
|
|
|
|
{
|
|
|
|
return { Arg_string::find_arg(args, "cap_quota").ulong_value(0) };
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline Session::Label session_label_from_args(char const *args)
|
|
|
|
{
|
|
|
|
return label_from_args(args);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline Session::Resources session_resources_from_args(char const *args)
|
|
|
|
{
|
|
|
|
return { ram_quota_from_args(args), cap_quota_from_args(args) };
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline Session::Diag session_diag_from_args(char const *args)
|
|
|
|
{
|
|
|
|
return { Arg_string::find_arg(args, "diag").bool_value(false) };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-20 20:52:51 +01:00
|
|
|
#endif /* _INCLUDE__SESSION__SESSION_H_ */
|