X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FScheduler.cci;h=873b64f0ff8d17ca87a35d6348edc72edccead28;hb=b89e3166f7680755683dccee5e48cb3a820185c0;hp=0549c0331333c0da9e016b24d00495d2a57f6bb5;hpb=4a677397c9d7a849e3431e747a73e1bb25a8ce12;p=senf.git diff --git a/Scheduler/Scheduler.cci b/Scheduler/Scheduler.cci index 0549c03..873b64f 100644 --- a/Scheduler/Scheduler.cci +++ b/Scheduler/Scheduler.cci @@ -39,36 +39,64 @@ prefix_ senf::ClockService::clock_type senf::scheduler::eventTime() return scheduler::detail::FdManager::instance().eventTime(); } -prefix_ void senf::scheduler::taskTimeout(unsigned ms) +prefix_ void senf::scheduler::watchdogTimeout(unsigned ms) { scheduler::detail::FIFORunner::instance().taskTimeout(ms); } -prefix_ unsigned senf::scheduler::taskTimeout() +prefix_ unsigned senf::scheduler::watchdogTimeout() { return scheduler::detail::FIFORunner::instance().taskTimeout(); } -prefix_ unsigned senf::scheduler::hangCount() +prefix_ unsigned senf::scheduler::watchdogEvents() { return scheduler::detail::FIFORunner::instance().hangCount(); } -prefix_ void senf::scheduler::hiresTimers() +prefix_ void senf::scheduler::watchdogAbort(bool flag) { - detail::TimerDispatcher::instance().setTimerSource( - std::auto_ptr(new detail::POSIXTimerSource())); + scheduler::detail::FIFORunner::instance().abortOnTimeout(flag); +} + +prefix_ bool senf::scheduler::watchdogAbort() +{ + return scheduler::detail::FIFORunner::instance().abortOnTimeout(); } prefix_ void senf::scheduler::loresTimers() { - detail::TimerDispatcher::instance().setTimerSource( + detail::TimerDispatcher::instance().timerSource( std::auto_ptr(new detail::PollTimerSource())); } prefix_ bool senf::scheduler::haveScalableHiresTimers() { +#ifndef HAVE_TIMERFD return false; +#else + return detail::TimerFDTimerSource::haveTimerFD(); +#endif +} + +prefix_ bool senf::scheduler::usingHiresTimers() +{ + return dynamic_cast( + detail::TimerDispatcher::instance().timerSource()) == 0; +} + +/////////////////////////////////////////////////////////////////////////// +// senf::scheduler::BlockSignals + +prefix_ senf::scheduler::BlockSignals::~BlockSignals() +{ + unblock(); +} + +prefix_ bool senf::scheduler::BlockSignals::blocked() + const +{ + return blocked_; } ///////////////////////////////cci.e///////////////////////////////////////