Duration count value of IPWM in S32K3

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

Duration count value of IPWM in S32K3

跳至解决方案
2,240 次查看
dnewbe
Contributor III

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.

dnewbe_0-1675225750540.png

The ration of ActiveTime is not understand each PWM duration.

 

1 解答
2,115 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

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

在原帖中查看解决方案

7 回复数
2,075 次查看
dnewbe
Contributor III

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.

2,218 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

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

 

0 项奖励
回复
2,210 次查看
dnewbe
Contributor III

I did refer code is nxf78987's code.

 

So I did test to caputure PWM signal from other Board that board generate PWM signal each 1kHz. I verify that signal with oscilloscope.

 

So I attach my project. Pls review my fault. 

 

Thaks

0 项奖励
回复
2,192 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

Hello @dnewbe,

Thank you for the project, but I can't open the .mex file of the project.

Which RTD version do you use?

Can you use the latest version?

 

BR, Daniel

 

 

 

0 项奖励
回复
2,170 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

Hello @dnewbe,

Could you increase the period of EMIOS_ICU_BUS_A in the MCL driver from the 1 you selected?

danielmartynek_0-1675782100941.png

So that the counter does not everflow?

 

Thank you,

Daniel

0 项奖励
回复
2,154 次查看
dnewbe
Contributor III

Capture image of my setting is below.

dnewbe_1-1676010846038.png

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.

 

 

0 项奖励
回复
2,116 次查看
danielmartynek
NXP TechSupport
NXP TechSupport

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