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

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

?? os_cpu_c.c

?? 這是AVR單片機移植UCOS
?? C
字號:
/*
*********************************************************************************************************
*                                              uC/OS-II
*                                        The Real-Time Kernel
* 
*                                       ATmega128 Specific code
*
* File     : OS_CPU_C.C
* By       : Jean J. Labrosse
*********************************************************************************************************
*/

#define   OS_CPU_GLOBALS
#include  <ucos_ii.h>

#if       OS_VIEW_MODULE > 0
#include  <OS_VIEWc.H>
#include  <OS_VIEW.H>
#endif

/*
*********************************************************************************************************
*                                        LOCAL GLOBAL VARIABLES
*********************************************************************************************************
*/

#if OS_VERSION >= 281 && OS_TMR_EN > 0
static  INT16U  OSTmrCtr;
#endif

/*
*********************************************************************************************************
*                                       OS INITIALIZATION HOOK
*                                            (BEGINNING)
*
* Description: This function is called by OSInit() at the beginning of OSInit().
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts should be disabled during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 && OS_VERSION > 203
void  OSInitHookBegin (void)
{
#if OS_VERSION >= 281 && OS_TMR_EN > 0
    OS_CPU_TmrCtr = 0;
#endif
}
#endif

/*
*********************************************************************************************************
*                                       OS INITIALIZATION HOOK
*                                               (END)
*
* Description: This function is called by OSInit() at the end of OSInit().
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts should be disabled during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 && OS_VERSION > 203
void  OSInitHookEnd (void)
{
}
#endif

/*$PAGE*/
/*
*********************************************************************************************************
*                                          TASK CREATION HOOK
*
* Description: This function is called when a task is created.
*
* Arguments  : ptcb   is a pointer to the task control block of the task being created.
*
* Note(s)    : 1) Interrupts are disabled during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 
void  OSTaskCreateHook (OS_TCB *ptcb)
{
#if OS_VIEW_MODULE > 0
    OSView_TaskCreateHook(ptcb);
#else
    ptcb = ptcb;                       /* Prevent compiler warning                                     */
#endif
}
#endif


/*
*********************************************************************************************************
*                                           TASK DELETION HOOK
*
* Description: This function is called when a task is deleted.
*
* Arguments  : ptcb   is a pointer to the task control block of the task being deleted.
*
* Note(s)    : 1) Interrupts are disabled during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 
void  OSTaskDelHook (OS_TCB *ptcb)
{
    ptcb = ptcb;                       /* Prevent compiler warning                                     */
}
#endif

/*
*********************************************************************************************************
*                                             IDLE TASK HOOK
*
* Description: This function is called by the idle task.  This hook has been added to allow you to do  
*              such things as STOP the CPU to conserve power.
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts are enabled during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 && OS_VERSION >= 251
void  OSTaskIdleHook (void)
{
}
#endif

/*
*********************************************************************************************************
*                                           STATISTIC TASK HOOK
*
* Description: This function is called every second by uC/OS-II's statistics task.  This allows your 
*              application to add functionality to the statistics task.
*
* Arguments  : none
*********************************************************************************************************
*/

#if OS_CPU_HOOKS_EN > 0 
void  OSTaskStatHook (void)
{
}
#endif

/*$PAGE*/
/*
**********************************************************************************************************
*                                       INITIALIZE A TASK'S STACK
*
* Description: This function is called by either OSTaskCreate() or OSTaskCreateExt() to initialize the
*              stack frame of the task being created. This function is highly processor specific.
*
* Arguments  : task          is a pointer to the task code
*
*              p_arg         is a pointer to a user supplied data area that will be passed to the task
*                            when the task first executes.
*
*              ptos          is a pointer to the top of stack. It is assumed that 'ptos' points to the
*                            highest valid address on the stack.
*
*              opt           specifies options that can be used to alter the behavior of OSTaskStkInit().
*                            (see uCOS_II.H for OS_TASK_OPT_???).
*
* Returns    : Always returns the location of the new top-of-stack' once the processor registers have
*              been placed on the stack in the proper order.
*
* Note(s)    : Interrupts are enabled when your task starts executing. You can change this by setting the
*              SREG to 0x00 instead. In this case, interrupts would be disabled upon task startup. The
*              application code would be responsible for enabling interrupts at the beginning of the task
*              code. You will need to modify OSTaskIdle() and OSTaskStat() so that they enable interrupts.
*              Failure to do this will make your system crash!
*
*              The AVR return stack is placed OS_TASK_HARD_STK_SIZE bytes before the bottom of the task's
*              stack.
*
*              (1) IMPORTANT: The ICC compiler handles function pointers by actually passing the pointer
*                             to a location in Flash that actually contains the pointer to the function.
*
*              (2) IMPORTANT: You MUST set OSTaskStkSize and OSTaskStkSizeHard BEFORE calling OSInit()
*                             to initialize the Idle and statistic tasks stacks.
**********************************************************************************************************
*/

OS_STK  *OSTaskStkInit (void (*task)(void *pd), void *p_arg, OS_STK *ptos, INT16U opt)
{
    INT8U  *psoft_stk;
    INT8U  *phard_stk;                      /* Temp. variable used for setting up AVR hardware stack    */
    INT16U  tmp;


    (void)opt;                              /* 'opt' is not used, prevent warning                       */
    psoft_stk    = (INT8U *)ptos;
    phard_stk    = (INT8U *)ptos
                 - OSTaskStkSize            /* Task stack size                                          */
                 + OSTaskStkSizeHard;       /* AVR return stack ("hardware stack")                      */

    tmp          = *(INT16U const *)task;   /* (1) ICC compiler handles function pointers indirectly!   */

    *phard_stk-- = (INT8U)(tmp & 0xFF);     /* Put task start address on top of "hardware stack"        */
    tmp        >>= 8;
    *phard_stk-- = (INT8U)(tmp & 0xFF);

    *psoft_stk-- = (INT8U)0x00;             /* R0    = 0x00                                             */
    *psoft_stk-- = (INT8U)0x01;             /* R1    = 0x01                                             */
    *psoft_stk-- = (INT8U)0x02;             /* R2    = 0x02                                             */
    *psoft_stk-- = (INT8U)0x03;             /* R3    = 0x03                                             */
    *psoft_stk-- = (INT8U)0x04;             /* R4    = 0x04                                             */
    *psoft_stk-- = (INT8U)0x05;             /* R5    = 0x05                                             */
    *psoft_stk-- = (INT8U)0x06;             /* R6    = 0x06                                             */
    *psoft_stk-- = (INT8U)0x07;             /* R7    = 0x07                                             */
    *psoft_stk-- = (INT8U)0x08;             /* R8    = 0x08                                             */
    *psoft_stk-- = (INT8U)0x09;             /* R9    = 0x09                                             */
    *psoft_stk-- = (INT8U)0x10;             /* R10   = 0x10                                             */
    *psoft_stk-- = (INT8U)0x11;             /* R11   = 0x11                                             */
    *psoft_stk-- = (INT8U)0x12;             /* R12   = 0x12                                             */
    *psoft_stk-- = (INT8U)0x13;             /* R13   = 0x13                                             */
    *psoft_stk-- = (INT8U)0x14;             /* R14   = 0x14                                             */
    *psoft_stk-- = (INT8U)0x15;             /* R15   = 0x15                                             */
    tmp          = (INT16U)p_arg;
    *psoft_stk-- = (INT8U)(tmp & 0xFF);     /* 'p_arg' passed in R17:R16                                */
    tmp        >>= 8;
    *psoft_stk-- = (INT8U)(tmp & 0xFF);
    *psoft_stk-- = (INT8U)0x18;             /* R18   = 0x18                                             */
    *psoft_stk-- = (INT8U)0x19;             /* R19   = 0x19                                             */
    *psoft_stk-- = (INT8U)0x20;             /* R20   = 0x20                                             */
    *psoft_stk-- = (INT8U)0x21;             /* R21   = 0x21                                             */
    *psoft_stk-- = (INT8U)0x22;             /* R22   = 0x22                                             */
    *psoft_stk-- = (INT8U)0x23;             /* R23   = 0x23                                             */
    *psoft_stk-- = (INT8U)0x24;             /* R24   = 0x24                                             */
    *psoft_stk-- = (INT8U)0x25;             /* R25   = 0x25                                             */
    *psoft_stk-- = (INT8U)0x26;             /* R26   = 0x26                                             */
    *psoft_stk-- = (INT8U)0x27;             /* R27   = 0x27                                             */
                                            /* R28     R29:R28 is the software stack which gets ...     */
                                            /* R29     ... stored in the task's OS_TCB.                 */
    *psoft_stk-- = (INT8U)0x30;             /* R30   = 0x30                                             */
    *psoft_stk-- = (INT8U)0x31;             /* R31   = 0x31                                             */
    *psoft_stk-- = (INT8U)0xAA;             /* RAMPZ = 0xAA                                             */
    *psoft_stk-- = (INT8U)0x80;             /* SREG  = Interrupts enabled                               */
    tmp          = (INT16U)phard_stk;
    *psoft_stk-- = (INT8U)(tmp >> 8);       /* SPH                                                      */
    *psoft_stk   = (INT8U) tmp;             /* SPL                                                      */
    return ((OS_STK *)psoft_stk);
}

