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

📄 setup.s

📁 UBOOT 源码
💻 S
字号:
/* * Board specific setup info * * (C) Copyright 2004 Ales Jindra <jindra@2n.cz> * (C) Copyright 2005 Ladislav Michl <michl@2n.cz> * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * version 2 published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <config.h>#include <version.h>_TEXT_BASE:	.word	TEXT_BASE	/* SDRAM load addr from config.mk */OMAP5910_LPG1_BASE:		.word 0xfffbd000OMAP5910_TIPB_SWITCHES_BASE:	.word 0xfffbc800OMAP5910_MPU_TC_BASE:		.word 0xfffecc00OMAP5910_MPU_CLKM_BASE:		.word 0xfffece00OMAP5910_ULPD_PWR_MNG_BASE:	.word 0xfffe0800OMAP5910_DPLL1_BASE:		.word 0xfffecf00OMAP5910_GPIO_BASE:		.word 0xfffce000OMAP5910_MPU_WD_TIMER_BASE:	.word 0xfffec800OMAP5910_MPUI_BASE:		.word 0xfffec900_OMAP5910_ARM_CKCTL:		.word OMAP5910_ARM_CKCTL_OMAP5910_ARM_EN_CLK:		.word OMAP5910_ARM_EN_CLKOMAP5910_MPUI_CTRL:		.word 0x0000ff1bVAL_EMIFS_CS0_CONFIG:		.word 0x00009090VAL_EMIFS_CS1_CONFIG:		.word 0x00003031VAL_EMIFS_CS2_CONFIG:		.word 0x00003031VAL_EMIFS_CS3_CONFIG:		.word 0x0000c0c0VAL_EMIFS_DYN_WAIT:		.word 0x00000000/* autorefresh counter 0x246 ((64000000/13.4)-400)/8192) */				/*     SLRF       SD_RET     ARE        SDRAM_TYPE   ARCV           SDRAM_FREQUENCY PWD     CLK */VAL_EMIFF_SDRAM_CONFIG:		.word ((0 << 0) | (0 << 1) | (3 << 2) | (0xd << 4) | (0x246 << 8) | (0 << 24) | (0 << 26) | (0 << 27))VAL_EMIFF_SDRAM_CONFIG2:	.word 0x00000003VAL_EMIFF_MRS:			.word 0x00000037/* * GPIO04 - D4 (Onboard LED) * GPIO07 - LAN91C111 reset */GPIO_DIRECTION:	.word 0x0000ff6f/* * Disable everything, but D4 LED (connected through invertor) */GPIO_OUTPUT:	.word 0x00000010MUX_CONFIG_BASE:	.word 0xfffe1000MUX_CONFIG_VALUES:	.align 4	.word 0x00000000	@ FUNC_MUX_CTRL_0	.word 0x00000000	@ FUNC_MUX_CTRL_1	.word 0x00000000	@ FUNC_MUX_CTRL_2	.word 0x00000000	@ FUNC_MUX_CTRL_3	.word 0x00000000	@ FUNC_MUX_CTRL_4	.word 0x12082480	@ FUNC_MUX_CTRL_5	.word 0x00000004	@ FUNC_MUX_CTRL_6	.word 0x00000003	@ FUNC_MUX_CTRL_7	.word 0x10001200	@ FUNC_MUX_CTRL_8	.word 0x01201012	@ FUNC_MUX_CTRL_9	.word 0x02081248	@ FUNC_MUX_CTRL_A	.word 0x00001248	@ FUNC_MUX_CTRL_B	.word 0x12240000	@ FUNC_MUX_CTRL_C	.word 0x00002000	@ FUNC_MUX_CTRL_D	.word 0x00000000	@ PULL_DWN_CTRL_0	.word 0x0000085f	@ PULL_DWN_CTRL_1	.word 0x01001000	@ PULL_DWN_CTRL_2	.word 0x00000000	@ PULL_DWN_CTRL_3	.word 0x00000000	@ GATE_INH_CTRL_0	.word 0x00000000	@ VOLTAGE_CTRL_0	.word 0x00000000	@ TEST_DBG_CTRL_0	.word 0x00000006	@ MOD_CONF_CTRL_0	.word 0x0000eaef	@ COMP_MODE_CTRL_0MUX_CONFIG_OFFSETS:	.align 1	.byte 0x00		@ FUNC_MUX_CTRL_0	.byte 0x04		@ FUNC_MUX_CTRL_1	.byte 0x08		@ FUNC_MUX_CTRL_2	.byte 0x10		@ FUNC_MUX_CTRL_3	.byte 0x14		@ FUNC_MUX_CTRL_4	.byte 0x18		@ FUNC_MUX_CTRL_5	.byte 0x1c		@ FUNC_MUX_CTRL_6	.byte 0x20		@ FUNC_MUX_CTRL_7	.byte 0x24		@ FUNC_MUX_CTRL_8	.byte 0x28		@ FUNC_MUX_CTRL_9	.byte 0x2c		@ FUNC_MUX_CTRL_A	.byte 0x30		@ FUNC_MUX_CTRL_B	.byte 0x34		@ FUNC_MUX_CTRL_C	.byte 0x38		@ FUNC_MUX_CTRL_D	.byte 0x40		@ PULL_DWN_CTRL_0	.byte 0x44		@ PULL_DWN_CTRL_1	.byte 0x48		@ PULL_DWN_CTRL_2	.byte 0x4c		@ PULL_DWN_CTRL_3	.byte 0x50		@ GATE_INH_CTRL_0	.byte 0x60		@ VOLTAGE_CTRL_0	.byte 0x70		@ TEST_DBG_CTRL_0	.byte 0x80		@ MOD_CONF_CTRL_0	.byte 0x0c		@ COMP_MODE_CTRL_0	.byte 0xff.globl lowlevel_initlowlevel_init:	/* Improve performance a bit... */	mrc	p15, 0, r1, c0, c0, 0		@ read C15 ID register	mrc	p15, 0, r1, c0, c0, 1		@ read C15 Cache information register	mrc	p15, 0, r1, c1, c0, 0		@ read C15 Control register	orr	r1, r1, #0x1000			@ enable I-cache, map interrupt vector 0xffff0000	mcr	p15, 0, r1, c1, c0, 0		@ write C15 Control register	mov	r1, #0x00	mcr	p15, 0, r1, c7, c5, 0		@ Flush I-cache	nop	nop	nop	nop	/* Setup clocking mode */	ldr	r0, OMAP5910_MPU_CLKM_BASE	@ prepare base of CLOCK unit	ldrh	r1, [r0, #0x18]			@ get reset status	bic	r1, r1, #(7 << 11)		@ clear clock select	orr	r1, r1, #(2 << 11)		@ set synchronous scalable	mov	r2, #0				@ set wait counter to 100 clock cyclesicache_loop:	cmp	r2, #0x01	streqh	r1, [r0, #0x18]	add	r2, r2, #0x01	cmp	r2, #0x10	bne	icache_loop	nop	/* Setup clock divisors */	ldr	r0, OMAP5910_MPU_CLKM_BASE	@ base of CLOCK unit	ldr	r1, _OMAP5910_ARM_CKCTL	orr	r1, r1, #0x2000			@ enable DSP clock	strh	r1, [r0, #0x00]			@ setup clock divisors	/* Setup DPLL to generate requested freq */	ldr	r0, OMAP5910_DPLL1_BASE		@ base of DPLL1 register	mov	r1, #0x0010			@ set PLL_ENABLE	orr	r1, r1, #0x2000			@ set IOB to new locking	orr	r1, r1, #(OMAP5910_DPLL_MUL << 7) @ setup multiplier CLKREF	orr	r1, r1, #(OMAP5910_DPLL_DIV << 5) @ setup divider CLKREF	strh	r1, [r0]			@ writelocking:	ldrh	r1, [r0]			@ get DPLL value	tst	r1, #0x01	beq	locking				@ while LOCK not set	/* Enable clock */	ldr	r0, OMAP5910_MPU_CLKM_BASE	@ base of CLOCK unit	mov	r1, #(1 << 10)			@ disable idle mode do not check						@ nWAKEUP pin, other remain active	strh	r1, [r0, #0x04]	ldr	r1, _OMAP5910_ARM_EN_CLK	strh	r1, [r0, #0x08]	mov	r1, #0x003f			@ FLASH.RP not enabled in idle and						@ max delayed ( 32 x CLKIN )	strh	r1, [r0, #0x0c]	/* Configure 5910 pins functions to match our board. */	ldr     r0, MUX_CONFIG_BASE	adr	r1, MUX_CONFIG_VALUES	adr	r2, MUX_CONFIG_OFFSETSnext_mux_cfg:	ldrb	r3, [r2], #1	ldr	r4, [r1], #4	cmp	r3, #0xff	strne	r4, [r0, r3]	bne	next_mux_cfg	/* Configure GPIO pins (also enables onboard LED) */	ldr	r0, OMAP5910_GPIO_BASE	ldr	r1, GPIO_OUTPUT	strh    r1, [r0, #0x04]	ldr	r1, GPIO_DIRECTION	strh	r1, [r0, #0x08]	/* EnablePeripherals */	ldr	r0, OMAP5910_MPU_CLKM_BASE	@ CLOCK unit	mov	r1, #0x0001			@ Peripheral enable	strh	r1, [r0, #0x14]	/* Program LED Pulse Generator */	ldr	r0, OMAP5910_LPG1_BASE		@ 1st LED Pulse Generator	mov	r1, #0x7F			@ Set obscure frequency in	strb	r1, [r0, #0x00]			@ LCR	mov	r1, #0x01			@ Enable clock (CLK_EN) in	strb    r1, [r0, #0x04]			@ PMR	/* TIPB Lock UART1 */	ldr	r0, OMAP5910_TIPB_SWITCHES_BASE	@ prepare base of TIPB switches	mov	r1, #1				@ ARM allocated	strh	r1, [r0,#0x04]			@ clear IRQ line and status bits	strh	r1, [r0,#0x00]	ldrh	r1, [r0,#0x04]	/* Disable watchdog */	ldr	r0, OMAP5910_MPU_WD_TIMER_BASE	mov	r1, #0xf5	strh	r1, [r0, #0x8]	mov	r1, #0xa0	strh	r1, [r0, #0x8]	/* Enable MCLK */	ldr	r0, OMAP5910_ULPD_PWR_MNG_BASE	mov	r1, #0x6	strh	r1, [r0, #0x34]	strh	r1, [r0, #0x34]	/* Setup clock divisors */	ldr	r0, OMAP5910_ULPD_PWR_MNG_BASE	@ base of ULDPL DPLL1 register	mov	r1, #0x0010			@ set PLL_ENABLE	orr	r1, r1, #0x2000			@ set IOB to new locking	strh	r1, [r0]			@ writeulocking:	ldrh	r1, [r0]			@ get DPLL value	tst	r1, #1	beq	ulocking			@ while LOCK not set	/* EMIF init */	ldr	r0, OMAP5910_MPU_TC_BASE	ldrh	r1, [r0, #0x0c]			@ EMIFS_CONFIG_REG	bic	r1, r1, #0x0c			@ pwr down disabled, flash WP	orr	r1, r1, #0x01	str	r1, [r0, #0x0c]	ldr	r1, VAL_EMIFS_CS0_CONFIG	str	r1, [r0, #0x10]			@ EMIFS_CS0_CONFIG	ldr	r1, VAL_EMIFS_CS1_CONFIG	str	r1, [r0, #0x14]			@ EMIFS_CS1_CONFIG	ldr	r1, VAL_EMIFS_CS2_CONFIG	str	r1, [r0, #0x18]			@ EMIFS_CS2_CONFIG	ldr	r1, VAL_EMIFS_CS3_CONFIG	str	r1, [r0, #0x1c]			@ EMIFS_CS3_CONFIG	ldr	r1, VAL_EMIFS_DYN_WAIT	str	r1, [r0, #0x40]			@ EMIFS_CFG_DYN_WAIT	/* Setup SDRAM */	ldr	r1, VAL_EMIFF_SDRAM_CONFIG	str	r1, [r0, #0x20]			@ EMIFF_SDRAM_CONFIG	ldr	r1, VAL_EMIFF_SDRAM_CONFIG2	str	r1, [r0, #0x3c]			@ EMIFF_SDRAM_CONFIG2	ldr	r1, VAL_EMIFF_MRS	str	r1, [r0, #0x24]			@ EMIFF_MRS	/* SDRAM needs 100us to stabilize */	mov	r0, #0x4000sdelay:	subs	r0, r0, #0x1	bne 	sdelay	/* back to arch calling code */	mov	pc, lr.end

⌨️ 快捷键说明

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