Arduino ZeroSold out
Arduino Zero is a simple and powerful 32-bit extension of the platform established by the UNO. This board aims to provide a platform for innovative projects in smart IoT devices, wearable technology, high-tech automation, crazy robotics, and much more.
The Zero is a simple and powerful 32-bit extension of the platform established by the UNO. The Zero board expands the family by providing increased performance, enabling a variety of project opportunities for devices, and acts as a great educational tool for learning about 32-bit application development. The Zero applications span from smart IoT devices, wearable technology, high-tech automation, to crazy robotics. The board is powered by Atmel’s SAMD21 MCU, which features a 32-bit ARM Cortex® M0+ core. One of its most important features is Atmel’s Embedded Debugger (EDBG), which provides a full debug interface without the need for additional hardware, significantly increasing the ease-of-use for software debugging. EDBG also supports a virtual COM port that can be used for device and bootloader programming.
Warning: Unlike most Arduino & Genuino boards, the Zero runs at 3.3V. The maximum voltage that the I/O pins can tolerate is 3.3V. Applying voltages higher than 3.3V to any I/O pin could damage the board.
The board contains everything needed to support the microcontroller; simply connect it to a computer with a micro-USB cable or power it with a AC-to-DC adapter or battery to get started. The Zero is compatible with all the shields that work at 3.3V and are compliant with the 1.0 Arduino pinout.
You can find your board warranty information here.
Arduino and Genuino boards based on AVR microcontrollers get a reset and restart sketch execution each time the Serial Monitor of the Arduino Software (IDE) is opened. This is also the mechanism used to upload sketches to these boards. This board is different: when the Zero is connected through the Programming Port and you open the Serial Monitor, the board does not automatically reset and the sketch loaded keeps running. To restart the sketch you need to press the reset button on the board itself.
In the Getting Started section, you can find all the information you need to configure your board, use the Arduino Software (IDE), and start to tinker with coding and electronics. To keep your Zero's Bootloader up to date, the the Update Procedure explains what you should do each time there is a new Arduino SAMD Boards release.
|Microcontroller||ATSAMD21G18, 32-Bit ARM Cortex M0+|
|Digital I/O Pins||20|
|PWM Pins||3, 4, 5, 6, 8, 9, 10, 11, 12, 13|
|UART||2 (Native and Programming)|
|Analog Input Pins||6, 12-bit ADC channels|
|Analog Output Pins||1, 10-bit DAC|
|External Interrupts||All pins except pin 4|
|DC Current per I/O Pin||7 mA|
|Flash Memory||256 KB|
|EEPROM||None. See documentation|
|Clock Speed||48 MHz|
The Zero is open-source hardware! You can build your own board using the following files:
Download the full pinout diagram as PDF here.
Interactive Board Viewer
ARM Core Benefits
- 32-bit core that allows operations on 4 byte wide data within a single CPU clock. (For more information see the int type page)
- CPU Clock at 48MHz
- 12 channels DMA controller that can relieve the CPU from doing memory intensive tasks
- 32 bit Real Time Counter (RTC) with clock/calendar function
- 32 bit CRC generator
- Two-channel Inter IC Sound (I2S) interface
- Peripheral Touch Controller (PTC)
For further information about the SAM-D21 microcontroller please refer to the datasheet.
Atmel Embedded DebuggerThe Atmel Embedded Debugger (EDBG) implements a SWD interface in order to program the on-board SAMD21 and is also connected to one hardware serial of the microcontroller. This means that the 'Serial' class responds to the programming port of the board. The Zero has been designed in collaboration with ATMEL, and the on-board EDBG can be used through ATMEL Studio to get full access to the microcontroller memories to help debug your code.
- VIN. The input voltage to the board when it's using an external power source (as opposed to 5 volts from the USB connection or other regulated power source). You can supply voltage through this pin, or if supplying voltage via the power jack, access it through this pin.
- 5V. This pin outputs a regulated 5V from the regulator on the board. The board can be supplied with power either from the DC power jack (7 - 12V), the USB connector (5V), or the VIN pin of the board (7-12V). Supplying voltage via the 5V or 3.3V pins bypasses the regulator, and can damage your board if it is not sufficiently regulated. We don't advise it.
- 3.3V. A 3.3 volt supply generated by the on-board regulator. Maximum current draw is 800 mA. This regulator also provides power to the SAMD21 microcontroller.
- GND. Ground pins.
- IOREF. This pin on the board provides the voltage reference with which the microcontroller operates. A properly configured shield can read the IOREF pin voltage and select the appropriate power source or enable voltage translators on the outputs for working with the 5V or 3.3V.
Input and Output
- Serial: 0 (RX) and 1 (TX). Used to receive (RX) and transmit (TX) TTL serial data. These pins are connected to the Serial1 class. The native usb port instead responds to the SerialUSB class
- External Interrupts: available on all the pins except pin 4.
- DAC: A0. Provide a 10bit voltage output with the analogWrite() function.
- PWM: 3, 4, 5, 6, 8, 9, 10, 11, 12, 13. Provide 8-bit PWM output with the analogWrite() function.
- SPI: SS, MOSI, MISO, SCK. Located on the ICSP header only support SPI communication using the SPI library.
- LED: 13. There is a built-in LED driven by digital pin 13. When the pin is HIGH value, the LED is on, when the pin is LOW, it's off.
- Analog Inputs. Six of the 20 general purpose I/O pins on the Zero provide analog input. These are labeled A0 through A5, and each provide up to 12bits of resolution (i.e. 4096 different values). By default they measure from ground to 3.3 volts, though is it possible to change the upper end of their range using the AREF pin and the analogReference() function.
- TWI: SDA pin and SCL pin. Support TWI communication using the Wire library
There are a couple of other pins on the board:
- AREF. Reference voltage for the analog inputs. Used with analogReference().
- Reset. Bring this line LOW to reset the microcontroller. Typically used to add a reset button to shields which block the one on the board.
- Programming port: To use this port, select "Arduino/Genuino Zero (Programming Port)" as your board in the Arduino IDE. Connect the Zero's programming port (the one closest to the DC power jack) to your computer. The programming port uses the EDBG as a USB-to-SWD chip.
- Native port: To use this port, select "Arduino/Genuino Zero (Native USB Port)" as your board in the Arduino IDE. The Native USB port is connected directly to the SAMD21. Connect the Zero's Native USB port (the one closest to the reset button) to your computer.
JTAG connector for debugging through SWDAnother external debugger can be used by means of the on-board JTAG connector.
ICSP Connector used for SPI communicationHere are details of the SPI pins location within the ICSP connector:
EEPROMPart of the Flash memory may be used as a non-volatile storage with some limitations, the lifetime of the typical flash memory is about 25K write-cycles, and unlike EEPROM, and it must be erased in pages before writing. The flash memory is erased when you upload a new sketch.
- Serial is a hardware serial port internally connected to the EDBG chip and corresponds to the virtual serial port on your computer when you connect the Arduino Zero through the programming USB connector;
- SerialUSB is a virtual USB serial port, which corresponds to the virtual serial port on your computer when you connect the Arduino Zero through the native USB connector.
- Serial1 is the hardware serial port connected to pin 0 and 1, which is free to use to connect to external serial devices.
Burn the Bootloader
- select Tools->Programmer->Atmel EDBG
- select Tools->Board->Arduino/Genuino Zero (Programming Port)
- select Tools->Burn Bootloader