/******************************************************************************* **+--------------------------------------------------------------------------+** **| **** |** **| **** |** **| ******o*** |** **| ********_///_**** |** **| ***** /_//_/ **** |** **| ** ** (__/ **** |** **| ********* |** **| **** |** **| *** |** **| |** **| Copyright (c) 1998-2005 Texas Instruments Incorporated |** **| ALL RIGHTS RESERVED |** **| |** **+--------------------------------------------------------------------------+** *******************************************************************************/ /** \file pal_osWait_inline.h \brief OsWAIT Services Soource File This file defines OS abstraction services for programmed interval-waits. \author PSP Architecture Team \version 1.0 */ #ifndef __PAL_OSWAIT_INLINE_H__ #define __PAL_OSWAIT_INLINE_H__ #include "pal_os.h" #include "pal_defs.h" #include "pal_osCfg.h" #include #include /** * \defgroup PalOSWait PAL OS Wait Interface * * PAL OS Wait Interface * \{ */ /** \name PAL OS Wait Interface * \{ */ /** * \brief PAL_osWaitMsecs() * PAL_osWaitTicks */ PAL_INLINE PAL_Result PAL_osWaitMsecs(Uint32 mSecs) { Uint32 ticks = (HZ * mSecs)/1000; /* If the wait period is less than 1 tick then busyloop */ if(ticks) { set_current_state(TASK_INTERRUPTIBLE); schedule_timeout(ticks); } else { mdelay(mSecs); } return PAL_SOK; } /** * \brief PAL_osWaitTicks() */ PAL_INLINE PAL_Result PAL_osWaitTicks(Uint32 ticks) { set_current_state(TASK_INTERRUPTIBLE); schedule_timeout(ticks); return PAL_SOK; } /*\}*/ /*\}*/ #endif