Could you tell me why ActiveTime of IPWM is not understand value.
Below pic is my result when detect PWM signal that are each 1/1000, 250/1000, 500/1000, 750/1000, 999/1000 PWM signal.
Reference code is same as https://community.nxp.com/t5/S32K/S32K344-MCAL-IPWM-ICU-CAPTURE/m-p/1541889 example.
MCU is S32K312 and SDK is PlatformSDK_S32K3_2022_07_S32K312_M7 Ver 2.0.1.
The ration of ActiveTime is not understand each PWM duration.
已解决! 转到解答。
Hello @dnewbe,
I'm sorry for the delay.
I made some changes in the project, and it works right now, plase find the modified project attached.
The main change was the edge polarity of the EMIOS IPWM channel.
It can't be set in the configuration tool of the ICU driver, so I set it by a direct write to the register in main().
IP_EMIOS_1->CH.UC[1].C |= eMIOS_C_EDPOL(1);
Overflow is an even when the MCL EMIOS_0_MasteBus0 overflows from 65535 to 0.
Regards,
Daniel
I modify for your answer and I got wanted result.
My log of result is
PWM duty (1), period (1061)
Bright Level (0)
PWM duty (319), period (1061)
Bright Level (30)
PWM duty (637), period (1061)
Bright Level (60)
PWM duty (1060), period (1061)
Bright Level (100)
Thanks danielmartynek.
Hello @dnewbe,
There are two projects in the thread that you linked.
I don't knonw which one you use and what changes you made in it since then.
Can you share the project you have right now?
Double-check the EMIOs clock that the IPWM uses, it is possible that the counter overflows?
What is the period in which the counter overflows and what is the period of the PWM signal?
Thank you,
BR, Daniel
Capture image of my setting is below.
The result is not change when each Prescaler and Alternate is DIVIDE_1.
And tell me overflow is what and how do I check ?
Test I did
my board run 160 MHz is count PWM signal.
other board generate PWM signal each 1, 25, 50, 75, 99 duty of 1 KHz.
Hello @dnewbe,
I'm sorry for the delay.
I made some changes in the project, and it works right now, plase find the modified project attached.
The main change was the edge polarity of the EMIOS IPWM channel.
It can't be set in the configuration tool of the ICU driver, so I set it by a direct write to the register in main().
IP_EMIOS_1->CH.UC[1].C |= eMIOS_C_EDPOL(1);
Overflow is an even when the MCL EMIOS_0_MasteBus0 overflows from 65535 to 0.
Regards,
Daniel