/* SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause */ /* * Copyright (C) 2015-2017, STMicroelectronics - All Rights Reserved */ /* ID = Device Version (bit31:16) + Device Part Number (RPN) (bit15:0) */ #define CPU_STM32MP157Cxx 0x05000000 #define CPU_STM32MP157Axx 0x05000001 #define CPU_STM32MP153Cxx 0x05000024 #define CPU_STM32MP153Axx 0x05000025 #define CPU_STM32MP151Cxx 0x0500002E #define CPU_STM32MP151Axx 0x0500002F #define CPU_STM32MP157Fxx 0x05000080 #define CPU_STM32MP157Dxx 0x05000081 #define CPU_STM32MP153Fxx 0x050000A4 #define CPU_STM32MP153Dxx 0x050000A5 #define CPU_STM32MP151Fxx 0x050000AE #define CPU_STM32MP151Dxx 0x050000AF #define CPU_STM32MP135Cxx 0x05010000 #define CPU_STM32MP135Axx 0x05010001 #define CPU_STM32MP133Cxx 0x050100C0 #define CPU_STM32MP133Axx 0x050100C1 #define CPU_STM32MP131Cxx 0x050106C8 #define CPU_STM32MP131Axx 0x050106C9 #define CPU_STM32MP135Fxx 0x05010800 #define CPU_STM32MP135Dxx 0x05010801 #define CPU_STM32MP133Fxx 0x050108C0 #define CPU_STM32MP133Dxx 0x050108C1 #define CPU_STM32MP131Fxx 0x05010EC8 #define CPU_STM32MP131Dxx 0x05010EC9 /* ID for STM32MP25x = Device Part Number (RPN) (bit31:0) */ #define CPU_STM32MP257Cxx 0x00002000 #define CPU_STM32MP255Cxx 0x00082000 #define CPU_STM32MP253Cxx 0x000B2004 #define CPU_STM32MP251Cxx 0x000B3065 #define CPU_STM32MP257Axx 0x40002E00 #define CPU_STM32MP255Axx 0x40082E00 #define CPU_STM32MP253Axx 0x400B2E04 #define CPU_STM32MP251Axx 0x400B3E65 #define CPU_STM32MP257Fxx 0x80002000 #define CPU_STM32MP255Fxx 0x80082000 #define CPU_STM32MP253Fxx 0x800B2004 #define CPU_STM32MP251Fxx 0x800B3065 #define CPU_STM32MP257Dxx 0xC0002E00 #define CPU_STM32MP255Dxx 0xC0082E00 #define CPU_STM32MP253Dxx 0xC00B2E04 #define CPU_STM32MP251Dxx 0xC00B3E65 /* return CPU_STMP32MP...Xxx constants */ u32 get_cpu_type(void); #define CPU_DEV_STM32MP15 0x500 #define CPU_DEV_STM32MP13 0x501 #define CPU_DEV_STM32MP25 0x505 /* return CPU_DEV constants */ u32 get_cpu_dev(void); #define CPU_REV1 0x1000 #define CPU_REV1_1 0x1001 #define CPU_REV1_2 0x1003 #define CPU_REV2 0x2000 #define CPU_REV2_1 0x2001 #define CPU_REV2_2 0x2003 /* return Silicon revision = REV_ID[15:0] of Device Version */ u32 get_cpu_rev(void); /* Get Package options from OTP */ u32 get_cpu_package(void); /* package used for STM32MP15x */ #define STM32MP15_PKG_AA_LBGA448 4 #define STM32MP15_PKG_AB_LBGA354 3 #define STM32MP15_PKG_AC_TFBGA361 2 #define STM32MP15_PKG_AD_TFBGA257 1 #define STM32MP15_PKG_UNKNOWN 0 /* package used for STM32MP25x */ #define STM32MP25_PKG_CUSTOM 0 #define STM32MP25_PKG_AL_TBGA361 3 #define STM32MP25_PKG_AK_TBGA424 4 #define STM32MP25_PKG_AI_TBGA436 5 #define STM32MP25_PKG_UNKNOWN 7 /* Get SOC name */ #define SOC_NAME_SIZE 20 void get_soc_name(char name[SOC_NAME_SIZE]); /* return boot mode */ u32 get_bootmode(void); /* return auth status and partition */ u32 get_bootauth(void); int get_eth_nb(void); int setup_mac_address(void); /* board power management : configure vddcore according OPP */ void board_vddcore_init(u32 voltage_mv); /* weak function */ void stm32mp_cpu_init(void); void stm32mp_misc_init(void); /* helper function: read data from OTP */ u32 get_otp(int index, int shift, int mask); uintptr_t get_stm32mp_rom_api_table(void); uintptr_t get_stm32mp_bl2_dtb(void);