blob: 58ea6289d37bc6a1f039e11ce9c869449b634d23 [file] [log] [blame]
Tom Warren41b68382011-01-27 10:58:05 +00001/*
2 * (C) Copyright 2010,2011
3 * NVIDIA Corporation <www.nvidia.com>
4 *
5 * See file CREDITS for list of people who contributed to this
6 * project.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21 * MA 02111-1307 USA
22 */
23
24#include <common.h>
25#include <asm/io.h>
Simon Glass96b7c432011-11-28 15:04:39 +000026#include <asm/arch/clock.h>
27#include <asm/arch/funcmux.h>
Tom Warrenab371962012-09-19 15:50:56 -070028#include <asm/arch/tegra.h>
Lucas Stache80f7ca2012-09-29 10:02:08 +000029#include <asm/arch-tegra/board.h>
Tom Warrenab371962012-09-19 15:50:56 -070030#include <asm/arch-tegra/pmc.h>
31#include <asm/arch-tegra/sys_proto.h>
32#include <asm/arch-tegra/warmboot.h>
Tom Warren41b68382011-01-27 10:58:05 +000033
34DECLARE_GLOBAL_DATA_PTR;
35
Simon Glass96b7c432011-11-28 15:04:39 +000036enum {
37 /* UARTs which we can enable */
38 UARTA = 1 << 0,
39 UARTB = 1 << 1,
Tom Warrene3d95bc2013-01-28 13:32:10 +000040 UARTC = 1 << 2,
Simon Glass96b7c432011-11-28 15:04:39 +000041 UARTD = 1 << 3,
Tom Warrene3d95bc2013-01-28 13:32:10 +000042 UARTE = 1 << 4,
43 UART_COUNT = 5,
Simon Glass96b7c432011-11-28 15:04:39 +000044};
45
Tom Warren41b68382011-01-27 10:58:05 +000046/*
47 * Boot ROM initializes the odmdata in APBDEV_PMC_SCRATCH20_0,
48 * so we are using this value to identify memory size.
49 */
50
51unsigned int query_sdram_size(void)
52{
Tom Warren22562a42012-09-04 17:00:24 -070053 struct pmc_ctlr *const pmc = (struct pmc_ctlr *)NV_PA_PMC_BASE;
Tom Warren41b68382011-01-27 10:58:05 +000054 u32 reg;
55
56 reg = readl(&pmc->pmc_scratch20);
Marek Vasut8148e112011-10-24 23:41:39 +000057 debug("pmc->pmc_scratch20 (ODMData) = 0x%08x\n", reg);
Tom Warren41b68382011-01-27 10:58:05 +000058
Tom Warren61c6d0e2012-12-11 13:34:15 +000059#if defined(CONFIG_TEGRA20)
60 /* bits 30:28 in OdmData are used for RAM size on T20 */
61 reg &= 0x70000000;
62
Tom Warren41b68382011-01-27 10:58:05 +000063 switch ((reg) >> 28) {
64 case 1:
65 return 0x10000000; /* 256 MB */
Tom Warren61c6d0e2012-12-11 13:34:15 +000066 case 0:
Tom Warren41b68382011-01-27 10:58:05 +000067 case 2:
Stephen Warrenb60fa392012-01-06 12:14:41 +000068 default:
Tom Warren41b68382011-01-27 10:58:05 +000069 return 0x20000000; /* 512 MB */
70 case 3:
Tom Warren41b68382011-01-27 10:58:05 +000071 return 0x40000000; /* 1GB */
72 }
Tom Warrene3d95bc2013-01-28 13:32:10 +000073#else /* Tegra30/Tegra114 */
Tom Warren61c6d0e2012-12-11 13:34:15 +000074 /* bits 31:28 in OdmData are used for RAM size on T30 */
75 switch ((reg) >> 28) {
76 case 0:
77 case 1:
78 default:
79 return 0x10000000; /* 256 MB */
80 case 2:
81 return 0x20000000; /* 512 MB */
82 case 3:
83 return 0x30000000; /* 768 MB */
84 case 4:
85 return 0x40000000; /* 1GB */
86 case 8:
87 return 0x7ff00000; /* 2GB - 1MB */
88 }
89#endif
Tom Warren41b68382011-01-27 10:58:05 +000090}
91
Tom Warren41b68382011-01-27 10:58:05 +000092int dram_init(void)
93{
Tom Warren41b68382011-01-27 10:58:05 +000094 /* We do not initialise DRAM here. We just query the size */
Simon Glassf6fcbbd2011-11-05 03:56:57 +000095 gd->ram_size = query_sdram_size();
Tom Warren41b68382011-01-27 10:58:05 +000096 return 0;
97}
98
99#ifdef CONFIG_DISPLAY_BOARDINFO
100int checkboard(void)
101{
102 printf("Board: %s\n", sysinfo.board_string);
103 return 0;
104}
105#endif /* CONFIG_DISPLAY_BOARDINFO */
Simon Glass5f3a8992011-11-05 03:56:49 +0000106
Stephen Warren59f90102012-05-14 13:13:45 +0000107static int uart_configs[] = {
Tom Warren61c6d0e2012-12-11 13:34:15 +0000108#if defined(CONFIG_TEGRA20)
109 #if defined(CONFIG_TEGRA_UARTA_UAA_UAB)
Stephen Warren59f90102012-05-14 13:13:45 +0000110 FUNCMUX_UART1_UAA_UAB,
Tom Warren61c6d0e2012-12-11 13:34:15 +0000111 #elif defined(CONFIG_TEGRA_UARTA_GPU)
Stephen Warrene4c01a82012-05-16 05:59:59 +0000112 FUNCMUX_UART1_GPU,
Tom Warren61c6d0e2012-12-11 13:34:15 +0000113 #elif defined(CONFIG_TEGRA_UARTA_SDIO1)
Lucas Stach4de6eec2012-05-16 08:21:02 +0000114 FUNCMUX_UART1_SDIO1,
Tom Warren61c6d0e2012-12-11 13:34:15 +0000115 #else
Stephen Warren59f90102012-05-14 13:13:45 +0000116 FUNCMUX_UART1_IRRX_IRTX,
Stephen Warren811af732013-01-22 06:20:08 +0000117#endif
118 FUNCMUX_UART2_UAD,
Stephen Warren59f90102012-05-14 13:13:45 +0000119 -1,
120 FUNCMUX_UART4_GMC,
121 -1,
Tom Warrene3d95bc2013-01-28 13:32:10 +0000122#elif defined(CONFIG_TEGRA30)
Tom Warren61c6d0e2012-12-11 13:34:15 +0000123 FUNCMUX_UART1_ULPI, /* UARTA */
124 -1,
125 -1,
126 -1,
127 -1,
Tom Warrene3d95bc2013-01-28 13:32:10 +0000128#else /* Tegra114 */
129 -1,
130 -1,
131 -1,
132 FUNCMUX_UART4_GMI, /* UARTD */
133 -1,
Tom Warren61c6d0e2012-12-11 13:34:15 +0000134#endif
Stephen Warren59f90102012-05-14 13:13:45 +0000135};
136
Simon Glass96b7c432011-11-28 15:04:39 +0000137/**
138 * Set up the specified uarts
139 *
140 * @param uarts_ids Mask containing UARTs to init (UARTx)
141 */
142static void setup_uarts(int uart_ids)
143{
144 static enum periph_id id_for_uart[] = {
145 PERIPH_ID_UART1,
146 PERIPH_ID_UART2,
147 PERIPH_ID_UART3,
148 PERIPH_ID_UART4,
Tom Warrene3d95bc2013-01-28 13:32:10 +0000149 PERIPH_ID_UART5,
Simon Glass96b7c432011-11-28 15:04:39 +0000150 };
151 size_t i;
152
153 for (i = 0; i < UART_COUNT; i++) {
154 if (uart_ids & (1 << i)) {
155 enum periph_id id = id_for_uart[i];
156
Stephen Warren59f90102012-05-14 13:13:45 +0000157 funcmux_select(id, uart_configs[i]);
Simon Glass96b7c432011-11-28 15:04:39 +0000158 clock_ll_start_uart(id);
159 }
160 }
161}
162
163void board_init_uart_f(void)
164{
165 int uart_ids = 0; /* bit mask of which UART ids to enable */
166
Tom Warren22562a42012-09-04 17:00:24 -0700167#ifdef CONFIG_TEGRA_ENABLE_UARTA
Simon Glass96b7c432011-11-28 15:04:39 +0000168 uart_ids |= UARTA;
169#endif
Tom Warren22562a42012-09-04 17:00:24 -0700170#ifdef CONFIG_TEGRA_ENABLE_UARTB
Simon Glass96b7c432011-11-28 15:04:39 +0000171 uart_ids |= UARTB;
172#endif
Tom Warrene3d95bc2013-01-28 13:32:10 +0000173#ifdef CONFIG_TEGRA_ENABLE_UARTC
174 uart_ids |= UARTC;
175#endif
Tom Warren22562a42012-09-04 17:00:24 -0700176#ifdef CONFIG_TEGRA_ENABLE_UARTD
Simon Glass96b7c432011-11-28 15:04:39 +0000177 uart_ids |= UARTD;
178#endif
Tom Warrene3d95bc2013-01-28 13:32:10 +0000179#ifdef CONFIG_TEGRA_ENABLE_UARTE
180 uart_ids |= UARTE;
181#endif
Simon Glass96b7c432011-11-28 15:04:39 +0000182 setup_uarts(uart_ids);
183}
Simon Glass410012f2012-01-09 13:22:15 +0000184
185#ifndef CONFIG_SYS_DCACHE_OFF
186void enable_caches(void)
187{
188 /* Enable D-cache. I-cache is already enabled in start.S */
189 dcache_enable();
190}
191#endif