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

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

?? os_cpu_c.c

?? UCOSII在mcs12dg128上的移植
?? C
?? 第 1 頁 / 共 2 頁
字號:
    tap                         // A contains the CCR value to restore, move to CCR
	}
}                      

/*********************************************************************************************************
;********************************************************************************************************
;                               START HIGHEST PRIORITY TASK READY-TO-RUN
;
; 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) The stack frame is assumed to look as follows:
;   
;                  OSTCBHighRdy->OSTCBStkPtr +  0  -->  PPAGE
;                                            +  1       CCR
;                                            +  2       B
;                                            +  3       A
;                                            +  4       X (H)
;                                            +  5       X (L)
;                                            +  6       Y (H)
;                                            +  7       Y (L)
;                                            +  8       PC(H)
;                                            +  9       PC(L)
;
;               2) OSStartHighRdy() MUST:
;                      a) Call OSTaskSwHook() then,
;                      b) Set OSRunning to TRUE,
;                      c) Switch to the highest priority task by loading the stack pointer of the
;                         highest priority task into the SP register and execute an RTI instruction.
;********************************************************************************************************
;********************************************************************************************************/

#pragma CODE_SEG NON_BANKED
			
#pragma TRAP_PROC
void OSStartHighRdy(void)
{
#if OS_CPU_HOOKS_EN > 0
    OSTaskSwHook(); 	/* 4~, Invoke user defined context switch hook */                                         
#endif
          
__asm{
    inc    OSRunning                  ;2~, Indicate that we are multitasking                  
    ldx    OSTCBHighRdy               ;3~, Point to TCB of highest priority task ready to run 
    lds    0,x                       ;3~, Load SP into 68HC12                               
    pula                               ;  3~, Get value of PPAGE register
    staa   PPAGE                       ;  3~, Store into CPU's PPAGE register  
	 } 
}

/********************************************************************************************************
;********************************************************************************************************
;                                       TASK LEVEL CONTEXT SWITCH
;
; Description : This function is called when a task makes a higher priority task ready-to-run.
;
; Arguments   : none
;
; Note(s)     : 1) Upon entry, 
;                  OSTCBCur     points to the OS_TCB of the task to suspend
;                  OSTCBHighRdy points to the OS_TCB of the task to resume
;
;               2) The stack frame of the task to suspend looks as follows:
;
;                  SP +  0  -->  PPAGE
;                     +  1       CCR
;                     +  2       B
;                     +  3       A
;                     +  4       X (H)
;                     +  5       X (L)
;                     +  6       Y (H)
;                     +  7       Y (L)
;                     +  8       PC(H)
;                     +  9       PC(L)
;
;               3) The stack frame of the task to resume looks as follows:
; 
;                  OSTCBHighRdy->OSTCBStkPtr +  0  -->  PPAGE
;                                            +  1       CCR
;                                            +  2       B
;                                            +  3       A
;                                            +  4       X (H)
;                                            +  5       X (L)
;                                            +  6       Y (H)
;                                            +  7       Y (L)
;                                            +  8       PC(H)
;                                            +  9       PC(L)
;********************************************************************************************************
;*********************************************************************************************************/

#pragma TRAP_PROC
void OSCtxSw(void)
{
__asm{
    ldaa   PPAGE                       ;  3~, Get current value of PPAGE register                                
    psha                               ;  2~, Push PPAGE register onto current task's stack

    ldy    OSTCBCur                   ;  3~, OSTCBCur->OSTCBStkPtr = Stack Pointer     
    sts    0,y                         ;  3~,                                           

    
    }
#if OS_CPU_HOOKS_EN > 0
    OSTaskSwHook(); 	/* 4~, Invoke user defined context switch hook */                                         
#endif
                       
__asm{    
    ldx    OSTCBHighRdy               ;  3~, OSTCBCur  = OSTCBHighRdy
    stx    OSTCBCur                   ;  3~                         
    
    ldab   OSPrioHighRdy              ;  3~, OSPrioCur = OSPrioHighRdy                        
    stab   OSPrioCur                  ;  3~
    
    lds    0,x                         ;  3~, Load SP into 68HC12                              
    
    pula                               ;  3~, Get value of PPAGE register
    staa   PPAGE                       ;  3~, Store into CPU's PPAGE register      
 }
}

