319 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			319 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
/*
 | 
						|
 * Copyright (C) 2009 Renesas Solutions Corp.
 | 
						|
 * Copyright (C) 2009 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
 | 
						|
 *
 | 
						|
 * board/espt/lowlevel_init.S
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier:	GPL-2.0+
 | 
						|
 */
 | 
						|
 | 
						|
#include <config.h>
 | 
						|
#include <asm/processor.h>
 | 
						|
#include <asm/macro.h>
 | 
						|
 | 
						|
	.global	lowlevel_init
 | 
						|
 | 
						|
	.text
 | 
						|
	.align	2
 | 
						|
 | 
						|
lowlevel_init:
 | 
						|
 | 
						|
	write32 WDTCSR_A, WDTCSR_D
 | 
						|
 | 
						|
	write32 WDTST_A, WDTST_D
 | 
						|
 | 
						|
	write32 WDTBST_A, WDTBST_D
 | 
						|
 | 
						|
	write32 CCR_A, CCR_CACHE_ICI_D
 | 
						|
 | 
						|
	write32 MMUCR_A, MMU_CONTROL_TI_D
 | 
						|
 | 
						|
	write32 MSTPCR0_A, MSTPCR0_D
 | 
						|
 | 
						|
	write32 MSTPCR1_A, MSTPCR1_D
 | 
						|
 | 
						|
	write32 RAMCR_A, RAMCR_D
 | 
						|
 | 
						|
	/*
 | 
						|
	 * Setting infomation from
 | 
						|
	 * original ESPT-GIGA bootloader register
 | 
						|
	 */
 | 
						|
	write32 MMSEL_A, MMSEL_D
 | 
						|
 | 
						|
	/* dummy */
 | 
						|
	mov.l   @r1, r2
 | 
						|
	mov.l   @r1, r2
 | 
						|
	synco
 | 
						|
 | 
						|
    write32 BCR_A, BCR_D
 | 
						|
 | 
						|
    write32 CS0BCR_A, CS0BCR_D
 | 
						|
 | 
						|
    write32 CS0WCR_A, CS0WCR_D
 | 
						|
 | 
						|
	/*
 | 
						|
	 * DDR-SDRAM setting
 | 
						|
	 */
 | 
						|
 | 
						|
	/* set DDR-SDRAM dummy read */
 | 
						|
	write32 MMSEL_A, MMSEL_D
 | 
						|
 | 
						|
	write32 MMSEL_A, CS0_A
 | 
						|
 | 
						|
	/* set DDR-SDRAM bus/endian etc */
 | 
						|
	write32 MIM_U_A, MIM_U_D
 | 
						|
 | 
						|
	write32 MIM_L_A, MIM_L_D0
 | 
						|
 | 
						|
	write32 SDR_L_A, SDR_L_A_D0
 | 
						|
 | 
						|
	write32 STR_L_A, STR_L_A_D0
 | 
						|
 | 
						|
	/* DDR-SDRAM access control */
 | 
						|
	write32 MIM_L_A, MIM_L_D1
 | 
						|
 | 
						|
	write32 SCR_L_A, SCR_L_A_D0
 | 
						|
 | 
						|
	write32 SCR_L_A, SCR_L_A_D1
 | 
						|
 | 
						|
	write32 EMRS_A, EMRS_D
 | 
						|
 | 
						|
	write32 MRS1_A, MRS1_D
 | 
						|
 | 
						|
	write32 MIM_U_A, MIM_U_D
 | 
						|
 | 
						|
	write32 MIM_L_A, MIM_L_A_D2
 | 
						|
 | 
						|
	write32 SCR_L_A, SCR_L_A_D2
 | 
						|
 | 
						|
	write32 SCR_L_A, SCR_L_A_D2
 | 
						|
 | 
						|
	write32 MRS2_A, MRS2_D
 | 
						|
 | 
						|
	/* wait 200us */
 | 
						|
	wait_timer REPEAT_R3
 | 
						|
 | 
						|
	/* GPIO setting */
 | 
						|
	write16 PSEL0_A, PSEL0_D
 | 
						|
 | 
						|
	write16 PSEL1_A, PSEL1_D
 | 
						|
 | 
						|
	write16 PSEL2_A, PSEL2_D
 | 
						|
 | 
						|
	write16 PSEL3_A, PSEL3_D
 | 
						|
 | 
						|
	write16 PSEL4_A, PSEL4_D
 | 
						|
 | 
						|
	write8 PADR_A, PADR_D
 | 
						|
 | 
						|
	write16 PACR_A, PACR_D
 | 
						|
 | 
						|
	write8 PBDR_A, PBDR_D
 | 
						|
 | 
						|
	write16 PBCR_A, PBCR_D
 | 
						|
 | 
						|
	write8 PCDR_A, PCDR_D
 | 
						|
 | 
						|
	write16 PCCR_A, PCCR_D
 | 
						|
 | 
						|
	write8	PDDR_A, PDDR_D
 | 
						|
 | 
						|
	write16 PDCR_A, PDCR_D
 | 
						|
 | 
						|
	write16 PECR_A, PECR_D
 | 
						|
 | 
						|
	write16 PFCR_A, PFCR_D
 | 
						|
 | 
						|
	write16 PGCR_A, PGCR_D
 | 
						|
 | 
						|
	write16 PHCR_A, PHCR_D
 | 
						|
 | 
						|
	write16 PICR_A, PICR_D
 | 
						|
 | 
						|
	write8 PJDR_A, PJDR_D
 | 
						|
 | 
						|
	write16 PJCR_A, PJCR_D
 | 
						|
 | 
						|
	/* wait 50us */
 | 
						|
	wait_timer REPEAT_R3
 | 
						|
 | 
						|
	write8 PKDR_A, PKDR_D
 | 
						|
 | 
						|
	write16 PKCR_A, PKCR_D
 | 
						|
 | 
						|
	write16 PLCR_A, PLCR_D
 | 
						|
 | 
						|
	write16 PMCR_A, PMCR_D
 | 
						|
 | 
						|
	write16 PNCR_A, PNCR_D
 | 
						|
 | 
						|
	write16 POCR_A, POCR_D
 | 
						|
 | 
						|
 | 
						|
	/* ICR0 ,ICR1 */
 | 
						|
	write32 ICR0_A, ICR0_D
 | 
						|
 | 
						|
	write32 ICR1_A, ICR1_D
 | 
						|
 | 
						|
	/* USB Host */
 | 
						|
	write32 USB_USBHSC_A, USB_USBHSC_D
 | 
						|
 | 
						|
	write32 CCR_A, CCR_CACHE_D_2
 | 
						|
 | 
						|
	rts
 | 
						|
	nop
 | 
						|
 | 
						|
	.align	2
 | 
						|
 | 
						|
