mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	Right now the SPL is trying to load u-boot based on defines, i.e. one has to define CONFIG_SPL_NAND_SIMPLE to boot from NAND, or CONFIG_SPL_SPI_LOAD to boot from SPI FLASH, etc... This prevent us from having a single SPL image that is able to boot from all media, and one need to build an image for each medium. This commit is replacing the #ifdef that select the boot medium by reading the value of the boot pins (via the BOOTCFG register). Now a single SPL image will be able to read from the boot pin to know which device should be used to load u-boot. Signed-off-by: Fabien Parent <fparent@baylibre.com> Reviewed-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			79 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (C) 2011
 | 
						|
 * Heiko Schocher, DENX Software Engineering, hs@denx.de.
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier:	GPL-2.0+
 | 
						|
 */
 | 
						|
#include <common.h>
 | 
						|
#include <config.h>
 | 
						|
#include <spl.h>
 | 
						|
#include <asm/u-boot.h>
 | 
						|
#include <asm/utils.h>
 | 
						|
#include <nand.h>
 | 
						|
#include <asm/arch/dm365_lowlevel.h>
 | 
						|
#include <ns16550.h>
 | 
						|
#include <malloc.h>
 | 
						|
#include <spi_flash.h>
 | 
						|
#include <mmc.h>
 | 
						|
 | 
						|
DECLARE_GLOBAL_DATA_PTR;
 | 
						|
 | 
						|
#ifndef CONFIG_SPL_LIBCOMMON_SUPPORT
 | 
						|
void puts(const char *str)
 | 
						|
{
 | 
						|
	while (*str)
 | 
						|
		putc(*str++);
 | 
						|
}
 | 
						|
 | 
						|
void putc(char c)
 | 
						|
{
 | 
						|
	if (c == '\n')
 | 
						|
		NS16550_putc((NS16550_t)(CONFIG_SYS_NS16550_COM1), '\r');
 | 
						|
 | 
						|
	NS16550_putc((NS16550_t)(CONFIG_SYS_NS16550_COM1), c);
 | 
						|
}
 | 
						|
#endif /* CONFIG_SPL_LIBCOMMON_SUPPORT */
 | 
						|
 | 
						|
void spl_board_init(void)
 | 
						|
{
 | 
						|
#ifdef CONFIG_SOC_DM365
 | 
						|
	dm36x_lowlevel_init(0);
 | 
						|
#endif
 | 
						|
#ifdef CONFIG_SOC_DA8XX
 | 
						|
	arch_cpu_init();
 | 
						|
#endif
 | 
						|
	preloader_console_init();
 | 
						|
}
 | 
						|
 | 
						|
u32 spl_boot_mode(const u32 boot_device)
 | 
						|
{
 | 
						|
	return MMCSD_MODE_RAW;
 | 
						|
}
 | 
						|
 | 
						|
u32 spl_boot_device(void)
 | 
						|
{
 | 
						|
	switch (davinci_syscfg_regs->bootcfg) {
 | 
						|
#ifdef CONFIG_SPL_NAND_SUPPORT
 | 
						|
	case DAVINCI_NAND8_BOOT:
 | 
						|
	case DAVINCI_NAND16_BOOT:
 | 
						|
		return BOOT_DEVICE_NAND;
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_SPL_MMC_SUPPORT
 | 
						|
	case DAVINCI_SD_OR_MMC_BOOT:
 | 
						|
	case DAVINCI_MMC_ONLY_BOOT:
 | 
						|
		return BOOT_DEVICE_MMC1;
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef CONFIG_SPL_SPI_FLASH_SUPPORT
 | 
						|
	case DAVINCI_SPI0_FLASH_BOOT:
 | 
						|
	case DAVINCI_SPI1_FLASH_BOOT:
 | 
						|
		return BOOT_DEVICE_SPI;
 | 
						|
#endif
 | 
						|
 | 
						|
	default:
 | 
						|
		puts("Unknown boot device\n");
 | 
						|
		hang();
 | 
						|
	}
 | 
						|
}
 |