blob: 107cb7f8e0581d0f8c7c5487773e6873eec70cfe [file] [log] [blame]
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -04001/*
2 * (C) Copyright 2010
3 * ISEE 2007 SL, <www.iseebcn.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#include <common.h>
24#include <twl4030.h>
25#include <asm/io.h>
26#include <asm/arch/mem.h>
Enric Balletbo i Serra50d8d3b2010-11-04 15:34:37 -040027#include <asm/arch/mmc_host_def.h>
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -040028#include <asm/arch/mux.h>
29#include <asm/arch/sys_proto.h>
30#include <asm/mach-types.h>
31#include "igep0030.h"
32
John Rigby0d21ed02010-12-20 18:27:51 -070033DECLARE_GLOBAL_DATA_PTR;
34
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -040035/*
36 * Routine: board_init
37 * Description: Early hardware init.
38 */
39int board_init(void)
40{
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -040041 gpmc_init(); /* in SRAM or SDRAM, finish GPMC */
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -040042 /* boot param addr */
43 gd->bd->bi_boot_params = (OMAP34XX_SDRC_CS0 + 0x100);
44
45 return 0;
46}
47
Javier Martinez Canillas361fc832012-07-28 01:19:34 +000048#ifdef CONFIG_SPL_BUILD
49/*
50 * Routine: omap_rev_string
51 * Description: For SPL builds output board rev
52 */
53void omap_rev_string(void)
54{
55}
56
57/*
58 * Routine: get_board_mem_timings
59 * Description: If we use SPL then there is no x-loader nor config header
60 * so we have to setup the DDR timings ourself on both banks.
61 */
62void get_board_mem_timings(u32 *mcfg, u32 *ctrla, u32 *ctrlb, u32 *rfr_ctrl,
63 u32 *mr)
64{
65 *mr = MICRON_V_MR_165;
66#ifdef CONFIG_BOOT_NAND
Enric Balletbò i Serra8e7f3fe2012-08-05 00:55:56 +000067 *mcfg = MICRON_V_MCFG_200(256 << 20);
Javier Martinez Canillas361fc832012-07-28 01:19:34 +000068 *ctrla = MICRON_V_ACTIMA_200;
69 *ctrlb = MICRON_V_ACTIMB_200;
70 *rfr_ctrl = SDP_3430_SDRC_RFR_CTRL_200MHz;
71#else
72 if (get_cpu_family() == CPU_OMAP34XX) {
Enric Balletbò i Serra8e7f3fe2012-08-05 00:55:56 +000073 *mcfg = NUMONYX_V_MCFG_165(256 << 20);
Javier Martinez Canillas361fc832012-07-28 01:19:34 +000074 *ctrla = NUMONYX_V_ACTIMA_165;
75 *ctrlb = NUMONYX_V_ACTIMB_165;
76 *rfr_ctrl = SDP_3430_SDRC_RFR_CTRL_165MHz;
77
78 } else {
Enric Balletbò i Serra8e7f3fe2012-08-05 00:55:56 +000079 *mcfg = NUMONYX_V_MCFG_200(256 << 20);
Javier Martinez Canillas361fc832012-07-28 01:19:34 +000080 *ctrla = NUMONYX_V_ACTIMA_200;
81 *ctrlb = NUMONYX_V_ACTIMB_200;
82 *rfr_ctrl = SDP_3430_SDRC_RFR_CTRL_200MHz;
83 }
84#endif
85}
86#endif
87
88#if defined(CONFIG_GENERIC_MMC) && !defined(CONFIG_SPL_BUILD)
Enric Balletbo i Serra50d8d3b2010-11-04 15:34:37 -040089int board_mmc_init(bd_t *bis)
90{
Jonathan Solnita9b05562012-02-24 11:30:18 +000091 omap_mmc_init(0, 0, 0);
Enric Balletbo i Serra50d8d3b2010-11-04 15:34:37 -040092 return 0;
93}
94#endif
95
Enric Balletbo i Serra3c1e54a2010-10-14 16:57:39 -040096/*
97 * Routine: misc_init_r
98 * Description: Configure board specific parts
99 */
100int misc_init_r(void)
101{
102 twl4030_power_init();
103
104 dieid_num_r();
105
106 return 0;
107}
108
109/*
110 * Routine: set_muxconf_regs
111 * Description: Setting up the configuration Mux registers specific to the
112 * hardware. Many pins need to be moved from protect to primary
113 * mode.
114 */
115void set_muxconf_regs(void)
116{
117 MUX_DEFAULT();
118}