<?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 Re: SDRAM data shifts in LPC Microcontrollers</title>
    <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563419#M16671</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by wlamers on Fri Jun 21 05:33:44 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Well I did some tests. First writing 0x1234ABCD + i (for loop sentinel, to mimick arbritrary data), then write 0xFFFFFFFF in a continious loop. I can configure the SDRAM up to 156 MHz succesfully (CPU clock also @ 156 MHz), or I configure the CPU at 204 MHz and the SDRAM at 102 MHz (and a CAS latency of 2 instead of 3) which yields the fastest speeds. This are the results with error checking (cost some additional CPU time):&lt;BR /&gt;&lt;BR /&gt;--- SDRAM @ 102MHz, CPU @ 204 MHz, no compiler optimization&lt;BR /&gt;- write 0x1234ABCD: 25575 KiB/s&lt;BR /&gt;- read 0x1234ABCD: 18930 KiB/s&lt;BR /&gt;- write 0xFFFFFFFF: 28469 KiB/s&lt;BR /&gt;- read 0xFFFFFFFF: 21918 KiB/s&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;--- SDRAM @ 102MHz, CPU @ 204 MHz, with compiler (-O2) optimization&lt;BR /&gt;- write 0x1234ABCD: 132663 KiB/s&lt;BR /&gt;- read 0x1234ABCD: 33886 KiB/s&lt;BR /&gt;- write 0xFFFFFFFF: 132663 KiB/s&lt;BR /&gt;- read 0xFFFFFFFF: 39479 KiB/s&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;The compiler optimization seems to work well based on the write speed increase of a factor 5! Anyone seen this kind of difference before?&lt;BR /&gt;&lt;BR /&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 15 Jun 2016 18:47:36 GMT</pubDate>
    <dc:creator>lpcware</dc:creator>
    <dc:date>2016-06-15T18:47:36Z</dc:date>
    <item>
      <title>SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563412#M16664</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by wlamers on Thu Jun 20 13:16:44 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;During a read write test of a SDRAM I get some sort of bitshift of the data.&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;The SDRAM is a Micron MT48LC16M16A2 (16 bit wide).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Configured as (Row, Bank, Column): 256 Mb (16Mx16), 4 banks, row length = 13, column length = 9&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;If i write, for example, 0x1234ABCD in an array of length 1024 (or whatever, length does not matter) and I read those locations back I get this:&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;pos[0] = 0xABCD1234&lt;BR /&gt;pos[1] = 0xABCD1234&lt;BR /&gt;pos[2] = 0xABCD1234&lt;BR /&gt;pos[3] = 0x12341234&lt;BR /&gt;pos[4] = 0xABCD1234&lt;BR /&gt;pos[5] = 0xABCD1234&lt;BR /&gt;pos[6] = 0xABCD1234&lt;BR /&gt;pos[7] = 0x12341234&lt;BR /&gt;pos[8] = 0xABCD1234&lt;BR /&gt;pos[9] = 0xABCD1234&lt;BR /&gt;pos[10] = 0xABCD1234&lt;BR /&gt;pos[11] = 0x12341234&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Note that every 4th location is different and all the others are shifted (as it appears).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Anybody a clue what is going on here? Has this something to do with the burst length maybe?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:31 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563412#M16664</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:31Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563413#M16665</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by suckfish on Thu Jun 20 23:12:26 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Could be a timing problem resulting in each 16-bit word getting delayed by a clock cycle? Try backing off all the timing parameters and/or the clock rate and see if that fixes things?&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;I have the same part on a board running fine. I did find that when I pushed the clock rates I had to back off one particular timing value from the data sheet values (I can't remember which, suspect it might have been DYNAMICDAL).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Also at higher clock rates you need to change EMCDELAYCLK (I have 0x0000 for &amp;amp;lt;= 96MHz, 0x1111 for 97 to 129MHz and 0x2222 above that).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Double check that you have CAS/RAS latencies configured identically between the memory controller and the SDRAM chip.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:32 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563413#M16665</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:32Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563414#M16666</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by suckfish on Thu Jun 20 23:14:38 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Could be a timing problem resulting in each 16-bit word getting delayed by a clock cycle? Try backing off all the timing parameters and/or the clock rate and see if that fixes things?&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;I have the same part on a board running fine. I did find that when I pushed the clock rates I had to back off one particular timing value from the data sheet values (I can't remember which, suspect it might have been DYNAMICDAL).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Also at higher clock rates you need to change EMCDELAYCLK (I have 0x0000 for &amp;amp;lt;= 96MHz, 0x1111 for 97 to 129MHz and 0x2222 above that).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Double check that you have CAS/RAS latencies configured identically between the memory controller and the SDRAM chip.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:32 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563414#M16666</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:32Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563415#M16667</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by suckfish on Thu Jun 20 23:20:52 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;SPAN&gt;Could be a timing problem resulting in each 16-bit word getting delayed by a clock cycle?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Try backing off all the timing parameters and/or the clock rate and see if that fixes things?&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I have the same part on a board running fine. I did find that when I pushed the clock rates I had to back off one particular timing value from the data sheet values (I can't remember which, suspect it might have been DYNAMICDAL).&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Also at higher clock rates you need to change EMCDELAYCLK (I have 0x0000 for &amp;amp;lt;= 96MHz, 0x1111 for 97 to 129MHz and 0x2222 above that).&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;Double check that you have CAS/RAS latencies configured identically between the memory controller and the SDRAM chip.&lt;/SPAN&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:33 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563415#M16667</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:33Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563416#M16668</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by suckfish on Thu Jun 20 23:26:16 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Could be a timing problem resulting in each 16-bit word getting delayed by a clock cycle? Try backing off all the timing parameters and/or the clock rate and see if that fixes things?&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;I have the same part on a board running fine. I did find that when I pushed the clock rates I had to back off one particular timing value from the data sheet values (I can't remember which, suspect it might have been DYNAMICDAL).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Also at higher clock rates you need to change EMCDELAYCLK (I have 0x0000 for up to 96MHz, 0x1111 for 97 to 129MHz and 0x2222 above that).&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Double check that you have CAS/RAS latencies configured identically between the memory controller and the SDRAM chip.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:34 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563416#M16668</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:34Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563417#M16669</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by wlamers on Fri Jun 21 02:13:05 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Thanks for your information.&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Unfortunately changing the EMCDELAYCLK (tried 0x0000 till 0x5555), or the clock frequency (tried 12 to 96 MHz) does not work. The latencies (3-3) are correct. Maybe I am doing something wrong in the other timings? These are the values @ 96 MHz:&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;LPC_SCU-&amp;amp;gt;EMCDELAYCLK &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0x00000000;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;LPC_EMC-&amp;amp;gt;DYNAMICCONFIG2&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = (0 &amp;amp;lt;&amp;amp;lt; 14) | (13 &amp;amp;lt;&amp;amp;lt; 7);&amp;nbsp;&amp;nbsp;&amp;nbsp; // 256Mbit(16Mb x 4 x 4 banks) in ROW BANK COLUMN mode (RBC), row len = 13, column len = 9&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DYNAMICCONFIG2-&amp;amp;gt; bit[14] = 0, bit[12:7] = 001101&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRASCAS2&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0x00000303;&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; // Latency: RAS 3, CAS 3 CCLK cyc.&lt;BR /&gt;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRP&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRAS &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 3;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICSREX &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 6;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICAPR &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICDAL &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 5;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICWR&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRC&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 5;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRFC &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 5;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICXSR &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 6;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICRRD &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;&lt;BR /&gt;LPC_EMC-&amp;amp;gt;DYNAMICMRD &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;LPC_EMC-&amp;amp;gt;DYNAMICREFRESH &amp;nbsp;&amp;nbsp;&amp;nbsp; = 110; &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; // 110x16 EMC_CCLK's between refresh cycles.&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;And this is the burst length:&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t DynBaseAddr&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = SDRAM_BASE_ADDR;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t ModeRegister&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0x23; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; // burst length 8, sequential mode, latency 2, standard operation mode, programmed burst length mode&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint8_t Offset &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 12; &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; // 9 columns + 1 bus width + 2 bank select bits = 12&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; *((volatile uint32_t *) (DynBaseAddr | (ModeRegister &amp;amp;lt;&amp;amp;lt; Offset)));&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;Any idea?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:35 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563417#M16669</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:35Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563418#M16670</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by wlamers on Fri Jun 21 04:53:13 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;I have found the error. I did some timing calculations wrong. These are the correct ones (works at 96 MHz):&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_SCU-&amp;amp;gt;EMCDELAYCLK &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0x00000000&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICRP&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICRAS &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 4;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICSREX &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 6;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICAPR &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICDAL &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 4;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICWR&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICRC&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 5;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICRFC &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 5;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICXSR &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 6;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICRRD &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICMRD &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 1;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t ModeRegister&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 0x33; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; // burst length 8, sequential mode, latency 3, standard operation mode, programmed burst length mode&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint8_t Offset &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; = 12; &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; // 9 columns + 1 bus width + 2 bank select bits = 12&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; *((volatile uint32_t *) (DynBaseAddr | (ModeRegister &amp;amp;lt;&amp;amp;lt; Offset)));&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; LPC_EMC-&amp;amp;gt;DYNAMICREFRESH &amp;nbsp;&amp;nbsp;&amp;nbsp; = 47;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:35 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563418#M16670</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:35Z</dc:date>
    </item>
    <item>
      <title>Re: SDRAM data shifts</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563419#M16671</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;STRONG&gt;Content originally posted in LPCWare by wlamers on Fri Jun 21 05:33:44 MST 2013&lt;/STRONG&gt;&lt;BR /&gt;&lt;P&gt;Well I did some tests. First writing 0x1234ABCD + i (for loop sentinel, to mimick arbritrary data), then write 0xFFFFFFFF in a continious loop. I can configure the SDRAM up to 156 MHz succesfully (CPU clock also @ 156 MHz), or I configure the CPU at 204 MHz and the SDRAM at 102 MHz (and a CAS latency of 2 instead of 3) which yields the fastest speeds. This are the results with error checking (cost some additional CPU time):&lt;BR /&gt;&lt;BR /&gt;--- SDRAM @ 102MHz, CPU @ 204 MHz, no compiler optimization&lt;BR /&gt;- write 0x1234ABCD: 25575 KiB/s&lt;BR /&gt;- read 0x1234ABCD: 18930 KiB/s&lt;BR /&gt;- write 0xFFFFFFFF: 28469 KiB/s&lt;BR /&gt;- read 0xFFFFFFFF: 21918 KiB/s&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;--- SDRAM @ 102MHz, CPU @ 204 MHz, with compiler (-O2) optimization&lt;BR /&gt;- write 0x1234ABCD: 132663 KiB/s&lt;BR /&gt;- read 0x1234ABCD: 33886 KiB/s&lt;BR /&gt;- write 0xFFFFFFFF: 132663 KiB/s&lt;BR /&gt;- read 0xFFFFFFFF: 39479 KiB/s&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;BR /&gt;&lt;P&gt;The compiler optimization seems to work well based on the write speed increase of a factor 5! Anyone seen this kind of difference before?&lt;BR /&gt;&lt;BR /&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 15 Jun 2016 18:47:36 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/SDRAM-data-shifts/m-p/563419#M16671</guid>
      <dc:creator>lpcware</dc:creator>
      <dc:date>2016-06-15T18:47:36Z</dc:date>
    </item>
  </channel>
</rss>

