Wio Terminal

Overview

The Wio Terminal is a small (72 mm x 57 mm x 12 mm) and powerful ARM board with wireless connectivity (2.4G/5G dual-band Wi-Fi and BLE 5.0), LCD display, USB C port, FPC connector, microSD card slot, Raspberry Pi compatible 40-pins header and 2 Grove connectors.

Hardware

  • ATSAMD51P19 ARM Cortex-M4F processor at 120 MHz

  • 512 KiB flash memory and 192 KiB of RAM

  • 4 MiB external flash

  • MicroSD card slot

  • RTL8720DN 2.4G/5G Dual Bands Wireless and BLE5.0 Combo Module

  • 2.4inch LCD display

  • LIS3DH accelerometer

  • Microphone 1.0V-10V -42dB

  • Speaker ≥78dB @10cm 4000Hz

  • Light Sensor 400-1050nm

  • Infrared Emitter 940nm

  • GPIO 40 pin (Raspberry Pi compatible)

  • 2x Grove connectors

  • 1x user LED

  • 3x user buttons

  • 5-way user button

  • Power/Reset/Boot mode switch

  • Native USB port

Supported Features

The wio_terminal board supports the hardware features listed below.

on-chip / on-board
Feature integrated in the SoC / present on the board.
2 / 2
Number of instances that are enabled / disabled.
Click on the label to see the first instance of this feature in the board/SoC DTS files.
vnd,foo
Compatible string for the Devicetree binding matching the feature.
Click on the link to view the binding documentation.
wio_terminal
/
samd51p19a

Type

Location

Description

Compatible

CPU

on-chip

ARM Cortex-M4F CPU1

arm,cortex-m4f

ADC

on-chip

Atmel SAM0 family ADC2

atmel,sam0-adc

ARM architecture

on-chip

For locating the Device ID (serial number) on Atmel SAM0 devices1

atmel,sam0-id

Clock control

on-chip

Atmel SAM0 Main Clock Controller (MCLK)1

atmel,sam0-mclk

on-chip

Atmel SAM0 32kHz Oscillator Controller (OSC32KCTRL)1

atmel,sam0-osc32kctrl

on-chip

Atmel SAMD0 Generic Clock Controller (GCLK)1

atmel,sam0-gclk

Counter

on-chip

Atmel SAM0 basic timer counter (TC) operating in 32-bit wide mode4

atmel,sam0-tc32

Display

on-board

ILI9341 320x240 display controller1

ilitek,ili9341

DMA

on-chip

Atmel SAM0 DMA controller1

atmel,sam0-dmac

Flash controller

on-chip

Atmel SAM0 NVMC (Non-Volatile Memory Controller)1

atmel,sam0-nvmctrl

GPIO & Headers

on-chip

SAM0 GPIO PORT node4

atmel,sam0-gpio

on-board

GPIO pins exposed on Grove 4 pins headers2

grove-header

on-board

GPIO pins exposed on Raspberry Pi 40-pin header1

raspberrypi-40pins-header

I2C

on-chip

Atmel SAM0 series SERCOM I2C2

atmel,sam0-i2c

Input

on-board

Group of GPIO-bound input keys2

gpio-keys

Interrupt controller

on-chip

ARMv7-M NVIC (Nested Vectored Interrupt Controller)1

arm,v7m-nvic

on-chip

Atmel SAM0 series External Interrupt Controller1

atmel,sam0-eic

LED

on-board

Group of GPIO-controlled LEDs1

gpio-leds

MMU / MPU

on-chip

ARMv7-M Memory Protection Unit (MPU)1

arm,armv7m-mpu

MTD

on-chip

Flash node1

soc-nv-flash

on-board

Fixed partitions of a flash (or other non-volatile storage) memory1

fixed-partitions

Pin control

on-chip

Atmel SAM0 PINMUX4

atmel,sam0-pinmux

on-chip

Atmel SAM0 Pinctrl Container1

atmel,sam0-pinctrl

Regulator

on-board

Fixed voltage regulators4

regulator-fixed

RNG

on-chip

Atmel SAM RNG1

atmel,sam-trng

RTC

on-chip

Atmel SAM0 RTC1

atmel,sam0-rtc

Sensors

on-board

STMicroelectronics LIS3DH 3-axis accelerometer1

st,lis3dh

Serial controller

on-chip

Atmel SAM0 SERCOM UART driver2

atmel,sam0-uart

SPI

on-chip

Atmel SAM0 SERCOM SPI controller4

atmel,sam0-spi

SRAM

on-chip

Generic on-chip SRAM description2

mmio-sram

Timer

on-chip

ARMv7-M System Tick1

arm,armv7m-systick

USB

on-chip

Atmel SAM0 USB in device mode1

atmel,sam0-usb

Watchdog

on-chip

Atmel SAM0 watchdog1

atmel,sam0-watchdog

Zephyr can use the default Cortex-M SYSTICK timer or the SAM0 specific RTC. To use the RTC, set CONFIG_CORTEX_M_SYSTICK=n and set CONFIG_SYS_CLOCK_TICKS_PER_SEC to no more than 32 kHZ divided by 7, i.e. no more than 4500.

Connections and IOs

The Wio Terminal Getting started guide [1] has detailed information about the board including pinouts [2] and its schematics [3].

System Clock

The SAMD51 MCU is configured to use the 32.768 kHz internal oscillator with the on-chip PLL generating the 120 MHz system clock.

Serial Port

Zephyr console output is available using the USB connector, which is used to make the console available on PC as USB CDC class.

USB Device Port

The SAMD51 MCU has a USB device port that can be used to communicate with a host PC. See the USB device support sample applications for more, such as the USB CDC-ACM sample which sets up a virtual serial port that echos characters back to the host PC.

Programming and Debugging

The Wio Terminal ships with an UF2 bootloader that is BOSSA compatible. The bootloader can be entered by quickly tapping the reset button twice.

The UF2 file is generated when building the application, and it is possible to use it to flash the target. Enter the bootloader by quickly sliding the power button twice, and copy the UF2 file to the USB mass storage device. The device reboots on the new firmware after the UF2 file has finished transferring.

Flashing

  1. Build the Zephyr kernel and the button sample application:

    west build -b wio_terminal samples/basic/button
    
  2. Swipe the reset/power button down twice quickly to enter bootloader mode

  3. Flash the image:

    west build -b wio_terminal samples/basic/button
    west flash
    

    You should see the blue (user) LED flashing whenever you press the third (counting from the top left) user button at the top of the Wio Terminal.

Debugging

In addition to the built-in bootloader, the Wio Terminal can be flashed and debugged using an SWD probe such as the Segger J-Link.

  1. Solder cables to the SWCLK, SWDIO, RESET, GND, and 3V3 pins. See Test with SWD [4] for more information.

  2. Connect the board to the probe by connecting the SWCLK, SWDIO, RESET, GND, and 3V3 pins on the Wio Terminal to the SWCLK, SWDIO, RESET, GND, and VTref pins on the J-Link [5].

  3. Flash the image:

    west build -b wio_terminal samples/basic/button
    west flash -r openocd
    
  4. Start debugging:

    west build -b wio_terminal samples/basic/button
    west debug
    

References