VLPS to RUN delay

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

VLPS to RUN delay

2,239 Views
rmelizalde
Contributor I

Hello,

We are meassuring a delay of over 500us from a wakeup event (falling edge in PORT) until the micro processes the related interrupt (PORT).

This seems to be too much.

We would like to get some support on this topic.

- Can we improve the wakeup reponse time?

- Is it specified somewhere the transition delay time from VLPS to RUN? In the past, I think I found a table with some numbers but I cannot find it anymore.

Thank you very much in advance.

Best regards,

Ricardo

0 Kudos
Reply
7 Replies

2,121 Views
rmelizalde
Contributor I

Hello,

I can confirm that:

- When RUN mode clock is SPLL and when going to VLPS, then the wakeup time from VLPS to RUN is more than 500us.

- When RUN mode clock is FIRC, when going to VLPS, then the wakeup time from VLPS to RUN is around 10us, as stated in the datasheet.

So, it seems that waking up when the system clock is SPLL is much slower than with FIRC.

Could you please confirm our observations?

Why is this difference? Is this the time to lock the SPLL? Is this delay described in the datasheet or the RM?

Thank you.

Ricardo

0 Kudos
Reply

2,121 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hello Ricardo,

The system clock cannot be derived from FIRC/SPLL when the MCU enters VLPS.

pastedImage_1.png

The Power Manager SDK driver switches the clock to SIRC in the Power_SYS_Setmode(VLPS, ...) function.

BR, Daniel

0 Kudos
Reply

2,121 Views
Jeremy_He
NXP Employee
NXP Employee

Hi Ricardo,

No matter you use SPLL or FIRC as the system clock, the time from VLPS to wakeup PORT ISR shouldn't be affected. The ISR will always be executed before the clock initializing. 

Also in the attached project, the system clock will switch to SPLL_CLK. And a clock out pin(PTE10) that connects to the bus clock is used to show the clock initialing procedure. You can test with the code directly.

pastedImage_1.png

pastedImage_2.png

pastedImage_3.png

pastedImage_4.jpg

Best wishes.

Jeremy

0 Kudos
Reply

2,121 Views
Jeremy_He
NXP Employee
NXP Employee

Hi Ricardo, you can find the numbers in the datasheet as below.

vlps to run time.png

0 Kudos
Reply

2,121 Views
rmelizalde
Contributor I

Hello Jeremy He,

Thanks for your response.

However, we are meassuring a delay of 500us from the PORT falling edge, which is the wakeup event, until the associated ISR is serviced.

What can be going on here? Maybe the system PLL is taking long to lock? Or what?

Any help or hint would be really appreciated. Because this makes no sense. Why the datasheet states max 17us but we can measure more than 500us.

Thank you

Ricardo

0 Kudos
Reply

2,121 Views
danielmartynek
NXP TechSupport
NXP TechSupport

Hi Ricardo,

One possible reason could be a delay caused by Digital filter on that port.

Could you scope the active edge along with BUS_CLK on a CLKOUT pin?

pastedImage_1.png

BR, Daniel

0 Kudos
Reply

2,120 Views
Jeremy_He
NXP Employee
NXP Employee

Hi Ricardo, I tested with a project using S32K144, The time from GPIO wake up to ISR toggle another pin is around 17 us, which matches the datasheet. Please check your code maybe something else is wrong. 

On the below oscilloscope, Channel 3 is connected to the button SW2(PTC12), Channel 2 is connected to BLUE LED(PTD0) which toggled in PORT ISR after waking up from VLPS. Please check the attached project.

VLPS to RUN ISR  timing 17us.jpg

0 Kudos
Reply