AliOS Things Developer Kit UART Operation Demo

This demo shows you how to use AliOS Things Developer Kit development board to produce outputs through the Universal Asynchronous Receiver/Transmitter (UART) of the backboard J903. We will be introducing the relevant code and implementation effects in this article.

Developer Kit Hardware

Developer Kit is hardware development board based on AliOS, with a variety of peripherals. The hardware is equipped with Audio Codec, eight sensors, 8-bits digital camera, LCD display, sixes LEDs, PCIe module, USB OTG FS, and Wi-Fi module. Because the software is embedded with the AliOS system, the local data uploading to the Ali-cloud can be realized through Wi-Fi. The Developer Kit provides a convenient way for developers to learn about the development environment in combination with practical applications.

To learn more about the Developer Kit, visit

Development Environment

  1. System: Win10 x 64
  2. IDE: Visual Studio Code
  3. Development board: Developer Kit
  4. Others: Breadboard line and USB-to-TTL serial port line


To follow this tutorial, you should be able to have the following:

  1. Ability to compile the AliOS-Things developer branch and to apply and write it under examples.
  2. Ability to read the helloworld application under the developer branch.

Introduction to UART

MCU has six UARTs

UART1 is used inside the system, UART3 communicates with Wi-Fi module BK7231, and UART2 is connected to Zigbee/LoRa on the J903 backboard

Source Code

  1. In the system, the six UARTs are defined in boarddeveloperkithalhal_uart_stm32l4.h
  2. The UART that communicates with BK7231 is defined in boarddeveloperkitaosatcmd_config_platform.h. If you change the AT_UART_PORT value of 3, Wi-Fi cannot work properly (give it a try).
  3. The read and write reference of UART is in exampledeviceIOdeviceIO.c
  1. init_uart defines the port to operate UART and initializes the relevant information. port = 2 means operating the PORT_UART2 defined in hal_uart_stm32l4.h;
  2. UART_DATA_BYTES defines the length of the read and returns the output synchronously after reading.


The USB-to-TTL line is connected to J903 RX/PA3 and TX/PA2. The following figure shows that this UART is UART2

The serial port tool opens the serial port and sends Hello world! rn, a total of 14 bytes, and the serial port returns the sending content. If only Hello is sent, the result is returned in 14 bytes, which is specifically “HelloHelloHell”.

Learn more about the UART demo by visiting the Developer Kit UART demo GitHub page.


Follow me to keep abreast with the latest technology news, industry insights, and developer trends.

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store