// SPDX-License-Identifier: GPL-2.0+ /* * K+P iMX6Q KP_IMX6Q_TPC board configuration * * Copyright (C) 2018 Lukasz Majewski */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include DECLARE_GLOBAL_DATA_PTR; int dram_init(void) { gd->ram_size = imx_ddr_size(); return 0; } /* * Do not overwrite the console * Use always serial for U-Boot console */ int overwrite_console(void) { return 1; } #ifdef CONFIG_FEC_MXC static int setup_fec_clock(void) { struct iomuxc *iomuxc_regs = (struct iomuxc *)IOMUXC_BASE_ADDR; /* set gpr1[21] to select anatop clock */ clrsetbits_le32(&iomuxc_regs->gpr[1], IOMUXC_GPR1_ENET_CLK_SEL_MASK, IOMUXC_GPR1_ENET_CLK_SEL_MASK); return enable_fec_anatop_clock(0, ENET_50MHZ); } static int ar8031_phy_fixup(struct phy_device *phydev) { unsigned short val; /* To enable AR8031 output a 125MHz clk from CLK_25M */ phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x7); phy_write(phydev, MDIO_DEVAD_NONE, 0xe, 0x8016); phy_write(phydev, MDIO_DEVAD_NONE, 0xd, 0x4007); val = phy_read(phydev, MDIO_DEVAD_NONE, 0xe); val &= 0xffe3; val |= 0x18; phy_write(phydev, MDIO_DEVAD_NONE, 0xe, val); /* introduce tx clock delay */ phy_write(phydev, MDIO_DEVAD_NONE, 0x1d, 0x5); val = phy_read(phydev, MDIO_DEVAD_NONE, 0x1e); val |= 0x0100; phy_write(phydev, MDIO_DEVAD_NONE, 0x1e, val); return 0; } int board_phy_config(struct phy_device *phydev) { ar8031_phy_fixup(phydev); if (phydev->drv->config) phydev->drv->config(phydev); return 0; } #endif #ifdef CONFIG_USB_EHCI_MX6 static void setup_usb(void) { /* * Set daisy chain for otg_pin_id on MX6Q. * For MX6DL, this bit is reserved. */ imx_iomux_set_gpr_register(1, 13, 1, 0); } #endif int board_early_init_f(void) { #ifdef CONFIG_USB_EHCI_MX6 setup_usb(); #endif #ifdef CONFIG_FEC_MXC setup_fec_clock(); #endif return 0; } int board_init(void) { struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR; /* address of boot parameters */ gd->bd->bi_boot_params = PHYS_SDRAM + 0x100; /* Enable eim_slow clocks */ setbits_le32(&mxc_ccm->CCGR6, 0x1 << MXC_CCM_CCGR6_EMI_SLOW_OFFSET); return 0; } #ifdef CONFIG_CMD_BMODE static const struct boot_mode board_boot_modes[] = { /* 4 bit bus width */ {"sd2", MAKE_CFGVAL(0x40, 0x28, 0x00, 0x00)}, /* 8 bit bus width */ {"emmc", MAKE_CFGVAL(0x60, 0x58, 0x00, 0x00)}, {NULL, 0}, }; #endif int board_late_init(void) { #ifdef CONFIG_CMD_BMODE add_board_boot_modes(board_boot_modes); #endif env_set("boardname", "kp-tpc"); env_set("boardsoc", "imx6q"); return 0; } int checkboard(void) { puts("Board: K+P KP_IMX6Q_TPC i.MX6Q\n"); return 0; }