mirror of
https://github.com/nasa/trick.git
synced 2025-01-24 21:36:56 +00:00
205 lines
8.7 KiB
Plaintext
205 lines
8.7 KiB
Plaintext
|
/**
|
||
|
|
||
|
@page LEVEL2 Trick Master/Slave Synchronization Design
|
||
|
Master/Slave synchronization is an optional class when running simulations.
|
||
|
|
||
|
Master/Slave synchronization synchronizes a master simulation to one or more slave
|
||
|
simulations. While synchronized, the master controls the overall simulation
|
||
|
mode as well as the current simulation time for all simulations. The set of
|
||
|
simulations may change mode if one of the simulations in the set freezes or exits
|
||
|
unexpectedly.
|
||
|
|
||
|
Master/Slave syncrhonization uses the Trick::MSConnect class for communications.
|
||
|
The MSConnect class is an abstract base class that defines functions for
|
||
|
connecting the simulations together and passing the simulation mode and
|
||
|
simulation time between simulations. The Trick::MSSocket class derives from the
|
||
|
Trick::MSConnect class, and uses sockets as the transport medium for master/slave communications.
|
||
|
|
||
|
@section LEVEL3 Master
|
||
|
|
||
|
The master simulation starts slave simulations during initialization. At the
|
||
|
end of each software frame during Run mode and at the end of each freeze frame
|
||
|
during Freeze mode the master reads the mode of all connected slave simulations.
|
||
|
The master will determine the mode of the simulations for the next frame
|
||
|
according to the slave modes and the master mode. The new mode and the
|
||
|
current simulation time is sent to the slaves.
|
||
|
|
||
|
Master/Slave synchronization is divided into code based on the mode of the
|
||
|
simulation. The modes are Initialization, Run, Freeze, and Shutdown.
|
||
|
|
||
|
Master/Slave functions are designed to be called from the S_define file.
|
||
|
|
||
|
Listed below are the various modes of operation and the Master
|
||
|
responsibilities within each.
|
||
|
|
||
|
@par Initialization -- Master
|
||
|
|
||
|
During Initialization slave connections are allocated and defined. Default
|
||
|
values to start each slave using ssh are set when a slave connection is
|
||
|
allocated. At the mimimum a slave must define a remote machine, the path
|
||
|
to the simulation executive, and a Trick::MSConnect class to use for
|
||
|
communications with the slave. Users may also define the remote shell to use,
|
||
|
a simulation executable name, a remote run directory, and additional user arguments
|
||
|
to pass to the slave. The allocation and definition of the slave
|
||
|
connections are typically done through Trick's input processor, but may also be
|
||
|
done in default_data or initialization jobs.
|
||
|
|
||
|
At the end of the scheduler initialization phase the master starts the slaves.
|
||
|
For each slave the master creates a slave startup command and executes the
|
||
|
slave startup command. This is how the slave startup command is created:
|
||
|
|
||
|
-# If the MSConnect class is not defined, return an error.
|
||
|
[@anchor d_master_init_0 d_master_init_0]
|
||
|
-# Begin the slave startup command with the slave remote shell.
|
||
|
[@anchor d_master_init_1 d_master_init_1]
|
||
|
-# Add the remote display environment variable to the startup command if
|
||
|
one was defined.
|
||
|
[@anchor d_master_init_2 d_master_init_2]
|
||
|
-# Add a cd command to the slave simulation path directory to the slave starup
|
||
|
command.
|
||
|
[@anchor d_master_init_3 d_master_init_3]
|
||
|
-# Add the S_main executable name to the slave startup command.
|
||
|
[@anchor d_master_init_4 d_master_init_4]
|
||
|
-# Add the Run Input File to the slave startup command.
|
||
|
[@anchor d_master_init_5 d_master_init_5]
|
||
|
-# Add additional user arguments to the slave startup command.
|
||
|
[@anchor d_master_init_6 d_master_init_6]
|
||
|
-# Execute the slave startup command.
|
||
|
[@anchor d_master_init_7 d_master_init_7]
|
||
|
|
||
|
The master sends its software frame to each slave.
|
||
|
|
||
|
@par Run -- Master
|
||
|
|
||
|
During Run mode the master reads the simulation mode of each slave. The
|
||
|
master determines the new simulation mode and sends the new mode and the
|
||
|
current simulation time to the slaves.
|
||
|
|
||
|
-# For each slave
|
||
|
-# Read the simulation command of the slave.
|
||
|
[@anchor d_master_run_0 d_master_run_0]
|
||
|
-# If the master mode command is not ExitCmd take action if the slave
|
||
|
returns the following:
|
||
|
-# If the slave command was not readable, returned ErrorCmd, and:
|
||
|
-# Terminate the sim if sync_error_terminate == true.
|
||
|
[@anchor d_master_run_1 d_master_run_1]
|
||
|
-# Deactivate the slave if sync_error_terminate == false.
|
||
|
[@anchor d_master_run_2 d_master_run_2]
|
||
|
-# If the slave command is ExitCmd:
|
||
|
-# Terminate the sim if sync_error_terminate == true.
|
||
|
[@anchor d_master_run_3 d_master_run_3]
|
||
|
-# Deactivate the slave if sync_error_terminate == false.
|
||
|
[@anchor d_master_run_4 d_master_run_4]
|
||
|
-# If the slave command is FreezeCmd:
|
||
|
-# Freeze the master sim
|
||
|
[@anchor d_master_run_5 d_master_run_5]
|
||
|
|
||
|
After gathering the simulation command from all of the slaves, send the
|
||
|
command to all of the slaves.
|
||
|
|
||
|
-# For each slave
|
||
|
-# Write the simulation time to the slave.
|
||
|
[@anchor d_master_run_0 d_master_run_0]
|
||
|
-# Write the simulation mode command to the slave.
|
||
|
[@anchor d_master_run_0 d_master_run_0]
|
||
|
|
||
|
@par Freeze -- Master
|
||
|
|
||
|
Upon entering freeze mode the master turns off sync_time_limit because while
|
||
|
in freeze, master/slave communications may not be regular and periodic.
|
||
|
[@anchor d_master_freeze_0 d_master_freeze_0]
|
||
|
|
||
|
At the end of each freeze frame call Trick::Master::end_of_frame() to perform the same
|
||
|
synchronization as in run mode.
|
||
|
[@anchor d_master_freeze_1 d_master_freeze_1]
|
||
|
|
||
|
When exiting freeze mode the master sets sync_time_limit back to the user
|
||
|
set value ready for running again.
|
||
|
[@anchor d_master_freeze_2 d_master_freeze_2]
|
||
|
|
||
|
@par Shutdown -- Master
|
||
|
|
||
|
The master tells the slaves that it is shutting down.
|
||
|
|
||
|
-# For each slave
|
||
|
-# Write the simulation time to the slave.
|
||
|
[@anchor d_master_shutdown_0 d_master_shutdown_0]
|
||
|
-# Write the simulation mode command ExitCmd to the slave.
|
||
|
[@anchor d_master_shutdown_0 d_master_shutdown_0]
|
||
|
|
||
|
|
||
|
@section LEVEL3 Slave
|
||
|
|
||
|
At the end of each software frame during Run mode and at the end of each
|
||
|
freeze frame during Freeze mode slave simulations send the master the current
|
||
|
mode of the slave. The slaves wait for the new mode and simulation time from
|
||
|
the master.
|
||
|
|
||
|
@par Initialization -- Slave
|
||
|
|
||
|
The Trick::Slave class is enabled by calling the MSConnect::process_sim_args()
|
||
|
routine. If the MSConnect::process_sim_args() finds command line arguments
|
||
|
specifying this simulation is a slave, then the Trick::Slave is enabled.
|
||
|
|
||
|
At the end of the scheduler initialization phase the slave connects to the
|
||
|
master.
|
||
|
|
||
|
-# Call Trick::MSConnect::connect() to connect the slave to the master.
|
||
|
[@anchor d_slave_init_0 d_slave_init_0]
|
||
|
-# Search for a RealtimeSync class. If one exists, turn the object off.
|
||
|
[@anchor d_slave_init_1 d_slave_init_1]
|
||
|
-# Search for a Master class. If one exists, turn the object off.
|
||
|
[@anchor d_slave_init_2 d_slave_init_2]
|
||
|
-# Read and set the slave's software frame from the master.
|
||
|
|
||
|
@par Run -- Slave
|
||
|
|
||
|
In Run mode the slave writes its next executive command to the master. The
|
||
|
master will return the overall next simulation mode to the slave. The slave
|
||
|
will also read the current simulation time from the master.
|
||
|
|
||
|
-# Write the simulation command to the master.
|
||
|
[@anchor d_slave_run_0 d_slave_run_0]
|
||
|
-# Read the simulation time from the master.
|
||
|
[@anchor d_slave_run_1 d_slave_run_1]
|
||
|
-# if the simulation time read was not successful:
|
||
|
-# Terminate the sim if sync_error_terminate == true.
|
||
|
[@anchor d_slave_run_2 d_slave_run_2]
|
||
|
-# Disable master/slave communication and command the sim to freeze if sync_error_terminate == false.
|
||
|
[@anchor d_slave_run_3 d_slave_run_3]
|
||
|
-# If the simulation time read was successful set the slave simulation
|
||
|
time to the time of the master.
|
||
|
[@anchor d_slave_run_4 d_slave_run_4]
|
||
|
-# Read the simulation command from the master.
|
||
|
[@anchor d_slave_run_5 d_slave_run_5]
|
||
|
-# If the simulation command was not successful:
|
||
|
-# Terminate the sim if sync_error_terminate == true.
|
||
|
[@anchor d_slave_run_6 d_slave_run_6]
|
||
|
-# Disable master/slave communication and command the sim to freeze if sync_error_terminate == false.
|
||
|
[@anchor d_slave_run_7 d_slave_run_7]
|
||
|
-# If the simulation command read was successful set the slave simulation
|
||
|
command to the command of the master.
|
||
|
[@anchor d_slave_run_8 d_slave_run_8]
|
||
|
|
||
|
@par Freeze -- Slave
|
||
|
|
||
|
Upon entering freeze mode the slave turns off sync_time_limit because while
|
||
|
in freeze, master/slave communications may not be regular and periodic.
|
||
|
[@anchor d_slave_freeze_0 d_slave_freeze_0]
|
||
|
|
||
|
At the end of each freeze frame call Trick::Slave::end_of_frame() to perform the same
|
||
|
synchronization as in run mode.
|
||
|
[@anchor d_slave_freeze_1 d_slave_freeze_1]
|
||
|
|
||
|
When exiting freeze mode the slave sets sync_time_limit back to the user
|
||
|
set value ready for running again.
|
||
|
[@anchor d_slave_freeze_2 d_slave_freeze_2]
|
||
|
|
||
|
@par Shutdown -- Slave
|
||
|
|
||
|
If a slave is shutting down, inform the master that it is exiting.
|
||
|
[@anchor d_slave_shutdown_0 d_slave_shutdown_0]
|
||
|
|
||
|
*/
|
||
|
|