blob: 462c43ceebc75b864d2001c10dd01e77846d58d4 [file] [log] [blame]
Gaurav Jaincb5d0412022-03-24 11:50:33 +05301// SPDX-License-Identifier: GPL-2.0-or-later
Peng Fan018e3fd2018-12-21 06:21:34 +00002/*
Gaurav Jaincb5d0412022-03-24 11:50:33 +05303 * Copyright 2018, 2021 NXP
Peng Fan018e3fd2018-12-21 06:21:34 +00004 *
Peng Fan018e3fd2018-12-21 06:21:34 +00005 */
6
7#include <common.h>
8#include <dm.h>
Simon Glass4d72caa2020-05-10 11:40:01 -06009#include <image.h>
Simon Glass691d7192020-05-10 11:40:02 -060010#include <init.h>
Simon Glassf7ae49f2020-05-10 11:40:05 -060011#include <log.h>
Peng Fan018e3fd2018-12-21 06:21:34 +000012#include <spl.h>
Simon Glass401d1c42020-10-30 21:38:53 -060013#include <asm/global_data.h>
Peng Fan018e3fd2018-12-21 06:21:34 +000014#include <dm/uclass.h>
15#include <dm/device.h>
16#include <dm/uclass-internal.h>
17#include <dm/device-internal.h>
18#include <dm/lists.h>
Fabio Estevam168fff22020-04-15 15:01:34 -030019#include <asm/io.h>
20#include <asm/gpio.h>
Peng Fan99ac6c72023-04-28 12:08:09 +080021#include <firmware/imx/sci/sci.h>
Fabio Estevam168fff22020-04-15 15:01:34 -030022#include <asm/arch/imx8-pins.h>
23#include <asm/arch/iomux.h>
Peng Fan231401d2020-05-05 20:28:40 +080024#include <asm/arch/sys_proto.h>
Shiji Yang506df9d2023-08-03 09:47:16 +080025#include <asm/sections.h>
Peng Fan018e3fd2018-12-21 06:21:34 +000026
27DECLARE_GLOBAL_DATA_PTR;
28
Fabio Estevam168fff22020-04-15 15:01:34 -030029#define GPIO_PAD_CTRL ((SC_PAD_CONFIG_NORMAL << PADRING_CONFIG_SHIFT) | \
30 (SC_PAD_ISO_OFF << PADRING_LPCONFIG_SHIFT) | \
31 (SC_PAD_28FDSOI_DSE_DV_HIGH << PADRING_DSE_SHIFT) | \
32 (SC_PAD_28FDSOI_PS_PU << PADRING_PULL_SHIFT))
33
34#define USDHC2_SD_PWR IMX_GPIO_NR(4, 19)
35static iomux_cfg_t usdhc2_sd_pwr[] = {
36 SC_P_USDHC1_RESET_B | MUX_PAD_CTRL(GPIO_PAD_CTRL),
37};
38
Peng Fan018e3fd2018-12-21 06:21:34 +000039void spl_board_init(void)
40{
41 struct udevice *dev;
Peng Fan018e3fd2018-12-21 06:21:34 +000042
Gaurav Jaincb5d0412022-03-24 11:50:33 +053043 uclass_get_device_by_driver(UCLASS_MISC, DM_DRIVER_GET(imx8_scu), &dev);
44
Peng Fan018e3fd2018-12-21 06:21:34 +000045 uclass_find_first_device(UCLASS_MISC, &dev);
46
47 for (; dev; uclass_find_next_device(&dev)) {
48 if (device_probe(dev))
49 continue;
50 }
51
Peng Fan018e3fd2018-12-21 06:21:34 +000052 arch_cpu_init();
53
54 board_early_init_f();
55
56 timer_init();
57
Fabio Estevam168fff22020-04-15 15:01:34 -030058 imx8_iomux_setup_multiple_pads(usdhc2_sd_pwr, ARRAY_SIZE(usdhc2_sd_pwr));
59 gpio_direction_output(USDHC2_SD_PWR, 0);
60
Peng Fan018e3fd2018-12-21 06:21:34 +000061 preloader_console_init();
62
63 puts("Normal Boot\n");
64}
65
Peng Fan231401d2020-05-05 20:28:40 +080066void spl_board_prepare_for_boot(void)
67{
Peng Faned5b2532020-05-05 20:28:43 +080068 imx8_power_off_pd_devices(NULL, 0);
Peng Fan231401d2020-05-05 20:28:40 +080069}
70
Peng Fan018e3fd2018-12-21 06:21:34 +000071#ifdef CONFIG_SPL_LOAD_FIT
72int board_fit_config_name_match(const char *name)
73{
74 /* Just empty function now - can't decide what to choose */
75 debug("%s: %s\n", __func__, name);
76
77 return 0;
78}
79#endif
80
81void board_init_f(ulong dummy)
82{
83 /* Clear global data */
84 memset((void *)gd, 0, sizeof(gd_t));
85
86 /* Clear the BSS. */
87 memset(__bss_start, 0, __bss_end - __bss_start);
88
89 board_init_r(NULL, 0);
90}