<?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: DMA preemption problem K24 in Kinetis Software Development Kit</title>
    <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/DMA-preemption-problem-K24/m-p/403490#M1601</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello Anders,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Could you please provide your project in order to test in on our side?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best Regards,&lt;/P&gt;&lt;P&gt;Isaac&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 19 Nov 2015 16:42:14 GMT</pubDate>
    <dc:creator>isaacavila</dc:creator>
    <dc:date>2015-11-19T16:42:14Z</dc:date>
    <item>
      <title>DMA preemption problem K24</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/DMA-preemption-problem-K24/m-p/403489#M1600</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi &lt;/P&gt;&lt;P&gt;In relation to my setup described in this post &lt;A _jive_internal="true" data-containerid="11234" data-containertype="14" data-objectid="378553" data-objecttype="1" href="https://community.nxp.com/thread/378553"&gt;SAI DMA double buffer problem&lt;/A&gt;,&amp;nbsp; i wan't to use the UART as debug channel during run time.&amp;nbsp; In order to load the system as little as possible during UART transfers, I have setup the system to use the UART via the DMA&amp;nbsp; via fsl_uart:_edma_driver.c&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The setup is as following:&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;DMA UART RX ch 0 (currently not used)&lt;/P&gt;&lt;P&gt;DMA UART TX ch 1&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;DMA I2S&amp;nbsp; RX Ch 2&amp;nbsp;&amp;nbsp; ( Configured in loop/ double buffer&amp;nbsp; mode )&lt;/P&gt;&lt;P&gt;DMA I2S&amp;nbsp; TX Ch 3&amp;nbsp;&amp;nbsp; ( Configured in loop/ double buffer&amp;nbsp; mode )&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;DMA abitration = Fixed priority&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Priorities are left with init value (0,1,2,3).&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Preemption values for the different channel has been setup.&lt;/P&gt;&lt;P&gt;EDMA_HAL_SetChannelPreemptMode(DMA_BASE_PTR, 0, 1, 1); // cannot suspend any channel DPA=1 ,&amp;nbsp; Can be suspended ECP=1&lt;/P&gt;&lt;P&gt;EDMA_HAL_SetChannelPreemptMode(DMA_BASE_PTR, 1, 1, 1); // cannot suspend any channel DPA=1 ,&amp;nbsp; Can be suspended ECP=1&lt;/P&gt;&lt;P&gt;EDMA_HAL_SetChannelPreemptMode(DMA_BASE_PTR, 2, 0 ,0); // can suspend low prio channel DPA=0 ,&amp;nbsp; Cannot&amp;nbsp; be suspended ECP=0&lt;/P&gt;&lt;P&gt;EDMA_HAL_SetChannelPreemptMode(DMA_BASE_PTR, 3, 0, 0); // can suspend low prio channel DPA=0 ,&amp;nbsp; Cannot&amp;nbsp; be suspended ECP=0&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The UART transfer is working, however it looks like the I2S DMA are not allowed to suspend the UART RX DMA until all bytes are written to the UART ( Major loop end)&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The attached dump from my scope illustrates the scenario &lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;D15 and D14 shows the is the DMA isr for the I2S RX and TX DMA. and analog ch1 is the actual UART output.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Normally I2S DMA's will issue interrupt each 5 ms.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;As can be seen the I2S DMA's seems to be blocked during UART tranmission.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Any suggestion on why this happens ?&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;A href="http://10.10.130.12/Flash/tmp/getImages/image12276.png"&gt;&lt;IMG alt="Instrument screen" class="jive-image" src="http://10.10.130.12/Flash/tmp/getImages/image12276.png" /&gt;&lt;/A&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 11 Nov 2015 12:04:23 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/DMA-preemption-problem-K24/m-p/403489#M1600</guid>
      <dc:creator>andersesbensen</dc:creator>
      <dc:date>2015-11-11T12:04:23Z</dc:date>
    </item>
    <item>
      <title>Re: DMA preemption problem K24</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/DMA-preemption-problem-K24/m-p/403490#M1601</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello Anders,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Could you please provide your project in order to test in on our side?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best Regards,&lt;/P&gt;&lt;P&gt;Isaac&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 19 Nov 2015 16:42:14 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/DMA-preemption-problem-K24/m-p/403490#M1601</guid>
      <dc:creator>isaacavila</dc:creator>
      <dc:date>2015-11-19T16:42:14Z</dc:date>
    </item>
  </channel>
</rss>

