<?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 HCS08: IIC MST-Bit cannot be set (MC9S08DZ60, IIC-Master-Mode) in 8-bit Microcontrollers</title>
    <link>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222882#M19244</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello all,&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;i am having a problem with IIC Master Mode at MC9S08DZ60CLC MCU. Since two days I try to figure out how to send anything on IIC-bus.&lt;/P&gt;&lt;P&gt;What I did: Initialize IIC -&amp;gt; Try to send 1 byte.&lt;/P&gt;&lt;P&gt;What happens:&lt;STRONG&gt; Nothing&lt;/STRONG&gt; (I monitor SDA, SCL with Logic-Analyzer, function verified). SDA, SCL lines stay high always.&lt;/P&gt;&lt;P&gt;What I can do: Toggle the two pins manually when setting them to GPIO.&lt;/P&gt;&lt;P&gt;What I read so far: Datasheet, AN3291 "How to Use IIC Module on M68HC08, HCS08, and HCS12 MCUs", HCS08QRUG.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Anybody has any idea what could be the problem?&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I would expect that my code (at least once) generates a start condition on the bus and/or transmit the data byte... &lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Kind regards,&lt;/P&gt;&lt;P&gt;Alex&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG style="text-decoration: underline;"&gt;Here is my (complete!) code:&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;void main(void) {&lt;BR /&gt;&amp;nbsp; MCU_init();&amp;nbsp; &lt;BR /&gt;&amp;nbsp; IICC_IICEN = 1;//Enable IIC module&lt;BR /&gt;&amp;nbsp; IICC_TXAK = 1;// SEND ACK &lt;BR /&gt;&amp;nbsp; IICC_MST = 0;//SLAVE MODE&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp; IICA = 0b10;//set slave address in IICA&amp;nbsp; //PTB6=SDA PTB7=SCL&lt;BR /&gt; &lt;BR /&gt;&amp;nbsp; //set baud rate = BUSCLK/(2xMULTx(SCL Divider))&lt;BR /&gt;&amp;nbsp; //&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; MUX | ICR|&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; &lt;BR /&gt;&amp;nbsp; IICF = 0b10010000;//MUX=2,ICR=0x16 Speed=100Khz&lt;/P&gt;&lt;P&gt;&amp;nbsp; IICS_SRW = 0;//R/W bit&amp;nbsp; = 0&lt;BR /&gt;&amp;nbsp; IICC_IICIE = 0;//Disable IIC interrupt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp; PTAD_PTAD7 = 1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; for(;;) {&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(IICC_MST == 1){&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PTAD_PTAD7 = 0;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; }&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(TPM1SC_TOF){&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WriteBytesI2C(0xAB, 0x0);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IICC_MST = 0;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1SC_TOF = 0;&lt;BR /&gt;&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; __RESET_WATCHDOG(); //By default COP is disabled with device init. When enabling, also reset the watchdog. */&lt;BR /&gt;&amp;nbsp; } /* loop forever */&lt;BR /&gt;&amp;nbsp; /* please make sure that you never leave main */&lt;BR /&gt;}&lt;/P&gt;&lt;P&gt;unsigned char WriteBytesI2C (unsigned char slaveAddress,unsigned char numberOfBytes){&lt;BR /&gt;&amp;nbsp; unsigned char Temp;&lt;BR /&gt;&amp;nbsp; &lt;BR /&gt;&amp;nbsp; /* Format the slave address to place a 0 on the R/W bit (LSB).*/&lt;BR /&gt;&amp;nbsp; slaveAddress &amp;amp;= 0xFE;&lt;BR /&gt;&amp;nbsp; IICC_IICEN = 0;&lt;BR /&gt;&amp;nbsp; IICC_IICEN = 1;&lt;BR /&gt;&amp;nbsp; IICS; /* Clear any pending interrupt */&lt;BR /&gt;&amp;nbsp; IICS_IICIF=1;&lt;BR /&gt;&amp;nbsp; IICC_MST = 0;&lt;BR /&gt;&amp;nbsp; IICS_SRW=0;&lt;BR /&gt;&amp;nbsp; IICC_TX = 1; /* Select Transmit Mode */&lt;BR /&gt;&amp;nbsp; IICC_MST = 1; /* Select Master Mode (Send Start Bit) */&lt;BR /&gt;&amp;nbsp; for(Temp=0;Temp&amp;lt;50;Temp++); /* Small delay */&lt;BR /&gt;&amp;nbsp; IICD=slaveAddress; /* Send selected slave address */&lt;BR /&gt;&amp;nbsp; return(1);&lt;BR /&gt;}&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 25 Jul 2013 07:21:06 GMT</pubDate>
    <dc:creator>alexanderbuerge</dc:creator>
    <dc:date>2013-07-25T07:21:06Z</dc:date>
    <item>
      <title>HCS08: IIC MST-Bit cannot be set (MC9S08DZ60, IIC-Master-Mode)</title>
      <link>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222882#M19244</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello all,&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;i am having a problem with IIC Master Mode at MC9S08DZ60CLC MCU. Since two days I try to figure out how to send anything on IIC-bus.&lt;/P&gt;&lt;P&gt;What I did: Initialize IIC -&amp;gt; Try to send 1 byte.&lt;/P&gt;&lt;P&gt;What happens:&lt;STRONG&gt; Nothing&lt;/STRONG&gt; (I monitor SDA, SCL with Logic-Analyzer, function verified). SDA, SCL lines stay high always.&lt;/P&gt;&lt;P&gt;What I can do: Toggle the two pins manually when setting them to GPIO.&lt;/P&gt;&lt;P&gt;What I read so far: Datasheet, AN3291 "How to Use IIC Module on M68HC08, HCS08, and HCS12 MCUs", HCS08QRUG.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Anybody has any idea what could be the problem?&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I would expect that my code (at least once) generates a start condition on the bus and/or transmit the data byte... &lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Kind regards,&lt;/P&gt;&lt;P&gt;Alex&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;STRONG style="text-decoration: underline;"&gt;Here is my (complete!) code:&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;void main(void) {&lt;BR /&gt;&amp;nbsp; MCU_init();&amp;nbsp; &lt;BR /&gt;&amp;nbsp; IICC_IICEN = 1;//Enable IIC module&lt;BR /&gt;&amp;nbsp; IICC_TXAK = 1;// SEND ACK &lt;BR /&gt;&amp;nbsp; IICC_MST = 0;//SLAVE MODE&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp; IICA = 0b10;//set slave address in IICA&amp;nbsp; //PTB6=SDA PTB7=SCL&lt;BR /&gt; &lt;BR /&gt;&amp;nbsp; //set baud rate = BUSCLK/(2xMULTx(SCL Divider))&lt;BR /&gt;&amp;nbsp; //&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; MUX | ICR|&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; &lt;BR /&gt;&amp;nbsp; IICF = 0b10010000;//MUX=2,ICR=0x16 Speed=100Khz&lt;/P&gt;&lt;P&gt;&amp;nbsp; IICS_SRW = 0;//R/W bit&amp;nbsp; = 0&lt;BR /&gt;&amp;nbsp; IICC_IICIE = 0;//Disable IIC interrupt&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp; PTAD_PTAD7 = 1;&lt;/P&gt;&lt;P&gt;&amp;nbsp; for(;;) {&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(IICC_MST == 1){&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PTAD_PTAD7 = 0;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; }&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(TPM1SC_TOF){&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; WriteBytesI2C(0xAB, 0x0);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; IICC_MST = 0;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; TPM1SC_TOF = 0;&lt;BR /&gt;&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; __RESET_WATCHDOG(); //By default COP is disabled with device init. When enabling, also reset the watchdog. */&lt;BR /&gt;&amp;nbsp; } /* loop forever */&lt;BR /&gt;&amp;nbsp; /* please make sure that you never leave main */&lt;BR /&gt;}&lt;/P&gt;&lt;P&gt;unsigned char WriteBytesI2C (unsigned char slaveAddress,unsigned char numberOfBytes){&lt;BR /&gt;&amp;nbsp; unsigned char Temp;&lt;BR /&gt;&amp;nbsp; &lt;BR /&gt;&amp;nbsp; /* Format the slave address to place a 0 on the R/W bit (LSB).*/&lt;BR /&gt;&amp;nbsp; slaveAddress &amp;amp;= 0xFE;&lt;BR /&gt;&amp;nbsp; IICC_IICEN = 0;&lt;BR /&gt;&amp;nbsp; IICC_IICEN = 1;&lt;BR /&gt;&amp;nbsp; IICS; /* Clear any pending interrupt */&lt;BR /&gt;&amp;nbsp; IICS_IICIF=1;&lt;BR /&gt;&amp;nbsp; IICC_MST = 0;&lt;BR /&gt;&amp;nbsp; IICS_SRW=0;&lt;BR /&gt;&amp;nbsp; IICC_TX = 1; /* Select Transmit Mode */&lt;BR /&gt;&amp;nbsp; IICC_MST = 1; /* Select Master Mode (Send Start Bit) */&lt;BR /&gt;&amp;nbsp; for(Temp=0;Temp&amp;lt;50;Temp++); /* Small delay */&lt;BR /&gt;&amp;nbsp; IICD=slaveAddress; /* Send selected slave address */&lt;BR /&gt;&amp;nbsp; return(1);&lt;BR /&gt;}&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 25 Jul 2013 07:21:06 GMT</pubDate>
      <guid>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222882#M19244</guid>
      <dc:creator>alexanderbuerge</dc:creator>
      <dc:date>2013-07-25T07:21:06Z</dc:date>
    </item>
    <item>
      <title>Re: HCS08: IIC MST-Bit cannot be set (MC9S08DZ60, IIC-Master-Mode)</title>
      <link>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222883#M19245</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Buergel,&lt;/P&gt;&lt;P&gt;I attached one IIC driver for your reference.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 25 Jul 2013 09:47:10 GMT</pubDate>
      <guid>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222883#M19245</guid>
      <dc:creator>weapon</dc:creator>
      <dc:date>2013-07-25T09:47:10Z</dc:date>
    </item>
    <item>
      <title>Re: HCS08: IIC MST-Bit cannot be set (MC9S08DZ60, IIC-Master-Mode)</title>
      <link>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222884#M19246</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello Alexander,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;were these divers helpful? Don't forget to keep us posted :smileyhappy:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best,&lt;/P&gt;&lt;P&gt;Monica.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 07 Aug 2013 01:25:27 GMT</pubDate>
      <guid>https://community.nxp.com/t5/8-bit-Microcontrollers/HCS08-IIC-MST-Bit-cannot-be-set-MC9S08DZ60-IIC-Master-Mode/m-p/222884#M19246</guid>
      <dc:creator>Monica</dc:creator>
      <dc:date>2013-08-07T01:25:27Z</dc:date>
    </item>
  </channel>
</rss>

