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

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

?? os_core.c

?? ucosii-2.76 ucosii 的源代碼
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
{
#if OS_TIME_GET_SET_EN > 0   
    OSTime        = 0L;                                    /* Clear the 32-bit system clock            */
#endif

    OSIntNesting  = 0;                                     /* Clear the interrupt nesting counter      */
    OSLockNesting = 0;                                     /* Clear the scheduling lock counter        */

    OSTaskCtr     = 0;                                     /* Clear the number of tasks                */

    OSRunning     = FALSE;                                 /* Indicate that multitasking not started   */
    
    OSCtxSwCtr    = 0;                                     /* Clear the context switch counter         */
    OSIdleCtr     = 0L;                                    /* Clear the 32-bit idle counter            */

#if OS_TASK_STAT_EN > 0
    OSIdleCtrRun  = 0L;
    OSIdleCtrMax  = 0L;
    OSStatRdy     = FALSE;                                 /* Statistic task is not ready              */
#endif
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                             INITIALIZATION
*                                       INITIALIZE THE READY LIST
*
* Description: This function is called by OSInit() to initialize the Ready List.
*
* Arguments  : none
*
* Returns    : none
*********************************************************************************************************
*/

static  void  OS_InitRdyList (void)
{
    INT8U    i;
    INT8U   *prdytbl;


    OSRdyGrp      = 0x00;                                  /* Clear the ready list                     */
    prdytbl       = &OSRdyTbl[0];
    for (i = 0; i < OS_RDY_TBL_SIZE; i++) {
        *prdytbl++ = 0x00;
    }

    OSPrioCur     = 0;
    OSPrioHighRdy = 0;

    OSTCBHighRdy  = (OS_TCB *)0;                                 
    OSTCBCur      = (OS_TCB *)0;
}

/*$PAGE*/
/*
*********************************************************************************************************
*                                             INITIALIZATION
*                                         CREATING THE IDLE TASK
*
* Description: This function creates the Idle Task.
*
* Arguments  : none
*
* Returns    : none
*********************************************************************************************************
*/

static  void  OS_InitTaskIdle (void)
{
#if OS_TASK_CREATE_EXT_EN > 0
    #if OS_STK_GROWTH == 1
    (void)OSTaskCreateExt(OS_TaskIdle,
                          (void *)0,                                 /* No arguments passed to OS_TaskIdle() */
                          &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1], /* Set Top-Of-Stack                     */
                          OS_IDLE_PRIO,                              /* Lowest priority level                */
                          OS_TASK_IDLE_ID,
                          &OSTaskIdleStk[0],                         /* 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
    (void)OSTaskCreateExt(OS_TaskIdle,
                          (void *)0,                                 /* No arguments passed to OS_TaskIdle() */
                          &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  */
    #endif
#else
    #if OS_STK_GROWTH == 1
    (void)OSTaskCreate(OS_TaskIdle,
                       (void *)0,
                       &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1],
                       OS_IDLE_PRIO);
    #else
    (void)OSTaskCreate(OS_TaskIdle,
                       (void *)0,
                       &OSTaskIdleStk[0],
                       OS_IDLE_PRIO);
    #endif
#endif
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                             INITIALIZATION
*                                      CREATING THE STATISTIC TASK
*
* Description: This function creates the Statistic Task.
*
* Arguments  : none
*
* Returns    : none
*********************************************************************************************************
*/

#if OS_TASK_STAT_EN > 0
static  void  OS_InitTaskStat (void)
{
#if OS_TASK_CREATE_EXT_EN > 0
    #if OS_STK_GROWTH == 1
    (void)OSTaskCreateExt(OS_TaskStat,
                          (void *)0,                                   /* No args passed to OS_TaskStat()*/
                          &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
    (void)OSTaskCreateExt(OS_TaskStat,
                          (void *)0,                                   /* No args passed to OS_TaskStat()*/
                          &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
    (void)OSTaskCreate(OS_TaskStat,
                       (void *)0,                                      /* No args passed to OS_TaskStat()*/
                       &OSTaskStatStk[OS_TASK_STAT_STK_SIZE - 1],      /* Set Top-Of-Stack               */
                       OS_STAT_PRIO);                                  /* One higher than the idle task  */
    #else
    (void)OSTaskCreate(OS_TaskStat,
                       (void *)0,                                      /* No args passed to OS_TaskStat()*/
                       &OSTaskStatStk[0],                              /* Set Top-Of-Stack               */
                       OS_STAT_PRIO);                                  /* One higher than the idle task  */
    #endif
#endif
}
#endif
/*$PAGE*/
/*
*********************************************************************************************************
*                                             INITIALIZATION
*                            INITIALIZE THE FREE LIST OF TASK CONTROL BLOCKS
*
* Description: This function is called by OSInit() to initialize the free list of OS_TCBs.
*
* Arguments  : none
*
* Returns    : none
*********************************************************************************************************
*/

static  void  OS_InitTCBList (void)
{
    INT8U    i;
    OS_TCB  *ptcb1;
    OS_TCB  *ptcb2;


    OS_MemClr((INT8U *)&OSTCBTbl[0],     sizeof(OSTCBTbl));      /* Clear all the TCBs                 */
    OS_MemClr((INT8U *)&OSTCBPrioTbl[0], sizeof(OSTCBPrioTbl));  /* Clear the priority table           */
    ptcb1 = &OSTCBTbl[0];
    ptcb2 = &OSTCBTbl[1];
    for (i = 0; i < (OS_MAX_TASKS + OS_N_SYS_TASKS - 1); i++) {  /* Init. list of free TCBs            */
        ptcb1->OSTCBNext = ptcb2;
#if OS_TASK_NAME_SIZE > 1
        ptcb1->OSTCBTaskName[0] = '?';                           /* Unknown name                       */
        ptcb1->OSTCBTaskName[1] = OS_ASCII_NUL;
#endif
        ptcb1++;
        ptcb2++;
    }
    ptcb1->OSTCBNext = (OS_TCB *)0;                              /* Last OS_TCB                        */
#if OS_TASK_NAME_SIZE > 1
    ptcb1->OSTCBTaskName[0] = '?';                               /* Unknown name                       */
    ptcb1->OSTCBTaskName[1] = OS_ASCII_NUL;
#endif
    OSTCBList               = (OS_TCB *)0;                       /* TCB lists initializations          */
    OSTCBFreeList           = &OSTCBTbl[0];
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                        CLEAR A SECTION OF MEMORY
*
* Description: This function is called by other uC/OS-II services to clear a contiguous block of RAM.
*
* Arguments  : pdest    is the start of the RAM to clear (i.e. write 0x00 to)
*
*              size     is the number of bytes to clear.  
*
* Returns    : none
*
* Notes      : 1) This function is INTERNAL to uC/OS-II and your application should not call it.
*              2) Note that we can only clear up to 64K bytes of RAM.  This is not an issue because none 
*                 of the uses of this function gets close to this limit.
*              3) The clear is done one byte at a time since this will work on any processor irrespective
*                 of the alignment of the destination.
*********************************************************************************************************
*/

void  OS_MemClr (INT8U *pdest, INT16U size)
{
    while (size > 0) {
        *pdest++ = (INT8U)0;
        size--;
    }
}
/*$PAGE*/
/*
*********************************************************************************************************
*                                        COPY A BLOCK OF MEMORY
*
* Description: This function is called by other uC/OS-II services to copy a block of memory from one 
*              location to another.
*
* Arguments  : pdest    is a pointer to the 'destination' memory block
*
*              psrc     is a pointer to the 'source'      memory block
*
*              size     is the number of bytes to copy.  
*
* Returns    : none
*
* Notes      : 1) This function is INTERNAL to uC/OS-II and your application should not call it.  There is 
*                 no provision to handle overlapping memory copy.  However, that's not a problem since this
*                 is not a situation that will happen.
*              2) Note that we can only copy up to 64K bytes of RAM
*              3) The copy is done one byte at a time since this will work on any processor irrespective
*                 of the alignment of the source and destination.
*********************************************************************************************************
*/

void  OS_MemCopy (INT8U *pdest, INT8U *psrc, INT16U size)
{
    while (size > 0) {
        *pdest++ = *psrc++;
        size--;
    }
}
/*$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 OS_SchedLock())
*********************************************************************************************************
*/

void  OS_Sched (void)
{
    INT8U      y;
#if OS_CRITICAL_METHOD == 3                            /* Allocate storage for CPU status register     */
    OS_CPU_SR  cpu_sr;



    cpu_sr = 0;                                        /* Prevent compiler warning                     */
#endif    
    OS_ENTER_CRITICAL();
    if (OSIntNesting == 0) {                           /* Schedule only if all ISRs done and ...       */
        if (OSLockNesting == 0) {                      /* ... scheduler is not locked                  */
            y             = OSUnMapTbl[OSRdyGrp];      /* Get pointer to HPT ready to run              */
            OSPrioHighRdy = (INT8U)((y << 3) + OSUnMapTbl[OSRdyTbl[y]]);
            if (OSPrioHighRdy != OSPrioCur) {          /* No Ctx Sw if current task is highest rdy     */
                OSTCBHighRdy = OSTCBPrioTbl[OSPrioHighRdy];

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品三级在线观看| 精品乱人伦小说| 青椒成人免费视频| 中文字幕av一区二区三区高 | 欧美曰成人黄网| 美女视频黄频大全不卡视频在线播放| 亚洲国产成人一区二区三区| 色综合天天综合网天天看片| 91网站黄www| 1024精品合集| 日韩欧美一级特黄在线播放| 色综合久久综合网| 成人亚洲精品久久久久软件| 麻豆精品久久久| 亚洲图片自拍偷拍| 亚洲婷婷综合色高清在线| 精品免费国产一区二区三区四区| 欧美中文字幕一区二区三区| 懂色av中文字幕一区二区三区| 免费在线成人网| 午夜精品久久久久久久| 亚洲色图.com| 国产精品国产三级国产| 精品国产1区2区3区| 欧美一级久久久| 欧美日韩精品三区| 91小宝寻花一区二区三区| 精品一区精品二区高清| 亚洲三级电影全部在线观看高清| 欧美美女bb生活片| 日本乱人伦一区| 91视频一区二区三区| 丁香激情综合五月| 高清不卡一二三区| 精品区一区二区| 日韩视频国产视频| 欧美一二三区在线观看| 51精品久久久久久久蜜臀| 欧美在线视频不卡| 欧美日韩视频专区在线播放| 欧洲生活片亚洲生活在线观看| 91麻豆免费看片| 色综合视频在线观看| 色先锋资源久久综合| 一本色道久久加勒比精品| 91麻豆123| 91国偷自产一区二区三区观看| 色婷婷久久综合| 欧美丝袜自拍制服另类| 欧美麻豆精品久久久久久| 欧美一区二区三区视频在线| 欧美欧美午夜aⅴ在线观看| 777a∨成人精品桃花网| 日韩一区二区三区在线观看| 精品国产免费人成电影在线观看四季 | 欧美三级日韩三级| 欧美精品日韩一本| 日韩欧美区一区二| 久久新电视剧免费观看| 国产精品久久免费看| 一区二区国产视频| 日本中文字幕不卡| 国产老肥熟一区二区三区| 精品国产伦一区二区三区观看体验 | 国产成人免费视频网站高清观看视频| 国产成人8x视频一区二区| 波多野结衣视频一区| 欧美最猛黑人xxxxx猛交| 91麻豆精品国产| 久久精品一区八戒影视| 亚洲精品乱码久久久久久| 日韩制服丝袜av| 国产成人精品综合在线观看| 91免费国产视频网站| 在线不卡的av| 国产女主播视频一区二区| 一区二区三区在线免费观看| 日韩精品亚洲专区| 成人午夜视频网站| 欧美乱熟臀69xxxxxx| 国产日韩一级二级三级| 亚洲国产日韩在线一区模特| 国产在线播放一区| 91福利视频网站| 久久色中文字幕| 亚洲国产一区二区在线播放| 精品中文字幕一区二区小辣椒| 成人短视频下载| 欧美一级久久久| 亚洲精品日韩专区silk| 国产在线播放一区三区四| 欧美三级在线视频| 国产日韩精品一区二区三区在线| 亚洲一二三区在线观看| 国产精一品亚洲二区在线视频| 一本高清dvd不卡在线观看| 日韩久久精品一区| 亚洲一区二区成人在线观看| 日本在线不卡视频一二三区| 国产a区久久久| 91精品福利在线一区二区三区| 综合久久久久综合| 精品午夜久久福利影院| 欧美日韩一区中文字幕| 中文字幕色av一区二区三区| 久久99精品久久久久婷婷| 欧美日韩一区二区在线视频| 国产精品国模大尺度视频| 久久成人麻豆午夜电影| 色噜噜狠狠成人中文综合| 欧美—级在线免费片| 久久国产婷婷国产香蕉| 欧美日韩国产中文| 亚洲激情综合网| 成人免费视频一区| 2022国产精品视频| 捆绑变态av一区二区三区| 在线观看日韩av先锋影音电影院| 中文av一区特黄| 国产黄人亚洲片| 欧美精品一区二区三区视频| 日韩专区一卡二卡| 欧美日韩国产综合久久| 亚洲综合无码一区二区| 91尤物视频在线观看| 国产精品久久久久久久久图文区| 国产美女av一区二区三区| 日韩精品一区二区三区在线播放 | 亚洲午夜激情av| 在线免费观看日本欧美| 亚洲男同1069视频| 一本久久a久久精品亚洲| 亚洲视频你懂的| 色综合婷婷久久| 亚洲午夜在线视频| 欧美自拍丝袜亚洲| 午夜电影网亚洲视频| 日本道免费精品一区二区三区| 欧美极品aⅴ影院| 成人app在线观看| 国产精品久久三区| 色综合天天在线| 亚洲一区二区在线播放相泽 | 99国产精品一区| 亚洲视频在线观看一区| 欧美在线免费播放| 天天色天天爱天天射综合| 在线播放欧美女士性生活| 热久久免费视频| 精品国产乱码久久久久久蜜臀| 麻豆精品国产传媒mv男同| 日韩欧美国产一二三区| 国产精品66部| 亚洲欧洲韩国日本视频| 在线精品视频一区二区| 日韩中文字幕亚洲一区二区va在线 | 久久久噜噜噜久久中文字幕色伊伊| 国产精品一线二线三线精华| 国产精品久久免费看| 欧美色爱综合网| 国内一区二区视频| 中文字幕精品一区| 在线精品观看国产| 免费亚洲电影在线| 国产精品午夜电影| 欧洲另类一二三四区| 美女视频黄 久久| 国产亚洲一本大道中文在线| 91最新地址在线播放| 午夜av区久久| 久久精品人人爽人人爽| 91在线视频播放地址| 午夜精品久久久久久| 久久久99久久| 99国产麻豆精品| 丝袜亚洲另类丝袜在线| 久久久久99精品一区| 91啦中文在线观看| 久久精品久久99精品久久| 国产精品美女视频| 69堂精品视频| 成人动漫视频在线| 免费欧美日韩国产三级电影| 国产精品久久久久毛片软件| 欧美人伦禁忌dvd放荡欲情| 韩国女主播一区二区三区| 亚洲日本一区二区三区| 欧美日韩五月天| 成人黄色软件下载| 日日骚欧美日韩| 国产精品麻豆网站| 欧美成人在线直播| 色美美综合视频| 国产成人欧美日韩在线电影| 天堂蜜桃91精品| 国产精品久久久久久久岛一牛影视 | 高清久久久久久| 日韩精品成人一区二区在线| 中文字幕一区三区| 日韩欧美三级在线|