X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FScheduler.cci;h=acce9dbc9019075dd497c1d72db56f7667639389;hb=556aea04a82b3e2e5cdfe28a0abd3b275c7decf9;hp=cda14cab57738bdf2cc180890dff42df7b13bea8;hpb=85ab07d100a382467a42e19d741d403a7a96c951;p=senf.git diff --git a/Scheduler/Scheduler.cci b/Scheduler/Scheduler.cci index cda14ca..acce9db 100644 --- a/Scheduler/Scheduler.cci +++ b/Scheduler/Scheduler.cci @@ -1,9 +1,9 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -27,18 +27,78 @@ //#include "Scheduler.ih" // Custom includes +#include #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// -prefix_ void senf::Scheduler::terminate() +// public members + +prefix_ senf::ClockService::clock_type senf::scheduler::eventTime() +{ + return scheduler::detail::FdManager::instance().eventTime(); +} + +prefix_ void senf::scheduler::taskTimeout(unsigned ms) +{ + scheduler::detail::FIFORunner::instance().taskTimeout(ms); +} + +prefix_ unsigned senf::scheduler::taskTimeout() +{ + return scheduler::detail::FIFORunner::instance().taskTimeout(); +} + +prefix_ unsigned senf::scheduler::hangCount() +{ + return scheduler::detail::FIFORunner::instance().hangCount(); +} + +prefix_ void senf::scheduler::hiresTimers() +{ +#ifdef HAVE_TIMERFD + if (haveScalableHiresTimers()) + detail::TimerDispatcher::instance().timerSource( + std::auto_ptr(new detail::TimerFDTimerSource())); + else +#endif + detail::TimerDispatcher::instance().timerSource( + std::auto_ptr(new detail::POSIXTimerSource())); +} + +prefix_ void senf::scheduler::loresTimers() +{ + detail::TimerDispatcher::instance().timerSource( + std::auto_ptr(new detail::PollTimerSource())); +} + +prefix_ bool senf::scheduler::haveScalableHiresTimers() +{ +#ifndef HAVE_TIMERFD + return false; +#else + return true; +#endif +} + +prefix_ bool senf::scheduler::usingHiresTimers() +{ + return dynamic_cast( + detail::TimerDispatcher::instance().timerSource()) == 0; +} + +/////////////////////////////////////////////////////////////////////////// +// senf::scheduler::BlockSignals + +prefix_ senf::scheduler::BlockSignals::~BlockSignals() { - terminate_ = true; + unblock(); } -prefix_ int senf::retrieve_filehandle(int fd) +prefix_ bool senf::scheduler::BlockSignals::blocked() + const { - return fd; + return blocked_; } ///////////////////////////////cci.e/////////////////////////////////////// @@ -51,4 +111,6 @@ prefix_ int senf::retrieve_filehandle(int fd) // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: