/*
** ver: 2.52
** file: os_time.c
** brief: 時間相關函數 C 文件
*/
#ifndef OS_MASTER_FILE
#include "includes.h" /* 包含頭文件 */
#endif
/*
*********************************************************************************
* 任務延時 'n' 時鐘節拍 (n : 0 - 65535)
*
* brief : 該函數用於將任務延時 ticks 個時鐘節拍後運行.
*
* ticks : 延時節拍數 <=65535
*
* note : 如果任務至少需要延時1個時鐘節拍,必須調用 OSTimeDly(2)
*********************************************************************************
*/
void OSTimeDly (INT16U ticks)
{
#if OS_CRITICAL_METHOD == 3
OS_CPU_SR cpu_sr;
#endif
if (ticks > 0) { /* 延時節拍數應大於0 */
OS_ENTER_CRITICAL();
if ((OSRdyTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0) {
OSRdyGrp &= ~OSTCBCur->OSTCBBitY; /* 從就緒表中移除該任務 */
}
OSTCBCur->OSTCBDly = ticks; /* 記錄ticks至TCB中 */
OS_EXIT_CRITICAL();
OS_Sched(); /* 任務調度 */
}
}
/*$PAGE*/
/*
********************************************************************************
* 按 h min sec ms 延時函數
*
* brief : 該函數用於將任務按時分秒毫秒延時.
*
* hours : 時 ( <=255)
* minutes : 分 ( <=59 )
* seconds : 秒 ( <=59 )
* milli : 毫秒 ( <=999)
*
* returns : OS_NO_ERR
* OS_TIME_INVALID_MINUTES
* OS_TIME_INVALID_SECONDS
* OS_TIME_INVALID_MS
* OS_TIME_ZERO_DLY
*
*********************************************************************************
*/
#if OS_TIME_DLY_HMSM_EN > 0
INT8U OSTimeDlyHMSM (INT8U hours, INT8U minutes, INT8U seconds, INT16U milli)
{
INT32U ticks;
INT16U loops;
if (hours > 0 || minutes > 0 || seconds > 0 || milli > 0) {
if (minutes > 59) {
return (OS_TIME_INVALID_MINUTES); /* 無效的分鐘數 */
}
if (seconds > 59) {
return (OS_TIME_INVALID_SECONDS); /* 無效的秒參數 */
}
if (milli > 999) {
return (OS_TIME_INVALID_MILLI); /* 無效的毫秒數 */
}
/* 計算總的延時節拍數 */
ticks = ((INT32U)hours * 3600L + (INT32U)minutes * 60L + (INT32U)seconds)
* OS_TICKS_PER_SEC
+ OS_TICKS_PER_SEC * ((INT32U)milli + 500L / OS_TICKS_PER_SEC) / 1000L;
loops = (INT16U)(ticks / 65536L); /* 計算總節拍數包括多少個65536節拍 */
ticks = ticks % 65536L; /* 剩餘節拍 */
OSTimeDly((INT16U)ticks); /* 剩餘節拍延時 */
while (loops > 0) { /* 整數個65536節拍延時 */
OSTimeDly(32768);
OSTimeDly(32768);
loops--;
}
return (OS_NO_ERR);
}
return (OS_TIME_ZERO_DLY);
}
#endif
/*$PAGE*/
/*
*******************************************************************************
* 恢復延時的任務
*
* breif: 該函數用於取消任務延時而進入就緒狀態,也可以喚醒正在等待事件的任務
* ,但不推薦使用這種方法,在這種情況下,等待事件的任務會把它當做超時
* 處理,延時節拍超過65535的任務也不能通過該函數恢復
*
* 65535 = (10 Minutes * 60 + 55 Seconds + 0.35) * 100 ticks/second.
*
* prio : 任務優先級
*
* returns : OS_NO_ERR 成功
* OS_PRIO_INVALID 無效的優先級
* OS_TIME_NOT_DLY 任務無延時
* OS_TASK_NOT_EXIST 任務不存在
*******************************************************************************
*/
#if OS_TIME_DLY_RESUME_EN > 0
INT8U OSTimeDlyResume (INT8U prio)
{
#if OS_CRITICAL_METHOD == 3
OS_CPU_SR cpu_sr;
#endif
OS_TCB *ptcb;
if (prio >= OS_LOWEST_PRIO) { /* 無效的優先級 */
return (OS_PRIO_INVALID);
}
OS_ENTER_CRITICAL();
ptcb = (OS_TCB *)OSTCBPrioTbl[prio]; /* 獲取任務控制塊 */
if (ptcb != (OS_TCB *)0) {
if (ptcb->OSTCBDly != 0) { /* 任務必須有延時 */
ptcb->OSTCBDly = 0; /* 清零延時節拍數 */
if ((ptcb->OSTCBStat & OS_STAT_SUSPEND) == OS_STAT_RDY) {
OSRdyGrp |= ptcb->OSTCBBitY; /* 將任務置於就緒表中 */
OSRdyTbl[ptcb->OSTCBY] |= ptcb->OSTCBBitX;
OS_EXIT_CRITICAL();
OS_Sched(); /* 任務調度 */
} else {
OS_EXIT_CRITICAL(); /* 任務被掛起 */
}
return (OS_NO_ERR);
} else {
OS_EXIT_CRITICAL();
return (OS_TIME_NOT_DLY); /* 任務無延時 */
}
}
OS_EXIT_CRITICAL();
return (OS_TASK_NOT_EXIST); /* 任務不存在 */
}
#endif
/*$PAGE*/
/*
*********************************************************************************
* 獲取當前系統時間
*
* brief : 獲取當前系統時鐘節拍數
*
*
* Returns : 當前 OSTime 值
**********************************************************************************
*/
#if OS_TIME_GET_SET_EN > 0
INT32U OSTimeGet (void)
{
#if OS_CRITICAL_METHOD == 3
OS_CPU_SR cpu_sr;
#endif
INT32U ticks;
OS_ENTER_CRITICAL();
ticks = OSTime; /* 記錄系統時鐘節拍數 */
OS_EXIT_CRITICAL();
return (ticks);
}
#endif
/*
********************************************************************************
* 設置系統時間
*
* brief : 該函數用於設置一個32位的時鐘節拍計數器
*
* ticks : 設置OSTime.
*
*********************************************************************************
*/
#if OS_TIME_GET_SET_EN > 0
void OSTimeSet (INT32U ticks)
{
#if OS_CRITICAL_METHOD == 3
OS_CPU_SR cpu_sr;
#endif
OS_ENTER_CRITICAL();
OSTime = ticks;
OS_EXIT_CRITICAL();
}
#endif
uC/OS-II源碼解析(os_time.c)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.