add stm32h755II chip

This commit is contained in:
jfbblue0922 2024-05-23 19:06:37 +09:00 committed by Xiang Xiao
parent 6c3eeb7d5c
commit 73949ac223
7 changed files with 85 additions and 1082 deletions

View File

@ -284,11 +284,34 @@ config STM32H7_HAVE_SMPS
bool bool
default n default n
config STM32H7_HAVE_PWR_DIRECT_SMPS_SUPPLY
bool
default n
config STM32H7_PWR_DIRECT_SMPS_SUPPLY config STM32H7_PWR_DIRECT_SMPS_SUPPLY
bool "Use direct SMPS supply mode" bool "Use direct SMPS supply mode"
depends on STM32H7_HAVE_SMPS depends on STM32H7_HAVE_SMPS
default n default n
choice
prompt "STM32 H7 Power Supply Selection"
default STM32H7_PWR_DEFAULT_SUPPLY
depends on STM32H7_HAVE_SMPS && !STM32H7_HAVE_PWR_DIRECT_SMPS_SUPPLY
---help---
The STM32H7x5 and STM32H7x7 support power supply configrations for the VCORE core domain and an external supply,
by configuring the SMPS step-down converter and voltage regulator.
Note:The SMPS step-down converter is not available on all packages.
Currenlty the only supported modes are Direct SMPS supply and LDO supply.
config STM32H7_PWR_DEFAULT_SUPPLY
bool "Default"
config STM32H7_PWR_LDO_SUPPLY
bool "Use LDO supply mode"
endchoice # "STM32 H7 Power Supply Selection"
config STM32H7_IO_CONFIG_A config STM32H7_IO_CONFIG_A
bool bool
default n default n

View File

@ -129,16 +129,18 @@
#define STM32_PWR_CR3_BYPASS (1 << 0) /* Bit 0: Power management unit bypass */ #define STM32_PWR_CR3_BYPASS (1 << 0) /* Bit 0: Power management unit bypass */
#define STM32_PWR_CR3_LDOEN (1 << 1) /* Bit 1: Low drop-out regulator enable */ #define STM32_PWR_CR3_LDOEN (1 << 1) /* Bit 1: Low drop-out regulator enable */
#define STM32_PWR_CR3_SCUEN (1 << 2) /* Bit 2: Supply configuration update enable */ #ifndef CONFIG_STM32H7_HAVE_SMPS
# define STM32_PWR_CR3_SCUEN (1 << 2) /* Bit 2: Supply configuration update enable */
#endif
#ifdef CONFIG_STM32H7_HAVE_SMPS #ifdef CONFIG_STM32H7_HAVE_SMPS
#define STM32_PWR_CR3_SDEN (1 << 2) /* Bit 2: SMPS step-down converter enable */ # define STM32_PWR_CR3_SDEN (1 << 2) /* Bit 2: SMPS step-down converter enable */
#define STM32_PWR_CR3_SMPSEXTHP (1 << 3) /* Bit 3: SMPS step-down converter external power delivery selection */ # define STM32_PWR_CR3_SMPSEXTHP (1 << 3) /* Bit 3: SMPS step-down converter external power delivery selection */
#define STM32_PWR_CR3_SMPSLEVEL_SHIFT (4) /* BitS 4-5: SMPS step-down converter voltage output level selection */ # define STM32_PWR_CR3_SMPSLEVEL_SHIFT (4) /* BitS 4-5: SMPS step-down converter voltage output level selection */
# define STM32_PWR_CR3_SMPSLEVEL_MASK (3 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) # define STM32_PWR_CR3_SMPSLEVEL_MASK (3 << STM32_PWR_CR3_SMPSLEVEL_SHIFT)
# define STM32_PWR_CR3_SMPSLEVEL_R (0 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 00: */ # define STM32_PWR_CR3_SMPSLEVEL_R (0 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 00: */
# define STM32_PWR_CR3_SMPSLEVEL_1V8 (1 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 01 */ # define STM32_PWR_CR3_SMPSLEVEL_1V8 (1 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 01 */
# define STM32_PWR_CR3_SMPSLEVEL_2V5 (2 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 10: */ # define STM32_PWR_CR3_SMPSLEVEL_2V5 (2 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 10: */
# define STM32_PWR_CR3_SMPSLEVEL_2V5B (3 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 11: */ # define STM32_PWR_CR3_SMPSLEVEL_2V5B (3 << STM32_PWR_CR3_SMPSLEVEL_SHIFT) /* 11: */
#endif #endif
/* Bits 6-7: Reserved */ /* Bits 6-7: Reserved */
#define STM32_PWR_CR3_VBE (1 << 8) /* Bit 8: VBAT charging enable */ #define STM32_PWR_CR3_VBE (1 << 8) /* Bit 8: VBAT charging enable */

