<?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>Kinetis Microcontrollers中的主题 Re: MGSTAT0 occasionally set on flash erase</title>
    <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541604#M33170</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, test it,&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; __DI();&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; i =&amp;nbsp;&amp;nbsp;&amp;nbsp; flash_erase_sector( 0x10000 );&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; __EI();&lt;/P&gt;&lt;P&gt;//--------------------------------------------------------------------&lt;/P&gt;&lt;P&gt;unsigned int flash_erase_sector(unsigned int destination) // Sector = 4k&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt; unsigned int returnCode=0;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt; if(FTFL_FSTAT&amp;amp;0b01000000){FTFL_FSTAT&amp;amp;=0b01000000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0b00100000){FTFL_FSTAT&amp;amp;=0b00100000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0b00010000){FTFL_FSTAT&amp;amp;=0b00010000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB0 = 0x09;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB1 = (unsigned char)(destination &amp;gt;&amp;gt; 16);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB2 = (unsigned char)((destination &amp;gt;&amp;gt; 8) &amp;amp; 0xFF);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB3 = (unsigned char)(destination &amp;amp; 0xFF);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FSTAT = 0x80;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // launch command&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0x30){&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(0xff);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; while(!(FTFL_FSTAT&amp;amp;(1&amp;lt;&amp;lt;7))){}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; returnCode = FTFL_FSTAT&amp;amp;0b01110001;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(returnCode);&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;//---------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 17 Jun 2016 21:22:06 GMT</pubDate>
    <dc:creator>CCandido</dc:creator>
    <dc:date>2016-06-17T21:22:06Z</dc:date>
    <item>
      <title>MGSTAT0 occasionally set on flash erase</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541603#M33169</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm using a K20 (MK20DX128VLK7) processor.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Occasionally when I try to erase a block of the program flash I get an FTFL_FSTAT result with the MGSTAT0 bit set.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The block of flash still seems to have been erased properly.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;It's very simple code:&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;FTFL_FCCOB0 = 0x09;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;FTFL_FCCOB1 = (addr &amp;gt;&amp;gt; 16) &amp;amp; 0xff;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;FTFL_FCCOB1 = (addr &amp;gt;&amp;gt; 8) &amp;amp; 0xff;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;FTFL_FCCOB1 = (addr) &amp;amp; 0xff;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;FTFL_FSTAT |= FTFL_FSTAT_CCIF_MASK;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;&lt;/P&gt;&lt;P style="padding-left: 30px;"&gt;while (!(FTFL_FSTAT &amp;amp; FTFL_FSTAT_CCIF_MASK)) ;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Any ideas on how to avoid this error or detect what is causing it?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;&amp;nbsp; Peter Steinberg&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 17 Jun 2016 20:01:26 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541603#M33169</guid>
      <dc:creator>petersteinberg</dc:creator>
      <dc:date>2016-06-17T20:01:26Z</dc:date>
    </item>
    <item>
      <title>Re: MGSTAT0 occasionally set on flash erase</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541604#M33170</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, test it,&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; __DI();&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; i =&amp;nbsp;&amp;nbsp;&amp;nbsp; flash_erase_sector( 0x10000 );&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; __EI();&lt;/P&gt;&lt;P&gt;//--------------------------------------------------------------------&lt;/P&gt;&lt;P&gt;unsigned int flash_erase_sector(unsigned int destination) // Sector = 4k&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt; unsigned int returnCode=0;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt; if(FTFL_FSTAT&amp;amp;0b01000000){FTFL_FSTAT&amp;amp;=0b01000000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0b00100000){FTFL_FSTAT&amp;amp;=0b00100000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0b00010000){FTFL_FSTAT&amp;amp;=0b00010000;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB0 = 0x09;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB1 = (unsigned char)(destination &amp;gt;&amp;gt; 16);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB2 = (unsigned char)((destination &amp;gt;&amp;gt; 8) &amp;amp; 0xFF);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FCCOB3 = (unsigned char)(destination &amp;amp; 0xFF);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; FTFL_FSTAT = 0x80;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // launch command&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; if(FTFL_FSTAT&amp;amp;0x30){&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(0xff);&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; while(!(FTFL_FSTAT&amp;amp;(1&amp;lt;&amp;lt;7))){}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; returnCode = FTFL_FSTAT&amp;amp;0b01110001;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(returnCode);&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;//---------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 17 Jun 2016 21:22:06 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541604#M33170</guid>
      <dc:creator>CCandido</dc:creator>
      <dc:date>2016-06-17T21:22:06Z</dc:date>
    </item>
    <item>
      <title>Re: MGSTAT0 occasionally set on flash erase</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541605#M33171</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Disabling interrupts around the flash writes had no effect.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 22 Jun 2016 16:50:22 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541605#M33171</guid>
      <dc:creator>petersteinberg</dc:creator>
      <dc:date>2016-06-22T16:50:22Z</dc:date>
    </item>
    <item>
      <title>Re: MGSTAT0 occasionally set on flash erase</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541606#M33172</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Was looking at MGSTAT0 as well and found it referenced in an errata for KINETIS: &lt;A href="http://cache.freescale.com/files/microcontrollers/doc/errata/KINETIS_2N03G.pdf" title="http://cache.freescale.com/files/microcontrollers/doc/errata/KINETIS_2N03G.pdf"&gt;http://cache.freescale.com/files/microcontrollers/doc/errata/KINETIS_2N03G.pdf&lt;/A&gt; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This could be your issue.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 14 Jul 2016 17:03:09 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/MGSTAT0-occasionally-set-on-flash-erase/m-p/541606#M33172</guid>
      <dc:creator>johnreid</dc:creator>
      <dc:date>2016-07-14T17:03:09Z</dc:date>
    </item>
  </channel>
</rss>

