2011-12-22 16:19:25 +01:00
|
|
|
/*
|
2017-03-03 16:54:45 +01:00
|
|
|
* \brief Child-policy helpers
|
2011-12-22 16:19:25 +01:00
|
|
|
* \author Norman Feske
|
|
|
|
* \date 2010-04-29
|
2017-03-03 16:54:45 +01:00
|
|
|
*
|
|
|
|
* \deprecated use os/dynamic_rom_session.h instead
|
2011-12-22 16:19:25 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2017-02-20 13:23:52 +01:00
|
|
|
* Copyright (C) 2010-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
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _INCLUDE__INIT__CHILD_POLICY_H_
|
|
|
|
#define _INCLUDE__INIT__CHILD_POLICY_H_
|
|
|
|
|
|
|
|
/* Genode includes */
|
2017-03-03 16:54:45 +01:00
|
|
|
#include <base/rpc_server.h>
|
2011-12-22 16:19:25 +01:00
|
|
|
#include <base/service.h>
|
2017-03-03 16:54:45 +01:00
|
|
|
#include <rom_session/rom_session.h>
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
namespace Init {
|
2015-03-04 21:12:14 +01:00
|
|
|
class Child_policy_provide_rom_file;
|
2017-01-03 18:12:53 +01:00
|
|
|
using namespace Genode;
|
2015-03-04 21:12:14 +01:00
|
|
|
}
|
2015-02-07 21:02:50 +01:00
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
class Init::Child_policy_provide_rom_file
|
|
|
|
{
|
|
|
|
private:
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
struct Local_rom_session_component : Rpc_object<Rom_session>
|
2015-03-04 21:12:14 +01:00
|
|
|
{
|
2017-01-03 18:12:53 +01:00
|
|
|
Rpc_entrypoint &ep;
|
|
|
|
Dataspace_capability ds_cap;
|
Support for dynamic ROM sessions, fix #170
This patch introduces support for ROM sessions that update their
provided data during the lifetime of the session. The 'Rom_session'
interface had been extended with the new 'release()' and 'sigh()'
functions, which are needed to support the new protocol. All ROM
services have been updated to the new interface.
Furthermore, the patch changes the child policy of init
with regard to the handling of configuration files. The 'Init::Child'
used to always provide the ROM dataspace with the child's config file
via a locally implemented ROM service. However, for dynamic ROM
sessions, we need to establish a session to the real supplier of the ROM
data. This is achieved by using a new 'Child_policy_redirect_rom_file'
policy to handle the 'configfile' rather than handling the 'configfile'
case entirely within 'Child_config'.
To see the new facility in action, the new 'os/run/dynamic_config.run'
script provides a simple scenario. The config file of the test program
is provided by a service, which generates and updates the config data
at regular intervals.
In addition, new support has been added to let slaves use dynamic
reconfiguration. By using the new 'Child_policy_dynamic_rom_file', the
configuration of a slave can be changed dynamically at runtime via the
new 'configure()' function.
The config is provided as plain null-terminated string (instead of a
dataspace capability) because we need to buffer the config data anyway.
So there is no benefit of using a dataspace. For buffering configuration
data, a 'Ram_session' must be supplied. If no 'Ram_session' is specified
at construction time of a 'Slave_policy', no config is supplied to the
slave (which is still a common case).
An example for dynamically reconfiguring a slave is provided by
'os/run/dynamic_config_slave.run'.
2012-04-04 17:07:19 +02:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2017-01-03 18:12:53 +01:00
|
|
|
Local_rom_session_component(Rpc_entrypoint &ep,
|
|
|
|
Dataspace_capability ds)
|
2016-11-06 14:26:34 +01:00
|
|
|
: ep(ep), ds_cap(ds) { ep.manage(this); }
|
|
|
|
|
|
|
|
~Local_rom_session_component() { ep.dissolve(this); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/***************************
|
|
|
|
** ROM session interface **
|
|
|
|
***************************/
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
Rom_dataspace_capability dataspace() override {
|
|
|
|
return static_cap_cast<Rom_dataspace>(ds_cap); }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
void sigh(Signal_context_capability) override { }
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2016-11-06 14:26:34 +01:00
|
|
|
} _session;
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
Session_label const _module_name;
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
typedef Local_service<Local_rom_session_component> Service;
|
2011-12-22 16:19:25 +01:00
|
|
|
|
2016-11-06 14:26:34 +01:00
|
|
|
Service::Single_session_factory _session_factory { _session };
|
|
|
|
Service _service { _session_factory };
|
Support for dynamic ROM sessions, fix #170
This patch introduces support for ROM sessions that update their
provided data during the lifetime of the session. The 'Rom_session'
interface had been extended with the new 'release()' and 'sigh()'
functions, which are needed to support the new protocol. All ROM
services have been updated to the new interface.
Furthermore, the patch changes the child policy of init
with regard to the handling of configuration files. The 'Init::Child'
used to always provide the ROM dataspace with the child's config file
via a locally implemented ROM service. However, for dynamic ROM
sessions, we need to establish a session to the real supplier of the ROM
data. This is achieved by using a new 'Child_policy_redirect_rom_file'
policy to handle the 'configfile' rather than handling the 'configfile'
case entirely within 'Child_config'.
To see the new facility in action, the new 'os/run/dynamic_config.run'
script provides a simple scenario. The config file of the test program
is provided by a service, which generates and updates the config data
at regular intervals.
In addition, new support has been added to let slaves use dynamic
reconfiguration. By using the new 'Child_policy_dynamic_rom_file', the
configuration of a slave can be changed dynamically at runtime via the
new 'configure()' function.
The config is provided as plain null-terminated string (instead of a
dataspace capability) because we need to buffer the config data anyway.
So there is no benefit of using a dataspace. For buffering configuration
data, a 'Ram_session' must be supplied. If no 'Ram_session' is specified
at construction time of a 'Slave_policy', no config is supplied to the
slave (which is still a common case).
An example for dynamically reconfiguring a slave is provided by
'os/run/dynamic_config_slave.run'.
2012-04-04 17:07:19 +02:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
public:
|
Support for dynamic ROM sessions, fix #170
This patch introduces support for ROM sessions that update their
provided data during the lifetime of the session. The 'Rom_session'
interface had been extended with the new 'release()' and 'sigh()'
functions, which are needed to support the new protocol. All ROM
services have been updated to the new interface.
Furthermore, the patch changes the child policy of init
with regard to the handling of configuration files. The 'Init::Child'
used to always provide the ROM dataspace with the child's config file
via a locally implemented ROM service. However, for dynamic ROM
sessions, we need to establish a session to the real supplier of the ROM
data. This is achieved by using a new 'Child_policy_redirect_rom_file'
policy to handle the 'configfile' rather than handling the 'configfile'
case entirely within 'Child_config'.
To see the new facility in action, the new 'os/run/dynamic_config.run'
script provides a simple scenario. The config file of the test program
is provided by a service, which generates and updates the config data
at regular intervals.
In addition, new support has been added to let slaves use dynamic
reconfiguration. By using the new 'Child_policy_dynamic_rom_file', the
configuration of a slave can be changed dynamically at runtime via the
new 'configure()' function.
The config is provided as plain null-terminated string (instead of a
dataspace capability) because we need to buffer the config data anyway.
So there is no benefit of using a dataspace. For buffering configuration
data, a 'Ram_session' must be supplied. If no 'Ram_session' is specified
at construction time of a 'Slave_policy', no config is supplied to the
slave (which is still a common case).
An example for dynamically reconfiguring a slave is provided by
'os/run/dynamic_config_slave.run'.
2012-04-04 17:07:19 +02:00
|
|
|
|
2015-03-04 21:12:14 +01:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
2017-01-03 18:12:53 +01:00
|
|
|
Child_policy_provide_rom_file(Session_label const &module_name,
|
|
|
|
Dataspace_capability ds_cap,
|
|
|
|
Rpc_entrypoint *ep)
|
2015-03-04 21:12:14 +01:00
|
|
|
:
|
2016-11-06 14:26:34 +01:00
|
|
|
_session(*ep, ds_cap), _module_name(module_name)
|
2016-05-12 14:58:51 +02:00
|
|
|
{ }
|
Support for dynamic ROM sessions, fix #170
This patch introduces support for ROM sessions that update their
provided data during the lifetime of the session. The 'Rom_session'
interface had been extended with the new 'release()' and 'sigh()'
functions, which are needed to support the new protocol. All ROM
services have been updated to the new interface.
Furthermore, the patch changes the child policy of init
with regard to the handling of configuration files. The 'Init::Child'
used to always provide the ROM dataspace with the child's config file
via a locally implemented ROM service. However, for dynamic ROM
sessions, we need to establish a session to the real supplier of the ROM
data. This is achieved by using a new 'Child_policy_redirect_rom_file'
policy to handle the 'configfile' rather than handling the 'configfile'
case entirely within 'Child_config'.
To see the new facility in action, the new 'os/run/dynamic_config.run'
script provides a simple scenario. The config file of the test program
is provided by a service, which generates and updates the config data
at regular intervals.
In addition, new support has been added to let slaves use dynamic
reconfiguration. By using the new 'Child_policy_dynamic_rom_file', the
configuration of a slave can be changed dynamically at runtime via the
new 'configure()' function.
The config is provided as plain null-terminated string (instead of a
dataspace capability) because we need to buffer the config data anyway.
So there is no benefit of using a dataspace. For buffering configuration
data, a 'Ram_session' must be supplied. If no 'Ram_session' is specified
at construction time of a 'Slave_policy', no config is supplied to the
slave (which is still a common case).
An example for dynamically reconfiguring a slave is provided by
'os/run/dynamic_config_slave.run'.
2012-04-04 17:07:19 +02:00
|
|
|
|
2017-02-15 16:42:49 +01:00
|
|
|
Service *resolve_session_request_with_label(Service::Name const &name,
|
|
|
|
Session_label const &label)
|
|
|
|
{
|
|
|
|
return (name == "ROM" && label.last_element() == _module_name)
|
|
|
|
? &_service : nullptr;
|
|
|
|
}
|
|
|
|
|
2017-01-03 18:12:53 +01:00
|
|
|
Service *resolve_session_request(const char *service_name,
|
2015-03-04 21:12:14 +01:00
|
|
|
const char *args)
|
|
|
|
{
|
2017-02-15 16:42:49 +01:00
|
|
|
return resolve_session_request_with_label(service_name,
|
|
|
|
label_from_args(args));
|
2015-03-04 21:12:14 +01:00
|
|
|
}
|
|
|
|
};
|
Support for dynamic ROM sessions, fix #170
This patch introduces support for ROM sessions that update their
provided data during the lifetime of the session. The 'Rom_session'
interface had been extended with the new 'release()' and 'sigh()'
functions, which are needed to support the new protocol. All ROM
services have been updated to the new interface.
Furthermore, the patch changes the child policy of init
with regard to the handling of configuration files. The 'Init::Child'
used to always provide the ROM dataspace with the child's config file
via a locally implemented ROM service. However, for dynamic ROM
sessions, we need to establish a session to the real supplier of the ROM
data. This is achieved by using a new 'Child_policy_redirect_rom_file'
policy to handle the 'configfile' rather than handling the 'configfile'
case entirely within 'Child_config'.
To see the new facility in action, the new 'os/run/dynamic_config.run'
script provides a simple scenario. The config file of the test program
is provided by a service, which generates and updates the config data
at regular intervals.
In addition, new support has been added to let slaves use dynamic
reconfiguration. By using the new 'Child_policy_dynamic_rom_file', the
configuration of a slave can be changed dynamically at runtime via the
new 'configure()' function.
The config is provided as plain null-terminated string (instead of a
dataspace capability) because we need to buffer the config data anyway.
So there is no benefit of using a dataspace. For buffering configuration
data, a 'Ram_session' must be supplied. If no 'Ram_session' is specified
at construction time of a 'Slave_policy', no config is supplied to the
slave (which is still a common case).
An example for dynamically reconfiguring a slave is provided by
'os/run/dynamic_config_slave.run'.
2012-04-04 17:07:19 +02:00
|
|
|
|
2011-12-22 16:19:25 +01:00
|
|
|
#endif /* _INCLUDE__INIT__CHILD_POLICY_H_ */
|