SAMA7G54-EK - Getting Started with MPLAB® Harmony v3 Development: CSP Application: pio_led_on_off_interrupt
Introduction
In this training topic, you will download, configure, and build an MPLAB® Harmony v3 application example using MPLAB X Integrated Development Environment (IDE) to run on the SAMA7G54-EK Evaluation Kit in debug mode. This scenario is typical of project development steps of coding, building, and debugging.
While in debug mode, the second-stage bootloader, at91bootstrap, is used by MPLAB X IDE to initialize DRAM so that it can continue loading the MPLAB Harmony 3 project binary (harmony.bin). Once the project has been loaded onto the SAMA7G54-EK, MPLAB X IDE can be used to run and debug the application.
Once a project has been fully developed, the application is cleaned and built for production. The application binary (harmony.bin) is loaded by at91bootstrap from Non-Volatile Memory (NVM), such as SD Memory Card, e.MMC, NAND and NOR Flash memories. Training topics on how to write binary files to NVM are given in the "What’s Next?" section below.
MPLAB Harmony v3 Application
This CSP Application example demonstrates the control of peripherals using Peripheral Libraries (PLIBs) with minimal external dependencies.
This application uses the PIO Peripheral library to generate callback on switch press and release and drives the GPIO pin connected to the RGB LED to indicate the switch status. The RGB LED is turned ON when the switch is pressed and turned OFF when the switch is released.
Prerequisites
- Install MPLAB® X IDE
- Install MPLAB® XC32 Compiler
Hardware
For this training, you will use the SAMA7G54-EK Evaluation Kit.
SAMA7G54-EK Evaluation Kit
See the “SAMA7G54-EK Evaluation Kit – Features” page.
Setup the SAMA7G54-EK as listed below to the host computer running MPLAB X IDE.
Jumpers
- Set the jumpers to their default positions as shown in the “Jumper Summary” section of the “SAMA7G54-EK - Features” page.
SD Memory Cards
- Ensure no SD memory cards are plugged into the SD card (J4) connector.
Power
- Apply power as shown in the “Power Options” section of the “SAMA7G54-EK - Features” page.
Debug Communications
- The SAMA7G54-EK contains a J-Link On-Board Debug Probe. Connect a micro-B USB cable to J24 and the host computer running MPLAB X IDE.
Console Serial Communications
- To view the target console, connect the host computer running a terminal emulation program in accordance with “SAMA7G54-EK – Console Serial Communications.”
Configure and Build a Project for Debugging
In this section, you will download, configure, and build a CSP Application example using MPLAB X IDE to run on the SAMA7G54-EK in debug mode. This scenario is typical of the initial project development steps of coding, building, and debugging.
Normally, the MPLAB Harmony v3 Software Framework libraries are downloaded when a new MCC project is created in MPLAB X IDE. However, when working with an example application, such as this one, the MPLAB Harmony v3 Software Framework libraries are assumed preinstalled on the host computer. Therefore, if you do not have the MPLAB Harmony v3 Software Framework libraries preloaded, you will have to download or clone the CSP Application Library from the Microchip MPLAB Harmony v3 GitHub repository before opening the example application project. We will show you how in the following steps.
Download CSP Application Library.
Create a Harmony3 directory.
Create a directory named Harmony3. For a Windows® operating system, it is typically located at C:\Users\<user>\Harmony3\.
Download or clone csp_apps_sam_a7g5.
Download or clone csp_apps_sam_a7g5 library from the Microchip MPLAB Harmony 3 GitHub repository to the Harmony3 directory.
Open project pio_led_on_off_interrupt_sam_a7g5_ek.
From MPLAB X IDE, select File > Open project.
An Open Project window will open.
Locate the following project in the Harmony3 directory:
C:\Users\<user>\Harmony3\csp_apps_sam_a7g5\apps\pio\pio_led_on_off_interrupt\firmware\sam_a7g5_ek.X.
Click on the Open Project button. The pio_led_on_off_interrupt_sam_a7g5_ek project loads into MPLAB X IDE.
Configure Project Properties for Debugging in MPLAB X IDE.
Open Project Properties.
Open the pio_led_on_off_interrupt_sam_a7g5_ek Project Properties using one of the following methods:
- In the Projects pane, highlight pio_led_on_off_interrupt_sam_a7g5_ek and click on the wrench icon in the pio_led_on_off_interrupt_sam_a7g5_ek - Dashboard.
- In the Projects pane, right-click on pio_led_on_off_interrupt_sam_a7g5_ek and select Properties from the menu.
The Projects Properties – pio_led_on_off_interrupt_sam_a7g5_ek dialog box opens.
Select the version of DFP and XC32 Compiler you require for the application.
In the Connected Hardware Tool drop-down menu, select the J-Link On-Board (OB) debug probe.
In the Categories pane, select Bootstrap.
Observe that Use bootstrap is selected and the pre-compiled version of the at91bootstrap.elf is selected.
Configure the Harmony Content Path.
In this step, you will let MPLAB X IDE know the location (directory) of the Harmony v3 Software Framework on your host computer.
Click on the Apply and OK buttons.
Set Debug Reset and Startup Options
In MPLAB X IDE, click on Tools > Options.
An Options window opens.
Configure the settings for:
- Debug Reset @ – Main
- Debug startup – Halt at Main
Power the SAMA7G54-EK
Power the SAMA7G54-EK by using one of the following two methods:
- Connect a USB Micro-B cable to USB-A Port (J7) and host computer, or
- +5 VDC external power applied to connector J1.
Press the nSTART push button (SW3).
Pressing the nSTART push button (SW3) will turn on (wakeup) the MPU.
On the SAMA7G54-EK, MPU startup is managed by Power Management Integrated Circuit U1 (MCP16502). The MCP16502 features a low no-load operational quiescent current and draws less than 10 μA in full shutdown.
Build the Project.
Click on the Debug Project icon on the toolbar.
The project will build with debugging parameters, load the application binary to the SAMA7G54-EK, and Halt at Main. Once the build is complete and the application binary is loaded into the target, the toolbar expands to show additional debugging icons.
You can view the second-stage bootloader (at91bootstrap) activity on the console.
Click on the Continue button. The application binary runs within the target.
Press the USER BUTTON (SW1) and observe the RGB LED (D7) lights blue. Release the USER BUTTON and the RGB LED will turn off.
Continuing Development with MPLAB Harmony v3 Software Framework
With the project in Debug mode, you can now pause, insert additional breakpoints, and continue running the project. If you change the source code, you will need to reset the SAMA7G54-EK prior to (re)building and loading the project to the target. Resetting places the MPU back into the bootloader mode.
For this example application, you only downloaded or cloned one MPLAB Harmony v3 library: CSP Applications for the SAMA7G54. There are several libraries required to perform full development. In this section, you will use MPLAB Code Configurator to download and manage these libraries.
Open MPLAB Code Configurator (MCC)
Open MCC by clicking on the MCC shield on the toolbar.
The MCC Content Manager Wizard will open. In the top half window is the Required Content.
Click on the Finish button at the top. The required content will download. Be patient, this will take a while.
A Package Versions Used vs Available dialog may appear if the MPLAB Harmony package versions that the project was developed with do not match the versions available locally. In the next steps, you will update the project to the latest package versions.
Click on the Continue button.
MCC is now available. The Project Graph, Project Resources, and Device Resources windows are active.
If you received a Package Versions Used vs Available dialog, perform the following steps:
In the Device Resources pane, click on the Content Manager button.
Observe the packages and versions that were called out in the dialog in Step 3.1 above. You can either:
- Individually select the latest version available for each package and click on the Apply button. In this example, the csp and dev_packs, or
- Click on the Select Latest Version(s) button and click on the Apply button. This will update all selected libraries to the latest version.
Click on the Generate button.
MCC will generate new source code.
Download Packages for MPU Development
There are additional libraries required for MPU development. They are the Board Support Package (bsp) and Core (core).
- The Board Support Package (bsp) contains the defines (names and attributes) of the features (clock configuration, pins, switches, and LEDs) of a selected evaluation kit.
- The Core Package (core) contains the device driver, system service, OSAL, and third-party software libraries.
Click on the Apply button.
The package versions will be downloaded and installed. MCC will restart.
The bsp and core libraries give you more resources for MPU development. However, there are a number of additional libraries available. Select and download them as needed using the same steps outlined above.
Click on the Generate button.
MCC will generate new source code.
Configure and Build a Project for Production
Once a project has been fully developed, the application is cleaned and built for production. The application binary (harmony.bin) is loaded from NVM, such as SD memory card, eMMC, NAND, and NOR Flash memories, by the second-stage bootloader: at91bootstrap.
Clean and Build the Project
Observe the location of the production binary. Take note of this location as it contains the harmony.bin binary that you will write into NVM.
C:/Users/<user>/Harmony3/csp_apps_sam_a7g5/apps/pio/pio_on_off_interrupt/firmware/sam_a7g5_ek.X/dist/sam_a7g5_ek/production/harmony.bin
Observe the DDRAM Address that harmony.bin is to be loaded by at91bootstrap. This is found in the Linker Files, ddram.ld. Take note of this value as it is required for configuring at91bootstrap to load harmony.bin from NVM.
Summary
In this training topic, you downloaded, configured, and built an MPLAB Harmony v3 application example using MPLAB X IDE to run on the SAMA7G54-EK Evaluation Kit in debug mode. You also cleaned and built the application for production and now it’s ready for writing into Non-Volatile Memory (NVM).
What’s Next?
Once an MPLAB Harmony v3 application (harmony.bin) has been developed and built for production, the next step is to configure and build the second-stage bootloader, at91bootstrap, for reading the harmony.bin binary from Non-Volatile Memory (NVM) and writing to SDRAM. The following training topics show how this is done for NOR Flash (QSPI), e.MMC, and SD Memory Card.
Learn More
- Configure and Build at91bootstrap for an MPLAB® Harmony v3 Project with MPLAB X IDE
- Configure and Build at91bootstrap to Load an MPLAB® Harmony v3 Application from NOR Flash (QSPI) Memory
- Writing MPLAB® Harmony v3 Application and at91bootstrap to NOR Flash (QSPI) Memory using SAM-BA ISP
- Configure and Build at91bootstrap to Load an MPLAB® Harmony v3 Application from e.MMC Flash Memory
- Writing MPLAB® Harmony v3 Application and at91bootstrap to e.MMC Flash Memory using SAM-BA ISP
- Configure and Build at91bootstrap to Load an MPLAB® Harmony v3 Application from an SD Memory Card
- Copy MPLAB® Harmony v3 Application and at91bootstrap to SD Memory Card