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

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

?? crt0_str75x_freertos.s

?? freertosV4.40 是一種small的嵌入式系統。利于嵌入式開好者入門學習嵌入式操作系統。通過對于源碼的學習可以很好的掌握freertos的運行機制。
?? S
?? 第 1 頁 / 共 3 頁
字號:
/*
This is the default Startup for STR75x devices for the GNU toolchain

It has been designed by ST Microelectronics and modified by Raisonance
and FreeRTOS.org.

You can use it, modify it, distribute it freely but without any waranty.

*/
.extern main

	   

/*; Depending on Your Application, Disable or Enable the following Defines*/
  /*; --------------------------------------------------------------------------
  ;                      SMI Bank0 configuration
; ----------------------------------------------------------------------------*/
.set SMI_Bank0_EN, 0 /*; enable access the SMI Bank0 if 1*/

/*; ----------------------------------------------------------------------------
  ;                      Memory remapping
; ----------------------------------------------------------------------------*/
.set Remap_SRAM, 0   /* remap SRAM at address 0x00 if 1 */
 
/*  ; ----------------------------------------------------------------------------
  ;                      EIC initialization
  ; ----------------------------------------------------------------------------*/
.set EIC_INIT, 1     /*; Configure and Initialize EIC if 1*/


;/* the following are useful for initializing the .data section */
.extern _sidata ;/* start address for the initialization values of the .data section. defined in linker script */
.extern _sdata ;/* start address for the .data section. defined in linker script */
.extern _edata ;/* end address for the .data section. defined in linker script */

;/* the following are useful for initializing the .bss section */
.extern _sbss ;/* start address for the .bss section. defined in linker script */
.extern _ebss ;/* end address for the .bss section. defined in linker script */

;/* Standard definitions of Mode bits and Interrupt (I & F) flags in PSRs */
.set  Mode_USR, 0x10            ;/* User Mode */
.set  Mode_FIQ, 0x11            ;/* FIQ Mode */
.set  Mode_IRQ, 0x12            ;/* IRQ Mode */
.set  Mode_SVC, 0x13            ;/* Supervisor Mode */
.set  Mode_ABT, 0x17            ;/* Abort Mode */
.set  Mode_UNDEF, 0x1B          ;/* Undefined Mode */
.set  Mode_SYS, 0x1F            ;/* System Mode */

.equ  I_Bit, 0x80               ;/* when I bit is set, IRQ is disabled */
.equ  F_Bit, 0x40               ;/* when F bit is set, FIQ is disabled */

/*; --- System memory locations */

;/* init value for the stack pointer. defined in linker script */
.extern _estack

;/* Stack Sizes. The default values are in the linker script, but they can be overriden. */
.extern _UND_Stack_Init
.extern _SVC_Stack_Init
.extern _ABT_Stack_Init
.extern _FIQ_Stack_Init
.extern _IRQ_Stack_Init
.extern _USR_Stack_Init

.extern _UND_Stack_Size
.extern _SVC_Stack_Size
.extern _ABT_Stack_Size
.extern _FIQ_Stack_Size
.extern _IRQ_Stack_Size
.extern _USR_Stack_Size
.extern vTaskSwitchContext
.extern ulCriticalNesting

SVC_Stack           =     _SVC_Stack_Init /*_estack*/           /*; 32 byte SVC stack at*/
                                              /*; top of memory */
                                              
IRQ_Stack           =     _IRQ_Stack_Init /*SVC_Stack - 32*/     /*; followed by IRQ stack */
USR_Stack           =     _USR_Stack_Init /*IRQ_Stack-256*/    /*; followed by USR stack */
FIQ_Stack           =     _FIQ_Stack_Init /*USR_Stack-256*/    /*; followed by FIQ stack*/
ABT_Stack           =     _ABT_Stack_Init /*FIQ_Stack-64*/     /*; followed by ABT stack */
UNDEF_Stack         =     _UND_Stack_Init /*ABT_Stack-0*/     /*; followed by UNDEF stack */

/*; --- System memory locations*/

/*; MRCC Register*/
MRCC_PCLKEN_Addr    =    0x60000030  /*; Peripheral Clock Enable register base address*/

