Trigger pulse delay longer than expected — is SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY causing inaccur

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

Trigger pulse delay longer than expected — is SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY causing inaccur

472件の閲覧回数
Manjunathb
Contributor II

 

Hello NXP Team,

I’m working with an NXP MCU based on the Cortex-M33 core (e.g., i.MX93 mcimx9352), and I noticed that when I use:

SDK_DelayAtLeastUs(10, SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY);

 

to generate a 10 µs trigger pulse, the actual pulse width measured on the oscilloscope is around 16 µs.

I’m using the default SDK definition:

#define SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY (250000000UL)

which, according to the datasheet, is the maximum clock frequency supported by the M33 core.

  1. Is SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY supposed to match the actual core frequency at runtime, or is it just a max-safe default?

  2. Is there a recommended way to dynamically query the actual core clock and pass it to SDK_DelayAtLeastUs() instead of relying on the macro?

Any clarification or best practices would be appreciated. Thanks in advance!

Best regards
Manjunath B

 

i.MX93 CONTROL-AND-TIMING-RELAY 

ラベル(1)
0 件の賞賛
返信
1 返信

400件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi,

SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY is not real frequency, it's the maximum value.

You can use CLOCK_GetFreq to get real frequency, the pass this value to SDK_DelayAtLeastUs.


Best Regards,
Zhiming

