QuickStart SAME70 Xplained Ultra Evaluation Kit - automaate/GFX_sandbox GitHub Wiki

Microchip Technology QuickStart SAME70 Xplained Ultra Evaluation Kit

This guide describes the basic steps to create a graphics-enabled application using the SAM E70 Xplained Ultra Evaluation Kit connected to a WQVGA display. You will build a simple application that displays an image and touch button. It starts with the creation of a new MPLAB® project and finishes with a graphics application equivalent to aria_quickstart.

The demonstration will render the following image on the display:

Microchip Technology

Who should use this guide

This guide is intended for developers who are building applications on a custom SAME70 board similar to or the same as the SAM E70 Xplained Ultra Evaluation Kit and the WQVGA Display Module (AC320005-4).

What this guide contains

You will build a simple application that displays an image and touch button. It starts with the creation of a new MPLAB® project and finishes with a graphics application equivalent to aria_quickstart. Here are the primary steps to create a graphics application for your SAME70 hardware:

  1. Create a new project and configure clock for SAME70 .
    • Create MPLAB Harmony v3 Project using MPLAB X IDE
    • Verify Clock Settings
  2. Configure Harmony components for graphics middleware and drivers
  3. Configure pins for external graphics communication
  4. Generate Code
  5. Add application code to project
  6. Build, program and observe outputs
Materials you will need

Documentation

Documentation Description
SAM E70 Xplained Ultra User's Guide User Guide with Schematics

Hardware

Hardware Description
SAM E70 Xplained Ultra Evaluation Kit Development Board
WQVGA Display Module (AC320005-4). High-Performance 4.3" WQVGA Display Module
WQVGA Display Module from MEB II Alternative High-Performance 4.3" WQVGA Display Module if an MEB-II board is available
Standard USB A to micro-B cable PC debugging connector.

NOTE: The SAM E70 Xplained Ultra Evaluation Kit includes an on-board Embedded Debugger (EDBG), which requires no additional hardware to get started. For programming/debugging, the EDBG connects to the host PC through the USB micro-B connector on the SAM E70 Xplained Ultra Evaluation Kit.

Hardware Setup

SAM E70 Xplained Ultra Evaluation Kit is connected to the display using the display ribbon cable. Programming is a board to PC link using a standard USB A to micro-B cable. The connection, illustrated below, provides power and debug communication.

If your WQVGA display cable is connected to a interposer board, following these steps:

  • Disconnect the ribbon cable that connects the display to the interposer board. The board is for the MEB 2 only, and not used with the SAM E70 Xplained Ultra Evaluation Kit.

Microchip Technology

  • Release the ribbon cable from the interposer board.
  • Release the black clamp on the J2 connector and turn the display over.
  • Insert the ribbon cable into J2 and close the clamp.

Microchip Technology

Important The board and display are powered by a Micro B – USB A cable from PC to the “USB Debug” port on the SAM E70 Xplained Ultra Evaluation Kit.

Software

Software Description Install
MPLAB® X Integrated Development Environment v5.15 or later Install MPLAB IDE
MPLAB® XC32/32++ C Compiler v2.20 or later Install Compiler
MPLAB® Harmony 3 v3.5 or later Install Harmony v3

NOTE: This project has been verified to work with the following versions of software tools: MPLAB X IDE v5.20, MPLAB XC32 Compiler v2.20, MPLAB Harmony v3.5.0

NOTE: Because we regularly update our tools, occasionally you may discover an issue while using the newer versions. If you suspect that to be the case, we recommend that you use the same versions that the project was tested with.

QuickStart steps

Create a new MPLAB Harmony v3 project

  1. Select File > New Project from the main IDE menu.

  2. In the Categories pane of the New Project dialog, select Microchip Embedded. In the Projects pane, select 32-bit MPLAB Harmony 3 Project, then click Next.

Microchip Technology

NOTE: If 32-Bit MPLAB Harmony 3 Project selection is not displayed, Download MPLAB Harmony Framework.

  1. In the Framework Path edit box, browse to the folder you downloaded the framework to. If you haven't done this, or want to download it to a different folder, click the Launch Framework Downloader button, then click Next.

