<?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>MQX Software Solutions中的主题 Re: Double interrupt problem on FRDMK64F - MQX RTOS</title>
    <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358416#M11698</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Yes, this is just misunderstanding.&lt;/P&gt;&lt;P&gt;For the lwgpio, the Kinetis PORT module generates a single interrupt that asserts when the interrupt status flag is set for any enabled interrupt for that port.&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; font-family: 'Calibri','sans-serif';"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; font-family: 'Calibri','sans-serif';"&gt;Thus, we get into this vector by any enabled PORTx interrupt, and so we need to test PORTx_ISFR register in the interrupt service routine to find out, which pin of that port causes the interrupt request. (or, alternatively, lwgpio_int_get_flag() checks ISF bit of the specified PORTx_PCRn register).&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I hope it helps you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;RadekS&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>Mon, 09 Mar 2015 17:09:22 GMT</pubDate>
    <dc:creator>RadekS</dc:creator>
    <dc:date>2015-03-09T17:09:22Z</dc:date>
    <item>
      <title>Double interrupt problem on FRDMK64F - MQX RTOS</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358415#M11697</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Dear All,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm working with FRDMK64F board with MQX RTOS s/w and facing some weird issue when I used 2 interrupts.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;i.e, I'm getting continuous interrupts from second interrupt and nothing from first interrupt (ISR)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I've taken GPIO code for reference from following location.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;C:\Freescale\Freescale_MQX_4_1\mqx\examples\gpio&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I need PTC2 and PTC3 for interrupt generations.&lt;/P&gt;&lt;P&gt;Actually I want to develop wiegand protocol.&lt;/P&gt;&lt;P&gt;PTC2 is for DATA0 and PTC3 is for DATA1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm getting correct no's of output when I enabled only one interrupt and other one set to disabled (lwgpio_int_enable(&amp;amp;d0, FALSE);)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This is my code,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;/* Titus */&lt;/P&gt;&lt;P&gt;#define BSP_SWPTC2&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (GPIO_PORT_C | GPIO_PIN2)&lt;/P&gt;&lt;P&gt;#define BSP_SWPTC3&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (GPIO_PORT_C | GPIO_PIN3)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;#define BSP_DATA0&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; BSP_SWPTC2&lt;/P&gt;&lt;P&gt;#define BSP_DATA1&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; BSP_SWPTC3&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;#define BSP_PTC2D0_MUX_GPIO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (LWGPIO_MUX_C2_GPIO)&lt;/P&gt;&lt;P&gt;#define BSP_PTC3D1_MUX_GPIO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (LWGPIO_MUX_C3_GPIO)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;#define BSP_PTC2_MUX_GPIO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BSP_PTC2D0_MUX_GPIO&lt;/P&gt;&lt;P&gt;#define BSP_PTC2_MUX_IRQ&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BSP_PTC2D0_MUX_GPIO&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;#define BSP_PTC3_MUX_GPIO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BSP_PTC3D1_MUX_GPIO&lt;/P&gt;&lt;P&gt;#define BSP_PTC3_MUX_IRQ&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BSP_PTC3D1_MUX_GPIO&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;void int_service_routine_d1(void *pin)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; lwgpio_int_clear_flag((LWGPIO_STRUCT_PTR) pin);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; printf("DATA1 interrupt raised\n");&lt;/P&gt;&lt;P&gt;//&amp;nbsp;&amp;nbsp;&amp;nbsp; count++;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; _lwsem_post(&amp;amp;lwsem);&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;void int_service_routine_d0(void *pin)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; lwgpio_int_clear_flag((LWGPIO_STRUCT_PTR) pin);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; printf("DATA0 interrupt raised\n");&lt;/P&gt;&lt;P&gt;//&amp;nbsp;&amp;nbsp;&amp;nbsp; count++;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; _lwsem_post(&amp;amp;lwsem2);&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;if (!lwgpio_init(&amp;amp;d0, BSP_DATA0, LWGPIO_DIR_INPUT, LWGPIO_VALUE_NOCHANGE))&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;{&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;printf("Initializing DATA0 as input failed.\n");&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_task_block();&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;}&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;if (!lwgpio_init(&amp;amp;d1, BSP_DATA1, LWGPIO_DIR_INPUT, LWGPIO_VALUE_NOCHANGE))&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;{&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;printf("Initializing DATA1 as input failed.\n");&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_task_block();&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;}&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_set_functionality(&amp;amp;d0, BSP_PTC2_MUX_IRQ);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_set_attribute(&amp;amp;d0, LWGPIO_ATTR_PULL_UP, LWGPIO_AVAL_ENABLE);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_set_functionality(&amp;amp;d1, BSP_PTC3_MUX_IRQ);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_set_attribute(&amp;amp;d1, LWGPIO_ATTR_PULL_UP, LWGPIO_AVAL_ENABLE);&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* enable gpio functionality for given pin, react on falling edge */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;if (!lwgpio_int_init(&amp;amp;d0, LWGPIO_INT_MODE_FALLING))&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;{&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;printf("Initializing DATA0 for interrupt failed.\n");&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_task_block();&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;}&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* enable gpio functionality for given pin, react on falling edge */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;if (!lwgpio_int_init(&amp;amp;d1, LWGPIO_INT_MODE_FALLING))&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;{&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;printf("Initializing DATA1 for interrupt failed.\n");&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_task_block();&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;}&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* install gpio interrupt service routine */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_int_install_isr(lwgpio_int_get_vector(&amp;amp;d0), int_service_routine_d0, (void *) &amp;amp;d0);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* set the interrupt level, and unmask the interrupt in interrupt controller */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_bsp_int_init(lwgpio_int_get_vector(&amp;amp;d0), 3, 0, TRUE);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* enable interrupt on GPIO peripheral module */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_int_enable(&amp;amp;d0, TRUE);&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* install gpio interrupt service routine */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_int_install_isr(lwgpio_int_get_vector(&amp;amp;d1), int_service_routine_d1, (void *) &amp;amp;d1);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* set the interrupt level, and unmask the interrupt in interrupt controller */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;_bsp_int_init(lwgpio_int_get_vector(&amp;amp;d1), 3, 0, TRUE);&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;/* enable interrupt on GPIO peripheral module */&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/TD&gt;&lt;TD&gt;lwgpio_int_enable(&amp;amp;d1, TRUE);&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Now I'm getting interrupt continuously from "int_service_routine_d1" ISR but nothing got from "int_service_routine_d0"&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Both interrupt code was working good but it won't work when I enabled both the interrupts.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Is that anything I'm missing or any change required here ?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Could you please support us on this.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 04 Mar 2015 16:27:19 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358415#M11697</guid>
      <dc:creator>titusstalin</dc:creator>
      <dc:date>2015-03-04T16:27:19Z</dc:date>
    </item>
    <item>
      <title>Re: Double interrupt problem on FRDMK64F - MQX RTOS</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358416#M11698</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Yes, this is just misunderstanding.&lt;/P&gt;&lt;P&gt;For the lwgpio, the Kinetis PORT module generates a single interrupt that asserts when the interrupt status flag is set for any enabled interrupt for that port.&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; font-family: 'Calibri','sans-serif';"&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; font-family: 'Calibri','sans-serif';"&gt;Thus, we get into this vector by any enabled PORTx interrupt, and so we need to test PORTx_ISFR register in the interrupt service routine to find out, which pin of that port causes the interrupt request. (or, alternatively, lwgpio_int_get_flag() checks ISF bit of the specified PORTx_PCRn register).&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I hope it helps you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;RadekS&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>Mon, 09 Mar 2015 17:09:22 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358416#M11698</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2015-03-09T17:09:22Z</dc:date>
    </item>
    <item>
      <title>Re: Double interrupt problem on FRDMK64F - MQX RTOS</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358417#M11699</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks RadekS.&lt;/P&gt;&lt;P&gt;Actually I've used different port for each GPIO.&lt;/P&gt;&lt;P&gt;Say, I've used PTC3 and PTB9 instead of PTC2 and PTC3.&lt;/P&gt;&lt;P&gt;Then I got expected results, so it seems you are right.&lt;/P&gt;&lt;P&gt;Could you share the code snippet for that, to find which port pin got interrupted which needs to be added in ISR.&lt;/P&gt;&lt;P&gt;Thank you.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 16 Mar 2015 07:15:06 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358417#M11699</guid>
      <dc:creator>titusstalin</dc:creator>
      <dc:date>2015-03-16T07:15:06Z</dc:date>
    </item>
    <item>
      <title>Re: Re: Double interrupt problem on FRDMK64F - MQX RTOS</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358418#M11700</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;For example:&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="jive_text_macro jive_macro_code _jivemacro_uid_14265116501452164" jivemacro_uid="_14265116501452164" modifiedtitle="true"&gt;
&lt;P&gt;/******************************************************************************&lt;/P&gt;
&lt;P&gt;*&lt;/P&gt;
&lt;P&gt;* Functio Name&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; : int_service_routine&lt;/P&gt;
&lt;P&gt;* Comments&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; : The interrupt service routine triggered by gpio&lt;/P&gt;
&lt;P&gt;*&lt;/P&gt;
&lt;P&gt;******************************************************************************/&lt;/P&gt;
&lt;P&gt;void int_service_routine(void *pin)&lt;/P&gt;
&lt;P&gt;{&lt;/P&gt;
&lt;P&gt;PORT_MemMapPtr&amp;nbsp; pctl;&lt;/P&gt;
&lt;P&gt;pctl = (PORT_MemMapPtr)PORTC_BASE_PTR;&lt;/P&gt;
&lt;P&gt;if (pctl-&amp;gt;PCR[1] &amp;amp; PORT_PCR_ISF_MASK)&lt;/P&gt;
&lt;P&gt;&amp;nbsp; {&lt;/P&gt;
&lt;P&gt;&amp;nbsp; //your code&lt;/P&gt;
&lt;P&gt;&amp;nbsp; pctl-&amp;gt;PCR[1] |= PORT_PCR_ISF_MASK;;&lt;/P&gt;
&lt;P&gt;&amp;nbsp; }&lt;/P&gt;
&lt;P&gt;if (pctl-&amp;gt;PCR[2] &amp;amp; PORT_PCR_ISF_MASK)&lt;/P&gt;
&lt;P&gt;&amp;nbsp; {&lt;/P&gt;
&lt;P&gt;&amp;nbsp; //your code&lt;/P&gt;
&lt;P&gt;&amp;nbsp; pctl-&amp;gt;PCR[2] |= PORT_PCR_ISF_MASK;;&lt;/P&gt;
&lt;P&gt;&amp;nbsp; }&amp;nbsp; &lt;/P&gt;
&lt;P&gt;&amp;nbsp; _lwsem_post(&amp;amp;lwsem);&lt;/P&gt;
&lt;P&gt;}&lt;/P&gt;
&lt;/PRE&gt;&lt;P&gt;OR&lt;/P&gt;&lt;PRE __default_attr="c++" __jive_macro_name="code" class="jive_text_macro _jivemacro_uid_14265117469327568 jive_macro_code" jivemacro_uid="_14265117469327568" modifiedtitle="true"&gt;
&lt;P&gt;/******************************************************************************&lt;/P&gt;
&lt;P&gt;*&lt;/P&gt;
&lt;P&gt;* Functio Name&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; : int_service_routine&lt;/P&gt;
&lt;P&gt;* Comments&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; : The interrupt service routine triggered by gpio&lt;/P&gt;
&lt;P&gt;*&lt;/P&gt;
&lt;P&gt;******************************************************************************/&lt;/P&gt;
&lt;P&gt;void int_service_routine(void *pin)&lt;/P&gt;
&lt;P&gt;{&lt;/P&gt;
&lt;P&gt;if (lwgpio_int_get_flag(&amp;amp;btn1) == TRUE)&lt;/P&gt;
&lt;P&gt;&amp;nbsp; {&lt;/P&gt;
&lt;P&gt;&amp;nbsp; //your code&lt;/P&gt;
&lt;P&gt;&amp;nbsp; lwgpio_int_clear_flag(&amp;amp;btn1);&lt;/P&gt;
&lt;P&gt;&amp;nbsp; }&lt;/P&gt;
&lt;P&gt;if (lwgpio_int_get_flag(&amp;amp;btn2) == TRUE)&lt;/P&gt;
&lt;P&gt;&amp;nbsp; {&lt;/P&gt;
&lt;P&gt;&amp;nbsp; //your code&lt;/P&gt;
&lt;P&gt;&amp;nbsp; lwgpio_int_clear_flag(&amp;amp;btn2);&lt;/P&gt;
&lt;P&gt;&amp;nbsp; }&lt;/P&gt;
&lt;P&gt;&amp;nbsp; _lwsem_post(&amp;amp;lwsem);&lt;/P&gt;
&lt;P&gt;}&lt;/P&gt;
&lt;/PRE&gt;&lt;P&gt;I hope it helps you.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 16 Mar 2015 13:16:21 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358418#M11700</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2015-03-16T13:16:21Z</dc:date>
    </item>
    <item>
      <title>Re: Re: Double interrupt problem on FRDMK64F - MQX RTOS</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358419#M11701</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thank you so much.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 16 Mar 2015 13:31:26 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Double-interrupt-problem-on-FRDMK64F-MQX-RTOS/m-p/358419#M11701</guid>
      <dc:creator>titusstalin</dc:creator>
      <dc:date>2015-03-16T13:31:26Z</dc:date>
    </item>
  </channel>
</rss>

