// SPDX-License-Identifier: GPL-2.0+ /* * Copyright 2022 Marek Vasut */ #include #include #include #include #include #include #include #include #include #include "../common/common.h" DECLARE_GLOBAL_DATA_PTR; int board_init(void) { return 0; } int board_late_init(void) { struct udevice *dev; int ret; dmo_setup_boot_device(); dmo_setup_mac_address(); ret = uclass_get_device_by_name(UCLASS_MISC, "usb-hub@2c", &dev); if (ret) printf("Error bringing up USB hub (%d)\n", ret); return 0; } int fdtdec_board_setup(const void *fdt_blob) { const void __iomem *mux = (void __iomem *)IOMUXC_BASE_ADDR + FIELD_GET(MUX_CTRL_OFS_MASK, IMX8MM_PAD_ENET_MDC_GPIO1_IO16); const char *phy_compat = "ethernet-phy-ieee802.3-c22"; bool is_bcmphy; int phy_node; int ret; /* Do nothing if not i.MX8MM eDM SBC */ ret = fdt_node_check_compatible(fdt_blob, 0, "dmo,imx8mm-data-modul-edm-sbc"); if (ret) return 0; /* * If GPIO1_16 RGMII_MDC is HIGH, then R530 is populated. * R530 is populated only on boards with AR8031 PHY. * * If GPIO1_16 RGMII_MDC is LOW, then the in-SoM pull down * is the dominant pull resistor. This is the case on boards * with BCM54213PE PHY. */ setbits_le32(mux, IOMUX_CONFIG_SION); is_bcmphy = !(readl(GPIO1_BASE_ADDR) & BIT(16)); clrbits_le32(mux, IOMUX_CONFIG_SION); phy_node = fdt_node_offset_by_compatible(fdt_blob, -1, phy_compat); if (phy_node < 0) return 0; /* * Update PHY MDC address in control DT based on the populated * PHY type. AR8031 is at address 0, BCM54213PE is at address 1. */ fdt_setprop_inplace_u32((void *)fdt_blob, phy_node, "reg", is_bcmphy ? 1 : 0); return 0; }