2018-07-26 11:48:55 +02:00
|
|
|
/**
|
|
|
|
@defgroup boards_sodaq-autonomo SODAQ Autonomo
|
|
|
|
@ingroup boards
|
|
|
|
@brief Support for the SODAQ Autonomo board.
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
The `SODAQ Autonomo` is a board by SODAQ featuring a ATSAMD21J18A. The SAMD21
|
|
|
|
is a ARM Cortex-M0+ micro-controller. It has 256Kb of flash memory and 32Kb of
|
|
|
|
RAM.
|
|
|
|
|
|
|
|
The Autonomo is available from the SODAQ [shop](http://shop.sodaq.com/).
|
|
|
|
|
|
|
|
## Hardware
|
|
|
|
|
2020-03-04 09:40:39 +01:00
|
|
|
![sodaq-autonomo image](https://support.sodaq.com/Boards/Autonomo/sodaq_autonomo.png)
|
2018-07-26 11:48:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
### MCU
|
|
|
|
| MCU | ATSAMD21J18A |
|
|
|
|
|:------------- |:--------------------- |
|
|
|
|
| Family | ARM Cortex-M0+ |
|
|
|
|
| Vendor | Atmel |
|
|
|
|
| RAM | 32Kb |
|
|
|
|
| Flash | 256Kb |
|
|
|
|
| Frequency | up to 48MHz |
|
|
|
|
| FPU | no |
|
|
|
|
| Timers | 6 (1x 16-bit, 2x 24-bit, 3x 32-bit) |
|
|
|
|
| ADCs | 1x 12-bit (8 channels) |
|
|
|
|
| UARTs | max 6 (SERCOMs shared with SPI and I2C) |
|
|
|
|
| SPIs | max 6 (see UART) |
|
|
|
|
| I2Cs | max 6 (see UART) |
|
|
|
|
| Vcc | 1.8V - 3.6V |
|
2020-03-04 13:28:23 +01:00
|
|
|
| Datasheet | [Datasheet](http://ww1.microchip.com/downloads/en/DeviceDoc/SAM_D21_DA1_Family_Data%20Sheet_DS40001882E.pdf) |
|
2018-07-26 11:48:55 +02:00
|
|
|
|
|
|
|
### User Interface
|
|
|
|
|
|
|
|
1 LED:
|
|
|
|
|
|
|
|
| Device | PIN |
|
|
|
|
|:------ |:--- |
|
|
|
|
| LED0 | PA19 |
|
|
|
|
|
|
|
|
|
|
|
|
## Implementation Status
|
|
|
|
|
|
|
|
Please refer to [this tracker](https://github.com/RIOT-OS/RIOT/issues/1646)
|
|
|
|
to see which projects are work in progress and who is the contact person for
|
|
|
|
this. Notice that the initial support for the Autonomo was based on
|
|
|
|
samr21-xpro. At some point we will add a separate issue to track changes for
|
|
|
|
this board.
|
|
|
|
|
|
|
|
| Device | ID | Supported | Comments |
|
|
|
|
|:------------- |:------------- |:------------- |:------------- |
|
|
|
|
| MCU | samd21 | partly | Energy saving modes not fully utilized|
|
|
|
|
| Low-level driver | GPIO | yes | |
|
|
|
|
| | PWM | yes | |
|
2018-08-05 15:22:55 +02:00
|
|
|
| | UART | yes | two UARTs by now|
|
2018-07-26 11:48:55 +02:00
|
|
|
| | I2C | yes | |
|
|
|
|
| | SPI | yes | |
|
2018-08-05 15:22:55 +02:00
|
|
|
| | ADC | yes | PA04 & PA05 disabled by default due to EDBG's use of them for UART, can be enabled from `periph_conf.h`|
|
2018-07-26 11:48:55 +02:00
|
|
|
| | USB | no | |
|
|
|
|
| | RTT | yes | |
|
2018-08-05 15:22:55 +02:00
|
|
|
| | RTC | yes | |
|
2018-07-26 11:48:55 +02:00
|
|
|
| | RNG | no | no HW module |
|
2018-08-05 15:22:55 +02:00
|
|
|
| | Timer | yes | |
|
2018-07-26 11:48:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Features of the board
|
|
|
|
|
|
|
|
Besides the SAMD21 the board has the following features:
|
|
|
|
|
|
|
|
| Feature | Description |
|
|
|
|
|:------ |:--- |
|
|
|
|
| Compatibility | Arduino M0 compatible |
|
|
|
|
| Size | 58.5 x 33.5 mm |
|
|
|
|
| Operating Voltage | 3.3V |
|
|
|
|
| Digital I/O Pins | 16, with 12 PWM, UART, SPI and TWI (I2C) |
|
|
|
|
| Analog Input Pins | 6, 12-bit ADC channels |
|
|
|
|
| Analog Output Pins | 10-bit DAC |
|
|
|
|
| External Interrupts | Available on all pins except pin 4 |
|
|
|
|
| DC Current per I/O pin | 7 mA |
|
|
|
|
| EEPROM | Up to 16KB by emulation |
|
|
|
|
| Clock Speed | 48 MHz |
|
|
|
|
| Debug | Serial Wire Interface |
|
|
|
|
| Communications | Bee compatible slot for communication modules with software switchable power |
|
|
|
|
| Storage | 16Mbit Dataflash Module and Micro SD card holder |
|
|
|
|
| Power | 5V USB power and/or 3.7V LiPo battery |
|
|
|
|
| Power switch | Software switchable power for connected devices up to 1A |
|
|
|
|
| Charging | Solar charge controller, up to 500mA charge current|
|
|
|
|
| LED's | Yellow charge LED and green LED on pin 13 |
|
|
|
|
|
|
|
|
## Flashing the device
|
|
|
|
|
2019-10-01 12:09:14 +02:00
|
|
|
Use `BOARD=sodaq-autonomo` with the `make` command.<br/>
|
|
|
|
Example with `hello-world` application:
|
2018-08-05 15:22:55 +02:00
|
|
|
```
|
|
|
|
make BOARD=sodaq-autonomo -C examples/hello-world flash
|
|
|
|
```
|
2018-07-26 11:48:55 +02:00
|
|
|
|
2019-10-01 12:09:14 +02:00
|
|
|
@note If the application crashes, automatic reflashing via USB, as explained
|
|
|
|
above won't be possible. In this case, the board must be set in
|
|
|
|
bootloader mode by double tapping the reset button before running the
|
|
|
|
flash command.
|
|
|
|
|
|
|
|
## Accessing STDIO via UART
|
|
|
|
|
|
|
|
STDIO of RIOT is directly available over the USB port.
|
|
|
|
|
|
|
|
The `TERM_DELAY` environment variable can be used to add a delay (in second)
|
|
|
|
before opening the serial terminal. The default value is 2s which should be
|
|
|
|
enough in most of the situation.
|
|
|
|
|
2018-07-26 11:48:55 +02:00
|
|
|
## Supported Toolchains
|
|
|
|
|
|
|
|
To build software for the autonomo board we strongly recommend the usage of
|
|
|
|
the [GNU Tools for ARM Embedded Processors](https://launchpad.net/gcc-arm-embedded) toolchain.
|
|
|
|
|
|
|
|
|
|
|
|
## Known Issues / Problems
|
|
|
|
|
|
|
|
### Stack sizes
|
|
|
|
The default stack sizes have not been tuned properly yet. If in doubt why
|
|
|
|
your application crashes try increasing the default stack sizes and use `ps` to
|
|
|
|
find out how much stack is being used.
|
|
|
|
Tracked in https://github.com/RIOT-OS/RIOT/issues/2228
|
|
|
|
*/
|