xref: /OK3568_Linux_fs/u-boot/board/astro/mcf5373l/mcf5373l.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * (C) Copyright 2000-2003
3*4882a593Smuzhiyun  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4*4882a593Smuzhiyun  * modified by Wolfgang Wegner <w.wegner@astro-kom.de> for ASTRO 5373l
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0+
7*4882a593Smuzhiyun  */
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #include <common.h>
10*4882a593Smuzhiyun #include <watchdog.h>
11*4882a593Smuzhiyun #include <command.h>
12*4882a593Smuzhiyun #include <asm/m5329.h>
13*4882a593Smuzhiyun #include <asm/immap_5329.h>
14*4882a593Smuzhiyun #include <asm/io.h>
15*4882a593Smuzhiyun 
16*4882a593Smuzhiyun /* needed for astro bus: */
17*4882a593Smuzhiyun #include <asm/uart.h>
18*4882a593Smuzhiyun #include "astro.h"
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun DECLARE_GLOBAL_DATA_PTR;
21*4882a593Smuzhiyun extern void uart_port_conf(void);
22*4882a593Smuzhiyun 
checkboard(void)23*4882a593Smuzhiyun int checkboard(void)
24*4882a593Smuzhiyun {
25*4882a593Smuzhiyun 	puts("Board: ");
26*4882a593Smuzhiyun 	puts("ASTRO MCF5373L (Urmel) Board\n");
27*4882a593Smuzhiyun 	return 0;
28*4882a593Smuzhiyun }
29*4882a593Smuzhiyun 
dram_init(void)30*4882a593Smuzhiyun int dram_init(void)
31*4882a593Smuzhiyun {
32*4882a593Smuzhiyun #if !defined(CONFIG_MONITOR_IS_IN_RAM)
33*4882a593Smuzhiyun 	sdram_t *sdp = (sdram_t *)(MMAP_SDRAM);
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun 	/*
36*4882a593Smuzhiyun 	 * GPIO configuration for bus should be set correctly from reset,
37*4882a593Smuzhiyun 	 * so we do not care! First, set up address space: at this point,
38*4882a593Smuzhiyun 	 * we should be running from internal SRAM;
39*4882a593Smuzhiyun 	 * so use CONFIG_SYS_SDRAM_BASE as the base address for SDRAM,
40*4882a593Smuzhiyun 	 * and do not care where it is
41*4882a593Smuzhiyun 	 */
42*4882a593Smuzhiyun 	__raw_writel((CONFIG_SYS_SDRAM_BASE & 0xFFF00000) | 0x00000018,
43*4882a593Smuzhiyun 			&sdp->cs0);
44*4882a593Smuzhiyun 	__raw_writel((CONFIG_SYS_SDRAM_BASE & 0xFFF00000) | 0x00000000,
45*4882a593Smuzhiyun 			&sdp->cs1);
46*4882a593Smuzhiyun 	/*
47*4882a593Smuzhiyun 	 * I am not sure from the data sheet, but it seems burst length
48*4882a593Smuzhiyun 	 * has to be 8 for the 16 bit data bus we use;
49*4882a593Smuzhiyun 	 * so these values are for BL = 8
50*4882a593Smuzhiyun 	 */
51*4882a593Smuzhiyun 	__raw_writel(0x33211530, &sdp->cfg1);
52*4882a593Smuzhiyun 	__raw_writel(0x56570000, &sdp->cfg2);
53*4882a593Smuzhiyun 	/* send PrechargeALL, REF and IREF remain cleared! */
54*4882a593Smuzhiyun 	__raw_writel(0xE1462C02, &sdp->ctrl);
55*4882a593Smuzhiyun 	udelay(1);
56*4882a593Smuzhiyun 	/* refresh SDRAM twice */
57*4882a593Smuzhiyun 	__raw_writel(0xE1462C04, &sdp->ctrl);
58*4882a593Smuzhiyun 	udelay(1);
59*4882a593Smuzhiyun 	__raw_writel(0xE1462C04, &sdp->ctrl);
60*4882a593Smuzhiyun 	/* init MR  */
61*4882a593Smuzhiyun 	__raw_writel(0x008D0000, &sdp->mode);
62*4882a593Smuzhiyun 	/* initialize EMR */
63*4882a593Smuzhiyun 	__raw_writel(0x80010000, &sdp->mode);
64*4882a593Smuzhiyun 	/* wait until DLL is locked */
65*4882a593Smuzhiyun 	udelay(1);
66*4882a593Smuzhiyun 	/*
67*4882a593Smuzhiyun 	 * enable automatic refresh, lock mode register,
68*4882a593Smuzhiyun 	 * clear iref and ipall
69*4882a593Smuzhiyun 	 */
70*4882a593Smuzhiyun 	__raw_writel(0x71462C00, &sdp->ctrl);
71*4882a593Smuzhiyun 	/* Dummy write to start SDRAM */
72*4882a593Smuzhiyun 	writel(0, CONFIG_SYS_SDRAM_BASE);
73*4882a593Smuzhiyun #endif
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun 	/*
76*4882a593Smuzhiyun 	 * for get_ram_size() to work, both CS areas have to be
77*4882a593Smuzhiyun 	 * configured, i.e. CS1 has to be explicitely disabled, else
78*4882a593Smuzhiyun 	 * probing for memory will cause the SDRAM bus to hang!
79*4882a593Smuzhiyun 	 * (Do not rely on the SDCS register(s) being set to 0x00000000
80*4882a593Smuzhiyun 	 * during reset as stated in the data sheet.)
81*4882a593Smuzhiyun 	 */
82*4882a593Smuzhiyun 	gd->ram_size = get_ram_size((long *)CONFIG_SYS_SDRAM_BASE,
83*4882a593Smuzhiyun 				0x80000000 - CONFIG_SYS_SDRAM_BASE);
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun 	return 0;
86*4882a593Smuzhiyun }
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun #define UART_BASE MMAP_UART0
rs_serial_init(int port,int baud)89*4882a593Smuzhiyun int rs_serial_init(int port, int baud)
90*4882a593Smuzhiyun {
91*4882a593Smuzhiyun 	uart_t *uart;
92*4882a593Smuzhiyun 	u32 counter;
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun 	switch (port) {
95*4882a593Smuzhiyun 	case 0:
96*4882a593Smuzhiyun 		uart = (uart_t *)(MMAP_UART0);
97*4882a593Smuzhiyun 		break;
98*4882a593Smuzhiyun 	case 1:
99*4882a593Smuzhiyun 		uart = (uart_t *)(MMAP_UART1);
100*4882a593Smuzhiyun 		break;
101*4882a593Smuzhiyun 	case 2:
102*4882a593Smuzhiyun 		uart = (uart_t *)(MMAP_UART2);
103*4882a593Smuzhiyun 		break;
104*4882a593Smuzhiyun 	default:
105*4882a593Smuzhiyun 		uart = (uart_t *)(MMAP_UART0);
106*4882a593Smuzhiyun 	}
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun 	uart_port_conf();
109*4882a593Smuzhiyun 
110*4882a593Smuzhiyun 	/* write to SICR: SIM2 = uart mode,dcd does not affect rx */
111*4882a593Smuzhiyun 	writeb(UART_UCR_RESET_RX, &uart->ucr);
112*4882a593Smuzhiyun 	writeb(UART_UCR_RESET_TX, &uart->ucr);
113*4882a593Smuzhiyun 	writeb(UART_UCR_RESET_ERROR, &uart->ucr);
114*4882a593Smuzhiyun 	writeb(UART_UCR_RESET_MR, &uart->ucr);
115*4882a593Smuzhiyun 	__asm__ ("nop");
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun 	writeb(0, &uart->uimr);
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun 	/* write to CSR: RX/TX baud rate from timers */
120*4882a593Smuzhiyun 	writeb(UART_UCSR_RCS_SYS_CLK | UART_UCSR_TCS_SYS_CLK, &uart->ucsr);
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun 	writeb(UART_UMR_BC_8 | UART_UMR_PM_NONE, &uart->umr);
123*4882a593Smuzhiyun 	writeb(UART_UMR_SB_STOP_BITS_1, &uart->umr);
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun 	/* Setting up BaudRate */
126*4882a593Smuzhiyun 	counter = (u32) (gd->bus_clk / (baud));
127*4882a593Smuzhiyun 	counter >>= 5;
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun 	/* write to CTUR: divide counter upper byte */
130*4882a593Smuzhiyun 	writeb((u8) ((counter & 0xff00) >> 8), &uart->ubg1);
131*4882a593Smuzhiyun 	/* write to CTLR: divide counter lower byte */
132*4882a593Smuzhiyun 	writeb((u8) (counter & 0x00ff), &uart->ubg2);
133*4882a593Smuzhiyun 
134*4882a593Smuzhiyun 	writeb(UART_UCR_RX_ENABLED | UART_UCR_TX_ENABLED, &uart->ucr);
135*4882a593Smuzhiyun 
136*4882a593Smuzhiyun 	return 0;
137*4882a593Smuzhiyun }
138*4882a593Smuzhiyun 
astro_put_char(char ch)139*4882a593Smuzhiyun void astro_put_char(char ch)
140*4882a593Smuzhiyun {
141*4882a593Smuzhiyun 	uart_t *uart;
142*4882a593Smuzhiyun 	unsigned long timer;
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun 	uart = (uart_t *)(MMAP_UART0);
145*4882a593Smuzhiyun 	/*
146*4882a593Smuzhiyun 	 * Wait for last character to go. Timeout of 6ms should
147*4882a593Smuzhiyun 	 * be enough for our lowest baud rate of 2400.
148*4882a593Smuzhiyun 	 */
149*4882a593Smuzhiyun 	timer = get_timer(0);
150*4882a593Smuzhiyun 	while (get_timer(timer) < 6) {
151*4882a593Smuzhiyun 		if (readb(&uart->usr) & UART_USR_TXRDY)
152*4882a593Smuzhiyun 			break;
153*4882a593Smuzhiyun 	}
154*4882a593Smuzhiyun 	writeb(ch, &uart->utb);
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun 	return;
157*4882a593Smuzhiyun }
158*4882a593Smuzhiyun 
astro_is_char(void)159*4882a593Smuzhiyun int astro_is_char(void)
160*4882a593Smuzhiyun {
161*4882a593Smuzhiyun 	uart_t *uart;
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun 	uart = (uart_t *)(MMAP_UART0);
164*4882a593Smuzhiyun 	return readb(&uart->usr) & UART_USR_RXRDY;
165*4882a593Smuzhiyun }
166*4882a593Smuzhiyun 
astro_get_char(void)167*4882a593Smuzhiyun int astro_get_char(void)
168*4882a593Smuzhiyun {
169*4882a593Smuzhiyun 	uart_t *uart;
170*4882a593Smuzhiyun 
171*4882a593Smuzhiyun 	uart = (uart_t *)(MMAP_UART0);
172*4882a593Smuzhiyun 	while (!(readb(&uart->usr) & UART_USR_RXRDY)) ;
173*4882a593Smuzhiyun 	return readb(&uart->urb);
174*4882a593Smuzhiyun }
175*4882a593Smuzhiyun 
misc_init_r(void)176*4882a593Smuzhiyun int misc_init_r(void)
177*4882a593Smuzhiyun {
178*4882a593Smuzhiyun 	int retval = 0;
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun 	puts("Configure Xilinx FPGA...");
181*4882a593Smuzhiyun 	retval = astro5373l_xilinx_load();
182*4882a593Smuzhiyun 	if (!retval) {
183*4882a593Smuzhiyun 		puts("failed!\n");
184*4882a593Smuzhiyun 		return retval;
185*4882a593Smuzhiyun 	}
186*4882a593Smuzhiyun 	puts("done\n");
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun 	puts("Configure Altera FPGA...");
189*4882a593Smuzhiyun 	retval = astro5373l_altera_load();
190*4882a593Smuzhiyun 	if (!retval) {
191*4882a593Smuzhiyun 		puts("failed!\n");
192*4882a593Smuzhiyun 		return retval;
193*4882a593Smuzhiyun 	}
194*4882a593Smuzhiyun 	puts("done\n");
195*4882a593Smuzhiyun 
196*4882a593Smuzhiyun 	return retval;
197*4882a593Smuzhiyun }
198