FTM operates with wrong clock when FIRC is selected as input clock?!

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

FTM operates with wrong clock when FIRC is selected as input clock?!

Jump to solution
1,994 Views
JeorgeB
Contributor III

Hi,

 

I use S32K144 and st the clock as following with using SOSC:

SOSC : 8MHz,  SPLL:160MHz, CORE_CLK: 80MHz, BUS_CLK: 40MHz; CLK_SRC_FIRC_DIV1:48MHz.

I select internal clock as input clock for FTM0 which is CLK_SRC_FIRC_DIV1 (48MHz), but when I run timer in normal counter and observe compare interrupt, it seems that timer work with 32MHz clock !!!

Next, I changed the CLK_SRC_FIRC_DIV1 to 2 and FTM works with correct frequency which is 24MHz !!!

FTM works fine with SOSC, SIRC, SPLL_DIV_2, SYS_CLK, LPO_CLK, but problem is when using FIRC as clock source for FTM with 48MHz configuration!!

 

has anybody any comment !

0 Kudos
Reply
1 Solution
1,953 Views
Robin_Shen
NXP TechSupport
NXP TechSupport

Hi JeorgeB,

According to the description of "47.5.1.1 Counter clock source" and "Table 27-9. Peripheral module clocking":
The frequency of the fixed frequency clock(RTC_CLK) must not exceed 1/2 of the FTM input clock frequency(FTM System clock SYS_CLK)..
The frequency of the external clock source(TCLK0 \ TCLK1 \ TCLK2 \ SOSCDIV1_CLK \ SIRCDIV1_CLK \ FIRCDIV1_CLK \ SPLLDIV1_CLK) must not exceed 1/4 of the FTM input clock frequency(FTM System clock SYS_CLK).

47.5.1.1 Counter clock source.png

Table 27-9. Peripheral module clocking.png

Due to: SYS_CLK = CORE_CLK = 80MHz
So:
Frequency of external clock source should not exceed 20MHz.
Frequency of fixed clock source should not exceed 40MHz.

But it seems to conflict with your test results. Would you please attached your test project? So that I can test it faster.

Best Regards,
Robin

 

 

View solution in original post

0 Kudos
Reply
3 Replies
1,992 Views
JeorgeB
Contributor III

I test an alternative clock source which in FTM_CLOCK_SOURCE_FIXEDCLK is used as FTM input clock. FIRC_DIV_1 is selected as RTC_CLK output which is "FTM_CLOCK_SOURCE_FIXEDCLK". 

But the result is the same as previous. When I change the prescaler in FTM registers, clock changes to : 32MHz, 16MHz, 8MHz , .... . It seems when choosing frequency of the FIRC (48MHz) as FTM input in any method (either with PCC_FLEXTMRn[PCS] or Fixed frequency clock) the clock changes from 48MHz to 32MHz !!!

 

P.S. I monitor the RTC_CLK in CLKOUT pin and there is a 48MHz signal which is correct !

0 Kudos
Reply
1,984 Views
JeorgeB
Contributor III

meanwhile reading RM, I see 2 points:

1. as you can see in below image, there is a synchronizer block between External clocks (which can include FIRC_DIV_1, SIR_DIV_1, SPLL_DIV_1 or TCLK[0:1]) and the FTM input. Unfortunately additional explanation about this block is not available and maybe this block is cause of the my question in first post. 

synchronizer.jpg

Has anybody any idea?

 

2. In continue, there is one paragraph about this block which is vague also:

external clock detail.JPG

 

what is purpose of these details about FTM?

 

Thanks.

0 Kudos
Reply
1,954 Views
Robin_Shen
NXP TechSupport
NXP TechSupport

Hi JeorgeB,

According to the description of "47.5.1.1 Counter clock source" and "Table 27-9. Peripheral module clocking":
The frequency of the fixed frequency clock(RTC_CLK) must not exceed 1/2 of the FTM input clock frequency(FTM System clock SYS_CLK)..
The frequency of the external clock source(TCLK0 \ TCLK1 \ TCLK2 \ SOSCDIV1_CLK \ SIRCDIV1_CLK \ FIRCDIV1_CLK \ SPLLDIV1_CLK) must not exceed 1/4 of the FTM input clock frequency(FTM System clock SYS_CLK).

47.5.1.1 Counter clock source.png

Table 27-9. Peripheral module clocking.png

Due to: SYS_CLK = CORE_CLK = 80MHz
So:
Frequency of external clock source should not exceed 20MHz.
Frequency of fixed clock source should not exceed 40MHz.

But it seems to conflict with your test results. Would you please attached your test project? So that I can test it faster.

Best Regards,
Robin

 

 

0 Kudos
Reply