|  | /* | 
|  | * (C) Copyright 2009 Faraday Technology | 
|  | * Po-Yu Chuang <ratbert@faraday-tech.com> | 
|  | * | 
|  | * SPDX-License-Identifier:	GPL-2.0+ | 
|  | */ | 
|  |  | 
|  | #include <config.h> | 
|  | #include <version.h> | 
|  |  | 
|  | #include <asm/macro.h> | 
|  | #include <faraday/ftsdmc020.h> | 
|  |  | 
|  | /* | 
|  | * parameters for the SDRAM controller | 
|  | */ | 
|  | #define TP0_A		(CONFIG_FTSDMC020_BASE + FTSDMC020_OFFSET_TP0) | 
|  | #define TP1_A		(CONFIG_FTSDMC020_BASE + FTSDMC020_OFFSET_TP1) | 
|  | #define CR_A		(CONFIG_FTSDMC020_BASE + FTSDMC020_OFFSET_CR) | 
|  | #define B0_BSR_A	(CONFIG_FTSDMC020_BASE + FTSDMC020_OFFSET_BANK0_BSR) | 
|  | #define ACR_A		(CONFIG_FTSDMC020_BASE + FTSDMC020_OFFSET_ACR) | 
|  |  | 
|  | #define TP0_D		CONFIG_SYS_FTSDMC020_TP0 | 
|  | #define TP1_D		CONFIG_SYS_FTSDMC020_TP1 | 
|  | #define CR_D1		FTSDMC020_CR_IPREC | 
|  | #define CR_D2		FTSDMC020_CR_ISMR | 
|  | #define CR_D3		FTSDMC020_CR_IREF | 
|  |  | 
|  | #define B0_BSR_D	(CONFIG_SYS_FTSDMC020_BANK0_BSR | \ | 
|  | FTSDMC020_BANK_BASE(PHYS_SDRAM_1)) | 
|  | #define ACR_D		FTSDMC020_ACR_TOC(0x18) | 
|  |  | 
|  | /* | 
|  | * numeric 7 segment display | 
|  | */ | 
|  | .macro	led, num | 
|  | write32	CONFIG_DEBUG_LED, \num | 
|  | .endm | 
|  |  | 
|  | /* | 
|  | * Waiting for SDRAM to set up | 
|  | */ | 
|  | .macro	wait_sdram | 
|  | ldr	r0, =CONFIG_FTSDMC020_BASE | 
|  | 1: | 
|  | ldr	r1, [r0, #FTSDMC020_OFFSET_CR] | 
|  | cmp	r1, #0 | 
|  | bne	1b | 
|  | .endm | 
|  |  | 
|  | .globl lowlevel_init | 
|  | lowlevel_init: | 
|  | mov	r11, lr | 
|  |  | 
|  | led	0x0 | 
|  |  | 
|  | bl	init_sdmc | 
|  |  | 
|  | led	0x1 | 
|  |  | 
|  | /* everything is fine now */ | 
|  | mov	lr, r11 | 
|  | mov	pc, lr | 
|  |  | 
|  | /* | 
|  | * memory initialization | 
|  | */ | 
|  | init_sdmc: | 
|  | led	0x10 | 
|  |  | 
|  | /* set SDRAM register */ | 
|  |  | 
|  | write32	TP0_A, TP0_D | 
|  | led	0x11 | 
|  |  | 
|  | write32	TP1_A, TP1_D | 
|  | led	0x12 | 
|  |  | 
|  | /* set to precharge */ | 
|  | write32	CR_A, CR_D1 | 
|  | led	0x13 | 
|  |  | 
|  | wait_sdram | 
|  | led	0x14 | 
|  |  | 
|  | /* set mode register */ | 
|  | write32	CR_A, CR_D2 | 
|  | led	0x15 | 
|  |  | 
|  | wait_sdram | 
|  | led	0x16 | 
|  |  | 
|  | /* set to refresh */ | 
|  | write32	CR_A, CR_D3 | 
|  | led	0x17 | 
|  |  | 
|  | wait_sdram | 
|  | led	0x18 | 
|  |  | 
|  | write32	B0_BSR_A, B0_BSR_D | 
|  | led	0x19 | 
|  |  | 
|  | write32	ACR_A, ACR_D | 
|  | led	0x1a | 
|  |  | 
|  | mov	pc, lr |