boards/adafruit/trinket_m0/doc/index.rst
.. zephyr:board:: adafruit_trinket_m0
Overview
The Adafruit Trinket M0 is a tiny (27 mm x 15 mm) ARM development board with an onboard RGB LED, USB port, and range of I/O broken out onto 5 pins.
Hardware
.. zephyr:board-supported-hw::
The Adafruit Trinket M0 Learn site_ has detailed information about
the board including pinouts_ and the schematic_.
The SAMD21 MCU is configured to use the 8 MHz internal oscillator with the on-chip PLL generating the 48 MHz system clock. The internal APB and GCLK unit are set up in the same way as the upstream Arduino libraries.
The SAMD21 MCU has 6 SERCOM based USARTs. On the Trinket, SERCOM0 is the Zephyr console and is available on pins 3 (RX) and 4 (TX). SERCOM2 is available on pins 2 (RX) and 0 (TX).
The SAMD21 MCU has 3 TCC based PWM units with up to 4 outputs each and a period
of 24 bits or 16 bits. If :code:CONFIG_PWM_SAM0_TCC is enabled then LED0 is
driven by TCC0 instead of by GPIO.
The SAMD21 MCU has 6 SERCOM based SPIs. On the Trinket, SERCOM1 is used to drive the DotStar RGB LED. SERCOM0 can be put into SPI mode and used to connect to devices over pin 2 (MISO), pin 4 (MOSI), and pin 3 (SCK).
The SAMD21 MCU has a USB device port that can be used to communicate
with a host PC. See the :zephyr:code-sample-category:usb sample applications for
more, such as the :zephyr:code-sample:usb-cdc-acm sample which sets up a virtual
serial port that echos characters back to the host PC.
Programming and Debugging
.. zephyr:board-supported-runners::
The Trinket M0 ships the BOSSA compatible UF2 bootloader. The bootloader can be entered by quickly tapping the reset button twice.
Additionally, if :code:CONFIG_USB_CDC_ACM is enabled then the bootloader
will be entered automatically when you run :code:west flash.
#. Build the Zephyr kernel and the :zephyr:code-sample:hello_world sample application:
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: adafruit_trinket_m0 :goals: build :compact:
#. Connect the Trinket M0 to your host computer using USB
#. 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.
#. Run your favorite terminal program to listen for output. Under Linux the
terminal should be :code:/dev/ttyACM0. For example:
.. code-block:: console
$ minicom -D /dev/ttyACM0 -o
The -o option tells minicom not to send the modem initialization string. Connection should be configured as follows:
#. Tap the reset button twice quickly to enter bootloader mode
#. Flash the image:
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: adafruit_trinket_m0 :goals: flash :compact:
You should see "Hello World! adafruit_trinket_m0" in your terminal.
References
.. target-notes::
.. _Adafruit Trinket M0 Learn site: https://learn.adafruit.com/adafruit-trinket-m0-circuitpython-arduino
.. _pinouts: https://learn.adafruit.com/assets/49778
.. _schematic: https://learn.adafruit.com/assets/45723