1.1 Console Debug System Service using UART

This example application demonstrates the UART based console and debug system service.

Description

  • The application example first demonstrates the various debug system service macros
  • It then demonstrates the console related APIs
  • The application asks the user to enter a character on the console which is echoed back using the console system service read/write APIs

Downloading and Building the Application

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

Path of the application within the repository is apps/system/console_debug/sys_console_debug_uart_read_write/firmware.

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

Project NameDescription
pic32mk_gp_db.XMPLABX project for PIC32MK GP Development Kit
pic32mk_mcj_curiosity_pro.XMPLABX project for PIC32MK MCJ Curiosity Pro Board
pic32mk_mcm_curiosity_pro.XMPLABX project for PIC32MK MCM Curiosity Pro Board
pic32mk_mca_curiosity_pro.XMPLABX project for PIC32MK MCA Curiosity Pro Board

Setting Up the Hardware

The following table shows the target hardware for the application projects.

Project NameDescription
pic32mk_gp_db.XPIC32MK GP Development Kit
pic32mk_mcj_curiosity_pro.XPIC32MK MCJ Curiosity Pro Board
pic32mk_mcm_curiosity_pro.XPIC32MK MCM Curiosity Pro Board
pic32mk_mca_curiosity_pro.XPIC32MK MCA Curiosity Pro Board

Setting Up PIC32MK GP Development Kit

  • Connect micro USB cable to the ‘Debug USB’ connector(J12) on the board to the computer
  • Connect a micro USB cable to the USART-USB port J25. This will enumerate as a COM port on the PC

Setting Up PIC32MK MCJ Curiosity Pro Board

  • Connect micro USB cable to the ‘Debug USB’ connector(J1) on the board to the computer. This will enumerate as a COM port on the PC

Setting Up PIC32MK MCM Curiosity Pro Board

  • Connect a micro USB cable to the USB DEBUG port J500
  • Connect a micro USB cable to the USB to UART port J400. This will enumerate as a COM port on the PC

Setting Up PIC32MK MCA Curiosity Pro Board

  • Connect micro USB cable to the ‘Debug USB’ connector(J1) on the board to the computer. This will enumerate as a COM port on the PC

Running the Application

  1. Open the Terminal application (Ex.:Tera term) on the computer
  2. Connect to the EDBG Virtual COM port and configure the serial settings as follows:
    • Baud : 115200
    • Data : 8 Bits
    • Parity : None
    • Stop : 1 Bit
    • Flow Control : None
  3. Build and Program the application using its IDE
  4. Observe the following output on the terminal
    • First few prints demonstrate the output from the debug system service APIs
    • It then prints the free space available in the receive buffer
    • It then asks the user to enter 10 characters
  5. After entering 10 characters, observe the following output on the terminal
    • The output first prints the free space available in the receive buffer
    • Since 10 characters are pending to be read out from the receive buffer, the free space in the receive buffer is reduced by 10
    • After this, it prints the received characters on the terminal
    • Application then waits for the transmit buffer to become empty
    • Once empty, the application prints the free space available in the transmit buffer, which should be same as the size of the transmit buffer configured in MCC minus 1
  6. After this, the demonstration asks the user to enter a character, and echoes it back on the terminal.
    • LED toggles every-time the character is printed on the terminal