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

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

?? os_cpu_c.c

?? keil編譯器下uocs在lpc2214上的移植
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
*********************************************************************************************************
*                                               uC/OS-II
*                                         The Real-Time Kernel
*
*
*                             (c) Copyright 1992-2007, Micrium, Weston, FL
*                                          All Rights Reserved
*
*                                           Generic ARM Port
*
* File      : OS_CPU_C.C
* Version   : V1.82
* By        : Jean J. Labrosse
*             Jean-Denis Hatier
*
* For       : ARM7 or ARM9
* Mode      : ARM or Thumb
* Toolchain : RealView Development Suite
*             RealView Microcontroller Development Kit (MDK)
*             ARM Developer Suite (ADS)
*             Keil uVision
*********************************************************************************************************
*/


#define  OS_CPU_GLOBALS
#include <ucos_ii.h>

/*$PAGE*/
/*
*********************************************************************************************************
*                                             本地常量
*********************************************************************************************************
*/

#define  ARM_MODE_ARM           0x00000000	 //CPSR位被設置為ARM模式
#define  ARM_MODE_THUMB         0x00000020	 //CPSR位被設置為THUMB模式

#define  ARM_SVC_MODE_THUMB    (0x00000013L + ARM_MODE_THUMB)	 //CPSR位被設置為SVC模式+THUMB模式
#define  ARM_SVC_MODE_ARM      (0x00000013L + ARM_MODE_ARM)		 //CPSR位被設置為SVC模式+ARM模式

#define  OS_NTASKS_FP          (OS_MAX_TASKS + OS_N_SYS_TASKS - 1)	 //有能力處理浮點的任務數
#define  OS_FP_STORAGE_SIZE            128L							 //浮點數存儲空間大小

/*
*********************************************************************************************************
*                                          本地變量
*********************************************************************************************************
*/

#if OS_TMR_EN > 0		 //判斷是否使能時間管理
static  INT16U  OSTmrCtr; //定義時間計數器
#endif

#if OS_CPU_FPU_EN > 0	 //判斷是否使能浮點運算單元(本實例中未使用)
static  OS_MEM  *OSFPPartPtr;//指向保存浮點運算寄存器存儲空間的指針
static  INT32U   OSFPPart[OS_NTASKS_FP][OS_FP_STORAGE_SIZE / sizeof(INT32U)];
#endif

/*$PAGE*/
/*
*********************************************************************************************************
*                                        INITIALIZE FP SUPPORT
*
* 功能描述: 這個函數用來初始化用來保存浮點運算寄存器的那些存儲空間
			在上下文切換的過程中,這個函數必須在OSInit()被調用后調用
			為了能編譯浮點運算模塊必須將 OS_CPU_FPU_EN定義為大于0

*
*入口參數: 無
*
*返回參數: 無
*
注意事項: 1)用到浮點運算功能的任務必須用OSTaskCreateExt()創建。
*         2)對于ARM的浮點協處理器要求用128 bytes來保存浮點協處理器的上下文切換。
*         3)如果你需要從OSStatTaskHook()內部完成浮點運算任務,你必須建立這個statistics任務的時候
			改變OSTaskCreatExt()的屬性選項。這只需要OS_TaskStat()用OSTaskCreateExt()建立。
*********************************************************************************************************
*/

#if OS_CPU_FPU_EN > 0
void  OS_CPU_FP_Init (void)
{
    INT8U    err;
#if OS_TASK_STAT_EN && OS_TASK_CREATE_EXT_EN
    OS_TCB  *ptcb;
    void    *pblk;
#endif


    OSFPPartPtr = OSMemCreate(&OSFPPart[0][0], OS_NTASKS_FP, OS_FP_STORAGE_SIZE, &err);

#if OS_TASK_STAT_EN && OS_TASK_CREATE_EXT_EN                            /* CHANGE 'OPTIONS' for OS_TaskStat()                       */
    ptcb            = OSTCBPrioTbl[OS_TASK_STAT_PRIO];
    ptcb->OSTCBOpt |= OS_TASK_OPT_SAVE_FP;                              /* Allow floating-point support for Statistic task          */
    pblk            = OSMemGet(OSFPPartPtr, &err);                      /* Get storage for VFP registers                            */
    if (pblk != (void *)0) {                                            /* Did we get a memory block?                               */
        ptcb->OSTCBExtPtr = pblk;                                       /* Yes, Link to task's TCB                                  */
        OS_CPU_FP_Save(pblk);                                           /*      Save the VFP registers in block                     */
    }
#endif
}
#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_TMR_EN > 0
    OSTmrCtr = 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)
{
#if OS_CPU_INT_DIS_MEAS_EN > 0
    OS_CPU_IntDisMeasInit();
#endif

#if OS_CPU_FPU_EN > 0
    OS_CPU_FP_Init();                                                   /* Initialize support for VFP register save / restore       */
#endif
}
#endif

