add stm32h755II chip
This commit is contained in:
parent
6c3eeb7d5c
commit
73949ac223
@ -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
|
||||||
|
@ -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 */
|
||||||
|
@ -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
|
||||||
|
@ -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
@ -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 */
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user