# SIEMENS

| Microcontrollers<br>ApNote                                                                                                                                                                                                                               | AP1624<br>additional file<br>AP162401. EXE available |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| Software emulation of the I <sup>2</sup> C-bus using Purpose Timer unit 1 of the C166 famil                                                                                                                                                              | 6                                                    |
| This is a software emulation of the I <sup>2</sup> C-bus by using two ge<br>microcontroller from the C166 family. The I <sup>2</sup> C-bus is used is<br>to communicate between devices connected to the bus.<br>Author: Tan Choon Hock / SCPL HL RM LAB |                                                      |

| 1 Introduction to I <sup>2</sup> C-bus |                                   |   |
|----------------------------------------|-----------------------------------|---|
| <b>2</b> I <sup>2</sup>                | <sup>2</sup> C-bus Specifications |   |
| 2.1                                    | Data Transfer Formats             |   |
| 2.2                                    | Timing Diagram                    | 6 |
| 2.3                                    | Hardware Connection               |   |
| 3 S                                    | Software Description              | 9 |
| 3.1                                    | Software Concept                  |   |
| 3.2                                    | Description of Module Subroutines |   |
| 3.3                                    | Software Compilation              |   |

| AP1624 ApNote - Revision History |                |                                            |  |  |
|----------------------------------|----------------|--------------------------------------------|--|--|
| Actual Revis                     | sion : Rel. 01 | Previous Revision: none (Original Version) |  |  |
| Page of                          | Page of        |                                            |  |  |
| actual Rel.                      | prev. Rel.     |                                            |  |  |
|                                  |                |                                            |  |  |

# 1 Introduction to l<sup>2</sup>C-bus

The I<sup>2</sup>C-bus or Inter-Integrated Circuit bus has been developed by Philips. It allows integrated circuits to communicate directly with each other via a simple bi-directional 2-wire bus. The two bus lines are serial clock line (SCL), and serial data line (SDA). Nowadays, the I<sup>2</sup>C-bus becomes a standard bus system which is used in consumer electronics, telecommunications, and industrial electronics. This software module for I<sup>2</sup>C-bus emulation supports the single master protocol only. It is using a timer interrupt to generate clock and transmit or receive the data. The clock frequency of the I<sup>2</sup>C-bus can achieve up to 100 KHz with 20 MHz CPU of the C16x microcontroller.

# 2 I<sup>2</sup>C-bus Specification

# 2.1 Data Transfer formats

A HIGH-to-LOW transition of the data line (SDA) while the clock line (SCL) is HIGH indicates a START condition. A LOW-to-HIGH transition of the SDA while SCL is HIGH defines a STOP condition. The data line can only be changed when the clock signal on the SCL line is LOW. Therefore, the data on the SDA line must be stable during the HIGH period of the clock signal. The bus is considered to be busy after the START condition and is considered to be free at a certain time interval after the STOP condition.

Each information put on the SDA line must be 8-bit long. The data is transferred serially with the most significant bit first, and followed by an acknowledge bit. The 9th clock pulse of the acknowledge bit is generated by the master. The transmitting device has to release the SDA line (HIGH or in the high impedance state) during this clock pulse while the device that needs to acknowledge has to pull down the SDA line during this clock pulse. The number of data bytes transferred between the START and STOP condition from the transmitter and receiver is not limited.

The receiver is obliged to generate an acknowledge bit after each byte of data that has been received. When the receiver does not provide an acknowledge bit after having received a byte of data, the data line must be left HIGH or in the high impedance state by the slave. The master can then generate a STOP condition to abort the transfer. One of the reasons for the receiver not to provide the acknowledge bit is that the receiver is performing some real- time function. If the master is receiving data, it must signal the end of the data to the slave by not generating an acknowledge bit on the last byte of data received. Then, the slave must release the data line to allow the master to generate the STOP

A complete data transfer format is shown in Figure #1. After a START condition, a slave address is sent. The address is 7 bits long followed by an 8th bit which is a data direction bit (R/W). A "0" for data direction bit indicates a transmission (WRITE), and a "1" indicates a request for data (READ). Figure #2 shows the I<sup>2</sup>C-bus data transfer format of writing data from master to slave device. Figure #3 shows the data transfer format of reading data from the slave device.

