| /* | 
 |  modified from SH-IPL+g | 
 |  Renesaso SuperH / Solution Enginge MS775xSE01 BSC setting. | 
 |  | 
 |  Support CPU : SH7750/SH7750S/SH7750R/SH7751/SH7751R | 
 |  | 
 |  Coyright (c) 2007 Nobuhiro Iwamatsu <iwmatsu@nigauri.org> | 
 |  | 
 |  * SPDX-License-Identifier:	GPL-2.0+ | 
 | */ | 
 |  | 
 | #include <config.h> | 
 |  | 
 | #include <asm/processor.h> | 
 | #include <asm/macro.h> | 
 |  | 
 | #ifdef CONFIG_CPU_SH7751 | 
 | #define BCR2_D_VALUE	0x2FFC		/* Area 1-6 width: 32/32/32/32/32/16 */ | 
 | #define WCR1_D_VALUE	0x02770771	/* DMA:0 A6:2 A3:0 A0:1 Others:15 */ | 
 | #ifdef CONFIG_MARUBUN_PCCARD | 
 | #define WCR2_D_VALUE	0xFFFE4FE7	/* A6:15 A6B:7 A5:15 A5B:7 A4:15 | 
 | 					   A3:2  A2:15 A1:15 A0:6  A0B:7  */ | 
 | #else /* CONFIG_MARUBUN_PCCARD */ | 
 | #define WCR2_D_VALUE	0x7FFE4FE7	/* A6:3  A6B:7 A5:15 A5B:7 A4:15 | 
 | 					   A3:2  A2:15 A1:15 A0:6  A0B:7  */ | 
 | #endif /* CONFIG_MARUBUN_PCCARD */ | 
 | #define WCR3_D_VALUE	0x01777771	/* A6: 0-1 A5: 1-3 A4: 1-3 A3: 1-3 | 
 | 					   A2: 1-3 A1: 1-3 A0: 0-1 */ | 
 | #define RTCOR_D_VALUE	0xA50D		/* Write code A5, data 0D (~15us?) */ | 
 | #define SDMR3_ADDRESS	0xFF940088	/* SDMR3 address on 32-bit bus */ | 
 | #define MCR_D1_VALUE	0x100901B4	/* SDRAM 32-bit, CAS/RAS Refresh, .. */ | 
 | #define MCR_D2_VALUE	0x500901B4	/* Same w/MRSET now 1 (mode reg cmd) */ | 
 | #else /* CONFIG_CPU_SH7751 */ | 
 | #define BCR2_D_VALUE	0x2E3C		/* Area 1-6 width: 32/32/64/16/32/16 */ | 
 | #define WCR1_D_VALUE	0x02720777	/* DMA:0 A6:2 A4:2 A3:0 Others:15 */ | 
 | #define WCR2_D_VALUE	0xFFFE4FFF	/* A6:15 A6B:7 A5:15 A5B:7 A4:15 | 
 | 					   A3:2  A2:15 A1:15 A0:15 A0B:7  */ | 
 | #define WCR3_D_VALUE	0x01717771	/* A6: 0-1 A5: 1-3 A4: 0-1 A3: 1-3 | 
 | 					   A2: 1-3 A1: 1-3 A0: 0-1 */ | 
 | #define RTCOR_D_VALUE	0xA510		/* Write code A5, data 10 (~15us?) */ | 
 | #define SDMR3_ADDRESS	0xFF940110	/* SDMR3 address on 64-bit bus */ | 
 | #define MCR_D1_VALUE	0x8801001C	/* SDRAM 64-bit, CAS/RAS Refresh, .. */ | 
 | #define MCR_D2_VALUE	0xC801001C	/* Same w/MRSET now 1 (mode reg cmd) */ | 
 | #endif /* CONFIG_CPU_SH7751 */ | 
 |  | 
 | 	.global lowlevel_init | 
 | 	.text | 
 | 	.align	2 | 
 |  | 
 | lowlevel_init: | 
 |  | 
 | 	write32	CCR_A, CCR_D_DISABLE | 
 |  | 
 | init_bsc: | 
 | 	write16	FRQCR_A, FRQCR_D | 
 |  | 
 | 	write32	BCR1_A, BCR1_D | 
 |  | 
 | 	write16	BCR2_A, BCR2_D | 
 |  | 
 | 	write32	WCR1_A, WCR1_D | 
 |  | 
 | 	write32	WCR2_A, WCR2_D | 
 |  | 
 | 	write32	WCR3_A, WCR3_D | 
 |  | 
 | 	write32	MCR_A, MCR_D1 | 
 |  | 
 | 	/* Set SDRAM mode */ | 
 | 	write8	SDMR3_A, SDMR3_D | 
 |  | 
 | 	! Do you need PCMCIA setting? | 
 | 	! If so, please add the lines here... | 
 |  | 
 | 	write16	RTCNT_A, RTCNT_D | 
 |  | 
 | 	write16	RTCOR_A, RTCOR_D | 
 |  | 
 | 	write16	RTCSR_A, RTCSR_D | 
 |  | 
 | 	write16	RFCR_A, RFCR_D | 
 |  | 
 | 	/* Wait DRAM refresh 30 times */ | 
 | 	mov	#30, r3 | 
 | 1: | 
 | 	mov.w	@r1, r0 | 
 | 	extu.w	r0, r2 | 
 | 	cmp/hi	r3, r2 | 
 | 	bf	1b | 
 |  | 
 | 	write32	MCR_A, MCR_D2 | 
 |  | 
 | 	/* Set SDRAM mode */ | 
 | 	write8	SDMR3_A, SDMR3_D | 
 |  | 
 | 	rts | 
 | 	nop | 
 |  | 
 | 	.align	2 | 
 |  | 
 | CCR_A:		 .long	CCR | 
 | CCR_D_DISABLE:	.long	0x0808 | 
 | FRQCR_A:	.long	FRQCR | 
 | FRQCR_D: | 
 | #ifdef CONFIG_CPU_TYPE_R | 
 | 		.word	0x0e1a	/* 12:3:3 */ | 
 | #else	/* CONFIG_CPU_TYPE_R */ | 
 | #ifdef CONFIG_GOOD_SESH4 | 
 | 		.word	0x00e13	/* 6:2:1 */ | 
 | #else | 
 | 		.word	0x00e23	/* 6:1:1 */ | 
 | #endif | 
 | .align 2 | 
 | #endif	/* CONFIG_CPU_TYPE_R */ | 
 |  | 
 | BCR1_A:		.long	BCR1 | 
 | BCR1_D:		.long	0x00000008	/* Area 3 SDRAM */ | 
 | BCR2_A:		.long	BCR2 | 
 | BCR2_D:		.long	BCR2_D_VALUE	/* Bus width settings */ | 
 | WCR1_A:		.long	WCR1 | 
 | WCR1_D:		.long	WCR1_D_VALUE	/* Inter-area or turnaround wait states */ | 
 | WCR2_A:		.long	WCR2 | 
 | WCR2_D:		.long	WCR2_D_VALUE	/* Per-area access and burst wait states */ | 
 | WCR3_A:		.long	WCR3 | 
 | WCR3_D:		.long	WCR3_D_VALUE	/* Address setup and data hold cycles */ | 
 | RTCSR_A:	.long	RTCSR | 
 | RTCSR_D:	.word	0xA518		/* RTCSR Write Code A5h Data 18h */ | 
 | .align 2 | 
 | RTCNT_A:	.long	RTCNT | 
 | RTCNT_D:	.word	0xA500		/* RTCNT Write Code A5h Data 00h */ | 
 | .align 2 | 
 | RTCOR_A:	.long	RTCOR | 
 | RTCOR_D:	.word	RTCOR_D_VALUE	/* Set refresh time (about 15us) */ | 
 | .align 2 | 
 | SDMR3_A:	.long	SDMR3_ADDRESS | 
 | SDMR3_D:	.long	0x00 | 
 | MCR_A:		.long	MCR | 
 | MCR_D1:		.long	MCR_D1_VALUE | 
 | MCR_D2:		.long	MCR_D2_VALUE | 
 | RFCR_A:		.long	RFCR | 
 | RFCR_D:		.word	0xA400		/* RFCR Write Code A4h Data 00h */ | 
 | .align 2 |