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

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

?? os_cpu_a.s

?? avr rtos AVR單片機上的實時操作系統
?? S
字號:
;*******************************************************************************
;                                   uC/OS-II
;                             The Real-Time Kernel
;
;                         ATmega103 Specific code
;                               (ICC V6.21)
;
;
; File:			OS_CPU_A.S
; By:			Ole Saether
; Modified by:	Joerg Meyer
; Port Version:	V1.00
;
;
;*******************************************************************************

;include 

;*******************************************************************************
;                 I/O PORT ADDRESSES
;*******************************************************************************


SREG    = 0x3F
SPH     = 0x3E
SPL     = 0x3D
RAMPZ   = 0x3B
TCNT0   = 0x32
TCNT2   = 0x24


;*******************************************************************************
;                MACROS
;*******************************************************************************

				; Push registers
				.macro PUSHRS
                ST      -Y,R0	
                ST      -Y,R1
                ST      -Y,R2
                ST      -Y,R3
                ST      -Y,R4
                ST      -Y,R5
                ST      -Y,R6
                ST      -Y,R7
                ST      -Y,R8
                ST      -Y,R9
                ST      -Y,R10
                ST      -Y,R11
                ST      -Y,R12
                ST      -Y,R13
                ST      -Y,R14
                ST      -Y,R15
                ST      -Y,R16
                ST      -Y,R17
                ST      -Y,R18
                ST      -Y,R19
                ST      -Y,R20
                ST      -Y,R21
                ST      -Y,R22
                ST      -Y,R23
                ST      -Y,R24
                ST      -Y,R25
                ST      -Y,R26
                ST      -Y,R27
                ST      -Y,R30
                ST      -Y,R31
                IN      R16,RAMPZ
                ST      -Y,R16
				.endmacro

				; Pop registers
                .macro POPRS
                LD      R16,Y+
                OUT     RAMPZ,R16
                LD      R31,Y+
                LD      R30,Y+
                LD      R27,Y+
                LD      R26,Y+
                LD      R25,Y+
                LD      R24,Y+
                LD      R23,Y+
                LD      R22,Y+
                LD      R21,Y+
                LD      R20,Y+
                LD      R19,Y+
                LD      R18,Y+
                LD      R17,Y+
                LD      R16,Y+
                LD      R15,Y+
                LD      R14,Y+
                LD      R13,Y+
                LD      R12,Y+
                LD      R11,Y+
                LD      R10,Y+
                LD      R9,Y+
                LD      R8,Y+
                LD      R7,Y+
                LD      R6,Y+
                LD      R5,Y+
                LD      R4,Y+
                LD      R3,Y+
                LD      R2,Y+
                LD      R1,Y+
                LD      R0,Y+
                .endmacro

				; Push stack pointer
                .macro PUSHSP
                IN      R16,SPH
                ST      -Y,R16
                IN      R16,SPL
                ST      -Y,R16
                .endmacro

				; Pop stack pointer
                .macro POPSP
                LD      R16,Y+
                OUT     SPL,R16
                LD      R16,Y+
                OUT     SPH,R16
                .endmacro

				;Push SREG
				.macro PUSHSREG
                IN      R16,SREG
                ST      -Y,R16
                .endmacro

				; Pop SREG
                .macro POPSREG
                LD      R16,Y+
                OUT     SREG,R16
				.endmacro

                .area    text(rel)

;*******************************************************************************
;               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().
;
; Note(s):
;	1) The (data)stack frame is assumed to look as follows:
;
;		OSTCBHighRdy->OSTCBStkPtr --> LSB of (return) stack pointer (Low memory)
;										MSB of (return) stack pointer
;										Flags to load in status register
;										R31
;										R30
;										R7
;										.
;										.
;										.
;										R0  (High memory)
;
;		where the stack pointer points to the task start address.
;
;
;	2) OSStartHighRdy() MUST:
;		a) Call OSTaskSwHook() then,
;		b) Set OSRunning to TRUE,
;		c) Switch to the highest priority task.
;*******************************************************************************