NOTE: For more information on the framework downloader, see the, Download MPLAB Harmony Framework section of the "MPLAB® Harmony Configurator Overview" page.

Microchip Technology

  1. In the Project Settings window, apply the following settings:

    • Location: Indicates the path to the root folder of the new project. All project files will be placed inside this folder. The project location can be any valid path, for example: C:\microchip\harmony\v3.
    • Folder: Indicates the name of the MPLABX .X folder. Enter “same70” to create a same70.X folder.
    • Name: Enter the project’s logical name as “my_board”. This is the name that will be shown from within the MPLAB X IDE.
    • Click Next to proceed to Configuration Settings.

NOTE: Folder must be a valid directory name for your operating system. The Path box is read-only. It will update as you make changes to the other entries.

Microchip Technology

  1. Follow the steps below to set the project’s Configuration Settings.

    • Name: Enter the configuration name as “same70”.
    • Target Device: Select “ATSAME70Q21B” as the target device.
    • Click Finish to launch the MHC.

NOTE: You can select the Device Family or enter a partial device name to filter the list in Target Device in order to make it easier to locate the desired device.

Microchip Technology

NOTE: The New Project Wizard opens a Configuration Database Setup window to allow you to review the packages that will be used by the current project.

  1. While the MHC tool launches, it will ask for the packages to be loaded. In the Load checkboxes list, select the gfx, core, and bsp packages and unselect all other packages.

Microchip Technology

Click Launch to launch the MHC Configurator tool with the selected packages.

  • Launching MPLAB Harmony Configurator. The following message will be displayed while the project is loaded into MPLAB X.

Microchip Technology

  1. The MHC plugin’s main window for the project will be displayed. This is the initial project graph.

Microchip Technology

  1. Before proceeding, set up the compiler toolchain. Click on the Projects tab on the top left pane. Right click on the project name my_board and go to Properties.

Microchip Technology

Make sure that XC32 (v2.20) is selected as the Compiler Toolchain for XC32. Click on Apply and then click on OK.

Microchip Technology

Verify Clock Settings

  1. Launch Clock Diagram by going to MHC tab in MPLABX IDE and then select Tools > Clock Configuration.

Microchip Technology

A new tab, Clock Diagram, is opened in the project’s main window.

  1. Click on the Clock Diagram tab, scroll to the right and verify that the Processor Clock (HCLK) and Master Clock (MCK) is set to 300 MHz and 150 MHz, respectively.

Microchip Technology

Configure Software

  1. This is a Harmony based application, therefore, you will need to use the Harmony Core Service Component.

Under the bottom left tab, Available Components, expand Harmony. Double click or drag and drop Core to add the Harmony Core Service to the project graph. When prompted to activate FreeRTOS, click No.

Microchip Technology

Microchip Technology

  1. You will also need the Time System Service.

NOTE: Harmony components lists Current Consumers and Available Consumers when a right click occurs on the circle icons.

  • On the Harmony Core Service component, right click the Core Service icon on Harmony Core Service component, select Available Consumers, then select TIME.

Microchip Technology

  • On the Time System Service component, right click the TMR icon, select CORE_TIMER(core_timer).

Microchip Technology

Because this is a GFX enabled application, you will need to select a graphics library. For this tutorial, we will use Aria.

  1. Under the bottom left tab, Available Components, expand Graphics>Middleware. Double click or drag and drop Aria to add the Aria graphics library to the project graph.

  2. On the Aria component, right click the GFX HAL, select Satisfiers, and select GFX Core.

Microchip Technology

  1. On the GFX Core component, right click the Display Driver icon, select Satisfiers, and select LCC.

Microchip Technology

  1. On the LCC component, right click SMC_CS diamond icon, select Satisfiers, and select SMC.

Microchip Technology

  1. On the GFX Core component, right click Graphics Display diamond icon, select Satisfiers, and select PDA TM4301B (gfx_disp_pdatm4301b_480x272).

Microchip Technology

  1. On the PDA TM4301B component, right click Touch Panel diamond icon, select Consumers, and select MaXTouch Controller (gfx_maxtouch_controller).

