Boot time with Cold boot vs POR

cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Boot time with Cold boot vs POR

Jump to solution
4,484 Views
pdgendt
Contributor II

Hi,

On the i.MX RT1064 EVK, using the demo blinky application (SDK v2.8.6) with MCUXpresso v11.2.1, we see that if we measure the 3v3 and PMIC_ON_REQ until the LED is actually set, it takes about ~270ms.

Using the switch to do a POR, this is almost instant.

What is taking so long to get to the application? Can this time be reduced? Are there settings in the DCD that can be tweaked?

Attached is a screenshot from our scope.

pdgendt_0-1632231837554.png

Thanks in advance,

Pieter

Labels (1)
0 Kudos
Reply
1 Solution
4,327 Views
manuel_pacheco
NXP Employee
NXP Employee

Hi @pdgendt @kerryzhou , 

I also performed some tests with the Zephyr Blinky App loaded on the RT1064 EVK running v2.7.0-rc4. I timed from DCDC_3V3 to the LED blinking (cold boot case) was 274ms and from POR_B to LED blinking (reset case) was only 16ms, which is similar to what you got.

I did some research and found that the reason that the cold boot takes so long, is due to a voltage supervisor chip on our EVKs (labeled U2) part number UM803RS. This chip holds the POR_B signal low for a minimum of 140 ms from the time DCDC_3v3 reaches the minimum threshold voltage. 

manuel_pacheco_0-1634328110877.png