/* GPIO Crontrol Register */
 | 
						|
PACR_A:	.long	0xFFEF0000
 | 
						|
PBCR_A:	.long	0xFFEF0002
 | 
						|
PCCR_A:	.long	0xFFEF0004
 | 
						|
PDCR_A:	.long	0xFFEF0006
 | 
						|
PECR_A:	.long	0xFFEF0008
 | 
						|
PFCR_A:	.long	0xFFEF000A
 | 
						|
PGCR_A:	.long	0xFFEF000C
 | 
						|
PHCR_A:	.long	0xFFEF000E
 | 
						|
PICR_A:	.long	0xFFEF0010
 | 
						|
PJCR_A:	.long	0xFFEF0012
 | 
						|
PKCR_A:	.long	0xFFEF0014
 | 
						|
PLCR_A:	.long	0xFFEF0016
 | 
						|
PMCR_A:	.long	0xFFEF0018
 | 
						|
PNCR_A:	.long	0xFFEF001A
 | 
						|
POCR_A:	.long	0xFFEF001C
 | 
						|
 | 
						|
/* GPIO Data Register */
 | 
						|
PADR_A:	.long	0xFFEF0020
 | 
						|
PBDR_A:	.long	0xFFEF0022
 | 
						|
PCDR_A:	.long	0xFFEF0024
 | 
						|
