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

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

?? os_cpu_c.c

?? The uC OS-II port for Keil C V6.20, V6.21 or higher
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
*********************************************************************************************************
*                                               uC/OS-II
*                                         The Real-Time Kernel
*
*                        (c) Copyright 1992-1998, Jean J. Labrosse, Plantation, FL
*                                          All Rights Reserved
*
*
*                                       80x86/80x88 Specific code
*                                          LARGE MEMORY MODEL
*
* File : OS_CPU_C.C
* By   : Jean J. Labrosse
*
* Ported date:     Dec 2, 2001
* By:              John X. Liu, China, (johnxliu@163.com)
* Target platform: Keil C51 V6.20
*         
* Revision:        
*     DEC 5, 2001  Add supports for uC/OS II V2.51
*                  Changed the context saving sequence so that the ISRs can be writen in c language.
*                  and now, the OSTickISR and a serial interrupt sample have been included in this file
*                  to show how to write ISRs in c and keep compatible with uC/OS II.
*********************************************************************************************************
*/

#define  OS_CPU_GLOBALS
#include "includes.h"
#include "os_kcdef.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.
*
*              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)    : Interrupts are enabled when your task starts executing. You can change this by setting the
*              PSW to 0x0002 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 stack variable points to the start pointer in hardware stack and is defined in OS_CPU_A */
extern idata unsigned char Stack[1];

OS_STK *OSTaskStkInit (void (*task)(void *pd) KCREENTRANT, void * vd, OS_STK *ptos, INT16U opt) KCREENTRANT
{
    INT8U * stk;

    opt    = opt;                           /* 'opt' is not used, prevent warning                      */
    stk    = (INT8U *) ptos;                /* Load stack pointer                                      */

	stk				-= sizeof(void *);		/* Save the vd to external stack */
	*(void**)stk	 = vd;                  /*                               */

	stk				-= sizeof(INT16U);      /* The value should be loaded to PC    */
	*(INT16U*)stk	 = (INT16U) task;       /* next time when this task is running */

	stk				-= sizeof(INT16U);      /* The value should be loaded to PC    */
	*(INT16U*)stk	 = (INT16U) task;       /* next time when this task is running */

/* Following is the registers pushed into hardware stack */
	*--stk			 = 'A';                 /* ACC */
	*--stk			 = 'B';                 /* B   */
	*--stk			 = 'H';                 /* DPH */
	*--stk			 = 'L';                 /* DPL */
	*--stk			 = PSW;					/* PSW */
	*--stk			 = 0;                   /* R0  */
/*
	*--stk			 = 1;                   // should be R1
	*--stk			 = 2;                   // should be R2
	*--stk			 = 3;                   // should be R3
*/
	stk				-= sizeof(void *);      /* Keil C uses R1,R2,R3 to pass the */
	*(void**)stk	 = vd;                  /* arguments of functions.          */

	*--stk			 = 4;                   /* R4  */
	*--stk			 = 5;                   /* R5  */
	*--stk			 = 6;                   /* R6  */
	*--stk			 = 7;                   /* R7  */

    *--stk           = 0x80;                /* IE, EA is enabled  */
/*
    Next is calculating the hardware stack pointer.
*/
    *--stk			 = (INT8U) Stack-1      /* Initial value when main was called    */
	                   +1                   /* IE */
	                   +8                   /* R0-R7, eight registers was saved      */
                       +5                   /* PSW, ACC, B, DPH, DPL, five registers */
                       +sizeof(INT16U)      /* The PC value to be loaded             */
                       +sizeof(INT16U)      /* The PC value to be loaded             */
					   ;

    return ((void *)stk);
}

OS_EXT  OS_TCB      *OSTCBHighRdy;                    /* Pointer to highest priority TCB ready to run  */

void LoadCtx() KCREENTRANT;   /* Save the current working registers to stack, defined in OS_CPU_A.ASM */

extern INT8U xdata * data C_XBP;

/*
***********************************************************************************************************
* OSStartHighRdy: START MULTITASKING
*     
* Duty:     a) Call OSTaskSwHook() then,
*           b) Set OSRunning to TRUE,
*           c) Switch to the highest priority task.
*
***********************************************************************************************************
*/
void OSStartHighRdy(void) KCREENTRANT
{
    OSTaskSwHook();
	OSRunning=1;

	C_XBP=OSTCBHighRdy->OSTCBStkPtr;

	LoadCtx();
}

