SAM9X60-EK – Writing MPLAB® Harmony 3 Application and at91bootstrap to NOR Flash (QSPI) Memory using SAM-BA ISP

Introduction

In this training topic, you will write two binary images, harmony.bin (an MPLAB® Harmony 3 Software Framework Application) and boot.bin (Second-stage bootloader, at91bootstrap), to NOR Flash (QSPI) memory on the SAM9X60-EK Evaluation Kit using the SAM-BA® In-System Programmer (ISP). Once the images are written, and upon reset, the SAM9X60-EK will boot and run the application.

For this exercise, you will write the binaries that were created in the training topics:


Prerequisites

This training topic was developed with SAM-BA ISP v3.7.


Hardware

For this training, you will use the SAM9X60-EK Evaluation Kit.

SAM9X60-EK Evaluation Kit

Set up the SAM9X60-EK as listed below to the host computer running SAM-BA Host Application.

Jumpers

SD Memory Cards

  • Ensure no SD memory cards are plugged into the SD card (J4) connector.

Power

Console Serial Communications

SAM-BA Host to Monitor Serial Communications

Be certain that the SAM-BA Host Application has been added to the path.

Be sure to observe RomBOOT on the console. Otherwise, the SAM-BA Host Application cannot talk to the monitor on the target.

For more information on SAM-BA Host Applets, see "SAM-BA In-System Programmer Applets"


NOR Flash (QSPI) Memory

The SAM9X60-EK has a 64 Mbit Serial Quad I/O™ (SQI™) Flash memory (U8) (Microchip Technology SST26VF064B) that can be used for booting the system.

The at91bootstrap (boot.bin) binary will be written to location 0x0 to 0x0003FFFF. The MPLAB Harmony 3 Software Framework application (harmony.bin) binary will be written to location 0x00040000 to 0x000FFFFF.

sam9x60_ek_df_harmony_memory_map.png

Setup SAM-BA Host to Monitor Communications

In this section, you will establish SAM-BA Host Application communications with the target’s (SAM9X60) SAM-BA Monitor. Then you will use the SAM-BA Host Applet (qspiflash) to erase and then write the boot.bin (at91bootstrap) and harmony.bin (MPLAB Harmony 3 Software Framework application) binary images to NOR Flash (QSPI) Memory.

1

To communicate with the SAM-BA Monitor on the target, you must have installed the SAM-BA Host on a host computer and connect a Micro-B USB cable to USBA port (J7) on the SAM9X60-EK.

2

Ensure there is no SD memory card inserted in slot J4.

3

Open jumper the DISABLE_BOOT (J13).

This will allow booting from the onboard memories (NAND and NOR (QSPI) Flash memory).

4

Press both the DIS_BOOT (SW4) and nRST (Reset) (SW3) push buttons.

Pressing the DIS_BOOT (SW4) push button disables booting from the onboard memories.

5

Continue pressing DIS_BOOT (SW4) while releasing the nRST (Reset) (SW3) push button.

6

Release the DIS_BOOT (SW4) push button.

The SAM9X60-EK will boot to the SAM-BA Monitor and start communications with the SAM-BA Host Application.

If you have the Console Serial Communications established, you can observe ROMBoot on the console (terminal emulator) indicating the SAM-BA Monitor is running.


Erase NOR Flash (QSPI) Memory

In this section, you will erase the contents of the NOR Flash memory. This is a necessary step before writing data to NOR Flash memory.

For more information on the SAM-BA Applet qspiflash, see "SAM-BA In-System Programmer - Applets"

Ensure that no other bootable Non-Volatile Memory (NVM) on the SAM9X60-EK contains a bootable image. Ensure there are no SD memory cards plugged into J4 and no bootable image in NAND Flash (U9). For information on the default boot sequence of the SAM9X60, see Section 12 – Boot Strategies in the SAM9X60 Datasheet.

1

Erase the contents of the NOR Flash memory using the following SAM-BA Host Applet command:

$ sam-ba -p serial -b sam9x60-ek -a qspiflash -c erase

cmd_qspiflash_erase_1.png
cmd_qspiflash_erase_2.png
console_qspiflash_erase.png

Write boot.bin to NOR Flash (QSPI) Memory

In this section, you will write the at91bootstrap binary image, boot.bin, to NOR Flash memory.

1

Change directory to the location of boot.bin:

<project_directory>\at91bootstrap\build\binaries\boot.bin

2

Write boot.bin to NOR Flash memory using the following sam-ba applet command:

$ sam-ba -p serial -b sam9x60-ek -a qspiflash -c writeboot:boot.bin

The writeboot command is used when programming a bootstrap file into an external NOR Flash memory boot partition.

cmd_qspiflash_writeboot_boot_bin.png
console_qspiflash_writeboot_boot_bin.png

Write harmony.bin to NOR Flash (QSPI) Memory

In this section, you will write the MPLAB Harmony 3 Software Framework application binary image, harmony.bin, to NOR Flash memory.

1

Change directory to the location of harmony.bin:

C:\Users\<user>\Harmony3\csp_apps_sam_9x60\apps\rtt\rtt_periodic_timeout\firmware\sam_9x60_ek.X\dist\sam_9x60_ek\production\

2

Write harmony.bin to NOR Flash memory using the following sam-ba applet command:

$ sam-ba -p serial -b sam9x60-ek -a qspiflash -c write:harmony.bin:0x200000

The write command is write:<filename>:[<addr>] where <addr> is the Flash Offset for Demo App value in the at91bootstrap configuration (Kconfig). The value 0x200000 you took note of in the training: "SAM9X60-EK – Configure and Build at91bootstrap to Load an MPLAB® Harmony 3 Application from NOR Flash (QSPI) Memory"

ide_at91_kconfig_nor_qspi.png
cmd_qspiflash_write_harmony_bin.png
console_qspiflash_write_harmony_bin.png

Run MPLAB Harmony 3 Application on the Target

To run the application, press the nRST (Reset) (SW3) push button. Observe the RGB LED (LD1) flashes blue. You can also observe the at91bootstrap reading from the NOR Flash memory on the console.

console_harmony_bin_run_qspi_rtt_periodic_timeout.png

Summary

In this training topic, you wrote the binary files harmony.bin and boot.bin to NOR Flash (QPSI) memory on the SAM9X60-EK and ran the application on the target.


What’s Next?

For training topics on configuring at91boostrap for other NVM, see:

Second-Stage Bootloader at91bootstrap

Writing to NVM

© 2024 Microchip Technology, Inc.
Notice: ARM and Cortex are the registered trademarks of ARM Limited in the EU and other countries.
Information contained on this site regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.