//========================================================================== // // io/watchdog/emulate.cxx // // Watchdog implementation emulation // //========================================================================== // ####ECOSGPLCOPYRIGHTBEGIN#### // ------------------------------------------- // This file is part of eCos, the Embedded Configurable Operating System. // Copyright (C) 1998, 1999, 2000, 2001, 2002 Free Software Foundation, Inc. // // eCos 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 or (at your option) any later // version. // // eCos 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. // // You should have received a copy of the GNU General Public License // along with eCos; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // As a special exception, if other files instantiate templates or use // macros or inline functions from this file, or you compile this file // and link it with other works to produce a work based on this file, // this file does not by itself cause the resulting work to be covered by // the GNU General Public License. However the source code for this file // must still be made available in accordance with section (3) of the GNU // General Public License v2. // // This exception does not invalidate any other reasons why a work based // on this file might be covered by the GNU General Public License. // ------------------------------------------- // ####ECOSGPLCOPYRIGHTEND#### //========================================================================== //#####DESCRIPTIONBEGIN#### // // Author(s): nickg // Contributors: nickg // Date: 1998-07-29 // Purpose: Watchdog class implementation // Description: Contains an implementation of the Watchdog class for use // when there is no hardware watchdog timer. Instead it is // emulated using an Alarm object. // //####DESCRIPTIONEND#### // //========================================================================== #include // watchdog configuration file #include // Kernel config #include // base kernel types #include // tracing macros #include // assertion macros #include // instrumentation #include // clock and alarm #include // scheduler #include // watchdog API #include // scheduler inlines // ------------------------------------------------------------------------- // Forward definitions static cyg_alarm_fn watchdog_alarm; // ------------------------------------------------------------------------- // Statics static Cyg_Alarm alarm( Cyg_Clock::real_time_clock, watchdog_alarm, 0 ); // One second's worth of ticks. static cyg_tick_count one_sec; // ------------------------------------------------------------------------- // HW init void Cyg_Watchdog::init_hw(void) { CYG_REPORT_FUNCTION(); Cyg_Clock::cyg_resolution res = Cyg_Clock::real_time_clock->get_resolution(); one_sec = ( res.divisor * 1000000000LL ) / res.dividend ; resolution = 1000000000LL; CYG_REPORT_RETURN(); } // ------------------------------------------------------------------------- // Start the watchdog running. void Cyg_Watchdog::start() { CYG_REPORT_FUNCTION(); Cyg_Clock::cyg_resolution res = Cyg_Clock::real_time_clock->get_resolution(); // Set alarm to a one second single-shot trigger alarm.initialize( Cyg_Clock::real_time_clock->current_value() + one_sec, 0 ); CYG_REPORT_RETURN(); } // ------------------------------------------------------------------------- // Reset watchdog timer. This needs to be called regularly to prevent // the watchdog firing. void Cyg_Watchdog::reset() { CYG_REPORT_FUNCTION(); Cyg_Clock::cyg_resolution res = Cyg_Clock::real_time_clock->get_resolution(); Cyg_Scheduler::lock(); // Set alarm to a one second single-shot trigger alarm.initialize( Cyg_Clock::real_time_clock->current_value() + one_sec, 0 ); Cyg_Scheduler::unlock(); CYG_REPORT_RETURN(); } // ------------------------------------------------------------------------- // Alarm function void watchdog_alarm( Cyg_Alarm *a, CYG_ADDRWORD data) { CYG_REPORT_FUNCTION(); // Disable alarm just in case alarm.disable(); Cyg_Watchdog::watchdog.trigger(); } // ------------------------------------------------------------------------- // EOF watchdog/emulate.cxx