亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? task.h

?? IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR IAR
?? H
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):

         // At some point the task wants to perform a long operation during
         // which it does not want to get swapped out.  It cannot use
         // taskENTER_CRITICAL ()/taskEXIT_CRITICAL () as the length of the
         // operation may cause interrupts to be missed - including the
         // ticks.

         // Prevent the real time kernel swapping out the task.
         vTaskSuspendAll ();

         // Perform the operation here.  There is no need to use critical
         // sections as we have all the microcontroller processing time.
         // During this time interrupts will still operate and the kernel
         // tick count will be maintained.

         // ...

         // The operation is complete.  Restart the kernel.
         xTaskResumeAll ();
     }
 }
   </pre>
 * \defgroup vTaskSuspendAll vTaskSuspendAll
 * \ingroup SchedulerControl
 */
void vTaskSuspendAll( void );
/******************************************************************************/
/**
 * task. h
 * <pre>portCHAR xTaskResumeAll( void );</pre>
 *
 * Resumes real time kernel activity following a call to vTaskSuspendAll ().
 * After a call to vTaskSuspendAll () the kernel will take control of which
 * task is executing at any time.
 *
 * @return If resuming the scheduler caused a context switch then pdTRUE is
 *         returned, otherwise pdFALSE is returned.
 *
 * Example usage:
   <pre>
 void vTask1( void * pvParameters )
 {
     for( ;; )
     {
         // Task code goes here.

         // ...

         // At some point the task wants to perform a long operation during
         // which it does not want to get swapped out.  It cannot use
         // taskENTER_CRITICAL ()/taskEXIT_CRITICAL () as the length of the
         // operation may cause interrupts to be missed - including the
         // ticks.

         // Prevent the real time kernel swapping out the task.
         vTaskSuspendAll ();

         // Perform the operation here.  There is no need to use critical
         // sections as we have all the microcontroller processing time.
         // During this time interrupts will still operate and the real
         // time kernel tick count will be maintained.

         // ...

         // The operation is complete.  Restart the kernel.  We want to force
         // a context switch - but there is no point if resuming the scheduler
         // caused a context switch already.
         if( !xTaskResumeAll () )
         {
              taskYIELD ();
         }
     }
 }
   </pre>
 * \defgroup xTaskResumeAll xTaskResumeAll
 * \ingroup SchedulerControl
 */
signed portBASE_TYPE xTaskResumeAll( void );
/******************************************************************************/
/**
 * task. h
 * <pre>signed portBASE_TYPE xTaskIsTaskSuspended( xTaskHandle xTask );</pre>
 *
 * Utility task that simply returns pdTRUE if the task referenced by xTask is
 * currently in the Suspended state, or pdFALSE if the task referenced by xTask
 * is in any other state.
 *
 */
signed portBASE_TYPE xTaskIsTaskSuspended( xTaskHandle xTask );
/******************************************************************************/
/*-----------------------------------------------------------
 * TASK UTILITIES
 *----------------------------------------------------------*/

/**
 * task. h
 * <PRE>volatile portTickType xTaskGetTickCount( void );</PRE>
 *
 * @return The count of ticks since vTaskStartScheduler was called.
 *
 * \page xTaskGetTickCount xTaskGetTickCount
 * \ingroup TaskUtils
 */
portTickType xTaskGetTickCount( void );
/******************************************************************************/
/**
 * task. h
 * <PRE>unsigned portSHORT uxTaskGetNumberOfTasks( void );</PRE>
 *
 * @return The number of tasks that the real time kernel is currently managing.
 * This includes all ready, blocked and suspended tasks.  A task that
 * has been deleted but not yet freed by the idle task will also be
 * included in the count.
 *
 * \page uxTaskGetNumberOfTasks uxTaskGetNumberOfTasks
 * \ingroup TaskUtils
 */
unsigned portBASE_TYPE uxTaskGetNumberOfTasks( void );
/******************************************************************************/
/**
 * task. h
 * <PRE>void vTaskList( portCHAR *pcWriteBuffer );</PRE>
 *
 * configUSE_TRACE_FACILITY, INCLUDE_vTaskDelete and INCLUDE_vTaskSuspend
 * must all be defined as 1 for this function to be available.
 * See the configuration section for more information.
 *
 * NOTE: This function will disable interrupts for its duration.  It is
 * not intended for normal application runtime use but as a debug aid.
 *
 * Lists all the current tasks, along with their current state and stack
 * usage high water mark.
 *
 * Tasks are reported as blocked ('B'), ready ('R'), deleted ('D') or
 * suspended ('S').
 *
 * @param pcWriteBuffer A buffer into which the above mentioned details
 * will be written, in ascii form.  This buffer is assumed to be large
 * enough to contain the generated report.  Approximately 40 bytes per
 * task should be sufficient.
 *
 * \page vTaskList vTaskList
 * \ingroup TaskUtils
 */
void vTaskList( signed portCHAR *pcWriteBuffer );
/******************************************************************************/
/**
 * task. h
 * <PRE>void vTaskStartTrace( portCHAR * pcBuffer, unsigned portBASE_TYPE uxBufferSize );</PRE>
 *
 * Starts a real time kernel activity trace.  The trace logs the identity of
 * which task is running when.
 *
 * The trace file is stored in binary format.  A separate DOS utility called
 * convtrce.exe is used to convert this into a tab delimited text file which
 * can be viewed and plotted in a spread sheet.
 *
 * @param pcBuffer The buffer into which the trace will be written.
 *
 * @param ulBufferSize The size of pcBuffer in bytes.  The trace will continue
 * until either the buffer in full, or ulTaskEndTrace () is called.
 *
 * \page vTaskStartTrace vTaskStartTrace
 * \ingroup TaskUtils
 */
void vTaskStartTrace( signed portCHAR * pcBuffer, unsigned portLONG ulBufferSize );
/******************************************************************************/
/**
 * task. h
 * <PRE>unsigned portLONG ulTaskEndTrace( void );</PRE>
 *
 * Stops a kernel activity trace.  See vTaskStartTrace ().
 *
 * @return The number of bytes that have been written into the trace buffer.
 *
 * \page usTaskEndTrace usTaskEndTrace
 * \ingroup TaskUtils
 */
unsigned portLONG ulTaskEndTrace( void );
/******************************************************************************/
/**
 * task.h
 * <PRE>unsigned portBASE_TYPE uxTaskGetStackHighWaterMark( xTaskHandle xTask );</PRE>
 *
 * INCLUDE_uxTaskGetStackHighWaterMark must be set to 1 in FreeRTOSConfig.h for
 * this function to be available.
 *
 * Returns the high water mark of the stack associated with xTask.  That is,
 * the minimum free stack space there has been (in bytes) since the task
 * started.  The smaller the returned number the closer the task has come
 * to overflowing its stack.
 *
 * @param xTask Handle of the task associated with the stack to be checked.
 * Set xTask to NULL to check the stack of the calling task.
 *
 * @return The smallest amount of free stack space there has been (in bytes)
 * since the task referenced by xTask was created.
 */
unsigned portBASE_TYPE uxTaskGetStackHighWaterMark( xTaskHandle xTask );
/******************************************************************************/
/**
 * task.h
 * <pre>void vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction );</pre>
 *
 * Sets pxHookFunction to be the task hook function used by the task xTask.
 * Passing xTask as NULL has the effect of setting the calling tasks hook
 * function.
 */
void vTaskSetApplicationTaskTag( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction );
/******************************************************************************/
/**
 * task.h
 * <pre>portBASE_TYPE xTaskCallApplicationTaskHook( xTaskHandle xTask, pdTASK_HOOK_CODE pxHookFunction );</pre>
 *
 * Calls the hook function associated with xTask.  Passing xTask as NULL has
 * the effect of calling the Running tasks (the calling task) hook function.
 *
 * pvParameter is passed to the hook function for the task to interpret as it
 * wants.
 */
