// SPDX-License-Identifier: GPL-2.0+ /* * Copyright 2021 Collabora Ltd. * */ #include #include #include #include #include #include #include #include #include #include #include int spl_board_boot_device(enum boot_device boot_dev_spl) { return BOOT_DEVICE_BOOTROM; } void spl_dram_init(void) { ddr_init(&dram_timing); } void spl_board_init(void) { struct udevice *dev; int ret; debug("Normal Boot\n"); ret = uclass_get_device_by_name(UCLASS_CLK, "clock-controller@30380000", &dev); if (ret < 0) puts("Failed to find clock node. Check device tree\n"); } int board_early_init_f(void) { init_uart_clk(3); return 0; } void board_init_f(ulong dummy) { int ret; /* Clear the BSS. */ memset(__bss_start, 0, __bss_end - __bss_start); arch_cpu_init(); board_early_init_f(); timer_init(); ret = spl_init(); if (ret) { debug("spl_init() failed: %d\n", ret); hang(); } preloader_console_init(); /* DDR initialization */ spl_dram_init(); board_init_r(NULL, 0); }