1 Star 1 Fork 0

Microchip_MPLAB_Harmony / csp_apps_sam_a5d2

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
GUID-A16AEF25-5EDE-4E24-8D07-2A22A8A078FB.md 5.64 KB
一键复制 编辑 原始数据 按行查看 历史

TWIHS EEPROM Emulation

This example application demonstrates how to use the TWIHS peripheral in Slave mode.

Parent topic:Harmony 3 Peripheral Library Application Examples for SAMA5D2 Family

Description

This example uses the TWIHS peripheral library in Slave mode and emulates an EEPROM
of 512 bytes. There are two pages each of size 256 bytes. TWIHS Slave expects two
bytes of memory address from the TWIHS Master and the memory address can range from
0x00 to 0x1FF. TWIHS Slave application supports following:

Byte Write: The TWIHS Master sends the Slave address, followed by two bytes of
memory address. The Slave provides the data present at the requested memory
address.

Page Write: A page write is initiated the same way as a byte write, but the
TWIHS Master can write up-to 256 bytes (1 page). If more than 256 bytes are sent by
the TWIHS Master to the TWIHS Slave, the memory address will “roll over� and
previous data will be overwritten. The address “roll over� during write is from the
last byte of the current page to the first byte of the same page.

Current Address Read: The internal memory address counter maintains the last
address accessed during the last read or write operation, incremented by one. Once
the device address with the read/write bit set to one is clocked in and acknowledged
by the EEPROM, the data byte at the current address is serially clocked out. After
reading the data from the current address, the TWIHS Master sends NAK and generates
a STOP condition.

Random Read: The TWIHS Master writes the 2 byte memory address and then reads
the data from that memory address. After reading the data, the TWIHS Master sends
NAK and generates a STOP condition.

Sequential Read: Sequential reads are initiated by either a current address
read or a random address read. As long as the EEPROM receives an acknowledge, it
will continue to increment the memory address and serially clock out sequential data
bytes. When the memory address limit is reached (0x1FF), the memory address will
“roll over� to 0x00 and the sequential read will continue. The sequential read
operation is terminated when the TWIHS Master sends a NAK and generates a STOP
condition.

To run the application, two evaluation kits will be required - one acting as the
TWIHS Master and the other as the TWIHS Slave. The TWIHS Master application to be
used for this demo application is available under
apps/twihs/master/twihs_eeprom/firmware folder. TWIHS Master writes an
array of values to the TWIHS Slave and verifies the value written by reading the
values back and comparing it to the value written.

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/slave/i2c_eeprom_emulation/firmware.

To build the application, refer to the following table and open the project using its
IDE.

Project Name Description
sam_a5d2_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_a5d2_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

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 J18 connector and TWIHS SCL line on Pin 12 (PD5) with the corresponding SDA and SCL lines of the TWIHS master. Refer the TWIHS master documentation for connection details.
  • 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_eeprom/firmware and open the main.c file. Make sure the following macro is defined to false.

    #define I2C_SLAVE_IS_ONBOARD_EEPROM           false
    

    Build twihs_eeprom application (which is used as TWIHS
    Master) using its IDE

  2. Build TWIHS Slave application (used as TWIHS Slave) using its IDE

  3. Run application on TWIHS Slave board and then run the application on TWIHS Master board

  4. LED on the TWIHS Master board indicates 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
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/Microchip-MPLAB-Harmony/csp_apps_sam_a5d2.git
git@gitee.com:Microchip-MPLAB-Harmony/csp_apps_sam_a5d2.git
Microchip-MPLAB-Harmony
csp_apps_sam_a5d2
csp_apps_sam_a5d2
master

搜索帮助

344bd9b3 5694891 D2dac590 5694891