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.
Type |
Location |
Description |
Compatible |
---|---|---|---|
CPU |
on-chip |
ARM Cortex-M4F CPU1 |
|
ADC |
on-chip |
Atmel SAM0 family ADC2 |
|
ARM architecture |
on-chip |
For locating the Device ID (serial number) on Atmel SAM0 devices1 |
|
Clock control |
on-chip |
Atmel SAM0 Main Clock Controller (MCLK)1 |
|
on-chip |
Atmel SAM0 32kHz Oscillator Controller (OSC32KCTRL)1 |
||
on-chip |
Atmel SAMD0 Generic Clock Controller (GCLK)1 |
||
Counter |
on-chip |
Atmel SAM0 basic timer counter (TC) operating in 32-bit wide mode4 |
|
Display |
on-board |
ILI9341 320x240 display controller1 |
|
DMA |
on-chip |
Atmel SAM0 DMA controller1 |
|
Flash controller |
on-chip |
Atmel SAM0 NVMC (Non-Volatile Memory Controller)1 |
|
GPIO & Headers |
on-chip |
SAM0 GPIO PORT node4 |
|
on-board |
GPIO pins exposed on Grove 4 pins headers2 |
||
on-board |
GPIO pins exposed on Raspberry Pi 40-pin header1 |
||
I2C |
on-chip |
Atmel SAM0 series SERCOM I2C2 |
|
Input |
on-board |
Group of GPIO-bound input keys2 |
|
Interrupt controller |
on-chip |
ARMv7-M NVIC (Nested Vectored Interrupt Controller)1 |
|
on-chip |
Atmel SAM0 series External Interrupt Controller1 |
||
LED |
on-board |
Group of GPIO-controlled LEDs1 |
|
MMU / MPU |
on-chip |
ARMv7-M Memory Protection Unit (MPU)1 |
|
MTD |
on-chip |
Flash node1 |
|
on-board |
Fixed partitions of a flash (or other non-volatile storage) memory1 |
||
Pin control |
on-chip |
Atmel SAM0 PINMUX4 |
|
on-chip |
Atmel SAM0 Pinctrl Container1 |
||
Regulator |
on-board |
Fixed voltage regulators4 |
|
RNG |
on-chip |
Atmel SAM RNG1 |
|
RTC |
on-chip |
Atmel SAM0 RTC1 |
|
Sensors |
on-board |
STMicroelectronics LIS3DH 3-axis accelerometer1 |
|
Serial controller |
on-chip |
Atmel SAM0 SERCOM UART driver2 |
|
SPI |
on-chip |
Atmel SAM0 SERCOM SPI controller4 |
|
SRAM |
on-chip |
Generic on-chip SRAM description2 |
|
Timer |
on-chip |
ARMv7-M System Tick1 |
|
USB |
on-chip |
Atmel SAM0 USB in device mode1 |
|
Watchdog |
on-chip |
Atmel SAM0 watchdog1 |
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
Build the Zephyr kernel and the
button
sample application:west build -b wio_terminal samples/basic/button
Swipe the reset/power button down twice quickly to enter bootloader mode
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.
Solder cables to the
SWCLK
,SWDIO
,RESET
,GND
, and3V3
pins. See Test with SWD [4] for more information.Connect the board to the probe by connecting the
SWCLK
,SWDIO
,RESET
,GND
, and3V3
pins on the Wio Terminal to theSWCLK
,SWDIO
,RESET
,GND
, andVTref
pins on the J-Link [5].Flash the image:
west build -b wio_terminal samples/basic/button west flash -r openocd
Start debugging:
west build -b wio_terminal samples/basic/button west debug