<?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 SPI with DMA, KL16Z128, Procesor expert in Processor Expert Software</title>
    <link>https://community.nxp.com/t5/Processor-Expert-Software/SPI-with-DMA-KL16Z128-Procesor-expert/m-p/613479#M3959</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; color: black;"&gt;Hi All,&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; color: black;"&gt;I am using processor KL16Z128 and KDS3.2 + PEx.&lt;BR /&gt; Because of speed and absence of SPI's input buffer I need to use SPI with DMA. If I set SPI parameters according to print screens attached below then every sent frame repeats its first byte (an extra byte is sent). How do I remove this extra byte? I found similar problem in discussion. It was solved with writing to register &lt;/SPAN&gt;&lt;SPAN style="font-size: 11.5pt; color: black; background: white;"&gt;SPI1_C3 = 0x01. &lt;/SPAN&gt;&lt;SPAN style="font-size: 11.5pt; color: black; background: white;"&gt;I have to use SPI0 and SPI0 does not have this register. If I allow trigger on RxDMA then I can see repeated byte only in first frame but I do not receive any data! Does anybody knows how to solve this problem?&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;LDD_TDeviceData *TimerData; // triggerTimer&lt;BR /&gt; LDD_TDeviceData *MySPIEthPtr; // SPI ETH W5200&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;TimerData = TU1_Init(NULL); // trigger Timer 40us&lt;BR /&gt; MySPIEthPtr = SpiETH_Init(NULL); // Spi pro W5200 ETH&lt;/P&gt;&lt;P&gt;w5200_spi_comm_buff[0] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[1] = 0x00;&lt;BR /&gt; // OP code + length&lt;BR /&gt; w5200_spi_comm_buff[2] = 0x80;&lt;BR /&gt; w5200_spi_comm_buff[3] = 19;&lt;BR /&gt; // mode registr = 0x00&lt;BR /&gt; w5200_spi_comm_buff[4] = 0x00;&lt;BR /&gt; // gateway&lt;BR /&gt; w5200_spi_comm_buff[5] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[6] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[7] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[8] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[3];&lt;BR /&gt; // subnet mask&lt;BR /&gt; w5200_spi_comm_buff[9] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[0];&lt;BR /&gt; w5200_spi_comm_buff[10] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[1];&lt;BR /&gt; w5200_spi_comm_buff[11] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[2];&lt;BR /&gt; w5200_spi_comm_buff[12] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[3];&lt;BR /&gt; // MAC adresa&lt;BR /&gt; w5200_spi_comm_buff[13] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[14] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[15] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[16] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[3];&lt;BR /&gt; w5200_spi_comm_buff[17] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[4];&lt;BR /&gt; w5200_spi_comm_buff[18] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[5];&lt;BR /&gt; // Source IP address&lt;BR /&gt; w5200_spi_comm_buff[19] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[20] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[21] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[22] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[3];&lt;BR /&gt; // &lt;BR /&gt; SpiETH_ReceiveBlock(MySPIEthPtr, data_buff_tmp, 23);&lt;BR /&gt; SpiETH_SendBlock(MySPIEthPtr, w5200_spi_comm_buff, 23);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Send&lt;/P&gt;&lt;P&gt;while(!SpiETH_GetBlockSentStatus(MySPIEthPtr))&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Check receive&lt;/SPAN&gt;&lt;BR /&gt; {}&lt;/P&gt;&lt;P&gt;&lt;BR /&gt; w5200_spi_comm_buff[0] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[1] = 0x00;&lt;BR /&gt; // OP code + length&lt;BR /&gt; w5200_spi_comm_buff[2] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[3] = 19;&lt;/P&gt;&lt;P&gt;DataReceivedSpiEthFlag = 0;&lt;BR /&gt; SpiETH_ReceiveBlock(MySPIEthPtr, data_buff_tmp, 23);&lt;BR /&gt; SpiETH_SendBlock(MySPIEthPtr, w5200_spi_comm_buff, 23);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Send&lt;/P&gt;&lt;P&gt;&lt;BR /&gt; while(!SpiETH_GetBlockReceivedStatus(MySPIEthPtr))&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;// Check receive&lt;BR /&gt; {}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="tek000150.jpg"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/12805i459C4F63314B6124/image-size/large?v=v2&amp;amp;px=999" role="button" title="tek000150.jpg" alt="tek000150.jpg" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;Without the trigger on Rx / Tx I do not receive data.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 14 Dec 2016 14:52:33 GMT</pubDate>
    <dc:creator>cerma</dc:creator>
    <dc:date>2016-12-14T14:52:33Z</dc:date>
    <item>
      <title>SPI with DMA, KL16Z128, Procesor expert</title>
      <link>https://community.nxp.com/t5/Processor-Expert-Software/SPI-with-DMA-KL16Z128-Procesor-expert/m-p/613479#M3959</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; color: black;"&gt;Hi All,&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 11.0pt; color: black;"&gt;I am using processor KL16Z128 and KDS3.2 + PEx.&lt;BR /&gt; Because of speed and absence of SPI's input buffer I need to use SPI with DMA. If I set SPI parameters according to print screens attached below then every sent frame repeats its first byte (an extra byte is sent). How do I remove this extra byte? I found similar problem in discussion. It was solved with writing to register &lt;/SPAN&gt;&lt;SPAN style="font-size: 11.5pt; color: black; background: white;"&gt;SPI1_C3 = 0x01. &lt;/SPAN&gt;&lt;SPAN style="font-size: 11.5pt; color: black; background: white;"&gt;I have to use SPI0 and SPI0 does not have this register. If I allow trigger on RxDMA then I can see repeated byte only in first frame but I do not receive any data! Does anybody knows how to solve this problem?&amp;nbsp;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;LDD_TDeviceData *TimerData; // triggerTimer&lt;BR /&gt; LDD_TDeviceData *MySPIEthPtr; // SPI ETH W5200&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;TimerData = TU1_Init(NULL); // trigger Timer 40us&lt;BR /&gt; MySPIEthPtr = SpiETH_Init(NULL); // Spi pro W5200 ETH&lt;/P&gt;&lt;P&gt;w5200_spi_comm_buff[0] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[1] = 0x00;&lt;BR /&gt; // OP code + length&lt;BR /&gt; w5200_spi_comm_buff[2] = 0x80;&lt;BR /&gt; w5200_spi_comm_buff[3] = 19;&lt;BR /&gt; // mode registr = 0x00&lt;BR /&gt; w5200_spi_comm_buff[4] = 0x00;&lt;BR /&gt; // gateway&lt;BR /&gt; w5200_spi_comm_buff[5] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[6] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[7] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[8] = w5200_init_conf_params_ptr-&amp;gt;gateway_addr[3];&lt;BR /&gt; // subnet mask&lt;BR /&gt; w5200_spi_comm_buff[9] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[0];&lt;BR /&gt; w5200_spi_comm_buff[10] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[1];&lt;BR /&gt; w5200_spi_comm_buff[11] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[2];&lt;BR /&gt; w5200_spi_comm_buff[12] = w5200_init_conf_params_ptr-&amp;gt;subnet_mask[3];&lt;BR /&gt; // MAC adresa&lt;BR /&gt; w5200_spi_comm_buff[13] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[14] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[15] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[16] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[3];&lt;BR /&gt; w5200_spi_comm_buff[17] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[4];&lt;BR /&gt; w5200_spi_comm_buff[18] = w5200_init_conf_params_ptr-&amp;gt;mac_addr[5];&lt;BR /&gt; // Source IP address&lt;BR /&gt; w5200_spi_comm_buff[19] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[0];&lt;BR /&gt; w5200_spi_comm_buff[20] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[1];&lt;BR /&gt; w5200_spi_comm_buff[21] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[2];&lt;BR /&gt; w5200_spi_comm_buff[22] = w5200_init_conf_params_ptr-&amp;gt;source_ip_addr[3];&lt;BR /&gt; // &lt;BR /&gt; SpiETH_ReceiveBlock(MySPIEthPtr, data_buff_tmp, 23);&lt;BR /&gt; SpiETH_SendBlock(MySPIEthPtr, w5200_spi_comm_buff, 23);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Send&lt;/P&gt;&lt;P&gt;while(!SpiETH_GetBlockSentStatus(MySPIEthPtr))&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&lt;/SPAN&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Check receive&lt;/SPAN&gt;&lt;BR /&gt; {}&lt;/P&gt;&lt;P&gt;&lt;BR /&gt; w5200_spi_comm_buff[0] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[1] = 0x00;&lt;BR /&gt; // OP code + length&lt;BR /&gt; w5200_spi_comm_buff[2] = 0x00;&lt;BR /&gt; w5200_spi_comm_buff[3] = 19;&lt;/P&gt;&lt;P&gt;DataReceivedSpiEthFlag = 0;&lt;BR /&gt; SpiETH_ReceiveBlock(MySPIEthPtr, data_buff_tmp, 23);&lt;BR /&gt; SpiETH_SendBlock(MySPIEthPtr, w5200_spi_comm_buff, 23);&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;// Send&lt;/P&gt;&lt;P&gt;&lt;BR /&gt; while(!SpiETH_GetBlockReceivedStatus(MySPIEthPtr))&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;// Check receive&lt;BR /&gt; {}&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="tek000150.jpg"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/12805i459C4F63314B6124/image-size/large?v=v2&amp;amp;px=999" role="button" title="tek000150.jpg" alt="tek000150.jpg" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #000000; background-color: #ffffff;"&gt;Without the trigger on Rx / Tx I do not receive data.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 14 Dec 2016 14:52:33 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Processor-Expert-Software/SPI-with-DMA-KL16Z128-Procesor-expert/m-p/613479#M3959</guid>
      <dc:creator>cerma</dc:creator>
      <dc:date>2016-12-14T14:52:33Z</dc:date>
    </item>
  </channel>
</rss>