/********************************************************************************************************
;********************************************************************************************************
;                                    INTERRUPT LEVEL CONTEXT SWITCH
;
; Description : This function is called by OSIntExit() to perform a context switch to a task that has
;               been made ready-to-run by an ISR.
;
; Arguments   : none
;********************************************************************************************************
;********************************************************************************************************/

#pragma TRAP_PROC
void OSIntCtxSw(void)
{
    #if OS_CPU_HOOKS_EN > 0
    OSTaskSwHook(); 	/* 4~, Invoke user defined context switch hook */                                         
	#endif                     
__asm{    
    ldx    OSTCBHighRdy               ;  3~, OSTCBCur  = OSTCBHighRdy
    stx    OSTCBCur                   ;  3~                        
    ldab   OSPrioHighRdy              ;  3~, OSPrioCur = OSPrioHighRdy                        
    stab   OSPrioCur                  ;  3~
    lds    0,x                        ;  3~, Load SP into 68HC12                        
    pula                               ;  3~, Get value of PPAGE register
    staa   PPAGE                       ;  3~, Store into CPU's PPAGE register   
	}
}

/*********************************************************************************************************
;********************************************************************************************************

;                                           SYSTEM TICK ISR
;
; Description : This function is the ISR used to notify uC/OS-II that a system tick has occurred.  You 
;               must setup the 68HC12's interrupt vector table so that an OUTPUT COMPARE interrupt 
;               vectors to this function.
;
; Arguments   : none
;
; Notes       :  1) The 'tick ISR' assumes the we are using the Output Compare specified by OS_TICK_OC
;                   (see OS_CFG.H and this file) to generate a tick that occurs every OS_TICK_OC_CNTS 
;                   (see OS_CFG.H and this file) which corresponds to the number of FRT (Free Running 
;                   Timer) counts to the next interrupt.
;
;                2) You must specify which output compare will be used by the tick ISR as follows:
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 0 to use OUTPUT COMPARE #0
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 1 to use OUTPUT COMPARE #1
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 2 to use OUTPUT COMPARE #2
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 3 to use OUTPUT COMPARE #3
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 4 to use OUTPUT COMPARE #4
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 5 to use OUTPUT COMPARE #5
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 6 to use OUTPUT COMPARE #6
;                       Set OS_TICK_OC in OS_CFG.H (AND in this file) to 7 to use OUTPUT COMPARE #7
;
;                3) TFLG1, TC0 ... TC7 are defined in 6812dp256.h.
;********************************************************************************************************
;********************************************************************************************************/

