-
Notifications
You must be signed in to change notification settings - Fork 518
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #308 from leon-anavi/master-olimex-imx8mp-lf-6.6.2…
…3-2.0.0 u-boot-imx_%.bbappend: Olimex iMX8MP-SOM-EVB-IND
- Loading branch information
Showing
1 changed file
with
41 additions
and
76 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
From f3f832527e0c52c9b46c19aae8efc48a48d90e9f Mon Sep 17 00:00:00 2001 | ||
From ed9f9b59980ead09a01ba472476f148ac8dbc561 Mon Sep 17 00:00:00 2001 | ||
From: Leon Anavi <[email protected]> | ||
Date: Wed, 10 Jul 2024 07:24:57 +0000 | ||
Date: Thu, 7 Nov 2024 11:39:12 +0000 | ||
Subject: [PATCH] imx: add Olimex iMX8MP-SOM-4GB-IND | ||
|
||
Add basic Olimex iMX8MP-SOM-4GB-IND and iMX8MP-SOM-EVB-IND board | ||
|
@@ -17,13 +17,13 @@ Signed-off-by: Leon Anavi <[email protected]> | |
board/freescale/imx8mp_olimex/MAINTAINERS | 6 + | ||
board/freescale/imx8mp_olimex/Makefile | 16 + | ||
board/freescale/imx8mp_olimex/ddr4_timing.c | 1312 +++++++++++ | ||
board/freescale/imx8mp_olimex/imx8mp_olimex.c | 512 +++++ | ||
board/freescale/imx8mp_olimex/imx8mp_olimex.c | 472 ++++ | ||
board/freescale/imx8mp_olimex/lpddr4_timing.c | 2048 +++++++++++++++++ | ||
.../imx8mp_olimex/lpddr4_timing_ndm.c | 1853 +++++++++++++++ | ||
board/freescale/imx8mp_olimex/spl.c | 179 ++ | ||
configs/imx8mp_olimex_defconfig | 211 ++ | ||
board/freescale/imx8mp_olimex/spl.c | 183 ++ | ||
configs/imx8mp_olimex_defconfig | 212 ++ | ||
include/configs/imx8mp_olimex.h | 184 ++ | ||
13 files changed, 7289 insertions(+) | ||
13 files changed, 7254 insertions(+) | ||
create mode 100644 arch/arm/dts/imx8mp-olimex.dts | ||
create mode 100644 board/freescale/imx8mp_olimex/Kconfig | ||
create mode 100644 board/freescale/imx8mp_olimex/MAINTAINERS | ||
|
@@ -37,11 +37,11 @@ Signed-off-by: Leon Anavi <[email protected]> | |
create mode 100644 include/configs/imx8mp_olimex.h | ||
|
||
diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile | ||
index ceec5c074a4..720537d4f9a 100644 | ||
index e494d16ffce..69dd59f1714 100644 | ||
--- a/arch/arm/dts/Makefile | ||
+++ b/arch/arm/dts/Makefile | ||
@@ -1074,6 +1074,7 @@ dtb-$(CONFIG_ARCH_IMX8M) += \ | ||
imx8mp-dhcom-pdk2.dtb \ | ||
@@ -1168,6 +1168,7 @@ dtb-$(CONFIG_ARCH_IMX8M) += \ | ||
imx8mp-dhcom-pdk3-overlay-rev100.dtbo \ | ||
imx8mp-ddr4-evk.dtb \ | ||
imx8mp-evk.dtb \ | ||
+ imx8mp-olimex.dtb \ | ||
|
@@ -996,10 +996,10 @@ index 00000000000..d9990e36d19 | |
+ }; | ||
+}; | ||
diff --git a/arch/arm/mach-imx/imx8m/Kconfig b/arch/arm/mach-imx/imx8m/Kconfig | ||
index b124027910d..bf9746155c6 100644 | ||
index 473cfa8e5e3..5afd90bac71 100644 | ||
--- a/arch/arm/mach-imx/imx8m/Kconfig | ||
+++ b/arch/arm/mach-imx/imx8m/Kconfig | ||
@@ -448,6 +448,16 @@ config TARGET_LIBREM5 | ||
@@ -446,6 +446,16 @@ config TARGET_LIBREM5 | ||
select SUPPORT_SPL | ||
select IMX8M_LPDDR4 | ||
|
||
|
@@ -1016,10 +1016,10 @@ index b124027910d..bf9746155c6 100644 | |
endchoice | ||
|
||
source "board/advantech/imx8mp_rsb3720a1/Kconfig" | ||
@@ -481,5 +491,6 @@ source "board/technexion/pico-imx8mq/Kconfig" | ||
source "board/variscite/imx8mn_var_som/Kconfig" | ||
@@ -482,5 +492,6 @@ source "board/variscite/imx8mn_var_som/Kconfig" | ||
source "board/toradex/verdin-imx8mm/Kconfig" | ||
source "board/toradex/verdin-imx8mp/Kconfig" | ||
source "board/voxelbotics/navqp/Kconfig" | ||
+source "board/freescale/imx8mp_olimex/Kconfig" | ||
|
||
endif | ||
|
@@ -2398,15 +2398,14 @@ index 00000000000..4951949ed3c | |
+#endif | ||
diff --git a/board/freescale/imx8mp_olimex/imx8mp_olimex.c b/board/freescale/imx8mp_olimex/imx8mp_olimex.c | ||
new file mode 100644 | ||
index 00000000000..235e16cfd0f | ||
index 00000000000..cc593d3da4b | ||
--- /dev/null | ||
+++ b/board/freescale/imx8mp_olimex/imx8mp_olimex.c | ||
@@ -0,0 +1,512 @@ | ||
@@ -0,0 +1,472 @@ | ||
+// SPDX-License-Identifier: GPL-2.0+ | ||
+/* | ||
+ */ | ||
+ | ||
+#include <common.h> | ||
+#include <efi_loader.h> | ||
+#include <env.h> | ||
+#include <errno.h> | ||
|
@@ -2464,10 +2463,10 @@ index 00000000000..235e16cfd0f | |
+ | ||
+struct efi_capsule_update_info update_info = { | ||
+ .dfu_string = "mmc 2=flash-bin raw 0 0x2000 mmcpart 1", | ||
+ .num_images = ARRAY_SIZE(fw_images), | ||
+ .images = fw_images, | ||
+}; | ||
+ | ||
+u8 num_image_type_guids = ARRAY_SIZE(fw_images); | ||
+#endif /* EFI_HAVE_CAPSULE_SUPPORT */ | ||
+ | ||
+int board_early_init_f(void) | ||
|
@@ -2708,9 +2707,9 @@ index 00000000000..235e16cfd0f | |
+ .power_down_scale = 2, | ||
+}; | ||
+ | ||
+int usb_gadget_handle_interrupts(int index) | ||
+int dm_usb_gadget_handle_interrupts(struct udevice *dev) | ||
+{ | ||
+ dwc3_uboot_handle_interrupt(index); | ||
+ dwc3_uboot_handle_interrupt(dev); | ||
+ return 0; | ||
+} | ||
+ | ||
|
@@ -2817,51 +2816,12 @@ index 00000000000..235e16cfd0f | |
+#endif | ||
+#endif | ||
+ | ||
+static void setup_fec(void) | ||
+{ | ||
+ struct iomuxc_gpr_base_regs *gpr = | ||
+ (struct iomuxc_gpr_base_regs *)IOMUXC_GPR_BASE_ADDR; | ||
+ | ||
+ /* Enable RGMII TX clk output */ | ||
+ setbits_le32(&gpr->gpr[1], BIT(22)); | ||
+} | ||
+ | ||
+static int setup_eqos(void) | ||
+{ | ||
+ struct iomuxc_gpr_base_regs *gpr = | ||
+ (struct iomuxc_gpr_base_regs *)IOMUXC_GPR_BASE_ADDR; | ||
+ | ||
+ /* set INTF as RGMII, enable RGMII TXC clock */ | ||
+ clrsetbits_le32(&gpr->gpr[1], | ||
+ IOMUXC_GPR_GPR1_GPR_ENET_QOS_INTF_SEL_MASK, BIT(16)); | ||
+ setbits_le32(&gpr->gpr[1], BIT(19) | BIT(21)); | ||
+ | ||
+ return set_clk_eqos(ENET_125MHZ); | ||
+} | ||
+ | ||
+#if CONFIG_IS_ENABLED(NET) | ||
+int board_phy_config(struct phy_device *phydev) | ||
+{ | ||
+ if (phydev->drv->config) | ||
+ phydev->drv->config(phydev); | ||
+ return 0; | ||
+} | ||
+#endif | ||
+ | ||
+int board_init(void) | ||
+{ | ||
+#ifdef CONFIG_USB_TCPC | ||
+ setup_typec(); | ||
+#endif | ||
+ | ||
+ if (IS_ENABLED(CONFIG_FEC_MXC)) { | ||
+ setup_fec(); | ||
+ } | ||
+ | ||
+ if (IS_ENABLED(CONFIG_DWC_ETH_QOS)) { | ||
+ setup_eqos(); | ||
+ } | ||
+ | ||
+#ifdef CONFIG_NAND_MXS | ||
+ setup_gpmi_nand(); | ||
+#endif | ||
|
@@ -2894,7 +2854,7 @@ index 00000000000..235e16cfd0f | |
+ | ||
+#ifdef CONFIG_SPL_MMC | ||
+#define UBOOT_RAW_SECTOR_OFFSET 0x40 | ||
+unsigned long spl_mmc_get_uboot_raw_sector(struct mmc *mmc) | ||
+unsigned long spl_mmc_get_uboot_raw_sector(struct mmc *mmc, unsigned long raw_sect) | ||
+{ | ||
+ u32 boot_dev = spl_boot_device(); | ||
+ switch (boot_dev) { | ||
|
@@ -6829,10 +6789,10 @@ index 00000000000..4765618afde | |
+}; | ||
diff --git a/board/freescale/imx8mp_olimex/spl.c b/board/freescale/imx8mp_olimex/spl.c | ||
new file mode 100644 | ||
index 00000000000..362751e23a3 | ||
index 00000000000..b7b21f0b490 | ||
--- /dev/null | ||
+++ b/board/freescale/imx8mp_olimex/spl.c | ||
@@ -0,0 +1,179 @@ | ||
@@ -0,0 +1,183 @@ | ||
+// SPDX-License-Identifier: GPL-2.0-or-later | ||
+/* | ||
+ * Copyright 2018-2019, 2021 NXP | ||
|
@@ -6862,6 +6822,7 @@ index 00000000000..362751e23a3 | |
+#include <fsl_esdhc_imx.h> | ||
+#include <mmc.h> | ||
+#include <asm/arch/ddr.h> | ||
+#include <asm/sections.h> | ||
+ | ||
+DECLARE_GLOBAL_DATA_PTR; | ||
+ | ||
|
@@ -6923,33 +6884,36 @@ index 00000000000..362751e23a3 | |
+ | ||
+ ret = pmic_get("pmic@25", &dev); | ||
+ if (ret == -ENODEV) { | ||
+ puts("No pca9450@25\n"); | ||
+ puts("No pmic@25\n"); | ||
+ return 0; | ||
+ } | ||
+ if (ret != 0) | ||
+ if (ret < 0) | ||
+ return ret; | ||
+ | ||
+ /* BUCKxOUT_DVS0/1 control BUCK123 output */ | ||
+ pmic_reg_write(dev, PCA9450_BUCK123_DVS, 0x29); | ||
+ | ||
+#ifdef CONFIG_IMX8M_LPDDR4 | ||
+ /* | ||
+ * increase VDD_SOC to typical value 0.95V before first | ||
+ * DRAM access, set DVS1 to 0.85v for suspend. | ||
+ * Increase VDD_SOC to typical value 0.95V before first | ||
+ * DRAM access, set DVS1 to 0.85V for suspend. | ||
+ * Enable DVS control through PMIC_STBY_REQ and | ||
+ * set B1_ENMODE=1 (ON by PMIC_ON_REQ=H) | ||
+ */ | ||
+#ifdef CONFIG_IMX8M_VDD_SOC_850MV | ||
+ /* set DVS0 to 0.85v for special case*/ | ||
+ pmic_reg_write(dev, PCA9450_BUCK1OUT_DVS0, 0x14); | ||
+#else | ||
+ pmic_reg_write(dev, PCA9450_BUCK1OUT_DVS0, 0x1C); | ||
+#endif | ||
+ if (CONFIG_IS_ENABLED(IMX8M_VDD_SOC_850MV)) | ||
+ pmic_reg_write(dev, PCA9450_BUCK1OUT_DVS0, 0x14); | ||
+ else | ||
+ pmic_reg_write(dev, PCA9450_BUCK1OUT_DVS0, 0x1C); | ||
+ | ||
+ pmic_reg_write(dev, PCA9450_BUCK1OUT_DVS1, 0x14); | ||
+ pmic_reg_write(dev, PCA9450_BUCK1CTRL, 0x59); | ||
+ | ||
+ /* Kernel uses OD/OD freq for SOC */ | ||
+ /* To avoid timing risk from SOC to ARM,increase VDD_ARM to OD voltage 0.95v */ | ||
+ /* | ||
+ * Kernel uses OD/OD freq for SOC. | ||
+ * To avoid timing risk from SOC to ARM,increase VDD_ARM to OD | ||
+ * voltage 0.95V. | ||
+ */ | ||
+ | ||
+ pmic_reg_write(dev, PCA9450_BUCK2OUT_DVS0, 0x1C); | ||
+#elif defined(CONFIG_IMX8M_DDR4) | ||
+ /* DDR4 runs at 3200MTS, uses default ND 0.85v for VDD_SOC and VDD_ARM */ | ||
|
@@ -7014,10 +6978,10 @@ index 00000000000..362751e23a3 | |
+} | ||
diff --git a/configs/imx8mp_olimex_defconfig b/configs/imx8mp_olimex_defconfig | ||
new file mode 100644 | ||
index 00000000000..8f763537537 | ||
index 00000000000..dd297f9bb6d | ||
--- /dev/null | ||
+++ b/configs/imx8mp_olimex_defconfig | ||
@@ -0,0 +1,211 @@ | ||
@@ -0,0 +1,212 @@ | ||
+CONFIG_ARM=y | ||
+CONFIG_ARCH_IMX8M=y | ||
+CONFIG_TEXT_BASE=0x40200000 | ||
|
@@ -7222,6 +7186,7 @@ index 00000000000..8f763537537 | |
+CONFIG_EFI_VAR_BUF_SIZE=139264 | ||
+CONFIG_EFI_IGNORE_OSINDICATIONS=y | ||
+CONFIG_EFI_CAPSULE_AUTHENTICATE=y | ||
+CONFIG_EFI_CAPSULE_ESL_FILE="CRT.esl" | ||
+CONFIG_OPTEE=y | ||
+CONFIG_CMD_OPTEE_RPMB=y | ||
+CONFIG_EFI_MM_COMM_TEE=y | ||
|
@@ -7420,5 +7385,5 @@ index 00000000000..6941d3ede4c | |
+ | ||
+#endif | ||
-- | ||
2.45.2 | ||
2.47.0 | ||
|