/**********************************************************************************************************
* C_OSCtxSw is the c part of OSCtxSw.
* When control passes to this function, the processor registers have been saved in external stack
***********************************************************************************************************/
void C_OSCtxSw(void) KCREENTRANT
{
/*	Save processor registers; DONE in the OSCtxSw part in OS_CPU_ASM.ASM                                  */

/*	Save the current task's stack pointer into the current task's OS_TCB:  
		OSTCBCur->OSTCBStkPtr = Stack pointer;
	Call user definable OSTaskSwHook();                                    
	OSTCBCur  = OSTCBHighRdy;                                              
	OSPrioCur = OSPrioHighRdy;                                             
	Get the stack pointer of the task to resume:                           
		Stack pointer = OSTCBHighRdy->OSTCBStkPtr;
	Restore all processor registers from the new task's stack;             
	Execute a return from interrupt instruction;                           */

    OSTCBCur->OSTCBStkPtr = C_XBP;
    
	OSTaskSwHook();
    OSTCBCur  = OSTCBHighRdy;
    OSPrioCur = OSPrioHighRdy;

    C_XBP       = OSTCBCur->OSTCBStkPtr;
    LoadCtx();
}

INT8U data SaveSP;

void OSIntCtxSw(void) KCREENTRANT
{
#pragma ASM
	CLR	EA
    MOV	SP, SaveSP
#pragma ENDASM

    C_XBP=OSTCBCur->OSTCBStkPtr;

#pragma ASM
	EXTRN   CODE(_?KCOSCtxSw)
	MOV		A, #LOW  _?KCOSCtxSw
	PUSH	ACC
	MOV		A, #HIGH _?KCOSCtxSw
	PUSH	ACC
	RETI
#pragma ENDASM
}

void UserTickTimer(void) KCREENTRANT;

unsigned char data TickCounter;
unsigned char data OSTickRate;

