boards/arduino/zero/doc/index.rst
.. zephyr:board:: arduino_zero
Overview
The Arduino Zero is a maker-friendly development board with Atmel’s Embedded Debugger (EDBG), which provides a full debug interface without the need for additional hardware.
Hardware
.. zephyr:board-supported-hw::
The Arduino store_ has detailed information about board
connections. Download the Arduino Zero Schematic_ for more detail.
The SAMD21 MCU is configured to use the 32.768 kHz external 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. One of the USARTs (SERCOM5) is connected to the onboard Atmel Embedded Debugger (EDBG). SERCOM0 is available on the D0/D1 pins.
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 TCC2 instead of by GPIO.
The SAMD21 MCU has 6 SERCOM based SPIs. On the Arduino Zero, SERCOM4 is available on the 6 pin connector at the edge of the board.
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.
The SAMD21 MCU has a single channel DAC with 10 bits of resolution. On the Arduino Zero, the DAC is available on pin A0.
Programming and Debugging
.. zephyr:board-supported-runners::
The Arduino Zero comes with a Atmel Embedded Debugger (EDBG). This provides a debug interface to the SAMD21 chip and is supported by OpenOCD.
#. Build the Zephyr kernel and the :zephyr:code-sample:hello_world sample application:
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: arduino_zero :goals: build :compact:
#. Connect the Arduino Zero to your host computer using the USB debug port.
#. 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:
#. To flash an image:
.. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: arduino_zero :goals: flash :compact:
You should see "Hello World! arduino_zero" in your terminal.
References
.. target-notes::
.. _Arduino Store: https://store.arduino.cc/genuino-zero
.. _Arduino Zero Schematic: https://www.arduino.cc/en/uploads/Main/Zero_V1.0.pdf