|
2 | 2 | title: 'A Guide to Arduino & the I2C Protocol (Two Wire)' |
3 | 3 | description: 'Allows the communication between devices or sensors connected via Two Wire Interface Bus.' |
4 | 4 | tags: [I2C, Wire, SDA, SCL] |
5 | | -author: 'Arduino, Nicholas Zambetti' |
| 5 | +author: 'Nicholas Zambetti, Karl Söderby, Jacob Hylén' |
6 | 6 | difficulty: 'intermediate' |
7 | 7 | --- |
8 | 8 |
|
9 | | ->This article was revised on 2021/11/18 by Karl Söderby. |
| 9 | +The I2C protocol involves using two lines to send and receive data: a serial clock pin **(SCL)** that the Arduino Controller board pulses at a regular interval, and a serial data pin **(SDA)** over which data is sent between the two devices. |
10 | 10 |
|
11 | | -The I2C protocol involves using two lines to send and receive data: a serial clock pin **(SCL)** that the Arduino Controller board pulses at a regular interval, and a serial data pin **(SDA)** over which data is sent between the two devices. As the clock line changes from low to high (known as the rising edge of the clock pulse), a single bit of information - that will form in sequence the address of a specific device and a command or data - is transferred from the board to the I2C device over the SDA line. When this information is sent - bit after bit -, the called upon device executes the request and transmits it's data back - if required - to the board over the same line using the clock signal still generated by the Controller on SCL as timing. |
| 11 | +As the clock line changes from low to high (known as the rising edge of the clock pulse), a single bit of information is transferred from the board to the I2C device over the SDA line. As the clock line keeps pulsing, more and more bits are sent until a sequence of a 7 or 8 bit address, and a command or data is formed. When this information is sent - bit after bit -, the called upon device executes the request and transmits it's data back - if required - to the board over the same line using the clock signal still generated by the Controller on SCL as timing. |
| 12 | + |
| 13 | +Each device in the I2C bus is functionally independent from the controller, but will respond with information when prompted by the controller. |
12 | 14 |
|
13 | 15 | Because the I2C protocol allows for each enabled device to have it's own unique address, and as both controller and peripheral devices to take turns communicating over a single line, it is possible for your Arduino board to communicate (in turn) with many devices, or other boards, while using just two pins of your microcontroller. |
14 | 16 |
|
| 17 | +An I2C message on a lower bit-level looks something like this: |
| 18 | + |
| 19 | + |
| 20 | + |
| 21 | +- The controller sends out instructions through the I2C bus on the data pin (SDA), and the instructions are prefaced with the address, so that only the correct device listens. |
| 22 | +- Then there is a bit signifying whether the controller wants to read or write. |
| 23 | +- Every message needs to be acknowledged, to combat unexpected results, once the receiver has acknowledged the previous information it lets the controller know, so it can move on to the next set of bits. |
| 24 | +- 8 bits of data |
| 25 | +- Another acknowledgement bit |
| 26 | +- 8 bits of data |
| 27 | +- Another acknowledgement bit |
| 28 | + |
| 29 | +But how does the controller and peripherals know where the address, messages, and so on starts and ends? That's what the SCL wire is for. It synchronises the clock of the controller with the devices, ensuring that they all move to the next instruction at the same time. |
| 30 | + |
| 31 | +However, you are nearly never going to *actually* need to consider any of this, in the Arduino ecosystem we have the [Wire library](https://www.arduino.cc/reference/en/language/functions/communication/wire/) that handles everything for you. |
| 32 | + |
15 | 33 | ## Hardware & Software Needed |
16 | 34 |
|
17 | 35 | - Arduino IDE ([online](https://create.arduino.cc/) or [offline](https://www.arduino.cc/en/main/software)). |
|
0 commit comments