/*; CFG Register*/
CFG_GLCONF_Addr     =    0x60000010  /*; Global Configuration register base address*/
SRAM_mask           =    0x0002      /*; to remap RAM at 0x0*/

/*; GPIO Register*/
GPIOREMAP0R_Addr    =    0xFFFFE420
SMI_EN_Mask         =    0x00000001

/*; SMI Register*/
SMI_CR1_Addr        =    0x90000000

/*; --- Stack Addres for each ARM mode*/
/*; add FIQ_Stack, ABT_Stack, UNDEF_Stack here if you need them*/


/*; --- EIC Registers offsets*/
EIC_base_addr       =    0xFFFFF800         /*; EIC base address*/
ICR_off_addr        =    0x00               /*; Interrupt Control register offset*/
CICR_off_addr       =    0x04               /*; Current Interrupt Channel Register*/
CIPR_off_addr       =    0x08               /*; Current Interrupt Priority Register offset*/
IVR_off_addr        =    0x18               /*; Interrupt Vector Register offset*/
FIR_off_addr        =    0x1C               /*; Fast Interrupt Register offset*/
IER_off_addr        =    0x20               /*; Interrupt Enable Register offset*/
IPR_off_addr        =    0x40               /*; Interrupt Pending Bit Register offset*/
SIR0_off_addr       =    0x60               /*; Source Interrupt Register 0*/

/***************************************************************************************/


.globl _start
.globl _startup

.text
_startup:
_start:
        LDR     PC, Reset_Addr
        LDR     PC, Undefined_Addr
        LDR     PC, SWI_Addr
        LDR     PC, Prefetch_Addr
        LDR     PC, Abort_Addr
        NOP                          /*; Reserved vector*/
        LDR     PC, IRQ_Addr
        LDR     PC, FIQ_Addr





Reset_Addr      : .long     Reset_Handler
Undefined_Addr  : .long     UndefinedHandler
SWI_Addr        : .long     SWIHandler
Prefetch_Addr   : .long     PrefetchAbortHandler
Abort_Addr      : .long     DataAbortHandler
                  .long 0      /*; Reserved vector*/
IRQ_Addr        : .long     IRQHandler
FIQ_Addr        : .long     FIQHandler

.text
/*;*******************************************************************************
;              Peripherals IRQ handlers address table
;********************************************************************************/

/* execution goes there when an interrupt occurs and there is no associated ISR */
.globl __wrongvector
__wrongvector:
	ldr     PC, __wrongvector_Addr	
__wrongvector_Addr:
	.long 0

WAKUP_Addr         :.long	WAKUPIRQHandler
TIM2_OC2_Addr      :.long	TIM2_OC2IRQHandler
TIM2_OC1_Addr      :.long	TIM2_OC1IRQHandler
TIM2_IC12_Addr     :.long	TIM2_IC12IRQHandler
TIM2_UP_Addr       :.long	TIM2_UPIRQHandler
TIM1_OC2_Addr      :.long	TIM1_OC2IRQHandler
TIM1_OC1_Addr      :.long	TIM1_OC1IRQHandler
TIM1_IC12_Addr     :.long	TIM1_IC12IRQHandler
TIM1_UP_Addr       :.long	TIM1_UPIRQHandler
TIM0_OC2_Addr      :.long	TIM0_OC2IRQHandler
TIM0_OC1_Addr      :.long	TIM0_OC1IRQHandler
TIM0_IC12_Addr     :.long	TIM0_IC12IRQHandler
TIM0_UP_Addr       :.long	TIM0_UPIRQHandler
PWM_OC123_Addr     :.long	PWM_OC123IRQHandler
PWM_EM_Addr        :.long	PWM_EMIRQHandler
PWM_UP_Addr        :.long	PWM_UPIRQHandler
I2C_Addr           :.long	I2CIRQHandler
SSP1_Addr          :.long	SSP1IRQHandler
SSP0_Addr          :.long	SSP0IRQHandler
UART2_Addr         :.long	UART2IRQHandler
UART1_Addr         :.long	UART1IRQHandler
UART0_Addr         :.long	vSerialISR
CAN_Addr           :.long	CANIRQHandler
USB_LP_Addr        :.long	USB_LPIRQHandler
USB_HP_Addr        :.long	USB_HPIRQHandler
ADC_Addr           :.long	ADCIRQHandler
DMA_Addr           :.long	DMAIRQHandler
EXTIT_Addr         :.long	EXTITIRQHandler
MRCC_Addr          :.long	MRCCIRQHandler
FLASHSMI_Addr      :.long	FLASHSMIIRQHandler
RTC_Addr           :.long	RTCIRQHandler
TB_Addr            :.long	vPortTickISR

