2017-08-24 11:44:56 +02:00
|
|
|
/**
|
2018-07-26 11:48:55 +02:00
|
|
|
@defgroup boards_feather-m0 Adafruit Feather M0
|
|
|
|
@ingroup boards
|
|
|
|
@brief Support for the Adafruit Feather M0.
|
|
|
|
|
|
|
|
### General information
|
|
|
|
|
|
|
|
Feather M0 boards are development boards shipped by
|
|
|
|
[Adafruit](https://learn.adafruit.com/adafruit-feather-m0-basic-proto/).
|
|
|
|
|
|
|
|
All the feather M0 boards are built based on the same Atmel SAMD21G18A
|
|
|
|
microcontroller. See @ref cpu_samd21.
|
|
|
|
|
|
|
|
Several types of Feather M0 boards exist:
|
2020-06-24 16:27:50 +02:00
|
|
|
- [Feather M0 WiFi](https://learn.adafruit.com/adafruit-feather-m0-wifi-atwinc1500/)
|
|
|
|
- [Feather M0 BLE](https://learn.adafruit.com/adafruit-feather-m0-bluefruit-le/overview)
|
|
|
|
- [Feather M0 Adalogger](https://learn.adafruit.com/adafruit-feather-m0-adalogger/)
|
|
|
|
- [Feather M0 LoRa](https://learn.adafruit.com/adafruit-feather-m0-radio-with-lora-radio-module)
|
2018-07-26 11:48:55 +02:00
|
|
|
|
2019-10-13 16:09:52 +02:00
|
|
|
The different modules used to differentiate the boards (ATWINC1500 WiFi,
|
2018-07-26 11:48:55 +02:00
|
|
|
Bluefruit LE, SD card, LoRa) are connected via SPI (SPI_DEV(0)) to the
|
|
|
|
SAMD21 mcu.
|
|
|
|
|
|
|
|
### Pinout
|
|
|
|
|
|
|
|
<img src="https://cdn-learn.adafruit.com/assets/assets/000/030/921/original/adafruit_products_2772_pinout_v1_0.png"
|
2019-06-05 22:21:22 +02:00
|
|
|
alt="Adafruit Feather M0 proto pinout" style="width:800px;"/><br/>
|
|
|
|
|
|
|
|
`AIN7` can be used to [measure the voltage of a connected Lipoly battery][battery].
|
|
|
|
It is mapped to ADC_LINE(6) in RIOT.
|
|
|
|
|
|
|
|
~~~~~~~~~~~~~~~~ {.c}
|
|
|
|
int vbat = adc_sample(ADC_LINE(6), ADC_RES_10BIT);
|
|
|
|
vbat *= 2; /* voltage was divided by 2, so multiply it back */
|
|
|
|
vbat *= 33; /* reference voltage 3.3V * 10 */
|
|
|
|
vbat /= 10240; /* resolution * 10 (because we multiplied 3.3V by 10) */
|
|
|
|
printf("Bat: %dV\n", vbat);
|
|
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
[battery]: https://learn.adafruit.com/adafruit-feather-m0-basic-proto/power-management#measuring-battery-4-9
|
2018-07-26 11:48:55 +02:00
|
|
|
|
|
|
|
### Flash the board
|
|
|
|
|
2019-10-01 12:09:04 +02:00
|
|
|
Use `BOARD=feather-m0` with the `make` command.<br/>
|
|
|
|
Example with `hello-world` application:
|
2018-07-26 11:48:55 +02:00
|
|
|
```
|
|
|
|
make BOARD=feather-m0 -C examples/hello-world flash
|
|
|
|
```
|
|
|
|
|
2019-10-01 12:09:04 +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.
|
|
|
|
|
2020-06-24 16:27:50 +02:00
|
|
|
### Using the WiFi interface
|
|
|
|
|
|
|
|
To enable the WiFi interface of the Feather M0 WiFi variant of the board
|
2020-08-08 17:04:27 +02:00
|
|
|
automatically for networking applications, use `feather-m0-wifi` as board
|
|
|
|
and define the required WiFi parameters, for example:
|
2020-06-24 16:27:50 +02:00
|
|
|
```
|
|
|
|
CFLAGS='-DWIFI_SSID=\"<ssid>\" -DWIFI_PASS=\"<pass>\"' \
|
2020-08-08 17:04:27 +02:00
|
|
|
make BOARD=feather-m0-wifi -C examples/gnrc_networking
|
2020-06-24 16:27:50 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
For detailed information about the parameters, see section
|
|
|
|
@ref drivers_atwinc15x0.
|
|
|
|
|
2020-11-05 15:07:48 +01:00
|
|
|
### Using with LoRa module
|
|
|
|
|
|
|
|
To enable the LoRa module available on the
|
|
|
|
[Feather M0 LoRa](https://learn.adafruit.com/adafruit-feather-m0-radio-with-lora-radio-module)
|
|
|
|
variant of the board automatically for LoRa applications,
|
|
|
|
use `feather-m0-lora` as board:
|
|
|
|
|
|
|
|
```
|
|
|
|
make BOARD=feather-m0-lora -C examples/gnrc_lorawan
|
|
|
|
```
|
|
|
|
|
|
|
|
For detailed information about the parameters, see section
|
|
|
|
@ref drivers_sx127x.
|
|
|
|
|
2018-07-26 11:48:55 +02:00
|
|
|
### Accessing STDIO via UART
|
|
|
|
|
2019-10-01 12:09:04 +02:00
|
|
|
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
|
|
|
*/
|