boot-common.c 4.2 KB
Newer Older
1 2 3 4 5 6 7
/*
 * boot-common.c
 *
 * Common bootmode functions for omap based boards
 *
 * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
 *
8
 * SPDX-License-Identifier:	GPL-2.0+
9 10 11
 */

#include <common.h>
D
Dmitry Lifshitz 已提交
12
#include <ahci.h>
13
#include <spl.h>
14 15
#include <asm/omap_common.h>
#include <asm/arch/omap.h>
T
Tom Rini 已提交
16
#include <asm/arch/mmc_host_def.h>
17
#include <asm/arch/sys_proto.h>
18
#include <watchdog.h>
D
Dmitry Lifshitz 已提交
19
#include <scsi.h>
20

21
DECLARE_GLOBAL_DATA_PTR;
22

23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
void save_omap_boot_params(void)
{
	u32 rom_params = *((u32 *)OMAP_SRAM_SCRATCH_BOOT_PARAMS);
	u8 boot_device;
	u32 dev_desc, dev_data;

	if ((rom_params <  NON_SECURE_SRAM_START) ||
	    (rom_params > NON_SECURE_SRAM_END))
		return;

	/*
	 * rom_params can be type casted to omap_boot_parameters and
	 * used. But it not correct to assume that romcode structure
	 * encoding would be same as u-boot. So use the defined offsets.
	 */
38 39 40 41 42 43 44 45 46 47 48 49 50
	boot_device = *((u8 *)(rom_params + BOOT_DEVICE_OFFSET));

#if defined(BOOT_DEVICE_NAND_I2C)
	/*
	 * Re-map NAND&I2C boot-device to the "normal" NAND boot-device.
	 * Otherwise the SPL boot IF can't handle this device correctly.
	 * Somehow booting with Hynix 4GBit NAND H27U4G8 on Siemens
	 * Draco leads to this boot-device passed to SPL from the BootROM.
	 */
	if (boot_device == BOOT_DEVICE_NAND_I2C)
		boot_device = BOOT_DEVICE_NAND;
#endif
	gd->arch.omap_boot_params.omap_bootdevice = boot_device;
51 52 53 54 55 56

	gd->arch.omap_boot_params.ch_flags =
				*((u8 *)(rom_params + CH_FLAGS_OFFSET));

	if ((boot_device >= MMC_BOOT_DEVICES_START) &&
	    (boot_device <= MMC_BOOT_DEVICES_END)) {
L
Lokesh Vutla 已提交
57 58
#if !defined(CONFIG_AM33XX) && !defined(CONFIG_TI81XX) && \
	!defined(CONFIG_AM43XX)
59 60 61 62 63 64 65 66 67 68 69 70 71
		if ((omap_hw_init_context() ==
				      OMAP_INIT_CONTEXT_UBOOT_AFTER_SPL)) {
			gd->arch.omap_boot_params.omap_bootmode =
			*((u8 *)(rom_params + BOOT_MODE_OFFSET));
		} else
#endif
		{
			dev_desc = *((u32 *)(rom_params + DEV_DESC_PTR_OFFSET));
			dev_data = *((u32 *)(dev_desc + DEV_DATA_PTR_OFFSET));
			gd->arch.omap_boot_params.omap_bootmode =
					*((u32 *)(dev_data + BOOT_MODE_OFFSET));
		}
	}
72

73
#if defined(CONFIG_DRA7XX) || defined(CONFIG_AM57XX)
74 75 76 77 78 79 80 81 82
	/*
	 * We get different values for QSPI_1 and QSPI_4 being used, but
	 * don't actually care about this difference.  Rather than
	 * mangle the later code, if we're coming in as QSPI_4 just
	 * change to the QSPI_1 value.
	 */
	if (gd->arch.omap_boot_params.omap_bootdevice == 11)
		gd->arch.omap_boot_params.omap_bootdevice = BOOT_DEVICE_SPI;
#endif
83 84
}

85
#ifdef CONFIG_SPL_BUILD
86
u32 spl_boot_device(void)
87
{
88
	return (u32) (gd->arch.omap_boot_params.omap_bootdevice);
89 90
}

91
u32 spl_boot_mode(void)
92
{
93 94 95 96
	u32 val = gd->arch.omap_boot_params.omap_bootmode;

	if (val == MMCSD_MODE_RAW)
		return MMCSD_MODE_RAW;
97 98
	else if (val == MMCSD_MODE_FS)
		return MMCSD_MODE_FS;
99 100 101 102 103 104
	else
#ifdef CONFIG_SUPPORT_EMMC_BOOT
		return MMCSD_MODE_EMMCBOOT;
#else
		return MMCSD_MODE_UNDEFINED;
#endif
105
}
T
Tom Rini 已提交
106

107 108
void spl_board_init(void)
{
109 110 111 112 113 114 115 116 117 118
	/*
	 * Save the boot parameters passed from romcode.
	 * We cannot delay the saving further than this,
	 * to prevent overwrites.
	 */
	save_omap_boot_params();

	/* Prepare console output */
	preloader_console_init();

119 120 121
#ifdef CONFIG_SPL_NAND_SUPPORT
	gpmc_init();
#endif
122 123 124
#if defined(CONFIG_AM33XX) && defined(CONFIG_SPL_MUSB_NEW_SUPPORT)
	arch_misc_init();
#endif
125 126 127
#if defined(CONFIG_HW_WATCHDOG)
	hw_watchdog_init();
#endif
128 129 130
#ifdef CONFIG_AM33XX
	am33xx_spl_board_init();
#endif
131 132
}

T
Tom Rini 已提交
133 134 135 136
int board_mmc_init(bd_t *bis)
{
	switch (spl_boot_device()) {
	case BOOT_DEVICE_MMC1:
137
		omap_mmc_init(0, 0, 0, -1, -1);
T
Tom Rini 已提交
138 139 140
		break;
	case BOOT_DEVICE_MMC2:
	case BOOT_DEVICE_MMC2_2:
141
		omap_mmc_init(1, 0, 0, -1, -1);
T
Tom Rini 已提交
142 143 144 145
		break;
	}
	return 0;
}
146 147 148 149 150 151 152 153 154 155 156

void __noreturn jump_to_image_no_args(struct spl_image_info *spl_image)
{
	typedef void __noreturn (*image_entry_noargs_t)(u32 *);
	image_entry_noargs_t image_entry =
			(image_entry_noargs_t) spl_image->entry_point;

	debug("image entry point: 0x%X\n", spl_image->entry_point);
	/* Pass the saved boot_params from rom code */
	image_entry((u32 *)&gd->arch.omap_boot_params);
}
157
#endif
D
Dmitry Lifshitz 已提交
158 159 160 161

#ifdef CONFIG_SCSI_AHCI_PLAT
void arch_preboot_os(void)
{
162
	ahci_reset((void __iomem *)DWC_AHSATA_BASE);
D
Dmitry Lifshitz 已提交
163 164
}
#endif
165 166 167 168 169 170 171 172 173 174

#if defined(CONFIG_CMD_FASTBOOT) && !defined(CONFIG_ENV_IS_NOWHERE)
int fb_set_reboot_flag(void)
{
	printf("Setting reboot to fastboot flag ...\n");
	setenv("dofastboot", "1");
	saveenv();
	return 0;
}
#endif