Microchip Technology

  1. On the MaXTouch Controller component, right click DRV_I2C diamond icon, select Satisfiers, and select I2C (drv_i2c).

Microchip Technology

  1. On the MaXTouch Controller component, right click Input System Service circle icon, select Available Satisfiers, and select Input System Service (sys_input).

Microchip Technology

  1. On the I2C Driver component, right click Input I2C diamond icon, select Satisfiers, and select TWIHS0.

Microchip Technology

On completion, your Project Graph window should look similar to the following image:

Microchip Technology

If the display needs to be configured, then you will need to launch Display Manager. For this tutorial, Display Managing is not required. See Getting started with Display Manager for more information.

Microchip Technology

Configure Hardware

In this step, you will need to connect the SAME70 to the external touch controller and display modules.

If you are using the SAME70 Xplained Pro Evaluation Kit, please reference the Curiosity SAME70 Xplained Pro Evaluation Kit schematic obtained from the SAM E70 Xplained Ultra User's Guide.

NOTE: If you are using a schematic for your custom board, map the required graphics pins to your board.

NOTE: the drv_maxtouch and drv_gfx_lcc drivers require specific names for its pins. If you do not have the correct pin names a compiler output will display an error along with the expected name.

The pin mapping table below is made available for convenience.

Required Pin Settings

Ball/Pin Number Pin ID Name Function Direction Latch
91 PA3 TWIHS0_TWD0 TWIHS0_TWD0
77 PA4 TWIHS0_TWCK0 TWIHS0_TWCK0
79 PB6 ICE_TMS/SWDIO TWIHS0_TWD0
89 PB7 ICE_TCK/SWDCLK TWIHS0_TWCK0
49 PA15 EBI_D14 EBI_D14
45 PA16 EBI_D15 EBI_D15
49 PA15 EBI_D14 EBI_D14
11 PC0 EBI_D0 EBI_D0
38 PC1 EBI_D1 EBI_D1
39 PC2 EBI_D2 EBI_D2
40 PC3 EBI_D3 EBI_D3
41 PC4 EBI_D4 EBI_D4
58 PC5 EBI_D5 EBI_D5
54 PC6 EBI_D6 EBI_D6
48 PC7 EBI_D7 EBI_D7
4 PE0 EBI_D8 EBI_D8
6 PE1 EBI_D9 EBI_D9
7 PE2 EBI_D10 EBI_D10
10 PE3 EBI_D11 EBI_D11
27 PE4 EBI_D12 EBI_D12
28 PE5 EBI_D13 EBI_D13
82 PC8 EBI_NWR0/NWE EBI_NWR0/NWE
86 PC9 GFX_DISP_INTF_PIN_BACKLIGHT GPIO Out High
94 PC30 GFX_DISP_INTF_PIN_DE GPIO Out High
19 PC11 GFX_DISP_INTF_PIN_RESET GPIO Out High
15 PC30 GFX_DISP_INTF_PIN_HSYNC GPIO Out High
67 PD19 GFX_DISP_INTF_PIN_VSYNC GPIO Out High
71 PD28 BSP_MAXTOUCH_CHG GPIO In
  1. Open the Pin Configuration tabs by clicking MHC > Tools > Pin Configuration.

Microchip Technology

  1. Select the MHC Pin Settings tab and sort the entries by Port names as shown below.

Microchip Technology

  1. Use the table above to establish your Pin Settings.

Add application UI code to project

The UI design is already developed. Use Graphics Composer to insert the design into your project.

Launch the Graphics Composer from the MHC/Tools Menu:

Microchip Technology

  • When MHGC’s Welcome Dialog is displayed. Click the Create a new project using the new project wizard button.

Microchip Technology

Important If the Welcome Dialog does not appear, it is because it had been disabled previously. The Welcome Dialog can be re-enabled by using MHGC’s File > Settings > General menu:

Microchip Technology

  • In the MPLAB Harmony Graphics Composer (MHGC) screen use the left-most icon to create a new graphics design.

Microchip Technology

