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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? os_core.c

?? S3C44B0X全套培訓資料及源代碼,是ARM入門非常實用的東西
?? C
?? 第 1 頁 / 共 3 頁
字號:
                    OS_TASK_IDLE_STK_SIZE,                     (void *)0,                                 /* No TCB extension                     */                    OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);/* Enable stack checking + clear stack  */    #else    OSTaskCreate(OSTaskIdle, (void *)0, &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1], OS_IDLE_PRIO);    #endif#else    #if OS_TASK_CREATE_EXT_EN    OSTaskCreateExt(OSTaskIdle,                     (void *)0,                                 /* No arguments passed to OSTaskIdle()  */                    &OSTaskIdleStk[0],                         /* Set Top-Of-Stack                     */                    OS_IDLE_PRIO,                              /* Lowest priority level                */                    OS_TASK_IDLE_ID,                    &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1], /* Set Bottom-Of-Stack                  */                    OS_TASK_IDLE_STK_SIZE,                     (void *)0,                                 /* No TCB extension                     */                    OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);/* Enable stack checking + clear stack  */    #else    OSTaskCreate(OSTaskIdle, (void *)0, &OSTaskIdleStk[0], OS_IDLE_PRIO);    #endif#endif#if OS_TASK_STAT_EN     #if OS_TASK_CREATE_EXT_EN        #if OS_STK_GROWTH == 1        OSTaskCreateExt(OSTaskStat,                         (void *)0,                                /* No args passed to OSTaskStat()    */                        &OSTaskStatStk[OS_TASK_STAT_STK_SIZE - 1],/* Set Top-Of-Stack                  */                        OS_STAT_PRIO,                             /* One higher than the idle task     */                        OS_TASK_STAT_ID,                        &OSTaskStatStk[0],                        /* Set Bottom-Of-Stack               */                        OS_TASK_STAT_STK_SIZE,                         (void *)0,                                /* No TCB extension                  */                        OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);  /* Enable stack checking + clear  */        #else        OSTaskCreateExt(OSTaskStat,                         (void *)0,                                /* No args passed to OSTaskStat()    */                        &OSTaskStatStk[0],                        /* Set Top-Of-Stack                  */                        OS_STAT_PRIO,                             /* One higher than the idle task     */                        OS_TASK_STAT_ID,                        &OSTaskStatStk[OS_TASK_STAT_STK_SIZE - 1],/* Set Bottom-Of-Stack               */                        OS_TASK_STAT_STK_SIZE,                         (void *)0,                                /* No TCB extension                  */                        OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);  /* Enable stack checking + clear  */        #endif    #else        #if OS_STK_GROWTH == 1        OSTaskCreate(OSTaskStat,                      (void *)0,                                   /* No args passed to OSTaskStat()    */                     &OSTaskStatStk[OS_TASK_STAT_STK_SIZE - 1],   /* Set Top-Of-Stack                  */                     OS_STAT_PRIO);                               /* One higher than the idle task     */        #else        OSTaskCreate(OSTaskStat,                      (void *)0,                                   /* No args passed to OSTaskStat()    */                     &OSTaskStatStk[0],                           /* Set Top-Of-Stack                  */                     OS_STAT_PRIO);                               /* One higher than the idle task     */        #endif    #endif#endif}/*$PAGE*//***********************************************************************************************************                                              ENTER ISR** Description: This function is used to notify uC/OS-II that you are about to service an interrupt*              service routine (ISR).  This allows uC/OS-II to keep track of interrupt nesting and thus*              only perform rescheduling at the last nested ISR.** Arguments  : none** Returns    : none** Notes      : 1) Your ISR can directly increment OSIntNesting without calling this function because *                 OSIntNesting has been declared 'global'.  You MUST, however, be sure that the increment*                 is performed 'indivisibly' by your processor to ensure proper access to this critical*                 resource.*              2) You MUST still call OSIntExit() even though you increment OSIntNesting directly.*              3) You MUST invoke OSIntEnter() and OSIntExit() in pair.  In other words, for every call*                 to OSIntEnter() at the beginning of the ISR you MUST have a call to OSIntExit() at the*                 end of the ISR.**********************************************************************************************************/void OSIntEnter (void){    OS_ENTER_CRITICAL();    OSIntNesting++;                              /* Increment ISR nesting level                        */    OS_EXIT_CRITICAL();}/*$PAGE*//***********************************************************************************************************                                               EXIT ISR** Description: This function is used to notify uC/OS-II that you have completed serviving an ISR.  When *              the last nested ISR has completed, uC/OS-II will call the scheduler to determine whether*              a new, high-priority task, is ready to run.** Arguments  : none** Returns    : none** Notes      : 1) You MUST invoke OSIntEnter() and OSIntExit() in pair.  In other words, for every call*                 to OSIntEnter() at the beginning of the ISR you MUST have a call to OSIntExit() at the*                 end of the ISR.*              2) Rescheduling is prevented when the scheduler is locked (see OSSchedLock())**********************************************************************************************************/void OSIntExit (void){    OS_ENTER_CRITICAL();    if ((--OSIntNesting | OSLockNesting) == 0) { /* Reschedule only if all ISRs completed & not locked */        OSIntExitY    = OSUnMapTbl[OSRdyGrp];        OSPrioHighRdy = (INT8U)((OSIntExitY << 3) + OSUnMapTbl[OSRdyTbl[OSIntExitY]]);        if (OSPrioHighRdy != OSPrioCur) {        /* No context switch if current task is highest ready */            OSTCBHighRdy  = OSTCBPrioTbl[OSPrioHighRdy];            OSCtxSwCtr++;                        /* Keep track of the number of context switches       */            OSIntCtxSw();                        /* Perform interrupt level context switch             */        }    }    OS_EXIT_CRITICAL();}void OSExIntExit (void){    if ((--OSIntNesting | OSLockNesting) == 0) { /* Reschedule only if all ISRs completed & not locked */        OSIntExitY    = OSUnMapTbl[OSRdyGrp];        OSPrioHighRdy = (INT8U)((OSIntExitY << 3) + OSUnMapTbl[OSRdyTbl[OSIntExitY]]);        if (OSPrioHighRdy != OSPrioCur) {        /* No context switch if current task is highest ready */            OSTCBHighRdy  = OSTCBPrioTbl[OSPrioHighRdy];            OSCtxSwCtr++;                        /* Keep track of the number of context switches       */            OSIntCtxSw();                        /* Perform interrupt level context switch             */        }    }}/*$PAGE*//***********************************************************************************************************                                              SCHEDULER** Description: This function is called by other uC/OS-II services to determine whether a new, high*              priority task has been made ready to run.  This function is invoked by TASK level code*              and is not used to reschedule tasks from ISRs (see OSIntExit() for ISR rescheduling).** Arguments  : none** Returns    : none** Notes      : 1) This function is INTERNAL to uC/OS-II and your application should not call it.*              2) Rescheduling is prevented when the scheduler is locked (see OSSchedLock())**********************************************************************************************************/void OSSched (void){    INT8U y;    OS_ENTER_CRITICAL();    if ((OSLockNesting | OSIntNesting) == 0) {   /* Task scheduling must be enabled and not ISR level  */        y             = OSUnMapTbl[OSRdyGrp];    /* Get pointer to highest priority task ready to run  */        OSPrioHighRdy = (INT8U)((y << 3) + OSUnMapTbl[OSRdyTbl[y]]);        if (OSPrioHighRdy != OSPrioCur) {         /* No context switch if current task is highest ready */            OSTCBHighRdy = OSTCBPrioTbl[OSPrioHighRdy];            OSCtxSwCtr++;                        /* Increment context switch counter                   */            OS_TASK_SW();                        /* Perform a context switch                           */        }    }    OS_EXIT_CRITICAL();}void OSIntSched (void){    INT8U y;    if ((OSLockNesting | OSIntNesting) == 0) {   /* Task scheduling must be enabled and not ISR level  */        y             = OSUnMapTbl[OSRdyGrp];    /* Get pointer to highest priority task ready to run  */        OSPrioHighRdy = (INT8U)((y << 3) + OSUnMapTbl[OSRdyTbl[y]]);        if (OSPrioHighRdy != OSPrioCur) {         /* No context switch if current task is highest ready */            OSTCBHighRdy = OSTCBPrioTbl[OSPrioHighRdy];            OSCtxSwCtr++;                        /* Increment context switch counter                   */            OS_TASK_SW();                        /* Perform a context switch                           */        }    }}/*$PAGE*//***********************************************************************************************************                                          PREVENT SCHEDULING** Description: This function is used to prevent rescheduling to take place.  This allows your application*              to prevent context switches until you are ready to permit context switching.** Arguments  : none** Returns    : none** Notes      : 1) You MUST invoke OSSchedLock() and OSSchedUnlock() in pair.  In other words, for every *                 call to OSSchedLock() you MUST have a call to OSSchedUnlock().**********************************************************************************************************/void OSSchedLock (void){    if (OSRunning == TRUE) {                     /* Make sure multitasking is running                  */        OS_ENTER_CRITICAL();        OSLockNesting++;                         /* Increment lock nesting level                       */        OS_EXIT_CRITICAL();    }}/*$PAGE*//***********************************************************************************************************                                          ENABLE SCHEDULING** Description: This function is used to re-allow rescheduling.  ** Arguments  : none** Returns    : none** Notes      : 1) You MUST invoke OSSchedLock() and OSSchedUnlock() in pair.  In other words, for every *                 call to OSSchedLock() you MUST have a call to OSSchedUnlock().**********************************************************************************************************/void OSSchedUnlock (void){    if (OSRunning == TRUE) {                           /* Make sure multitasking is running            */        OS_ENTER_CRITICAL();        if (OSLockNesting > 0) {                       /* Do not decrement if already 0                */            OSLockNesting--;                           /* Decrement lock nesting level                 */            if ((OSLockNesting | OSIntNesting) == 0) { /* See if scheduling re-enabled and not an ISR  */                OS_EXIT_CRITICAL();                OSSched();                             /* See if a higher priority task is ready       */            } else {                OS_EXIT_CRITICAL();            }        } else {            OS_EXIT_CRITICAL();        }    }}/*$PAGE*//***********************************************************************************************************                                          START MULTITASKING** Description: This function is used to start the multitasking process which lets uC/OS-II manages the*              task that you have created.  Before you can call OSStart(), you MUST have called OSInit()*              and you MUST have created at least one task.** Arguments  : none** Returns    : none** Note       : OSStartHighRdy() MUST:*                 a) Call OSTaskSwHook() then,*                 b) Set OSRunning to TRUE.**********************************************************************************************************/void OSStart (void){    INT8U y;    INT8U x;    if (OSRunning == FALSE) {        y             = OSUnMapTbl[OSRdyGrp];        /* Find highest priority's task priority number   */        x             = OSUnMapTbl[OSRdyTbl[y]];        OSPrioHighRdy = (INT8U)((y << 3) + x);        OSPrioCur     = OSPrioHighRdy;        OSTCBHighRdy  = OSTCBPrioTbl[OSPrioHighRdy]; /* Point to highest priority task ready to run    */        OSTCBCur      = OSTCBHighRdy;        OSStartHighRdy();                            /* Execute target specific code to start task     */    }}/*$PAGE*//**********************************************************************************************************

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩三级一区| 亚洲一区在线观看网站| 国产高清亚洲一区| 日本一区二区视频在线观看| 成人高清在线视频| 亚洲自拍偷拍av| 制服.丝袜.亚洲.中文.综合| 久久99深爱久久99精品| 久久欧美中文字幕| 99久久er热在这里只有精品15 | 国产欧美日韩在线| 99riav一区二区三区| 亚洲va韩国va欧美va精品| 日韩免费观看高清完整版| 成人va在线观看| 午夜亚洲国产au精品一区二区| 精品电影一区二区三区| 99re热这里只有精品免费视频| 亚洲在线视频一区| 日韩免费高清视频| 91视频观看视频| 美国十次了思思久久精品导航| 国产女人18毛片水真多成人如厕| 不卡视频在线看| 捆绑紧缚一区二区三区视频| 中文字幕一区二区三中文字幕| 91麻豆精品国产91久久久| 高清在线成人网| 亚洲高清免费观看高清完整版在线观看 | 欧美一区二区三区系列电影| 国产成人精品亚洲日本在线桃色 | 日韩精品欧美成人高清一区二区| 国产三级欧美三级日产三级99| 91香蕉视频污| 久久国产精品区| 日韩精品电影在线观看| 欧美电视剧在线看免费| 91福利精品视频| 国产美女久久久久| 午夜日韩在线观看| **性色生活片久久毛片| 精品国产乱码91久久久久久网站| 欧美专区在线观看一区| 国产成人精品三级麻豆| 理论电影国产精品| 亚洲国产日韩a在线播放性色| 国产精品免费免费| 久久这里都是精品| 欧美一区二区三级| 色狠狠色噜噜噜综合网| 不卡免费追剧大全电视剧网站| 黄一区二区三区| 日韩有码一区二区三区| 亚洲亚洲精品在线观看| ...中文天堂在线一区| 欧美激情在线一区二区三区| 欧美一区二区三区男人的天堂| 91电影在线观看| 91色porny| 99精品在线观看视频| 成人在线综合网| 国产二区国产一区在线观看| 激情六月婷婷久久| 久久99蜜桃精品| 蜜桃av一区二区三区电影| 亚洲一区二区三区四区在线观看| 亚洲欧洲av在线| 日韩久久一区二区| 中文字幕一区二区三中文字幕| 国产精品免费视频观看| 中文字幕制服丝袜一区二区三区| 久久夜色精品国产欧美乱极品| 日韩女同互慰一区二区| 精品免费视频一区二区| 欧美sm极限捆绑bd| 欧美精品一区二区三区视频 | 欧美视频在线一区二区三区 | 亚洲精品一区二区三区四区高清| 欧美一区二区三区四区高清| 欧美一区二区在线视频| 欧美成人video| 国产亚洲精品中文字幕| 国产日韩精品一区| 国产精品免费看片| 一区二区三区蜜桃网| 一区二区三区在线视频观看| 亚洲综合av网| 奇米影视一区二区三区小说| 日韩avvvv在线播放| 久久91精品久久久久久秒播 | 丁香啪啪综合成人亚洲小说| 成人福利视频在线看| 一本一道久久a久久精品| 欧美午夜精品电影| 日韩欧美一级在线播放| 久久久久久亚洲综合| 国产精品嫩草影院av蜜臀| 日韩高清一级片| 国产一区二区在线视频| 99麻豆久久久国产精品免费| 欧美日韩在线观看一区二区 | 亚洲一区二区美女| 日本欧美加勒比视频| 国产不卡视频一区| 欧美亚洲免费在线一区| 日韩一区二区免费高清| 国产精品乱子久久久久| 亚洲超碰精品一区二区| 激情偷乱视频一区二区三区| 99久精品国产| 欧美一级黄色录像| 亚洲视频免费观看| 免费在线观看精品| 99久久免费视频.com| 欧美一级在线免费| 国产精品免费aⅴ片在线观看| 亚洲国产成人porn| 国产精品88888| 91.xcao| 亚洲三级在线观看| 国产一区二区视频在线| 欧美日韩在线免费视频| 国产精品美女久久久久久2018 | 亚洲精品视频免费看| 另类小说综合欧美亚洲| 色综合天天综合网国产成人综合天| 欧美精品九九99久久| 国产精品天美传媒| 免费观看成人鲁鲁鲁鲁鲁视频| 99亚偷拍自图区亚洲| 精品国产一区二区三区忘忧草 | 色综合天天综合狠狠| 精品日韩一区二区三区 | 国产精品成人免费精品自在线观看| 丝袜诱惑制服诱惑色一区在线观看| 丰满少妇久久久久久久| 精品日韩在线观看| 石原莉奈在线亚洲三区| 91丝袜国产在线播放| 久久蜜桃香蕉精品一区二区三区| 天天影视涩香欲综合网| 一本大道av伊人久久综合| 欧美国产综合色视频| 激情欧美一区二区| 欧美mv日韩mv| 久久99热99| 日韩午夜激情av| 视频一区二区国产| 精品国免费一区二区三区| 亚洲午夜免费视频| 一本到高清视频免费精品| 国产欧美日韩中文久久| 国产一区二区电影| 日韩精品专区在线影院观看| 天堂成人国产精品一区| 日本精品免费观看高清观看| 专区另类欧美日韩| 99久久精品久久久久久清纯| 国产精品激情偷乱一区二区∴| 国产乱色国产精品免费视频| 精品久久久久久久久久久久包黑料 | 久久国产人妖系列| 日韩精品中文字幕一区二区三区| 丝袜a∨在线一区二区三区不卡| 欧美在线一区二区三区| 亚洲国产成人porn| 欧美美女bb生活片| 视频在线观看一区| 91精品国产综合久久久久久漫画 | 亚洲成人7777| 欧美日韩免费在线视频| 五月开心婷婷久久| 欧美一区二区三区小说| 裸体歌舞表演一区二区| 久久久久久日产精品| 成人黄动漫网站免费app| 成人欧美一区二区三区视频网页| 91色porny蝌蚪| 天堂av在线一区| 欧美精品一区男女天堂| 国产精品一区二区在线看| 国产精品女人毛片| 欧美中文字幕不卡| 日韩av一区二| 久久久国产一区二区三区四区小说 | 久久精品国产亚洲aⅴ| 久久亚洲精品国产精品紫薇| 丁香网亚洲国际| 一区二区三区精品视频在线| 91精品欧美综合在线观看最新| 蓝色福利精品导航| 国产精品福利一区二区| 欧美日韩一区二区三区四区五区| 免费人成网站在线观看欧美高清| 欧美大片日本大片免费观看| 成人美女视频在线观看| 麻豆极品一区二区三区| 国产精品成人一区二区艾草 | 国产大陆a不卡| 亚洲摸摸操操av|