Hi Lukasz, > Subject: Re: [U-Boot] [PATCH 1/4] imx: add module fuse support > > Hi Peng, > > > Hi Lukasz, > > > > > Subject: Re: [U-Boot] [PATCH 1/4] imx: add module fuse support > > > > > > Hi Peng, > > > > > > > There are different parts from one SoC. Take i.MX6ULL for example, > > > > some part might not have ENET, some might have; some might not > > > > have USB, some might have. The information could be got from > > > > OCOTP, to make one image support the different parts, we need > > > > runtime disable linux kernel dts node and uboot driver probe if > > > > the corresponding module not exists in the part. > > > > > > If I understand correctly the concept is interesting to make the > > > final binary smaller. > > > > No. This is to use one image to support multiple parts of a same kind > > SoC. So this patch will make the uboot image size larger. > > > > As described in commit log, some i.MX6UL parts not have enet, some > > have Enet, > > Is there any markings on the SoC? (like MX6ULXXXXXX) which indicates which > SoC has enet and which doesn't have one?
I do not have that marketing information. We just have the information that to use fuse to indicate whether the module is there. Regards, Peng. > > > so we need find a method to make the same image could work on the two > > parts, that is what this patch does. > > Ok. Thanks for explanation. > > > > > Thanks, > > Peng. > > > > > > > > > > > > > Signed-off-by: Peng Fan <peng....@nxp.com> > > > > --- > > > > arch/arm/include/asm/mach-imx/module_fuse.h | 127 +++++++++++ > > > > arch/arm/include/asm/mach-imx/sys_proto.h | 1 + > > > > arch/arm/mach-imx/Kconfig | 7 + > > > > arch/arm/mach-imx/mx6/Makefile | 1 + > > > > arch/arm/mach-imx/mx6/module_fuse.c | 322 > > > > ++++++++++++++++++++++++++++ 5 files changed, 458 insertions(+) > > > > create mode 100644 > arch/arm/include/asm/mach-imx/module_fuse.h > > > > create mode 100644 arch/arm/mach-imx/mx6/module_fuse.c > > > > > > > > diff --git a/arch/arm/include/asm/mach-imx/module_fuse.h > > > > b/arch/arm/include/asm/mach-imx/module_fuse.h new file mode > 100644 > > > > index 0000000000..6b93f0402e > > > > --- /dev/null > > > > +++ b/arch/arm/include/asm/mach-imx/module_fuse.h > > > > @@ -0,0 +1,127 @@ > > > > +/* SPDX-License-Identifier: GPL-2.0+ */ > > > > +/* > > > > + * Copyright 2019 NXP > > > > + */ > > > > + > > > > +#ifndef __MODULE_FUSE_H__ > > > > +#define __MODULE_FUSE_H__ > > > > + > > > > +enum fuse_module_type { > > > > + MODULE_TSC, > > > > + MODULE_ADC1, > > > > + MODULE_ADC2, > > > > + MODULE_SIM1, > > > > + MODULE_SIM2, > > > > + MODULE_FLEXCAN1, > > > > + MODULE_FLEXCAN2, > > > > + MODULE_SPDIF, > > > > + MODULE_EIM, > > > > + MODULE_SD1, > > > > + MODULE_SD2, > > > > + MODULE_SD3, > > > > + MODULE_SD4, > > > > + MODULE_QSPI1, > > > > + MODULE_QSPI2, > > > > + MODULE_GPMI, > > > > + MODULE_APBHDMA, > > > > + MODULE_LCDIF, > > > > + MODULE_PXP, > > > > + MODULE_CSI, > > > > + MODULE_ENET1, > > > > + MODULE_ENET2, > > > > + MODULE_CAAM, > > > > + MODULE_USB_OTG1, > > > > + MODULE_USB_OTG2, > > > > + MODULE_SAI2, > > > > + MODULE_SAI3, > > > > + MODULE_BEE, > > > > + MODULE_UART1, > > > > + MODULE_UART2, > > > > + MODULE_UART3, > > > > + MODULE_UART4, > > > > + MODULE_UART5, > > > > + MODULE_UART6, > > > > + MODULE_UART7, > > > > + MODULE_UART8, > > > > + MODULE_PWM5, > > > > + MODULE_PWM6, > > > > + MODULE_PWM7, > > > > + MODULE_PWM8, > > > > + MODULE_ECSPI1, > > > > + MODULE_ECSPI2, > > > > + MODULE_ECSPI3, > > > > + MODULE_ECSPI4, > > > > + MODULE_ECSPI5, > > > > + MODULE_I2C1, > > > > + MODULE_I2C2, > > > > + MODULE_I2C3, > > > > + MODULE_I2C4, > > > > + MODULE_GPT1, > > > > + MODULE_GPT2, > > > > + MODULE_EPIT1, > > > > + MODULE_EPIT2, > > > > + MODULE_EPDC, > > > > + MODULE_ESAI, > > > > + MODULE_DCP, > > > > + MODULE_DCP_CRYPTO, > > > > +}; > > > > + > > > > +struct fuse_entry_desc { > > > > + enum fuse_module_type module; > > > > + const char *node_path; > > > > + u32 fuse_word_offset; > > > > + u32 fuse_bit_offset; > > > > + u32 status; > > > > +}; > > > > + > > > > +#if !IS_ENABLED(CONFIG_IMX_MODULE_FUSE) > > > > +static inline u32 check_module_fused(enum fuse_module_type > > > > module) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 esdhc_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 ecspi_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 uart_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 usb_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 qspi_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 i2c_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > + > > > > +static inline u32 enet_fused(u32 base_addr) { > > > > + return 0; > > > > +}; > > > > +#else > > > > +u32 check_module_fused(enum fuse_module_type module); > > > > +u32 esdhc_fused(u32 base_addr); > > > > +u32 ecspi_fused(u32 base_addr); > > > > +u32 uart_fused(u32 base_addr); > > > > +u32 usb_fused(u32 base_addr); > > > > +u32 qspi_fused(u32 base_addr); > > > > +u32 i2c_fused(u32 base_addr); > > > > +u32 enet_fused(u32 base_addr); > > > > +#endif > > > > +#endif /* __MODULE_FUSE_H__ */ > > > > diff --git a/arch/arm/include/asm/mach-imx/sys_proto.h > > > > b/arch/arm/include/asm/mach-imx/sys_proto.h index > > > > 79cb4e6dc9..14b016ee99 100644 --- > > > > a/arch/arm/include/asm/mach-imx/sys_proto.h +++ > > > > b/arch/arm/include/asm/mach-imx/sys_proto.h @@ -9,6 +9,7 @@ > > > > > > > > #include <asm/io.h> > > > > #include <asm/mach-imx/regs-common.h> > > > > +#include <asm/mach-imx/module_fuse.h> > > > > #include <common.h> > > > > #include "../arch-imx/cpu.h" > > > > > > > > diff --git a/arch/arm/mach-imx/Kconfig b/arch/arm/mach-imx/Kconfig > > > > index d3942f6b3f..b8625962a6 100644 > > > > --- a/arch/arm/mach-imx/Kconfig > > > > +++ b/arch/arm/mach-imx/Kconfig > > > > @@ -27,6 +27,13 @@ config IMX_BOOTAUX > > > > help > > > > bootaux [addr] to boot auxiliary core. > > > > > > > > +config IMX_MODULE_FUSE > > > > + bool "i.MX Module Fuse" > > > > + depends on ARCH_MX6 > > > > + help > > > > + i.MX module fuse to runtime disable some driver, > > > > including > > > > + Linux OS device node. > > > > + > > > > config USE_IMXIMG_PLUGIN > > > > bool "Use imximage plugin code" > > > > depends on ARCH_MX7 || ARCH_MX6 || ARCH_MX7ULP diff --git > > > > a/arch/arm/mach-imx/mx6/Makefile > b/arch/arm/mach-imx/mx6/Makefile > > > > index 81e2913d14..7ea8f91e4f 100644 > > > > --- a/arch/arm/mach-imx/mx6/Makefile > > > > +++ b/arch/arm/mach-imx/mx6/Makefile > > > > @@ -6,6 +6,7 @@ > > > > # (C) Copyright 2011 Freescale Semiconductor, Inc. > > > > > > > > obj-y := soc.o clock.o > > > > +obj-$(CONFIG_IMX_MODULE_FUSE) += module_fuse.o > > > > obj-$(CONFIG_SPL_BUILD) += ddr.o > > > > obj-$(CONFIG_MP) += mp.o > > > > obj-$(CONFIG_MX6UL_LITESOM) += litesom.o diff --git > > > > a/arch/arm/mach-imx/mx6/module_fuse.c > > > > b/arch/arm/mach-imx/mx6/module_fuse.c new file mode 100644 index > > > > 0000000000..417264b15c > > > > --- /dev/null > > > > +++ b/arch/arm/mach-imx/mx6/module_fuse.c > > > > @@ -0,0 +1,322 @@ > > > > +// SPDX-License-Identifier: GPL-2.0+ > > > > +/* > > > > + * Copyright 2019 NXP > > > > + */ > > > > + > > > > +#include <common.h> > > > > +#include <fdt_support.h> > > > > +#include <asm/io.h> > > > > +#include <asm/arch/sys_proto.h> > > > > +#include <asm/arch/imx-regs.h> > > > > +#include <asm/mach-imx/module_fuse.h> #include <linux/errno.h> > > > > + > > > > +static struct fuse_entry_desc mx6_fuse_descs[] = { #if > > > > +defined(CONFIG_MX6ULL) > > > > + {MODULE_TSC, "/soc/aips-bus@2000000/tsc@2040000", 0x430, > > > > 22}, > > > > + {MODULE_ADC2, "/soc/aips-bus@2100000/adc@219c000", 0x430, > > > > 23}, > > > > + {MODULE_EPDC, "/soc/aips-bus@2200000/epdc@228c000", > > > > 0x430, 24}, > > > > + {MODULE_ESAI, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/esai@2024000", 0x430, > 25}, > > > > + {MODULE_FLEXCAN1, "/soc/aips-bus@2000000/can@2090000", > > > > 0x430, 26}, > > > > + {MODULE_FLEXCAN2, "/soc/aips-bus@2000000/can@2094000", > > > > 0x430, 27}, > > > > + {MODULE_SPDIF, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/spdif@2004000", 0x440, > 2}, > > > > + {MODULE_EIM, "/soc/aips-bus@2100000/weim@21b8000", > > > > 0x440, 3}, > > > > + {MODULE_SD1, "/soc/aips-bus@2100000/usdhc@2190000", > > > > 0x440, 4}, > > > > + {MODULE_SD2, "/soc/aips-bus@2100000/usdhc@2194000", > > > > 0x440, 5}, > > > > + {MODULE_QSPI1, "/soc/aips-bus@2100000/qspi@21e0000", > > > > 0x440, 6}, > > > > + {MODULE_GPMI, "/soc/gpmi-nand@1806000", 0x440, 7}, > > > > + {MODULE_APBHDMA, "/soc/dma-apbh@1804000", 0x440, 7}, > > > > + {MODULE_LCDIF, "/soc/aips-bus@2100000/lcdif@21c8000", > > > > 0x440, 8}, > > > > + {MODULE_PXP, "/soc/aips-bus@2100000/pxp@21cc000", 0x440, > > > > 9}, > > > > + {MODULE_CSI, "/soc/aips-bus@2100000/csi@21c4000", 0x440, > > > > 10}, > > > > + {MODULE_ADC1, "/soc/aips-bus@2100000/adc@2198000", 0x440, > > > > 11}, > > > > + {MODULE_ENET1, "/soc/aips-bus@2100000/ethernet@2188000", > > > > 0x440, 12}, > > > > + {MODULE_ENET2, "/soc/aips-bus@2000000/ethernet@20b4000", > > > > 0x440, 13}, > > > > + {MODULE_DCP, "/soc/aips-bus@2200000/dcp@2280000", 0x440, > > > > 14}, > > > > + {MODULE_USB_OTG2, "/soc/aips-bus@2100000/usb@2184200", > > > > 0x440, 15}, > > > > + {MODULE_SAI2, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/sai@202c000", 0x440, > 24}, > > > > + {MODULE_SAI3, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/sai@2030000", 0x440, > 24}, > > > > + {MODULE_DCP_CRYPTO, > "/soc/aips-bus@2200000/dcp@2280000", > > > > 0x440, 25}, > > > > + {MODULE_UART5, "/soc/aips-bus@2100000/serial@21f4000", > > > > 0x440, 26}, > > > > + {MODULE_UART6, "/soc/aips-bus@2100000/serial@21fc000", > > > > 0x440, 26}, > > > > + {MODULE_UART7, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/serial@2018000", > 0x440, > > > 26}, > > > > + {MODULE_UART8, "/soc/aips-bus@2200000/serial@2288000", > > > > 0x440, 26}, > > > > + {MODULE_PWM5, "/soc/aips-bus@2000000/pwm@20f0000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM6, "/soc/aips-bus@2000000/pwm@20f4000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM7, "/soc/aips-bus@2000000/pwm@20f8000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM8, "/soc/aips-bus@2000000/pwm@20fc000", > 0x440, > > > > 27}, > > > > + {MODULE_ECSPI3, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/ecspi@2010000", 0x440, > > > 28}, > > > > + {MODULE_ECSPI4, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/ecspi@2014000", 0x440, > > > 28}, > > > > + {MODULE_I2C3, "/soc/aips-bus@2100000/i2c@21a8000", 0x440, > > > > 29}, > > > > + {MODULE_I2C4, "/soc/aips-bus@2100000/i2c@21f8000", 0x440, > > > > 29}, > > > > + {MODULE_GPT2, "/soc/aips-bus@2000000/gpt@20e8000", 0x440, > > > > 30}, > > > > + {MODULE_EPIT2, "/soc/aips-bus@2000000/epit@20d4000", > > > > 0x440, 31}, > > > > + /* Paths for older imx tree: */ > > > > + {MODULE_TSC, "/soc/aips-bus@02000000/tsc@02040000", > > > > 0x430, 22}, > > > > + {MODULE_ADC2, "/soc/aips-bus@02100000/adc@0219c000", > > > > 0x430, 23}, > > > > + {MODULE_EPDC, "/soc/aips-bus@02200000/epdc@0228c000", > > > > 0x430, 24}, > > > > + {MODULE_ESAI, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/esai@02024000", > 0x430, > > > 25}, > > > > + {MODULE_FLEXCAN1, "/soc/aips-bus@02000000/can@02090000", > > > > 0x430, 26}, > > > > + {MODULE_FLEXCAN2, "/soc/aips-bus@02000000/can@02094000", > > > > 0x430, 27}, > > > > + {MODULE_SPDIF, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/spdif@02004000", > > > > 0x440, > > > 2}, > > > > + {MODULE_EIM, "/soc/aips-bus@02100000/weim@021b8000", > > > > 0x440, 3}, > > > > + {MODULE_SD1, "/soc/aips-bus@02100000/usdhc@02190000", > > > > 0x440, 4}, > > > > + {MODULE_SD2, "/soc/aips-bus@02100000/usdhc@02194000", > > > > 0x440, 5}, > > > > + {MODULE_QSPI1, "/soc/aips-bus@02100000/qspi@021e0000", > > > > 0x440, 6}, > > > > + {MODULE_GPMI, "/soc/gpmi-nand@01806000", 0x440, 7}, > > > > + {MODULE_APBHDMA, "/soc/dma-apbh@01804000", 0x440, 7}, > > > > + {MODULE_LCDIF, "/soc/aips-bus@02100000/lcdif@021c8000", > > > > 0x440, 8}, > > > > + {MODULE_PXP, "/soc/aips-bus@02100000/pxp@021cc000", > > > > 0x440, 9}, > > > > + {MODULE_CSI, "/soc/aips-bus@02100000/csi@021c4000", > > > > 0x440, 10}, > > > > + {MODULE_ADC1, "/soc/aips-bus@02100000/adc@02198000", > > > > 0x440, 11}, > > > > + {MODULE_ENET1, > > > > "/soc/aips-bus@02100000/ethernet@02188000", 0x440, 12}, > > > > + {MODULE_ENET2, > > > > "/soc/aips-bus@02000000/ethernet@020b4000", 0x440, 13}, > > > > + {MODULE_DCP, "/soc/aips-bus@02200000/dcp@02280000", > > > > 0x440, 14}, > > > > + {MODULE_USB_OTG2, > "/soc/aips-bus@02100000/usb@02184200", > > > > 0x440, 15}, > > > > + {MODULE_SAI2, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/sai@0202c000", > 0x440, > > > 24}, > > > > + {MODULE_SAI3, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/sai@02030000", > 0x440, > > > 24}, > > > > + {MODULE_DCP_CRYPTO, > > > > "/soc/aips-bus@02200000/dcp@02280000", 0x440, 25}, > > > > + {MODULE_UART5, "/soc/aips-bus@02100000/serial@021f4000", > > > > 0x440, 26}, > > > > + {MODULE_UART6, "/soc/aips-bus@02100000/serial@021fc000", > > > > 0x440, 26}, > > > > + {MODULE_UART7, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/serial@02018000", > > > 0x440, > > > > 26}, > > > > + {MODULE_UART8, "/soc/aips-bus@02200000/serial@02288000", > > > > 0x440, 26}, > > > > + {MODULE_PWM5, "/soc/aips-bus@02000000/pwm@020f0000", > > > > 0x440, 27}, > > > > + {MODULE_PWM6, "/soc/aips-bus@02000000/pwm@020f4000", > > > > 0x440, 27}, > > > > + {MODULE_PWM7, "/soc/aips-bus@02000000/pwm@020f8000", > > > > 0x440, 27}, > > > > + {MODULE_PWM8, "/soc/aips-bus@02000000/pwm@020fc000", > > > > 0x440, 27}, > > > > + {MODULE_ECSPI3, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/ecspi@02010000", > > > > 0x440, > > > 28}, > > > > + {MODULE_ECSPI4, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/ecspi@02014000", > > > > 0x440, > > > 28}, > > > > + {MODULE_I2C3, "/soc/aips-bus@02100000/i2c@021a8000", > > > > 0x440, 29}, > > > > + {MODULE_I2C4, "/soc/aips-bus@02100000/i2c@021f8000", > > > > 0x440, 29}, > > > > + {MODULE_GPT2, "/soc/aips-bus@02000000/gpt@020e8000", > > > > 0x440, 30}, > > > > + {MODULE_EPIT2, "/soc/aips-bus@02000000/epit@020d4000", > > > > 0x440, 31}, +#elif defined(CONFIG_MX6UL) > > > > + {MODULE_TSC, "/soc/aips-bus@2000000/tsc@2040000", 0x430, > > > > 22}, > > > > + {MODULE_ADC2, "/soc/aips-bus@2100000/adc@219c000", 0x430, > > > > 23}, > > > > + {MODULE_SIM1, "/soc/aips-bus@2100000/sim@218c000", 0x430, > > > > 24}, > > > > + {MODULE_SIM2, "/soc/aips-bus@2100000/sim@21b4000", 0x430, > > > > 25}, > > > > + {MODULE_FLEXCAN1, "/soc/aips-bus@2000000/can@2090000", > > > > 0x430, 26}, > > > > + {MODULE_FLEXCAN2, "/soc/aips-bus@2000000/can@2094000", > > > > 0x430, 27}, > > > > + {MODULE_SPDIF, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/spdif@2004000", 0x440, > 2}, > > > > + {MODULE_EIM, "/soc/aips-bus@2100000/weim@21b8000", > > > > 0x440, 3}, > > > > + {MODULE_SD1, "/soc/aips-bus@2100000/usdhc@2190000", > > > > 0x440, 4}, > > > > + {MODULE_SD2, "/soc/aips-bus@2100000/usdhc@2194000", > > > > 0x440, 5}, > > > > + {MODULE_QSPI1, "/soc/aips-bus@2100000/qspi@21e0000", > > > > 0x440, 6}, > > > > + {MODULE_GPMI, "/soc/gpmi-nand@1806000", 0x440, 7}, > > > > + {MODULE_APBHDMA, "/soc/dma-apbh@1804000", 0x440, 7}, > > > > + {MODULE_LCDIF, "/soc/aips-bus@2100000/lcdif@21c8000", > > > > 0x440, 8}, > > > > + {MODULE_PXP, "/soc/aips-bus@2100000/pxp@21cc000", 0x440, > > > > 9}, > > > > + {MODULE_CSI, "/soc/aips-bus@2100000/csi@21c4000", 0x440, > > > > 10}, > > > > + {MODULE_ADC1, "/soc/aips-bus@2100000/adc@2198000", 0x440, > > > > 11}, > > > > + {MODULE_ENET1, "/soc/aips-bus@2100000/ethernet@2188000", > > > > 0x440, 12}, > > > > + {MODULE_ENET2, "/soc/aips-bus@2000000/ethernet@20b4000", > > > > 0x440, 13}, > > > > + {MODULE_CAAM, "/soc/aips-bus@2100000/caam@2140000", > > > > 0x440, 14}, > > > > + {MODULE_USB_OTG2, "/soc/aips-bus@2100000/usb@2184200", > > > > 0x440, 15}, > > > > + {MODULE_SAI2, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/sai@202c000", 0x440, > 24}, > > > > + {MODULE_SAI3, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/sai@2030000", 0x440, > 24}, > > > > + {MODULE_BEE, "/soc/aips-bus@2000000/bee@2044000", 0x440, > > > > 25}, > > > > + {MODULE_UART5, "/soc/aips-bus@2100000/serial@21f4000", > > > > 0x440, 26}, > > > > + {MODULE_UART6, "/soc/aips-bus@2100000/serial@21fc000", > > > > 0x440, 26}, > > > > + {MODULE_UART7, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/serial@2018000", > 0x440, > > > 26}, > > > > + {MODULE_UART8, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/serial@2024000", > 0x440, > > > 26}, > > > > + {MODULE_PWM5, "/soc/aips-bus@2000000/pwm@20f0000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM6, "/soc/aips-bus@2000000/pwm@20f4000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM7, "/soc/aips-bus@2000000/pwm@20f8000", > 0x440, > > > > 27}, > > > > + {MODULE_PWM8, "/soc/aips-bus@2000000/pwm@20fc000", > 0x440, > > > > 27}, > > > > + {MODULE_ECSPI3, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/ecspi@2010000", 0x440, > > > 28}, > > > > + {MODULE_ECSPI4, > > > > "/soc/aips-bus@2000000/spba-bus@2000000/ecspi@2014000", 0x440, > > > 28}, > > > > + {MODULE_I2C3, "/soc/aips-bus@2100000/i2c@21a8000", 0x440, > > > > 29}, > > > > + {MODULE_I2C4, "/soc/aips-bus@2100000/i2c@21f8000", 0x440, > > > > 29}, > > > > + {MODULE_GPT2, "/soc/aips-bus@2000000/gpt@20e8000", 0x440, > > > > 30}, > > > > + {MODULE_EPIT2, "/soc/aips-bus@2000000/epit@20d4000", > > > > 0x440, 31}, > > > > + /* Paths for older imx tree: */ > > > > + {MODULE_TSC, "/soc/aips-bus@02000000/tsc@02040000", > > > > 0x430, 22}, > > > > + {MODULE_ADC2, "/soc/aips-bus@02100000/adc@0219c000", > > > > 0x430, 23}, > > > > + {MODULE_SIM1, "/soc/aips-bus@02100000/sim@0218c000", > > > > 0x430, 24}, > > > > + {MODULE_SIM2, "/soc/aips-bus@02100000/sim@021b4000", > > > > 0x430, 25}, > > > > + {MODULE_FLEXCAN1, "/soc/aips-bus@02000000/can@02090000", > > > > 0x430, 26}, > > > > + {MODULE_FLEXCAN2, "/soc/aips-bus@02000000/can@02094000", > > > > 0x430, 27}, > > > > + {MODULE_SPDIF, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/spdif@02004000", > > > > 0x440, > > > 2}, > > > > + {MODULE_EIM, "/soc/aips-bus@02100000/weim@021b8000", > > > > 0x440, 3}, > > > > + {MODULE_SD1, "/soc/aips-bus@02100000/usdhc@02190000", > > > > 0x440, 4}, > > > > + {MODULE_SD2, "/soc/aips-bus@02100000/usdhc@02194000", > > > > 0x440, 5}, > > > > + {MODULE_QSPI1, "/soc/aips-bus@02100000/qspi@021e0000", > > > > 0x440, 6}, > > > > + {MODULE_GPMI, "/soc/gpmi-nand@01806000", 0x440, 7}, > > > > + {MODULE_APBHDMA, "/soc/dma-apbh@01804000", 0x440, 7}, > > > > + {MODULE_LCDIF, "/soc/aips-bus@02100000/lcdif@021c8000", > > > > 0x440, 8}, > > > > + {MODULE_PXP, "/soc/aips-bus@02100000/pxp@021cc000", > > > > 0x440, 9}, > > > > + {MODULE_CSI, "/soc/aips-bus@02100000/csi@021c4000", > > > > 0x440, 10}, > > > > + {MODULE_ADC1, "/soc/aips-bus@02100000/adc@02198000", > > > > 0x440, 11}, > > > > + {MODULE_ENET1, > > > > "/soc/aips-bus@02100000/ethernet@02188000", 0x440, 12}, > > > > + {MODULE_ENET2, > > > > "/soc/aips-bus@02000000/ethernet@020b4000", 0x440, 13}, > > > > + {MODULE_CAAM, "/soc/aips-bus@02100000/caam@2140000", > > > > 0x440, 14}, > > > > + {MODULE_USB_OTG2, > "/soc/aips-bus@02100000/usb@02184200", > > > > 0x440, 15}, > > > > + {MODULE_SAI2, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/sai@0202c000", > 0x440, > > > 24}, > > > > + {MODULE_SAI3, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/sai@02030000", > 0x440, > > > 24}, > > > > + {MODULE_BEE, "/soc/aips-bus@02000000/bee@02044000", > > > > 0x440, 25}, > > > > + {MODULE_UART5, "/soc/aips-bus@02100000/serial@021f4000", > > > > 0x440, 26}, > > > > + {MODULE_UART6, "/soc/aips-bus@02100000/serial@021fc000", > > > > 0x440, 26}, > > > > + {MODULE_UART7, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/serial@02018000", > > > 0x440, > > > > 26}, > > > > + {MODULE_UART8, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/serial@02024000", > > > 0x440, > > > > 26}, > > > > + {MODULE_PWM5, "/soc/aips-bus@02000000/pwm@020f0000", > > > > 0x440, 27}, > > > > + {MODULE_PWM6, "/soc/aips-bus@02000000/pwm@020f4000", > > > > 0x440, 27}, > > > > + {MODULE_PWM7, "/soc/aips-bus@02000000/pwm@020f8000", > > > > 0x440, 27}, > > > > + {MODULE_PWM8, "/soc/aips-bus@02000000/pwm@020fc000", > > > > 0x440, 27}, > > > > + {MODULE_ECSPI3, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/ecspi@02010000", > > > > 0x440, > > > 28}, > > > > + {MODULE_ECSPI4, > > > > "/soc/aips-bus@02000000/spba-bus@02000000/ecspi@02014000", > > > > 0x440, > > > 28}, > > > > + {MODULE_I2C3, "/soc/aips-bus@02100000/i2c@021a8000", > > > > 0x440, 29}, > > > > + {MODULE_I2C4, "/soc/aips-bus@02100000/i2c@021f8000", > > > > 0x440, 29}, > > > > + {MODULE_GPT2, "/soc/aips-bus@02000000/gpt@020e8000", > > > > 0x440, 30}, > > > > + {MODULE_EPIT2, "/soc/aips-bus@02000000/epit@020d4000", > > > > > > I'm wondering if there would be a way to avoid the hardcoded DTS > > > patch ("/soc/aips-bus@02000000/epit@020d4000") ? > > > > > > Maybe, after reading the the OCOTP values this could be found > > > dynamically (by using the e.g. i2c@021f8000 string) on the DTS > > > already stored in RAM (which is thereafter passed to Linux kernel at > > > bootm execution) ? > > > > > > > 0x440, 31}, +#endif > > > > +}; > > > > + > > > > +u32 check_module_fused(enum fuse_module_type module) { > > > > + u32 i, reg; > > > > + > > > > + for (i = 0; i < ARRAY_SIZE(mx6_fuse_descs); i++) { > > > > + if (mx6_fuse_descs[i].module == module) { > > > > + reg = readl(OCOTP_BASE_ADDR + > > > > + > > > > mx6_fuse_descs[i].fuse_word_offset); > > > > + if (reg & > > > > BIT(mx6_fuse_descs[i].fuse_bit_offset)) > > > > + return 1; /* disabled */ > > > > + else > > > > + return 0; /* enabled */ > > > > + } > > > > + } > > > > + > > > > + return 0; /* Not has a fuse, always enabled */ } > > > > + > > > > +#ifdef CONFIG_OF_SYSTEM_SETUP > > > > +int ft_system_setup(void *blob, bd_t *bd) { > > > > + const char *status = "disabled"; > > > > + u32 i, reg; > > > > + int rc, off; > > > > + > > > > + for (i = 0; i < ARRAY_SIZE(mx6_fuse_descs); i++) { > > > > + reg = readl(OCOTP_BASE_ADDR + > > > > + mx6_fuse_descs[i].fuse_word_offset); > > > > + if (reg & > > > > BIT(mx6_fuse_descs[i].fuse_bit_offset)) { > > > > + off = fdt_path_offset(blob, > > > > + > > > > mx6_fuse_descs[i].node_path); + > > > > + if (off < 0) > > > > + continue; /* Not found, skip it > > > > */ +add_status: > > > > + rc = fdt_setprop(blob, nodeoff, "status", > > > > status, > > > > + strlen(status) + 1); > > > > + if (rc) { > > > > + if (rc == -FDT_ERR_NOSPACE) { > > > > + rc = > > > > fdt_increase_size(blob, 512); > > > > + if (!rc) > > > > + goto add_status; > > > > + } > > > > + printf("Unable to update property > > > > %s:%s, err=%s\n", mx6_fuse_descs[i].node_path, "status", > > > > fdt_strerror(rc)); > > > > + } else { > > > > + printf("Modify %s disabled\n", > > > > mx6_fuse_descs[i].node_path); > > > > + } > > > > + } > > > > + } > > > > + > > > > + return 0; > > > > +} > > > > +#endif > > > > + > > > > +u32 esdhc_fused(u32 base_addr) > > > > +{ > > > > + switch (base_addr) { > > > > + case USDHC1_BASE_ADDR: > > > > + return check_module_fused(MODULE_SD1); > > > > + case USDHC2_BASE_ADDR: > > > > + return check_module_fused(MODULE_SD2); #ifdef > > > USDHC3_BASE_ADDR > > > > + case USDHC3_BASE_ADDR: > > > > + return check_module_fused(MODULE_SD3); #endif > > > > #ifdef +USDHC4_BASE_ADDR > > > > + case USDHC4_BASE_ADDR: > > > > + return check_module_fused(MODULE_SD4); #endif > > > > + default: > > > > + return 0; > > > > + } > > > > +} > > > > + > > > > +u32 ecspi_fused(u32 base_addr) > > > > +{ > > > > + switch (base_addr) { > > > > + case ECSPI1_BASE_ADDR: > > > > + return check_module_fused(MODULE_ECSPI1); > > > > + case ECSPI2_BASE_ADDR: > > > > + return check_module_fused(MODULE_ECSPI2); > > > > + case ECSPI3_BASE_ADDR: > > > > + return check_module_fused(MODULE_ECSPI3); > > > > + case ECSPI4_BASE_ADDR: > > > > + return check_module_fused(MODULE_ECSPI4); > > > > +#ifdef ECSPI5_BASE_ADDR > > > > + case ECSPI5_BASE_ADDR: > > > > + return check_module_fused(MODULE_ECSPI5); > > > > +#endif > > > > + default: > > > > + return 0; > > > > + } > > > > +} > > > > + > > > > +u32 usb_fused(u32 base_addr) > > > > +{ > > > > + int i = (base_addr - USB_BASE_ADDR) / 0x200; > > > > + > > > > + return check_module_fused(MODULE_USB_OTG1 + i); } > > > > + > > > > +u32 qspi_fused(u32 base_addr) > > > > +{ > > > > + switch (base_addr) { > > > > +#ifdef QSPI1_BASE_ADDR > > > > + case QSPI1_BASE_ADDR: > > > > + return check_module_fused(MODULE_QSPI1); #endif > > > > + > > > > +#ifdef QSPI2_BASE_ADDR > > > > + case QSPI2_BASE_ADDR: > > > > + return check_module_fused(MODULE_QSPI2); #endif > > > > + default: > > > > + return 0; > > > > + } > > > > +} > > > > + > > > > +u32 i2c_fused(u32 base_addr) > > > > +{ > > > > + switch (base_addr) { > > > > + case I2C1_BASE_ADDR: > > > > + return check_module_fused(MODULE_I2C1); > > > > + case I2C2_BASE_ADDR: > > > > + return check_module_fused(MODULE_I2C2); > > > > + case I2C3_BASE_ADDR: > > > > + return check_module_fused(MODULE_I2C3); #ifdef > > > I2C4_BASE_ADDR > > > > + case I2C4_BASE_ADDR: > > > > + return check_module_fused(MODULE_I2C4); #endif > > > > + } > > > > + > > > > + return 0; > > > > +} > > > > + > > > > +u32 enet_fused(u32 base_addr) > > > > +{ > > > > + switch (base_addr) { > > > > + case ENET_BASE_ADDR: > > > > + return check_module_fused(MODULE_ENET1); #ifdef > > > ENET2_BASE_ADDR > > > > + case ENET2_BASE_ADDR: > > > > + return check_module_fused(MODULE_ENET2); #endif > > > > + default: > > > > + return 0; > > > > + } > > > > +} > > > > > > > > > > > > > > > Best regards, > > > > > > Lukasz Majewski > > > > > > -- > > > > > > DENX Software Engineering GmbH, Managing Director: Wolfgang > > > Denk HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, > > > Germany Phone: (+49)-8142-66989-59 Fax: (+49)-8142-66989-80 Email: > > > lu...@denx.de > > > > > Best regards, > > Lukasz Majewski > > -- > > DENX Software Engineering GmbH, Managing Director: Wolfgang Denk > HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany > Phone: (+49)-8142-66989-59 Fax: (+49)-8142-66989-80 Email: > lu...@denx.de _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot