|
17 | 17 | * device drivers should go into this module.
|
18 | 18 | *
|
19 | 19 |
|
| 20 | +Board Selection Guide {#board-selection-guide} |
| 21 | +===================== |
| 22 | + |
| 23 | +There is no single best board to buy for use with RIOT, as hardware design |
| 24 | +involves many trade-offs. The challenge is to clearly assess the use case and |
| 25 | +collect the requirements and to find the best match for those. |
| 26 | + |
| 27 | +With this in mind, it is still possible to give some hints and recommendations: |
| 28 | + |
| 29 | +1. During Development: |
| 30 | + - An integrated programmer/debugger is immensely useful. At the very least |
| 31 | + a standard JTAG/SWD connector for quick and fool-proof connection is |
| 32 | + required |
| 33 | + - If possible, pick an MCU with *more* RAM and flash than your target board. |
| 34 | + This allows to spend the excess in memory for debug features such as |
| 35 | + utility modules, verbose assert messages, etc. during development |
| 36 | + - Standard connectors such as Arduino Headers, or Grove, STEMMA, STEMMA QT, |
| 37 | + QUIIC connectors etc. make hardware prototyping easier |
| 38 | +2. Final Product: |
| 39 | + - An integrated programmer/debugger is a waste of resources (money, power, |
| 40 | + space, ...) |
| 41 | + - ... |
| 42 | + |
| 43 | +Popular Boards |
| 44 | +-------------- |
| 45 | + |
| 46 | +| Board | Use Case | Performance | Integrated Debugger | Integrated Networking | Native USB | Arduino Headers | Other Connectors | Integrated Sensors/... | Breadboard Friendly | Costs | Remarks | |
| 47 | +|:------------------------------------- |:--------------------- |:------------- |:--------------------- |:--------------------------------- |:------------- |:--------------------- |:------------------------- |:----------------------------------------------------- |:--------------------- |:--------- |:----------------------------- | |
| 48 | +| @ref boards_arduino-due | Education | `++` | ✔ | ✗ | ✔ | `+++` (Uno, Mega, ISP)| ✗ | `-` (1 LED) | `+` | `o` | Better buy the nrf52840dk | |
| 49 | +| @ref boards_arduino-mega2560 | You have them anyway | `--` | ✗ | ✗ | ✗ | `+++` (Uno, Mega, ISP)| ✗ | `-` (1 LED) | `+` | `--` | Better buy the nrf52840dk | |
| 50 | +| @ref boards_arduino-uno | You have them anyway | `---` | ✗ | ✗ | ✗ | `++` (Uno, ISP) | ✗ | `-` (1 LED) | `+` | `--` | You like pain, don't you? | |
| 51 | +| @ref boards_common_nucleo32 | Development | `-/o/+/++` | ✔ | ✗ | ✗ | `o` (Nano) | Custom | `o` (1 button, 1 LED) | `+` | `++` | Good bang for the buck | |
| 52 | +| @ref boards_common_nucleo64 | Development | `o/+/++` | ✔ | ✗ | ✗ | `+` (Uno) | ST Morpho Headers | `o` (1 button, 1 LED) | `+` | `++` | Good bang for the buck | |
| 53 | +| @ref boards_common_nucleo144 | Development | `+/++/+++` | ✔ | (✔) (some have Ethernet) | ✔ | `++` (Uno, Mega) | ST Morpho Headers | `+` (1 button, 3 LEDs) | `+` | `++` | Good bang for the buck | |
| 54 | +| @ref boards_esp32_esp-ethernet-kit | Development | `+++` | ✔ | ✔ (WiFi, BLE, Ethernet, custom) | ✗ | ✗ | Custom | `-` (1 button) | `+` | `o` | Requires proprietary software | |
| 55 | +| @ref boards_esp32_wroom-32 | Prototyping | `+++` | ✗ | ✔ (WiFi, BLE, custom) | ✗ | ✗ | Custom | `-` (1 button) | `+++` | `+++` | Requires proprietary software | |
| 56 | +| @ref boards_microbit_v2 | Education | `++` | ✔ | ✔ (802.15.4, BLE, custom) | ✗ | ✗ | micro:bit edge connector | `+++` (6 buttons, LED matrix, mic, speaker, IMO) | `--` | `++` | Good education board | |
| 57 | +| @ref boards_nrf52840dk | Development | `++` | ✔ | ✔ (802.15.4, BLE, custom) | ✔ | `+++`(Uno, Mega) | Custom | `+` (4 buttons, 4 LEDs) | `+` | `+` | Excellent border router | |
| 58 | +| @ref boards_nrf52840dongle | Prototyping | `++` | ✗ | ✔ (802.15.4, BLE, custom) | ✔ | ✗ | Custom | o (1 button, 4 LEDs) | `++` | `++` | Good wireless dev board | |
| 59 | +| @ref boards_nucleo-wl55jc | Development | `++` | ✔ | ✔ (LoRa) | ✗ | `+` (Uno) | ST Morpho Headers | `+` (3 buttons, 3 LEDs) | `+` | `++` | Good bang for the buck | |
| 60 | +| @ref boards_pinetime | Gadget | `++` | ✗ | ✔ (BLE) | ✗ | ✗ | ✗ | `+++` (LCD, button, touch screen, IMU, flash, ...) | `---` | `+++` | Buy two: One with SWD access | |
| 61 | +| @ref boards_samr21-xpro | Development | `+` | ✔ | ✔ (802.15.4) | ✔ | ✗ | XPRO Expansion Header | `o` (1 button, 1 LED) | `+` | `--` | Quite expensive | |
| 62 | +| @ref boards_samr34-xpro | Development | `++` | ✔ | ✔ (LoRa) | ✔ | ✗ | XPRO Expansion Header | `o` (1 button, 2 LEDs) | `+` | `---` | Got a spare kidney to sell? | |
| 63 | +| @ref boards_weact-f411ce | Prototyping | `++` | ✗ | ✗ | ✔ | ✗ | Custom | `+` (1 button, 1 LED, SPI flash) | `+++` | `+++` | Excellent bang for the buck | |
| 64 | + |
| 65 | +@note Only boards with mature RIOT support and decent documentation qualify for above list |
| 66 | +@details This list was last updated in May 2023 |
| 67 | + |
| 68 | + |
| 69 | +<!-- Add when doc is fixed |
| 70 | +| @ref boards_b-l072z-lrwan1 | Development | `+` | ✔ | ✔ (LoRa) | ✗ | `++` (Uno, Mega) | ST Morpho Headers | `+` (1 button, 4 LEDs) | `+` | `++` | Good bang for the buck | |
| 71 | +--> |
| 72 | + |
| 73 | +### Notes on Arduino Compatibility |
| 74 | + |
| 75 | +- Perfect (`+++`) only if it is fully compatible with both Arduino Uno and Arduino Mega Shields (including SPI via ISP connector) |
| 76 | +- Good (`++`) if it is fully compatible with Arduino Uno shields (including SPI via ISP connector) |
| 77 | +- Good (`++`) if it is partially compatible with both Arduino Uno and Arduino Mega Shields (no SPI via ISP connector) |
| 78 | +- Decent (`+`) if it is partially compatible with Arduino Uno Shields (no SPI via ISP connector) |
| 79 | +- Decent (`+`) if it is fully compatible with Arduino Nano Shields (including SPI via ISP connector) |
| 80 | +- OK (`o`) if it is partially compatible with Arduino Nano Shields |
| 81 | + |
20 | 82 | Guide to board pinouts {#pinout_guide}
|
21 | 83 | =====================================
|
22 | 84 |
|
|
0 commit comments