/*
*********************************************************************************************************
*                                          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_CPU_FPU_EN > 0
    INT8U  err;
    void  *pblk;
#endif


#if OS_CPU_FPU_EN > 0
    if (ptcb->OSTCBOpt & OS_TASK_OPT_SAVE_FP) {                         /* See if task needs FP support                             */
        pblk = OSMemGet(OSFPPartPtr, &err);                             /* Yes, Get storage for VFP registers                       */
        if (pblk != (void *)0) {                                        /*      Did we get a memory block?                          */
            ptcb->OSTCBExtPtr = pblk;                                   /*      Yes, Link to task's TCB                             */
            OS_CPU_FP_Save(pblk);                                       /*           Save the VFP registers in block                */
        }
    }
#endif

#if OS_APP_HOOKS_EN > 0
    App_TaskCreateHook(ptcb);
#else
    (void)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)
{
#if OS_CPU_FPU_EN > 0
    if (ptcb->OSTCBOpt & OS_TASK_OPT_SAVE_FP) {                         /* See if task had FP support                               */
        if (ptcb->OSTCBExtPtr != (void *)0) {                           /* Yes, OSTCBExtPtr must not be NULL                        */
            OSMemPut(OSFPPartPtr, ptcb->OSTCBExtPtr);                   /*      Return memory block to free pool                    */
        }
    }
#endif

#if OS_APP_HOOKS_EN > 0
    App_TaskDelHook(ptcb);
#else
    (void)ptcb;                                                         /* Prevent compiler warning                                 */
#endif
}
#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)
{
#if OS_CPU_ARM_DCC_EN > 0
    OSDCC_Handler();
#endif

#if OS_APP_HOOKS_EN > 0
    App_TaskIdleHook();
#endif
}
#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)
{
#if OS_APP_HOOKS_EN > 0
    App_TaskStatHook();
#endif
}
#endif

/*
*********************************************************************************************************
*                                        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
*                            a 'free' entry on the task stack.  If OS_STK_GROWTH is set to 1 then
*                            'ptos' will contain the HIGHEST valid address of the stack.  Similarly, if
*                            OS_STK_GROWTH is set to 0, the 'ptos' will contains the LOWEST valid address
*                            of the stack.
*
*              opt           specifies options that can be used to alter the behavior of OSTaskStkInit().
*                            (see uCOS_II.H for OS_TASK_OPT_xxx).
*
* 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)    : 1) Interrupts are enabled when your task starts executing.
*              2) All tasks run in SVC mode.
*********************************************************************************************************
*/

