// SPDX-License-Identifier: GPL-2.0+ // Copyright (C) 2021 Oleh Kravchenko <oleg@kaa.org.ua> #include <asm/arch-mx6/clock.h> #include <asm/arch/sys_proto.h> #include <asm/global_data.h> #include <asm/mach-imx/boot_mode.h> #include <common.h> #include <env.h> DECLARE_GLOBAL_DATA_PTR; int dram_init(void) { gd->ram_size = imx_ddr_size(); return 0; } int board_early_init_f(void) { return 0; } static int setup_fec_clock(void) { if (IS_ENABLED(CONFIG_FEC_MXC) && !IS_ENABLED(CONFIG_CLK_IMX6Q)) { struct iomuxc *const iomuxc_regs = (struct iomuxc *)IOMUXC_BASE_ADDR; int ret; /* * Use 50M anatop loopback REF_CLK1 for ENET1, * clear gpr1[13], set gpr1[17]. */ clrsetbits_le32(&iomuxc_regs->gpr[1], IOMUX_GPR1_FEC1_MASK, IOMUX_GPR1_FEC1_CLOCK_MUX1_SEL_MASK); ret = enable_fec_anatop_clock(0, ENET_50MHZ); if (ret) return ret; if (!IS_ENABLED(CONFIG_EV_IMX280_NANO_X_MB)) { /* * Use 50M anatop loopback REF_CLK2 for ENET2, * clear gpr1[14], set gpr1[18]. */ clrsetbits_le32(&iomuxc_regs->gpr[1], IOMUX_GPR1_FEC2_MASK, IOMUX_GPR1_FEC2_CLOCK_MUX1_SEL_MASK); ret = enable_fec_anatop_clock(1, ENET_50MHZ); if (ret) return ret; } enable_enet_clk(1); } return 0; } int board_init(void) { /* Address of boot parameters */ gd->bd->bi_boot_params = PHYS_SDRAM + 0x100; return setup_fec_clock(); } int board_late_init(void) { if (IS_ENABLED(CONFIG_CMD_BMODE)) add_board_boot_modes(NULL); if (IS_ENABLED(CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG)) { const char *model; model = fdt_getprop(gd->fdt_blob, 0, "model", NULL); if (model) env_set("board_name", model); } if (is_boot_from_usb()) { env_set("bootcmd", "run bootcmd_mfg"); env_set("bootdelay", "0"); } return 0; }