xref: /openbmc/u-boot/board/siemens/common/board.c (revision c0dcece7)
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