mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 07:32:45 +01:00
88 lines
3.3 KiB
Plaintext
88 lines
3.3 KiB
Plaintext
/**
|
|
@defgroup boards_nucleo-f401re STM32 Nucleo-F401RE
|
|
@ingroup boards_common_nucleo64
|
|
@brief Support for the STM32 Nucleo-F401RE
|
|
|
|
## Overview
|
|
|
|
The Nucleo-F401 is a board from ST's Nucleo family supporting a ARM Cortex-M4
|
|
STM32F401RE microcontroller with 96Kb of SRAM and 512Kb of ROM Flash.
|
|
|
|
## Hardware
|
|
|
|
![Nucleo64 F401](http://www.open-electronics.org/wp-
|
|
content/uploads/2015/08/Figura2-500x467.png)
|
|
|
|
### MCU
|
|
|
|
| MCU | STM32F401RE |
|
|
|:------------- |:--------------------- |
|
|
| Family | ARM Cortex-M4 |
|
|
| Vendor | ST Microelectronics |
|
|
| RAM | 96Kb |
|
|
| Flash | 512Kb |
|
|
| Frequency | up to 84MHz |
|
|
| FPU | yes |
|
|
| Timers | 11 (2x watchdog, 1 SysTick, 6x 16-bit, 2x 32-bit [TIM2]) |
|
|
| ADCs | 1x 12-bit |
|
|
| UARTs | 3 |
|
|
| SPIs | 4 |
|
|
| I2Cs | 3 |
|
|
| RTC | 1 |
|
|
| Vcc | 2.0V - 3.6V |
|
|
| Datasheet | [Datasheet](http://www.st.com/resource/en/datasheet/stm32f401re.pdf) |
|
|
| Reference Manual | [Reference Manual](http://www.st.com/web/en/resource/technical/document/reference_manual/DM00031936.pdf) |
|
|
| Programming Manual | [Programming Manual](http://www.st.com/resource/en/programming_manual/dm00046982.pdf) |
|
|
| Board Manual | [Board Manual](http://www.st.com/resource/en/user_manual/dm00105823.pdf)|
|
|
|
|
## Implementation Status
|
|
|
|
| Device | ID | Supported | Comments |
|
|
|:------------- |:------------- |:------------- |:------------- |
|
|
| MCU | STM32F401RE | partly | Energy saving modes not fully utilized |
|
|
| Low-level driver | GPIO | yes | |
|
|
| | PWM | yes (7 pins available)) | |
|
|
| | UART | 2 UARTs | USART2 via STLink/USB or D0(RX)/D1(TX) and USART6 on PA12(RX)/PA11(TX) |
|
|
| | I2C | 1 I2C | |
|
|
| | SPI | 1 SPI | |
|
|
| | USB | no | |
|
|
| | Timer | 2 32 bit timers | |
|
|
|
|
## Flashing the device
|
|
|
|
The ST Nucleo-F401RE board includes an on-board ST-LINK V2 programmer. The
|
|
easiest way to program the board is to use OpenOCD. Once you have installed
|
|
OpenOCD (look [here](https://github.com/RIOT-OS/RIOT/wiki/OpenOCD) for
|
|
installation instructions), you can flash the board simply by typing
|
|
|
|
```
|
|
make BOARD=nucleo-f401 flash
|
|
```
|
|
and debug via GDB by simply typing
|
|
```
|
|
make BOARD=nucleo-f401 debug
|
|
```
|
|
|
|
## Supported Toolchains
|
|
|
|
For using the ST Nucleo-F401 board we strongly recommend the usage of the
|
|
[GNU Tools for ARM Embedded Processors](https://launchpad.net/gcc-arm-
|
|
embedded)
|
|
toolchain.
|
|
|
|
## Issues with old Hardware Revisions
|
|
|
|
Some Nucleo 64 Boards come in different hardware revisions, which is located
|
|
on a sticker at the backside of the board. As discussed in issue
|
|
[#6721](https://github.com/RIOT-OS/RIOT/issues/6721), there are some issues with
|
|
the external clock sources in revisions smaller than `C-03`. (This would also be
|
|
true for all boards with board ID `MB1136`).
|
|
The revision `C-01` has a different configuration for the high speed external
|
|
clock (HSE), which is used in RIOT. This could be fixed by reconfiguring some
|
|
solder bridges as mentioned in the [user
|
|
manual](http://www.st.com/resource/en/user_manual/dm00105823.pdf), section
|
|
6.7.1.
|
|
The other issue is, that revision `C-01` also has no 32kHz oscillator, so the
|
|
RTC module of RIOT cannot be used.
|
|
*/
|