portBASE_TYPE xTaskCallApplicationTaskHook( xTaskHandle xTask, void *pvParameter );
/******************************************************************************/

/*-----------------------------------------------------------
 * SCHEDULER INTERNALS AVAILABLE FOR PORTING PURPOSES
 *----------------------------------------------------------*/

/*
 * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS ONLY
 * INTENDED FOR USE WHEN IMPLEMENTING A PORT OF THE SCHEDULER AND IS
 * AN INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.
 *
 * Called from the real time kernel tick (either preemptive or cooperative),
 * this increments the tick count and checks if any tasks that are blocked
 * for a finite period required removing from a blocked list and placing on
 * a ready list.
 */
void vTaskIncrementTick( void );
/******************************************************************************/
/*
 * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN
 * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.
 *
 * THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED.
 *
 * Removes the calling task from the ready list and places it both
 * on the list of tasks waiting for a particular event, and the
 * list of delayed tasks.  The task will be removed from both lists
 * and replaced on the ready list should either the event occur (and
 * there be no higher priority tasks waiting on the same event) or
 * the delay period expires.
 *
 * @param pxEventList The list containing tasks that are blocked waiting
 * for the event to occur.
 *
 * @param xTicksToWait The maximum amount of time that the task should wait
 * for the event to occur.  This is specified in kernel ticks,the constant
 * portTICK_RATE_MS can be used to convert kernel ticks into a real time
 * period.
 */
void vTaskPlaceOnEventList( const xList * const pxEventList, portTickType xTicksToWait );
/******************************************************************************/
/*
 * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN
 * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.
 *
 * THIS FUNCTION MUST BE CALLED WITH INTERRUPTS DISABLED.
 *
 * Removes a task from both the specified event list and the list of blocked
 * tasks, and places it on a ready queue.
 *
 * xTaskRemoveFromEventList () will be called if either an event occurs to
 * unblock a task, or the block timeout period expires.
 *
 * @return pdTRUE if the task being removed has a higher priority than the task
 * making the call, otherwise pdFALSE.
 */
signed portBASE_TYPE xTaskRemoveFromEventList( const xList * const pxEventList );
/******************************************************************************/
/*
 * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS AN
 * INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.
 *
 * INCLUDE_vTaskCleanUpResources and INCLUDE_vTaskSuspend must be defined as 1
 * for this function to be available.
 * See the configuration section for more information.
 *
 * Empties the ready and delayed queues of task control blocks, freeing the
 * memory allocated for the task control block and task stacks as it goes.
 */
void vTaskCleanUpResources( void );
/******************************************************************************/
/*
 * THIS FUNCTION MUST NOT BE USED FROM APPLICATION CODE.  IT IS ONLY
 * INTENDED FOR USE WHEN IMPLEMENTING A PORT OF THE SCHEDULER AND IS
 * AN INTERFACE WHICH IS FOR THE EXCLUSIVE USE OF THE SCHEDULER.
 *
 * Sets the pointer to the current TCB to the TCB of the highest priority task
 * that is ready to run.
 */
void vTaskSwitchContext( void );
/******************************************************************************/
/*
 * Return the handle of the calling task.
 */
xTaskHandle xTaskGetCurrentTaskHandle( void );
/******************************************************************************/
/*
 * Capture the current time status for future reference.
 */
void vTaskSetTimeOutState( xTimeOutType * const pxTimeOut );
/******************************************************************************/
/*
 * Compare the time status now with that previously captured to see if the
 * timeout has expired.
 */
