Vxworks API操作系统和驱动程序设计API。压缩的HTML文件

源代码在线查看: wdlib.html

软件大小: 1083 K
上传用户: yangjiuhe
关键词: API Vxworks HTML 操作系统
下载地址: 免注册下载 普通下载 VIP

相关代码

																  wdLib 								 																VxWorks API Reference :  OS Libraries								wdLib NAME  				wdLib - watchdog timer library 												ROUTINES								wdCreate( )  -  create a watchdog timer				wdDelete( )  -  delete a watchdog timer				wdStart( )  -  start a watchdog timer				wdCancel( )  -  cancel a currently counting watchdog								DESCRIPTION				This library provides a general watchdog timer facility.  Any task may				create a watchdog timer and use it to run a specified routine in				the context of the system-clock ISR, after a specified delay.								Once a timer has been created with wdCreate( ), it can be started with				wdStart( ).  The wdStart( ) routine specifies what routine to run, a				parameter for that routine, and the amount of time (in ticks) before				the routine is to be called.  (The timeout value is in ticks as				determined by the system clock; see sysClkRateSet( ) for more				information.)  After the specified delay ticks have elapsed (unless				wdCancel( ) is called first to cancel the timer) the timeout routine is				invoked with the parameter specified in the wdStart( ) call.  The				timeout routine is invoked whether the task which started the watchdog				is running, suspended, or deleted.								The timeout routine executes only once per wdStart( ) invocation; there				is no need to cancel a timer with wdCancel( ) after it has expired, or				in the expiration callback itself.								Note that the timeout routine is invoked at interrupt level, rather than				in the context of the task.  Thus, there are restrictions on what the				routine may do.  Watchdog routines are constrained to the same rules				as interrupt service routines.  For example, they may not take semaphores,				issue other calls that may block, or use I/O system routines like printf( ).								EXAMPLE				In the fragment below, if maybeSlowRoutine( ) takes more than 60 ticks,				logMsg( ) will be called with the string as a parameter, causing the message to				be printed on the console.  Normally, of course, more significant corrective				action would be taken.				    WDOG_ID wid = wdCreate ();				    wdStart (wid, 60, logMsg, "Help, I've timed out!");				    maybeSlowRoutine ();        /* user-supplied routine */				    wdCancel (wid);												INCLUDE FILES				wdLib.h								SEE ALSO				logLib,				VxWorks Programmer's Guide: Basic OS 																				OS Libraries :  Routines								wdCreate( ) NAME  				wdCreate( ) - create a watchdog timer								SYNOPSIS				WDOG_ID wdCreate (void)								DESCRIPTION				This routine creates a watchdog timer by allocating a WDOG structure in				memory.								RETURNS				The ID for the watchdog created, or NULL if memory is insufficient.								SEE ALSO				wdLib, wdDelete( )																				OS Libraries :  Routines								wdDelete( ) NAME  				wdDelete( ) - delete a watchdog timer								SYNOPSIS				STATUS wdDelete				    (				    WDOG_ID wdId              /* ID of watchdog to delete */				    )												DESCRIPTION				This routine de-allocates a watchdog timer.  The watchdog will be removed				from the timer queue if it has been started.  This routine complements				wdCreate( ).								RETURNS				OK, or ERROR if the watchdog timer cannot be de-allocated.								SEE ALSO				wdLib, wdCreate( )																				OS Libraries :  Routines								wdStart( ) NAME  				wdStart( ) - start a watchdog timer								SYNOPSIS				STATUS wdStart				    (				    WDOG_ID wdId,             /* watchdog ID */				    int     delay,            /* delay count, in ticks */				    FUNCPTR pRoutine,         /* routine to call on time-out */				    int     parameter         /* parameter with which to call routine */				    )												DESCRIPTION				This routine adds a watchdog timer to the system tick queue.  The				specified watchdog routine will be called from interrupt level after				the specified number of ticks has elapsed.  Watchdog timers may be				started from interrupt level.  								To replace either the timeout delay or the routine to be executed,				call wdStart( ) again with the same wdId; only the most recent				wdStart( ) on a given watchdog ID has any effect.  (If your				application requires multiple watchdog routines, use wdCreate( ) to				generate separate a watchdog ID for each.)  To cancel a watchdog				timer before the specified tick count is reached, call wdCancel( ).								Watchdog timers execute only once, but some applications require				periodically executing timers.  To achieve this effect, the timer				routine itself must call wdStart( ) to restart the timer on each				invocation.								WARNING				The watchdog routine runs in the context of the				system-clock ISR; thus, it is subject to all ISR restrictions.								RETURNS				OK, or ERROR if the watchdog timer cannot be started.								SEE ALSO				wdLib, wdCancel( )																				OS Libraries :  Routines								wdCancel( ) NAME  				wdCancel( ) - cancel a currently counting watchdog								SYNOPSIS				STATUS wdCancel				    (				    WDOG_ID wdId              /* ID of watchdog to cancel */				    )												DESCRIPTION				This routine cancels a currently running watchdog timer by				zeroing its delay count.  Watchdog timers may be canceled from interrupt				level.								RETURNS				OK, or ERROR if the watchdog timer cannot be canceled.								SEE ALSO				wdLib, wdStart( )																															

相关资源