Basic History and Invention:
The I2C bus was developed in the early 1980’s by Philips Semiconductors. Its original purpose was to provide an easy way to connect a CPU to peripheral chips in a TV-set.
The research done by Philips Labs in Eindhoven (The Netherlands) to overcome these problems resulted in a 2-wire communication bus called the I2C bus. I2C is an acronym for Inter-IC bus. Its name literally explains its purpose: to provide a communication link between Integrated Circuits.
I2C is trademark for standard and TWI is another name of that protocol.
Information:
The I2C bus physically consists of 2 active wires and a ground connection. The active wires, called SDA and SCL, are both bi-directional. SDA is the Serial DAta line, and SCL is the Serial Clock line.
The I2C bus is a multi-master bus. This means that more than one IC capable of initiating a data transfer can be connected to it. The I2C protocol specification states that the IC that initiates a data transfer on the bus is considered the Bus Master. Consequently, at that time, all the other ICs are regarded to be Bus Slaves. It is depending on clock pulse so that it called as Synchronous communication.
I2C/TWI is a half-duplex serial transmission and hence the data flow can be in a direction at a time. The data transfer rate depends on crystal frequency of slave controller. The rate of data transfer refers to clock frequency on SCL bus which must be 1/16th of slave frequency.
Capable Length of protocol is depends on the load of the bus and the speed you run at. In typical applications, the length is a few meters (9-12ft). Another thing to be taken into account is the amount of noise picked up by long cabling. The length can be increased significantly by running at a lower clock frequency. One particular application – clocked at about 500Hz – had a bus length of about 100m (300ft). If you are careful in routing your PCB’s and use proper cabling (twisted pair and/or shielded cable), you can also gain some length.
Features:
8 bit data bite oriented transfer.
It is capable to handle maximum 128 devices(depend on clock frequency)
Speed is 100Kbps in standard mode and 400Kbps in Fast mode, also 5Mbps in high speed mode.
Only two bus are required for communication for each device
Specific address for each Slave
Each device can be as Master/Slave
Also worked as Multi Master/ Multi slave serial communication
Hardware:
Fig. 1: Overview of Inter Integrated Circuit (I2C) Master Slave connections
As mentioned above I2C has two mail lines SDA for data and SCL for Clock pulse also need pullup resister to both buss for Bus Idle condition.
There needs to be a third wire which is just the ground or 0 volts. There may also be a 5volt wire is power is being distributed to the devices. Both SCL and SDA lines are “open drain” drivers. What this means is that the chip can drive its output low, but it cannot drive it high. For the line to be able to go high you must provide pull-up resistors to the 5v supply. There should be a resistor from the SCL line to the 5v line and another from the SDA line to the 5v line. You only need one set of pull-up resistors for the whole I2C bus, ot for each device
Protocol sequence:
Send the START bit (S).
Send the slave address (ADDR) include point 3.
Send the Read(R)-1 / Write(W)-0 bit.
Wait for/Send an acknowledge bit (A).
Send/Receive the data byte (8 bits) (DATA).
Expect/Send acknowledge bit (A).
Send the STOP bit (P).
The Real Communication:
As we saw already, the active lines used for communication in I²C protocol are bi-directional. Each & every device (for example: MCU, LCD driver, ASIC, remote I/O ports, RAM, EEPROM, data converters) connected to the bus will be having a unique address. Each of these devices can act as a receiver and/or transmitter, depending on the functionality. And also each device connected to the bus is software addressable by this unique address.
As we already know the nodes or any other peripheral devices (no matter whether its master or slave) use micro controllers to connect and communicate through the bus, this communication can be considered as inter-IC communication in general.
Let us assume that the master MCU (as always, it’s the master who initiates the communication) wants to send data to one of its slaves. The step-by-step procedure will be as follows.
Wait until it sees no activity on the I2C bus. The SDA and SCL lines are both high. The bus is ‘free’.
The Master MCU issues a start condition, telling that “its mine – I have started to use the bus”. Thiscondition informs all the slave devices to listen on the serial data line for instructions/data.
Provide on the SCL line a clock signal. It will be used by all the ICs as the reference time at whicheach bit of data on the SDA line will be correct (valid) and can be used. The data on the data line must be valid at the time the clock line switches from ‘low’ to ‘high’ voltage.The Master MCU sends the unique binary address of the target device it wants to access.
Master MCU puts a one-bit message (called read/write flag) on the bus telling whether it wants toSEND or RECEIVE data from the other chip. This read/write flag is an indication to the slave nodewhether the access is a read or a write operation.
The slave node ICs will then compare the received address with its own address. The Slave devicewith the matching address responds back with an acknowledgement signal. If the address doesn’tmatch, they simply wait until the bus is released by the stop condition.
Once the master MCU receives the acknowledgment signal, it starts transmitting or receiving andthe data communication proceeds between the Master and the Slave on the data bus. Both themaster and slave can receive or transmit data depending on whether the communication is a read orwrite. The transmitter sends 8-bits of data to the receiver, which replies with a 1-bit acknowledgment. And the action of data transfer continues.
When the communication is complete, the master issues a stop condition indicating that everythingis done. This action free ups the bus. The stop signal is just one bit of information transferred by aspecial ‘wiggling’ of the SDA/SCL wires of the bus.
Protocol Detail:
Every byte put on the SDA line must be eight bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte must be followed by an Acknowledge bit. Data is transferred with the Most Significant Bit (MSB) first to LSB last.
For each clock pulse one bit of data is transferred. The SDA signal can only change when the SCL signal is low – when the clock is high the data should be stable.
Fig. 2: Timing Diagram of SDA and SCL Signals for implementing I2C serial communication
Fig. 3: Timing Diagram showing Low SCL signal for change in SDA signal
The data on the SDA line must be stable during the HIGH period of the clock. The HIGH or LOW state of the data line can only change when the clock signal on the SCL line is LOW.
Start and Stop Condition:
Fig. 4: Timing Diagram showing Start and Stop Conditions on I2C Bus
Start and stop condition always generated by master.
Bus is busy after start condition and free after stop condition.
To send another data or receive data, need to generate Repeated Start instead of stop.
Sending Address and Read/Write Bit:
After sending start condition need to send 7 bit device address and one bit of operation bit like below.
Fig. 5: Timing Diagram showing Address and Read-Write Bit sent on I2C Bus
Each device you use on the I2C bus must have a unique address. For some devices e.g. serial memory you can set the lower address bits using input pins on the device others have a fixed internal address setting e.g. a real time clock DS1307. You can put several memory devices on the same IC bus by using a different address for each.
10 bit of addressing is another method of addressing slave but not used widely
Sending Data:
Data is sending after receiving Ack Byte from slave and data must be 8 bit.
ACK:
Data transfer with acknowledge is obligatory. The acknowledge-related clock pulse is generated by the master. The transmitter releases the SDA line (HIGH) during the acknowledge clock pulse.
The receiver must pull down the SDA line during the acknowledge clock pulse so that it remains stable LOW during the HIGH period of this clock pulse. Of course, set-up and hold times must also be taken into account.
Usually, a receiver which has been addressed is obliged to generate an acknowledgement after each byte has been received. The master can then generate either a STOP condition to abort the transfer, or a repeated START condition to start a new transfer.
No ACK:
If, after transmission of the 8th bit from the master to the slave the slave does not pull the SDA line low, then this is considered a No ACK condition.
This condition may be created due to the following reasons.
The slave is not there (in case of an address).
The slave missed a pulse and got out of sync with the SCL line of the master.
The bus is “stuck”. One of the lines could be held low permanently.
In any case the master should abort by attempting to send a stop condition on the bus.
Project Source Code
###
1. #define SDA P0_0
2. #define SCL P0_1
3.
4. void I2CInit()
5. {
6. SDA =1;
7. SCL =1;
8. }
9.
10. void I2CStart()
11. {
12. SDA =0;
13. SCL =0;
14. }
15.
16. void I2CRestart()
17. {
18. SDA =1;
19. SCL =1;
20. SDA =0;
21. SCL =0;
22. }
23.
24. void I2CStop()
25. {
26. SCL =0;
27. SDA =0;
28. SCL =1;
29. SDA =1;
30. }
31.
32. void I2CAck()
33. {
34. SDA =0;
35. SCL =1;
36. SCL =0;
37. SDA =1;
38. }
39.
40. void I2CNak()
41. {
42. SDA =1;
43. SCL =1;
44. SCL =0;
45. SDA =1;
46. }
47.
48. unsignedchar I2CSend(unsignedcharData)
49. {
50. unsignedchar i, ack_bit;
51. for(i =0; i <8; i++){
52. if((Data&0x80)==0)
53. SDA =0;
54. else
55. SDA =1;
56. SCL =1;
57. SCL =0;
58. Data<<=1;
59. }
60. SDA =1;
61. SCL =1;
62. ack_bit = SDA;
63. SCL =0;
64. return ack_bit;
65. }
66.
67. unsignedchar I2CRead()
68. {
69. unsignedchar i,Data=0;
70. for(i =0; i <8; i++){
71. SCL =1;
72. if(SDA)
73. Data|=1;
74. if(i<7)
75. Data<<=1;
76. SCL =0;
77. }
78. returnData;
79. }
Using C code is very simple. Here is a small example similar to assembly
1. /*****************************************
2. * Write to slave device with
3. * slave address e.g. say 0x20
4. *****************************************/
5. /* Init i2c ports first */
6. I2CInit();
7. /* Send start condition */
8. I2CStart();
9. /* Send slave address */
10. ack = I2CSend(0x20);
11. /*
12. * ack == 1 => NAK
13. * ack == 0 => ACK
14. */
15. ack = I2CSend(0x07);
16. /* Send another data */
17. ack = I2CSend(0x10);
18. /* Send stop condition */
19. I2CStop();
20.
21. /*****************************************
22. * Read from slave device with
23. * slave address e.g. say 0x20
24. *****************************************/
25. /* Init i2c ports first - Should be done once in main */
26. I2CInit();
27. /* Send start condition */
28. I2CStart();
29. /*
30. * Send slave address with Read bit set
31. * So address is 0x20 | 1 = 0x21
32. */
33. I2CSend(0x21);
34. data = I2CRead();
35. /* Send ack */
36. I2CAck();
37. /* Read last byte */
38. data = I2CRead();
39. /*
40. * Send nak for last byte to indicate
41. * End of transmission
42. */
43. I2CNak();
44. /* Send stop condition */
45. I2CStop();###
Filed Under: Electronic Projects
Questions related to this article?
👉Ask and discuss on EDAboard.com and Electro-Tech-Online.com forums.
Tell Us What You Think!!
You must be logged in to post a comment.