1.41 TWIHS HOST write read
This example application shows how to use the TWIHS peripheral in master mode to write and read data.
Description
This example uses the TWIHS peripheral library to write data and read back from TWIHS slave.
Downloading and Building the Application
To clone or download this application from Github, go to the main page of this repository and then click Clone button to clone this repository or download as zip file. This content can also be downloaded using content manager by following these instructions.
Path of the application within the repository is apps/twihs/master/twihs_master_write_read/firmware.
To build the application, refer to the following table and open the project using its IDE.
Project Name | Description |
---|---|
sam_a5d29_curiosity.X | MPLABX project for SAMA5D29 Curiosity Development Board Kit |
Setting Up AT91Bootstrap Loader
To load the application binary onto the target device, we need to use at91bootstrap loader. Refer to the at91bootstrap loader documentation for details on how to configure, build and run bootstrap loader project and use it to bootstrap the application binaries.
Setting Up the Hardware
The following table shows the target hardware for the application projects.
Project Name | Description |
---|---|
sam_a5d29_curiosity.X | SAMA5D29 Curiosity Development Board Kit |
Hardware setup requires two boards, one acting as the TWIHS Master and the other as the TWIHS Slave.
Setting Up SAMA5D29 Curiosity Development Board
- Connect the Debug USB port on the board to the computer using a Type-C USB cable
- Connect TWIHS SDA line on Pin 11 (PD4) of J19 connector and TWIHS SCL line on Pin 12 (PD5) of J19 connector with the corresponding SDA and SCL lines of the TWIHS slave.
- Connect a ground wire between TWIHS Master and TWIHS Slave boards
Running the Application
- Open the twihs_eeprom application
from apps/twihs/master/twihs_master_write_read/firmware and open the
main.c file. Make sure the following macro is defined to
false.
#define I2C_SLAVE_IS_ONBOARD_EEPROM false
- Build the application using its IDE
- Build and program TWIHS Slave board from path within the repository apps/twihs/slave/i2c_eeprom_emulation/firmware and then run the application on TWIHS Master board
- The LED indicates the success or
failure:
- The LED is turned ON when the value read from the TWIHS Slave matches with the written value
- The LED is turned OFF when the value read from the TWIHS Slave did not match with the written value