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