portBASE_TYPE xTaskCheckForTimeOut( xTimeOutType * const pxTimeOut, portTickType * const pxTicksToWait );
/******************************************************************************/
/*
 * Shortcut used by the queue implementation to prevent unnecessary call to
 * taskYIELD();
 */
void vTaskMissedYield( void );
/******************************************************************************/
/*
 * Returns the scheduler state as taskSCHEDULER_RUNNING,
 * taskSCHEDULER_NOT_STARTED or taskSCHEDULER_SUSPENDED.
 */
portBASE_TYPE xTaskGetSchedulerState( void );
/******************************************************************************/
/*
 * Raises the priority of the mutex holder to that of the calling task should
 * the mutex holder have a priority less than the calling task.
 */
void vTaskPriorityInherit( xTaskHandle * const pxMutexHolder );
/******************************************************************************/
/*
 * Set the priority of a task back to its proper priority in the case that it
 * inherited a higher priority while it was holding a semaphore.
 */
void vTaskPriorityDisinherit( xTaskHandle * const pxMutexHolder );
/******************************************************************************/
#ifdef __cplusplus
}
#endif
#endif /* TASK_H */



?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产suv精品一区二区6| 91麻豆高清视频| 一区二区视频在线| 日韩欧美一级片| 色综合欧美在线| 国产一区美女在线| 日日摸夜夜添夜夜添精品视频 | 在线看国产一区| 国产一区二区三区免费播放| 一片黄亚洲嫩模| 国产精品视频一二三| 欧美成人精品二区三区99精品| av爱爱亚洲一区| 国产乱码精品1区2区3区| 午夜电影网亚洲视频| 中文字幕亚洲不卡| 亚洲国产精华液网站w| 精品国产一二三区| 日韩欧美不卡一区| 欧美日韩高清一区二区不卡| jvid福利写真一区二区三区| 国产精品综合一区二区| 秋霞午夜av一区二区三区| 亚洲午夜免费电影| 一区二区三区成人| 亚洲男同1069视频| 亚洲人xxxx| 亚洲六月丁香色婷婷综合久久| 久久久久久一二三区| 欧美日韩国产大片| 欧美亚洲国产怡红院影院| 91蜜桃在线免费视频| 不卡av免费在线观看| 成人免费黄色大片| 成人动漫一区二区| 丁香婷婷综合色啪| 成人精品在线视频观看| 国产99久久久国产精品潘金| 国产麻豆精品在线| 国产乱理伦片在线观看夜一区 | 国产a精品视频| 国产精品资源网| 国产成人久久精品77777最新版本| 久久精品国产99| 狠狠色丁香久久婷婷综合丁香| 日本系列欧美系列| 精品一区二区三区影院在线午夜| 日本不卡一二三区黄网| 免费观看一级特黄欧美大片| 男人的j进女人的j一区| 韩国欧美一区二区| 高清久久久久久| 一本一道久久a久久精品| 91蝌蚪porny| 精品污污网站免费看| 欧美精品高清视频| 久久毛片高清国产| 国产精品美女久久久久av爽李琼 | 国产精品九色蝌蚪自拍| 亚洲欧美一区二区三区国产精品| 夜夜嗨av一区二区三区| 日韩av一二三| 国产盗摄一区二区三区| 91网站视频在线观看| 欧美日韩国产bt| 精品久久久网站| 亚洲日本在线视频观看| 午夜精品视频一区| 国产成人精品影视| 欧美亚洲愉拍一区二区| 日韩欧美不卡在线观看视频| 国产精品久久久久久久久免费樱桃| 亚洲人一二三区| 麻豆成人91精品二区三区| 国产成人8x视频一区二区 | 这里只有精品电影| 久久蜜桃香蕉精品一区二区三区| 亚洲同性gay激情无套| 亚洲成在线观看| 国产在线精品免费| 欧美在线不卡视频| 久久久精品免费免费| 一区二区三区高清| 国产经典欧美精品| 69堂精品视频| 国产精品久久久久一区二区三区 | 在线免费亚洲电影| 精品国产乱码久久久久久夜甘婷婷| 国产精品久久久久久久午夜片| 亚洲成人精品在线观看| 国产91丝袜在线18| 欧美特级限制片免费在线观看| 久久综合精品国产一区二区三区| 亚洲激情校园春色| 国产精品一区一区| 日韩一区二区在线播放| 亚洲精品成人a在线观看| 国产成人av自拍| 日韩一区二区高清| 一区二区三区产品免费精品久久75| 蜜桃视频一区二区| 欧美日韩日日夜夜| 亚洲乱码精品一二三四区日韩在线| 欧美在线观看一区| 中文字幕第一区第二区| 另类综合日韩欧美亚洲| 欧美午夜精品电影| 亚洲美腿欧美偷拍| 国产成人av影院| 久久丝袜美腿综合| 美腿丝袜在线亚洲一区 | 欧美va在线播放| 亚洲第四色夜色| 91免费版在线| **欧美大码日韩| 国产麻豆精品视频| 精品国产乱码久久久久久1区2区| 亚洲妇熟xx妇色黄| 色婷婷av一区二区三区gif| 国产精品无码永久免费888| 韩国v欧美v亚洲v日本v| 精品国产乱码久久| 免费看精品久久片| 日韩区在线观看| 日韩va欧美va亚洲va久久| 欧美专区在线观看一区| 一区二区三区精品在线| 在线日韩一区二区| 亚洲黄色尤物视频| 一本久久综合亚洲鲁鲁五月天 | 免费成人在线观看| 欧美精品丝袜中出| 五月天网站亚洲| 欧美日本一道本在线视频| 五月天丁香久久| 欧美一区日韩一区| 日本亚洲三级在线| 日韩免费看的电影| 国内精品久久久久影院一蜜桃| 欧美mv和日韩mv的网站| 国产精品一色哟哟哟| 中文无字幕一区二区三区| 成人免费毛片app| 日韩美女啊v在线免费观看| 色综合久久综合网| 亚洲图片欧美色图| 欧美福利一区二区| 国产一区二区三区黄视频| 国产视频一区在线播放| 99久久免费视频.com| 亚洲色欲色欲www在线观看| 欧美午夜片在线看| 免费在线观看成人| 久久精品亚洲一区二区三区浴池| 国产成人亚洲综合a∨猫咪| **网站欧美大片在线观看| 欧美少妇bbb| 狠狠色丁香婷婷综合| 亚洲国产成人自拍| 欧美性受xxxx黑人xyx| 免费观看30秒视频久久| 中文字幕精品一区二区三区精品| www.欧美.com| 香蕉av福利精品导航| 26uuu成人网一区二区三区| 不卡av在线免费观看| 午夜视频久久久久久| 久久久久久免费网| 91婷婷韩国欧美一区二区| 日韩av一级片| 国产精品理论片在线观看| 欧美日韩一级黄| 国产不卡视频在线观看| 亚洲综合一区二区三区| 日韩视频一区在线观看| 国产成人在线视频免费播放| 亚洲欧美日本韩国| 日韩欧美亚洲一区二区| 不卡一区二区中文字幕| 五月婷婷综合激情| 国产精品久久久久影院亚瑟| 欧美久久一二三四区| 成人在线一区二区三区| 日韩高清一区在线| 中文字幕亚洲欧美在线不卡| 日韩一区二区在线看| 色久综合一二码| 国产一区999| 日韩精品成人一区二区三区| 国产精品视频一区二区三区不卡| 777亚洲妇女| 91网站视频在线观看| 国产一区二区精品久久99| 亚洲成人av在线电影| 中文字幕一区av| 久久久无码精品亚洲日韩按摩| 欧美性极品少妇| 99久久er热在这里只有精品15| 黑人精品欧美一区二区蜜桃 | 亚洲精品一区二区三区福利|