Skip to content

Latest commit

 

History

History
126 lines (63 loc) · 4.95 KB

GUID-4A60C8CA-FD44-4D91-8CCB-4BB781EB6CDE.md

File metadata and controls

126 lines (63 loc) · 4.95 KB

PIC32MZ Embedded Connectivity with FPU (EF) Starter Kit: Building and Running the USB Device HID Bootloader applications

Parent topic:USB Device HID Bootloader

Downloading and building the application

To clone or download these application from Github,go to the main page of this repository and then click Clone button to clone this repo or download as zip file. This content can also be download using content manager by following these instructions

Path of the application within the repository is apps/usb_device_hid_bootloader/

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

Bootloader Application

Project Name Description
bootloader/firmware/pic32mz_ef_sk.X MPLABX Project for PIC32MZ Embedded Connectivity with FPU (EF) Starter Kit

Test Application

Project Name Description
test_app/firmware/pic32mz_ef_sk.X MPLABX Project for PIC32MZ Embedded Connectivity with FPU (EF) Starter Kit
  • Connect a mini USB cable to the UART-USB port J11

  • For programming, connect a mini USB cable to the USB Debug port J3

  • Use the micro-A/B port J4 (which is located on the bottom side of the board) to connect the USB Device to the USB Host PC

Running the Application

  1. Open the test application project test_app/firmware/pic32mz_ef_sk.X in the IDE

  2. Build the project to generate the binary (Do not program the binary)

  3. Open the bootloader project bootloader/firmware/pic32mz_ef_sk.X in the IDE

  4. Build and program the application using the IDE

  5. Once programming is completed and bootloader starts running

    • LED1 will be Turned On

    • HID Custom device with product ID 3C will be enumerated on Host PC

  6. Open the Terminal application (Ex.:Tera Term) on the computer to get test application messages through UART once bootloaded

  7. Configure the serial port settings as follows:

    • Baud : 115200

    • Data : 8 Bits

    • Parity : None

    • Stop : 1 Bit

    • Flow Control : None

  8. Launch the Unified Host application from below path

    • <harmony3_path>/bootloader/tools/UnifiedHost-*/UnifiedHost-*.jar
  9. Configure the Unified host application

    • Select the Device architecture and Protocol as shown below

      hostConfig

    • Click on configure button and select the USB Device as 3C

      hostUSBSetting

    • Load the test application hex file to be programmed using below option

      • <harmony3_path>/bootloader_apps_usb/apps/usb_device_hid_bootloader/test_app/firmware/pic32mz_ef_sk.X/dist/pic32mz_ef_sk/production/pic32mz_ef_sk.X.production.hex

      hostLoadHex

    • Open the Console window of the host application to view application bootloading sequence

      hostToolsConsole

  10. Click on Program Device button to program the loaded test application hex file on to the device

    hostProgramDevice

  11. Following snapshot shows output of successfully programming the test application

    hostSuccess

  12. If above step is successful then LED3 should start blinking and you should see below output on the console

    output

  13. Press and hold the Switch SW1 to trigger Bootloader from test application and you should see below output

    output

  14. Repeat Steps 10-12 once and jump to Step-15

    • This step is to verify that bootloader is running after triggering bootloader from test application in Step 13
  15. Press and hold the Switch SW1 and then Power cycle the device to force trigger bootloader at startup

  16. Repeat Steps 10-12 once

    • This step is to verify whether bootloader is triggered by switch press at reset

Note

  • Unified Host application has to be closed in order to program any application using MPLAB X IDE

Additional Steps (Optional)