]>
git.ipfire.org Git - thirdparty/u-boot.git/blob - board/astro/mcf5373l/mcf5373l.c
1 // SPDX-License-Identifier: GPL-2.0+
3 * (C) Copyright 2000-2003
4 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5 * modified by Wolfgang Wegner <w.wegner@astro-kom.de> for ASTRO 5373l
11 #include <asm/m5329.h>
12 #include <asm/immap_5329.h>
15 /* needed for astro bus: */
19 DECLARE_GLOBAL_DATA_PTR
;
20 extern void uart_port_conf(void);
25 puts("ASTRO MCF5373L (Urmel) Board\n");
31 #if !defined(CONFIG_MONITOR_IS_IN_RAM)
32 sdram_t
*sdp
= (sdram_t
*)(MMAP_SDRAM
);
35 * GPIO configuration for bus should be set correctly from reset,
36 * so we do not care! First, set up address space: at this point,
37 * we should be running from internal SRAM;
38 * so use CONFIG_SYS_SDRAM_BASE as the base address for SDRAM,
39 * and do not care where it is
41 __raw_writel((CONFIG_SYS_SDRAM_BASE
& 0xFFF00000) | 0x00000018,
43 __raw_writel((CONFIG_SYS_SDRAM_BASE
& 0xFFF00000) | 0x00000000,
46 * I am not sure from the data sheet, but it seems burst length
47 * has to be 8 for the 16 bit data bus we use;
48 * so these values are for BL = 8
50 __raw_writel(0x33211530, &sdp
->cfg1
);
51 __raw_writel(0x56570000, &sdp
->cfg2
);
52 /* send PrechargeALL, REF and IREF remain cleared! */
53 __raw_writel(0xE1462C02, &sdp
->ctrl
);
55 /* refresh SDRAM twice */
56 __raw_writel(0xE1462C04, &sdp
->ctrl
);
58 __raw_writel(0xE1462C04, &sdp
->ctrl
);
60 __raw_writel(0x008D0000, &sdp
->mode
);
62 __raw_writel(0x80010000, &sdp
->mode
);
63 /* wait until DLL is locked */
66 * enable automatic refresh, lock mode register,
67 * clear iref and ipall
69 __raw_writel(0x71462C00, &sdp
->ctrl
);
70 /* Dummy write to start SDRAM */
71 writel(0, CONFIG_SYS_SDRAM_BASE
);
75 * for get_ram_size() to work, both CS areas have to be
76 * configured, i.e. CS1 has to be explicitely disabled, else
77 * probing for memory will cause the SDRAM bus to hang!
78 * (Do not rely on the SDCS register(s) being set to 0x00000000
79 * during reset as stated in the data sheet.)
81 gd
->ram_size
= get_ram_size((long *)CONFIG_SYS_SDRAM_BASE
,
82 0x80000000 - CONFIG_SYS_SDRAM_BASE
);
87 #define UART_BASE MMAP_UART0
88 int rs_serial_init(int port
, int baud
)
95 uart
= (uart_t
*)(MMAP_UART0
);
98 uart
= (uart_t
*)(MMAP_UART1
);
101 uart
= (uart_t
*)(MMAP_UART2
);
104 uart
= (uart_t
*)(MMAP_UART0
);
109 /* write to SICR: SIM2 = uart mode,dcd does not affect rx */
110 writeb(UART_UCR_RESET_RX
, &uart
->ucr
);
111 writeb(UART_UCR_RESET_TX
, &uart
->ucr
);
112 writeb(UART_UCR_RESET_ERROR
, &uart
->ucr
);
113 writeb(UART_UCR_RESET_MR
, &uart
->ucr
);
116 writeb(0, &uart
->uimr
);
118 /* write to CSR: RX/TX baud rate from timers */
119 writeb(UART_UCSR_RCS_SYS_CLK
| UART_UCSR_TCS_SYS_CLK
, &uart
->ucsr
);
121 writeb(UART_UMR_BC_8
| UART_UMR_PM_NONE
, &uart
->umr
);
122 writeb(UART_UMR_SB_STOP_BITS_1
, &uart
->umr
);
124 /* Setting up BaudRate */
125 counter
= (u32
) (gd
->bus_clk
/ (baud
));
128 /* write to CTUR: divide counter upper byte */
129 writeb((u8
) ((counter
& 0xff00) >> 8), &uart
->ubg1
);
130 /* write to CTLR: divide counter lower byte */
131 writeb((u8
) (counter
& 0x00ff), &uart
->ubg2
);
133 writeb(UART_UCR_RX_ENABLED
| UART_UCR_TX_ENABLED
, &uart
->ucr
);
138 void astro_put_char(char ch
)
143 uart
= (uart_t
*)(MMAP_UART0
);
145 * Wait for last character to go. Timeout of 6ms should
146 * be enough for our lowest baud rate of 2400.
148 timer
= get_timer(0);
149 while (get_timer(timer
) < 6) {
150 if (readb(&uart
->usr
) & UART_USR_TXRDY
)
153 writeb(ch
, &uart
->utb
);
158 int astro_is_char(void)
162 uart
= (uart_t
*)(MMAP_UART0
);
163 return readb(&uart
->usr
) & UART_USR_RXRDY
;
166 int astro_get_char(void)
170 uart
= (uart_t
*)(MMAP_UART0
);
171 while (!(readb(&uart
->usr
) & UART_USR_RXRDY
)) ;
172 return readb(&uart
->urb
);
175 int misc_init_r(void)
179 puts("Configure Xilinx FPGA...");
180 retval
= astro5373l_xilinx_load();
187 puts("Configure Altera FPGA...");
188 retval
= astro5373l_altera_load();