OS_STK *OSTaskStkInit (void (*task)(void *p_arg), void *p_arg, OS_STK *ptos, INT16U opt)
{
    OS_STK *stk;
    INT32U  task_addr;


    opt       = opt;                                                    /* 'opt' is not used, prevent warning                       */
    stk       = ptos;                                                   /* Load stack pointer                                       */
    task_addr = (INT32U)task & ~1;                                      /* Mask off lower bit in case task is thumb mode            */
    *(stk)    = (INT32U)task_addr;                                      /* Entry Point                                              */
    *(--stk)  = (INT32U)0x14141414L;                                    /* R14 (LR)                                                 */
    *(--stk)  = (INT32U)0x12121212L;                                    /* R12                                                      */
    *(--stk)  = (INT32U)0x11111111L;                                    /* R11                                                      */
    *(--stk)  = (INT32U)0x10101010L;                                    /* R10                                                      */
    *(--stk)  = (INT32U)0x09090909L;                                    /* R9                                                       */
    *(--stk)  = (INT32U)0x08080808L;                                    /* R8                                                       */
    *(--stk)  = (INT32U)0x07070707L;                                    /* R7                                                       */
    *(--stk)  = (INT32U)0x06060606L;                                    /* R6                                                       */
    *(--stk)  = (INT32U)0x05050505L;                                    /* R5                                                       */
    *(--stk)  = (INT32U)0x04040404L;                                    /* R4                                                       */
    *(--stk)  = (INT32U)0x03030303L;                                    /* R3                                                       */
    *(--stk)  = (INT32U)0x02020202L;                                    /* R2                                                       */
    *(--stk)  = (INT32U)0x01010101L;                                    /* R1                                                       */
    *(--stk)  = (INT32U)p_arg;                                          /* R0 : argument                                            */
    if ((INT32U)task & 0x01) {                                          /* See if task runs in Thumb or ARM mode                    */
        *(--stk) = (INT32U)ARM_SVC_MODE_THUMB;                          /* CPSR  (Enable both IRQ and FIQ interrupts, THUMB-mode)   */
    } else {
        *(--stk) = (INT32U)ARM_SVC_MODE_ARM;                            /* CPSR  (Enable both IRQ and FIQ interrupts, ARM-mode)     */
    }

    return (stk);
}

