Skip to content

Latest commit

 

History

History
89 lines (42 loc) · 4.89 KB

GUID-C4C2DFDC-C41B-4AB4-A500-170B6B69DF51.md

File metadata and controls

89 lines (42 loc) · 4.89 KB

I2C Bootloader

This example application shows how to use the Bootloader Library to bootload an application using I2C protocol.

Bootloader Application

  • This is a bootloader application which resides from starting location of the device flash memory

  • It uses I2C peripheral library in non-interrupt mode

  • Trigger Methods

    • It uses the On board Switch as bootloader trigger pin to force enter the bootloader at reset of device

    • It checks for bootloader request pattern (0x5048434D) from the starting 16 Bytes of RAM to force enter bootloader at reset of device

NVM Host Application

  • This is a embedded I2C host application which sends the application image stored in it's internal flash (NVM) to the target board over the I2C bus

  • The user application binary must be converted to a header file containing the application image in HEX format in a C style array. A btl_bin_to_c_array.py utility is provided to do this conversion

    i2c_bootloader_host_nvm

  • Add the generated application image header file to the NVM host application project. Rebuild and program the NVM host application. This results in the application image being copied in the host MCU's flash (NVM)

SDCARD Host Application

  • This is a embedded I2C host application which sends the application image stored in the SD card to the target board over the I2C bus

  • The user application binary is copied into an SD card and inserted in the SD card connected on the host board

    i2c_bootloader_host_sdcard

Test Application

  • This is a test application which resides from end of bootloader size in device flash memory

  • It will be loaded into flash memory by bootloader application

  • It blinks an LED and provides console output

  • It uses the On board Switch to trigger the bootloader from firmware (May not be supported on all devices)

    • Once the switch is pressed it loads first 16 bytes of RAM with bootloader request pattern (0x5048434D) and resets the device

Development Kits
The following table provides links to documentation on how to build and run I2C bootloader on different development kits

Parent topic:MPLAB® Harmony 3 I2C Bootloader Application Examples