<?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>ColdFire/68K Microcontrollers and ProcessorsのトピックProblem with chip select line with qspi on mcf52233</title>
    <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160867#M5081</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;DIV&gt;I am having problems with the chip select line. I need it to be active low and can only get it to work active high. When I set the &amp;nbsp;MCF_QSPI_QWR[CSIV] bit the line doesn't do anything. If I don't set the bit the chip select line works but is active high. I&amp;nbsp;am trying to use an external a-d chip and when I use the cs line as an&amp;nbsp;I/O it is too slow so&amp;nbsp;I need to use the qspi chip select. I also tried another board to make sure it wasn't the chip without any luck. Any help would be great.&lt;/DIV&gt;&lt;DIV&gt;Here is my code:&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;void&amp;nbsp; &amp;nbsp;spi_init()&lt;BR /&gt;{&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;int temp_buff[2];&lt;BR /&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;/* Enable QSPI Pins Primary Functions */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR =&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_DOUT_DOUT|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_DIN_DIN|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_SCK_SCK|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_CS0_CS0;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QMR&amp;nbsp;= MCF_QSPI_QMR_MSTR&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QMR_CPOL&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QMR_BAUD(3);&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;&lt;BR /&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;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR&amp;nbsp;&amp;nbsp;&amp;nbsp; = MCF_QSPI_QIR_ABRTL&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_ABRTB&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;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_WCEFB&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_ABRT&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_WCEF&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_SPIF;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QWR &amp;nbsp;= MCF_QSPI_QWR_NEWQP(0)&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QWR_ENDQP(0)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QWR_CSIV ; //**//&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR &amp;nbsp;= MCF_QSPI_QDLYR_DTL(1)&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QDLYR_QCD(3)&amp;nbsp; ;&lt;/DIV&gt;&lt;DIV&gt;///////////************************//////////////&lt;BR /&gt;&amp;nbsp;//command pointer set&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x4100;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR&amp;nbsp; &amp;nbsp;=&amp;nbsp;0x8030;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;BR /&gt;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|=&amp;nbsp;MCF_QSPI_QDLYR_SPE;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR |= MCF_QSPI_QIR_SPIF;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;temp_buff[0] = MCF_QSPI_QDR &amp;amp; 0x1FFF;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;///////////************************//////////////&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;//command pointer set&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x4100;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;=&amp;nbsp;0xBFE0;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|= MCF_QSPI_QDLYR_SPE;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR |= MCF_QSPI_QIR_SPIF;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;temp_buff[1] = MCF_QSPI_QDR &amp;amp; 0x1FFF;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;DIV&gt;&lt;BR /&gt;void &amp;nbsp;a2d_spi()&lt;BR /&gt;{&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;int i = 0;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x7100; &amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;=&amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QWR |= MCF_QSPI_QWR_WREN;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QWR &amp;amp;= ~MCF_QSPI_QWR_HALT;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|=&amp;nbsp; MCF_QSPI_QDLYR_SPE&amp;nbsp;;&lt;BR /&gt;&amp;nbsp;//&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;while(1)//i&amp;lt;5000) &amp;nbsp;&lt;BR /&gt;&amp;nbsp;{&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QIR = 0xD00F;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;data_buff[0/*i++*/ ] = MCF_QSPI_QDR;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QWR |= MCF_QSPI_QWR_HALT;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;}&amp;nbsp;&amp;nbsp;&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 06 Nov 2007 00:24:05 GMT</pubDate>
    <dc:creator>admin</dc:creator>
    <dc:date>2007-11-06T00:24:05Z</dc:date>
    <item>
      <title>Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160867#M5081</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;DIV&gt;I am having problems with the chip select line. I need it to be active low and can only get it to work active high. When I set the &amp;nbsp;MCF_QSPI_QWR[CSIV] bit the line doesn't do anything. If I don't set the bit the chip select line works but is active high. I&amp;nbsp;am trying to use an external a-d chip and when I use the cs line as an&amp;nbsp;I/O it is too slow so&amp;nbsp;I need to use the qspi chip select. I also tried another board to make sure it wasn't the chip without any luck. Any help would be great.&lt;/DIV&gt;&lt;DIV&gt;Here is my code:&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;void&amp;nbsp; &amp;nbsp;spi_init()&lt;BR /&gt;{&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;int temp_buff[2];&lt;BR /&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;/* Enable QSPI Pins Primary Functions */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR =&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_DOUT_DOUT|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_DIN_DIN|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_SCK_SCK|&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;MCF_GPIO_PQSPAR_CS0_CS0;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QMR&amp;nbsp;= MCF_QSPI_QMR_MSTR&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QMR_CPOL&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QMR_BAUD(3);&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;&lt;BR /&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;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR&amp;nbsp;&amp;nbsp;&amp;nbsp; = MCF_QSPI_QIR_ABRTL&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_ABRTB&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;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_WCEFB&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_ABRT&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_WCEF&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QIR_SPIF;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QWR &amp;nbsp;= MCF_QSPI_QWR_NEWQP(0)&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QWR_ENDQP(0)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QWR_CSIV ; //**//&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR &amp;nbsp;= MCF_QSPI_QDLYR_DTL(1)&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;| MCF_QSPI_QDLYR_QCD(3)&amp;nbsp; ;&lt;/DIV&gt;&lt;DIV&gt;///////////************************//////////////&lt;BR /&gt;&amp;nbsp;//command pointer set&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x4100;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR&amp;nbsp; &amp;nbsp;=&amp;nbsp;0x8030;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;BR /&gt;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|=&amp;nbsp;MCF_QSPI_QDLYR_SPE;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR |= MCF_QSPI_QIR_SPIF;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;temp_buff[0] = MCF_QSPI_QDR &amp;amp; 0x1FFF;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;///////////************************//////////////&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;//command pointer set&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x4100;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;=&amp;nbsp;0xBFE0;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|= MCF_QSPI_QDLYR_SPE;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QIR |= MCF_QSPI_QIR_SPIF;&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;temp_buff[1] = MCF_QSPI_QDR &amp;amp; 0x1FFF;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;}&lt;/DIV&gt;&lt;DIV&gt;&lt;BR /&gt;void &amp;nbsp;a2d_spi()&lt;BR /&gt;{&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;int i = 0;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR&amp;nbsp;&amp;nbsp;&amp;nbsp; =&amp;nbsp;&amp;nbsp; 0x0020;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;= &amp;nbsp;0x7100; &amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QAR &amp;nbsp;= &amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QDR &amp;nbsp;=&amp;nbsp;0x0000;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QWR |= MCF_QSPI_QWR_WREN;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QWR &amp;amp;= ~MCF_QSPI_QWR_HALT;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;//start transfer&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QDLYR&amp;nbsp;|=&amp;nbsp; MCF_QSPI_QDLYR_SPE&amp;nbsp;;&lt;BR /&gt;&amp;nbsp;//&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;while(1)//i&amp;lt;5000) &amp;nbsp;&lt;BR /&gt;&amp;nbsp;{&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;// wait for transfer to complete&lt;BR /&gt;&amp;nbsp;&amp;nbsp;while(!(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF))&amp;nbsp;{}&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QIR = 0xD00F;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;MCF_QSPI_QAR = 0x0010;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;data_buff[0/*i++*/ ] = MCF_QSPI_QDR;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;}&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;MCF_QSPI_QWR |= MCF_QSPI_QWR_HALT;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;}&amp;nbsp;&amp;nbsp;&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Nov 2007 00:24:05 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160867#M5081</guid>
      <dc:creator>admin</dc:creator>
      <dc:date>2007-11-06T00:24:05Z</dc:date>
    </item>
    <item>
      <title>Re: Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160868#M5082</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;The CSIV bit worked for me on the 52233 chip. You have to set it on every write to the QWR register; early in initialization I send just that bit to the QWR.&lt;BR /&gt;&lt;BR /&gt;I noticed in your code you have &amp;amp;= and |= into device registers. I found out the hard way that doesn't always work (on the 5282 you cannot |= into QDLYR for example). It is safer to construct the entire write value and use a simple = assignment for device output.&lt;BR /&gt;&lt;DIV&gt;&lt;/DIV&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Nov 2007 04:55:58 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160868#M5082</guid>
      <dc:creator>bkatt</dc:creator>
      <dc:date>2007-11-06T04:55:58Z</dc:date>
    </item>
    <item>
      <title>Re: Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160869#M5083</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;DIV&gt;I went back and changed all the &amp;amp;= and |=. Thats good to know so I don't run into that later. It didn't fix the problem. I went into debug mode and verified that that CSIV bit is set but I just get a high output the entire time. I unset the bit and got the chipselect line working but active high.&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Nov 2007 05:25:58 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160869#M5083</guid>
      <dc:creator>admin</dc:creator>
      <dc:date>2007-11-06T05:25:58Z</dc:date>
    </item>
    <item>
      <title>Re: Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160870#M5084</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;DIV&gt;I use the following code to write to a Digital to Analog device using MCF52223 Coldfire device using CS Active low interface. The Chip Select 4-bit nibble in Command register should be set&amp;nbsp;to what the CSx pin state should be when active. For example CS0 would be binary %1110 or 0xE hex. Hope this helps.&lt;/DIV&gt;&lt;DIV&gt;&amp;nbsp;&lt;/DIV&gt;&lt;DIV&gt;&lt;DIV class="msg_source_code"&gt;&lt;DIV class="text_smallest"&gt;Code:&lt;/DIV&gt;&lt;PRE&gt;INT8U SetAnalogOut(INT8U Data){ /* Local variables */ int Timeout; INT16U SerialData, Value;   /* Convert volt data to binary */ Value = Data / 10;   SerialData = (Data * 5) + Value;   SerialData &amp;lt;&amp;lt;= 4; /* Check for QSPI in operation */ if(MCF_QSPI_QDLYR &amp;amp; MCF_QSPI_QDLYR_SPE) {  for(Timeout = 0; Timeout &amp;lt;= QSPI_TIMEOUT; Timeout++)  {   /* Check for QSPI in operation */   if(MCF_QSPI_QDLYR &amp;amp; MCF_QSPI_QDLYR_SPE)    /* Timeout elapsed— */    if(Timeout &amp;gt;= QSPI_TIMEOUT)     /* Exit with timeout err */     return QSPI_TIMEOUT_ERR;    else    /* Exit loop, QSPI is free */    break;  } } /* Setup for 16-bit transfer */ MCF_QSPI_QMR = 0x8004; /* No error interrupts */ MCF_QSPI_QIR = 0x0000; /* Point to first command entry */ MCF_QSPI_QAR = 0x0020; /* Setup SPI transfer command */ MCF_QSPI_QDR = 0x4b00; /* Point to first data entry */ MCF_QSPI_QAR = 0x0000; /* Setup SPI transfer data */ MCF_QSPI_QDR = SerialData; /* Just use first entry in queue */ MCF_QSPI_QWR = 0x1000; /* Start spi transfer */ MCF_QSPI_QDLYR = 0x8001; for(Timeout = 0; Timeout &amp;lt;= QSPI_TIMEOUT; Timeout++) {  /* Check for QSPI in operation */  if(MCF_QSPI_QIR &amp;amp; MCF_QSPI_QIR_SPIF)   break;  else   if(Timeout &amp;gt;= QSPI_TIMEOUT)    /* Exit with timeout err */    return;  }}&lt;/PRE&gt;&lt;/DIV&gt;&lt;BR /&gt;&amp;nbsp;&lt;BR /&gt;&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 29 Oct 2020 09:06:17 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160870#M5084</guid>
      <dc:creator>Technoman64</dc:creator>
      <dc:date>2020-10-29T09:06:17Z</dc:date>
    </item>
    <item>
      <title>Re: Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160871#M5085</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;As technoman said, the chip select pattern written into the QDR must also be inverted. In the CSIV case I use these chip select defines:&lt;BR /&gt;&lt;BR /&gt;#define CS0&amp;nbsp; &amp;nbsp;&amp;nbsp; 0xE00&lt;BR /&gt;#define CS1&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 0xD00&lt;BR /&gt;#define CS2&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 0xB00&lt;BR /&gt;#define CS3&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; 0x700&lt;BR /&gt;&lt;BR /&gt;It would be reasonable to expect the device to do this for you when you have CSIV on, but for whatever reason the hardware requires the software to account for it.&lt;BR /&gt;&lt;DIV&gt;&lt;/DIV&gt;&lt;BR /&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Nov 2007 21:24:05 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160871#M5085</guid>
      <dc:creator>bkatt</dc:creator>
      <dc:date>2007-11-06T21:24:05Z</dc:date>
    </item>
    <item>
      <title>Re: Problem with chip select line with qspi on mcf52233</title>
      <link>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160872#M5086</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;DIV&gt;That was it. I didn't invert the chip select bit in the QDR. I don't think I would have figured that out. I guess this is one of those small things that are big when you don't know it. Thank you all for all your help. That saved me a lot of time and headaches.&lt;/DIV&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Nov 2007 22:42:50 GMT</pubDate>
      <guid>https://community.nxp.com/t5/ColdFire-68K-Microcontrollers/Problem-with-chip-select-line-with-qspi-on-mcf52233/m-p/160872#M5086</guid>
      <dc:creator>admin</dc:creator>
      <dc:date>2007-11-06T22:42:50Z</dc:date>
    </item>
  </channel>
</rss>

