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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? os_cpu_c.c

?? PIC18F452下的uCOS2移植成功代碼+MPLAB IDE V8.0的項(xiàng)目文件。結(jié)構(gòu)非常精簡
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
*********************************************************************************************************
*                                               uC/OS-II
*                                         The Real-Time Kernel
*
*                           (c) Copyright 2002, Nathan Brown, Longview, TX
*                                      http://www.sputnickonline.com/
*                                          All Rights Reserved
*
*                                       PIC18xxxx Specific Code
*                                       V1.00 - October 27, 2002
*
* File : OS_CPU_C.C
* By   : Nathan Brown
*********************************************************************************************************
*/

#define  OS_CPU_GLOBALS
#include "includes.h"

/*
*********************************************************************************************************
*                                        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
*
*              pdata         is a pointer to a user supplied data area that will be passed to the task
*                            when the task first executes.  For the TASKING compiler, 'pdata' is passed
*                            in R1:R0.
*
*              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_???).
*
* 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) Save the current context onto the stack
*
*              3) The return addresses are in a different stack, so save all of those into the stack
*
*              4) The last stacking operation (before the return) places the number of return stack
*                 items in the software stack.
*********************************************************************************************************
*/

OS_STK *OSTaskStkInit (void (*task)(void *pd), void *pdata, OS_STK *ptos, INT16U opt)
{
    OS_STK *stk;

    stk     = ptos;                     // local pointer to our new proccess stack
    *stk++  = (OS_STK)*(((INT8U*)&pdata));  // data being passed
    *stk++  = (OS_STK)*(((INT8U*)&pdata)+1);
    *stk++  = 0xFF;                     // <-- FSR1 Pointer position on function call.
    *stk++  = 0x1A;                     // STATUS register
    *stk++  = 0x1B;                     // BSR register
    *stk++  = 0x1C;                     // W register
    *stk++  = 0x1D;                     // FSR0L register
    *stk++  = 0x1E;                     // FSR0H register
    *stk++  = 0x1F;                     // FSR2L register
    *stk++  = 0x2A;                     // FSR2H register
    *stk++  = 0x2B;                     // TBLPTRL Prog Mem Table Pointer Upper
    *stk++  = 0x2C;                     // TBLPTRH Prog Mem Table Pointer High
    *stk++  = 0x2D;                     // TBLPTRU Prog Mem Table Pointer Low
    *stk++  = 0x2E;                     // PRODL Product Reg high
    *stk++  = 0x2F;                     // PRODH Product Reg low
    *stk++  = 0x3A;						// AARGB3
    *stk++  = 0x3B;						// AARGB2
    *stk++  = 0x3C;						// AARGB1
    *stk++  = 0x3D;						// AARGB0

    // first return address, the task address, goes on the hardware return stack in a context switch
    *stk++  = (OS_STK)*(((INT8U*)&task));   // TOSL - Top of stack - Lower bits
    *stk++  = (OS_STK)*(((INT8U*)&task)+1); // TOSH - Top of stack - High bits
    *stk++  = (OS_STK)*(((INT8U*)&task)+2); // TOSU - Top of stack - Uppre bits
    // repeat...

    *stk++  = 0x01;                     // size of return stack

    return ((OS_STK *)stk);             // Return pointer to task's top-of-stack
}

#if OS_CPU_HOOKS_EN
/*
*********************************************************************************************************
*                                          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.
*********************************************************************************************************
*/
void OSTaskCreateHook(OS_TCB *ptcb)
{
}


/*
*********************************************************************************************************
*                                           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.
*********************************************************************************************************
*/
void OSTaskDelHook (OS_TCB *ptcb)
{
}

/*
*********************************************************************************************************
*                                           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).
*********************************************************************************************************
*/
void OSTaskSwHook (void)
{
	// Clear watch dog timer on context switches.  If enabled, the processor
	// will reset if this does not get called (application frozen).
_asm
	CLRWDT
_endasm
}

/*
*********************************************************************************************************
*                                           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
*********************************************************************************************************
*/
void OSTaskStatHook (void)
{
}

/*
*********************************************************************************************************
*                                               TICK HOOK
*
* Description: This function is called every tick.
*
* Arguments  : none
*
* Note(s)    : 1) Interrupts may or may not be ENABLED during this call.
*********************************************************************************************************
*/
void OSTimeTickHook (void)
{
}



