<?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 S12 MCU, How to get memory size at runtime ? in S12 / MagniV Microcontrollers</title>
    <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12-MCU-How-to-get-memory-size-at-runtime/m-p/640812#M13637</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm using S12G and S12VR series MCU and I wrote an own bootloder for these device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Everything works smootly, but I don't want to build all the time separately for different memory sized device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Currently I determine the real P-Flash size by initiate a Section erase from Global address 0x0_8000 to 0x3_F7FF in 16 KBytes step.(Boot loader part is not erased !)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;After issuing the command I check the ACCERR bit in FSTAT to detemine the validity of the address.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This method is failed on the S9S12G48 device because the command is accepted without error for address range 0x3_0000-0x3_3FFF which is valid for S9S12G64+ device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Any other tip for determine the memory size at runtime ?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sat, 01 Apr 2017 07:07:15 GMT</pubDate>
    <dc:creator>fmiku</dc:creator>
    <dc:date>2017-04-01T07:07:15Z</dc:date>
    <item>
      <title>S12 MCU, How to get memory size at runtime ?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12-MCU-How-to-get-memory-size-at-runtime/m-p/640812#M13637</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm using S12G and S12VR series MCU and I wrote an own bootloder for these device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Everything works smootly, but I don't want to build all the time separately for different memory sized device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Currently I determine the real P-Flash size by initiate a Section erase from Global address 0x0_8000 to 0x3_F7FF in 16 KBytes step.(Boot loader part is not erased !)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;After issuing the command I check the ACCERR bit in FSTAT to detemine the validity of the address.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This method is failed on the S9S12G48 device because the command is accepted without error for address range 0x3_0000-0x3_3FFF which is valid for S9S12G64+ device.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Any other tip for determine the memory size at runtime ?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 01 Apr 2017 07:07:15 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12-MCU-How-to-get-memory-size-at-runtime/m-p/640812#M13637</guid>
      <dc:creator>fmiku</dc:creator>
      <dc:date>2017-04-01T07:07:15Z</dc:date>
    </item>
    <item>
      <title>Re: S12 MCU, How to get memory size at runtime ?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12-MCU-How-to-get-memory-size-at-runtime/m-p/640813#M13638</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Ferenc,&lt;/P&gt;&lt;P&gt;Unfortunately, there isn’t way how to exactly detect differences between some of the derivatives directly from a code.&lt;/P&gt;&lt;P&gt;S12G:&lt;/P&gt;&lt;P&gt;You cannot distinguish between 16kB and 32kB, between 48kB and 64kB, between 96kB and 128kB, between 192 and 240kB derivatives.&lt;/P&gt;&lt;P&gt;S12VR:&lt;/P&gt;&lt;P&gt;You cannot distinguish between 16kB and 32kB, between 48kB and 64kB derivatives.&lt;/P&gt;&lt;P&gt;In fact, the chips are the same, just some part of Flash is not fully tested. However, your bootloader may erase even that page.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The simplest way how to detect a flash size is reading Part ID. The S12G/S12VR doesn’t have special register with a flash size information.&lt;/P&gt;&lt;P&gt;The example of such routine may be found in AN4258. Updated version for you:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;static UINT8 EraseFlash(void)&lt;/P&gt;&lt;P&gt;{&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; switch (PARTID)&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;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; //S12G&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N95B:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x004000UL, 0x03EFDFUL));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N51A:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x020000UL, 0x03EFDFUL));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N75C:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_1N75C:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x030000UL, 0x03EFDFUL));&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; case MASK_0N48A:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_1N48A:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x038000UL, 0x03EFDFUL));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; //S12VR&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N59H:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N05E:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_1N05E:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_2N05E:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N92B:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x030000UL, 0x03EFDFUL));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; case MASK_0N11N:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; //erase whole P-Flash memory except bootloader area&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(PFlash_EraseSectorBySector(0x038000UL, 0x03EFDFUL));&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; default:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return(UnknownPartID);&lt;/P&gt;&lt;P&gt;&amp;nbsp; }&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Note: the 0N92B, 0N05E, 1N05E and 2N05E masksets are obsolete versions of S12VR.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;PartIDs:&lt;/P&gt;&lt;P&gt;0N92B 0x3280&lt;/P&gt;&lt;P&gt;0N05E 0x3281&lt;/P&gt;&lt;P&gt;1N05E 0x3281&lt;/P&gt;&lt;P&gt;2N05E 0x3282&lt;/P&gt;&lt;P&gt;0N59H 0x3290&lt;/P&gt;&lt;P&gt;0N11N 0x3380&lt;/P&gt;&lt;P&gt;0N95B 0xF080&lt;/P&gt;&lt;P&gt;0N51A 0xF180&lt;/P&gt;&lt;P&gt;0N75C 0xF280&lt;/P&gt;&lt;P&gt;1N75C 0xF281&lt;/P&gt;&lt;P&gt;0N48A 0xF380&lt;/P&gt;&lt;P&gt;1N48A 0xF381&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;Radek&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, 03 Apr 2017 09:09:50 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/S12-MCU-How-to-get-memory-size-at-runtime/m-p/640813#M13638</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2017-04-03T09:09:50Z</dc:date>
    </item>
  </channel>
</rss>