0 件の賞賛
返信
%3CLINGO-SUB%20id%3D%22lingo-sub-2132761%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%E3%83%91%E3%83%AB%E3%82%B9%E3%81%AE%E9%81%85%E5%BB%B6%E3%81%8C%E4%BA%88%E6%83%B3%E3%82%88%E3%82%8A%E3%82%82%E9%95%B7%E3%81%84%20-%20SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY%E3%81%8C%E4%B8%8D%E6%AD%A3%E7%A2%BA%E3%81%AA%E5%8E%9F%E5%9B%A0%E3%81%A8%E3%81%AA%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2132761%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CBR%20%2F%3E%3CP%3ENXP%E3%83%81%E3%83%BC%E3%83%A0%E3%81%AE%E7%9A%86%E6%A7%98%E3%80%81%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%82%3C%2FP%3E%3CP%3E%E7%A7%81%E3%81%AF%20Cortex-M33%20%E3%82%B3%E3%82%A2%20(%E4%BE%8B%3A%20i.MX93%20mcimx9352)%20%E3%82%92%E3%83%99%E3%83%BC%E3%82%B9%E3%81%AB%E3%81%97%E3%81%9F%20NXP%20MCU%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E6%AC%A1%E3%81%AE%E5%A0%B4%E5%90%88%E3%81%AB%E6%AC%A1%E3%81%AE%E3%81%93%E3%81%A8%E3%81%AB%E6%B0%97%E4%BB%98%E3%81%8D%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FP%3E%3CDIV%20class%3D%22%22%3E%3CDIV%20class%3D%22%22%3E%3CSPAN%3ESDK_DelayAtLeastUs(%20%3CSPAN%20class%3D%22%22%3E10%3C%2FSPAN%3E%20%E3%80%81%20SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY)%3B%20%3C%2FSPAN%3E%3C%2FDIV%3E%3C%2FDIV%3E%3CBR%20%2F%3E%3CP%3E10%20%C2%B5s%20%E3%81%AE%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%20%E3%83%91%E3%83%AB%E3%82%B9%E3%82%92%E7%94%9F%E6%88%90%E3%81%99%E3%82%8B%E5%A0%B4%E5%90%88%E3%80%81%E3%82%AA%E3%82%B7%E3%83%AD%E3%82%B9%E3%82%B3%E3%83%BC%E3%83%97%E3%81%A7%E6%B8%AC%E5%AE%9A%E3%81%95%E3%82%8C%E3%82%8B%E5%AE%9F%E9%9A%9B%E3%81%AE%E3%83%91%E3%83%AB%E3%82%B9%E5%B9%85%E3%81%AF%E7%B4%84%3CSTRONG%3E16%20%C2%B5s%3C%2FSTRONG%3E%E3%81%AB%E3%81%AA%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%81%AE%20SDK%20%E5%AE%9A%E7%BE%A9%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%3A%3C%2FP%3E%3CDIV%20class%3D%22%22%3E%3CDIV%20class%3D%22%22%3E%3CSPAN%3E%3CSPAN%20class%3D%22%22%3E%23%20SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY%20(250000000UL)%3CSPAN%20class%3D%22%22%3E%E3%82%92%E5%AE%9A%E7%BE%A9%E3%81%97%E3%81%BE%E3%81%99%3C%2FSPAN%3E%3C%2FSPAN%3E%20%3C%2FSPAN%3E%3C%2FDIV%3E%3C%2FDIV%3E%3CP%3E%E3%83%87%E3%83%BC%E3%82%BF%E3%82%B7%E3%83%BC%E3%83%88%E3%81%AB%E3%82%88%E3%82%8B%E3%81%A8%E3%80%81%E3%81%93%E3%82%8C%E3%81%AF%20M33%20%E3%82%B3%E3%82%A2%E3%81%A7%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E3%81%95%E3%82%8C%E3%82%8B%3CSTRONG%3E%E6%9C%80%E5%A4%A7%3C%2FSTRONG%3E%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%E5%91%A8%E6%B3%A2%E6%95%B0%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%3COL%3E%3CLI%3E%3CP%3ESDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY%20%E3%81%AF%3CSTRONG%3E%E5%AE%9F%E8%A1%8C%E6%99%82%E3%81%AE%E5%AE%9F%E9%9A%9B%E3%81%AE%E3%82%B3%E3%82%A2%E5%91%A8%E6%B3%A2%E6%95%B0%3C%2FSTRONG%3E%E3%81%A8%E4%B8%80%E8%87%B4%E3%81%99%E3%82%8B%E3%81%AF%E3%81%9A%E3%81%A7%E3%81%99%E3%81%8B%E3%80%81%E3%81%9D%E3%82%8C%E3%81%A8%E3%82%82%E6%9C%80%E5%A4%A7%E5%80%A4%E5%AE%89%E5%85%A8%E3%81%AA%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%81%A7%E3%81%99%E3%81%8B%3F%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E3%83%9E%E3%82%AF%E3%83%AD%E3%81%AB%E9%A0%BC%E3%82%8B%E3%81%AE%E3%81%A7%E3%81%AF%E3%81%AA%E3%81%8F%E3%80%81%E5%AE%9F%E9%9A%9B%E3%81%AE%E3%82%B3%E3%82%A2%20%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%E3%82%92%E5%8B%95%E7%9A%84%E3%81%AB%E7%85%A7%E4%BC%9A%E3%81%97%E3%81%A6%20SDK_DelayAtLeastUs()%20%E3%81%AB%E6%B8%A1%E3%81%99%E6%8E%A8%E5%A5%A8%E6%96%B9%E6%B3%95%E3%81%AF%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F%3C%2FP%3E%3C%2FLI%3E%3C%2FOL%3E%3CP%3E%E8%AA%AC%E6%98%8E%E3%82%84%E3%83%99%E3%82%B9%E3%83%88%E3%83%97%E3%83%A9%E3%82%AF%E3%83%86%E3%82%A3%E3%82%B9%E3%81%8C%E3%81%82%E3%82%8C%E3%81%B0%E6%95%99%E3%81%88%E3%81%A6%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%82%8B%E3%81%A8%E5%B9%B8%E3%81%84%E3%81%A7%E3%81%99%E3%80%82%E5%89%8D%E3%82%82%E3%81%A3%E3%81%A6%E6%84%9F%E8%AC%9D%E3%81%97%E3%81%BE%E3%81%99%EF%BC%81%3C%2FP%3E%3CP%3E%E3%82%88%E3%82%8D%E3%81%97%E3%81%8F%E3%81%8A%E9%A1%98%E3%81%84%E3%81%97%E3%81%BE%E3%81%99%3CBR%20%2F%3E%E3%83%9E%E3%83%B3%E3%82%B8%E3%83%A5%E3%83%8A%E3%82%B9B%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fc-pwmxy87654%2Fi.MX93%2Fpd-p%2Fi.MX93%22%20class%3D%22lia-product-mention%22%20data-product%3D%22509-1%22%20target%3D%22_blank%22%3Ei.MX93%3C%2FA%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fc-pwmxy87654%2FCONTROL-AND-TIMING-RELAY%2Fpd-p%2FCONTROL-AND-TIMING-RELAY%22%20class%3D%22lia-product-mention%22%20data-product%3D%222561-1%22%20target%3D%22_blank%22%3E%E5%88%B6%E5%BE%A1%E3%81%8A%E3%82%88%E3%81%B3%E3%82%BF%E3%82%A4%E3%83%9F%E3%83%B3%E3%82%B0%E3%83%AA%E3%83%AC%E3%83%BC%3C%2FA%3E%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-2132761%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CLINGO-LABEL%3E%E3%82%AF%E3%83%AD%E3%83%83%E3%82%AF%7C%E3%82%BF%E3%82%A4%E3%83%9E%E3%83%BC%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2136921%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Trigger%20pulse%20delay%20longer%20than%20expected%20%E2%80%94%20is%20SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY%20causing%20ina%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2136921%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%81%3CBR%20%2F%3E%3CBR%20%2F%3E%20SDK_DEVICE_MAXIMUM_CPU_CLOCK_FREQUENCY%20%E3%81%AF%E5%AE%9F%E9%9A%9B%E3%81%AE%E5%91%A8%E6%B3%A2%E6%95%B0%E3%81%A7%E3%81%AF%E3%81%AA%E3%81%8F%E3%80%81%E6%9C%80%E5%A4%A7%E5%80%A4%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3ECLOCK_GetFreq%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E5%AE%9F%E9%9A%9B%E3%81%AE%E5%91%A8%E6%B3%A2%E6%95%B0%E3%82%92%E5%8F%96%E5%BE%97%E3%81%97%E3%80%81%E3%81%93%E3%81%AE%E5%80%A4%E3%82%92%3CSPAN%3ESDK_DelayAtLeastUs%20%E3%81%AB%E6%B8%A1%E3%81%99CAN%E3%80%82%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%3CBR%20%2F%3E%E3%82%88%E3%82%8D%E3%81%97%E3%81%8F%E3%81%8A%E9%A1%98%E3%81%84%E3%81%97%E3%81%BE%E3%81%99%E3%80%81%3CBR%20%2F%3E%E5%BF%97%E6%98%8E%3C%2FP%3E%3C%2FLINGO-BODY%3E