PDDR_A:	.long	0xFFEF0026
 | 
						|
PJDR_A:	.long	0xFFEF0032
 | 
						|
PKDR_A:	.long	0xFFEF0034
 | 
						|
 | 
						|
/* GPIO Set data */
 | 
						|
PADR_D:	.long	0x00000000
 | 
						|
PACR_D:	.word 	0x1400
 | 
						|
.align 2
 | 
						|
PBDR_D:	.long	0x00000000
 | 
						|
PBCR_D:	.word	0x555A
 | 
						|
.align 2
 | 
						|
PCDR_D:	.long	0x00000000
 | 
						|
PCCR_D:	.word	0x5555
 | 
						|
.align 2
 | 
						|
PDDR_D:	.long	0x00000000
 | 
						|
PDCR_D:	.word	0x0155
 | 
						|
PECR_D:	.word	0x0000
 | 
						|
PFCR_D:	.word	0x0000
 | 
						|
PGCR_D:	.word	0x0000
 | 
						|
PHCR_D:	.word	0x0000
 | 
						|
PICR_D:	.word	0x0800
 | 
						|
PJDR_D:	.long	0x00000006
 | 
						|
PJCR_D:	.word	0x5A57
 | 
						|
.align 2
 | 
						|
PKDR_D:	.long	0x00000000
 | 
						|
PKCR_D:	.word	0xFFF9
 | 
						|
.align 2
 | 
						|
PLCR_D:	.word 	0xC330
 | 
						|
PMCR_D:	.word	0xFFFF
 | 
						|
PNCR_D:	.word	0x0242
 | 
						|
POCR_D:	.word	0x0000
 | 
						|
 | 
						|
/* Pin Select */
 | 
						|
PSEL0_A:	.long	0xFFEF0070
 | 
						|
PSEL1_A:	.long	0xFFEF0072
 | 
						|
PSEL2_A:	.long	0xFFEF0074
 | 
						|
PSEL3_A:	.long	0xFFEF0076
 | 
						|
PSEL4_A:	.long	0xFFEF0078
 | 
						|
PSEL0_D:	.word	0x0001
 | 
						|
PSEL1_D:	.word	0x2400
 | 
						|
PSEL2_D:	.word	0x0000
 | 
						|
PSEL3_D:	.word	0x2421
 | 
						|
PSEL4_D:	.word	0x0000
 | 
						|
.align 2
 | 
						|
 | 
						|
MMSEL_A:	.long	0xFE600020
 | 
						|
BCR_A:		.long	0xFF801000
 | 
						|
CS0BCR_A:	.long	0xFF802000
 | 
						|
CS0WCR_A:	.long	0xFF802008
 | 
						|
ICR0_A:		.long	0xFFD00000
 | 
						|
ICR1_A:		.long	0xFFD0001C
 | 
						|
 | 
						|
MMSEL_D:	.long	0xA5A50000
 | 
						|
BCR_D:		.long	0x05000000
 | 
						|
CS0BCR_D:	.long	0x232306F0
 | 
						|
CS0WCR_D:	.long	0x00011104
 | 
						|
ICR0_D:		.long	0x80C00000
 | 
						|
ICR1_D:		.long	0x00020000
 | 
						|
 | 
						|
/* RWBT Address */
 | 
						|
WDTST_A:	.long	0xFFCC0000
 | 
						|
WDTCSR_A:	.long	0xFFCC0004
 | 
						|
WDTBST_A:	.long	0xFFCC0008
 | 
						|
