X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FScheduler%2FTimerSource.cc;h=98f8f7cee47d2bf6a7e35e67e308168c2c4edca0;hb=refs%2Fheads%2Fmaster;hp=c03002f285fabbd52b416761e5c65ed869f32646;hpb=7661548b20e6c7627f54bff87e0758396fd523ef;p=senf.git diff --git a/senf/Scheduler/TimerSource.cc b/senf/Scheduler/TimerSource.cc index c03002f..98f8f7c 100644 --- a/senf/Scheduler/TimerSource.cc +++ b/senf/Scheduler/TimerSource.cc @@ -2,23 +2,28 @@ // // Copyright (C) 2009 // 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 -// the Free Software Foundation; either version 2 of the License, or -// (at your option) any later version. +// The contents of this file are subject to the Fraunhofer FOKUS Public License +// Version 1.0 (the "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// http://senf.berlios.de/license.html // -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. +// The Fraunhofer FOKUS Public License Version 1.0 is based on, +// but modifies the Mozilla Public License Version 1.1. +// See the full license text for the amendments. // -// You should have received a copy of the GNU General Public License -// along with this program; if not, write to the -// Free Software Foundation, Inc., -// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// Software distributed under the License is distributed on an "AS IS" basis, +// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +// for the specific language governing rights and limitations under the License. +// +// The Original Code is Fraunhofer FOKUS code. +// +// The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. +// (registered association), Hansastraße 27 c, 80686 Munich, Germany. +// All Rights Reserved. +// +// Contributor(s): +// Stefan Bund /** \file \brief TimerSource non-inline non-template implementation */ @@ -51,8 +56,7 @@ prefix_ senf::scheduler::detail::POSIXTimerSource::POSIXTimerSource() { if (pipe(timerPipe_) < 0) SENF_THROW_SYSTEM_EXCEPTION("pipe()"); - senf::scheduler::detail::FdManager::instance().set( - timerPipe_[0], detail::FdManager::EV_READ, this); + FdManager::instance().set( timerPipe_[0], FdManager::EV_READ, this); sigemptyset(&sigSet_); sigaddset(&sigSet_, SIGALRM); @@ -79,7 +83,7 @@ prefix_ senf::scheduler::detail::POSIXTimerSource::~POSIXTimerSource() timer_delete(timerId_); ::signal(SIGALRM, SIG_IGN); sigprocmask(SIG_UNBLOCK, &sigSet_, 0); - senf::scheduler::detail::FdManager::instance().remove(timerPipe_[0]); + FdManager::instance().remove(timerPipe_[0]); close(timerPipe_[0]); close(timerPipe_[1]); } @@ -89,8 +93,8 @@ senf::scheduler::detail::POSIXTimerSource::timeout(ClockService::clock_type time { if (! timeoutEnabled_ || timeout_ != timeout) { timeout_ = timeout; - if (timeout_ <= 0) - timeout_ = 1; + if (timeout_ <= ClockService::clock_type(0)) + timeout_ = ClockService::clock_type(1); timeoutEnabled_ = true; reschedule(); } @@ -180,18 +184,17 @@ prefix_ void senf::scheduler::detail::PollTimerSource::disable() #ifdef HAVE_TIMERFD_CREATE prefix_ senf::scheduler::detail::TimerFDTimerSource::TimerFDTimerSource() - : timerfd_ (-1), timeoutEnabled_ (false), timeout_ (0) + : timerfd_ (-1), timeoutEnabled_ (false), timeout_(0) { timerfd_ = timerfd_create(CLOCK_MONOTONIC, 0); if (timerfd_ < 0) SENF_THROW_SYSTEM_EXCEPTION("timerfd_create()"); - senf::scheduler::detail::FdManager::instance().set( - timerfd_, detail::FdManager::EV_READ, this); + FdManager::instance().set( timerfd_, FdManager::EV_READ, this); } prefix_ senf::scheduler::detail::TimerFDTimerSource::~TimerFDTimerSource() { - senf::scheduler::detail::FdManager::instance().remove(timerfd_); + FdManager::instance().remove(timerfd_); close(timerfd_); } @@ -200,8 +203,8 @@ senf::scheduler::detail::TimerFDTimerSource::timeout(ClockService::clock_type ti { if (!timeoutEnabled_ || timeout_ != timeout) { timeout_ = timeout; - if (timeout_ <= 0) - timeout_ = 1; + if (timeout_ <= ClockService::clock_type(0)) + timeout_ = ClockService::clock_type(1); timeoutEnabled_ = true; reschedule(); }