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