_OSStartHighRdy:: 
	CALL    _OSTaskSwHook		; Invoke user defined context switch hook
	LDS     R16,_OSRunning		; Indicate that we are multitasking
	INC     R16					
	STS     _OSRunning,R16		;

	LDS     R30,_OSTCBHighRdy	; Let Z point to TCB of highest priority task
	LDS     R31,_OSTCBHighRdy+1	; ready to run
	LD      R28,Z+				; Load Y (R29:R28) pointer
	LD      R29,Z+				;

	POPSP		; restore stack pointer
	POPSREG		; restore SREG
	POPRS		; restore registers
	RET			; start task

;*******************************************************************************
;                 TASK LEVEL CONTEXT SWITCH
;
; Description : This function is called when a task makes a higher priority task
; ready-to-run.
;
; 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 --> LSB of task code address
;			+1     MSB of task code address	(High memory)
;
;	3) The saved context of the task to resume looks as follows:
;
;		OSTCBHighRdy->OSTCBStkPtr --> LSB of (return) stack pointer (Low memory)
;                                     MSB of (return) stack pointer
;                                     Flags to load in status register
;                                     R31
;                                     R30
;                                     R7
;                                     .
;                                     .
;                                     .
;                                     R0    (High memory)
;*******************************************************************************

_OSCtxSw::
		PUSHRS						; Save current task's context
		PUSHSREG
		PUSHSP

		LDS     R30,_OSTCBCur		; Z = OSTCBCur->OSTCBStkPtr
		LDS     R31,_OSTCBCur+1		;
		ST      Z+,R28				; Save Y (R29:R28) pointer
		ST      Z+,R29				;
	
		CALL    _OSTaskSwHook		; Call user defined task switch hook

		LDS     R16,_OSPrioHighRdy	; OSPrioCur = OSPrioHighRdy
		STS     _OSPrioCur,R16
	
		LDS     R30,_OSTCBHighRdy ; Let Z point to TCB of highest priority task
		LDS     R31,_OSTCBHighRdy+1	; ready to run
		STS     _OSTCBCur,R30		; OSTCBCur = OSTCBHighRdy
		STS     _OSTCBCur+1,R31 	;

		LD      R28,Z+		; Restore Y pointer
		LD      R29,Z+		;

		POPSP				; restore stack pointer
		POPSREG				; restore SREG
		POPRS				; restore registers
		RET


;*******************************************************************************
;               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.
;
; 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 --> LSB of return address of OSIntCtxSw()   (Low memory)
;			+1     MSB of return address of OSIntCtxSw()
;			+2     LSB of return address of OSIntExit()
;			+3     MSB of return address of OSIntExit()
;			+4     LSB of task code address
;			+5     MSB of task code address		(High memory)
;
;	3) The saved context of the task to resume looks as follows:
;
;		OSTCBHighRdy->OSTCBStkPtr --> 	LSB of (return) stack pointer (Low mem)
;										MSB of (return) stack pointer
;										Flags to load in status register
;										R31
;										R30
;										R7
;										.
;										.
;										.
;										R0		(High memory)
;*******************************************************************************

_OSIntCtxSw::
		IN      R30,SPL				; Z = SP
		IN      R31,SPH
	;	ADIW    R30,4	; (Uncomment if OS_CRITICAL_METHOD is 1, see OS_CPU.H)
		ADIW    R30,5				; Adjust Z to point to task return address
		ST      -Y,R31				; Save SP
		ST      -Y,R30				;
	
		LDS     R30,_OSTCBCur		; Z = OSTCBCur->OSTCBStkPtr
		LDS     R31,_OSTCBCur+1		;
		ST      Z+,R28				; Save Y pointer
		ST      Z+,R29				;

		CALL    _OSTaskSwHook		; Call user defined task switch hook

		LDS     R16,_OSPrioHighRdy	; OSPrioCur = OSPrioHighRdy
		STS     _OSPrioCur,R16	;

		LDS     R30,_OSTCBHighRdy	; Z = OSTCBHighRdy->OSTCBStkPtr
		LDS     R31,_OSTCBHighRdy+1	;
		STS     _OSTCBCur,R30		; OSTCBCur = OSTCBHighRdy
		STS     _OSTCBCur+1,R31		;

		LD      R28,Z+				; Restore Y pointer
		LD      R29,Z+				;
		POPSP						; restore stack pointer
		POPSREG						; restore SREG
		POPRS						; restore registers
		RET

;******************************************************************************
;                          SYSTEM TICK ISR
;
; Description: This function is the ISR used to notify uC/OS-II that a system
; tick has occurred.
;
;
;*******************************************************************************
; 
_OSTickISR::    
		PUSHRS				; save all registers
		IN	R16, SREG
		SBR	R16, 0x80		; bei Aufruf dieser ISR geloeschtes I-Flag setzen 
		ST	-Y, R16

		; TimerCounter aufrischen
		LDI     R16,256-(4000000/100/1024)	; Reload TC_2, 10ms bei 4MHz
		OUT     TCNT2,R16

		LDS     R16,_OSIntNesting           ; Notify uC/OS-II of ISR
		INC     R16                         ;
		STS     _OSIntNesting,R16           ;

		CALL    _OSTimeTick		; Call uC/OS-II's tick updating function
		; bearbeitet die tasktimer, wenn 0 --> deren Prio in Aufruftab stellen

		CALL    _OSIntExit		; Notify uC/OS-II about end of ISR
		; fuehrt gegebenfalls einen Context-Switch aus

		POPSREG		; restore SREG
		POPRS		; restore all registers
		RET			; Note: RET instead of RETI

;*******************************************************************************
;
;*******************************************************************************

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合网色综合| 国产午夜三级一区二区三| 日韩影院在线观看| 日韩视频免费观看高清完整版 | 亚洲综合精品久久| 欧美日韩一区二区三区在线看| 亚洲一区二区三区自拍| 欧美久久久久久久久| 另类调教123区| 欧美韩国一区二区| 91在线观看地址| 亚洲观看高清完整版在线观看| 在线播放视频一区| 国产麻豆视频精品| 欧美—级在线免费片| 色婷婷综合激情| 日韩av午夜在线观看| 国产亚洲制服色| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 欧美区视频在线观看| 久久精工是国产品牌吗| 国产欧美日韩精品一区| 色呦呦日韩精品| 免费人成在线不卡| 国产欧美精品日韩区二区麻豆天美| 91老师片黄在线观看| 日韩中文字幕区一区有砖一区 | 国产精品国产三级国产aⅴ中文| 欧美亚洲动漫精品| 91黄色在线观看| 蜜臀精品久久久久久蜜臀| 国产日韩三级在线| 欧美日韩亚洲综合一区二区三区| 激情五月播播久久久精品| 亚洲日本一区二区| 日韩视频不卡中文| 一本到三区不卡视频| 美女国产一区二区| 亚洲乱码日产精品bd| 日韩欧美国产1| 91视频免费看| 国内精品久久久久影院薰衣草 | 亚洲欧美在线视频观看| 欧美一区欧美二区| 99久久777色| 经典一区二区三区| 亚洲一区二区视频在线观看| 国产亚洲成aⅴ人片在线观看| 欧美视频一区在线| 成人午夜免费视频| 免费成人你懂的| 亚洲精品亚洲人成人网在线播放| 亚洲精品一区二区三区影院| 欧洲av一区二区嗯嗯嗯啊| 国产一区二区三区av电影| 亚洲国产人成综合网站| 国产欧美日韩中文久久| 欧美一区二区成人6969| 91国产免费观看| 国产成人亚洲综合a∨婷婷图片 | 免费人成网站在线观看欧美高清| 亚洲日本va在线观看| 久久五月婷婷丁香社区| 在线不卡免费欧美| 在线观看日韩毛片| 成人午夜碰碰视频| 国内精品免费**视频| 日日夜夜免费精品| 亚洲一区二区三区中文字幕在线| 中文字幕va一区二区三区| 精品久久久久久久一区二区蜜臀| 欧美日韩一区二区三区四区| 97久久超碰国产精品电影| 国产精品资源网站| 老司机午夜精品| 蜜臀久久99精品久久久久久9| 亚洲国产视频在线| 亚洲欧美一区二区不卡| 中日韩av电影| 久久久精品影视| 精品国产乱码久久久久久久| 91精品中文字幕一区二区三区| 91国偷自产一区二区开放时间 | av亚洲精华国产精华精华| 国产一区二区不卡老阿姨| 免费一级欧美片在线观看| 午夜视频在线观看一区| 亚洲国产精品久久一线不卡| 亚洲欧美精品午睡沙发| 国产精品高潮呻吟久久| 中文字幕精品在线不卡| 久久久亚洲高清| 久久亚洲综合av| 精品免费视频.| 精品久久99ma| 精品久久久三级丝袜| 欧美成人在线直播| 日韩精品在线看片z| 欧美电影免费观看高清完整版在线观看| 欧美人与禽zozo性伦| 欧美日韩国产精选| 欧美三区在线观看| 欧美日韩免费不卡视频一区二区三区| 色猫猫国产区一区二在线视频| 一本色道久久综合精品竹菊| 91啪亚洲精品| 91国产免费观看| 欧美影院午夜播放| 欧美日韩一区不卡| 欧美日韩国产首页| 欧美一区二区三区人| 日韩欧美一区二区视频| 精品免费99久久| 久久综合资源网| 国产蜜臀av在线一区二区三区| 国产婷婷一区二区| 国产精品免费看片| 亚洲欧美韩国综合色| 99免费精品视频| 99精品视频一区二区三区| 日本乱码高清不卡字幕| 欧美日韩久久久一区| 日韩视频一区二区三区在线播放| 精品国精品国产尤物美女| 国产视频一区不卡| 中文字幕一区二区三中文字幕| 亚洲精品视频免费观看| 香港成人在线视频| 久久不见久久见免费视频7| 国产精品一二三四| 9l国产精品久久久久麻豆| 在线观看一区不卡| 91麻豆精品国产91久久久更新时间| 日韩一区二区三区精品视频| 久久精品亚洲精品国产欧美 | 亚洲免费观看在线视频| 性做久久久久久久久| 激情欧美日韩一区二区| 成人激情午夜影院| 欧美视频在线观看一区二区| 日韩午夜在线影院| 中文字幕成人在线观看| 夜夜揉揉日日人人青青一国产精品 | 视频一区中文字幕| 久久国产精品第一页| 成人性生交大合| 欧美午夜精品理论片a级按摩| 欧美一区二区三区免费观看视频| 久久精品欧美一区二区三区麻豆| 亚洲欧美一区二区不卡| 蜜臀久久久久久久| 成人免费电影视频| 欧美日韩精品是欧美日韩精品| 欧美大肚乱孕交hd孕妇| 亚洲视频在线一区| 日本不卡一区二区| 成人晚上爱看视频| 欧美日韩视频在线第一区| 久久久激情视频| 一区二区三区在线免费视频| 久久精品免费观看| 91影院在线免费观看| 欧美精品一区二区三区久久久| 亚洲色欲色欲www| 免费欧美高清视频| 99精品国产热久久91蜜凸| 欧美一区二区福利视频| 日韩一区欧美小说| 久久精品国产一区二区三| 91丨porny丨首页| 精品国内二区三区| 亚洲一区二区精品久久av| 国产高清不卡一区| 欧美裸体bbwbbwbbw| 国产精品久久久久婷婷| 日本欧美一区二区| 91一区二区三区在线观看| 欧美成人a视频| 一区二区三区免费网站| 国产精品小仙女| 欧美精品tushy高清| 18欧美亚洲精品| 国产一区二区三区综合| 欧美日韩一区二区电影| 中文字幕一区在线| 韩日欧美一区二区三区| 欧美三级视频在线| 国产精品久久久久国产精品日日| 蜜臀a∨国产成人精品| 色88888久久久久久影院按摩| 国产日产精品1区| 看电影不卡的网站| 欧美日韩久久久| 亚洲欧美激情小说另类| 国产传媒一区在线| 日韩美女视频在线| 亚洲成va人在线观看| 91亚洲永久精品| 国产亚洲成aⅴ人片在线观看| 日本不卡一区二区三区|