/* * (C) Copyright 2011 * Graeme Russ, * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include DECLARE_GLOBAL_DATA_PTR; /************************************************************************ * Init Utilities * ************************************************************************ * Some of this code should be moved into the core functions, * or dropped completely, * but let's get it working (again) first... */ int display_banner(void) { printf("\n\n%s\n\n", version_string); return 0; } int display_dram_config(void) { int i; puts("DRAM Configuration:\n"); for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) { printf("Bank #%d: %08lx ", i, gd->bd->bi_dram[i].start); print_size(gd->bd->bi_dram[i].size, "\n"); } return 0; } int init_baudrate_f(void) { gd->baudrate = getenv_ulong("baudrate", 10, CONFIG_BAUDRATE); return 0; } /* Get the top of usable RAM */ __weak ulong board_get_usable_ram_top(ulong total_size) { return gd->ram_size; } int calculate_relocation_address(void) { const ulong uboot_size = (uintptr_t)&__bss_end - (uintptr_t)&__text_start; ulong total_size; ulong dest_addr; total_size = ALIGN(uboot_size, 1 << 12) + CONFIG_SYS_MALLOC_LEN + CONFIG_SYS_STACK_SIZE; /* * NOTE: All destination address are rounded down to 16-byte * boundary to satisfy various worst-case alignment * requirements */ dest_addr = board_get_usable_ram_top(total_size); /* U-Boot is below the FDT */ dest_addr -= uboot_size; dest_addr &= ~((1 << 12) - 1); gd->relocaddr = dest_addr; gd->reloc_off = dest_addr - (uintptr_t)&__text_start; /* Stack is at the bottom, so it can grow down */ gd->start_addr_sp = dest_addr - CONFIG_SYS_MALLOC_LEN; return 0; } int init_cache_f_r(void) { /* Initialise the CPU cache(s) */ return init_cache(); } int set_reloc_flag_r(void) { gd->flags = GD_FLG_RELOC; return 0; } int mem_malloc_init_r(void) { mem_malloc_init(((gd->relocaddr - CONFIG_SYS_MALLOC_LEN)+3)&~3, CONFIG_SYS_MALLOC_LEN); return 0; } bd_t bd_data; int init_bd_struct_r(void) { gd->bd = &bd_data; memset(gd->bd, 0, sizeof(bd_t)); return 0; } #ifndef CONFIG_SYS_NO_FLASH int flash_init_r(void) { ulong size; puts("Flash: "); /* configure available FLASH banks */ size = flash_init(); print_size(size, "\n"); return 0; } #endif #ifdef CONFIG_STATUS_LED int status_led_set_r(void) { status_led_set(STATUS_LED_BOOT, STATUS_LED_BLINKING); return 0; } #endif int set_load_addr_r(void) { /* Initialize from environment */ load_addr = getenv_ulong("loadaddr", 16, load_addr); return 0; } int init_func_spi(void) { puts("SPI: "); spi_init(); puts("ready\n"); return 0; } #ifdef CONFIG_OF_CONTROL int find_fdt(void) { #ifdef CONFIG_OF_EMBED /* Get a pointer to the FDT */ gd->fdt_blob = _binary_dt_dtb_start; #elif defined CONFIG_OF_SEPARATE /* FDT is at end of image */ gd->fdt_blob = (void *)(_end_ofs + _TEXT_BASE); #endif /* Allow the early environment to override the fdt address */ gd->fdt_blob = (void *)getenv_ulong("fdtcontroladdr", 16, (uintptr_t)gd->fdt_blob); return 0; } int prepare_fdt(void) { /* For now, put this check after the console is ready */ if (fdtdec_prepare_fdt()) { panic("** CONFIG_OF_CONTROL defined but no FDT - please see " "doc/README.fdt-control"); } return 0; } #endif