/*$PAGE*/
/*
*********************************************************************************************************
*                                           TASK SWITCH HOOK
*
* Description: This function is called when a task switch is performed.  This allows you to perform other
*              operations during a context switch.
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts are disabled during this call.
*              2) It is assumed that the global pointer 'OSTCBHighRdy' points to the TCB of the task that
*                 will be 'switched in' (i.e. the highest priority task) and, 'OSTCBCur' points to the 
*                 task being switched out (i.e. the preempted task).
*********************************************************************************************************
*/
#if (OS_CPU_HOOKS_EN > 0) && (OS_TASK_SW_HOOK_EN > 0)
void  OSTaskSwHook (void)
{
#if OS_VIEW_MODULE > 0
    OSView_TaskSwHook();
#endif
}
#endif

/*
*********************************************************************************************************
*                                           OS_TCBInit() HOOK
*
* Description: This function is called by OS_TCBInit() after setting up most of the TCB.
*
* Arguments  : ptcb    is a pointer to the TCB of the task being created.
*
* Note(s)    : 1) Interrupts may or may not be ENABLED during this call.
*********************************************************************************************************
*/
#if OS_CPU_HOOKS_EN > 0 && OS_VERSION > 203
void  OSTCBInitHook (OS_TCB *ptcb)
{
    ptcb = ptcb;                                           /* Prevent Compiler warning                 */
}
#endif


/*
*********************************************************************************************************
*                                               TICK HOOK
*
* Description: This function is called every tick.
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts may or may not be ENABLED during this call.
*********************************************************************************************************
*/
#if (OS_CPU_HOOKS_EN > 0) && (OS_TIME_TICK_HOOK_EN > 0)
void  OSTimeTickHook (void)
{
#if OS_VIEW_MODULE > 0
    OSView_TickHook();
#endif

#if OS_VERSION >= 281 && OS_TMR_EN > 0
    OSTmrCtr++;
    if (OSTmrCtr >= (OS_TICKS_PER_SEC / OS_TMR_CFG_TICKS_PER_SEC)) {
        OSTmrCtr = 0;
        OSTmrSignal();
    }
#endif
}
#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91视频在线看| 欧美久久久久久蜜桃| 成人黄页在线观看| 一本到不卡精品视频在线观看| 91黄色激情网站| 欧美成人a视频| 国产精品久久久久aaaa樱花| 天天综合天天做天天综合| 国产一区日韩二区欧美三区| 91浏览器在线视频| 欧美主播一区二区三区美女| 久久久久久久综合日本| 亚洲午夜国产一区99re久久| 国产精品一区免费视频| 在线观看国产91| 精品福利视频一区二区三区| 亚洲美女区一区| 亚洲精品视频免费观看| 久久99久国产精品黄毛片色诱| 色又黄又爽网站www久久| 精品久久久三级丝袜| 一区二区三区精品| 国产一区二区在线电影| 精品视频1区2区3区| 日韩免费在线观看| 亚洲成人av一区| 91小视频在线免费看| 精品播放一区二区| 性久久久久久久| 99九九99九九九视频精品| 精品国产免费一区二区三区香蕉| 亚洲综合丝袜美腿| 91香蕉视频在线| 国产精品国模大尺度视频| 奇米四色…亚洲| 欧美福利电影网| 亚洲二区视频在线| 色婷婷综合久色| 国产精品家庭影院| 国产精品自在欧美一区| 日韩一区二区三区四区| 天堂久久久久va久久久久| 欧美伊人久久久久久午夜久久久久| 国产精品久久一级| 成人aa视频在线观看| 国产日产欧美一区| 国产精品一级在线| www一区二区| 国模无码大尺度一区二区三区| 日韩一级完整毛片| 亚洲成人综合视频| 欧美日韩在线亚洲一区蜜芽| 亚洲夂夂婷婷色拍ww47 | 国产欧美日韩亚州综合| 日本不卡一区二区三区高清视频| 欧美体内she精高潮| 亚洲午夜三级在线| 欧美精品tushy高清| 婷婷成人综合网| 日韩精品一区二区三区在线| 蜜臀av一区二区| 国产日韩精品视频一区| www.日韩大片| ...av二区三区久久精品| 成年人网站91| 一个色在线综合| 欧美色图在线观看| 人人狠狠综合久久亚洲| 日韩一区二区三区观看| 九色综合狠狠综合久久| 国产香蕉久久精品综合网| 成人精品国产一区二区4080| 日韩美女精品在线| 欧美视频在线一区二区三区| 视频一区欧美日韩| 久久这里只有精品6| 99久久99久久精品免费看蜜桃| 国产欧美日韩在线| 色8久久精品久久久久久蜜| 亚洲高清久久久| 久久综合九色综合97婷婷女人| 不卡影院免费观看| 天天射综合影视| 欧美经典一区二区| 一本大道久久a久久精品综合| 日韩电影在线观看网站| 国产亚洲欧美色| 欧美日韩一区国产| 国产乱子轮精品视频| 亚洲免费观看高清完整| 欧美一区二区观看视频| 免费成人美女在线观看.| 国产精品午夜免费| 91精品国产福利在线观看| 成人一区在线看| 麻豆成人免费电影| 亚洲色图一区二区| 久久只精品国产| 欧美亚洲动漫精品| 粉嫩13p一区二区三区| 日韩一区精品视频| 中文字幕亚洲区| 精品少妇一区二区三区日产乱码| 91麻豆自制传媒国产之光| 男女男精品视频| 亚洲一区在线播放| 欧美一级淫片007| 色综合久久中文综合久久97 | 91精品国产欧美一区二区18 | 国产日韩欧美激情| 欧美精品一区二区三区一线天视频| 欧美日韩成人在线| 欧美精品在欧美一区二区少妇| 欧洲日韩一区二区三区| 色婷婷国产精品| 色综合天天综合网国产成人综合天| 成人免费视频一区二区| 成人丝袜18视频在线观看| 国产不卡视频在线观看| 福利一区二区在线| 成人精品免费看| 成人的网站免费观看| 99久久综合99久久综合网站| 97久久久精品综合88久久| 91网站在线播放| 欧洲国产伦久久久久久久| 色网综合在线观看| 欧美日韩亚洲综合一区二区三区| 51午夜精品国产| 精品日本一线二线三线不卡| 久久久噜噜噜久噜久久综合| 国产拍揄自揄精品视频麻豆| 中文字幕视频一区二区三区久| 亚洲精选视频在线| 午夜成人免费电影| 久久成人综合网| 成人av资源下载| 精品视频999| 久久综合色综合88| 综合激情网...| 亚洲成人av电影在线| 精品在线播放免费| 成人精品gif动图一区| 欧美在线观看一二区| 欧美成人女星排名| 亚洲视频一区在线| 日本不卡一二三| av一本久道久久综合久久鬼色| 欧美写真视频网站| 欧美精品一区二区三区在线 | 日本福利一区二区| 欧美一级一级性生活免费录像| 欧美国产欧美综合| 亚洲一二三四久久| 欧美日韩中文一区| 欧美精品一区二区三区蜜桃视频| 中文字幕免费在线观看视频一区| 亚洲精品免费在线观看| 久久国产欧美日韩精品| 91蜜桃免费观看视频| 欧美成人三级电影在线| 一区二区三区在线免费观看| 精品亚洲porn| 欧美日韩国产免费| 亚洲国产精品成人久久综合一区 | 久久国产精品99精品国产 | 国产裸体歌舞团一区二区| 欧美影院一区二区三区| 中文字幕va一区二区三区| 丝袜亚洲另类欧美| 一本色道久久加勒比精品| 精品欧美一区二区在线观看| 亚洲国产综合色| voyeur盗摄精品| 久久久精品tv| 青青草原综合久久大伊人精品 | 激情小说欧美图片| 欧美色电影在线| 亚洲女爱视频在线| 大尺度一区二区| 久久综合精品国产一区二区三区| 亚洲午夜在线视频| 色狠狠桃花综合| 亚洲男人天堂一区| 成人av午夜影院| 欧美国产欧美综合| 国产成人av网站| 久久精品亚洲国产奇米99| 美女视频一区在线观看| 欧美区视频在线观看| 亚洲自拍偷拍av| 欧美怡红院视频| 亚洲国产wwwccc36天堂| 欧美在线免费播放| 一区二区三区色| 欧美综合在线视频| 亚洲一二三区不卡| 欧美日韩一区二区三区视频| 亚洲高清免费观看| 欧美肥大bbwbbw高潮|