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

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

?? os_time.c

?? arm7學(xué)習(xí)資料
?? C
字號(hào):
/***********************************************************************************************************                                                uC/OS-II*                                          The Real-Time Kernel*                                             TIME MANAGEMENT**                          (c) Copyright 1992-2001, Jean J. Labrosse, Weston, FL*                                           All Rights Reserved** File : OS_TIME.C* By   : Jean J. Labrosse**********************************************************************************************************/#ifndef  OS_MASTER_FILE#include "includes.h"#endif/***********************************************************************************************************                                DELAY TASK 'n' TICKS   (n from 0 to 65535)** Description: This function is called to delay execution of the currently running task until the*              specified number of system ticks expires.  This, of course, directly equates to delaying*              the current task for some time to expire.  No delay will result If the specified delay is*              0.  If the specified delay is greater than 0 then, a context switch will result.** Arguments  : ticks     is the time delay that the task will be suspended in number of clock 'ticks'.*                        Note that by specifying 0, the task will not be delayed.** Returns    : none**********************************************************************************************************/void  OSTimeDly (INT16U ticks){#if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */    OS_CPU_SR  cpu_sr;#endif        if (ticks > 0) {                                                      /* 0 means no delay!         */        OS_ENTER_CRITICAL();        if ((OSRdyTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0) {  /* Delay current task        */            OSRdyGrp &= ~OSTCBCur->OSTCBBitY;        }        OSTCBCur->OSTCBDly = ticks;                                       /* Load ticks in TCB         */        OS_EXIT_CRITICAL();        OS_Sched();                                                       /* Find next task to run!    */    }}/*$PAGE*//***********************************************************************************************************                                     DELAY TASK FOR SPECIFIED TIME** Description: This function is called to delay execution of the currently running task until some time*              expires.  This call allows you to specify the delay time in HOURS, MINUTES, SECONDS and*              MILLISECONDS instead of ticks.** Arguments  : hours     specifies the number of hours that the task will be delayed (max. is 255)*              minutes   specifies the number of minutes (max. 59)*              seconds   specifies the number of seconds (max. 59)*              milli     specifies the number of milliseconds (max. 999)** Returns    : OS_NO_ERR*              OS_TIME_INVALID_MINUTES*              OS_TIME_INVALID_SECONDS*              OS_TIME_INVALID_MS*              OS_TIME_ZERO_DLY** Note(s)    : The resolution on the milliseconds depends on the tick rate.  For example, you can't do*              a 10 mS delay if the ticker interrupts every 100 mS.  In this case, the delay would be*              set to 0.  The actual delay is rounded to the nearest tick.**********************************************************************************************************/#if OS_TIME_DLY_HMSM_EN > 0INT8U  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);    /* Validate arguments to be within range              */        }        if (seconds > 59) {            return (OS_TIME_INVALID_SECONDS);        }        if (milli > 999) {            return (OS_TIME_INVALID_MILLI);        }                                                 /* Compute the total number of clock ticks required.. */                                                 /* .. (rounded to the nearest tick)                   */        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);        /* Compute the integral number of 65536 tick delays   */        ticks = ticks % 65536L;                  /* Obtain  the fractional number of ticks             */        OSTimeDly((INT16U)ticks);        while (loops > 0) {            OSTimeDly(32768);            OSTimeDly(32768);            loops--;        }        return (OS_NO_ERR);    }    return (OS_TIME_ZERO_DLY);}#endif/*$PAGE*//***********************************************************************************************************                                         RESUME A DELAYED TASK** Description: This function is used resume a task that has been delayed through a call to either*              OSTimeDly() or OSTimeDlyHMSM().  Note that you MUST NOT call this function to resume a*              task that is waiting for an event with timeout.  This situation would make the task look*              like a timeout occurred (unless you desire this effect).  Also, you cannot resume a task*              that has called OSTimeDlyHMSM() with a combined time that exceeds 65535 clock ticks.  In*              other words, if the clock tick runs at 100 Hz then, you will not be able to resume a*              delayed task that called OSTimeDlyHMSM(0, 10, 55, 350) or higher.**                  (10 Minutes * 60 + 55 Seconds + 0.35) * 100 ticks/second.** Arguments  : prio      specifies the priority of the task to resume** Returns    : OS_NO_ERR                 Task has been resumed*              OS_PRIO_INVALID           if the priority you specify is higher that the maximum allowed*                                        (i.e. >= OS_LOWEST_PRIO)*              OS_TIME_NOT_DLY           Task is not waiting for time to expire*              OS_TASK_NOT_EXIST         The desired task has not been created**********************************************************************************************************/#if OS_TIME_DLY_RESUME_EN > 0INT8U  OSTimeDlyResume (INT8U prio){#if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */    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];                   /* Make sure that task exist                */    if (ptcb != (OS_TCB *)0) {        if (ptcb->OSTCBDly != 0) {                         /* See if task is delayed                   */            ptcb->OSTCBDly  = 0;                           /* Clear the time delay                     */            if ((ptcb->OSTCBStat & OS_STAT_SUSPEND) == 0x00) {  /* See if task is ready to run         */                OSRdyGrp               |= ptcb->OSTCBBitY;      /* Make task ready to run              */                OSRdyTbl[ptcb->OSTCBY] |= ptcb->OSTCBBitX;                OS_EXIT_CRITICAL();                OS_Sched();                                /* See if this is new highest priority      */            } else {                OS_EXIT_CRITICAL();                        /* Task may be suspended                    */            }            return (OS_NO_ERR);        } else {            OS_EXIT_CRITICAL();            return (OS_TIME_NOT_DLY);                      /* Indicate that task was not delayed       */        }    }    OS_EXIT_CRITICAL();    return (OS_TASK_NOT_EXIST);                            /* The task does not exist                  */}#endif    /*$PAGE*//***********************************************************************************************************                                         GET CURRENT SYSTEM TIME** Description: This function is used by your application to obtain the current value of the 32-bit*              counter which keeps track of the number of clock ticks.** Arguments  : none** Returns    : The current value of OSTime**********************************************************************************************************/#if OS_TIME_GET_SET_EN > 0INT32U  OSTimeGet (void){#if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */    OS_CPU_SR  cpu_sr;#endif        INT32U     ticks;    OS_ENTER_CRITICAL();    ticks = OSTime;    OS_EXIT_CRITICAL();    return (ticks);}#endif    /***********************************************************************************************************                                            SET SYSTEM CLOCK** Description: This function sets the 32-bit counter which keeps track of the number of clock ticks.** Arguments  : ticks      specifies the new value that OSTime needs to take.** Returns    : none**********************************************************************************************************/#if OS_TIME_GET_SET_EN > 0void  OSTimeSet (INT32U ticks){#if OS_CRITICAL_METHOD == 3                      /* Allocate storage for CPU status register           */    OS_CPU_SR  cpu_sr;#endif        OS_ENTER_CRITICAL();    OSTime = ticks;    OS_EXIT_CRITICAL();}#endif    

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品天天看| 欧美mv和日韩mv国产网站| 美洲天堂一区二卡三卡四卡视频| 精品国产电影一区二区| 91免费在线播放| 麻豆精品精品国产自在97香蕉 | 26uuu亚洲综合色欧美 | 精品久久久久久久人人人人传媒 | wwwwxxxxx欧美| 欧美视频一区二| 成人综合婷婷国产精品久久 | 欧美一级在线免费| 色成人在线视频| 国产精品456| 麻豆成人久久精品二区三区小说| 亚洲欧美日韩精品久久久久| 精品国产一区二区三区不卡| 欧美视频第二页| 99精品欧美一区二区三区小说| 日本一区中文字幕| 亚洲国产日日夜夜| 亚洲日穴在线视频| 国产欧美日韩三区| 2023国产精品| 欧美一区二区二区| 欧美日产国产精品| 91成人免费网站| av高清久久久| 成人福利视频在线看| 国产一区二区网址| 免费看精品久久片| 视频在线观看国产精品| 亚洲一二三四区不卡| 亚洲三级久久久| 亚洲视频资源在线| 亚洲欧美激情小说另类| 国产精品国产精品国产专区不蜜 | 久久女同精品一区二区| 欧美大胆人体bbbb| 欧美mv日韩mv亚洲| 日韩一二三四区| 日韩一区二区免费高清| 日韩视频在线一区二区| 欧美一级视频精品观看| 欧美一区二区观看视频| 日韩精品综合一本久道在线视频| 欧美一区二区视频在线观看2020| 欧美精品视频www在线观看| 欧美日韩mp4| 日韩一区二区三区免费看 | 欧美区在线观看| 欧美日韩在线观看一区二区| 欧美亚洲一区二区三区四区| 欧美日韩在线三级| 日韩欧美一二三区| 久久精品亚洲乱码伦伦中文| 国产三级一区二区| 日韩一区欧美小说| 亚洲国产视频网站| 久99久精品视频免费观看| 黄色日韩网站视频| 高清国产一区二区三区| 97aⅴ精品视频一二三区| 色婷婷激情一区二区三区| 欧美三级电影一区| 日韩欧美国产一区二区三区| 久久久久88色偷偷免费| 国产精品久久毛片| 亚洲二区在线视频| 久久精品免费看| 国产精品一区二区无线| 91色在线porny| 欧美另类videos死尸| 久久亚区不卡日本| 亚洲人精品午夜| 全国精品久久少妇| 成人综合日日夜夜| 欧美日韩免费高清一区色橹橹| 欧美一区二区日韩| 国产精品久久一级| 免费观看一级欧美片| 国产成人综合在线观看| 欧美三级日韩三级| 国产夜色精品一区二区av| 国产一本一道久久香蕉| 99re热这里只有精品免费视频 | 色综合久久天天| 欧美精品久久久久久久多人混战| 欧美不卡视频一区| 亚洲美女免费在线| 国内成人免费视频| 欧美天天综合网| 国产精品网站在线播放| 免费在线一区观看| 色哟哟精品一区| 精品国产伦一区二区三区免费| 国产精品久久久久久户外露出| 午夜精品久久久久久久久久久 | 亚洲综合区在线| 国产精品小仙女| 欧美另类久久久品| 亚洲欧洲综合另类| 国产夫妻精品视频| 91麻豆精品国产自产在线| 国产精品久久毛片| 国产自产视频一区二区三区| 欧美中文一区二区三区| 欧美激情一二三区| 激情六月婷婷综合| 欧美日韩精品三区| 亚洲乱码国产乱码精品精98午夜| 国产九色sp调教91| 制服丝袜成人动漫| 亚洲资源在线观看| 91在线无精精品入口| 久久久久国色av免费看影院| 麻豆一区二区99久久久久| 欧美亚洲动漫精品| 亚洲免费观看高清| a在线欧美一区| 国产午夜精品在线观看| 狠狠色伊人亚洲综合成人| 欧美高清视频一二三区 | 精品国产在天天线2019| 天天综合色天天| 欧美三级日韩在线| 亚洲自拍另类综合| 在线免费av一区| 自拍偷拍亚洲激情| 91在线观看免费视频| 国产精品久久久久影院老司| 精品一区二区三区影院在线午夜| 91精品欧美久久久久久动漫 | 久久综合网色—综合色88| 麻豆国产精品视频| 精品久久一区二区三区| 美女脱光内衣内裤视频久久影院| 欧美精品777| 日韩福利视频网| 91精品国产综合久久精品麻豆| 亚洲高清一区二区三区| 欧美日本在线视频| 人人狠狠综合久久亚洲| 日韩视频在线一区二区| 国产一区二区视频在线| 国产欧美日韩综合精品一区二区| 欧美一级电影网站| 裸体歌舞表演一区二区| 精品国产一区二区三区不卡| 国产精品1区2区3区| 中文字幕在线播放不卡一区| 91在线观看美女| 午夜精品视频在线观看| 日韩欧美资源站| 国产一区福利在线| 国产精品久久网站| 在线观看亚洲精品视频| 日韩电影一二三区| www精品美女久久久tv| 成人网页在线观看| 一区二区三区在线视频观看58| 精品视频免费看| 久久99精品久久只有精品| 国产欧美综合在线观看第十页| 成人av午夜电影| 亚洲国产一区在线观看| 日韩女优制服丝袜电影| 成人午夜视频在线| 亚洲香肠在线观看| 欧美成人三级电影在线| 成人性生交大片免费看在线播放| 亚洲乱码国产乱码精品精的特点 | 成人av免费在线播放| 亚洲一二三四在线观看| 日韩精品一区国产麻豆| 成人免费毛片高清视频| 午夜精品123| 久久久久一区二区三区四区| 色综合亚洲欧洲| 美女网站视频久久| 国产精品乱码一区二区三区软件 | 亚洲va欧美va人人爽| 久久婷婷国产综合国色天香| 91污在线观看| 美女免费视频一区| 一区二区三区在线看| 精品日产卡一卡二卡麻豆| 日本高清成人免费播放| 激情综合色综合久久| 夜夜揉揉日日人人青青一国产精品| 日韩一区二区电影网| 一本色道久久综合狠狠躁的推荐| 老司机精品视频导航| 亚洲综合男人的天堂| 国产亚洲欧美一级| 6080日韩午夜伦伦午夜伦| 91网站在线观看视频| 国产呦萝稀缺另类资源| 午夜精品成人在线视频| 亚洲欧美视频一区|