#pragma TRAP_PROC
void interrupt OSTickISR(void)
{

 __asm
 {
 	inc OSIntNesting;               // 4~, Notify uC/OS-II about ISR
 	ldaa   PPAGE                       ;  3~, Get current value of PPAGE register                                
    psha   	;  2~, Push PPAGE register onto current task's stack
 }                            
if (OSIntNesting == 1){				// 4~, if (OSIntNesting == 1) {
 __asm 
   	{
        ldy    OSTCBCur               //  3~, OSTCBCur->OSTCBStkPtr = Stack Pointer     
    	sts    0,y                    //  3~,}                                           
   	}
}

 #if OS_TICK_OC == 0
 __asm{   
    ldab   #$01                        ;  2~, Clear C0F interrupt flag (bit 0)
    stab   TFLG1                       ;  4~
    ldd    TC0                         ;  5~, Set TC0 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC0                         ;  5~
 	}
 #endif

 #if OS_TICK_OC == 1
  __asm{
    ldab   #$02                        ;  2~, Clear C1F interrupt flag (bit 1)
    stab   TFLG1                       ;  4~
    ldd    TC1                         ;  5~, Set TC1 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~   
    std    TC1                         ;  5~
	} 
 #endif

 #if OS_TICK_OC == 2
 __asm{ 
    ldab   #$04                        ;  2~, Clear C2F interrupt flag (bit 2)
    stab   TFLG1                       ;  4~
    ldd    TC2                         ;  5~, Set TC2 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC2                         ;  5~
 	}
 #endif

 #if OS_TICK_OC == 3
 __asm{
    ldab   #$08                        ;  2~, Clear C3F interrupt flag (bit 3)
    stab   TFLG1                       ;  4~
    ldd    TC3                         ;  5~, Set TC3 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC3                         ;  5~
 	}
 #endif

 #if OS_TICK_OC == 4
 __asm{
    ldab   #$10                        ;  2~, Clear C4F interrupt flag (bit 4)
    stab   TFLG1                       ;  4~
    ldd    TC4                         ;  5~, Set TC4 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC4                         ;  5~
	} 
 #endif

 #if OS_TICK_OC == 5
 __asm{
    ldab   #$20                        ;  2~, Clear C5F interrupt flag (bit 5)
    stab   TFLG1                       ;  4~
    ldd    TC5                         ;  5~, Set TC5 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC5                         ;  5~
 	}
 #endif

 #if OS_TICK_OC == 6
 __asm{
    ldab   #$40                        ;  2~, Clear C6F interrupt flag (bit 6)
    stab   TFLG1                       ;  4~
    ldd    TC6                         ;  5~, Set TC6 to present time + desired counts to next ISR
    addd   #OS_TICK_OC_CNTS            ;  4~    
    std    TC6                         ;  5~
 	}
 #endif

 #if OS_TICK_OC == 7
 __asm{
    LDAB   #$80                        ;  2~, Clear C7F interrupt flag (bit 7)
    STAB   TFLG1                       ;  4~
    LDD    TC7                         ;  5~, Set TC7 to present time + desired counts to next ISR
    ADDD   #OS_TICK_OC_CNTS            ;  4~    
    STD    TC7                         ;  5~
 	} 
 #endif

    asm cli;									/*  2~, Enable interrupts to allow interrupt nesting*/
   
    OSTimeTick();                 /* 6~+, Call uC/OS-II's tick updating function */                 
    OSIntExit ();                 /* 6~+, Notify uC/OS-II about end of ISR */
   	__asm
   	{
   	pula                               ;  3~, Get value of PPAGE register
    staa   PPAGE                       ;  3~, Store into CPU's PPAGE register        	
   	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久综合视频| 综合久久久久综合| 综合久久综合久久| 老司机午夜精品| 精品视频一区三区九区| 国产性做久久久久久| 青青草国产成人99久久| 成人av资源站| 久久久久久久综合狠狠综合| 亚洲3atv精品一区二区三区| 成人中文字幕合集| 精品国产乱码久久久久久浪潮| 亚洲线精品一区二区三区八戒| 国产风韵犹存在线视精品| 欧美一二三在线| 亚洲国产美女搞黄色| 99久久国产综合精品麻豆| 久久久久久黄色| 美女任你摸久久| 91精品国产欧美一区二区18| 亚洲一区在线观看视频| 色一情一伦一子一伦一区| 中国色在线观看另类| 国内精品视频666| 日韩午夜av电影| 蜜桃视频一区二区三区在线观看| 欧美系列日韩一区| 亚洲精品成人天堂一二三| 91网站在线观看视频| 国产精品高清亚洲| av电影在线观看一区| 国产精品美女www爽爽爽| 岛国精品在线播放| 欧美国产成人精品| aaa欧美色吧激情视频| 国产精品每日更新在线播放网址| 不卡视频一二三四| 亚洲四区在线观看| 色视频欧美一区二区三区| 亚洲你懂的在线视频| 在线观看亚洲精品视频| 日韩专区一卡二卡| 555www色欧美视频| 美女任你摸久久 | 国产日产欧美一区二区视频| 经典三级在线一区| 国产欧美日韩另类一区| eeuss鲁片一区二区三区在线看| 国产精品色婷婷| 在线观看不卡一区| 麻豆精品国产91久久久久久| 国产亚洲婷婷免费| 91麻豆视频网站| 天堂一区二区在线| 久久尤物电影视频在线观看| aaa亚洲精品一二三区| 亚洲福利视频三区| 久久久久久麻豆| 91黄色激情网站| 美女脱光内衣内裤视频久久影院| 国产欧美一区二区在线| 欧美综合一区二区| 乱一区二区av| 亚洲三级电影网站| 日韩欧美黄色影院| av一区二区三区黑人| 日本不卡中文字幕| 国产精品欧美一区喷水| 欧美精品在线一区二区| 国产成人在线视频网址| 视频一区欧美精品| 中文字幕人成不卡一区| 欧美一区二视频| 91在线观看成人| 久久精品久久精品| 亚洲欧美另类图片小说| 久久网这里都是精品| 欧美综合久久久| 国产成人精品影视| 免费的国产精品| 亚洲综合网站在线观看| 国产精品女主播av| 精品美女在线播放| 欧美日韩小视频| 成人国产在线观看| 激情文学综合丁香| 亚洲成av人片一区二区三区| 国产精品麻豆网站| 精品国产91洋老外米糕| 91精品久久久久久久久99蜜臂| 成人免费不卡视频| 久久精品av麻豆的观看方式| 亚洲国产视频a| 亚洲欧美日韩国产手机在线| 久久久不卡影院| 2024国产精品视频| 日韩免费一区二区三区在线播放| 欧美亚洲禁片免费| 97精品久久久午夜一区二区三区 | 国产乱国产乱300精品| 亚洲不卡av一区二区三区| 亚洲欧洲精品一区二区精品久久久| 欧美精品一区二区三区蜜桃视频 | 综合久久国产九一剧情麻豆| 久久综合狠狠综合久久综合88 | 国产综合成人久久大片91| 五月婷婷久久综合| 亚洲永久精品大片| 亚洲黄一区二区三区| 亚洲欧美另类在线| 一区二区三区色| 亚洲在线观看免费视频| 亚洲国产精品久久艾草纯爱| 夜夜操天天操亚洲| 亚洲综合一区二区| 五月天亚洲精品| 日韩av电影免费观看高清完整版在线观看 | 亚洲欧美一区二区三区国产精品| 久久久久久久久久久久电影| 精品欧美一区二区久久 | 亚洲人成人一区二区在线观看| 亚洲国产精品传媒在线观看| 国产精品视频看| 中文字幕在线不卡| 亚洲欧美激情小说另类| 亚洲一区在线播放| 免费一级欧美片在线观看| 精品一区二区三区在线播放视频| 91福利视频久久久久| 色婷婷av一区二区三区大白胸| 91黄色免费版| 日韩欧美综合一区| 日本一区二区三区四区| 国产精品二区一区二区aⅴ污介绍| 国产精品传媒入口麻豆| 亚洲精品乱码久久久久久黑人| 亚洲综合色婷婷| 另类小说欧美激情| 成人av在线资源网站| 欧美主播一区二区三区美女| 欧美一级艳片视频免费观看| 久久精子c满五个校花| 亚洲人成7777| 毛片不卡一区二区| 99久久免费视频.com| 欧美日韩夫妻久久| 国产午夜精品一区二区三区嫩草| 亚洲欧美电影院| 精品一区二区三区在线观看国产| eeuss鲁一区二区三区| 337p亚洲精品色噜噜噜| 中文字幕欧美激情一区| 亚洲成人综合视频| 国产91精品精华液一区二区三区 | 欧美精品一区二区三区蜜桃| 综合电影一区二区三区 | 国产精品久久看| 免费不卡在线观看| av一区二区不卡| 欧美大度的电影原声| 亚洲精品国产精华液| 久久国产剧场电影| 欧美私人免费视频| 国产精品视频九色porn| 日韩精品一二三区| 91欧美一区二区| 久久九九国产精品| 日本伊人精品一区二区三区观看方式| 国产99久久久国产精品潘金网站| 欧美精品丝袜久久久中文字幕| 国产精品伦理在线| 狠狠狠色丁香婷婷综合久久五月| 一本色道久久综合亚洲91| 久久这里只精品最新地址| 午夜精品一区二区三区免费视频 | 精品国产在天天线2019| 亚洲成人手机在线| 成人av午夜影院| 欧美精品一区二区高清在线观看| 亚洲成人黄色影院| 91女厕偷拍女厕偷拍高清| 久久久国产午夜精品| 久久丁香综合五月国产三级网站| 欧美日韩精品高清| 一区二区高清视频在线观看| 久久久精品免费免费| 视频一区二区三区中文字幕| 欧美午夜不卡在线观看免费| 亚洲视频中文字幕| 成人黄色国产精品网站大全在线免费观看| 亚洲精品在线电影| 国内外精品视频| 欧美一区二区美女| 热久久国产精品| 日韩欧美综合在线| 久久99国产精品久久| 久久久久久一级片| 成人的网站免费观看| 亚洲欧洲日本在线| 91麻豆精东视频|