A data transfer is always terminated by a STOP condition generated by the master. However, if the master still wishes to communicate on the bus, it can generate a repeated START condition and address the same device or another slave device without first generating a STOP condition. This combined data transfer format is shown in figure #4.



Figure 1:

# A complete data transfer format of I<sup>2</sup>C-bus

| S | Slave Address | R/W A         | Data | A                            | Data         | Α | Р |
|---|---------------|---------------|------|------------------------------|--------------|---|---|
|   |               | 0 (WRITE)     |      | Data trans<br>(n bytes + ack |              |   |   |
|   | From mast     | ter to slave. |      | From slave                   | e to master. |   |   |

# Figure 2:

# I<sup>2</sup>C-bus data transfer format of writing data to slave

| Data transfer<br>(n bytes + acknowledge)<br>1 (READ)<br>From master to slave. From slave to master. | S Slave Address R/W A                   | Data                      | A Data                | NA P |  |
|-----------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------|-----------------------|------|--|
|                                                                                                     |                                         |                           |                       |      |  |
| From master to slave. From slave to master.                                                         | 1 (READ)                                |                           |                       |      |  |
|                                                                                                     | From master to slave.                   |                           | From slave to master. |      |  |
| NA not acknowledge for the last data to be received. (SDA = HIGH)                                   | NA not acknowledge for the last data to | o be received. (SDA = HIG | H)                    |      |  |

# Figure 3:

# I<sup>2</sup>C-bus data transfer format of reading data from slave





A combined data transfer format for I<sup>2</sup>C-bus

# 2.2 Timing Diagram

The clock frequency of SCL is in the range of 0 up to 100 KHz. The clock on the  $l^2$ C-bus has a minimum LOW period of 4.7µs, and a minimum HIGH period of 4.0µs.

Occasionally, the slave device may slow down the transmission by holding the clock line low after receiving a byte of data from microcontroller. This event is defined as a WAIT condition. Therefore, the master needs to switch the SCL output to high impedance and read the SCL line before transmitting another byte of data to the slave device.

Figure #5 shows the data transfer timing requirements in detail. The description of the abbreviations used is shown in the Table #1. The minimum timing requirements are needed to be fulfilled in order for  $l^2$ C-bus to operate properly.





I<sup>2</sup>C-bus timing diagram

## Table 1:

# Abbreviation for I<sup>2</sup>C-bus timing diagram

| Parameter                                                                          | Symbol              | Limit | alues | Unit |
|------------------------------------------------------------------------------------|---------------------|-------|-------|------|
|                                                                                    |                     | min.  | max.  |      |
| 1. Bus free time between a STOP and<br>START condition                             | t <sub>BUF</sub>    | 4.7   |       | μs   |
| 2. Hold time for START condition. After this period, the first pulse is generated. | t <sub>hd;sta</sub> | 4.0   |       | μs   |
| 3. The HIGH period of SCL clock.                                                   | t <sub>HIGH</sub>   | 4.0   |       | μs   |
| 4. The LOW period of SCL clock.                                                    | t <sub>LOW</sub>    | 4.7   |       | μs   |
| 5. Data hold time                                                                  | t <sub>hd;dat</sub> | 0*    |       | μs   |
| 6. Rise time for both SCL and SDA signals.                                         | t <sub>R</sub>      |       | 1.0   | μs   |
| 7. Fall time for both SCL and SDA signals.                                         | t <sub>F</sub>      |       | 300   | ns   |
| 8. Data set-up time                                                                | $t_{\text{SU;DAT}}$ | 250   |       | ns   |
| 9. Set-up time for a repeated START condition.                                     | t <sub>su;sta</sub> | 4.7   |       | μs   |
| 10. Set-up time for STOP condition.                                                | t <sub>su;sто</sub> | 4.0   |       | μs   |
| 11. SCL clcok frequency                                                            | 0                   | 100   |       | KHz  |
| 12. Capacitor load for each bus line                                               | Cb                  |       | 400   | pF   |

\* A device must internally provide a hold time of at least 300 ns for SDA signal in order to bridge the undefined region of the falling edge of SCL.

# 2.3 Hardware Connection

Every device connected to the l<sup>2</sup>C-bus must have an open drain/open collector output for both the clock (SCL) and data (SDA) lines. Each of the lines is connected to the VDD supply via a common pull-up resistor of  $10K\Omega$  in value. The connection among master and many slave devices is shown in Figure 6. The number of devices that can be connected to the l<sup>2</sup>C-bus is limited only by the maximum bus load capacitance of 400pF.



#### Figure 6:

## Hardware connection among master and slave devices

# 3 Software Description

## 3.1 Software Concept

The clock and data of the  $l^2$ C-bus are generated by the timer T3 interrupt of the C16x microcontroller. The clock frequency of the  $l^2$ C-bus is 100 KHz with 20 MHz CPU of the microcontroller. A reload mode for the timer is required to generate a clock frequency of 100KHz. The reload mode requires two general purpose timers; one of the timer is used as the core timer (T3) with 400ns resolution, the other timer is the auxiliary timer in reload mode (T2). The reload value for the T2 timer is 24 which will generate an interrupt every 10µs/100KHz((24+1)\*400ns) in count-down mode. A complete cycle of the clock will be generated within the timer interrupt service routine. The priority of the timer interrupt is at the lowest which can be changed depending on the priority in your application.

The I2C\_HW.C software module is divided into 5 software subroutines which can be accessed by the main or external program. Those 5 software subroutines are used to construct the data transfer format of the  $l^2$ C-bus. Those 5 software subroutines are  $l^2$ Clnit, I2CStart, I2CMasterWrite, I2CMasterRead, and I2CStop.

The two types of data transfer format (master write, and master read/combined format) are written in the  $I2CHW_TS.C$ . The  $I2CHW_TS.C$  is a simple test program which just to verify the  $I2C_HW.C$  software module. This test program transmits 10 bytes of data to an  $E^2PROM$  IC from the array location of the microcontroller. The 10 bytes of data will be stored in the word address 0 to 9 of the  $E^2PROM$  IC. Next, the microcontroller will read back the contents of the 10 bytes from the word address 0 to 9 of the  $E^2PROM$  IC and then store it into another array location of the microcontroller.

## 3.2 Description of Module Subroutines

# I<sup>2</sup>C-BUS Software Module

| Source file:          | I2C_HW.C |
|-----------------------|----------|
| Header file:          |          |
| User definition file: | I2C.DEF  |

#### Description

This module is a standard I<sup>2</sup>C-bus single master protocol by using timer T3 interrupt. The clock as well as transmit/receive data are handled by the timer interrupt.

#### Module Subroutines

1. void Delay(unsigned int count); 2. unsigned char Check\_SCL(); 3. unsigned char I2CInit(); 4. void I2CStart(); 5. void I2CMasterWrite(unsigned char input\_byte); 6. void I2CMasterRead(unsigned char ack); 7. unsigned char I2CStop();

#### void Delay(unsigned int count)

To create time delay for clock and data signal.

ParameterDescriptionunsigned int countnumber of count for time delay.

#### unsigned char Check\_SCL()

Send HIGH and read the SCL line. It will wait until the line has been released from slave device with the time-out of 10 ms.

Parameter

Description

None

#### Return

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

#### unsigned char I2CInit()

Set up timer in reload mode which requires two timers; T2 as the reload timer, and T3 as the core timer. Those two timers will act like a reload timer and have an resolution of 100 KHz.(1/(400ns \* 25)). After that, check the clock and data lines for any bus faulty like no pull-up resistor on SDA/SCL or pull-down to low by the slave device.

Parameter

Description

None

#### Return

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

#### void I2CStart()

Generate a START condition on  $I^2C$ - bus.

| Parameter | Description |  |
|-----------|-------------|--|
| None      |             |  |

#### void I2CMasterWrite(unsigned char input\_byte)

Check for any WAIT condition before writing one byte of data to the slave device. Set-up the first bit of data right after the START condition.

Parameter

Description

unsigned char input\_byte one byte of data to be sent to slave.

#### void I2CMasterRead(unsigned char ack)

Check for WAIT condition before reading one byte of data from the slave device.

| Parameter         | Description                                                                                                                                                   |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| unsigned char ack | "0" - generate LOW output by the master after a byte of<br>data is received.<br>"1" - generate HIGH output by the master after a byte of<br>data is received. |

#### unsigned char I2CStop()

Generate a STOP condition on the I<sup>2</sup>C bus. In addition, it will generate clock pulses until the line is released by the slave device and the time-out is 10 ms before returning a "HIGH" value indicating an error.

| Parameter | Description |  |
|-----------|-------------|--|
| Nono      |             |  |

None

#### Return

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

# I<sup>2</sup>C-BUS Application Software

| Source file: | I2CHW_TS.C |
|--------------|------------|
| Header file: | I2C_HW.H   |

#### Description

This program is for testing only. The purpose of this program is to make use of the standard I<sup>2</sup>C protocol module (I2C\_HW.C) to control the nonvolatile memory (E<sup>2</sup>PROM). This program writes 10 bytes of data into the E<sup>2</sup>PROM in sequence and the data is retrieved from the array location of the microcontroller. Then read back 10 bytes of data from the E<sup>2</sup>PROM at the same location to which they have been programmed and store it in the array location of the microcontroller.

#### Software subroutines

- 1. unsigned char CheckWrite()
- 2. unsigned char WriteE2prom(unsigned char address,signed int sub\_addr,unsigned char \*buffer,unsigned char count)
- 3. unsigned char ReadE2prom (unsigned char address, signed int sub\_addr, unsigned char \*buffer, unsigned char count)

#### unsigned char CheckWrite()

Check for the completion of programming after the memory write. If the programming is completed, the acknowledge bit will be "0".

Parameter
Description

None
Image: Comparison of the second seco

#### Return

If the return value is "0", the programming of  $E^2 PROM$  is considered to be done. Otherwise, the programming of  $E^2 PROM$  is still in progress.

unsigned char WriteE2prom(unsigned char adress, signed int sub\_addr,unsigned char \*buffer,unsigned char count)

Write number of data bytes to  $E^2$ PROM. The flow of this subroutine is derived from the data format of writing to the  $E^2$ PROM as in the figure #2.

| Parameter             | Description                              |
|-----------------------|------------------------------------------|
| unsigned char address | specifies the slave device address       |
| signed int sub_addr   | specifies the sub-address/word address   |
| unsigned char *buffer | point to the location of data to be sent |
| unsigned char count   | number of bytes to be sent               |

#### Return

If the return value is "0", the programming of  $E^2 PROM$  is completed. Otherwise, the data is needed to be sent again because there is no acknowledge from the slave device.

unsigned char ReadE2prom(unsigned char address, signed int sub\_addr,unsigned char \*buffer,unsigned char count)

Read number of data bytes from  $E^2$ PROM. The flow of this subroutine is derived from the data format of reading from the  $E^2$ PROM as in the figure #3.

| Parameter             | Description                                |
|-----------------------|--------------------------------------------|
| unsigned char address | specifies the slave device address         |
| signed int sub_addr   | specifies the sub-address                  |
| unsigned char *buffer | point to the location of data to be stored |
| unsigned char count   | number of bytes to be received             |

#### Return

If the return value is "0", the reading of  $E^2 PROM$  is completed. Otherwise, the data is needed to be sent again because there is no acknowledge from the slave device.

# 3.3 Software Compilation

The compilation of this software is using the KEIL C166 compiler. First of all, under the PROJECT menu, click on the "New Project", then key in the name of this project and add files to the project which are the I2C\_HW.C and I2CHW\_TS.C. Then, save the project. After that, go to the OPTIONS menu and click on the "C166 Compiler..." . Lastly, select the option under OBJECT and cross the box under "Enable 80C167 instructions". This option will allow you to use the C16x derivatives. Now the project is ready to compile and link all the object files. The compiling and linking of the project can be done by clicking the icon "BUILD ALL".

The AP162401.EXE is a compressed file and contains I2C\_HW.H, I2C\_DEF, I2C\_HW.C, and I2CHW\_TS.C. All these files are necessary to complete the compilation of the software program.