2019-09-04 14:58:32 +02:00
|
|
|
/**
|
2020-03-04 13:28:20 +01:00
|
|
|
@defgroup boards_common_blxxxpill Blackpill and Bluepill common code
|
2019-09-04 14:58:32 +02:00
|
|
|
@ingroup boards_common
|
|
|
|
@brief Support for cheap stm32f103c8 based boards such as bluepill and blackpill.
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
The bluepill and the blackpill are STM32F103 based board which can be bought for
|
|
|
|
around 2€ on sides like AliExpress, eBay and others. Although the STM32F130C8
|
|
|
|
MCU nominally has 64 KiB flash, most [actually have 128 KiB flash][Flashsize].
|
|
|
|
|
|
|
|
There are also versions that only report to have 32 KiB, but actually have
|
|
|
|
64 KiB.
|
|
|
|
|
boards/common/blxxxpill: rework periph configuration
The peripheral configuration has been completely reworked to resolve
pin conflicts while provided as much of the peripherals as possible.
The changes include:
- Move `I2C_DEV(0)` from PB6/PB7 to PB8/PB9 to solve pin conflict with
`QDEC_DEV(2)`.
- Use pins PB0, PB1, PB4, and PB5 for PWM instead PA8, PA9, PA10, and
PA11
- PA9 and PA10 is in pin conflict with `UART_DEV(0)` which is used
for stdio with `stdio_uart`, PA8 was in conflict with
`QDEC_DEV(0)`, PA11 was in conflict with USB D-
- Use PB6, PB7 as `QDEC_DEV(0)` (previously `QDEC_DEV(2)`), as this is
the only completely conflict free setting
- Use PB4/PB5 instead of PA6/PA7 for QDEC_DEV(1)
- This fixes a pin conflict with `SPI_DEV(0)` MISO (and
`ADC_LINE(4)`)
- Only provide QDEC at PB4/PB5 when PWM is not used to avoid conflict
- Only provide QDEC at PA8/PA9 when UART is not used to avoid conflict
- Use SPI2 (PB15, PB14, PB13, PB12) as `SPI_DEV(0)` instead of SPI1,
use SPI1 (PA7, PA6, PA5, PA4) as `SPI_DEV(1)`
- Only provide `SPI_DEV(1)` if the ADC is not in used to resolve a
pin conflict
- Move PB0 and PB1 at the end of the ADC lines (previously
`ADC_LINE(6)` and `ADC_LINE(7)`, now `ADC_LINE(8)` and `ADC_LINE(9)`)
- Only provide them when PWM is not in use (to resolve pin conflict
with PWM)
- Also do not provide them for the Blackpill boards, which are
missing pins PB0 and PB1 on the headers
To make life of users easier, a Pinout diagram with the new
configuration was added.
2022-10-21 18:27:54 +02:00
|
|
|
## Pinout
|
|
|
|
|
|
|
|
![pinout](pinouts/pinout-bluepill.svg)
|
2019-09-04 14:58:32 +02:00
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
## MCU
|
2019-09-04 14:58:32 +02:00
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
| MCU | STM32F103C8 / STM32F103CB |
|
2019-09-04 14:58:32 +02:00
|
|
|
|:----------|:--------------------------|
|
|
|
|
| Family | ARM Cortex-M3 |
|
|
|
|
| Vendor | STMicroelectronics |
|
|
|
|
| RAM | 20 KiB |
|
2022-09-13 21:16:44 +02:00
|
|
|
| Flash | 32 KiB / 64 KiB / 128 KiB |
|
2019-09-04 14:58:32 +02:00
|
|
|
| Frequency | up to 72 MHz |
|
|
|
|
| Timer | 3x 16-Bit |
|
|
|
|
| ADC | 2x 12-bit, 10 channels |
|
|
|
|
| UART | 3 |
|
|
|
|
| SPI | 2 |
|
|
|
|
| I2C | 2 |
|
|
|
|
| CAN | 1 |
|
|
|
|
| Vcc | 2.0 to 3.6 V |
|
|
|
|
| Datasheet | [Datasheet][Datasheet] |
|
|
|
|
|
|
|
|
## Implementation Status
|
|
|
|
|
|
|
|
| ID | Supported |
|
|
|
|
|:----- |:--------- |
|
|
|
|
| GPIO | yes |
|
|
|
|
| PWM | yes |
|
|
|
|
| UART | yes |
|
|
|
|
| ADC | yes |
|
|
|
|
| I2C | yes |
|
|
|
|
| SPI | yes |
|
|
|
|
| USB | no |
|
|
|
|
| Timer | yes |
|
|
|
|
| CAN | no |
|
|
|
|
|
|
|
|
|
|
|
|
## Flashing
|
|
|
|
|
|
|
|
To program and debug the board you need a SWD capable debugger. The
|
|
|
|
easiest way is using [OpenOCD][OpenOCD]. By default RIOT uses the hardware
|
|
|
|
reset signal and connects to the chip under reset for flashing. This is
|
|
|
|
required to reliably connect to the device even when the MCU is in a low power
|
|
|
|
mode. Therefore not only SWDIO and SWCLK, but also the RST pin of your
|
|
|
|
debugger need to be connected to the board. Once the device is connected to
|
|
|
|
the debugger and OpenOCD is installed, you can flash the device with:
|
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
$ make BOARD=bluepill-stm32f103c8 flash
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
Or for the blackpill with:
|
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
$ make BOARD=blackpill-stm32f103c8 flash
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
### Additional Flash
|
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
Typically, the STM32F103C8 does actually have 128 KiB flash. To make use of
|
|
|
|
this, just flash with
|
2019-09-04 14:58:32 +02:00
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
$ make BOARD=bluepill-stm32f103cb flash
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
Or for the blackpill with:
|
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
$ make BOARD=blackpill-stm32f103cb flash
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
This sets the `CPU_MODEL` make variable to `stm32f103cb`, the default
|
|
|
|
value is `stm32f103c8`. These two CPU models basically only have one
|
|
|
|
major difference, the former has 128 KiB flash while the latter has 64
|
|
|
|
KiB.
|
|
|
|
|
2022-09-13 21:16:44 +02:00
|
|
|
In order to flash the *cb variant onto *c8 hardware requires OpenOCD in version
|
|
|
|
0.11 or later.
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
## Connecting via Serial
|
|
|
|
|
2022-08-12 17:09:21 +02:00
|
|
|
The default UART port used is UART1, which uses pins A9 (TX) and A10 (RX).
|
|
|
|
To use it, configure your UART to operate at a symbol rate of 115200 baud,
|
|
|
|
1 stop bit and no parity (8N1).
|
2019-09-04 14:58:32 +02:00
|
|
|
|
|
|
|
## Using PWM
|
|
|
|
|
|
|
|
PWM is available at pins A8 to A11.
|
|
|
|
|
|
|
|
## Known Issues
|
|
|
|
|
|
|
|
### USB connector
|
|
|
|
|
|
|
|
The Micro-USB port is sometimes not soldered properly. Also, it is
|
|
|
|
usually equipped with an incorrect resistor. [This can be fixed multiple
|
|
|
|
ways][USB].
|
|
|
|
|
|
|
|
### Flashing fails
|
|
|
|
|
|
|
|
Please check whether the debugger is properly connected, including the hardware
|
|
|
|
reset signal pin.
|
|
|
|
|
|
|
|
| Pin on Debugger | Pin on Blue Pill |
|
|
|
|
|:------------------ |:---------------- |
|
|
|
|
| SWDIO | DIO |
|
|
|
|
| SWCLK | DCLK |
|
|
|
|
| NRST | R |
|
|
|
|
| GND | GND |
|
|
|
|
| VDD (3.3V) (*) | 3.3 |
|
|
|
|
| Target VCC (**) | 3.3 |
|
|
|
|
|
|
|
|
- (*) Most debuggers have a 3.3V supply voltage to power the board. You can
|
|
|
|
alternatively power the board using the TTL-Adapter or via Micro-USB.
|
|
|
|
- (**) Some debuggers monitor the voltage of the target MCU. Their target VCC
|
|
|
|
pin needs to be connected to one of the 3.3V pins of the boards.
|
|
|
|
|
|
|
|
Most very cheap SWD debuggers (especially those imported for about 2€ from far
|
|
|
|
east) do not have a Target VCC pin; they will still work just fine. On these
|
|
|
|
cheap debuggers the pin to send the reset signal to the board is often either
|
|
|
|
not present or defunct. You can work around this by pressing the reset button
|
|
|
|
when OpenOCD wants to connect to the Blue Pill. Hit the reset button again after
|
|
|
|
flashing in order to boot the newly flashed image.
|
|
|
|
|
|
|
|
## Where to buy
|
|
|
|
|
|
|
|
The board is sold under different names. On some sites it is called
|
|
|
|
`bluepill` or `blue pill`. On others you might find it by searching for
|
|
|
|
`stm32f103c8` or `stm32f103c8t6`.
|
|
|
|
|
|
|
|
Try [eBay][eBay] or [AliExpress][AliExpress].
|
|
|
|
|
|
|
|
## Further reading
|
|
|
|
|
2020-03-04 13:28:20 +01:00
|
|
|
- [Blue Pill Wiki](https://web.archive.org/web/20190428082446/http://wiki.stm32duino.com/index.php?title=Blue_Pill)
|
|
|
|
- [Maple Mini Wiki](https://web.archive.org/web/20190428082446/http://wiki.stm32duino.com/index.php?title=Maple_Mini#Clones)
|
|
|
|
- [STM32F103C8 Datasheet](http://www.st.com/content/st_com/en/products/microcontrollers/stm32-32-bit-arm-cortex-mcus/stm32-mainstream-mcus/stm32f1-series/stm32f103/stm32f103c8.html)
|
2019-09-04 14:58:32 +02:00
|
|
|
|
2020-03-04 13:28:20 +01:00
|
|
|
[Datasheet]: http://www.st.com/content/ccc/resource/technical/document/datasheet/33/d4/6f/1d/df/0b/4c/6d/CD00161566.pdf/files/CD00161566.pdf/jcr:content/translations/en.CD00161566.pdf
|
2019-09-04 14:58:32 +02:00
|
|
|
[Flashsize]:
|
2019-12-28 06:32:06 +01:00
|
|
|
https://web.archive.org/web/20190428082446/http://wiki.stm32duino.com/index.php?title=Blue_Pill#128_KB_flash_on_C8_version
|
2019-09-04 14:58:32 +02:00
|
|
|
[eBay]: https://www.ebay.com/sch/i.html?_nkw=stm32f103c8
|
|
|
|
[AliExpress]: https://www.aliexpress.com/wholesale?SearchText=STM32F103C8T6
|
|
|
|
[OpenOCD]: https://github.com/RIOT-OS/RIOT/wiki/OpenOCD
|
|
|
|
[USB]:
|
2019-12-28 06:32:06 +01:00
|
|
|
https://web.archive.org/web/20190428082446/http://wiki.stm32duino.com/index.php?title=Blue_Pill#Hardware_installation
|
2019-09-04 14:58:32 +02:00
|
|
|
[imgTop]:
|
2020-03-04 13:28:20 +01:00
|
|
|
https://web.archive.org/web/20190428082446/http://wiki.stm32duino.com/images/thumb/1/19/STM32_Blue_Pill_top.jpg/800px-STM32_Blue_Pill_top.jpg
|
2019-09-04 14:58:32 +02:00
|
|
|
*/
|