<?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 flash signature generation in LPC Microcontrollers</title>
    <link>https://community.nxp.com/t5/LPC-Microcontrollers/flash-signature-generation/m-p/583999#M20957</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by jpplus on Thu May 21 01:55:35 MST 2015&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi all,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt; I try to generate flash signature for LPC43XX, the problem I faced is I can get the correct signature (same with reference one which implement in Python and run in PC) when I generate signature for bank B.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;my setting is:&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;1) my code is in bank A&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;2) main function and flash generation function are linked to RAM(verified by map file,&amp;nbsp;&amp;nbsp;&amp;nbsp; [color=#00c] flash_signature&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; 0x10000001&amp;nbsp;&amp;nbsp; Thumb Code&amp;nbsp;&amp;nbsp;&amp;nbsp; 70&amp;nbsp; main.o(ram_section)[/color])&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;3)If I put the address to Bank B, then I get correct data&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;4) if&amp;nbsp; I put addres to Bank A which hold same flash content, I get wrong signature&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;5) Keil ARM compiler and tick box "one ELF section per function" &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;6) I have to reset the flash controller, otherwise, I cannot ge correct signature from Bank B.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I think problem still rely on the code in BankA. I disable interrupt when running this code, but still get wrong.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;void flash_signature ( uint32_t start, uint32_t stop, int index, uint32_t *sig) &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; __attribute__((section ("ram_section")));&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;void flash_signature( uint32_t start, uint32_t stop, int index, uint32_t *sig )&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;FLASHSIG_Type * LPC_FMC;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__disable_irq();&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC = (FLASHSIG_Type *)(LPC_FMCA_BASE);//if bank B, change to bank B address&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSSTART = (start &amp;gt;&amp;gt; 4);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSTATCLR =&amp;nbsp; (1 &amp;lt;&amp;lt; 2);&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSSTOP = (stop &amp;gt;&amp;gt; 4) | FLASHSIG_BUSY;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;while((LPC_FMC-&amp;gt;FMSTAT &amp;amp; (1 &amp;lt;&amp;lt; 2)) == 0);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*sig=LPC_FMC-&amp;gt;FMSW0;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 1) = LPC_FMC-&amp;gt;FMSW1;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 2) = LPC_FMC-&amp;gt;FMSW2;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 3) = LPC_FMC-&amp;gt;FMSW3;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSTATCLR =&amp;nbsp; (1 &amp;lt;&amp;lt; 2);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__enable_irq();&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;}&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 15 Jun 2016 19:10:51 GMT</pubDate>
    <dc:creator>lpcware</dc:creator>
    <dc:date>2016-06-15T19:10:51Z</dc:date>
    <item>
      <title>flash signature generation</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/flash-signature-generation/m-p/583999#M20957</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by jpplus on Thu May 21 01:55:35 MST 2015&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Hi all,&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt; I try to generate flash signature for LPC43XX, the problem I faced is I can get the correct signature (same with reference one which implement in Python and run in PC) when I generate signature for bank B.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;my setting is:&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;1) my code is in bank A&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;2) main function and flash generation function are linked to RAM(verified by map file,&amp;nbsp;&amp;nbsp;&amp;nbsp; [color=#00c] flash_signature&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; 0x10000001&amp;nbsp;&amp;nbsp; Thumb Code&amp;nbsp;&amp;nbsp;&amp;nbsp; 70&amp;nbsp; main.o(ram_section)[/color])&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;3)If I put the address to Bank B, then I get correct data&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;4) if&amp;nbsp; I put addres to Bank A which hold same flash content, I get wrong signature&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;5) Keil ARM compiler and tick box "one ELF section per function" &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;6) I have to reset the flash controller, otherwise, I cannot ge correct signature from Bank B.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I think problem still rely on the code in BankA. I disable interrupt when running this code, but still get wrong.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;void flash_signature ( uint32_t start, uint32_t stop, int index, uint32_t *sig) &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; __attribute__((section ("ram_section")));&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;void flash_signature( uint32_t start, uint32_t stop, int index, uint32_t *sig )&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;FLASHSIG_Type * LPC_FMC;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__disable_irq();&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC = (FLASHSIG_Type *)(LPC_FMCA_BASE);//if bank B, change to bank B address&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSSTART = (start &amp;gt;&amp;gt; 4);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSTATCLR =&amp;nbsp; (1 &amp;lt;&amp;lt; 2);&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSSTOP = (stop &amp;gt;&amp;gt; 4) | FLASHSIG_BUSY;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;while((LPC_FMC-&amp;gt;FMSTAT &amp;amp; (1 &amp;lt;&amp;lt; 2)) == 0);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*sig=LPC_FMC-&amp;gt;FMSW0;&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 1) = LPC_FMC-&amp;gt;FMSW1;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 2) = LPC_FMC-&amp;gt;FMSW2;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;*(sig + 3) = LPC_FMC-&amp;gt;FMSW3;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;LPC_FMC-&amp;gt;FMSTATCLR =&amp;nbsp; (1 &amp;lt;&amp;lt; 2);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;__enable_irq();&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;}&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 19:10:51 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/flash-signature-generation/m-p/583999#M20957</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T19:10:51Z</dc:date>
    </item>
  </channel>
</rss>

