<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: How do I detect both rising and falling edge interrupt with input capture? in Kinetis Microcontrollers</title>
    <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442078#M25929</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I figured it out. The issue was with my initialization of TPM1 as capture input and ISR:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="_jivemacro_uid_14443295574029489 jive_macro_code jive_text_macro" data-renderedposition="50_8_1155_672" jivemacro_uid="_14443295574029489" modifiedtitle="true"&gt;&lt;P&gt;void TPM1_CH0_Timer_Capture_Init(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SCGC5 |= SIM_SCGC5_PORTA_MASK;&amp;nbsp; /* Enable clock to PORTA */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 &amp;amp;= ~(PORT_PCR_PS_MASK);&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 |= PORT_PCR_PE_MASK;&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 = PORT_PCR_MUX(3);&amp;nbsp; /* Set Port A for TPM1CH0 input */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SCGC6 |= SIM_SCGC6_TPM1_MASK;&amp;nbsp; /* Enable clock to TPM1 */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 |= SIM_SOPT2_PLLFLLSEL_MASK;&amp;nbsp; /* Set for MCGPLLCLK with fixed divide by two */&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 &amp;amp;= ~(SIM_SOPT2_TPMSRC_MASK);&amp;nbsp; /* Clear TPMSRC bit filed to 2'b00 */&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 |= SIM_SOPT2_TPMSRC(1);&amp;nbsp; /* Set for MCGPLLCLK/2 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_SC = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_CONF = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_SC = TPM_SC_PS(TPM1_CLK_PRESCALE);&amp;nbsp; /* Setup prescaler to DIV by 64 */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_MOD = 0xFFFF;&amp;nbsp; /* Set max modulo */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Input Capture mode rising and falling edge interrupt */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHIE_MASK | TPM_CnSC_ELSA_MASK | TPM_CnSC_ELSB_MASK;&amp;nbsp; /* Set all these bits */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC &amp;amp;= ~(TPM_CnSC_MSA_MASK | TPM_CnSC_MSB_MASK);&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Clear these bits */&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;void FTM1_IRQHandler(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp; if(TPM1_C0SC &amp;amp; TPM_CnSC_CHF_MASK) {&amp;nbsp;&amp;nbsp; /* Check to see if channel capture interrupt flag is set */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHF_MASK;&amp;nbsp;&amp;nbsp; /* If set then clear interrupt flag */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC) { /* Check logic level of PTA12 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1_CNT = 0; /* If rising edge has hapened, reset the count to 0 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; if(!(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC)) { /*check level of PTA12 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLUE_LED_ON;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; val = TPM1_C0V; /* if LOW store the current count */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; return; &lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 08 Oct 2015 18:40:09 GMT</pubDate>
    <dc:creator>exgreyfox</dc:creator>
    <dc:date>2015-10-08T18:40:09Z</dc:date>
    <item>
      <title>How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442075#M25926</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I am trying to measure the pulse width of an input signal at TPM1_CH0 but I am having no luck. I am configuring TPM1_C0SC register to interrupt on both rising and falling edges as such:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="jive_macro_code _jivemacro_uid_14442524055591695 jive_text_macro" data-renderedposition="71_8_1155_96" jivemacro_uid="_14442524055591695"&gt;&lt;P&gt;/* Input Capture mode rising and falling edge interrupt */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_ELSA_MASK; &lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_ELSB_MASK; &lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC &amp;amp;= ~(TPM_CnSC_MSA_MASK);&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC &amp;amp;= ~(TPM_CnSC_MSB_MASK); &lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHIE_MASK;&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;And then inside main.c I execute the following code:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="jive_macro_code jive_text_macro _jivemacro_uid_14442526561092004" data-renderedposition="230_8_1155_112" jivemacro_uid="_14442526561092004"&gt;&lt;P&gt;enable_irq (INT_TPM1-16);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Enable Timer1 interrupt in NVIC */&lt;/P&gt;&lt;P&gt;TPM1_SC |= TPM_SC_CMOD(0);&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Enable the TPM1_CH0 Timer */&lt;/P&gt;&lt;P&gt;TPM1_CNT = 0;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Reset TPM1 */&lt;/P&gt;&lt;P&gt;DelayMs_NoIRQ(19);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* delay 19ms */&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;TPM1_SC |= TPM_SC_CMOD&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Disable the TPM1_CH0 Timer */&lt;/P&gt;&lt;P&gt;disable_irq (INT_TPM1-16);&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Disable Timer1 interrupt in NVIC */&lt;/P&gt;&lt;P&gt;val = falling_val - rising_val; /* calculate pulse width of input signal */&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;And inside the ISR i attempt to detect the logic level of the input signal to and decide whether it is falling or rising edge:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="jive_macro_code jive_text_macro _jivemacro_uid_14442527546487581" data-renderedposition="405_8_1155_272" jivemacro_uid="_14442527546487581" modifiedtitle="true"&gt;&lt;P&gt;void FTM1_IRQHandler(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp; if(TPM1_C0SC &amp;amp; TPM_CnSC_CHF_MASK)&lt;/P&gt;&lt;P&gt;&amp;nbsp; {&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHF_MASK;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; rising_val = TPM1_C0V;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(!(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC))&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; falling_val = TPM1_C0V;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; return;&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;But I am not having any luck as "val" returns wrong value. I am using KL25Z freedom board.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 07 Oct 2015 21:23:13 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442075#M25926</guid>
      <dc:creator>exgreyfox</dc:creator>
      <dc:date>2015-10-07T21:23:13Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442076#M25927</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi exgreyfox,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Another way to detect both rising and falling edge, just like the KL25 tpm sample code, use to channel.&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="17.jpg"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/59289i312F2707AF2A8C8F/image-size/large?v=v2&amp;amp;px=999" role="button" title="17.jpg" alt="17.jpg" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; You can find this sample code from this link:&lt;/P&gt;&lt;P&gt;&lt;A href="http://cache.freescale.com/files/32bit/software/KL25_SC.exe" title="http://cache.freescale.com/files/32bit/software/KL25_SC.exe"&gt;http://cache.freescale.com/files/32bit/software/KL25_SC.exe&lt;/A&gt;&lt;/P&gt;&lt;P&gt;path is : kl25_sc_rev10\klxx-sc-baremetal\build\iar\LQRUG_tpm_ex1&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Wish it helps you!&lt;/P&gt;&lt;P&gt;If you still have question, please contact me!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Have a great day,&lt;BR /&gt;Jingjing&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 08 Oct 2015 09:16:47 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442076#M25927</guid>
      <dc:creator>kerryzhou</dc:creator>
      <dc:date>2015-10-08T09:16:47Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442077#M25928</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks, but I don't see any source code in that directory. &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 08 Oct 2015 14:16:02 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442077#M25928</guid>
      <dc:creator>exgreyfox</dc:creator>
      <dc:date>2015-10-08T14:16:02Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442078#M25929</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I figured it out. The issue was with my initialization of TPM1 as capture input and ISR:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="_jivemacro_uid_14443295574029489 jive_macro_code jive_text_macro" data-renderedposition="50_8_1155_672" jivemacro_uid="_14443295574029489" modifiedtitle="true"&gt;&lt;P&gt;void TPM1_CH0_Timer_Capture_Init(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SCGC5 |= SIM_SCGC5_PORTA_MASK;&amp;nbsp; /* Enable clock to PORTA */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 &amp;amp;= ~(PORT_PCR_PS_MASK);&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 |= PORT_PCR_PE_MASK;&lt;/P&gt;&lt;P&gt;&amp;nbsp; PORTA_PCR12 = PORT_PCR_MUX(3);&amp;nbsp; /* Set Port A for TPM1CH0 input */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SCGC6 |= SIM_SCGC6_TPM1_MASK;&amp;nbsp; /* Enable clock to TPM1 */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 |= SIM_SOPT2_PLLFLLSEL_MASK;&amp;nbsp; /* Set for MCGPLLCLK with fixed divide by two */&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 &amp;amp;= ~(SIM_SOPT2_TPMSRC_MASK);&amp;nbsp; /* Clear TPMSRC bit filed to 2'b00 */&lt;/P&gt;&lt;P&gt;&amp;nbsp; SIM_SOPT2 |= SIM_SOPT2_TPMSRC(1);&amp;nbsp; /* Set for MCGPLLCLK/2 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_SC = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_CONF = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC = 0;&amp;nbsp; /* Blow away the control registers to ensure that the counter is not running */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_SC = TPM_SC_PS(TPM1_CLK_PRESCALE);&amp;nbsp; /* Setup prescaler to DIV by 64 */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_MOD = 0xFFFF;&amp;nbsp; /* Set max modulo */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Input Capture mode rising and falling edge interrupt */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHIE_MASK | TPM_CnSC_ELSA_MASK | TPM_CnSC_ELSB_MASK;&amp;nbsp; /* Set all these bits */&lt;/P&gt;&lt;P&gt;&amp;nbsp; TPM1_C0SC &amp;amp;= ~(TPM_CnSC_MSA_MASK | TPM_CnSC_MSB_MASK);&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Clear these bits */&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;void FTM1_IRQHandler(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp; if(TPM1_C0SC &amp;amp; TPM_CnSC_CHF_MASK) {&amp;nbsp;&amp;nbsp; /* Check to see if channel capture interrupt flag is set */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1_C0SC |= TPM_CnSC_CHF_MASK;&amp;nbsp;&amp;nbsp; /* If set then clear interrupt flag */&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC) { /* Check logic level of PTA12 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1_CNT = 0; /* If rising edge has hapened, reset the count to 0 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; if(!(GPIOA_PDIR &amp;amp; GPIO_PTA12_LOC)) { /*check level of PTA12 */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLUE_LED_ON;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; val = TPM1_C0V; /* if LOW store the current count */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&amp;nbsp; return; &lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 08 Oct 2015 18:40:09 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442078#M25929</guid>
      <dc:creator>exgreyfox</dc:creator>
      <dc:date>2015-10-08T18:40:09Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442079#M25930</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;That directory is the project path, if you want to find the source code, please goto this directory:&lt;/P&gt;&lt;P&gt;kl25_sc_rev10\klxx-sc-baremetal\src\projects\LQRUG_tpm_ex1&lt;/P&gt;&lt;P&gt;If your TPM1 capture pin is enough, you can use two capture pin instead of just one caputure pin associate the GPIO state read.&lt;/P&gt;&lt;P&gt;Two capture pin, on is for rising edge capture, another is for falling edge capture is more accurate than on capture pin with GPIO state read.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 09 Oct 2015 01:35:04 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442079#M25930</guid>
      <dc:creator>kerryzhou</dc:creator>
      <dc:date>2015-10-09T01:35:04Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442080#M25931</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi &lt;SPAN class=""&gt;&lt;A _jive_internal="true" class="" data-content-finding="Community" data-userid="248665" data-username="exgreyfox" href="https://community.nxp.com/people/exgreyfox"&gt;exgreyfox&lt;/A&gt;&lt;/SPAN&gt;,&lt;/P&gt;&lt;P&gt;Could you further explain on your fix? I just encountered the same issue as yours. Thanks.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 16 Dec 2016 10:32:57 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442080#M25931</guid>
      <dc:creator>ysoh-</dc:creator>
      <dc:date>2016-12-16T10:32:57Z</dc:date>
    </item>
    <item>
      <title>Re: How do I detect both rising and falling edge interrupt with input capture?</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442081#M25932</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;See also chapter 7 (from page 9) of &lt;/SPAN&gt;&lt;A class="jive-link-external-small" href="https://community.nxp.com/external-link.jspa?url=http%3A%2F%2Fwww.utasker.com%2Fdocs%2FuTasker%2FuTaskerHWTimers.PDF" rel="nofollow" target="_blank"&gt;http://www.utasker.com/docs/uTasker/uTaskerHWTimers.PDF&lt;/A&gt;&lt;BR /&gt;This shows a method for measuring PWM signals (on any Kinetis with a DMA channel) with very high accuracy and no interrupt overhead (50kHz PWM signals can be measured with &amp;lt; 0.01% accuracy with a processor with 60MHz bus clock).&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;It is not limited to pins that are connected to the TPM (or FlexTimer) and so has greater flexibility.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Mark&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 16 Dec 2016 13:32:14 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/How-do-I-detect-both-rising-and-falling-edge-interrupt-with/m-p/442081#M25932</guid>
      <dc:creator>mjbcswitzerland</dc:creator>
      <dc:date>2016-12-16T13:32:14Z</dc:date>
    </item>
  </channel>
</rss>

