1*c0dcece7SHeiko Schocher /* 2*c0dcece7SHeiko Schocher * Common board functions for siemens AM335X based boards 3*c0dcece7SHeiko Schocher * (C) Copyright 2013 Siemens Schweiz AG 4*c0dcece7SHeiko Schocher * (C) Heiko Schocher, DENX Software Engineering, hs@denx.de. 5*c0dcece7SHeiko Schocher * 6*c0dcece7SHeiko Schocher * Based on: 7*c0dcece7SHeiko Schocher * U-Boot file:/board/ti/am335x/board.c 8*c0dcece7SHeiko Schocher * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/ 9*c0dcece7SHeiko Schocher * 10*c0dcece7SHeiko Schocher * SPDX-License-Identifier: GPL-2.0+ 11*c0dcece7SHeiko Schocher */ 12*c0dcece7SHeiko Schocher 13*c0dcece7SHeiko Schocher #include <common.h> 14*c0dcece7SHeiko Schocher #include <errno.h> 15*c0dcece7SHeiko Schocher #include <spl.h> 16*c0dcece7SHeiko Schocher #include <asm/arch/cpu.h> 17*c0dcece7SHeiko Schocher #include <asm/arch/hardware.h> 18*c0dcece7SHeiko Schocher #include <asm/arch/omap.h> 19*c0dcece7SHeiko Schocher #include <asm/arch/ddr_defs.h> 20*c0dcece7SHeiko Schocher #include <asm/arch/clock.h> 21*c0dcece7SHeiko Schocher #include <asm/arch/gpio.h> 22*c0dcece7SHeiko Schocher #include <asm/arch/mmc_host_def.h> 23*c0dcece7SHeiko Schocher #include <asm/arch/sys_proto.h> 24*c0dcece7SHeiko Schocher #include <asm/io.h> 25*c0dcece7SHeiko Schocher #include <asm/emif.h> 26*c0dcece7SHeiko Schocher #include <asm/gpio.h> 27*c0dcece7SHeiko Schocher #include <i2c.h> 28*c0dcece7SHeiko Schocher #include <miiphy.h> 29*c0dcece7SHeiko Schocher #include <cpsw.h> 30*c0dcece7SHeiko Schocher #include <watchdog.h> 31*c0dcece7SHeiko Schocher #include "../common/factoryset.h" 32*c0dcece7SHeiko Schocher 33*c0dcece7SHeiko Schocher DECLARE_GLOBAL_DATA_PTR; 34*c0dcece7SHeiko Schocher 35*c0dcece7SHeiko Schocher #ifdef CONFIG_SPL_BUILD 36*c0dcece7SHeiko Schocher void set_uart_mux_conf(void) 37*c0dcece7SHeiko Schocher { 38*c0dcece7SHeiko Schocher enable_uart0_pin_mux(); 39*c0dcece7SHeiko Schocher } 40*c0dcece7SHeiko Schocher 41*c0dcece7SHeiko Schocher void set_mux_conf_regs(void) 42*c0dcece7SHeiko Schocher { 43*c0dcece7SHeiko Schocher /* Initalize the board header */ 44*c0dcece7SHeiko Schocher enable_i2c0_pin_mux(); 45*c0dcece7SHeiko Schocher i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); 46*c0dcece7SHeiko Schocher if (read_eeprom() < 0) 47*c0dcece7SHeiko Schocher puts("Could not get board ID.\n"); 48*c0dcece7SHeiko Schocher 49*c0dcece7SHeiko Schocher enable_board_pin_mux(); 50*c0dcece7SHeiko Schocher } 51*c0dcece7SHeiko Schocher 52*c0dcece7SHeiko Schocher void sdram_init(void) 53*c0dcece7SHeiko Schocher { 54*c0dcece7SHeiko Schocher spl_siemens_board_init(); 55*c0dcece7SHeiko Schocher board_init_ddr(); 56*c0dcece7SHeiko Schocher 57*c0dcece7SHeiko Schocher return; 58*c0dcece7SHeiko Schocher } 59*c0dcece7SHeiko Schocher #endif /* #ifdef CONFIG_SPL_BUILD */ 60*c0dcece7SHeiko Schocher 61*c0dcece7SHeiko Schocher #ifndef CONFIG_SPL_BUILD 62*c0dcece7SHeiko Schocher /* 63*c0dcece7SHeiko Schocher * Basic board specific setup. Pinmux has been handled already. 64*c0dcece7SHeiko Schocher */ 65*c0dcece7SHeiko Schocher int board_init(void) 66*c0dcece7SHeiko Schocher { 67*c0dcece7SHeiko Schocher #if defined(CONFIG_HW_WATCHDOG) 68*c0dcece7SHeiko Schocher hw_watchdog_init(); 69*c0dcece7SHeiko Schocher #endif /* defined(CONFIG_HW_WATCHDOG) */ 70*c0dcece7SHeiko Schocher i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); 71*c0dcece7SHeiko Schocher if (read_eeprom() < 0) 72*c0dcece7SHeiko Schocher puts("Could not get board ID.\n"); 73*c0dcece7SHeiko Schocher 74*c0dcece7SHeiko Schocher gd->bd->bi_arch_number = CONFIG_MACH_TYPE; 75*c0dcece7SHeiko Schocher gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100; 76*c0dcece7SHeiko Schocher 77*c0dcece7SHeiko Schocher #ifdef CONFIG_FACTORYSET 78*c0dcece7SHeiko Schocher factoryset_read_eeprom(CONFIG_SYS_I2C_EEPROM_ADDR); 79*c0dcece7SHeiko Schocher #endif 80*c0dcece7SHeiko Schocher gpmc_init(); 81*c0dcece7SHeiko Schocher 82*c0dcece7SHeiko Schocher #ifdef CONFIG_VIDEO 83*c0dcece7SHeiko Schocher board_video_init(); 84*c0dcece7SHeiko Schocher #endif 85*c0dcece7SHeiko Schocher 86*c0dcece7SHeiko Schocher return 0; 87*c0dcece7SHeiko Schocher } 88*c0dcece7SHeiko Schocher #endif /* #ifndef CONFIG_SPL_BUILD */ 89*c0dcece7SHeiko Schocher 90*c0dcece7SHeiko Schocher #define OSC (V_OSCK/1000000) 91*c0dcece7SHeiko Schocher const struct dpll_params dpll_ddr = { 92*c0dcece7SHeiko Schocher DDR_PLL_FREQ, OSC-1, 1, -1, -1, -1, -1}; 93*c0dcece7SHeiko Schocher 94*c0dcece7SHeiko Schocher const struct dpll_params *get_dpll_ddr_params(void) 95*c0dcece7SHeiko Schocher { 96*c0dcece7SHeiko Schocher return &dpll_ddr; 97*c0dcece7SHeiko Schocher } 98*c0dcece7SHeiko Schocher 99*c0dcece7SHeiko Schocher #ifdef CONFIG_BOARD_LATE_INIT 100*c0dcece7SHeiko Schocher int board_late_init(void) 101*c0dcece7SHeiko Schocher { 102*c0dcece7SHeiko Schocher omap_nand_switch_ecc(1, 8); 103*c0dcece7SHeiko Schocher 104*c0dcece7SHeiko Schocher return 0; 105*c0dcece7SHeiko Schocher } 106*c0dcece7SHeiko Schocher #endif 107*c0dcece7SHeiko Schocher 108*c0dcece7SHeiko Schocher #ifndef CONFIG_SPL_BUILD 109*c0dcece7SHeiko Schocher #if defined(BOARD_DFU_BUTTON_GPIO) 110*c0dcece7SHeiko Schocher /* 111*c0dcece7SHeiko Schocher * This command returns the status of the user button on 112*c0dcece7SHeiko Schocher * Input - none 113*c0dcece7SHeiko Schocher * Returns - 1 if button is held down 114*c0dcece7SHeiko Schocher * 0 if button is not held down 115*c0dcece7SHeiko Schocher */ 116*c0dcece7SHeiko Schocher static int 117*c0dcece7SHeiko Schocher do_userbutton(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 118*c0dcece7SHeiko Schocher { 119*c0dcece7SHeiko Schocher int button = 0; 120*c0dcece7SHeiko Schocher int gpio; 121*c0dcece7SHeiko Schocher 122*c0dcece7SHeiko Schocher gpio = BOARD_DFU_BUTTON_GPIO; 123*c0dcece7SHeiko Schocher gpio_request(gpio, "DFU"); 124*c0dcece7SHeiko Schocher gpio_direction_input(gpio); 125*c0dcece7SHeiko Schocher if (gpio_get_value(gpio)) 126*c0dcece7SHeiko Schocher button = 1; 127*c0dcece7SHeiko Schocher else 128*c0dcece7SHeiko Schocher button = 0; 129*c0dcece7SHeiko Schocher 130*c0dcece7SHeiko Schocher gpio_free(gpio); 131*c0dcece7SHeiko Schocher if (!button) { 132*c0dcece7SHeiko Schocher /* LED0 - RED=1: GPIO2_0 2*32 = 64 */ 133*c0dcece7SHeiko Schocher gpio_request(BOARD_DFU_BUTTON_LED, ""); 134*c0dcece7SHeiko Schocher gpio_direction_output(BOARD_DFU_BUTTON_LED, 1); 135*c0dcece7SHeiko Schocher gpio_set_value(BOARD_DFU_BUTTON_LED, 1); 136*c0dcece7SHeiko Schocher } 137*c0dcece7SHeiko Schocher 138*c0dcece7SHeiko Schocher return button; 139*c0dcece7SHeiko Schocher } 140*c0dcece7SHeiko Schocher 141*c0dcece7SHeiko Schocher U_BOOT_CMD( 142*c0dcece7SHeiko Schocher dfubutton, CONFIG_SYS_MAXARGS, 1, do_userbutton, 143*c0dcece7SHeiko Schocher "Return the status of the DFU button", 144*c0dcece7SHeiko Schocher "" 145*c0dcece7SHeiko Schocher ); 146*c0dcece7SHeiko Schocher #endif 147*c0dcece7SHeiko Schocher 148*c0dcece7SHeiko Schocher static int 149*c0dcece7SHeiko Schocher do_usertestwdt(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) 150*c0dcece7SHeiko Schocher { 151*c0dcece7SHeiko Schocher printf("\n\n\n Go into infinite loop\n\n\n"); 152*c0dcece7SHeiko Schocher while (1) 153*c0dcece7SHeiko Schocher ; 154*c0dcece7SHeiko Schocher return 0; 155*c0dcece7SHeiko Schocher }; 156*c0dcece7SHeiko Schocher 157*c0dcece7SHeiko Schocher U_BOOT_CMD( 158*c0dcece7SHeiko Schocher testwdt, CONFIG_SYS_MAXARGS, 1, do_usertestwdt, 159*c0dcece7SHeiko Schocher "Sends U-Boot into infinite loop", 160*c0dcece7SHeiko Schocher "" 161*c0dcece7SHeiko Schocher ); 162*c0dcece7SHeiko Schocher 163*c0dcece7SHeiko Schocher #ifndef CONFIG_SYS_DCACHE_OFF 164*c0dcece7SHeiko Schocher void enable_caches(void) 165*c0dcece7SHeiko Schocher { 166*c0dcece7SHeiko Schocher printf("Enable d-cache\n"); 167*c0dcece7SHeiko Schocher /* Enable D-cache. I-cache is already enabled in start.S */ 168*c0dcece7SHeiko Schocher dcache_enable(); 169*c0dcece7SHeiko Schocher } 170*c0dcece7SHeiko Schocher #endif /* CONFIG_SYS_DCACHE_OFF */ 171*c0dcece7SHeiko Schocher #endif /* !CONFIG_SPL_BUILD */ 172