blob: 0f19141cc23ab362c5c66f5ff4d907cd2bb29067 [file] [log] [blame]
Chandan Nath77a73fe2012-01-09 20:38:59 +00001/*
2 * boot-common.c
3 *
4 * Common bootmode functions for omap based boards
5 *
6 * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
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
19#include <common.h>
Tom Rini28591df2012-08-13 12:03:19 -070020#include <spl.h>
Chandan Nath77a73fe2012-01-09 20:38:59 +000021#include <asm/omap_common.h>
22#include <asm/arch/omap.h>
Tom Rinia0b9fa52012-08-14 10:25:15 -070023#include <asm/arch/mmc_host_def.h>
Chandan Nath77a73fe2012-01-09 20:38:59 +000024
25/*
26 * This is used to verify if the configuration header
27 * was executed by rom code prior to control of transfer
28 * to the bootloader. SPL is responsible for saving and
29 * passing the boot_params pointer to the u-boot.
30 */
31struct omap_boot_parameters boot_params __attribute__ ((section(".data")));
32
33#ifdef CONFIG_SPL_BUILD
34/*
35 * We use static variables because global data is not ready yet.
36 * Initialized data is available in SPL right from the beginning.
37 * We would not typically need to save these parameters in regular
38 * U-Boot. This is needed only in SPL at the moment.
39 */
40u32 omap_bootmode = MMCSD_MODE_FAT;
41
Tom Rini0be93ff2012-08-13 12:53:23 -070042u32 spl_boot_device(void)
Chandan Nath77a73fe2012-01-09 20:38:59 +000043{
44 return (u32) (boot_params.omap_bootdevice);
45}
46
Tom Rinia76ff952012-08-14 09:19:44 -070047u32 spl_boot_mode(void)
Chandan Nath77a73fe2012-01-09 20:38:59 +000048{
49 return omap_bootmode;
50}
Tom Rinia0b9fa52012-08-14 10:25:15 -070051
Tom Rini9e0c2602012-08-14 12:26:08 -070052void spl_board_init(void)
53{
54#ifdef CONFIG_SPL_NAND_SUPPORT
55 gpmc_init();
56#endif
57}
58
Tom Rinia0b9fa52012-08-14 10:25:15 -070059int board_mmc_init(bd_t *bis)
60{
61 switch (spl_boot_device()) {
62 case BOOT_DEVICE_MMC1:
63 omap_mmc_init(0, 0, 0);
64 break;
65 case BOOT_DEVICE_MMC2:
66 case BOOT_DEVICE_MMC2_2:
67 omap_mmc_init(1, 0, 0);
68 break;
69 }
70 return 0;
71}
Chandan Nath77a73fe2012-01-09 20:38:59 +000072#endif