The EVK is designed to be overly conservative with this. There are power-up sequencing requirements even without the voltage supervisor. If the on-chip DCDC is used, you need at least 1ms delay from when the DCDC input voltage is stable to starting up the DCDC. And then the DCDC also has a startup time. So it's not possible to completely eliminate the power-sequencing time. The chip will have voltage monitors of it's own, to prevent the POR_B signal from being asserted internally (so you can't see it on the outside pin). 

The external voltage supervisor could be removed in your custom design if desired, which would likely reduce the power-sequencing time. Just make sure to evaluate the rest of your power-sequencing needs, in case you have other power supplies that need a longer time to get up and running. 

Hope this helps provide some closure and solution to the issue. 

 

Regards, 

-Manuel 

View solution in original post

12 Replies
4,477 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @pdgendt ,

  Do you boot the code from the external QSPI flash, right?

  If yes, let's talk about the boot mode at first, after POR, the chip will run the internal ROM code at first, it will read the external QSPI flash FCB, then configure the flexSPI interface, then check the external memory IVT, after it is valid, it will jump to the customer code, so all these operation need the time.

  I think you can set higher flexSPI frequency, eg, project xip folder, evkmimxrt1064_flexspi_nor_config.c, qspiflash_config,

Set:

.serialClkFreq = kFlexSpiSerialClk_100MHz,

to

.serialClkFreq = kFlexSpiSerialClk_133MHz,

The time may be shorten, but, about 270ms enter the user APP after POR, I think it is correct, as the ROM code, flexspi interface configuration, and jumpt to the app all need code execution time.

 

Wish it helps you!

Bes Regards,

Kerry

0 Kudos
Reply
4,473 Views
pdgendt
Contributor II

Hi @kerryzhou 

We boot from the internal NOR flash (W25Q32JV), the external QSPI flash isn't used.

Can't the device configuration performance be improved, for example with the DCD data? Are there options using the boot mode/config/fuses to skip some unnecessary steps?

Still 270ms feels huge, if the customer application is able to configure the other flexspi interface in a few milliseconds.

Thanks,

Pieter

0 Kudos
Reply
4,469 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @pdgendt ,

RT1064 Internal QSPI in fact is also the external QSPI, as it just put the external QSPI into the RT internal side, but the operation is the same as the external QSPI flash.

  So the boot process is the same.

Do you try to modify the flexspi frequency to higher?

About the DCD, the supported register is:

kerryzhou_0-1632296842222.png

You can find the GPIO is not in the support register.

You also can put your GPIO pull-down code in this API:SystemInit, after the watchdog disabled code, this will be executed after enter the app reset handler.

 

Best Regards,

Kerry

 

 

 

 

0 Kudos
Reply
4,467 Views
pdgendt
Contributor II

Hi @kerryzhou 

The GPIO is just an example we could measure, we'd like to have the user application boot faster.

Even changing the frequency from 100 to 133 MHz would still result in a boot time, higher than 200ms right?

0 Kudos
Reply
4,464 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @pdgendt ,

  Do you test 133 MHz  on your side? That will shorten the boot time, especially when do the code access in the QSPI flash and execution.

 But the internal ROM code which is used for booting, that time can't be shorten, as it is fixed and can't be modifiy.

DCD normally used for the SEMC interface configuration for the external SDRAM initialize.

What I can suggest you is the flexSPI speed set to higher.

Best Regards,

Kerry

0 Kudos
Reply
4,460 Views
pdgendt
Contributor II

HI @kerryzhou 

I will verify the 133 MHz and let you know what gain we got.

For the DCD you mentioned external SDRAM, can this be left out as we don't need this on our custom board. Won't this speed up the boot process as well?

0 Kudos
Reply
4,449 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @pdgendt 

  If you don't need to use the SDRAM, you can don't configure the DCD, just leave it as default, it's OK.

Best Regards,

Kerry

0 Kudos
Reply
4,456 Views
pdgendt
Contributor II

Hi @kerryzhou 

In the reference manual there is this flow:

pdgendt_0-1632303446591.png

In the case of a low power wakeup, could the boot time be faster? Where should the wakeup handler be defined?

Thanks,

Pieter

0 Kudos
Reply
4,434 Views
manuel_pacheco
NXP Employee
NXP Employee

Hi @pdgendt , 

Please refer to App Note 12085 on how to enable low power on the RT devices: 

https://www.nxp.com.cn/docs/en/application-note/AN12085.pdf 

You can also see the Power Mode Switch example available in the SDK: 

RT 1064 SDK -> demo_apps -> power_mode_switch_bm or power_mode_switch_rtos 

I tried to look online, but couldn't find anything on low-power wake-up times on the RT1064, so if you run any tests, please let us know the results. 

It seems there's a couple different low-power modes: System Idle, Low Power Idle, Suspend, and SNVS. With each increasing in exit times. Looks like some need to disable some PLLs/Clocks, and gate some of the peripherals. 

In the past, I ran a test to determine boot-times with different memories on the RT1050, and I found that they were very close to each other (all ~10ms). So I'm not sure that changing the memory clock speed or changing which memory you boot from would have much of an impact on your boot time: 

https://community.nxp.com/t5/i-MX-RT-Knowledge-Base/Boot-up-times-for-different-memories-on-RT1050/t... 

 

I hope this helps, 

-Manuel 

0 Kudos
Reply
4,448 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @pdgendt ,

  If it is the wakeup, you will run the code directly.

But the first time you still need to run the app code which let the chip enter the low power mode.

 To some low power mode, not the reset wakeup, it will run the code after the code which enters the low power directly.

 

Best Regards,

Kerry

0 Kudos
Reply
4,328 Views
manuel_pacheco
NXP Employee
NXP Employee

Hi @pdgendt @kerryzhou , 

I also performed some tests with the Zephyr Blinky App loaded on the RT1064 EVK running v2.7.0-rc4. I timed from DCDC_3V3 to the LED blinking (cold boot case) was 274ms and from POR_B to LED blinking (reset case) was only 16ms, which is similar to what you got.

I did some research and found that the reason that the cold boot takes so long, is due to a voltage supervisor chip on our EVKs (labeled U2) part number UM803RS. This chip holds the POR_B signal low for a minimum of 140 ms from the time DCDC_3v3 reaches the minimum threshold voltage. 

manuel_pacheco_0-1634328110877.png

The EVK is designed to be overly conservative with this. There are power-up sequencing requirements even without the voltage supervisor. If the on-chip DCDC is used, you need at least 1ms delay from when the DCDC input voltage is stable to starting up the DCDC. And then the DCDC also has a startup time. So it's not possible to completely eliminate the power-sequencing time. The chip will have voltage monitors of it's own, to prevent the POR_B signal from being asserted internally (so you can't see it on the outside pin). 

The external voltage supervisor could be removed in your custom design if desired, which would likely reduce the power-sequencing time. Just make sure to evaluate the rest of your power-sequencing needs, in case you have other power supplies that need a longer time to get up and running. 

Hope this helps provide some closure and solution to the issue. 

 

Regards, 

-Manuel 

4,315 Views
kerryzhou
NXP TechSupport
NXP TechSupport

Hi @manuel_pacheco 

   Thanks so much for your experience sharing, that's very useful!

 

Best Regards,

Kerry