⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rominitasm.s

📁 包含makefile config.h rominit romstart userinit 等等文件
💻 S
字号:
/* romInit.s - ARM Integrator ROM initialization module *//*modification history--------------------2004/10/23 this file is modified form VxWorks demo bsp integrator920t*//*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.*/#define	_ASMLANGUAGE#include "vxWorks.h"#include "sysLib.h"#include "asm.h"#include "regs.h"	#include "config.h"#include "arch/arm/mmuArmLib.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 */	.extern FUNC(StartHwInit)
	.extern FUNC( romCInitRtn )_sdata:VAR_LABEL(sdata)	.asciz	"start of data"	.balign	4	.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-2004 ARM Limited"	.ascii   "\nCopyright 1999-2004 JSEPTRI, 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, #AT91RM9200_DELAY_VALUE	MOVNE	r1, #1delay_loop:	SUBS	r1, r1, #1	BNE	delay_loop#if defined(CPU_920T)	/*	 * 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(AT91RM9200_EARLY_I_CACHE_ENABLE)	ORR	r1, r1, #MMUCR_I_ENABLE		/* conditionally enable Icache*/#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.	 */	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*/        /*	 * 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,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	/*	 * CPU INTERRUPTS DISABLED	 *	 * disable individual interrupts in the interrupt controller	 */	LDR	r2, =AIC_BASE_ADDR			/* R2->interrupt controller */	MVN	r1, #0				/* &FFFFFFFF */	STR	r1, [r2, #AIC_IDCR_OFFSET]	/* disable all IRQ sources */		/*	 * 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:		/*	 * 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, #1	LDR	r2, =MC_BASE_ADDR	STR	r1, [r2, #MC_RCR_OFFSET]

	LDR sp, =ARM920T_ROMINIT_C_STACK_TOP

	MOV lr, pc
	LDR pc, L$_romCInit_ADDR 
	
	/*	 * SSRAM is now mapped from 0 upwards.	 *	 * Setup asynchronous clocking (eg. core and memory clocks different)	 */		/* disable all interrup for pmc */	LDR r1, =PMC_BASE_ADDR	LDR r2, =PMC_CKGR_MOR_VALUE	STR r2, [r1,#PMC_CKGR_MOR_OFFSET]	/* start the Main osc */	/*wait main os stabliize */	LDR r3, =DELAY_MAIN_FREQ
branch1:	LDR r2, [r1, #(PMC_SR_OFFSET)]	TST r2, #PMC_SR_MOSCS	BNE branch2	SUBS r3, r3, #1	BGT  branch1branch2:		/* main osc should stab now, continue startup PLLA */	MVN r2, #0	/*0xfffffff disable all interrupt*/	STR r2, [r1, #(PMC_IDR_OFFSET)]		LDR r2, =PMC_PLLA_VALUE	STR r2, [r1, #(PMC_CKGR_PLLAR_OFFSET)]		LDR r3, =DELAY_MAIN_FREQ
	LDR r4, =PMC_SR_LOCKA	branch3:	LDR r2, [r1, #(PMC_SR_OFFSET)]	TST r2, r4	BNE branch4	SUBS r3, r3, #1	BGT branch3	branch4:
	/* in order to ascess flash correctly, it seems need to fir setup SMC, and MC first	1. setup EBI	2. setup chip select 0(SMC)	*/	LDR r2, =EBI_CSA_VALUE	LDR r1, =EBI_BASE_ADDR	STR r2, [r1, #EBI_CSA_OFFSET]		LDR r1, =SMC_BASE_ADDR	LDR R2, =SMC_CSR0_VALUE	STR r2, [r1, #SMC_CSR0_OFFSET]			/* master clock setup, now the flash ascess time already setup		write a dirty value to MCKR, the new MCKR value must not same as before	  so make a dummy write to it first	*/		LDR r1, =PMC_BASE_ADDR	LDR r2, =0x203	STR r2, [r1, #(PMC_MCKR_OFFSET)]		LDR r3, =DELAY_MAIN_FREQ 
		branch5:	/*wait new state to be stability */	LDR r2, [r1, #(PMC_SR_OFFSET)]	TST r2, #PMC_SR_MCKRDY	BNE branch6	SUBS r3, r3, #1	BGT branch5branch6:					/*write real used set value to MCKR*/	LDR r2, =PMC_MCKR_VALUE	/*select PLLA as master clock */	STR r2, [r1, #(PMC_MCKR_OFFSET)]		LDR r3, =DELAY_MAIN_FREQ 
		branch7:	/*wait new state to be stability again*/	LDR r2, [r1, #(PMC_SR_OFFSET)]	TST r2, #PMC_SR_MCKRDY	BNE branch8	SUBS r3, r3, #1	BGT branch7	branch8:	/* here we finished setup the process frequency and 	MASTER clock frequency, and now we should run at 180MHz	ok, now we need to setup SDRAM	 */

	 	 	/* Configure PIOC as peripheral (D16/D31) */	LDR r1, =PIOC_BASE_ADDR	LDR r2, =PIOC_ENABLE_D16	STR r2, [r1, #PIO_ASR_OFFSET]	STR r2, [r1, #PIO_PDR_OFFSET]		/*Init SDRAM, DBW is 32 bit always*/	LDR r2, =SDRAMC_CR_VALUE	LDR r1, =SDRAMC_BASE_ADDR	STR r2, [r1, #SDRAMC_CR_OFFSET]		MOV r2, #SDRAMC_MR_PRECHG	STR r2, [r1, #SDRAMC_MR_OFFSET]		LDR r3, =LOCAL_MEM_LOCAL_ADRS	MOV r4, #0	STR r4,[r3]	
			LDR r2, =SDRAMC_MR_REFLASH	STR r2, [r1, #SDRAMC_MR_OFFSET]		STR r4,[r3]	STR r4,[r3]	STR r4,[r3]	STR r4,[r3]	STR r4,[r3]	STR r4,[r3]	STR r4,[r3]	STR r4,[r3]			LDR r2, =SDRAMC_MR_LDMODE	STR r2, [r1, #SDRAMC_MR_OFFSET]		LDR r2, =SDRAMC_TR_VALUE	STR r2, [r1, #SDRAMC_TR_OFFSET]		MOV r2, #SDRAMC_MR_NORMAL	STR r2, [r1, #SDRAMC_MR_OFFSET]			/* we should finished the SDRAM init, what will we do next? */		/*	 * End of DRAM initialisation.	 *	 * Initialize the stack pointer to just before where the	 * uncompress code, copied from ROM to RAM, will run.	 */	LDR	sp, L$_STACK_ADDR	MOV	fp, #0			/* zero frame pointer */	/* jump to C entry point in ROM: routine - entry point + ROM base */#if	(ARM_THUMB)	LDR	r12, L$_rStrtInRom	ORR	r12, r12, #1		/* force Thumb state */	BX	r12#else	LDR	pc, L$_rStrtInRom#endif	/* (ARM_THUMB) *//******************************************************************************//* * PC-relative-addressable pointers - LDR Rn,=sym is broken * note "_" after "$" to stop preprocessor performing substitution */	.balign	4	L$_HiPosn:	.long	ROM_TEXT_ADRS + HiPosn - FUNC(romInit)L$_rStrtInRom:	.long	ROM_TEXT_ADRS + FUNC(romStart) - FUNC(romInit)L$_STACK_ADDR:	.long	STACK_ADRS

L$_romCInit_ADDR:
	.long  ROM_TEXT_ADRS + FUNC(romCInitRtn) - FUNC(romInit) 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -