cancel
Showing results for 
Search instead for 
Did you mean: 

Configuring NUCLEO-H755ZI-Q at 480MHz

GMG
Associate III

I'm trying to configure NUCLEO demo board at 480Mhz but I'm not able in any way, the following clock configuration seams to be correct, no conflicts

0690X00000DXYieQAH.png

But the code will permanently hang on on the following configuration line

0690X00000DXYijQAH.png

If I comment the line

while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY))

all seams to work correctly, why?

Chip revision seams to be V so It will be capable of 480MHz

0690X00000DXZ6vQAH.jpg

What is wrong? Can someone post a correct clock configuration ? Is there a modify to the board to do? I'm using the last STM32CubeIDE 1.3.0 with H7 1.7.0 support library

best regards

GMG

14 REPLIES 14

I've got Y step parts that run >500MHz

Check if it is wired for a SMPS supply?

STM32Cube_FW_H7_V1.7.0\Projects\NUCLEO-H745ZI-Q\Examples\PWR\PWR_VOS0_480MHZ\CM7\Src\main.c

  /* The voltage scaling allows optimizing the power consumption when the device is
     clocked below the maximum system frequency, to update the voltage scaling value
     regarding system frequency refer to product datasheet.  */
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {}
 
  __HAL_RCC_SYSCFG_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE0);
  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {}
 

Tips, Buy me a coffee, or three.. PayPal Venmo
Up vote any posts that you find helpful, it shows what's working..
berendi
Principal

Clock configuration on the STM32H7 using CubeMX has not worked reliably for me. However the RCC chapter in the reference manual gives usable instructions for setting up the clock tree.

This is for a STM32H743ZI on a Nucleo board. Check the steps in your reference manual, the H755 might require some additional steps.

void Systemclock_Config_480(void) {
	// Enable the SYSCFG clock in the RCC by setting the SYSCFGEN bit in the RCC_APB4ENR register.
	RCC->APB4ENR |= RCC_APB4ENR_SYSCFGEN;
	PWR->CR3 = PWR_CR3_LDOEN;
	while(!(PWR->CSR1 & PWR_CSR1_ACTVOSRDY))
		;
	PWR->D3CR = PWR_D3CR_VOS; // 11: VOS 1
	while((PWR->D3CR & (PWR_D3CR_VOSRDY | PWR_D3CR_VOS)) != (PWR_D3CR_VOSRDY | PWR_D3CR_VOS))
		;
	SYSCFG->PWRCR = SYSCFG_PWRCR_ODEN; // VOS 0
	while((PWR->D3CR & (PWR_D3CR_VOSRDY | PWR_D3CR_VOS)) != (PWR_D3CR_VOSRDY | PWR_D3CR_VOS))
		;
	RCC->D1CFGR =
			(0b0000u << RCC_D1CFGR_D1CPRE_Pos) | // 0000: 0xxx: sys_ck not divided
			(0b0100u << RCC_D1CFGR_D1PPRE_Pos) | // 100 : 100: rcc_pclk3 = rcc_hclk3 / 2
			(0b1000u << RCC_D1CFGR_HPRE_Pos)   | // 1000: rcc_hclk3 = sys_d1cpre_ck / 2
			0;
	RCC->D2CFGR =
			(0b0100u << RCC_D2CFGR_D2PPRE2_Pos) | // 100: rcc_pclk2 = rcc_hclk1 / 2
			(0b0100u << RCC_D2CFGR_D2PPRE1_Pos) | // 100: rcc_pclk1 = rcc_hclk1 / 2
			0;
	RCC->D3CFGR = 0b0100 << RCC_D3CFGR_D3PPRE_Pos; // 100: rcc_pclk4 = rcc_hclk4 / 2
	RCC->PLLCKSELR =                              // PLLSRC=0 HSI
			( 4u << RCC_PLLCKSELR_DIVM1_Pos) |    // DIVM1 = 4
			(32u << RCC_PLLCKSELR_DIVM2_Pos) |    // DIVM2 = 32
			(32u << RCC_PLLCKSELR_DIVM3_Pos);     // DIVM3 = 32
	RCC->PLL1DIVR =
			((60u - 1u) << RCC_PLL1DIVR_N1_Pos) | // DIVN1 = 60
			((2u - 1u) << RCC_PLL1DIVR_P1_Pos)  | // DIVP1 = 2
			0;
	RCC->PLLCFGR =
			// 11: The PLL1 input (ref1_ck) clock range frequency is between 8 and 16 MHz
			(0b11u << RCC_PLLCFGR_PLL1RGE_Pos) | // ref1_ck=16MHz (HSI/4)
			RCC_PLLCFGR_DIVP1EN                | // PLL1 DIVP divider output enable
			0;
	RCC->CR |= RCC_CR_PLL1ON;
	while((RCC->CR & RCC_CR_PLL1RDY) != RCC_CR_PLL1RDY)
		;
	RCC->CFGR |= RCC_CFGR_SW_0 | RCC_CFGR_SW_1; // select system clock source pll
	while((RCC->CFGR & RCC_CFGR_SWS) != (RCC_CFGR_SWS_0 | RCC_CFGR_SWS_1)) // wait until clock source is ready
		;
	// now the system is running on 480 MHz.
}

Hi, I think you may be right, now the problem is that I can't find a working solution to go to 480MHz using IDE configurator

0690X00000DYO0KQAX.png

Board power configuration may be the default one as write in the user manual of the NUCLEO

0690X00000DYO0UQAX.png

0690X00000DYO0ZQAX.png

Power Regulator Voltage Scale options can only be 0

0690X00000DYO0oQAH.png

The symptoms seem to be exactly those, but I don't understand how to solve it

The problem was in the IDE, I was selected LDO and not SMPS

BKMY
Associate II

I know this is an old thread, thought I'd add a helpful tidbit. I had the darndest time getting the board to work at 480MHz, and when I got it (LDO, VC0) the board locked up when powering on. Once it was properly booted with a 240MHz build, I could flash the 480, and it would be fine until the next power cycle. So the solution is in the system clock startup, to start with the SMPS, then switch to the LDO. This worked on the stock Nucleo-H755ZI-Q board (rev V chip)

Use MX to configure for 480MHz (240MHz M4)(LDO, VS0), then in main.c, add:

 

/* USER CODE BEGIN Init */

 

// Start with SMPS before switching to LDO; necessary for 480MHz @ boot up

HAL_PWREx_ConfigSupply(PWR_DIRECT_SMPS_SUPPLY);

__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE2);

while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {}

 

/* USER CODE END Init */

 

 

@BKMY , thank you. It works!

SofLit
ST Employee

To all,

By specification VOS0 (480MHz max) can be reached only with LDO.

So no VOS0 with SMPS.

SMPS can reach up to 400MHz at VOS1:

Refer to the datasheet:

SofLit_0-1708359568609.png

So with NUCLEO-H745ZI-Q the power configuration is SMPS => The max system clock is 400Mhz with this board except if you modify the board to be in LDO config.

 

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is NOT an online support (https://ols.st.com) but a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.

I'm guessing either you didn't read and/or understand my posting. Without changing solder pad jumpers, when I set LDO/VS0, it works until power down/power up, at which point it locks up (race condition). By booting up and setting  SMPS FIRST, and THEN switching to LDO, this lock up is prevented, and the 755 boots up like it should.

My comment was to all and especially to the the first question posted by GMG "Configuring NUCLEO-H755ZI-Q at 480MHz".

 

To give better visibility on the answered topics, please click on "Accept as Solution" on the reply which solved your issue or answered your question.
PS: This is NOT an online support (https://ols.st.com) but a collaborative space. So please be polite in your reply. Otherwise, it will be reported as inappropriate and you will be permanently blacklisted from my help/support.