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

📄 lowlevel_init.s

📁 uboot200903最新版本的通用uboot
💻 S
字号:
/* * Copyright (C) 2008 Renesas Solutions Corp. * Copyright (C) 2008 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com> * * board/ap325rxa/lowlevel_init.S * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * 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>#include <asm/processor.h>#include <asm/macro.h>/* * Board specific low level init code, called _very_ early in the * startup sequence. Relocation to SDRAM has not happened yet, no * stack is available, bss section has not been initialised, etc. * * (Note: As no stack is available, no subroutines can be called...). */	.global	lowlevel_init	.text	.align	2lowlevel_init:	write16	DRVCRA_A, DRVCRA_D	write16	DRVCRB_A, DRVCRB_D	write16	RWTCSR_A, RWTCSR_D1	write16	RWTCNT_A, RWTCNT_D	write16	RWTCSR_A, RWTCSR_D2	write32	FRQCR_A, FRQCR_D	write32	CMNCR_A, CMNCR_D	write32	CS0BCR_A, CS0BCR_D	write32	CS4BCR_A, CS4BCR_D	write32	CS5ABCR_A, CS5ABCR_D	write32	CS5BBCR_A, CS5BBCR_D	write32	CS6ABCR_A, CS6ABCR_D	write32	CS6BBCR_A, CS6BBCR_D	write32	CS0WCR_A, CS0WCR_D	write32	CS4WCR_A, CS4WCR_D	write32	CS5AWCR_A, CS5AWCR_D	write32	CS5BWCR_A, CS5BWCR_D	write32	CS6AWCR_A, CS6AWCR_D	write32	CS6BWCR_A, CS6BWCR_D	write32	SBSC_SDCR_A, SBSC_SDCR_D1	write32	SBSC_SDWCR_A, SBSC_SDWCR_D	write32	SBSC_SDPCR_A, SBSC_SDPCR_D	write32	SBSC_RTCSR_A, SBSC_RTCSR_D	write32	SBSC_RTCNT_A, SBSC_RTCNT_D	write32	SBSC_RTCOR_A, SBSC_RTCOR_D	write8	SBSC_SDMR3_A1, SBSC_SDMR3_D	write8	SBSC_SDMR3_A2, SBSC_SDMR3_D	mov.l	SLEEP_CNT, r12:	tst	r1, r1	nop	bf/s	2b	dt	r1	write8	SBSC_SDMR3_A3, SBSC_SDMR3_D	write32	SBSC_SDCR_A, SBSC_SDCR_D2	write32	CCR_A, CCR_D	! BL bit off (init = ON) (?!?)	stc	sr, r0				! BL bit off(init=ON)	mov.l	SR_MASK_D, r1	and	r1, r0	ldc	r0, sr	rts	 mov	#0, r0	.align	2DRVCRA_A:	.long	DRVCRADRVCRB_A:	.long	DRVCRBDRVCRA_D:	.long	0x4555DRVCRB_D:	.long	0x0005RWTCSR_A:	.long	RWTCSRRWTCNT_A:	.long	RWTCNTFRQCR_A:	.long	FRQCRRWTCSR_D1:	.long	0xa507RWTCSR_D2:	.long	0xa504RWTCNT_D:	.long	0x5a00FRQCR_D:	.long	0x0b04474aSBSC_SDCR_A:	.long	SBSC_SDCRSBSC_SDWCR_A:	.long	SBSC_SDWCRSBSC_SDPCR_A:	.long	SBSC_SDPCRSBSC_RTCSR_A:	.long	SBSC_RTCSRSBSC_RTCNT_A:	.long	SBSC_RTCNTSBSC_RTCOR_A:	.long	SBSC_RTCORSBSC_SDMR3_A1:	.long	0xfe510000SBSC_SDMR3_A2:	.long	0xfe500242SBSC_SDMR3_A3:	.long	0xfe5c0042SBSC_SDCR_D1:	.long	0x92810112SBSC_SDCR_D2:	.long	0x92810912SBSC_SDWCR_D:	.long	0x05162482SBSC_SDPCR_D:	.long	0x00300087SBSC_RTCSR_D:	.long	0xa55a0212SBSC_RTCNT_D:	.long	0xa55a0000SBSC_RTCOR_D:	.long	0xa55a0040SBSC_SDMR3_D:	.long	0x00CMNCR_A:	.long	CMNCRCS0BCR_A:	.long	CS0BCRCS4BCR_A:	.long	CS4BCRCS5ABCR_A:	.long	CS5ABCRCS5BBCR_A:	.long	CS5BBCRCS6ABCR_A:	.long	CS6ABCRCS6BBCR_A:	.long	CS6BBCRCS0WCR_A:	.long	CS0WCRCS4WCR_A:	.long	CS4WCRCS5AWCR_A:	.long	CS5AWCRCS5BWCR_A:	.long	CS5BWCRCS6AWCR_A:	.long	CS6AWCRCS6BWCR_A:	.long	CS6BWCRCMNCR_D:	.long	0x00000013CS0BCR_D:	.long	0x24920400CS4BCR_D:	.long	0x24920400CS5ABCR_D:	.long	0x24920400CS5BBCR_D:	.long	0x7fff0600CS6ABCR_D:	.long	0x24920400CS6BBCR_D:	.long	0x24920600CS0WCR_D:	.long	0x00000480CS4WCR_D:	.long	0x00000480CS5AWCR_D:	.long	0x00000380CS5BWCR_D:	.long	0x00000080CS6AWCR_D:	.long	0x00000300CS6BWCR_D:	.long	0x00000540CCR_A:		.long	0xff00001cCCR_D:		.long	0x0000090dSLEEP_CNT:	.long	0x00000800SR_MASK_D:	.long	0xEFFFFF0F

⌨️ 快捷键说明

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