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

📄 timerserverfireafter.c

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 C
字号:
/* *  Timer Manager - rtems_timer_server fire_after directive * * *  COPYRIGHT (c) 1989-2002. *  On-Line Applications Research Corporation (OAR). * *  The license and distribution terms for this file may be *  found in the file LICENSE in this distribution or at *  http://www.rtems.com/license/LICENSE. * *  $Id: timerserverfireafter.c,v 1.3.2.4 2005/08/18 13:39:00 joel Exp $ */#include <rtems/system.h>#include <rtems/rtems/status.h>#include <rtems/rtems/support.h>#include <rtems/score/object.h>#include <rtems/score/thread.h>#include <rtems/rtems/timer.h>#include <rtems/score/tod.h>#include <rtems/score/watchdog.h>/*PAGE * *  rtems_timer_server_fire_after * *  This directive allows a thread to start a timer which will by  *  executed by the Timer Server when it fires. * *  Input parameters: *    id        - timer id *    ticks     - interval until routine is fired *    routine   - routine to schedule *    user_data - passed as argument to routine when it is fired * *  Output parameters: *    RTEMS_SUCCESSFUL - if successful *    error code       - if unsuccessful */rtems_status_code rtems_timer_server_fire_after(  Objects_Id                         id,  rtems_interval                     ticks,  rtems_timer_service_routine_entry  routine,  void                              *user_data){  Timer_Control        *the_timer;  Objects_Locations     location;  ISR_Level             level;  extern Chain_Control  _Timer_Ticks_chain;  if ( !_Timer_Server )    return RTEMS_INCORRECT_STATE;  if ( !routine )    return RTEMS_INVALID_ADDRESS;  if ( ticks == 0 )    return RTEMS_INVALID_NUMBER;  the_timer = _Timer_Get( id, &location );  switch ( location ) {    case OBJECTS_REMOTE:            /* should never return this */      return RTEMS_INTERNAL_ERROR;    case OBJECTS_ERROR:      return RTEMS_INVALID_ID;    case OBJECTS_LOCAL:      (void) _Watchdog_Remove( &the_timer->Ticker );      _ISR_Disable( level );        /*         *  Check to see if the watchdog has just been inserted by a         *  higher priority interrupt.  If so, abandon this insert.         */        if ( the_timer->Ticker.state != WATCHDOG_INACTIVE ) {          _ISR_Enable( level );          _Thread_Enable_dispatch();          return RTEMS_SUCCESSFUL;        }        /*         *  OK.  Now we now the timer was not rescheduled by an interrupt         *  so we can atomically initialize it as in use.         */        the_timer->the_class = TIMER_INTERVAL_ON_TASK;        _Watchdog_Initialize( &the_timer->Ticker, routine, id, user_data );        the_timer->Ticker.initial = ticks;      _ISR_Enable( level );      _Timer_Server_stop_ticks_timer();      _Timer_Server_process_ticks_chain();      _Watchdog_Insert( &_Timer_Ticks_chain, &the_timer->Ticker );       _Timer_Server_reset_ticks_timer();      _Thread_Enable_dispatch();      return RTEMS_SUCCESSFUL;  }  return RTEMS_INTERNAL_ERROR;   /* unreached - only to remove warnings */}

⌨️ 快捷键说明

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