/* RWBT Data */
 | 
						|
WDTST_D:	.long	0x5A000FFF
 | 
						|
WDTCSR_D:	.long	0xA5000000
 | 
						|
WDTBST_D:	.long	0x55000000
 | 
						|
 | 
						|
/* Cache Address */
 | 
						|
CCR_A:		.long	0xFF00001C
 | 
						|
MMUCR_A:	.long	0xFF000010
 | 
						|
RAMCR_A:	.long	0xFF000074
 | 
						|
 | 
						|
/* Cache Data */
 | 
						|
CCR_CACHE_ICI_D:.long	0x00000800
 | 
						|
CCR_CACHE_D_2:	.long	0x00000103
 | 
						|
MMU_CONTROL_TI_D:.long	0x00000004
 | 
						|
RAMCR_D:	.long	0x00000200
 | 
						|
 | 
						|
/* Low power mode control Address */
 | 
						|
MSTPCR0_A:	.long	0xFFC80030
 | 
						|
MSTPCR1_A:	.long	0xFFC80038
 | 
						|
/* Low power mode control Data */
 | 
						|
MSTPCR0_D:	.long	0x00000000
 | 
						|
MSTPCR1_D:	.long	0x00000000
 | 
						|
 | 
						|
REPEAT0_R3:	.long	0x00002000
 | 
						|
REPEAT_R3:	.long	0x00000200
 | 
						|
CS0_A:		.long	0xA8000000
 | 
						|
 | 
						|
MIM_U_A:	.long	0xFE800008
 | 
						|
MIM_L_A:	.long	0xFE80000C
 | 
						|
SCR_U_A:	.long	0xFE800010
 | 
						|
SCR_L_A:	.long	0xFE800014
 | 
						|
STR_U_A:	.long	0xFE800018
 | 
						|
STR_L_A:	.long	0xFE80001C
 | 
						|
SDR_U_A:	.long	0xFE800030
 | 
						|
SDR_L_A:	.long	0xFE800034
 | 
						|
EMRS_A:		.long	0xFE902000
 | 
						|
MRS1_A:		.long	0xFE900B08
 | 
						|
MRS2_A:		.long	0xFE900308
 | 
						|
 | 
						|
MIM_U_D:	.long	0x00000000
 | 
						|
MIM_L_D0:	.long	0x04100008
 | 
						|
MIM_L_D1:	.long	0x02EE0009
 | 
						|
MIM_L_D2:	.long	0x02EE0209
 | 
						|
 | 
						|
SDR_L_A_D0:	.long	0x00000300
 | 
						|
STR_L_A_D0:	.long	0x00010040
 | 
						|
MIM_L_A_D1:	.long	0x04100009
 | 
						|
SCR_L_A_D0:	.long 	0x00000003
 | 
						|
SCR_L_A_D1:	.long 	0x00000002
 | 
						|
MIM_L_A_D2:	.long	0x04100209
 | 
						|
SCR_L_A_D2:	.long	0x00000004
 | 
						|
 | 
						|
SCR_L_NORMAL:	.long	0x00000000
 | 
						|
SCR_L_NOP:		.long	0x00000001
 | 
						|
SCR_L_PALL:		.long	0x00000002
 | 
						|
SCR_L_CKE_EN:	.long	0x00000003
 | 
						|
SCR_L_CBR:		.long	0x00000004
 | 
						|
 | 
						|
STR_L_D:	.long	0x000F3980
 | 
						|
SDR_L_D:	.long	0x00000400
 | 
						|
EMRS_D:		.long	0x00000000
 | 
						|
MRS1_D:		.long	0x00000000
 | 
						|
MRS2_D:		.long	0x00000000
 | 
						|
 | 
						|
/* USB */
 | 
						|
USB_USBHSC_A:	.long	0xFFEC80F0
 | 
						|
USB_USBHSC_D:	.long	0x00000000
 |