/*
*********************************************************************************************************
*                                           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
*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美久久一区| 91精品欧美久久久久久动漫 | 色琪琪一区二区三区亚洲区| 黑人巨大精品欧美黑白配亚洲| 日韩国产欧美三级| 亚洲1区2区3区4区| 日产国产高清一区二区三区| 天天操天天综合网| 国产成人亚洲精品青草天美| 国产一区二区三区av电影 | 久久久不卡网国产精品一区| 久久综合九色综合欧美98 | 日韩伦理电影网| 亚洲欧美在线观看| 亚洲综合图片区| 首页亚洲欧美制服丝腿| 另类小说视频一区二区| 国产精品系列在线播放| 99久久伊人精品| 成人av网站在线观看免费| 91丨九色丨蝌蚪富婆spa| 欧洲视频一区二区| 欧美成人a∨高清免费观看| 久久女同性恋中文字幕| 亚洲美女在线一区| 日韩国产一二三区| 成人av资源在线| 欧美性欧美巨大黑白大战| 91精品一区二区三区在线观看| 久久一区二区视频| **网站欧美大片在线观看| 婷婷国产在线综合| 成人精品一区二区三区四区 | 丁香网亚洲国际| 欧美在线不卡视频| 欧美成人伊人久久综合网| 椎名由奈av一区二区三区| 石原莉奈在线亚洲二区| 成人国产精品视频| 欧美精品乱人伦久久久久久| 日本一区二区不卡视频| 国产一区二区在线影院| 91理论电影在线观看| 欧美成人r级一区二区三区| 亚洲色图制服诱惑| 久久超碰97人人做人人爱| 色婷婷综合视频在线观看| 精品国产一区二区三区av性色| 亚洲欧洲在线观看av| 激情综合色综合久久综合| 色88888久久久久久影院野外| 欧美videos大乳护士334| 亚洲黄网站在线观看| 国产成人一级电影| 精品噜噜噜噜久久久久久久久试看 | 精品视频在线看| 国产精品国产a| 久久99国产精品麻豆| 欧美日韩一区二区欧美激情| 亚洲欧洲成人精品av97| 狠狠色综合日日| 欧美一区二区三区在线视频| 亚洲黄色小说网站| 91丨国产丨九色丨pron| 日本一区二区高清| 国产91丝袜在线18| 国产校园另类小说区| 极品尤物av久久免费看| 日韩欧美亚洲国产精品字幕久久久| 亚洲国产毛片aaaaa无费看| 91视频在线看| 亚洲欧美激情小说另类| 一本久久精品一区二区| 中文字幕五月欧美| 色诱视频网站一区| 亚洲免费观看在线观看| 91视视频在线观看入口直接观看www| 国产精品久久久久久久岛一牛影视| 国产精品88av| 国产精品麻豆一区二区 | 最新国产精品久久精品| av激情亚洲男人天堂| 国产精品国产精品国产专区不片| 成人白浆超碰人人人人| 国产精品色眯眯| 色婷婷一区二区三区四区| 伊人夜夜躁av伊人久久| 欧美日韩aaa| 免费看日韩精品| 精品乱码亚洲一区二区不卡| 国产精品 欧美精品| 国产精品久久久一本精品| 99精品一区二区三区| 一区二区三区色| 91精品国产手机| 国产精品2024| 亚洲免费成人av| 欧美一级欧美三级在线观看| 国产一区二三区| 一区二区在线观看视频| 91精品国产高清一区二区三区 | 国产日本亚洲高清| 色综合天天综合网国产成人综合天| 一区二区三区鲁丝不卡| 欧美一区二区三区四区在线观看 | 亚洲高清一区二区三区| 日韩视频免费观看高清完整版在线观看 | 暴力调教一区二区三区| 亚洲午夜电影网| 久久精品视频在线看| 91久久精品网| 久久福利视频一区二区| 亚洲日穴在线视频| 精品三级av在线| 91日韩精品一区| 久久爱另类一区二区小说| 亚洲三级理论片| 日韩精品一区二区三区在线观看 | 欧美视频你懂的| 国产高清视频一区| 夜夜嗨av一区二区三区四季av | 亚洲一区二三区| 久久久久久亚洲综合影院红桃| 97国产精品videossex| 麻豆精品在线观看| 一区二区三区在线影院| 国产免费观看久久| 日韩欧美一区电影| 欧美亚洲日本一区| 成人精品在线视频观看| 蜜臀av国产精品久久久久| 亚洲线精品一区二区三区| 国产精品视频观看| wwwwww.欧美系列| 欧美福利视频导航| 欧美视频一二三区| 色偷偷久久一区二区三区| 国产精品911| 国产一区二区剧情av在线| 日本不卡一二三| 亚洲高清免费在线| 亚洲一卡二卡三卡四卡无卡久久 | 欧美一区二区在线免费观看| 日本丰满少妇一区二区三区| 国产99久久久国产精品潘金 | 欧美国产日韩一二三区| 欧美大尺度电影在线| 欧美一区二区三区四区视频| 欧美日韩日日摸| 欧美色视频一区| 欧美日韩在线播放一区| 欧洲精品中文字幕| 91国产福利在线| 欧美亚洲日本国产| 欧美乱熟臀69xxxxxx| 欧美日韩免费观看一区二区三区| 色老头久久综合| 欧美在线色视频| 欧美挠脚心视频网站| 欧美日本免费一区二区三区| 51精品视频一区二区三区| 51精品秘密在线观看| 日韩欧美在线观看一区二区三区| 日韩欧美资源站| 久久毛片高清国产| 欧美国产乱子伦| 亚洲欧美日本韩国| 亚洲成人av电影| 久久爱另类一区二区小说| 国产一区二区三区久久久| 成人高清视频在线| 在线影视一区二区三区| 欧美精品一二三四| 精品国产自在久精品国产| 国产欧美日韩在线视频| 亚洲欧洲av在线| 午夜精品久久久久影视| 另类成人小视频在线| 国产69精品久久久久毛片| 色吊一区二区三区| 欧美一区二区三区色| 国产欧美一区二区精品性色| 亚洲欧美日韩国产综合| 亚洲地区一二三色| 国产一区二区三区黄视频 | 国产老女人精品毛片久久| 99久久精品国产一区二区三区 | 成人激情免费视频| 欧美日韩视频在线第一区| 精品国产乱码久久久久久蜜臀| 国产精品丝袜91| 亚洲va韩国va欧美va| 国产乱理伦片在线观看夜一区| 91成人免费在线| 欧美激情中文字幕| 性做久久久久久免费观看| 国产不卡一区视频| 欧美精品在线视频| 18成人在线观看| 国产一区二区影院|