ItsyBitsy M4 Express

Overview

The Adafruit ItsyBitsy M4 express is a small (36 mm x 18 mm) ARM development board with an onboard RGB LED, USB port, 2 MiB of SPI flash, and range of I/O broken out onto 23 GPIO pins.

Hardware

  • ATSAMD51G19A ARM Cortex-M4 processor at 120 MHz

  • 512 KiB of flash memory and 192 KiB of RAM

  • 2 MiB of SPI flash

  • Internal trimmed 8 MHz oscillator

  • A user LED

  • An RGB DotStar LED

  • Native USB port

  • One reset button

Supported Features

The adafruit_itsybitsy_m4_express 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.

adafruit_itsybitsy_m4_express/samd51g19a target

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

on-chip

Atmel SAM0 multi-protocol (UART, SPI, I2C) SERCOM unit6

atmel,sam0-sercom

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

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

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

on-board

Group of PWM-controlled LEDs1

pwm-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

PWM

on-chip

Atmel SAM0 TCC in PWM mode1

atmel,sam0-tcc-pwm

RNG

on-chip

Atmel SAM RNG1

atmel,sam-trng

RTC

on-chip

Atmel SAM0 RTC1

atmel,sam0-rtc

Serial controller

on-chip

Atmel SAM0 SERCOM UART driver1

atmel,sam0-uart

SPI

on-chip

Atmel SAM0 SERCOM SPI controller1

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 Adafruit Learning System [1] has detailed information about the board including pinouts [2] and the schematic [3].

System Clock

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

Serial Port

The SAMD51 MCU has 6 SERCOM based USARTs. On the ItsyBitsy, SERCOM3 is the Zephyr console and is available on pins 0 (RX) and 1 (TX).

SPI Port

The SAMD51 MCU has 6 SERCOM based SPIs. On the ItsyBitsy, SERCOM1 can be put into SPI mode and used to connect to devices over the SCK (SCLK), MO (MOSI), and MI (MISO) pins.

PWM

The SAMD51 has three PWM generators with up to six channels each. TCC_0 has a resolution of 24 bits and all other generators are 16 bit. TCC_1 pin 2 is mapped to PA18 (D7) and pin 3 is mapped to PA19 (D9).

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 ItsyBitsy ships with a the BOSSA compatible UF2 bootloader. The bootloader can be entered by quickly tapping the reset button twice.

Additionally, if CONFIG_USB_CDC_ACM is enabled then the bootloader will be entered automatically when you run west flash.

Flashing

  1. Build the Zephyr kernel and the Hello World sample application:

    west build -b adafruit_itsybitsy_m4_express samples/hello_world
    
  2. Connect the ItsyBitsy to your host computer using USB

  3. Connect a 3.3 V USB to serial adapter to the board and to the host. See the Serial Port section above for the board’s pin connections.

  4. Run your favorite terminal program to listen for output. Under Linux the terminal should be /dev/ttyUSB0. For example:

    $ minicom -D /dev/ttyUSB0 -o
    

    The -o option tells minicom not to send the modem initialization string. Connection should be configured as follows:

    • Speed: 115200

    • Data: 8 bits

    • Parity: None

    • Stop bits: 1

  5. Tap the reset button twice quickly to enter bootloader mode

  6. Flash the image:

    west build -b adafruit_itsybitsy_m4_express samples/hello_world
    west flash
    

    You should see “Hello World! adafruit_itsybitsy_m4_express” in your terminal.

Debugging

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

  1. Connect the board to the probe by connecting the SWCLK, SWDIO, RESET, GND, and 3V3 pins on the ItsyBitsy to the SWCLK, SWDIO, RESET, GND, and VTref pins on the J-Link [4].

  2. Flash the image:

    west build -b adafruit_itsybitsy_m4_express samples/hello_world
    west flash -r openocd
    
  3. Start debugging:

    west build -b adafruit_itsybitsy_m4_express samples/hello_world
    west debug
    

References