Tom Rini | 8b0c8a1 | 2018-05-06 18:27:01 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause */ |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 2 | /* |
| 3 | * Copyright (C) 2015-2017, STMicroelectronics - All Rights Reserved |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 4 | */ |
| 5 | |
Patrick Delaunay | 123687c | 2022-05-20 18:24:46 +0200 | [diff] [blame] | 6 | /* ID = Device Version (bit31:16) + Device Part Number (RPN) (bit15:0) */ |
Patrick Delaunay | 45c82d2 | 2019-02-27 17:01:13 +0100 | [diff] [blame] | 7 | #define CPU_STM32MP157Cxx 0x05000000 |
| 8 | #define CPU_STM32MP157Axx 0x05000001 |
| 9 | #define CPU_STM32MP153Cxx 0x05000024 |
| 10 | #define CPU_STM32MP153Axx 0x05000025 |
| 11 | #define CPU_STM32MP151Cxx 0x0500002E |
| 12 | #define CPU_STM32MP151Axx 0x0500002F |
Patrick Delaunay | db33b0e | 2020-02-26 11:26:43 +0100 | [diff] [blame] | 13 | #define CPU_STM32MP157Fxx 0x05000080 |
| 14 | #define CPU_STM32MP157Dxx 0x05000081 |
| 15 | #define CPU_STM32MP153Fxx 0x050000A4 |
| 16 | #define CPU_STM32MP153Dxx 0x050000A5 |
| 17 | #define CPU_STM32MP151Fxx 0x050000AE |
| 18 | #define CPU_STM32MP151Dxx 0x050000AF |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 19 | |
Patrick Delaunay | 123687c | 2022-05-20 18:24:46 +0200 | [diff] [blame] | 20 | #define CPU_STM32MP135Cxx 0x05010000 |
| 21 | #define CPU_STM32MP135Axx 0x05010001 |
| 22 | #define CPU_STM32MP133Cxx 0x050100C0 |
| 23 | #define CPU_STM32MP133Axx 0x050100C1 |
| 24 | #define CPU_STM32MP131Cxx 0x050106C8 |
| 25 | #define CPU_STM32MP131Axx 0x050106C9 |
| 26 | #define CPU_STM32MP135Fxx 0x05010800 |
| 27 | #define CPU_STM32MP135Dxx 0x05010801 |
| 28 | #define CPU_STM32MP133Fxx 0x050108C0 |
| 29 | #define CPU_STM32MP133Dxx 0x050108C1 |
| 30 | #define CPU_STM32MP131Fxx 0x05010EC8 |
| 31 | #define CPU_STM32MP131Dxx 0x05010EC9 |
| 32 | |
Patrice Chotard | d29531c | 2023-10-27 16:43:04 +0200 | [diff] [blame] | 33 | /* ID for STM32MP25x = Device Part Number (RPN) (bit31:0) */ |
| 34 | #define CPU_STM32MP257Cxx 0x00002000 |
| 35 | #define CPU_STM32MP255Cxx 0x00082000 |
| 36 | #define CPU_STM32MP253Cxx 0x000B2004 |
| 37 | #define CPU_STM32MP251Cxx 0x000B3065 |
| 38 | #define CPU_STM32MP257Axx 0x40002E00 |
| 39 | #define CPU_STM32MP255Axx 0x40082E00 |
| 40 | #define CPU_STM32MP253Axx 0x400B2E04 |
| 41 | #define CPU_STM32MP251Axx 0x400B3E65 |
| 42 | #define CPU_STM32MP257Fxx 0x80002000 |
| 43 | #define CPU_STM32MP255Fxx 0x80082000 |
| 44 | #define CPU_STM32MP253Fxx 0x800B2004 |
| 45 | #define CPU_STM32MP251Fxx 0x800B3065 |
| 46 | #define CPU_STM32MP257Dxx 0xC0002E00 |
| 47 | #define CPU_STM32MP255Dxx 0xC0082E00 |
| 48 | #define CPU_STM32MP253Dxx 0xC00B2E04 |
| 49 | #define CPU_STM32MP251Dxx 0xC00B3E65 |
| 50 | |
Patrick Delaunay | 45c82d2 | 2019-02-27 17:01:13 +0100 | [diff] [blame] | 51 | /* return CPU_STMP32MP...Xxx constants */ |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 52 | u32 get_cpu_type(void); |
| 53 | |
Patrick Delaunay | 79bc640 | 2020-03-18 09:24:48 +0100 | [diff] [blame] | 54 | #define CPU_DEV_STM32MP15 0x500 |
Patrick Delaunay | 123687c | 2022-05-20 18:24:46 +0200 | [diff] [blame] | 55 | #define CPU_DEV_STM32MP13 0x501 |
Patrice Chotard | d29531c | 2023-10-27 16:43:04 +0200 | [diff] [blame] | 56 | #define CPU_DEV_STM32MP25 0x505 |
Patrick Delaunay | 79bc640 | 2020-03-18 09:24:48 +0100 | [diff] [blame] | 57 | |
| 58 | /* return CPU_DEV constants */ |
| 59 | u32 get_cpu_dev(void); |
| 60 | |
Patrick Delaunay | 9203359 | 2022-04-15 15:00:43 +0200 | [diff] [blame] | 61 | #define CPU_REV1 0x1000 |
| 62 | #define CPU_REV1_1 0x1001 |
Patrick Delaunay | 95b0276 | 2022-06-30 10:20:16 +0200 | [diff] [blame] | 63 | #define CPU_REV1_2 0x1003 |
Patrick Delaunay | 9203359 | 2022-04-15 15:00:43 +0200 | [diff] [blame] | 64 | #define CPU_REV2 0x2000 |
| 65 | #define CPU_REV2_1 0x2001 |
Patrick Delaunay | c4a76ff | 2023-04-27 15:36:33 +0200 | [diff] [blame] | 66 | #define CPU_REV2_2 0x2003 |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 67 | |
Patrick Delaunay | 9203359 | 2022-04-15 15:00:43 +0200 | [diff] [blame] | 68 | /* return Silicon revision = REV_ID[15:0] of Device Version */ |
Patrick Delaunay | 01e3afe | 2018-03-19 19:09:21 +0100 | [diff] [blame] | 69 | u32 get_cpu_rev(void); |
Patrick Delaunay | c74d634 | 2019-07-05 17:20:13 +0200 | [diff] [blame] | 70 | |
| 71 | /* Get Package options from OTP */ |
| 72 | u32 get_cpu_package(void); |
| 73 | |
Patrick Delaunay | e4bdd54 | 2022-05-20 18:24:42 +0200 | [diff] [blame] | 74 | /* package used for STM32MP15x */ |
| 75 | #define STM32MP15_PKG_AA_LBGA448 4 |
| 76 | #define STM32MP15_PKG_AB_LBGA354 3 |
| 77 | #define STM32MP15_PKG_AC_TFBGA361 2 |
| 78 | #define STM32MP15_PKG_AD_TFBGA257 1 |
| 79 | #define STM32MP15_PKG_UNKNOWN 0 |
Patrick Delaunay | c74d634 | 2019-07-05 17:20:13 +0200 | [diff] [blame] | 80 | |
Patrice Chotard | d29531c | 2023-10-27 16:43:04 +0200 | [diff] [blame] | 81 | /* package used for STM32MP25x */ |
| 82 | #define STM32MP25_PKG_CUSTOM 0 |
| 83 | #define STM32MP25_PKG_AL_TBGA361 3 |
| 84 | #define STM32MP25_PKG_AK_TBGA424 4 |
| 85 | #define STM32MP25_PKG_AI_TBGA436 5 |
| 86 | #define STM32MP25_PKG_UNKNOWN 7 |
| 87 | |
Patrick Delaunay | 3e738f2 | 2020-02-12 19:37:43 +0100 | [diff] [blame] | 88 | /* Get SOC name */ |
| 89 | #define SOC_NAME_SIZE 20 |
| 90 | void get_soc_name(char name[SOC_NAME_SIZE]); |
| 91 | |
Patrick Delaunay | 18660a6 | 2019-02-27 17:01:12 +0100 | [diff] [blame] | 92 | /* return boot mode */ |
| 93 | u32 get_bootmode(void); |
Marek Vasut | 187cae2 | 2019-12-18 16:52:19 +0100 | [diff] [blame] | 94 | |
Igor Opaniuk | 100e0ec | 2023-11-06 11:41:52 +0100 | [diff] [blame] | 95 | /* return auth status and partition */ |
| 96 | u32 get_bootauth(void); |
| 97 | |
Patrick Delaunay | 6425f58 | 2022-05-20 18:24:47 +0200 | [diff] [blame] | 98 | int get_eth_nb(void); |
Marek Vasut | 187cae2 | 2019-12-18 16:52:19 +0100 | [diff] [blame] | 99 | int setup_mac_address(void); |
Patrice Chotard | 539fec3 | 2024-01-15 15:05:50 +0100 | [diff] [blame] | 100 | int setup_serial_number(void); |
Patrick Delaunay | 3d1fe4e | 2020-05-25 12:19:45 +0200 | [diff] [blame] | 101 | |
| 102 | /* board power management : configure vddcore according OPP */ |
| 103 | void board_vddcore_init(u32 voltage_mv); |
Patrick Delaunay | 9fa24a5 | 2022-05-20 18:24:41 +0200 | [diff] [blame] | 104 | |
Patrick Delaunay | e4bdd54 | 2022-05-20 18:24:42 +0200 | [diff] [blame] | 105 | /* weak function */ |
| 106 | void stm32mp_cpu_init(void); |
| 107 | void stm32mp_misc_init(void); |
| 108 | |
Patrick Delaunay | 9fa24a5 | 2022-05-20 18:24:41 +0200 | [diff] [blame] | 109 | /* helper function: read data from OTP */ |
| 110 | u32 get_otp(int index, int shift, int mask); |
Marek Vasut | efdedcb | 2023-01-12 18:58:40 +0100 | [diff] [blame] | 111 | |
| 112 | uintptr_t get_stm32mp_rom_api_table(void); |
| 113 | uintptr_t get_stm32mp_bl2_dtb(void); |