/*;*******************************************************************************
;                         Exception Handlers
;********************************************************************************/


/*;*******************************************************************************
;* FreeRTOS.org macros for saving and restoring a task context
;*******************************************************************************/

	.macro portSAVE_CONTEXT MACRO

	/* ; Push R0 as we are going to use the register. */
	STMDB	SP!, {R0}

	/* ; Set R0 to point to the task stack pointer. */
	STMDB	SP, {SP}^
	NOP
	SUB		SP, SP, #4
	LDMIA	SP!, {R0}

	/* ; Push the return address onto the stack. 	*/
	STMDB	R0!, {LR}

	/* ; Now we have saved LR we can use it instead of R0. 	*/
	MOV		LR, R0

	/* ; Pop R0 so we can save it onto the system mode stack. */
	LDMIA	SP!, {R0}

	/* ; Push all the system mode registers onto the task stack. */
	STMDB	LR, {R0-LR}^
	NOP
	SUB		LR, LR, #60

	/* ; Push the SPSR onto the task stack.  */
	MRS		R0, SPSR
	STMDB	LR!, {R0}

	LDR		R0, =ulCriticalNesting 
	LDR		R0, [R0]
	STMDB	LR!, {R0}

	/* ; Store the new top of stack for the task. 	*/
	LDR		R1, =pxCurrentTCB
	LDR		R0, [R1]
	STR		LR, [R0]

	.endm


	.macro portRESTORE_CONTEXT MACRO

	/* ; Set the LR to the task stack. 	*/
	LDR		R1, =pxCurrentTCB
	LDR		R0, [R1]
	LDR		LR, [R0]

	/* ; The critical nesting depth is the first item on the stack. 	
	; Load it into the ulCriticalNesting variable. 	*/
	LDR		R0, =ulCriticalNesting
	LDMFD	LR!, {R1}
	STR		R1, [R0]

	/* ; Get the SPSR from the stack. 	*/
	LDMFD	LR!, {R0}
	MSR		SPSR_cxsf, R0

	/* ; Restore all system mode registers for the task. */
	LDMFD	LR, {R0-R14}^
	NOP

	/* ; Restore the return address. */
	LDR		LR, [LR, #+60]

	/* ; And return - correcting the offset in the LR to obtain the 	
	; correct address. 	*/
	SUBS	PC, LR, #4
	
	.endm



/*;*******************************************************************************
;* Macro Name     : SaveContext
;* Description    : This macro used to save the context before entering
;                   an exception handler.
;* Input          : The range of registers to store.
;* Output         : none
;********************************************************************************/

       .macro SaveContext $r0,$r12
        STMFD  sp!,{r0-r12,lr} /*; Save The workspace plus the current return*/
                               /*; address lr_ mode into the stack.*/
        MRS    r1,spsr         /*; Save the spsr_mode into r1.*/
        STMFD  sp!,{r1}        /*; Save spsr.*/
        .endm

/*;*******************************************************************************
;* Macro Name     : RestoreContext
;* Description    : This macro used to restore the context to return from
;                   an exception handler and continue the program execution.
;* Input          : The range of registers to restore.
;* Output         : none
;********************************************************************************/

        .macro RestoreContext $r0,$r12
        LDMFD   sp!,{r1}        /*; Restore the saved spsr_mode into r1.*/
        MSR     spsr_cxsf,r1    /*; Restore spsr_mode.*/
        LDMFD   sp!,{r0-r12,pc}^/*; Return to the instruction following...*/
                                /*; ...the exception interrupt.*/
        .endm



/*;*******************************************************************************
;* Function Name  : UndefinedHandler
;* Description    : This function called when undefined instruction
;                   exception is entered.
;* Input          : none
;* Output         : none
;*********************************************************************************/

UndefinedHandler:
        SaveContext r0,r12    /*; Save the workspace plus the current*/
                              /*; return address lr_ und and spsr_und.*/
        BL      Undefined_Handler/*; Branch to Undefined_Handler*/
        RestoreContext r0,r12 /*; Return to the instruction following...*/
                              /*; ...the undefined instruction.*/

/*;*******************************************************************************
;* Function Name  : SWIHandler
;* Description    : This function called when SWI instruction executed.
;* Input          : none
;* Output         : none
;********************************************************************************/

SWIHandler:
		ADD	LR, LR, #4
        portSAVE_CONTEXT        
        LDR R0, =vTaskSwitchContext
        MOV LR, PC
        BX R0
        portRESTORE_CONTEXT 


/*;*******************************************************************************
;* Function Name  : IRQHandler
;* Description    : This function called when IRQ exception is entered.
;* Input          : none
;* Output         : none
;********************************************************************************/


IRQHandler:

	portSAVE_CONTEXT					/*; Save the context of the current task. */

	LDR    r0, =EIC_base_addr
	LDR    r1, =IVR_off_addr
	LDR    lr, =ReturnAddress			/*; Load the return address. */
	ADD    pc,r0,r1						/*; Branch to the IRQ handler. */
ReturnAddress:
	LDR    r0, =EIC_base_addr
	LDR    r2, [r0, #CICR_off_addr]		/*; Get the IRQ channel number. */
	MOV    r3,#1

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产拍揄自揄精品视频麻豆| 国产精品一区二区男女羞羞无遮挡| 国产成a人亚洲| 欧美国产激情二区三区| 不卡电影一区二区三区| 五月天中文字幕一区二区| 久久黄色级2电影| 亚洲免费在线电影| 国产视频一区不卡| 黄色精品一二区| 精品国内二区三区| 国产一区二三区| 久久这里只精品最新地址| 免费的成人av| 久久老女人爱爱| 国产黄人亚洲片| 国产精品乱人伦一区二区| 精品视频全国免费看| 精品无人码麻豆乱码1区2区| 亚洲特黄一级片| 日韩精品一区二区三区蜜臀| a级高清视频欧美日韩| 午夜激情久久久| 久久综合九色综合97婷婷| 99久久综合国产精品| 免费成人在线观看视频| 亚洲天天做日日做天天谢日日欢| 欧美国产精品一区二区三区| 天天综合色天天综合色h| 亚洲猫色日本管| 亚洲sss视频在线视频| 综合激情网...| 国产日韩高清在线| 日韩久久久精品| 在线不卡免费av| 欧美一激情一区二区三区| 91在线精品一区二区| 国产精品亚洲一区二区三区妖精| 亚洲香肠在线观看| 一区二区视频在线| 亚洲一区二区在线免费观看视频| 国产日韩精品一区二区三区在线| 欧美日韩在线播放三区| 色婷婷精品大在线视频| 91首页免费视频| 国产麻豆精品在线观看| 美国十次综合导航| 亚洲一区二区三区四区五区中文| 国产精品久久久久aaaa| 久久久久久久免费视频了| 日韩精品中文字幕在线一区| 欧美吞精做爰啪啪高潮| 欧美精三区欧美精三区| 在线成人小视频| 2014亚洲片线观看视频免费| 国产精品你懂的| 香蕉影视欧美成人| 成人污污视频在线观看| 欧美午夜一区二区三区| 欧美日韩久久久久久| 91精品国产综合久久香蕉的特点| 日韩一级片网站| 国产女同互慰高潮91漫画| 亚洲丝袜精品丝袜在线| 亚洲网友自拍偷拍| 麻豆成人免费电影| 懂色av一区二区夜夜嗨| 91精品免费在线观看| 亚洲欧洲一区二区在线播放| 一区二区三区欧美日韩| 久久99精品久久久久| 91老师国产黑色丝袜在线| 6080日韩午夜伦伦午夜伦| 成人欧美一区二区三区黑人麻豆| 五月激情综合婷婷| 波波电影院一区二区三区| 3d成人动漫网站| 欧美电影免费观看高清完整版在 | 亚洲一区二区黄色| 国产伦精一区二区三区| 91免费国产在线| 中文字幕成人av| 日韩高清在线不卡| 欧美三级韩国三级日本一级| 中文字幕一区二区三区不卡在线 | 成人做爰69片免费看网站| 欧美一级片在线观看| 亚洲免费视频中文字幕| 成人午夜av影视| 亚洲国产精品ⅴa在线观看| 国产乱子伦一区二区三区国色天香| 在线观看日韩毛片| 亚洲丝袜另类动漫二区| 91片在线免费观看| 一区二区三区免费观看| 91久久线看在观草草青青| 亚洲欧美日韩在线| 欧美亚日韩国产aⅴ精品中极品| 亚洲三级免费电影| 色94色欧美sute亚洲13| 一区二区视频在线| 欧美一区二区三区的| 婷婷一区二区三区| 欧美成人女星排行榜| 国产在线一区观看| 欧美激情一区二区三区四区| 成人性视频免费网站| 一区二区三区免费在线观看| 欧美视频中文字幕| 91福利国产精品| 久久国产剧场电影| 国产精品久久毛片av大全日韩| 成人国产一区二区三区精品| 一区二区三区欧美日| 日韩一卡二卡三卡| heyzo一本久久综合| 亚洲v日本v欧美v久久精品| 欧美一级专区免费大片| 成人黄色小视频| 日av在线不卡| 亚洲一区二区黄色| 国产午夜精品理论片a级大结局| 在线观看三级视频欧美| 国产一区二区三区av电影 | 亚洲国产欧美日韩另类综合| 国产欧美一区二区精品性色超碰| 一本色道久久综合狠狠躁的推荐| 久久激情综合网| 午夜精品福利一区二区三区av | 有码一区二区三区| 中文字幕av一区 二区| 久久亚洲综合色| 久久影院电视剧免费观看| 欧美日本在线播放| 在线视频观看一区| 99精品一区二区| 成人激情视频网站| av高清久久久| 成人免费观看视频| 福利一区二区在线观看| 国产一区二区久久| 成人网页在线观看| 91成人在线观看喷潮| 欧美三电影在线| 欧美日韩精品一区二区三区蜜桃| 色综合一个色综合| 欧美亚洲尤物久久| 欧美精品高清视频| 91精品一区二区三区久久久久久 | 91精品福利在线一区二区三区| 91精彩视频在线观看| 欧美天天综合网| 欧美男生操女生| 日本一区二区三区在线观看| 国产精品美女久久久久久久久 | 91尤物视频在线观看| 欧美怡红院视频| 日韩欧美久久一区| 国产欧美视频一区二区| 亚洲六月丁香色婷婷综合久久| 亚洲狼人国产精品| 麻豆免费精品视频| av亚洲精华国产精华精| 日本一区二区三级电影在线观看 | av午夜精品一区二区三区| 欧美日韩视频专区在线播放| 欧美成人一区二区三区片免费| 久久久久久久综合色一本| 亚洲免费观看在线视频| 久久精品国产999大香线蕉| 一本高清dvd不卡在线观看| 91精品国产91久久综合桃花| 成人免费在线视频观看| 激情文学综合网| 欧美午夜一区二区三区免费大片| 久久久久国产精品厨房| 日本中文一区二区三区| 91在线精品一区二区三区| 久久色.com| 日本视频一区二区| 欧美日韩免费一区二区三区| 亚洲人成精品久久久久久| 国产一区二区在线视频| 欧美美女一区二区在线观看| 中文字幕乱码日本亚洲一区二区| 另类欧美日韩国产在线| 51精品久久久久久久蜜臀| 亚洲综合一二区| 91久久国产最好的精华液| 亚洲欧美乱综合| 97久久超碰国产精品电影| 中文字幕一区二区日韩精品绯色| 国产成人免费xxxxxxxx| 欧美激情一区二区三区全黄| 国产大陆精品国产| 国产精品美女一区二区三区| 99久久久久久| 一区二区三区欧美| 欧美一区二区三区男人的天堂| 日本视频在线一区|