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

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

?? rominit.s

?? vxworks for Sam2410 bsp NoNet
?? S
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* romInit.s - ARM Integrator ROM initialization module *//* Copyright 1999-2001 ARM Limited *//* Copyright 1999-2001 Wind River Systems, Inc. *//*modification history--------------------01m,25jan02,m_h  sdata needs "_" for bootrom_res01l,09oct01,jpd  added clock speed setting for 946ES.01k,03oct01,jpd  tidied slightly.01j,28sep01,pr   added support for ARM946ES.01i,04jun01,rec  memory clock rate changes for 740t01h,21feb01,h_k  added support for ARM966ES and ARM966ES_T.01g,20nov00,jpd  change speeds on 920T and add conditional early		 enabling of I-cache on 920T.01f,18sep00,rec  Add delay during power up01e,23feb00,jpd  comments changes.01d,22feb00,jpd  changed copyright string.01c,20jan00,jpd  added support for ARM720T/ARM920T.01b,13jan00,pr	 added support for ARM740T.01a,30nov99,ajb  created, based on PID version 01i.*//*DESCRIPTIONThis module contains the entry code for VxWorks images that startrunning from ROM, such as 'bootrom' and 'vxWorks_rom'.  The entrypoint, romInit(), is the first code executed on power-up.  It performsthe minimal setup needed to call the generic C routine romStart() withparameter BOOT_COLD.romInit() masks interrupts in the processor and the interruptcontroller and sets the initial stack pointer (to STACK_ADRS which isdefined in configAll.h).  Other hardware and device initialisation isperformed later in the sysHwInit routine in sysLib.c.The routine sysToMonitor() jumps to a location after the beginning ofromInit, (defined by ROM_WARM_ADRS) to perform a "warm boot".  Thisentry point allows a parameter to be passed to romStart().The routines in this module don't use the "C" frame pointer %r11@ ! orestablish a stack frame.SEE ALSO:.I "ARM Architecture Reference Manual,".I "ARM 7TDMI Data Sheet,". "ARM 720T Data Sheet,".I "ARM 740T Data Sheet,".I "ARM 920T Technical Reference Manual",.I "ARM 940T Technical Reference Manual",.I "ARM 946E-S Technical Reference Manual",.I "ARM 966E-S Technical Reference Manual",.I "ARM Reference Peripherals Specification,".I "ARM Integrator/AP User Guide",.I "ARM Integrator/CM7TDMI User Guide",.I "ARM Integrator/CM720T User Guide",.I "ARM Integrator/CM740T User Guide",.I "ARM Integrator/CM920T User Guide",.I "ARM Integrator/CM940T User Guide",.I "ARM Integrator/CM946E User Guide",.I "ARM Integrator/CM9x6ES Datasheet".*/#define	_ASMLANGUAGE#include "vxWorks.h"#include "sysLib.h"#include "asm.h"#include "regs.h"	#include "config.h"#include "arch/arm/mmuArmLib.h"#include "s3c2410.h"#include "smdk2410.h"        .data        .globl   VAR(copyright_wind_river)        .long    VAR(copyright_wind_river)/* internals */	.globl	FUNC(romInit)		/* start of system code */	.globl	VAR(sdata)		/* start of data */        .globl  _sdata	.globl	VAR(integratorMemSize)	/* actual memory size *//* externals */	.extern	FUNC(romStart)	/* system initialization routine */_sdata:VAR_LABEL(sdata)	.asciz	"start of data"	.balign	4/* variables */	.dataVAR_LABEL(integratorMemSize)	.long	0	.text	.balign 4/********************************************************************************* romInit - entry point for VxWorks in ROM** romInit*     (*     int startType	/@ only used by 2nd entry point @/*     )* INTERNAL* sysToMonitor examines the ROM for the first instruction and the string* "Copy" in the third word so if this changes, sysToMonitor must be updated.*/_ARM_FUNCTION(romInit)_romInit:cold:	MOV	r0, #BOOT_COLD	/* fall through to warm boot entry */warm:	B	start	/* copyright notice appears at beginning of ROM (in TEXT segment) */	.ascii   "Copyright 1999-2001 ARM Limited"	.ascii   "\nCopyright 1999-2001 Wind River Systems, Inc."	.balign 4start:	/*	 * There have been reports of problems with certain boards and	 * certain power supplies not coming up after a power-on reset,	 * and adding a delay at the start of romInit appears to help	 * with this.	 */	TEQS	r0, #BOOT_COLD	MOVEQ	r1, #INTEGRATOR_DELAY_VALUE	MOVNE	r1, #1delay_loop:	SUBS	r1, r1, #1	BNE	delay_loop#if defined(CPU_720T)  || defined(CPU_720T_T) || \    defined(CPU_740T)  || defined(CPU_740T_T) || \    defined(CPU_920T)  || defined(CPU_920T_T) || \    defined(CPU_940T)  || defined(CPU_940T_T) || \    defined(CPU_946ES) || defined(CPU_946ES_T)	/*	 * Set processor and MMU to known state as follows (we may have not	 * been entered from a reset). We must do this before setting the CPU	 * mode as we must set PROG32/DATA32.	 *	 * MMU Control Register layout.	 *	 * bit	 *  0 M 0 MMU disabled	 *  1 A 0 Address alignment fault disabled, initially	 *  2 C 0 Data cache disabled	 *  3 W 0 Write Buffer disabled	 *  4 P 1 PROG32	 *  5 D 1 DATA32	 *  6 L 1 Should Be One (Late abort on earlier CPUs)	 *  7 B ? Endianness (1 => big)	 *  8 S 0 System bit to zero } Modifies MMU protections, not really	 *  9 R 1 ROM bit to one     } relevant until MMU switched on later.	 * 10 F 0 Should Be Zero	 * 11 Z 0 Should Be Zero (Branch prediction control on 810)	 * 12 I 0 Instruction cache control	 */	/* Setup MMU Control Register */	MOV	r1, #MMU_INIT_VALUE		/* Defined in mmuArmLib.h */#if defined(CPU_920T) || defined(CPU_920T_T)#if defined(INTEGRATOR_EARLY_I_CACHE_ENABLE)	ORR	r1, r1, #MMUCR_I_ENABLE		/* conditionally enable Icache*/#endif#endif	MCR	CP_MMU, 0, r1, c1, c0, 0	/* Write to MMU CR */	/*	 * If MMU was on before this, then we'd better hope it was set	 * up for flat translation or there will be problems. The next	 * 2/3 instructions will be fetched "translated" (number depends	 * on CPU).	 *	 * We would like to discard the contents of the Write-Buffer	 * altogether, but there is no facility to do this. Failing that,	 * we do not want any pending writes to happen at a later stage,	 * so drain the Write-Buffer, i.e. force any pending writes to	 * happen now.	 */#if defined(CPU_720T) || defined(CPU_720T_T) || \    defined(CPU_740T) || defined(CPU_740T_T)	MOV	r2, #INTEGRATOR_RESET_RAM_BASE	/* RAM base at reset */	SWPB	r1, r1, [r2]			/* Drain write-buffer */	/* Flush, (i.e. invalidate) all entries in the ID-cache */	MCR	CP_MMU, 0, r1, c7, c0, 0	/* Flush (inval) all ID-cache */#endif /* defined(CPU_720T,740T) */#if defined(CPU_920T)  || defined(CPU_920T_T) || \    defined(CPU_946ES) || defined(CPU_946ES_T)	MOV	r1, #0				/* data SBZ */	MCR	CP_MMU, 0, r1, c7, c10, 4	/* drain write-buffer */	/* Flush (invalidate) both I and D caches */	MCR	CP_MMU, 0, r1, c7, c7, 0	/* R1 = 0 from above, data SBZ*/#endif /* defined(CPU_920T,946ES) */#if defined(CPU_940T) || defined(CPU_940T_T)	LDR	r1, L$_sysCacheUncachedAdrs	/* R1 -> uncached area */	LDR	r1, [r1]			/* drain write-buffer */	/* Flush (invalidate) both caches */	MOV	r1, #0				/* data SBZ */	MCR	CP_MMU, 0, r1, c7, c5, 0	/* Flush (inval) all I-cache */	MCR	CP_MMU, 0, r1, c7, c6, 0	/* Flush (inval) all D-cache */#endif /* defined(CPU_940T,940T_T) */#if defined(CPU_720T) || defined(CPU_720T_T) || \    defined(CPU_920T) || defined(CPU_920T_T)        /*	 * Set Process ID Register to zero, this effectively disables	 * the process ID remapping feature.	 */	MOV	r1, #0	MCR	CP_MMU, 0, r1, c13, c0, 0#endif /* defined(CPU_720T,920T) */#endif /* defined(CPU_720T,740T,920T,940T,946ES) */	/* disable interrupts in CPU and switch to SVC32 mode */	MRS	r1, cpsr	BIC	r1, r1, #MASK_MODE	ORR	r1, r1, #MODE_SVC32 | I_BIT | F_BIT	MSR	cpsr, r1/***************************************************************************************************************/       /*	 Disable watch dog timer       */  	mov	r1, #0x53000000	mov	r2, #0x0	str	r2, [r1]	/*	 * CPU INTERRUPTS DISABLED	 *	 * disable individual interrupts in the interrupt controller	 */	MOV	r2, #IC_BASE			/* R2->interrupt controller */	MVN	r1, #0				/* &FFFFFFFF */	str	r2, [r1, #oINTMSK]	ldr	r2, =0x7ff	str	r2, [r1, #oINTSUBMSK]		/*	 initialise system clocks        */	mov	r1, #CLK_CTL_BASE	mvn	r2, #0xff000000	str	r2, [r1, #oLOCKTIME]	/*         1:2:4        */	mov	r1, #CLK_CTL_BASE	mov	r2, #0x3	str	r2, [r1, #oCLKDIVN]	mrc	p15, 0, r1, c1, c0, 0		/*  read ctrl register */	orr	r1, r1, #0xc0000000		/*  Asynchronous   */	mcr	p15, 0, r1, c1, c0, 0		/* write ctrl register */	/*          now, CPU clock is 200 Mhz        */	mov	r1, #CLK_CTL_BASE	ldr	r2, L$_mpll_user	str	r2, [r1, #oMPLLCON]        bl	memsetup	/*	All Led On	*/	mov	r1, #GPIO_CTL_BASE	add	r1, r1, #oGPIO_F	ldr	r2,=0x55aa	str	r2, [r1, #oGPIO_CON]	mov	r2, #0xff	str	r2, [r1, #oGPIO_UP]	mov	r2, #0x00	str	r2, [r1, #oGPIO_DAT]	mov	r1, #GPIO_CTL_BASE	add	r1, r1, #oGPIO_H	ldr	r2, L$_gpio_con_uart		str	r2, [r1, #oGPIO_CON]	ldr	r2, L$_gpio_up_uart	str	r2, [r1, #oGPIO_UP]		bl	InitUART#if 1	/*	Print current Program Counter        */	ldr	r1, L$_SerBase	mov	r0, #'\r'	bl	PrintChar	mov	r0, #'\n'	bl	PrintChar	mov	r0, #'@'	bl	PrintChar	mov	r0, pc	bl	PrintHexWord#endif#if 0	STR	r1, [r2, #FIQ_DISABLE-IC_BASE]	/* disable all FIQ sources */	STR	r1, [r2, #IRQ_DISABLE-IC_BASE]	/* disable all IRQ sources */#endif	/*	 * Jump to the normal (higher) ROM Position. After a reset, the	 * ROM is mapped into memory from* location zero upwards as well	 * as in its normal position at This code could be executing in	 * the lower position. We wish to be executing the code, still	 * in ROM, but in its normal (higher) position before we remap	 * the machine so that the ROM is no longer dual-mapped from zero	 * upwards, but so that RAM appears from 0 upwards.	 */	LDR	pc, L$_HiPosnHiPosn:#if defined(CPU_966ES) || defined(CPU_966ES_T)	/*	 * Set 966RAM emulation, makes external SSRAM look like	 * internal RAM.	 */	MOV	r2, #INTEGRATOR_HDR_BASE	LDR	r1, =0xA05F	STR	r1, [r2, #INTEGRATOR_HDR_LOCK_OFFSET]	LDR	r1, =INTEGRATOR_HDR_TCRAM_EMULATE | \                     INTEGRATOR_HDR_CLKRATIO_2 | \                     INTEGRATOR_HDR_HCLKDIV_3 | \                     INTEGRATOR_HDR_PLLBYPASS_ON	STR	r1, [r2, #INTEGRATOR_HDR_INIT_OFFSET]	MOV	r1, #0	STR	r1, [r2, #INTEGRATOR_HDR_LOCK_OFFSET]	/*	 * Enable Instruction SRAM, Data SRAM and Write buffer.	 */	LDR	r1, =ARM966_I_SRAM_ENABLE | ARM966_WBUFF_ENABLE | \                     ARM966_D_SRAM_ENABLE	MCR	CP_MMU, 0, r1, c1, c0, 0#endif   /*  defined(CPU_966ES) || defined(CPU_966ES_T) */#if 0    /* No remap */	/*	 * We are now executing in the normal (higher, still in ROM)	 * position in the memory map.  Remap memory to post-reset state,	 * so that the ROM is not now dual-mapped to zero upwards, but	 * RAM is mapped from zero, instead.	 */	MOV	r1, #INTEGRATOR_HDR_REMAP	MOV	r2, #INTEGRATOR_HDR_BASE	STR	r1, [r2, #INTEGRATOR_HDR_CTRL_OFFSET]	/*	 * SSRAM is now mapped from 0 upwards.	 *	 * Setup asynchronous clocking (eg. core and memory clocks different)	 */#endif /* No Remap */#if  0    /* Follow code were not need at all    cxg8888  */	LDR	r1, =INTEGRATOR_HDR_BASE	LDR	r2, [r1, #INTEGRATOR_HDR_OSC_OFFSET]	AND	r2, r2, #(3 << 23)	CMP	r2, #(1 << 23)	BNE	clock1#if defined(CPU_920T) || defined(CPU_920T_T) || \    defined(CPU_940T) || defined(CPU_940T_T)	/*	 * if HDR_OSC indicates (bits[23:24] = 01), set	 * implementation-specific bits in the MMU control register - set	 * asynchronous mode.	 */	MRC	CP_MMU, 0, r2, c1, c0, 0	ORR	r2, r2, #MMUCR_ASYNC	MCR	CP_MMU, 0, r2, c1, c0, 0#endif   /*  defined(CPU_920T) || defined(CPU_920T_T) || \		    defined(CPU_940T) || defined(CPU_940T_T)  */           clock1:	/* If bits[23:24] were 0, set asynchronous mode in HDR_CTRL */	LDRLT	r2, [r1, #INTEGRATOR_HDR_CTRL_OFFSET]	BICLT	r2, r2, #INTEGRATOR_HDR_CTRL_FASTBUS	STRLT	r2, [r1, #INTEGRATOR_HDR_CTRL_OFFSET]	/*	 * setup default clocks	 *	 * Core clock must always be greater than memory clock.	 *	 * Read HDR_PROC register, if this is non zero then there is no	 * coprocessor, in this case use the default settings. First,	 * load the default settings.	 */	LDR	r2, =INTEGRATOR_HDR_OSC_DFLT_VAL	LDR	r1, =INTEGRATOR_HDR_BASE	LDR	r3, [r1, #INTEGRATOR_HDR_PROC_OFFSET]	CMP	r3, #0	BNE	write_clock		/*	 * HDR_PROC was zero => there is a coprocessor. Get the processor ID.	 *	 * If the processor type is not recognised then the default settings	 * will be used.	 *	 * For safety's sake, make the following conditional upon there being a	 * coprocessor in the CPU.	 */#if defined(CPU_720T)  || defined(CPU_720T_T)  || \    defined(CPU_740T)  || defined(CPU_740T_T)  || \    defined(CPU_920T)  || defined(CPU_920T_T)  || \    defined(CPU_940T)  || defined(CPU_940T_T)  || \    defined(CPU_946ES) || defined(CPU_946ES_T) || \    defined(CPU_966ES) || defined(CPU_966ES_T)	MRC	CP_MMU, 0, r1, c0, c0, 0	MOV	r3, r1, LSL #16	MOV	r3, r3, LSR #20		/* move bits 15-3 to 12-0 */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩午夜激情av| 国产精品全国免费观看高清| 国产欧美日韩三区| 奇米影视一区二区三区| 日本电影亚洲天堂一区| 中文字幕免费不卡| 99视频国产精品| 国产精品美日韩| 3751色影院一区二区三区| 日精品一区二区三区| 欧美人妖巨大在线| 美女视频黄 久久| 亚洲精品在线观看网站| 精品国产一区久久| 一道本成人在线| 亚洲成国产人片在线观看| 欧美区在线观看| 一本色道久久综合亚洲精品按摩 | 日日夜夜一区二区| 国产精品久久久久久久久搜平片 | 欧美精品v日韩精品v韩国精品v| 天天综合天天综合色| 日韩精品一区二区在线观看| 国产91在线|亚洲| 国产精品区一区二区三区| 日韩一级大片在线| 在线播放91灌醉迷j高跟美女 | 欧美日韩国产小视频在线观看| 成人黄动漫网站免费app| 亚洲黄色小说网站| 欧美精品第1页| 欧美视频一区二区| 精品一区二区免费看| 欧美激情一区二区三区四区| 久久久久综合网| 色综合久久88色综合天天| 99久久精品免费精品国产| 蜜臀av一区二区| 日本视频一区二区三区| 中文字幕日韩欧美一区二区三区| 欧美调教femdomvk| 日本精品视频一区二区三区| 91尤物视频在线观看| 日韩专区在线视频| 日韩精品乱码av一区二区| 五月天欧美精品| 日本不卡视频在线观看| 蜜臀精品一区二区三区在线观看 | 精品国产一二三| 欧美成人女星排行榜| 色女孩综合影院| 一本到高清视频免费精品| 91福利在线看| 欧美一级片免费看| 日本高清免费不卡视频| 欧美视频完全免费看| 欧美乱妇15p| 欧美电影免费观看高清完整版 | 亚洲线精品一区二区三区八戒| 精品国产第一区二区三区观看体验| 精品欧美一区二区在线观看| 日韩亚洲电影在线| 中文字幕免费不卡在线| 一区二区成人在线| 国产精品不卡一区| 亚洲一区中文在线| 中文欧美字幕免费| 色综合久久88色综合天天| 欧美性感一区二区三区| 日韩丝袜情趣美女图片| 欧美国产综合一区二区| 亚洲资源在线观看| 极品美女销魂一区二区三区免费| 国内精品国产三级国产a久久| 亚洲一区二区三区中文字幕| 奇米在线7777在线精品| 成人激情校园春色| 欧美军同video69gay| 久久蜜桃一区二区| 亚洲一区在线观看视频| 狠狠色狠狠色综合| 在线视频国内一区二区| 色综合久久久久| 日韩欧美一级二级三级| 国产精品色在线| 日韩**一区毛片| 成人手机电影网| 波多野结衣中文字幕一区二区三区 | 91成人在线免费观看| 日韩女优av电影在线观看| 亚洲人成7777| 一区二区三区四区不卡在线| 久久99久久99| 欧美视频三区在线播放| 国产日韩精品一区二区浪潮av | 中文字幕日韩一区| 乱中年女人伦av一区二区| 久久69国产一区二区蜜臀| 在线亚洲免费视频| 欧美激情一区不卡| 麻豆一区二区三| 欧美怡红院视频| 国产精品婷婷午夜在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产偷国产偷亚洲高清人白洁| 国产夜色精品一区二区av| 亚洲国产综合色| 99久久精品国产一区| 久久久www成人免费毛片麻豆| 三级在线观看一区二区| 91在线视频免费观看| 久久亚洲精华国产精华液 | 国产精品久久久久久久久图文区| 久久精品国产精品亚洲精品 | 精品国产a毛片| 五月天视频一区| 欧美性大战久久| 亚洲综合无码一区二区| 91免费国产视频网站| 欧美国产在线观看| 国产成人精品免费| 色婷婷av一区二区三区大白胸 | 久久欧美一区二区| 麻豆传媒一区二区三区| 制服丝袜亚洲播放| 首页国产欧美久久| 欧美精品99久久久**| 亚洲一级片在线观看| 日本乱人伦aⅴ精品| 亚洲精品网站在线观看| 91福利精品第一导航| 一区二区三区在线观看国产| 色狠狠一区二区| 亚洲一区二区三区小说| 精品视频999| 久久众筹精品私拍模特| 久久国产综合精品| 精品福利一二区| 国产一区二区看久久| 欧美日韩在线一区二区| 亚洲一区二区黄色| 欧美乱妇15p| 日本不卡一区二区| 精品国产免费一区二区三区四区 | 一区二区三区在线影院| 欧美亚州韩日在线看免费版国语版| 亚洲女厕所小便bbb| 欧美亚男人的天堂| 亚洲gay无套男同| 日韩一区二区精品葵司在线| 久久99精品久久久| 国产欧美精品一区二区色综合| 成人免费不卡视频| 一区二区视频在线| 69久久夜色精品国产69蝌蚪网| 狂野欧美性猛交blacked| 国产午夜精品一区二区三区嫩草 | 麻豆国产精品视频| 久久美女艺术照精彩视频福利播放| 高清成人免费视频| 一区二区高清在线| 日韩欧美国产一区二区在线播放| 国产成人精品一区二区三区四区 | 91蝌蚪国产九色| 婷婷中文字幕一区三区| 精品三级在线观看| 成人aa视频在线观看| 婷婷六月综合网| 久久久久99精品国产片| 91福利区一区二区三区| 免费观看久久久4p| 国产精品乱码久久久久久| 精品视频在线看| 国产最新精品免费| 亚洲影院在线观看| 久久色在线观看| 日本丰满少妇一区二区三区| 精品一区二区三区香蕉蜜桃| 中文字幕在线观看一区二区| 91.麻豆视频| 99精品热视频| 精品在线一区二区| 亚洲国产精品久久人人爱蜜臀 | 99精品欧美一区| 日本亚洲最大的色成网站www| 国产免费成人在线视频| 91精品欧美久久久久久动漫| 成人免费视频一区| 日韩av一区二区在线影视| 国产精品狼人久久影院观看方式| 亚洲制服欧美中文字幕中文字幕| 精品国产一区二区三区av性色| 99re在线视频这里只有精品| 久久精品噜噜噜成人av农村| 亚洲天堂精品在线观看| 99在线精品观看| 日韩高清不卡一区二区三区| 亚洲卡通欧美制服中文| 精品国精品国产| 7777精品久久久大香线蕉|