<?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: AN4369: Audio options for Kinetis in Kinetis Microcontrollers</title>
    <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173534#M1340</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks finally found it. I have a few questions regarding I2S example. I think the TCD is not set properly for I2S mode. See the code below for the code marked in red which is not used for I2S mode.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; // fill the TCD area&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) Audio_Source_Blk_A ; // alternated with Audio_Source_Blk_B&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SOFF&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = 2;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // 2 byte offset&lt;BR /&gt;&amp;nbsp; DMA_TCD0_ATTR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = DMA_ATTR_SMOD(0) | DMA_ATTR_SSIZE(1) | DMA_ATTR_DMOD(0) | DMA_ATTR_DSIZE(1);&amp;nbsp;&amp;nbsp; // no circular addressing S&amp;amp;D, 16 bit S&amp;amp;D&lt;BR /&gt;&amp;nbsp; DMA_TCD0_NBYTES_MLNO&amp;nbsp;&amp;nbsp;&amp;nbsp; = 2;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // one&amp;nbsp; 16bit sample every minor loop&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SLAST&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;//-(AUDIO_SIZE*2);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // source address will always be newly written before each new start&amp;nbsp; DMA_TCD0_DADDR &amp;nbsp;&lt;BR /&gt;#if (AUDIO_DMA_OUTPUT == USE_PWM)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;FTM2_C0V;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value &amp;nbsp;&lt;BR /&gt;#elif (AUDIO_DMA_OUTPUT == USE_I2S)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;I2S0_TX0;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value&lt;BR /&gt;#elif (AUDIO_DMA_OUTPUT == USE_DAC)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;DAC0_DAT0L;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_DOFF = 0;&lt;/FONT&gt;&lt;/FONT&gt;&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_CITER_ELINKNO = AUDIO_SIZE&lt;/FONT&gt;&lt;/FONT&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; // total samples ( &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;128&lt;/FONT&gt;&lt;/FONT&gt; )&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCDO_DLASTSGA = 0;&lt;/FONT&gt;&lt;/FONT&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; // no final last adjustment ( does not move )&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_CSR = DMA_CSR_INTMAJOR_MASK&lt;/FONT&gt;&lt;/FONT&gt;;&amp;nbsp; // interrupt when done &amp;nbsp;&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_BITER_ELINKNO = AUDIO_SIZE&lt;/FONT&gt;&lt;/FONT&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; // no chan links, total samples ( &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;128&lt;/FONT&gt;&lt;/FONT&gt;)&lt;BR /&gt;#endif //DMA_OUTPUT&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Can anyone please confirm if this is correct ?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Mohsin455&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sun, 24 Jun 2012 04:24:01 GMT</pubDate>
    <dc:creator>Mohsin455</dc:creator>
    <dc:date>2012-06-24T04:24:01Z</dc:date>
    <item>
      <title>AN4369: Audio options for Kinetis</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173532#M1338</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Hi All,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&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; Can anyone please provide me the link to the example code used in AN4369: Audio options for Kinetis ?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;Mohsin455&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 20 Jun 2012 18:19:50 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173532#M1338</guid>
      <dc:creator>Mohsin455</dc:creator>
      <dc:date>2012-06-20T18:19:50Z</dc:date>
    </item>
    <item>
      <title>Re: AN4369: Audio options for Kinetis</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173533#M1339</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Search by keyword can be your friend. Anyway, here's the link:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;A href="http://cache.freescale.com/files/32bit/doc/app_note/AN4369SW.zip" rel="nofollow" target="_self"&gt;http://cache.freescale.com/files/32bit/doc/app_note/AN4369SW.zip&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;---Tom&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 21 Jun 2012 20:03:36 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173533#M1339</guid>
      <dc:creator>J2MEJediMaster</dc:creator>
      <dc:date>2012-06-21T20:03:36Z</dc:date>
    </item>
    <item>
      <title>Re: AN4369: Audio options for Kinetis</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173534#M1340</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks finally found it. I have a few questions regarding I2S example. I think the TCD is not set properly for I2S mode. See the code below for the code marked in red which is not used for I2S mode.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; // fill the TCD area&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) Audio_Source_Blk_A ; // alternated with Audio_Source_Blk_B&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SOFF&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = 2;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // 2 byte offset&lt;BR /&gt;&amp;nbsp; DMA_TCD0_ATTR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = DMA_ATTR_SMOD(0) | DMA_ATTR_SSIZE(1) | DMA_ATTR_DMOD(0) | DMA_ATTR_DSIZE(1);&amp;nbsp;&amp;nbsp; // no circular addressing S&amp;amp;D, 16 bit S&amp;amp;D&lt;BR /&gt;&amp;nbsp; DMA_TCD0_NBYTES_MLNO&amp;nbsp;&amp;nbsp;&amp;nbsp; = 2;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // one&amp;nbsp; 16bit sample every minor loop&lt;BR /&gt;&amp;nbsp; DMA_TCD0_SLAST&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = 0;//-(AUDIO_SIZE*2);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // source address will always be newly written before each new start&amp;nbsp; DMA_TCD0_DADDR &amp;nbsp;&lt;BR /&gt;#if (AUDIO_DMA_OUTPUT == USE_PWM)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;FTM2_C0V;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value &amp;nbsp;&lt;BR /&gt;#elif (AUDIO_DMA_OUTPUT == USE_I2S)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;I2S0_TX0;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value&lt;BR /&gt;#elif (AUDIO_DMA_OUTPUT == USE_DAC)&lt;BR /&gt;&amp;nbsp; DMA_TCD0_DADDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; = (uint32_t) &amp;amp;DAC0_DAT0L;&amp;nbsp;&amp;nbsp;&amp;nbsp; // the FTM Channel 0 duty value&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_DOFF = 0;&lt;/FONT&gt;&lt;/FONT&gt;&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_CITER_ELINKNO = AUDIO_SIZE&lt;/FONT&gt;&lt;/FONT&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; // total samples ( &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;128&lt;/FONT&gt;&lt;/FONT&gt; )&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCDO_DLASTSGA = 0;&lt;/FONT&gt;&lt;/FONT&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; // no final last adjustment ( does not move )&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_CSR = DMA_CSR_INTMAJOR_MASK&lt;/FONT&gt;&lt;/FONT&gt;;&amp;nbsp; // interrupt when done &amp;nbsp;&lt;BR /&gt;&amp;nbsp; &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;DMA_TCD0_BITER_ELINKNO = AUDIO_SIZE&lt;/FONT&gt;&lt;/FONT&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; // no chan links, total samples ( &lt;FONT color="#FF0000"&gt;&lt;FONT size="2"&gt;128&lt;/FONT&gt;&lt;/FONT&gt;)&lt;BR /&gt;#endif //DMA_OUTPUT&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Can anyone please confirm if this is correct ?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Mohsin455&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 24 Jun 2012 04:24:01 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173534#M1340</guid>
      <dc:creator>Mohsin455</dc:creator>
      <dc:date>2012-06-24T04:24:01Z</dc:date>
    </item>
    <item>
      <title>Re: AN4369: Audio options for Kinetis</title>
      <link>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173535#M1341</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;did anyone try with success to play a .wav file from an SD card directly using the AN4369 example?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks for any response&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thomas&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 19 Jul 2013 07:13:52 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Microcontrollers/AN4369-Audio-options-for-Kinetis/m-p/173535#M1341</guid>
      <dc:creator>ThomNet</dc:creator>
      <dc:date>2013-07-19T07:13:52Z</dc:date>
    </item>
  </channel>
</rss>

