2015-02-26 15:02:31 +00:00
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
2015-06-01 15:28:29 +00:00
|
|
|
#include "trick/VariableServer.hh"
|
|
|
|
#include "trick/variable_server_proto.h"
|
|
|
|
#include "trick/variable_server_sync_types.h"
|
|
|
|
#include "trick/TrickConstant.hh"
|
2015-02-26 15:02:31 +00:00
|
|
|
|
|
|
|
int Trick::VariableServer::freeze_init() {
|
|
|
|
|
2023-03-20 22:53:01 +00:00
|
|
|
long long next_call_tics = TRICK_MAX_LONG_LONG ;
|
2015-02-26 15:02:31 +00:00
|
|
|
|
|
|
|
pthread_mutex_lock(&map_mutex) ;
|
2023-03-20 22:53:01 +00:00
|
|
|
for ( auto it = var_server_sessions.begin() ; it != var_server_sessions.end() ; it++ ) {
|
|
|
|
VariableServerSession * session = (*it).second ;
|
2022-08-23 18:47:56 +00:00
|
|
|
session->freeze_init() ;
|
|
|
|
if ( session->get_freeze_next_tics() < next_call_tics ) {
|
|
|
|
next_call_tics = session->get_freeze_next_tics() ;
|
2015-02-26 15:02:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
pthread_mutex_unlock(&map_mutex) ;
|
|
|
|
|
|
|
|
//reschedule the current job. TODO: a call needs to be created to do this the OO way
|
2023-03-20 22:53:01 +00:00
|
|
|
if ( copy_and_write_freeze_job != NULL ) {
|
|
|
|
copy_and_write_freeze_job->next_tics = next_call_tics ;
|
2015-02-26 15:02:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return(0) ;
|
|
|
|
}
|