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 NameDescription
sam_a5d29_curiosity.XMPLABX 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 NameDescription
sam_a5d29_curiosity.XSAMA5D29 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

SETTING UP THE 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

  1. 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
    
  2. Build the application using its IDE
  3. 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
  4. 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