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

📄 rominit.s

📁 workbench下vxworks6.6的ARM920T核对应的BSP源码
💻 S
📖 第 1 页 / 共 2 页
字号:
/* romInit.s - ARM Integrator ROM initialization module *//* Copyright 1999-2001 ARM Limited *//* * Copyright (c) 1999-2007 Wind River Systems, Inc. * * The right to copy, distribute or otherwise make use of this software * may be licensed only pursuant to the terms of an applicable Wind River * license agreement. *//*modification history--------------------01v,16oct07,j_b  adjustment for >16-bit MMU_INIT_VALUE for 926e (WIND00060071)01u,26sep07,mdo  Clear out apigen errors/warnings01t,04jan06,jb  Fix incomplete comment bug01s,28sep05,h_k  added a missing .data. (SPR #112990)01r,21jul05,h_k  removed copyright_wind_river.01q,01apr05,rec  fix typo in CPU_926E preprocessor statements01p,29mar05,jb   Adding 1136jfs support01o,12aug04,scm  add 926E support...01n,04feb03,jb   Adding ARM10 Support01m,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 initialization 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.INCLUDE FILES:SEE ALSO:\tb "ARM Architecture Reference Manual,"\tb "ARM 7TDMI Data Sheet,"\tb "ARM 720T Data Sheet,"\tb "ARM 740T Data Sheet,"\tb "ARM 920T Technical Reference Manual",\tb "ARM 940T Technical Reference Manual",\tb "ARM 946E-S Technical Reference Manual",\tb "ARM 966E-S Technical Reference Manual",\tb "ARM 1020E Technical Reference Manual",\tb "ARM 1022E Technical Reference Manual",\tb "ARM 1136JF-S Technical Reference Manual",\tb "ARM Reference Peripherals Specification,"\tb "ARM Integrator/AP User Guide",\tb "ARM Integrator/CM7TDMI User Guide",\tb "ARM Integrator/CM720T User Guide",\tb "ARM Integrator/CM740T User Guide",\tb "ARM Integrator/CM920T User Guide",\tb "ARM Integrator/CM940T User Guide",\tb "ARM Integrator/CM946E User Guide",\tb "ARM Integrator/CM9x6ES Datasheet".\tb "ARM Integrator/CM10200 User Guide",\tb "ARM Integrator/CM1136JF-S User Guide",*/#define	_ASMLANGUAGE#include <vxWorks.h>#include <sysLib.h>#include <asm.h>#include <regs.h>#include <config.h>#include <arch/arm/mmuArmLib.h>/* 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 */	.data_sdata:VAR_LABEL(sdata)	.asciz	"start of data"	.balign	4/* variables */VAR_LABEL(integratorMemSize)	.long	0	.text	.balign 4/********************************************************************************* romInit - entry point for VxWorks in ROM** SYNOPSIS* \ss* romInit*     (*     int startType	/@ only used by 2nd entry point @/*     )* \se** RETURNS: N/A** 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-2007 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.	 */	TEQ	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_926E)  || defined(CPU_926E_T) || \    defined(CPU_940T)  || defined(CPU_940T_T) || \    defined(CPU_946ES) || defined(CPU_946ES_T) || \    defined(CPU_1020E) || defined(CPU_1022E) || \    defined(CPU_1136JF)	/*	 * 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 */	LDR	r1, =MMU_INIT_VALUE		/* Defined in mmuArmLib.h */#endif /* defined(CPU_920T/920T_T/1020E/1022E/1136JF) */	MCR	CP_MMU, 0, r1, c1, c0, 0	/* Write to MMU CR */#if defined(CPU_1020E)	NOP	NOP	NOP#endif /* defined(CPU_1020E) */	/*	 * 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_926E) || defined(CPU_926E_T) || \    defined(CPU_946ES) || defined(CPU_946ES_T) || \    defined(CPU_1020E) || defined(CPU_1022E) || \    defined(CPU_1136JF)	MOV	r1, #0				/* data SBZ */	MCR	CP_MMU, 0, r1, c7, c10, 4	/* drain write-buffer */#if defined(CPU_1020E)        NOP        NOP        NOP#endif /* defined(CPU_1020E) */	/* Flush (invalidate) both I and D caches */	MCR	CP_MMU, 0, r1, c7, c7, 0	/* R1 = 0 from above, data SBZ*/#if defined(CPU_1020E)        NOP        NOP        NOP#endif /* defined(CPU_1020E) */#if defined(CPU_920T) || defined(CPU_920T_T) || \    defined(CPU_926E) || defined(CPU_926E_T) || \    defined(CPU_1020E) || defined(CPU_1022E) || \    defined(CPU_1136JF)#if defined(INTEGRATOR_EARLY_I_CACHE_ENABLE)        MRC     CP_MMU, 0, r1, c1, c0, 0	ORR	r1, r1, #MMUCR_I_ENABLE		/* conditionally enable Icache*/        MCR     CP_MMU, 0, r1, c1, c0, 0        /* Write to MMU CR */#endif /* defined(INTEGRATOR_EARLY_I_CACHE_ENABLE) */#endif /* defined(CPU_920T,926E,946ES,1020E,1022E,1136JF) */#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(940T,940T_T) */#if defined(CPU_720T)  || defined(CPU_720T_T) || \    defined(CPU_920T)  || defined(CPU_920T_T) || \    defined (CPU_926E) || defined (CPU_926E_T) || \    defined(CPU_1020E) || defined(CPU_1022E) || \    defined(CPU_1136JF)        /*	 * 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#if defined(CPU_1020E)        NOP        NOP        NOP#endif /* defined(CPU_1020E) */#endif /* defined(CPU_720T,920T,1020E, 1022E) */#if defined (CPU_926E) || defined (CPU_926E_T) || \    defined (CPU_946ES) || defined (CPU_946ES_T) || \    defined (CPU_1020E) || defined (CPU_1020E_T) || \    defined (CPU_1022E) || defined (CPU_1022E_T) || \    defined (CPU_1136JF)            /* Set Context ID Register to zero, including Address Space ID */            MCR     CP_MMU, 0, r1, c13, c0, 1#endif /* defined (CPU_926E, 946ES,1020E, 1022E, 1136JF) */#endif /* defined(CPU_720T,740T,920T,940T,946ES,1020E,1022E,1136JF) */	/* 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	 */	MOV	r2, #IC_BASE			/* R2->interrupt controller */	MVN	r1, #0				/* &FFFFFFFF */	STR	r1, [r2, #FIQ_DISABLE-IC_BASE]	/* disable all FIQ sources */	STR	r1, [r2, #IRQ_DISABLE-IC_BASE]	/* 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:#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.	 */

⌨️ 快捷键说明

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