<?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>ColdFire/68K Microcontrollers and ProcessorsのトピックRe: MCF5235 Interrupt enable/disable spuriousity</title>
    <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690230#M13267</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;There's another thing that is very commonly gotten wrong.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Interrupt handling is like the little/big-endian problems. If it doesn't scare you then you don't understand it properly :-)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Most chip manufacturers get interrupt handing badly wrong. Motorola got it dead right. Maybe they patented "the one true solution" so nobody else could use it, or maybe the other manufacturers didn't realise the True Majesty of Motorola's Solution. Which carried over into most of Freescale's parts.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The "solution" is called "W1C".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If you don't know how insanely great this is then you might not be using it properly, and so your problem may not be the interrupt setting, but in your interrupt service code.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Of course I've detailed this before, so I suggest you read through this post to see if it shows up any problems in your interrupt handler.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;A _jive_internal="true" href="https://community.nxp.com/message/105778?commentID=105778#comment-105778"&gt;https://community.nxp.com/message/105778?commentID=105778#comment-105778&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If dumping the registers around your setting code doesn't show the problem then it might be with your use of W1C.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 20 Jul 2017 03:21:09 GMT</pubDate>
    <dc:creator>TomE</dc:creator>
    <dc:date>2017-07-20T03:21:09Z</dc:date>
    <item>
      <title>MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690218#M13255</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I have a problem when enabling/disabling single EPORT-Interrupts.&lt;/P&gt;&lt;P&gt;I do it this way:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;void EPORT::InterruptOn() /*-FUNCTION HEADER-------------------------------------------------------- | description : enables a certain interrupt | side effects : | parameters : | return value : none | precondition : | postcondition: +--END FUNCTION HEADER--------------------------------------------------*/ { MCF_EPORT_EPIER |= MCF_EPORT_EPIER_EPIEx(m_byPortNr); } void EPORT::InterruptOff() /*-FUNCTION HEADER-------------------------------------------------------- | description : disables a certain interrupt | side effects : | parameters : | return value : none | precondition : | postcondition: +--END FUNCTION HEADER--------------------------------------------------*/ { MCF_EPORT_EPIER &amp;amp;= ~MCF_EPORT_EPIER_EPIEx(m_byPortNr); }&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Do you have an idea what I´m doing wrong?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The behavior is like that:&lt;/P&gt;&lt;P&gt;When I disable a certain interrupt other interrupts also get disabled, not all of them, just some, and those are always the same.&lt;/P&gt;&lt;P&gt;For example when I disable port:1 -&amp;gt; port:3 also gets disabled&lt;/P&gt;&lt;P&gt;or &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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; disable Port:3 -&amp;gt; port:5 also gets disabled&lt;/P&gt;&lt;P&gt;or &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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; disable Port:5 -&amp;gt; port:3 also gets disabled&lt;/P&gt;&lt;P&gt;or &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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; disable Port:7 -&amp;gt; port:1 also gets disabled&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I really would appreciate some help :smileyhappy:&lt;/P&gt;&lt;P&gt;regards, Richard&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 11 Jul 2017 14:42:08 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690218#M13255</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-11T14:42:08Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690219#M13256</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;gt; Do you have an idea what I´m doing wrong?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I can't read the scrambled mess you've pasted in. Try reformatting it so it can be read.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Hint - click on "use advanced editor" and then click on the "dots" to get the "Expanded Toolbar".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Then click on the "More" and "Syntax Highlighter" and then paste your code in THERE with an appropriate "Language".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;They really couldn't have hidden this much deeper. If I wanted to navigate a "maze of twisty little passages" to find hidden treasures, I'd play Zork.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Other sites I use have an "Insert Code" BUTTON on the main toolbar, as that's what we're wanting to do most of the time.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I've just noticed a "&amp;lt;&amp;gt;" on the Advanced Toolbar which is called "Source Code". I thought that might be for pasting "Source Code" in, but it shows the HTML "source code" of this page itself, in case you want to try and write raw HTML to bypass the interface they've given you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You also need to provide some sort of reference as to where the "MCF_EPORT_EPIER" and "MCF_EPORT_EPIER_EPIEx()" definitions come from, preferably links where we can read the header files that define these. Given they're probably CW and not on the internet, you should paste parts of the defining headers in so we can see what those macros actually do.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;What actual values are you passing in as "m_byPortNr"? Valid values are probably "1" to "7".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;It would also be worth disassembling your code and see what assembly instructions it is actually turning into. That might give a hint as to the problem.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You should also disable interrupts around these operations or you'll risk getting Spurious Interrupts.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Jul 2017 07:08:18 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690219#M13256</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-12T07:08:18Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690220#M13257</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thank you very much for the help!!&lt;/P&gt;&lt;P&gt;I have not found the "Syntax highlighter" button... &lt;/P&gt;&lt;P&gt;EPORT.cpp&lt;/P&gt;&lt;PRE class="language-cpp line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;
EPORT&lt;SPAN class="operator token"&gt;::&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;InterruptOn&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;/*-FUNCTION HEADER--------------------------------------------------------
|&amp;nbsp;&amp;nbsp; description&amp;nbsp; : enables a certain interrupt
|&amp;nbsp;&amp;nbsp; side effects :
|&amp;nbsp;&amp;nbsp; parameters&amp;nbsp;&amp;nbsp; :
|&amp;nbsp;&amp;nbsp; return value : none
|&amp;nbsp;&amp;nbsp; precondition :
|&amp;nbsp;&amp;nbsp; postcondition:
+--END FUNCTION HEADER--------------------------------------------------*/&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_disable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPIER &lt;SPAN class="operator token"&gt;|&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;MCF_EPORT_EPIER_EPIEx&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_enable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;
&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;
EPORT&lt;SPAN class="operator token"&gt;::&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;InterruptOff&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;/*-FUNCTION HEADER--------------------------------------------------------
|&amp;nbsp;&amp;nbsp; description&amp;nbsp; : disables a certain interrupt
|&amp;nbsp;&amp;nbsp; side effects :
|&amp;nbsp;&amp;nbsp; parameters&amp;nbsp;&amp;nbsp; :
|&amp;nbsp;&amp;nbsp; return value : none
|&amp;nbsp;&amp;nbsp; precondition :
|&amp;nbsp;&amp;nbsp; postcondition:
+--END FUNCTION HEADER--------------------------------------------------*/&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_disable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPIER &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;MCF_EPORT_EPIER_EPIEx&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_enable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;mcf523x_eport.h:&lt;/P&gt;&lt;PRE class="language-cpp line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="property macro token"&gt;#define MCF_EPORT_EPIER&amp;nbsp;&amp;nbsp;&amp;nbsp; (*(vuint8 *)(void*)(&amp;amp;__IPSBAR[0x130003]))&lt;/SPAN&gt;
&lt;SPAN class="property macro token"&gt;#define MCF_EPORT_EPIER_EPIEx(x)&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (0x01)&amp;lt;&amp;lt;(x)&lt;/SPAN&gt;&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;m_byPortNr is the member variable of the EPORT defining the port and yes it´s 1-7.&lt;/P&gt;&lt;PRE class="language-c line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="keyword token"&gt;asm&lt;/SPAN&gt; &lt;SPAN class="keyword token"&gt;int&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;asm_set_ipl&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;UINT32&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;link&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;a6&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;#&lt;SPAN class="operator token"&gt;-&lt;/SPAN&gt;&lt;SPAN class="number token"&gt;8&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;movem&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;d6&lt;SPAN class="operator token"&gt;-&lt;/SPAN&gt;d7&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;sp&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;move&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;w&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;sr&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d7&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* current sr&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;move&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;d7&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* prepare return value&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;andi&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;#&lt;SPAN class="number token"&gt;0x0700&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* mask out IPL&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;lsr&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;#&lt;SPAN class="number token"&gt;8&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d0&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* IPL&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;move&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;8&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;a6&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d6&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* get argument&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;andi&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;#&lt;SPAN class="number token"&gt;0x07&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d6&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* least significant three bits&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;lsl&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;#&lt;SPAN class="number token"&gt;8&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d6&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* move over to make mask&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;andi&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;#&lt;SPAN class="number token"&gt;0x0000F8FF&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d7&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;/* zero out current IPL&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;or&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;d6&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d7&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;&lt;SPAN class="comment token"&gt;/* place new IPL in sr&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;move&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;w&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;d7&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;sr

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;movem&lt;SPAN class="punctuation token"&gt;.&lt;/SPAN&gt;l&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;sp&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;d6&lt;SPAN class="operator token"&gt;-&lt;/SPAN&gt;d7
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;lea&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;8&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;sp&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt;sp
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;unlk&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;a6
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;rts
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;/********************************************************************/&lt;/SPAN&gt;
&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;
&lt;SPAN class="token function"&gt;mcf523x_irq_enable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;asm_set_ipl&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="number token"&gt;0&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;/********************************************************************/&lt;/SPAN&gt;
&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;
&lt;SPAN class="token function"&gt;mcf523x_irq_disable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;asm_set_ipl&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="number token"&gt;6&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Adding the disabling and enabling didn´t made a difference.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Jul 2017 07:47:52 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690220#M13257</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-12T07:47:52Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690221#M13258</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Are you sure you have unique levels and priorities for all the separate interrupts in the ICRs? That can cause problem if you don't have them all unique.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;13.2.1.6 Interrupt Control Register (ICRnx, (x = 1, 2,..., 63))&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Jul 2017 07:51:24 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690221#M13258</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-12T07:51:24Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690222#M13259</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Yes, pretty sure.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;So the Initialization looks like this:&lt;/P&gt;&lt;PRE class="language-cpp line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="keyword token"&gt;void&lt;/SPAN&gt;
EPORT&lt;SPAN class="operator token"&gt;::&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;Init&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;/*-FUNCTION HEADER--------------------------------------------------------
|&amp;nbsp;&amp;nbsp; description&amp;nbsp; : Initialize GPIO
|&amp;nbsp;&amp;nbsp; side effects :
|&amp;nbsp;&amp;nbsp; parameters&amp;nbsp;&amp;nbsp; :
|&amp;nbsp;&amp;nbsp; return value : none
|&amp;nbsp;&amp;nbsp; precondition :
|&amp;nbsp;&amp;nbsp; postcondition:
+--END FUNCTION HEADER--------------------------------------------------*/&lt;/SPAN&gt;
&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPPAR &lt;SPAN class="operator token"&gt;|&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;MCF_EPORT_EPPAR_EPPAx&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;,&lt;/SPAN&gt; m_byEdgeDetect&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="keyword token"&gt;if&lt;/SPAN&gt; &lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_bOutput&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPDDR &lt;SPAN class="operator token"&gt;|&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;MCF_EPORT_EPDDR_EPDDx&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="keyword token"&gt;else&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPDDR &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;MCF_EPORT_EPDDR_EPDDx&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;