/* OSTickISR can be writen in c language now, so it is more easy for user to write code for their own */
void OSTickISR(void) interrupt 1
{
    if(TickCounter++!=OSTickRate)
	    return;

    TickCounter=0;

    OSIntEnter();					/* Must be called first at every hardware interrupt entry point */
    if(OSIntNesting==1)
	{
#pragma ASM
		PUSH IE
		CLR	 EA
		MOV	 SaveSP, SP
#pragma ENDASM
		EA=0;
        OSTCBCur->OSTCBStkPtr=C_XBP;	/* OSTCBCur->OSTCBStkPtr is free now, so it can be used to story the value of SP */
    }
    UserTickTimer();				/* User functions can be called here. */
   	OSTimeTick();					/* Must be called during tick isr */
   	OSIntExit();					/* Must be called finally at every hardware interupt exit point */
    if(OSIntNesting==0)
	{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品久久综合| 狠狠色狠狠色综合日日91app| 日韩欧美一区二区视频| 欧美天堂一区二区三区| 一本大道综合伊人精品热热| 91香蕉视频在线| 色欧美片视频在线观看| 91久久精品一区二区二区| 在线影视一区二区三区| 91福利在线免费观看| 欧美色图12p| 日韩亚洲电影在线| 精品99999| 中文字幕第一区综合| 亚洲私人影院在线观看| 天堂久久一区二区三区| 久久精品国产99国产精品| 国产在线视频一区二区三区| 丁香五精品蜜臀久久久久99网站| 99在线精品免费| 91精品国产综合久久精品app| 日韩一区二区三区视频在线观看| 国产亚洲一二三区| 亚洲综合在线第一页| 日韩av中文字幕一区二区| 福利一区福利二区| 欧洲一区在线电影| 欧美xxxxx裸体时装秀| 国产精品成人网| 午夜精品视频在线观看| 国产激情偷乱视频一区二区三区| 欧美性猛片xxxx免费看久爱| 国产欧美一区二区精品仙草咪| 中文字幕一区在线| 日韩精品色哟哟| 99re66热这里只有精品3直播| 欧美日韩日本视频| 中文字幕不卡在线播放| 性久久久久久久| 成人国产精品免费观看动漫| 这里只有精品99re| 亚洲免费毛片网站| 国产成人午夜视频| 91精品国产色综合久久不卡蜜臀| 中文字幕在线播放不卡一区| 极品少妇xxxx精品少妇| 欧美色窝79yyyycom| 国产精品毛片大码女人 | 久久99热国产| 91在线观看高清| 久久丝袜美腿综合| 免费观看30秒视频久久| 欧美午夜不卡在线观看免费| 国产女人18毛片水真多成人如厕| 久久成人精品无人区| 欧美精三区欧美精三区| 亚洲激情第一区| 成人深夜福利app| 久久精品男人的天堂| 久久精品国产一区二区三| 欧美日韩美少妇| 亚洲123区在线观看| 91麻豆产精品久久久久久| 国产欧美一区在线| 国产自产v一区二区三区c| 日韩三级视频在线观看| 日韩不卡在线观看日韩不卡视频| 在线观看国产91| 亚洲国产成人精品视频| 91视视频在线直接观看在线看网页在线看| 精品国产伦一区二区三区观看方式| 丝袜a∨在线一区二区三区不卡| 欧洲精品一区二区| 亚洲成人av电影在线| 91精品国产综合久久国产大片 | 久久夜色精品一区| 久久99日本精品| 欧美一级二级在线观看| 99久久精品国产毛片| 久久久久久久国产精品影院| 久久99热国产| 国产偷v国产偷v亚洲高清| 国产一区二区三区免费看| 精品久久久久久综合日本欧美 | 色成人在线视频| 亚洲尤物在线视频观看| 欧美三级日韩三级| 肉色丝袜一区二区| 欧美草草影院在线视频| 国产一区二三区好的| 中文一区在线播放| 一本色道久久综合狠狠躁的推荐| 亚洲国产一区二区三区| 91精品一区二区三区在线观看| 精品一区二区三区的国产在线播放 | 国产麻豆午夜三级精品| 国产精品久久久久久久久快鸭 | 亚洲va国产va欧美va观看| 欧美一卡在线观看| 国产经典欧美精品| 亚洲伦在线观看| 精品日韩欧美一区二区| www.成人在线| 美女国产一区二区| 国产精品免费av| 69堂亚洲精品首页| 国产成人一区二区精品非洲| 亚洲男人天堂av网| 欧美mv日韩mv国产网站app| av一区二区三区| 日韩精品乱码免费| 国产精品不卡在线观看| 日韩视频免费观看高清在线视频| 成人激情黄色小说| 美女性感视频久久| 一区二区在线观看免费视频播放| 777色狠狠一区二区三区| k8久久久一区二区三区| 国内精品第一页| 天堂蜜桃一区二区三区| 亚洲欧美日韩久久精品| 精品国产伦一区二区三区观看体验| 色婷婷综合中文久久一本| 精品一区二区在线播放| 亚洲成人1区2区| 成人免费在线视频观看| 久久久久国产精品人| 91麻豆精品国产91久久久| 91色在线porny| 粉嫩欧美一区二区三区高清影视| 另类专区欧美蜜桃臀第一页| 亚洲一区在线视频| 亚洲欧美日韩国产成人精品影院| 久久久五月婷婷| 日韩欧美一级在线播放| 欧美日韩亚洲丝袜制服| 欧洲视频一区二区| 色999日韩国产欧美一区二区| 国产精品乡下勾搭老头1| 精品夜夜嗨av一区二区三区| 日韩高清在线观看| 石原莉奈一区二区三区在线观看 | 国产亚洲1区2区3区| 欧美大胆一级视频| 日韩精品专区在线| 日韩一区二区三区视频在线观看| 欧美精品精品一区| 欧美午夜精品理论片a级按摩| 91麻豆免费看片| 色又黄又爽网站www久久| 97精品国产97久久久久久久久久久久 | 亚洲成av人影院在线观看网| 一区二区三区电影在线播| 中文字幕一区二区不卡| 综合分类小说区另类春色亚洲小说欧美 | 中文字幕在线免费不卡| 国产精品久久久久久一区二区三区| 久久精品一区二区三区av| 久久先锋影音av鲁色资源网| 精品盗摄一区二区三区| 亚洲国产精品ⅴa在线观看| 国产日本亚洲高清| 亚洲私人黄色宅男| 亚洲一本大道在线| 日本va欧美va瓶| 精品在线亚洲视频| 波多野结衣亚洲一区| 91日韩在线专区| 欧美日韩亚洲高清一区二区| 日韩美女天天操| 国产精品第一页第二页第三页 | 日韩一区二区在线观看视频播放| 日韩免费视频线观看| 国产日韩欧美亚洲| 亚洲一线二线三线视频| 蜜臀a∨国产成人精品| 成人动漫av在线| 欧美日韩国产小视频| 久久天天做天天爱综合色| 亚洲欧美日韩国产手机在线| 天天做天天摸天天爽国产一区| 国产毛片精品一区| 在线一区二区观看| 精品国产乱码久久久久久久| 日韩毛片一二三区| 麻豆久久久久久久| 99精品欧美一区二区蜜桃免费| 欧美日韩精品欧美日韩精品一综合 | 欧美在线一二三| 久久九九全国免费| 日韩国产精品久久| 播五月开心婷婷综合| 337p亚洲精品色噜噜狠狠| 国产精品久久久久久户外露出 | 樱桃国产成人精品视频| 国产在线视频不卡二| 在线观看视频一区| 中文天堂在线一区| 国产毛片精品视频| 日韩视频在线永久播放|