2013-08-10 03:44:55 +02:00
|
|
|
/*
|
|
|
|
* \brief TRACE session interface
|
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2013-08-11
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2013-2017 Genode Labs GmbH
|
2013-08-10 03:44:55 +02: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.
|
2013-08-10 03:44:55 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__TRACE_SESSION__TRACE_SESSION_H_
|
|
|
|
#define _INCLUDE__TRACE_SESSION__TRACE_SESSION_H_
|
|
|
|
|
|
|
|
#include <base/exception.h>
|
|
|
|
#include <base/trace/types.h>
|
|
|
|
#include <dataspace/capability.h>
|
|
|
|
#include <session/session.h>
|
|
|
|
|
|
|
|
namespace Genode { namespace Trace { struct Session; } }
|
|
|
|
|
|
|
|
|
|
|
|
struct Genode::Trace::Session : Genode::Session
|
|
|
|
{
|
2017-05-24 14:41:19 +02:00
|
|
|
/**
|
|
|
|
* \noapi
|
|
|
|
*/
|
2013-08-10 03:44:55 +02:00
|
|
|
static const char *service_name() { return "TRACE"; }
|
|
|
|
|
2017-05-07 22:03:25 +02:00
|
|
|
enum { CAP_QUOTA = 4 };
|
|
|
|
|
2013-08-10 03:44:55 +02:00
|
|
|
/**
|
|
|
|
* Allocate policy-module backing store
|
|
|
|
*
|
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
|
|
|
* \throw Out_of_ram
|
|
|
|
* \throw Out_of_caps
|
2013-08-10 03:44:55 +02:00
|
|
|
*/
|
|
|
|
virtual Policy_id alloc_policy(size_t size) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request policy-module backing store
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_policy
|
|
|
|
*/
|
|
|
|
virtual Dataspace_capability policy(Policy_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a policy module from the TRACE service
|
|
|
|
*/
|
|
|
|
virtual void unload_policy(Policy_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Start tracing of a subject
|
|
|
|
*
|
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
|
|
|
* \throw Out_of_ram
|
|
|
|
* \throw Out_of_caps
|
2013-08-10 03:44:55 +02:00
|
|
|
* \throw Already_traced
|
|
|
|
* \throw Source_is_dead
|
|
|
|
* \throw Nonexistent_policy
|
2018-01-24 00:33:51 +01:00
|
|
|
* \throw Nonexistent_subject
|
2013-08-10 03:44:55 +02:00
|
|
|
* \throw Traced_by_other_session
|
|
|
|
*/
|
|
|
|
virtual void trace(Subject_id, Policy_id, size_t buffer_size) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Install a matching rule for automatically tracing new threads
|
|
|
|
*/
|
|
|
|
virtual void rule(Session_label const &, Thread_name const &,
|
|
|
|
Policy_id, size_t buffer_size) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Pause generation of tracing data
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_subject
|
|
|
|
*/
|
|
|
|
virtual void pause(Subject_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Resume generation of tracing data
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_subject
|
|
|
|
* \throw Source_is_dead
|
|
|
|
*/
|
|
|
|
virtual void resume(Subject_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain details about tracing subject
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_subject
|
|
|
|
*/
|
|
|
|
virtual Subject_info subject_info(Subject_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain trace buffer of given subject
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_subject
|
|
|
|
*/
|
|
|
|
virtual Dataspace_capability buffer(Subject_id) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Release subject and free buffers
|
|
|
|
*
|
|
|
|
* If the source still exists, the buffers are freed but the subject
|
|
|
|
* stays intact.
|
|
|
|
*
|
|
|
|
* \throw Nonexistent_subject
|
|
|
|
*/
|
|
|
|
virtual void free(Subject_id) = 0;
|
|
|
|
|
|
|
|
virtual ~Session() { }
|
|
|
|
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
** RPC declaration **
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
GENODE_RPC(Rpc_dataspace, Dataspace_capability, dataspace);
|
|
|
|
GENODE_RPC_THROW(Rpc_alloc_policy, Policy_id, alloc_policy,
|
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
|
|
|
GENODE_TYPE_LIST(Out_of_ram, Out_of_caps),
|
2013-08-10 03:44:55 +02:00
|
|
|
size_t);
|
|
|
|
GENODE_RPC_THROW(Rpc_policy, Dataspace_capability, policy,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_policy),
|
|
|
|
Policy_id);
|
|
|
|
GENODE_RPC_THROW(Rpc_unload_policy, void, unload_policy,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_policy), Policy_id);
|
|
|
|
GENODE_RPC_THROW(Rpc_trace, void, trace,
|
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
|
|
|
GENODE_TYPE_LIST(Out_of_ram, Out_of_caps, Already_traced,
|
2018-01-24 00:33:51 +01:00
|
|
|
Source_is_dead, Nonexistent_subject,
|
|
|
|
Nonexistent_policy,
|
2013-08-10 03:44:55 +02:00
|
|
|
Traced_by_other_session),
|
|
|
|
Subject_id, Policy_id, size_t);
|
|
|
|
GENODE_RPC_THROW(Rpc_rule, void, rule,
|
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
|
|
|
GENODE_TYPE_LIST(Out_of_ram, Out_of_caps),
|
2013-08-10 03:44:55 +02:00
|
|
|
Session_label const &, Thread_name const &,
|
|
|
|
Policy_id, size_t);
|
|
|
|
GENODE_RPC_THROW(Rpc_pause, void, pause,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_subject), Subject_id);
|
|
|
|
GENODE_RPC_THROW(Rpc_resume, void, resume,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_subject, Source_is_dead),
|
|
|
|
Subject_id);
|
2015-06-17 13:25:51 +02:00
|
|
|
GENODE_RPC_THROW(Rpc_subjects, size_t, subjects,
|
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
|
|
|
GENODE_TYPE_LIST(Out_of_ram, Out_of_caps));
|
2013-08-10 03:44:55 +02:00
|
|
|
GENODE_RPC_THROW(Rpc_subject_info, Subject_info, subject_info,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_subject), Subject_id);
|
|
|
|
GENODE_RPC_THROW(Rpc_buffer, Dataspace_capability, buffer,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_subject, Subject_not_traced),
|
|
|
|
Subject_id);
|
|
|
|
GENODE_RPC_THROW(Rpc_free, void, free,
|
|
|
|
GENODE_TYPE_LIST(Nonexistent_subject), Subject_id);
|
|
|
|
|
2016-05-11 17:23:51 +02:00
|
|
|
GENODE_RPC_INTERFACE(Rpc_dataspace, Rpc_alloc_policy, Rpc_policy,
|
|
|
|
Rpc_unload_policy, Rpc_trace, Rpc_rule, Rpc_pause,
|
|
|
|
Rpc_resume, Rpc_subjects, Rpc_subject_info, Rpc_buffer,
|
|
|
|
Rpc_free);
|
2013-08-10 03:44:55 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _INCLUDE__TRACE_SESSION__TRACE_SESSION_H_ */
|