2015-08-29 20:20:46 +02:00
|
|
|
####################################################################################################################################
|
|
|
|
# COMMON WAIT MODULE
|
|
|
|
####################################################################################################################################
|
|
|
|
package BackRest::Common::Wait;
|
|
|
|
|
|
|
|
use threads;
|
|
|
|
use strict;
|
|
|
|
use warnings FATAL => qw(all);
|
|
|
|
use Carp qw(confess);
|
|
|
|
|
|
|
|
use Exporter qw(import);
|
|
|
|
our @EXPORT = qw();
|
|
|
|
use File::Basename qw(dirname);
|
|
|
|
use POSIX qw(ceil);
|
|
|
|
use Time::HiRes qw(gettimeofday usleep);
|
|
|
|
|
|
|
|
use lib dirname($0) . '/../lib';
|
|
|
|
use BackRest::Common::Log;
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# waitRemainder
|
|
|
|
####################################################################################################################################
|
|
|
|
sub waitRemainder
|
|
|
|
{
|
2016-04-14 01:09:35 +02:00
|
|
|
my $bWait = shift;
|
|
|
|
|
2015-08-29 20:20:46 +02:00
|
|
|
my $lTimeBegin = gettimeofday();
|
|
|
|
|
2016-04-14 01:09:35 +02:00
|
|
|
if (!defined($bWait) || $bWait)
|
|
|
|
{
|
|
|
|
my $lSleepMs = ceil(((int($lTimeBegin) + 1.05) - $lTimeBegin) * 1000);
|
|
|
|
|
|
|
|
usleep($lSleepMs * 1000);
|
2015-08-29 20:20:46 +02:00
|
|
|
|
2016-04-14 01:09:35 +02:00
|
|
|
&log(TRACE, "WAIT_REMAINDER: slept ${lSleepMs}ms: begin ${lTimeBegin}, end " . gettimeofday());
|
|
|
|
}
|
2015-08-29 20:20:46 +02:00
|
|
|
|
|
|
|
return int($lTimeBegin);
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(waitRemainder);
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# waitHiRes
|
|
|
|
####################################################################################################################################
|
|
|
|
sub waitHiRes
|
|
|
|
{
|
|
|
|
my $fSecond = shift;
|
|
|
|
|
|
|
|
return usleep($fSecond * 1000000);
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(waitHiRes);
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# waitInit
|
|
|
|
####################################################################################################################################
|
|
|
|
sub waitInit
|
|
|
|
{
|
|
|
|
my $fWaitTime = shift;
|
|
|
|
my $fSleep = shift;
|
|
|
|
|
|
|
|
# Declare oWait hash
|
|
|
|
my $oWait = {};
|
|
|
|
|
|
|
|
# If wait seconds is not defined or 0 then return undef
|
|
|
|
if (!defined($fWaitTime) || $fWaitTime == 0)
|
|
|
|
{
|
2016-02-23 16:25:22 +02:00
|
|
|
return;
|
2015-08-29 20:20:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Wait seconds can be a minimum of .1
|
|
|
|
if ($fWaitTime < .1)
|
|
|
|
{
|
|
|
|
confess &log(ASSERT, 'fWaitTime cannot be < .1');
|
|
|
|
}
|
|
|
|
|
|
|
|
# If fSleep is not defined set it
|
|
|
|
if (!defined($fSleep))
|
|
|
|
{
|
|
|
|
if ($fWaitTime >= 1)
|
|
|
|
{
|
|
|
|
$$oWait{sleep} = .1;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$$oWait{sleep} = $fWaitTime / 10;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
# Else make sure it's not greater than fWaitTime
|
|
|
|
else
|
|
|
|
{
|
|
|
|
# Make sure fsleep is less than fWaitTime
|
|
|
|
if ($fSleep >= $fWaitTime)
|
|
|
|
{
|
|
|
|
confess &log(ASSERT, 'fSleep > fWaitTime - this is useless');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Set variables
|
|
|
|
$$oWait{wait_time} = $fWaitTime;
|
|
|
|
$$oWait{time_begin} = gettimeofday();
|
|
|
|
$$oWait{time_end} = $$oWait{time_begin};
|
|
|
|
|
|
|
|
return $oWait;
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(waitInit);
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# waitMore
|
|
|
|
####################################################################################################################################
|
|
|
|
sub waitMore
|
|
|
|
{
|
|
|
|
my $oWait = shift;
|
|
|
|
|
|
|
|
# Return if oWait is not defined
|
|
|
|
if (!defined($oWait))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Sleep for fSleep time
|
|
|
|
waitHiRes($$oWait{sleep});
|
|
|
|
|
|
|
|
# Capture the end time
|
|
|
|
$$oWait{time_end} = gettimeofday();
|
|
|
|
|
|
|
|
# Exit if wait time has expired
|
|
|
|
if ((gettimeofday() - $$oWait{time_begin}) < $$oWait{wait_time})
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Else calculate the new sleep time
|
|
|
|
my $fSleepNext = $$oWait{sleep} + (defined($$oWait{sleep_prev}) ? $$oWait{sleep_prev} : 0);
|
|
|
|
|
|
|
|
if ($fSleepNext > $$oWait{wait_time} - ($$oWait{time_end} - $$oWait{time_begin}))
|
|
|
|
{
|
|
|
|
$fSleepNext = ($$oWait{wait_time} - ($$oWait{time_end} - $$oWait{time_begin})) + .001
|
|
|
|
}
|
|
|
|
|
|
|
|
$$oWait{sleep_prev} = $$oWait{sleep};
|
|
|
|
$$oWait{sleep} = $fSleepNext;
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(waitMore);
|
|
|
|
|
|
|
|
####################################################################################################################################
|
|
|
|
# waitInterval
|
|
|
|
####################################################################################################################################
|
|
|
|
sub waitInterval
|
|
|
|
{
|
|
|
|
my $oWait = shift;
|
|
|
|
|
|
|
|
# Error if oWait is not defined
|
|
|
|
if (!defined($oWait))
|
|
|
|
{
|
|
|
|
confess &log(ERROR, "oWait is not defined");
|
|
|
|
}
|
|
|
|
|
|
|
|
return int(($$oWait{time_end} - $$oWait{time_begin}) * 1000) / 1000;
|
|
|
|
}
|
|
|
|
|
|
|
|
push @EXPORT, qw(waitInterval);
|
|
|
|
|
|
|
|
1;
|