⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 watchdog.cxx

📁 Intel XScale PXA255 引导Linux的Redboot 版bootloader源代码!
💻 CXX
字号:
//==========================================================================////        watchdog.cxx////        Watchdog test////==========================================================================//####COPYRIGHTBEGIN####//                                                                          // -------------------------------------------                              // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (the "License"); you may not use this file except in         // compliance with the License.  You may obtain a copy of the License at    // http://www.redhat.com/                                                   //                                                                          // 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 eCos - Embedded Configurable Operating System,      // released September 30, 1998.                                             //                                                                          // The Initial Developer of the Original Code is Red Hat.                   // Portions created by Red Hat are                                          // Copyright (C) 1998, 1999, 2000 Red Hat, Inc.                             // All Rights Reserved.                                                     // -------------------------------------------                              //                                                                          //####COPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):     nickg// Contributors:    nickg// Date:          1998-07-20// Description:   This test exercises the Watchdog class and checks that it//                works as advertised.//####DESCRIPTIONEND####// -------------------------------------------------------------------------#include <pkgconf/kernel.h>#include <cyg/kernel/thread.hxx>#include <cyg/kernel/thread.inl>#include <cyg/kernel/sched.hxx>#include <cyg/kernel/mutex.hxx>#include <cyg/kernel/sema.hxx>#include <cyg/kernel/clock.hxx>#include <cyg/kernel/diag.h>#include <cyg/io/watchdog.hxx>#include <cyg/infra/testcase.h>#include <cyg/infra/diag.h>#if defined(CYGFUN_KERNEL_THREADS_TIMER) && \    defined(CYGVAR_KERNEL_COUNTERS_CLOCK)#include <cyg/kernel/sched.inl>// -------------------------------------------------------------------------// Data for the test#ifdef CYGNUM_HAL_STACK_SIZE_TYPICAL#define STACKSIZE CYGNUM_HAL_STACK_SIZE_TYPICAL#else#define STACKSIZE       (2*1024)        // size of thread stack#endifchar thread_stack[STACKSIZE];inline void *operator new(size_t size, void *ptr) { return ptr; };// array of threads.char thread[sizeof(Cyg_Thread)];Cyg_Thread *th;//cyg_tick_count one_sec;cyg_tick_count watchdog_delay;volatile bool watchdog_fired;volatile cyg_tick_count watchdog_time;#define WATCHDOG_LOOPS_HW               5#define WATCHDOG_LOOPS_SIM              1#define WATCHDOG_CYCLES_PER_LOOP_HW     10#define WATCHDOG_CYCLES_PER_LOOP_SIM    2#define WATCHDOG_TICKS_TILL_TIMEOUT     10// -------------------------------------------------------------------------// Action functions:void watchdog_action1( CYG_ADDRWORD data ){    watchdog_fired = true;    watchdog_time = Cyg_Clock::real_time_clock->current_value();}void watchdog_action2( CYG_ADDRWORD data ){    CYG_TEST_PASS_FINISH("Watchdog OK");    }// -------------------------------------------------------------------------// Thread bodyvoid watchdog_thread( CYG_ADDRWORD id ){    cyg_tick_count watchdog_start_time;    cyg_tick_count thread_start_time, thread_end_time;    cyg_ucount8 watchdog_loops, watchdog_cycles_per_loop;    if (cyg_test_is_simulator) {        watchdog_loops = WATCHDOG_LOOPS_SIM;        watchdog_cycles_per_loop = WATCHDOG_CYCLES_PER_LOOP_SIM;    } else {        watchdog_loops = WATCHDOG_LOOPS_HW;        watchdog_cycles_per_loop = WATCHDOG_CYCLES_PER_LOOP_HW;    }    watchdog_fired = false;    Cyg_Watchdog::watchdog.start();    CYG_TEST_INFO("Testing that watchdog does not fire early");    for (cyg_ucount8 tries = 0;  tries < watchdog_loops;  tries++) {        diag_printf("Iteration #%d (testing over %d cycles)\n",                    tries, watchdog_cycles_per_loop);        // First test that the watchdog does not trigger when being reset.        Cyg_Watchdog_Action wdaction( watchdog_action1, 0 );        wdaction.install();        Cyg_Watchdog::watchdog.reset();        watchdog_start_time = Cyg_Clock::real_time_clock->current_value();        watchdog_fired = false;                for( cyg_ucount8 i = 0; i < watchdog_cycles_per_loop; i++ ) {            thread_start_time = Cyg_Clock::real_time_clock->current_value();            th->delay( watchdog_delay-2 );            Cyg_Watchdog::watchdog.reset();            if (watchdog_fired) {                thread_end_time = Cyg_Clock::real_time_clock->current_value();                diag_printf("Watchdog fired prematurely after %d ticks\n",                             (int)(watchdog_time - watchdog_start_time));                diag_printf("  Thread slept for %d ticks, loop #%d\n",                             (int)(thread_end_time - thread_start_time), i);                CYG_TEST_FAIL_FINISH("Watchdog triggered unexpectedly");                break;            } else {                CYG_TEST_STILL_ALIVE(i, "Resetting watchdog...");                Cyg_Watchdog::watchdog.reset();                watchdog_fired = false;                watchdog_start_time = Cyg_Clock::real_time_clock->current_value();            }        }    }    // Now check that it triggers when not reset    CYG_TEST_INFO("Testing that watchdog fires");    {        Cyg_Watchdog_Action wdaction( watchdog_action2, 0 );        wdaction.install();                Cyg_Watchdog::watchdog.reset();                th->delay( watchdog_delay*WATCHDOG_TICKS_TILL_TIMEOUT );            }    CYG_TEST_FAIL_FINISH("Watchdog failed to trigger");    }// -------------------------------------------------------------------------    externC voidcyg_start( void ){    CYG_TEST_INIT();#if !defined(CYGIMP_WATCHDOG_EMULATE) && defined(CYGPKG_HAL_MN10300_STDEVAL1)    // Workaround for PR 17974    if( cyg_test_is_simulator )        CYG_TEST_NA("Watchdog device not implemented in MN10300 simulator.");#endif    Cyg_Clock::cyg_resolution res = Cyg_Clock::real_time_clock->get_resolution();        cyg_uint64 wres = Cyg_Watchdog::watchdog.get_resolution();    // Calculate how many clock ticks there are in a watchdog cycle.        watchdog_delay = ((cyg_tick_count)wres * (cyg_tick_count)res.divisor );    watchdog_delay /= res.dividend;        th = new((void *)&thread) Cyg_Thread(CYG_SCHED_DEFAULT_INFO,                                         watchdog_thread,                                         0,                                         "watchdog_thread",                                         (CYG_ADDRESS)thread_stack,                                         STACKSIZE        );    th->resume();    // Get the world going    Cyg_Scheduler::scheduler.start();}#else // if defined(CYGFUN_KERNEL_THREADS_TIMER) etc...externC voidcyg_start( void ){    CYG_TEST_INIT();    CYG_TEST_NA("Kernel real-time clock/threads timer disabled");}#endif // if defined(CYGFUN_KERNEL_THREADS_TIMER) etc...// -------------------------------------------------------------------------// EOF watchdog.cxx

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -