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

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

?? os_cpu_c.c

?? ucos 2.86是目前最高版本
?? 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
*/
#include "ucos_ii.h"
/*
*********************************************************************************************************
*                                        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一区二区三区免费野_久草精品视频
欧美日本在线看| 夜夜嗨av一区二区三区中文字幕| 亚洲麻豆国产自偷在线| 亚洲永久免费av| 国产成人福利片| 欧美一区二区国产| 亚洲国产欧美在线人成| av中文一区二区三区| 欧美mv日韩mv国产| 日本免费新一区视频| 欧美亚洲综合另类| 亚洲欧美日韩一区二区三区在线观看 | 99国产精品99久久久久久| 日韩精品资源二区在线| 视频一区二区欧美| 精品视频1区2区3区| 亚洲精品高清在线观看| 99久久精品费精品国产一区二区| 国产亚洲精久久久久久| 激情综合五月婷婷| 欧美成人aa大片| 免费人成黄页网站在线一区二区| 欧美日韩三级一区二区| 亚洲老司机在线| 91成人免费网站| 一区二区久久久久久| 一本久久a久久免费精品不卡| 日本一区二区不卡视频| 国产高清精品在线| 国产精品视频你懂的| 成人精品免费看| 国产精品热久久久久夜色精品三区 | 久久久精品国产免大香伊| 极品美女销魂一区二区三区| 精品国产麻豆免费人成网站| 久久精品国产99久久6| 日韩女优制服丝袜电影| 国内久久精品视频| 国产日本欧洲亚洲| 不卡av在线网| 亚洲图片欧美视频| 日韩欧美中文一区| 国产成人综合在线| 亚洲欧洲精品天堂一级| 色欧美片视频在线观看| 亚洲第一二三四区| 精品国产凹凸成av人网站| 国产精品一区二区视频| 亚洲欧洲日产国产综合网| 一本久道中文字幕精品亚洲嫩| 一区二区成人在线视频| 日韩一二三四区| 国产精品资源在线观看| 亚洲欧洲av在线| 777久久久精品| 国产精品主播直播| 亚洲自拍偷拍av| 精品国产乱码久久久久久夜甘婷婷| 国产在线精品不卡| 亚洲免费毛片网站| 精品欧美乱码久久久久久1区2区| 成人av网址在线| 日韩精品高清不卡| 国产精品久久精品日日| 欧美精三区欧美精三区| 国产99精品视频| 亚洲午夜成aⅴ人片| 久久精品一区四区| 欧美性xxxxxxxx| 国产成人鲁色资源国产91色综| 一区二区三区成人| 国产日韩在线不卡| 91精品在线观看入口| 99国内精品久久| 国产在线播放一区三区四| 亚洲自拍与偷拍| 国产日韩av一区| 日韩三级.com| 欧美亚一区二区| 成人aa视频在线观看| 麻豆精品一区二区三区| 亚洲一区二区三区四区在线观看 | 狠狠色伊人亚洲综合成人| 亚洲欧美日韩国产一区二区三区| 欧美v日韩v国产v| 欧美人狂配大交3d怪物一区| av亚洲精华国产精华精华| 国内精品久久久久影院色| 午夜精品久久久久久久蜜桃app| 中文字幕精品三区| 欧美精品一区二区三区蜜桃| 欧美精品自拍偷拍动漫精品| 色播五月激情综合网| 99re这里都是精品| 粉嫩aⅴ一区二区三区四区| 久久成人久久鬼色| 美女脱光内衣内裤视频久久影院| 亚洲va韩国va欧美va精品| 综合久久久久综合| 国产精品美女久久福利网站| 国产日韩欧美在线一区| 久久婷婷久久一区二区三区| 日韩一级片网址| 欧美一卡二卡三卡| 日韩欧美一级片| 欧美一级黄色片| 日韩精品一区二区三区在线| 欧美一区国产二区| 日韩午夜小视频| 精品久久一二三区| 久久无码av三级| 26uuu精品一区二区三区四区在线| 欧美一二三区在线观看| 精品免费国产二区三区| 精品理论电影在线| 久久综合国产精品| 国产婷婷色一区二区三区四区| 久久九九全国免费| 亚洲欧洲日韩一区二区三区| 亚洲色图欧美在线| 亚洲午夜成aⅴ人片| 日韩不卡一二三区| 国产在线播放一区二区三区| 国产成人综合网| 91浏览器入口在线观看| 在线免费精品视频| 日韩一区二区三区免费观看| 欧美大胆人体bbbb| 欧美高清在线精品一区| 亚洲最大的成人av| 蜜桃91丨九色丨蝌蚪91桃色| 国产精品综合在线视频| 91麻豆国产福利在线观看| 91久久免费观看| 欧美一级高清片在线观看| 精品国产a毛片| 亚洲视频一区二区在线观看| 亚洲chinese男男1069| 韩国理伦片一区二区三区在线播放 | 欧美猛男超大videosgay| 欧美美女喷水视频| 国产肉丝袜一区二区| 一区二区三区免费观看| 麻豆视频观看网址久久| 成人app在线观看| 欧美日韩aaaaaa| 国产精品私人自拍| 日韩中文字幕麻豆| www.爱久久.com| 日韩精品中文字幕一区二区三区| 中文av一区二区| 美女一区二区视频| 色婷婷综合久色| 久久精品一区四区| 日本中文字幕不卡| 97精品视频在线观看自产线路二| 欧美一级一区二区| 亚洲精品自拍动漫在线| 国内外成人在线| 欧美喷潮久久久xxxxx| 中文在线一区二区| 久久av老司机精品网站导航| 色婷婷精品久久二区二区蜜臀av | 色婷婷av久久久久久久| 2023国产精华国产精品| 亚洲成人av一区| 91蜜桃在线免费视频| 国产亚洲一区二区在线观看| 亚洲成av人片在线观看| 91麻豆视频网站| 国产三级精品在线| 久久99久久99| 欧美一区二区三区在线观看 | 欧美一级国产精品| 亚洲一区二区三区视频在线播放 | 欧美一区二区三区小说| 一区二区三区高清| 色婷婷久久综合| 亚洲色图欧美在线| 99精品视频在线观看免费| 国产亚洲欧美日韩在线一区| 日本色综合中文字幕| 欧美日韩极品在线观看一区| 一区二区三区中文免费| 91香蕉视频mp4| 亚洲欧洲日产国码二区| 成人aa视频在线观看| 中文字幕精品一区二区精品绿巨人| 裸体健美xxxx欧美裸体表演| 欧美高清视频在线高清观看mv色露露十八| 中文字幕一区二区三| 粉嫩av一区二区三区| 国产精品毛片无遮挡高清| 成人免费视频一区| 中文天堂在线一区| 91伊人久久大香线蕉| 一区二区三区中文免费| 欧美偷拍一区二区| 日韩激情视频在线观看| 欧美一区二区三区视频在线|