View File

@ -59,11 +59,7 @@
#elif defined(CONFIG_STM32H7_STM32H7B3XX) #elif defined(CONFIG_STM32H7_STM32H7B3XX)
# include "stm32h7x3xx_rcc.c" # include "stm32h7x3xx_rcc.c"
#elif defined(CONFIG_STM32H7_STM32H7X5XX) #elif defined(CONFIG_STM32H7_STM32H7X5XX)
# if defined(CONFIG_ARCH_CHIP_STM32H755II) # include "stm32h7x3xx_rcc.c"
# include "stm32h7x5xx_rcc.c"
# else
# include "stm32h7x3xx_rcc.c"
# endif
#elif defined(CONFIG_STM32H7_STM32H7X7XX) #elif defined(CONFIG_STM32H7_STM32H7X7XX)
# include "stm32h7x7xx_rcc.c" # include "stm32h7x7xx_rcc.c"
#else #else

View File

@ -133,6 +133,30 @@
# endif # endif
#endif #endif
/* When the SoC supports SMPS we currently support 2 configurations:
* Direct SMP Supply OR LDO only supply.
*
* When the Soc does not supports SMPS we support only the LDO supply.
*/
#ifdef CONFIG_STM32H7_HAVE_SMPS
# define STM32_PWR_CR3_MASK ~(STM32_PWR_CR3_BYPASS | \
STM32_PWR_CR3_LDOEN | \
STM32_PWR_CR3_SDEN | \
STM32_PWR_CR3_SMPSEXTHP | \
STM32_PWR_CR3_SMPSLEVEL_MASK)
# if defined(CONFIG_STM32H7_PWR_DIRECT_SMPS_SUPPLY)
# define STM32_PWR_CR3_SELECTION STM32_PWR_CR3_SDEN
# else
# define STM32_PWR_CR3_SELECTION STM32_PWR_CR3_LDOEN
# endif
#else
# define STM32_PWR_CR3_MASK 0xffffffff
# define STM32_PWR_CR3_SELECTION (STM32_PWR_CR3_LDOEN | STM32_PWR_CR3_SCUEN)
#endif
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
****************************************************************************/ ****************************************************************************/
@ -880,17 +904,10 @@ void stm32_stdclockconfig(void)
* N.B. The system shall be power cycled before writing a new value. * N.B. The system shall be power cycled before writing a new value.
*/ */
#if defined(CONFIG_STM32H7_PWR_DIRECT_SMPS_SUPPLY)
regval = getreg32(STM32_PWR_CR3); regval = getreg32(STM32_PWR_CR3);
regval &= ~(STM32_PWR_CR3_BYPASS | STM32_PWR_CR3_LDOEN | regval &= STM32_PWR_CR3_MASK;
STM32_PWR_CR3_SMPSEXTHP | STM32_PWR_CR3_SMPSLEVEL_MASK); regval |= STM32_PWR_CR3_SELECTION;
regval |= STM32_PWR_CR3_SCUEN;
putreg32(regval, STM32_PWR_CR3); putreg32(regval, STM32_PWR_CR3);
#else
regval = getreg32(STM32_PWR_CR3);
regval |= STM32_PWR_CR3_LDOEN | STM32_PWR_CR3_SCUEN;
putreg32(regval, STM32_PWR_CR3);
#endif
/* Set the voltage output scale */ /* Set the voltage output scale */