/*
*********************************************************************************************************
*                                           OSTCBInit() HOOK
*
* Description: This function is called by OSTCBInit() 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_VERSION > 203
void OSTCBInitHook(struct os_tcb *ptcb)
{
}
#endif


/*
*********************************************************************************************************
*                                           IDLE TASK HOOK
*
* Description: This function is called by OS_TaskIdle() which is executed whenever no other task is
*              ready to run.  This function can put the CPU to sleep, ready to be woken by an interupt
*              or it can blink a LED to indicate how busy the processor is.
*
* Arguments  : none
*********************************************************************************************************
*/
void OSTaskIdleHook (void)
{
}


/*
*********************************************************************************************************
*                                       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_VERSION > 203
void OSInitHookBegin (void)
{
}
#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_VERSION > 203
void OSInitHookEnd (void)
{
}
#endif


#endif

/*$PAGE*/
/*
*********************************************************************************************************
*                                       START HIGHEST PRIORITY TASK
*
* Description : This function is called by OSStart() to start the highest priority task that was created
*               by your application before calling OSStart().
*
* Arguments   : none
*
* Note(s)     : 1)  Interupts are disabled when calling.
*
*               2) The stack frame (8-bit wide stack) is assumed to look as follows:
*
*                                                                                          LOW MEMORY
*                                           -   23      pdata (lower 8 bits)
*                                           -   22      pdata (upper 8 bits)
*                                           -   21      XX (pointed to by FSR1, frame pointer)
*                                           -   20      STATUS  register
*                                           -   19      BSR     register
*                                           -   18      W       register
*                                           -   17      FSR0L   register
*                                           -   16      FSR0H   register
*                                           -   15      FSR2L   register (frame pointer, low)
*                                           -   14      FSR2H   register (frame pointer, high)
*                                           -   13      TBLPTRL register
*                                           -   12      TBLPTRH register
*                                           -   11      TBLPTRU register
*                                           -   10      PRODL   register

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合视频在线观看| 欧美日韩亚洲国产综合| 国产精品一卡二卡在线观看| 精品亚洲国内自在自线福利| 国产精品亚洲第一区在线暖暖韩国 | 国产成人免费视频网站高清观看视频| 国产成人精品影视| 中文字幕乱码一区二区免费| 国产精品国产自产拍在线| 亚洲国产一区在线观看| 久久99精品久久久久久动态图 | 91精品国模一区二区三区| 日韩一区二区高清| 国产精品久线在线观看| 91精品福利视频| 国产亚洲综合性久久久影院| 亚洲小说欧美激情另类| 欧美日韩卡一卡二| 综合自拍亚洲综合图不卡区| 麻豆精品在线看| 91在线一区二区| 欧美一区二区三区免费视频| 伊人色综合久久天天人手人婷| 久久国产剧场电影| 69久久夜色精品国产69蝌蚪网| 麻豆精品一区二区综合av| 久久久精品日韩欧美| 日韩av不卡在线观看| 91在线看国产| 日韩电影在线观看网站| 日本一区二区综合亚洲| 国产资源在线一区| 日韩欧美激情一区| 人妖欧美一区二区| 7777女厕盗摄久久久| 国产美女精品在线| 久久久久久久综合日本| 在线精品视频免费观看| 亚洲人成网站影音先锋播放| 成人动漫精品一区二区| 精品91自产拍在线观看一区| 午夜伊人狠狠久久| 91激情五月电影| 韩国v欧美v日本v亚洲v| 亚洲欧美日韩国产综合在线| 91精品国产全国免费观看| 99久久亚洲一区二区三区青草| 午夜精品久久久久久久蜜桃app| 欧美日韩国产色站一区二区三区| 国产在线精品一区二区夜色| 亚洲成人在线观看视频| 中文在线资源观看网站视频免费不卡| 欧美日韩黄色影视| 99精品热视频| 国产麻豆日韩欧美久久| 午夜国产不卡在线观看视频| 中文乱码免费一区二区| www.色精品| 一区二区三区欧美| 欧美视频在线一区二区三区 | 欧美一区二区在线免费播放| 91亚洲精品久久久蜜桃| 亚洲图片激情小说| 欧美成人乱码一区二区三区| 国产精品一区二区三区99| 午夜视频在线观看一区二区 | 精品国产乱码久久久久久图片| 欧洲av一区二区嗯嗯嗯啊| 大胆欧美人体老妇| 亚洲一二三四区| 欧美精品粉嫩高潮一区二区| 久久国产乱子精品免费女| 午夜精品一区在线观看| 一区二区三区四区视频精品免费| 中文字幕国产一区二区| 国产日韩精品一区二区三区| 26uuu色噜噜精品一区| 国产成人av一区二区三区在线| 日本不卡高清视频| 日韩成人午夜电影| 日韩精品1区2区3区| 中文字幕第一区第二区| 久久亚洲综合色| 久久网站热最新地址| 精品国产一区二区精华| 欧美一级精品大片| 欧美高清视频在线高清观看mv色露露十八| 91成人免费在线视频| 色噜噜狠狠成人网p站| 91免费观看国产| 日本高清成人免费播放| 在线观看亚洲专区| 欧美日韩高清一区| 91精品蜜臀在线一区尤物| 69堂国产成人免费视频| 日韩欧美的一区二区| 欧美成人vr18sexvr| 精品久久人人做人人爰| 国产亚洲一区二区三区| 欧美经典一区二区三区| 中文字幕一区二区三区在线不卡| 日韩欧美美女一区二区三区| 精品欧美一区二区在线观看| 久久免费电影网| 亚洲欧洲av一区二区三区久久| 有码一区二区三区| 偷偷要91色婷婷| 国产精品一色哟哟哟| 国产成人免费视频网站| 91久久精品一区二区| 日韩欧美国产精品一区| 国产精品水嫩水嫩| 亚洲成av人片在www色猫咪| 老鸭窝一区二区久久精品| 懂色av一区二区三区蜜臀| 麻豆精品国产91久久久久久| 国产一区二区按摩在线观看| 一道本成人在线| 欧美一级黄色片| 日韩理论电影院| 青青草原综合久久大伊人精品 | 理论电影国产精品| 成人18视频日本| 欧美日韩电影在线播放| 久久久精品日韩欧美| 亚洲一区视频在线| 日本美女视频一区二区| 一区二区成人在线| 国内不卡的二区三区中文字幕| 国产一区二区三区免费观看| 成人av片在线观看| 欧美精品日韩一本| 日韩精品一区二区三区视频播放 | 亚洲国产精华液网站w| 国产精品久久久久久久蜜臀| 亚洲丝袜美腿综合| 日本不卡123| 成人免费精品视频| 欧美在线一区二区三区| 精品久久久久久最新网址| 中文字幕亚洲在| 亚洲成人免费观看| 国产一区二区三区高清播放| 在线免费观看一区| 26uuu国产日韩综合| 亚洲大尺度视频在线观看| 国产激情91久久精品导航| 欧美性xxxxxx少妇| 国产亚洲欧美激情| 亚洲成a人在线观看| 91福利资源站| 久久久久久久久久久黄色| 亚洲影院免费观看| 国产69精品久久久久777| 在线亚洲一区二区| 中文字幕亚洲精品在线观看| 蜜臀av一区二区在线观看| 色婷婷综合激情| 国产亚洲午夜高清国产拍精品| 三级久久三级久久久| 99久久精品久久久久久清纯| 日韩视频免费直播| 亚洲自拍欧美精品| av日韩在线网站| 17c精品麻豆一区二区免费| 麻豆免费看一区二区三区| 91国产精品成人| 久久精品夜夜夜夜久久| 日韩av午夜在线观看| 91国偷自产一区二区开放时间 | 亚洲国产综合色| 一本到不卡免费一区二区| 国产清纯在线一区二区www| 美女免费视频一区| 欧美亚洲动漫精品| 一区二区三区自拍| 99精品久久只有精品| 国产亚洲女人久久久久毛片| 久久精品国产精品亚洲精品| 91精品婷婷国产综合久久性色| 日本不卡高清视频| 欧美电影影音先锋| 亚洲国产视频在线| 91.xcao| 亚洲国产另类精品专区| 在线观看av不卡| 依依成人综合视频| 337p亚洲精品色噜噜噜| 亚洲国产美国国产综合一区二区| 欧美主播一区二区三区| 亚洲在线中文字幕| 91精品国产一区二区人妖| 亚洲国产综合在线| 欧美三电影在线| 日韩精品乱码av一区二区| 久久亚洲综合色一区二区三区| 国产成人丝袜美腿| 国产精品国产三级国产普通话99| 成人动漫一区二区| 亚洲a一区二区|