1 /* 2 * 3 * Common functions for OMAP4/5 based boards 4 * 5 * (C) Copyright 2010 6 * Texas Instruments, <www.ti.com> 7 * 8 * Author : 9 * Aneesh V <aneesh@ti.com> 10 * Steve Sakoman <steve@sakoman.com> 11 * 12 * SPDX-License-Identifier: GPL-2.0+ 13 */ 14 #include <common.h> 15 #include <debug_uart.h> 16 #include <spl.h> 17 #include <asm/arch/sys_proto.h> 18 #include <linux/sizes.h> 19 #include <asm/emif.h> 20 #include <asm/omap_common.h> 21 #include <linux/compiler.h> 22 #include <asm/system.h> 23 24 DECLARE_GLOBAL_DATA_PTR; 25 26 void do_set_mux(u32 base, struct pad_conf_entry const *array, int size) 27 { 28 int i; 29 struct pad_conf_entry *pad = (struct pad_conf_entry *) array; 30 31 for (i = 0; i < size; i++, pad++) 32 writew(pad->val, base + pad->offset); 33 } 34 35 static void set_mux_conf_regs(void) 36 { 37 switch (omap_hw_init_context()) { 38 case OMAP_INIT_CONTEXT_SPL: 39 set_muxconf_regs(); 40 break; 41 case OMAP_INIT_CONTEXT_UBOOT_AFTER_SPL: 42 break; 43 case OMAP_INIT_CONTEXT_UBOOT_FROM_NOR: 44 case OMAP_INIT_CONTEXT_UBOOT_AFTER_CH: 45 set_muxconf_regs(); 46 break; 47 } 48 } 49 50 u32 cortex_rev(void) 51 { 52 53 unsigned int rev; 54 55 /* Read Main ID Register (MIDR) */ 56 asm ("mrc p15, 0, %0, c0, c0, 0" : "=r" (rev)); 57 58 return rev; 59 } 60 61 static void omap_rev_string(void) 62 { 63 u32 omap_rev = omap_revision(); 64 u32 soc_variant = (omap_rev & 0xF0000000) >> 28; 65 u32 omap_variant = (omap_rev & 0xFFFF0000) >> 16; 66 u32 major_rev = (omap_rev & 0x00000F00) >> 8; 67 u32 minor_rev = (omap_rev & 0x000000F0) >> 4; 68 69 const char *sec_s; 70 71 switch (get_device_type()) { 72 case TST_DEVICE: 73 sec_s = "TST"; 74 break; 75 case EMU_DEVICE: 76 sec_s = "EMU"; 77 break; 78 case HS_DEVICE: 79 sec_s = "HS"; 80 break; 81 case GP_DEVICE: 82 sec_s = "GP"; 83 break; 84 default: 85 sec_s = "?"; 86 } 87 88 if (soc_variant) 89 printf("OMAP"); 90 else 91 printf("DRA"); 92 printf("%x-%s ES%x.%x\n", omap_variant, sec_s, major_rev, minor_rev); 93 } 94 95 #ifdef CONFIG_SPL_BUILD 96 void spl_display_print(void) 97 { 98 omap_rev_string(); 99 } 100 #endif 101 102 void __weak srcomp_enable(void) 103 { 104 } 105 106 /** 107 * do_board_detect() - Detect board description 108 * 109 * Function to detect board description. This is expected to be 110 * overridden in the SoC family board file where desired. 111 */ 112 void __weak do_board_detect(void) 113 { 114 } 115 116 /** 117 * vcores_init() - Assign omap_vcores based on board 118 * 119 * Function to pick the vcores based on board. This is expected to be 120 * overridden in the SoC family board file where desired. 121 */ 122 void __weak vcores_init(void) 123 { 124 } 125 126 void s_init(void) 127 { 128 } 129 130 /** 131 * early_system_init - Does Early system initialization. 132 * 133 * Does early system init of watchdog, muxing, andclocks 134 * Watchdog disable is done always. For the rest what gets done 135 * depends on the boot mode in which this function is executed when 136 * 1. SPL running from SRAM 137 * 2. U-Boot running from FLASH 138 * 3. U-Boot loaded to SDRAM by SPL 139 * 4. U-Boot loaded to SDRAM by ROM code using the 140 * Configuration Header feature 141 * Please have a look at the respective functions to see what gets 142 * done in each of these cases 143 * This function is called with SRAM stack. 144 */ 145 void early_system_init(void) 146 { 147 init_omap_revision(); 148 hw_data_init(); 149 150 #ifdef CONFIG_SPL_BUILD 151 if (warm_reset()) 152 force_emif_self_refresh(); 153 #endif 154 watchdog_init(); 155 set_mux_conf_regs(); 156 #ifdef CONFIG_SPL_BUILD 157 srcomp_enable(); 158 do_io_settings(); 159 #endif 160 setup_early_clocks(); 161 do_board_detect(); 162 vcores_init(); 163 #ifdef CONFIG_DEBUG_UART_OMAP 164 debug_uart_init(); 165 #endif 166 prcm_init(); 167 } 168 169 #ifdef CONFIG_SPL_BUILD 170 void board_init_f(ulong dummy) 171 { 172 early_system_init(); 173 #ifdef CONFIG_BOARD_EARLY_INIT_F 174 board_early_init_f(); 175 #endif 176 /* For regular u-boot sdram_init() is called from dram_init() */ 177 sdram_init(); 178 gd->ram_size = omap_sdram_size(); 179 } 180 #endif 181 182 int arch_cpu_init_dm(void) 183 { 184 early_system_init(); 185 return 0; 186 } 187 188 /* 189 * Routine: wait_for_command_complete 190 * Description: Wait for posting to finish on watchdog 191 */ 192 void wait_for_command_complete(struct watchdog *wd_base) 193 { 194 int pending = 1; 195 do { 196 pending = readl(&wd_base->wwps); 197 } while (pending); 198 } 199 200 /* 201 * Routine: watchdog_init 202 * Description: Shut down watch dogs 203 */ 204 void watchdog_init(void) 205 { 206 struct watchdog *wd2_base = (struct watchdog *)WDT2_BASE; 207 208 writel(WD_UNLOCK1, &wd2_base->wspr); 209 wait_for_command_complete(wd2_base); 210 writel(WD_UNLOCK2, &wd2_base->wspr); 211 } 212 213 214 /* 215 * This function finds the SDRAM size available in the system 216 * based on DMM section configurations 217 * This is needed because the size of memory installed may be 218 * different on different versions of the board 219 */ 220 u32 omap_sdram_size(void) 221 { 222 u32 section, i, valid; 223 u64 sdram_start = 0, sdram_end = 0, addr, 224 size, total_size = 0, trap_size = 0, trap_start = 0; 225 226 for (i = 0; i < 4; i++) { 227 section = __raw_readl(DMM_BASE + i*4); 228 valid = (section & EMIF_SDRC_ADDRSPC_MASK) >> 229 (EMIF_SDRC_ADDRSPC_SHIFT); 230 addr = section & EMIF_SYS_ADDR_MASK; 231 232 /* See if the address is valid */ 233 if ((addr >= TI_ARMV7_DRAM_ADDR_SPACE_START) && 234 (addr < TI_ARMV7_DRAM_ADDR_SPACE_END)) { 235 size = ((section & EMIF_SYS_SIZE_MASK) >> 236 EMIF_SYS_SIZE_SHIFT); 237 size = 1 << size; 238 size *= SZ_16M; 239 240 if (valid != DMM_SDRC_ADDR_SPC_INVALID) { 241 if (!sdram_start || (addr < sdram_start)) 242 sdram_start = addr; 243 if (!sdram_end || ((addr + size) > sdram_end)) 244 sdram_end = addr + size; 245 } else { 246 trap_size = size; 247 trap_start = addr; 248 } 249 } 250 } 251 252 if ((trap_start >= sdram_start) && (trap_start < sdram_end)) 253 total_size = (sdram_end - sdram_start) - (trap_size); 254 else 255 total_size = sdram_end - sdram_start; 256 257 return total_size; 258 } 259 260 261 /* 262 * Routine: dram_init 263 * Description: sets uboots idea of sdram size 264 */ 265 int dram_init(void) 266 { 267 sdram_init(); 268 gd->ram_size = omap_sdram_size(); 269 return 0; 270 } 271 272 /* 273 * Print board information 274 */ 275 int checkboard(void) 276 { 277 puts(sysinfo.board_string); 278 return 0; 279 } 280 281 #if defined(CONFIG_DISPLAY_CPUINFO) 282 /* 283 * Print CPU information 284 */ 285 int print_cpuinfo(void) 286 { 287 puts("CPU : "); 288 omap_rev_string(); 289 290 return 0; 291 } 292 #endif 293