File diff suppressed because it is too large Load Diff

View File

@ -126,6 +126,26 @@
# endif # endif
#endif #endif
/* When the SoC supports SMPS we currently support 2 configurations:
* Direct SMP Supply OR LDO only supply.
*
* When the Soc does not supports SMPS we support only the LDO supply.
*/
#ifdef CONFIG_STM32H7_HAVE_SMPS
# define STM32_PWR_CR3_MASK ~(STM32_PWR_CR3_BYPASS | \
STM32_PWR_CR3_LDOEN | \
STM32_PWR_CR3_SDEN | \
STM32_PWR_CR3_SMPSEXTHP | \
STM32_PWR_CR3_SMPSLEVEL_MASK)
# define STM32_PWR_CR3_SELECTION STM32_PWR_CR3_SDEN
#else
# define STM32_PWR_CR3_MASK 0xffffffff
# define STM32_PWR_CR3_SELECTION (STM32_PWR_CR3_LDOEN | STM32_PWR_CR3_SCUEN)
#endif
/**************************************************************************** /****************************************************************************
* Private Data * Private Data
****************************************************************************/ ****************************************************************************/
@ -854,17 +874,10 @@ void stm32_stdclockconfig(void)
* N.B. The system shall be power cycled before writing a new value. * N.B. The system shall be power cycled before writing a new value.
*/ */
#if defined(CONFIG_STM32H7_PWR_DIRECT_SMPS_SUPPLY)
regval = getreg32(STM32_PWR_CR3); regval = getreg32(STM32_PWR_CR3);
regval &= ~(STM32_PWR_CR3_BYPASS | STM32_PWR_CR3_LDOEN | regval &= STM32_PWR_CR3_MASK;
STM32_PWR_CR3_SMPSEXTHP | STM32_PWR_CR3_SMPSLEVEL_MASK); regval |= STM32_PWR_CR3_SELECTION;
regval |= STM32_PWR_CR3_SCUEN;
putreg32(regval, STM32_PWR_CR3); putreg32(regval, STM32_PWR_CR3);
#else
regval = getreg32(STM32_PWR_CR3);
regval |= STM32_PWR_CR3_LDOEN | STM32_PWR_CR3_SCUEN;
putreg32(regval, STM32_PWR_CR3);
#endif
/* Set the voltage output scale */ /* Set the voltage output scale */

View File

@ -1747,6 +1747,7 @@ config ARCH_BOARD_NUCLEO_H745ZI
depends on ARCH_CHIP_STM32H745ZI depends on ARCH_CHIP_STM32H745ZI
select ARCH_HAVE_LEDS select ARCH_HAVE_LEDS
select ARCH_HAVE_BUTTONS select ARCH_HAVE_BUTTONS
select STM32H7_HAVE_PWR_DIRECT_SMPS_SUPPLY
---help--- ---help---
STMicro Nucleo H745ZI board based on the STMicro STM32H745ZI MCU. STMicro Nucleo H745ZI board based on the STMicro STM32H745ZI MCU.
@ -2588,6 +2589,7 @@ config ARCH_BOARD_STM32H747I_DISCO
select ARCH_HAVE_LEDS select ARCH_HAVE_LEDS
select ARCH_HAVE_BUTTONS select ARCH_HAVE_BUTTONS
select ARCH_HAVE_IRQBUTTONS select ARCH_HAVE_IRQBUTTONS
select STM32H7_HAVE_PWR_DIRECT_SMPS_SUPPLY
---help--- ---help---
STMicro STM32H747I-DISCO development board featuring the STM32H747XIH6 STMicro STM32H747I-DISCO development board featuring the STM32H747XIH6
MCU. The STM32H747XIH6 is a dual core (480MHz Cortex-M7, 240MHz Cortex-M4) MCU. The STM32H747XIH6 is a dual core (480MHz Cortex-M7, 240MHz Cortex-M4)