blob: 54aff78894a58b390bbc710fb0bc16d2597feb71 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Heiko Schocher565a09c2011-11-01 20:00:29 +00002/*
3 * Copyright (C) 2011
4 * Heiko Schocher, DENX Software Engineering, hs@denx.de.
Heiko Schocher565a09c2011-11-01 20:00:29 +00005 */
6#include <common.h>
Tom Rini12938582012-08-14 12:27:13 -07007#include <config.h>
Simon Glassf11478f2019-12-28 10:45:07 -07008#include <hang.h>
Simon Glass97589732020-05-10 11:40:02 -06009#include <init.h>
Tom Rini12938582012-08-14 12:27:13 -070010#include <spl.h>
Heiko Schocher565a09c2011-11-01 20:00:29 +000011#include <asm/u-boot.h>
12#include <asm/utils.h>
13#include <nand.h>
14#include <asm/arch/dm365_lowlevel.h>
15#include <ns16550.h>
Christian Riesch17a6a2f2011-12-09 09:47:36 +000016#include <malloc.h>
17#include <spi_flash.h>
Lad, Prabhakar8dc6df82012-06-24 21:35:20 +000018#include <mmc.h>
Christian Riesch17a6a2f2011-12-09 09:47:36 +000019
Tom Rini12938582012-08-14 12:27:13 -070020#ifndef CONFIG_SPL_LIBCOMMON_SUPPORT
Heiko Schocher565a09c2011-11-01 20:00:29 +000021void puts(const char *str)
22{
23 while (*str)
24 putc(*str++);
25}
26
27void putc(char c)
28{
29 if (c == '\n')
Simon Glass2b923982020-12-22 19:30:19 -070030 ns16550_putc((struct ns16550 *)(CONFIG_SYS_NS16550_COM1), '\r');
Heiko Schocher565a09c2011-11-01 20:00:29 +000031
Simon Glass2b923982020-12-22 19:30:19 -070032 ns16550_putc((struct ns16550 *)(CONFIG_SYS_NS16550_COM1), c);
Heiko Schocher565a09c2011-11-01 20:00:29 +000033}
Christian Riesch17a6a2f2011-12-09 09:47:36 +000034#endif /* CONFIG_SPL_LIBCOMMON_SUPPORT */
35
Sekhar Nori68e4f8f2019-05-30 19:04:55 +053036void board_init_f(ulong dummy)
Heiko Schocher565a09c2011-11-01 20:00:29 +000037{
Christian Riesch17a6a2f2011-12-09 09:47:36 +000038 arch_cpu_init();
Sekhar Nori68e4f8f2019-05-30 19:04:55 +053039
40 spl_early_init();
41
Tom Rini12938582012-08-14 12:27:13 -070042 preloader_console_init();
43}
Lad, Prabhakar5dad9212012-06-24 21:35:18 +000044
Tom Rini12938582012-08-14 12:27:13 -070045u32 spl_boot_device(void)
46{
Fabien Parent9efa10f2017-01-09 11:06:36 +010047 switch (davinci_syscfg_regs->bootcfg) {
48#ifdef CONFIG_SPL_NAND_SUPPORT
49 case DAVINCI_NAND8_BOOT:
50 case DAVINCI_NAND16_BOOT:
51 return BOOT_DEVICE_NAND;
52#endif
53
Simon Glassb58bfe02021-08-08 12:20:09 -060054#ifdef CONFIG_SPL_MMC
Fabien Parent9efa10f2017-01-09 11:06:36 +010055 case DAVINCI_SD_OR_MMC_BOOT:
56 case DAVINCI_MMC_ONLY_BOOT:
57 return BOOT_DEVICE_MMC1;
58#endif
59
60#ifdef CONFIG_SPL_SPI_FLASH_SUPPORT
61 case DAVINCI_SPI0_FLASH_BOOT:
62 case DAVINCI_SPI1_FLASH_BOOT:
63 return BOOT_DEVICE_SPI;
Lad, Prabhakar8dc6df82012-06-24 21:35:20 +000064#endif
Fabien Parent9efa10f2017-01-09 11:06:36 +010065
66 default:
67 puts("Unknown boot device\n");
68 hang();
69 }
Heiko Schocher565a09c2011-11-01 20:00:29 +000070}