&lt;SPAN class="comment token"&gt;//&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_EPORT_EPDDR |= MCF_EPORT_EPPAR_EPDDx(m_byPortNr, m_bOutput);&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="keyword token"&gt;if&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byInterruptLevel &lt;SPAN class="operator token"&gt;&amp;gt;&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;&amp;amp;&amp;amp;&lt;/SPAN&gt; m_byInterruptPriority &lt;SPAN class="operator token"&gt;&amp;gt;&lt;/SPAN&gt; &lt;SPAN class="number token"&gt;0&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="punctuation token"&gt;{&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&lt;SPAN class="comment token"&gt;// disable Interrupts&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;?&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_disable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&lt;SPAN class="comment token"&gt;// Set Interrupt Control Register &lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;MCF_INTC0_ICRn&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;MCF_INTC0_ICRn_IL&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byInterruptLevel&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;|&lt;/SPAN&gt; &lt;SPAN class="token function"&gt;MCF_INTC0_ICRn_IP&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byInterruptPriority&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;// Clear Interrupt Mask Bits&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_INTC0_IMRL &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;MCF_INTC0_IMRL_MASKALL&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&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;&lt;SPAN class="comment token"&gt;// bit 0 = mask All bit =&amp;gt;UnMask&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_INTC0_IMRL &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;MCF_INTC0_IMRL_INT_MASK&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;// UnMask Bit m_byPortNr = EPORTx&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;// enable Interrupt at all&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="token function"&gt;mcf523x_irq_enable&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt; &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;&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;
&lt;SPAN class="punctuation token"&gt;}&lt;/SPAN&gt;&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;And the m_byInterruptLevel and m_byInterruptPriority are for every EPORT the same but for Port to Port different. &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Like that:&lt;/P&gt;&lt;P&gt;USB_Read: m_byInterruptLevel:1 m_byInterruptPriority:1&lt;/P&gt;&lt;P&gt;Button_OFF: m_byInterruptLevel:2 m_byInterruptPriority:2&lt;/P&gt;&lt;P&gt;Button_OPEN: m_byInterruptLevel:3 m_byInterruptPriority:3&lt;/P&gt;&lt;P&gt;TRIGGER: m_byInterruptLevel:5 m_byInterruptPriority:5&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Jul 2017 08:02:10 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690222#M13259</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-12T08:02:10Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690223#M13260</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;PRE class="language-cpp line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="property macro token"&gt;#define MCF_INTC0_ICRn(x)&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (*(vuint8 *)(void*)(&amp;amp;__IPSBAR[0x000C40+((x)*0x001)]))&lt;/SPAN&gt;
&lt;SPAN class="property macro token"&gt;#define MCF_INTC0_ICRn_IP(x)&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (((x)&amp;amp;0x07)&amp;lt;&amp;lt;0)&lt;/SPAN&gt;
&lt;SPAN class="property macro token"&gt;#define MCF_INTC0_ICRn_IL(x)&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; (((x)&amp;amp;0x07)&amp;lt;&amp;lt;3)&lt;/SPAN&gt;&lt;SPAN class="line-numbers-rows"&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;SPAN&gt;‍&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 12 Jul 2017 08:11:59 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690223#M13260</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-12T08:11:59Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690224#M13261</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;gt; I have not found the "Syntax highlighter" button...&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You found something that let you format your code well. How did you do it?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;To get to "Syntax Highlighter":&lt;/P&gt;&lt;P&gt;1 - Click on "Use advanced editor" at the top-right of the edit window,&lt;/P&gt;&lt;P&gt;2 - The Toolbar (B I = = " Ix Chain Camera ***) - click on the "***",&lt;/P&gt;&lt;P&gt;3 - There are now two rows in the Toolbad. Click on "More".&lt;/P&gt;&lt;P&gt;4 - Click on "Syntax highlighter".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;gt; And the m_byInterruptLevel and m_byInterruptPriority are for every EPORT the same but for Port to Port different.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;They MUST be different for every separate interrupt source, and that includes every EPORT. All seven of them have to unique Priority:Level. So if you want all EPORTs at the the same level, then they have to have priorities 1, 2, 3, 4, 5, 6, 7.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;13.2.1.6 Interrupt Control Register (ICRnx, (x = 1, 2,..., 63))&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;&lt;/P&gt;&lt;P style="padding-left: 30px; text-align: center;"&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;Note: It is the responsibility of the software to program the ICRnx&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;registers with unique and non-overlapping level and priority definitions.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;Failure to program the ICRnx registers in this manner can result in&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;undefined behavior. If a specific interrupt request is completely unused,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;the ICRnx value can remain in its reset (and disabled) state.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;Figure 13-9. Interrupt Control Register (ICRnx)&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Everyone thinks on reading that that you can only have 64 different interrupts active in a system. But you shouldn't be using Level 7, so there are only 8 priorities and 7 levels, so that means only 56 interrupts. It is very easy to run out, as there are 60 interrupts on INTC0, and 51 on INTC1.&lt;/P&gt;&lt;P&gt;Except (and it doesn't say this anywhere) the interrupts only have to be unique within one controller. So you can use (say) Level 4 and Priority 4 for an interrupt on INTC0 and use the same Level and Priority for a different interrupt on INTC1.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I suggest you search this Forum for "&lt;SPAN style="font-family: courier new,courier,monospace;"&gt;It is the responsibility of the software to program the ICRnx&lt;/SPAN&gt;" and look at previous interrupt controller problems and answers.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The above probably isn't causing this problem.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;You're not writing to "EPFn" anywhere that I can see. You should do that before enabling interrupts (to clear any previous ones). That wouldn't cause your problem either.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;PRE class="language-cpp line-numbers"&gt;&lt;CODE&gt;&lt;SPAN class="comment token"&gt;// Clear Interrupt Mask Bits&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_INTC0_IMRL &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;MCF_INTC0_IMRL_MASKALL&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&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;&lt;SPAN class="comment token"&gt;// bit 0 = mask All bit =&amp;gt;UnMask&lt;/SPAN&gt;
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_INTC0_IMRL &lt;SPAN class="operator token"&gt;&amp;amp;&lt;/SPAN&gt;&lt;SPAN class="operator token"&gt;=&lt;/SPAN&gt; &lt;SPAN class="operator token"&gt;~&lt;/SPAN&gt;&lt;SPAN class="token function"&gt;MCF_INTC0_IMRL_INT_MASK&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;(&lt;/SPAN&gt;m_byPortNr&lt;SPAN class="punctuation token"&gt;)&lt;/SPAN&gt;&lt;SPAN class="punctuation token"&gt;;&lt;/SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN class="comment token"&gt;// UnMask Bit m_byPortNr = EPORTx&lt;/SPAN&gt;
&lt;SPAN class="comment token"&gt;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I thought the above might be a problem, but it is OK. You're clearing the MASKALL bit, and then that allows the other ones to be cleared. Check that second macro is doing what you expect. Also note that the fact that EPORTs 1-7 use INTC0 Interrupts 1-7 is a fluke. That doesn't work anywhere else. So the "type" of "m_byPortNr" isn't the same as the argument to that macro, but it works. It would be slightly cleaner (for other code) to make this mapping more explicit somewhere.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Back to your original problem. Assuming you can duplicate it (enable one port interrupt, enable a second, disable the first and the second one now doesn't work) I'd suggest you:&lt;/P&gt;&lt;P&gt;1 - Write some code to dump all the EPORT and relevant INTC0 registers.&lt;/P&gt;&lt;P&gt;2 - Dump the registers.&lt;/P&gt;&lt;P&gt;3 - Enable two EPORTs.&lt;/P&gt;&lt;P&gt;4 - Dump the registers.&lt;/P&gt;&lt;P&gt;5 - Disable one EPORT (causing the other one to stop).&lt;/P&gt;&lt;P&gt;6 - Dump the registers.&lt;/P&gt;&lt;P&gt;7 - Compare the last two dumps for all differences. Look for anything that explains the port that doesn't work.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 13 Jul 2017 00:01:34 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690224#M13261</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-13T00:01:34Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690225#M13262</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;You seem to have created a second post with the same SUBJECT as your original one. Maybe you created it "as new" rather than using the "Reply" buttons in this one. Can you delete the other one as I think I've answered your quesionn in this thread. I think there's a "Delete" option under the "Actions" button on the lower left of the page.&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 13 Jul 2017 00:04:18 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690225#M13262</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-13T00:04:18Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690226#M13263</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;For sure I meant: " I have not found the "Syntax highlighter" button... &lt;STRONG&gt;previously&lt;/STRONG&gt;" :smileygrin:&lt;/P&gt;&lt;P&gt;So I found it with your help, thanks :smileyhappy:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;gt;They MUST be different for every separate interrupt source, and that includes every EPORT. All seven of them have to unique Priority:Level. So if you want all EPORTs at the the same level, then they have to have priorities 1, 2, 3, 4, 5, 6, 7.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Yeah I wrote the settings are:&lt;/P&gt;&lt;P&gt;USB_Read: m_byInterruptLevel:1 m_byInterruptPriority:1&lt;/P&gt;&lt;P&gt;Button_OFF: m_byInterruptLevel:2 m_byInterruptPriority:2&lt;/P&gt;&lt;P&gt;Button_OPEN: m_byInterruptLevel:3 m_byInterruptPriority:3&lt;/P&gt;&lt;P&gt;TRIGGER: m_byInterruptLevel:5 m_byInterruptPriority:5&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;EPFn is written a level above, so you can´t see it in that routines.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;So .. I´m pretty sure it´s a fluke, as you can see in the attached picture.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;And the last thing you suggested, I have to admit that I haven´t got what you wanted to explain :smileysad: Could you reexplain it another way ? :smileyhappy:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;best, Richard&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 17 Jul 2017 13:59:53 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690226#M13263</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-17T13:59:53Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690227#M13264</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;gt; So .. I´m pretty sure it´s a fluke, as you can see in the attached picture.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;There's no "attached picture". Could you try again, or say what's in the picture as text?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;gt; And the last thing you suggested, I have to admit that I haven´t got what you wanted to explain&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The last thing I suggested was that you delete the duplicate post. So I assume you mean the second-last thing. But it would help if you'd have said which thing.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;So I have to guess you are referring to my numbered-list 1-7. Do you mean all of that or just the last item it that?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm suggesting you read the EPORT control registers and print their numeric values either side of when it works and when it doesn't.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;gt; USB_Read: m_byInterruptLevel:1 m_byInterruptPriority:1&lt;/P&gt;&lt;P&gt;&amp;gt; Button_OFF: m_byInterruptLevel:2 m_byInterruptPriority:2&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I wouldn't recommend different levels AND priorities. You should normally have all "similar interrupts" that are being handled similarly at the same level, distinguished by priority. That way they can't accidentally interrupt each other.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 18 Jul 2017 02:26:34 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690227#M13264</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-18T02:26:34Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690228#M13265</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="20170717_145105.jpg"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/25266i821D9386A9F0FA53/image-size/large?v=v2&amp;amp;px=999" role="button" title="20170717_145105.jpg" alt="20170717_145105.jpg" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 19 Jul 2017 07:33:37 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690228#M13265</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-19T07:33:37Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690229#M13266</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Yeah I meant the bullet points :smileyhappy: Now I got it, thank you, I will try this.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 19 Jul 2017 07:51:02 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690229#M13266</guid>
      <dc:creator>richardwielend</dc:creator>
      <dc:date>2017-07-19T07:51:02Z</dc:date>
    </item>
    <item>
      <title>Re: MCF5235 Interrupt enable/disable spuriousity</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690230#M13267</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;There's another thing that is very commonly gotten wrong.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Interrupt handling is like the little/big-endian problems. If it doesn't scare you then you don't understand it properly :-)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Most chip manufacturers get interrupt handing badly wrong. Motorola got it dead right. Maybe they patented "the one true solution" so nobody else could use it, or maybe the other manufacturers didn't realise the True Majesty of Motorola's Solution. Which carried over into most of Freescale's parts.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The "solution" is called "W1C".&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If you don't know how insanely great this is then you might not be using it properly, and so your problem may not be the interrupt setting, but in your interrupt service code.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Of course I've detailed this before, so I suggest you read through this post to see if it shows up any problems in your interrupt handler.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;A _jive_internal="true" href="https://community.nxp.com/message/105778?commentID=105778#comment-105778"&gt;https://community.nxp.com/message/105778?commentID=105778#comment-105778&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If dumping the registers around your setting code doesn't show the problem then it might be with your use of W1C.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Tom&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 20 Jul 2017 03:21:09 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/MCF5235-Interrupt-enable-disable-spuriousity/m-p/690230#M13267</guid>
      <dc:creator>TomE</dc:creator>
      <dc:date>2017-07-20T03:21:09Z</dc:date>
    </item>
  </channel>
</rss>

