mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-17 06:12:43 +01:00
boards/stm32f4discovery: update and clean up doc
Most importantly, this fixes outdated statements about stdio, which now by default is over USB rather than UART.
This commit is contained in:
parent
30c9204322
commit
fc6e35fa54
@ -12,48 +12,105 @@ for a quick getting started guide.
|
|||||||
![Stm32f4discovery with RIOT pin names](https://raw.githubusercontent.com/wiki/RIOT-OS/RIOT/images/stm32f4discovery_pinout_RIOT.png)
|
![Stm32f4discovery with RIOT pin names](https://raw.githubusercontent.com/wiki/RIOT-OS/RIOT/images/stm32f4discovery_pinout_RIOT.png)
|
||||||
|
|
||||||
### MCU
|
### MCU
|
||||||
| MCU | STM32F407VGT6 |
|
|
||||||
|:------------- |:--------------------- |
|
| MCU | STM32F407VGT6 |
|
||||||
| Family | ARM Cortex-M4 |
|
|:--------------------- |:----------------------------------------- |
|
||||||
| Vendor | ST Microelectronics |
|
| Family | ARM Cortex-M4 |
|
||||||
| Package | LQFP100 |
|
| Vendor | ST Microelectronics |
|
||||||
| RAM | 192Kb (128Kb RAM + 64Kb CCMRAM) |
|
| Package | LQFP100 |
|
||||||
| Flash | 1024Kb |
|
| RAM | 192 KiB (128 KiB RAM + 64 KiB CCMRAM) |
|
||||||
| Frequency | up to 168MHz |
|
| Flash | 1024 KiB |
|
||||||
| FPU | yes |
|
| Frequency | up to 168 MHz |
|
||||||
| Timers | 14 (12x 16bit, 2x 32bit [TIM2 + TIM5]) |
|
| FPU | yes |
|
||||||
| ADCs | 3x 16 channel 6 to 12-bit |
|
| Timers | 14 (12× 16bit, 2× 32bit [TIM2 + TIM5]) |
|
||||||
| UARTs | 6 |
|
| ADCs | 3× 16 channel 6 to 12-bit |
|
||||||
| SPIs | 3 |
|
| UARTs | 6 |
|
||||||
| I2Cs | 3 |
|
| SPIs | 3 |
|
||||||
| Vcc | 2.0V - 3.6V |
|
| I2Cs | 3 |
|
||||||
| Datasheet | [Datasheet](https://www.st.com/resource/en/datasheet/stm32f407vg.pdf) |
|
| Vcc | 2.0 V - 3.6 V |
|
||||||
| Reference Manual | [Reference Manual](https://www.st.com/resource/en/reference_manual/dm00031020.pdf) |
|
| MCU Datasheet | [MCU Datasheet][mcu-datasheet] |
|
||||||
| Programming Manual | [Programming Manual](https://www.st.com/resource/en/programming_manual/dm00046982.pdf) |
|
| Reference Manual | [Reference Manual][reference-manual] |
|
||||||
| Board Manual | [Board Manual](https://www.st.com/resource/en/user_manual/dm00039084.pdf)|
|
| Programming Manual | [Programming Manual][programming-manual] |
|
||||||
|
| Board Manual | [Board Manual][board-manual] |
|
||||||
|
|
||||||
|
[mcu-datasheet]: https://www.st.com/resource/en/datasheet/stm32f407vg.pdf
|
||||||
|
[reference-manual]: https://www.st.com/resource/en/reference_manual/dm00031020.pdf
|
||||||
|
[programming-manual]: https://www.st.com/resource/en/programming_manual/dm00046982.pdf
|
||||||
|
[board-manual]: https://www.st.com/resource/en/user_manual/dm00039084.pdf
|
||||||
|
|
||||||
|
## Flashing
|
||||||
|
|
||||||
|
After connecting the board to your computer using the Mini USB port, `cd` to
|
||||||
|
the directory of the app you intend to flash and run:
|
||||||
|
|
||||||
|
```
|
||||||
|
make BOARD=stm32f4discovery flash
|
||||||
|
```
|
||||||
|
|
||||||
|
@note You will need to have OpenOCD installed, e.g. `sudo apt install openocd`
|
||||||
|
|
||||||
|
## STDIO
|
||||||
|
|
||||||
|
By default, STDIO is implemented via the native USB interface.
|
||||||
|
|
||||||
|
### Using USB
|
||||||
|
|
||||||
|
Connect your computer via the micro USB connector to the board. (It is safe
|
||||||
|
to connect both the native USB port of the MCU at the micro USB connector
|
||||||
|
and the ST-Link programmer/debugger at the mini USB connector at the same
|
||||||
|
time.)
|
||||||
|
|
||||||
|
Afterwards, simply run (with the current working directory of your terminal
|
||||||
|
set to directory of the app you flashed):
|
||||||
|
|
||||||
|
```
|
||||||
|
make BOARD=stm32f4discovery term
|
||||||
|
```
|
||||||
|
|
||||||
|
### Using UART
|
||||||
|
|
||||||
|
Connect your USB to UART bridge as follows:
|
||||||
|
|
||||||
|
| Pin UART Adapter | Pin Board |
|
||||||
|
|:----------------- |:------------- |
|
||||||
|
| TXD | RXD (PA3) |
|
||||||
|
| RXD | TXD (PA2) |
|
||||||
|
| GND | GND |
|
||||||
|
|
||||||
|
Now flash with stdio over UART by selecting the module `stdio_uart` and connect
|
||||||
|
to the serial. You can do both by running in a terminal (and the working
|
||||||
|
directory set to the directory of the app you want to run):
|
||||||
|
|
||||||
|
```
|
||||||
|
USEMODULE=stdio_uart make BOARD=stm32f4discovery flash term
|
||||||
|
```
|
||||||
|
|
||||||
|
@note The `USEMODULE=stdio` needs to be specified *before* the `make` command
|
||||||
|
to pass it as environment variable.
|
||||||
|
|
||||||
### RIOT pin mapping
|
### RIOT pin mapping
|
||||||
|
|
||||||
Please refer to [this document](https://docs.google.com/spreadsheets/d/11iqdux3K1-7FPZChufNgpChwENkgCiLrnKJPoCcJxdg/edit?usp=sharing)
|
Please refer to [this document][pin-mapping-gdocs] for the RIOTs pin
|
||||||
for the RIOTs pin
|
|
||||||
mapping for the stm32f4discovery board. The pin mapping is chosen completely
|
mapping for the stm32f4discovery board. The pin mapping is chosen completely
|
||||||
arbitrary and can be altered by editing the
|
arbitrary and can be altered by editing the
|
||||||
`boards/stm32f4discovery/include/periph_conf.h` header file.
|
`boards/stm32f4discovery/include/periph_conf.h` header file.
|
||||||
|
|
||||||
|
[pin-mapping-gdocs]: https://docs.google.com/spreadsheets/d/11iqdux3K1-7FPZChufNgpChwENkgCiLrnKJPoCcJxdg
|
||||||
|
|
||||||
### User Interface
|
### User Interface
|
||||||
|
|
||||||
2 Buttons:
|
2 Buttons:
|
||||||
|
|
||||||
| NAME | USER | RESET |
|
| NAME | USER | RESET |
|
||||||
|:----- |:----- |:--------- |
|
|:----- |:--------- |:--------- |
|
||||||
| Pin | PA0 (IN) | NRST |
|
| Pin | PA0 (IN) | NRST |
|
||||||
|
|
||||||
6 User controllable LEDs:
|
6 User controllable LEDs:
|
||||||
|
|
||||||
| NAME | LD3 | LD4 | LD5 | LD6 | LD7 | LD8 |
|
| NAME | LD3 | LD4 | LD5 | LD6 | LD7 | LD8 |
|
||||||
| ----- | ----- | ----- | ----- | ----- | ----- | ------ |
|
|:----- |:--------- | :---- |:----- |:----- |:----- |:------ |
|
||||||
| Color | orange| green | red | blue | green | red |
|
| Color | orange | green | red | blue | green | red |
|
||||||
| Pin | PD13 | PD12 | PD14 | PD15 | PA9 | PD5 |
|
| Pin | PD13 | PD12 | PD14 | PD15 | PA9 | PD5 |
|
||||||
|
|
||||||
LEDs LD7 and LD8 are used by the USB connector for over-current (LD8) and
|
LEDs LD7 and LD8 are used by the USB connector for over-current (LD8) and
|
||||||
data (LD7) indication.
|
data (LD7) indication.
|
||||||
@ -69,58 +126,78 @@ mapped to the micro USB port by default (via CDC ACM).
|
|||||||
The STM32F4discovery board contains a 3-axis MEMS accelerometer that can
|
The STM32F4discovery board contains a 3-axis MEMS accelerometer that can
|
||||||
sample with up to 1.6kHz.
|
sample with up to 1.6kHz.
|
||||||
|
|
||||||
| Sensor | LIS3DSH |
|
| Sensor | LIS3DSH |
|
||||||
|:------------- |:--------------------- |
|
|:------------- |:--------------------------------- |
|
||||||
| Type | Accelerometer |
|
| Type | Accelerometer |
|
||||||
| Vendor | ST Microelectronics |
|
| Vendor | ST Microelectronics |
|
||||||
| Datasheet | [Datasheet](http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00040962.pdf)|
|
| Datasheet | [Datasheet][lis3dsh-datasheet] |
|
||||||
| Connected to | SPI_0 |
|
|
||||||
| Pin Config: | |
|
[lis3dsh-datasheet]: http://www.st.com/st-web-ui/static/active/en/resource/technical/document/datasheet/DM00040962.pdf
|
||||||
| Device | SPI1 |
|
|
||||||
| SCK | PA5 (OUT, SPI1_SCK) |
|
#### Pin Config:
|
||||||
| MISO | PA6 (IN, SPI1_MISO) |
|
|
||||||
| MOSI | PA7 (OUT, SPI1_MOSI) |
|
| Pin / Bus | Function |
|
||||||
| INT1 | PE0 (IN) |
|
|:--------------------- |:------------------------- |
|
||||||
| INT2 | PE1 (IN) |
|
| SPI bus (RIOT) | `SPI_DEV(0)` |
|
||||||
| CS | PE3 (OUT) |
|
| SPI bus (hardware) | SPI1 |
|
||||||
|
| SCK | PA5 (OUT, SPI1_SCK) |
|
||||||
|
| MISO | PA6 (IN, SPI1_MISO) |
|
||||||
|
| MOSI | PA7 (OUT, SPI1_MOSI) |
|
||||||
|
| INT1 | PE0 (IN) |
|
||||||
|
| INT2 | PE1 (IN) |
|
||||||
|
| CS | PE3 (OUT) |
|
||||||
|
|
||||||
### Digital Microphone
|
### Digital Microphone
|
||||||
|
|
||||||
The STM32F4discovery board contains a on-board MEMS audio sensor.
|
The STM32F4discovery board contains a on-board MEMS audio sensor.
|
||||||
|
|
||||||
| Sensor | MP45DT02 |
|
| Sensor | MP45DT02 |
|
||||||
|:------------- |:--------------------- |
|
|:------------- |:--------------------------------- |
|
||||||
| Type | Audio sensor |
|
| Type | Audio sensor |
|
||||||
| Vendor | ST Microelectronics |
|
| Vendor | ST Microelectronics |
|
||||||
| Datasheet | [Datasheet](http://www.mouser.com/pdfdocs/STM_MP45DT02_Datasheet.PDF)|
|
| Datasheet | [Datasheet][mp45dt02-datasheet] |
|
||||||
| Connected to | n/a |
|
|
||||||
| Pin Config: | |
|
|
||||||
| Device | I2S2 |
|
|
||||||
| CLK | PB10 |
|
|
||||||
| DOUT | PC3 |
|
|
||||||
|
|
||||||
|
[mp45dt02-datasheet]: http://www.mouser.com/pdfdocs/STM_MP45DT02_Datasheet.PDF
|
||||||
|
|
||||||
|
#### Pin Config:
|
||||||
|
|
||||||
|
| Pin / Interface | Function |
|
||||||
|
|:------------------------- |:------------------------- |
|
||||||
|
| I2S interface (hardware) | I2S2 |
|
||||||
|
| I2S interface (RIOT) | n/a |
|
||||||
|
| CLK | PB10 |
|
||||||
|
| DOUT | PC3 |
|
||||||
|
|
||||||
### Audio DAC with integrated class D speaker driver
|
### Audio DAC with integrated class D speaker driver
|
||||||
|
|
||||||
The board contains an digital analog converter (DAC) with integrated class D
|
The board contains an digital analog converter (DAC) with integrated class D
|
||||||
speaker driver.
|
speaker driver.
|
||||||
|
|
||||||
| Device | CS43L22 |
|
| Device | CS43L22 |
|
||||||
|:------------- |:--------------------- |
|
|:------------- |:--------------------------------- |
|
||||||
| Type | DAC |
|
| Type | DAC |
|
||||||
| Vendor | Cirrus Logic |
|
| Vendor | Cirrus Logic |
|
||||||
| Datasheet | [Datasheet](http://www.cirrus.com/en/pubs/proDatasheet/CS43L22_F2.pdf) |
|
| Datasheet | [Datasheet][cs43l22-datasheet] |
|
||||||
| Connected to | DAC + I2C + I2S |
|
|
||||||
| Pin Config: | |
|
|
||||||
| Device | DAC1 + I2C1 + I2S3 |
|
|
||||||
| AIN1 | PA4 (DAC1_OUT) |
|
|
||||||
| SCL | PB6 (I2C1_SCL) |
|
|
||||||
| SDA | PB9 (I2C1_SDA) |
|
|
||||||
| MCLK | PC7 (I2S3_MCK) |
|
|
||||||
| SCLK | PC10 (I2S3_CK) |
|
|
||||||
| SDIN | PC12 (I2S3_SD) |
|
|
||||||
| RESET | PD4 (OUT) |
|
|
||||||
|
|
||||||
|
#### Pin Config:
|
||||||
|
|
||||||
|
| Pin / Interface / Bus | Function |
|
||||||
|
|:------------------------- |:------------------------- |
|
||||||
|
| Analog (hardware) | DAC1 |
|
||||||
|
| Analog (RIOT) | `DAC_LINE(0)` |
|
||||||
|
| I2S interface (hardware) | I2S3 |
|
||||||
|
| I2S interface (RIOT) | n/a |
|
||||||
|
| I2C bus (hardware) | I2C1 |
|
||||||
|
| I2C bus (RIOT) | `I2C_BUS(0)` |
|
||||||
|
| AIN1 | PA4 (DAC1_OUT) |
|
||||||
|
| SCL | PB6 (I2C1_SCL) |
|
||||||
|
| SDA | PB9 (I2C1_SDA) |
|
||||||
|
| MCLK | PC7 (I2S3_MCK) |
|
||||||
|
| SCLK | PC10 (I2S3_CK) |
|
||||||
|
| SDIN | PC12 (I2S3_SD) |
|
||||||
|
| RESET | PD4 (OUT) |
|
||||||
|
|
||||||
|
[cs43l22-datasheet]: http://www.cirrus.com/en/pubs/proDatasheet/CS43L22_F2.pdf
|
||||||
|
|
||||||
## Supported Toolchains
|
## Supported Toolchains
|
||||||
|
|
||||||
@ -163,13 +240,6 @@ OS/RIOT/examples/ipc_pingpong/bin/stm32f4discovery/ipc_pingpong.hex in 1.200528s
|
|||||||
```
|
```
|
||||||
The board is now flashed with your RIOT binary
|
The board is now flashed with your RIOT binary
|
||||||
|
|
||||||
## Using UART
|
|
||||||
|
|
||||||
1. connect your usb tty to: RX=PA3 TX=PA2 and GND=GND
|
|
||||||
- **PA3** is connected with **TX** on the UART converter
|
|
||||||
- **PA2** is connected with **RX** on the UART converter
|
|
||||||
2. done
|
|
||||||
|
|
||||||
# Emulator
|
# Emulator
|
||||||
|
|
||||||
To emulate this board you need an updated version of
|
To emulate this board you need an updated version of
|
||||||
|
Loading…
Reference in New Issue
Block a user