In the New Project Wizard, for the Color Mode step,

  • Select RGB_565
  • Click NEXT.

Microchip Technology

Memory Size

For the Memory Size step, accept the default Flash Memory Size and click NEXT. It is not recommended to change this setting for this tutorial.

Microchip Technology

Project Type

For the Project Type step, chose the second option create a new project using a basic template and click NEXT.

Microchip Technology

The MHGC window will display the following image:

Microchip Technology

Generate Code

  1. When done, before generating code, click Save MHC State as shown below.

Microchip Technology

  1. Save the configuration in its default location when prompted.

  2. Generate the code as shown below.

Microchip Technology

  1. Click on the Generate button in the Generate Project window, keeping the default settings as shown below. If prompted for saving the configuration, click Save.

Microchip Technology

  1. As the code is generated, MHC displays the progress as shown below.

Microchip Technology

  1. Examine the generated code.

MHC will include all the MPLAB Harmony library files and generate the code based on the MHC selections. The generated code would add files and folders to your Harmony project

  1. Navigate to the Projects tab to view the project tree structure.

  2. Build the code by clicking on the Clean and Build icon Microchip Technology and verify that the project builds successfully.

Add application UI code to project

The UI design is already developed. Use Graphics Composer to insert the design into your project.

Launch the Graphics Composer from the MHC/Tools Menu:

Microchip Technology

  • When MHGC’s Welcome Dialog is displayed. Click the Create a new project using the new project wizard button.

Microchip Technology

Important If the Welcome Dialog does not appear, it is because it had been disabled previously. The Welcome Dialog can be re-enabled by using MHGC’s File > Settings > General menu:

Microchip Technology

  • In the MPLAB Harmony Graphics Composer (MHGC) screen use the left-most icon to create a new graphics design.

Microchip Technology

In the New Project Wizard, for the Color Mode step,

  • Select RGB_565
  • Click NEXT.

Microchip Technology

Memory Size

For the Memory Size step, accept the default Flash Memory Size and click NEXT. It is not recommended to change this setting for this tutorial.

Microchip Technology

Project Type

For the Project Type step, chose the second option create a new project using a basic template and click NEXT.

Microchip Technology

The MHGC window will display the following image:

Microchip Technology

You are now ready to build the code!

Build, program and observe outputs

  1. Verify that the display is connected to GFX Connector on the Curiosity PIC32MZ EF 2.0 Development Board.

  2. The Curiosity PIC32MZ EF 2.0 Development Board allows using the Embedded Debugger (EDBG ) for debugging. Connect the Type-A male to micro-B USB cable to micro-B DEBUG USB port to power and debug the Curiosity PIC32MZ EF 2.0 Development Board.

  3. Go to File > Project Properties and make sure that the EDBG is selected as the debugger under the Hardware Tools and XC32 (v2.20) is selected as the Compiler Toolchain for XC32.

  4. Clean and build your application by clicking on the Clean and Build button as shown below.

Microchip Technology

  1. Program your application to the device, by clicking on the Make and Program button as shown below.

Microchip Technology

The application should build and program successfully. A compilation error could occur if a pin name is undefined. For example: Microchip Technology

The demonstration will display the following UI:

Microchip Technology

Observations

You observed that the application displayed the home screen. You were able to change screens and control widgets.

Review

You have successfully created an application using MPLAB Harmony v3 on SAME70. Your application used all the fundamental elements that go in building a graphics application. Your application successfully rendered a UI to the High-Performance 4.3" WQVGA Display Module. The application also took user from the display module.

In this application, you used MPLAB® Harmony Configurator (MHC) to configure SAME70. You used MHC to add and connect components. You used Pin Configurator to set up the pins for display and maxTouch controller.

Summary

This guide provided you training of configuring and using all the fundamental components needed to build a graphics application on a SAME70 Development Board with MPLAB Harmony v3 Framework. As a next step, you may customize this application and reconfigure some of the components used in this tutorial. You could also add new components (PLIBs, etc.) to enhance this application to realize your end application.

Send Feedback

⚠️ **GitHub.com Fallback** ⚠️