.. _black_f407ve_board: Black STM32 F407VE Development Board #################################### Overview ******** The BLACK_F407VE board features an ARM Cortex-M4 based STM32F407xx MCU with a wide range of connectivity support and configurations. There are multiple version of this board like ``black_f407ve``. Here are some highlights of the BLACK_F407VE board: - STM32 microcontroller in LQFP100 package - Extension header for all LQFP100 I/Os for quick connection to prototyping board and easy probing - Flexible board power supply: - USB VBUS or external source (3.3V, 5V) - Power management access point - Three LEDs: - 3.3 V power on (LD0) - Two user LEDs: green (LD1), green (LD2) - Four push-buttons: RESET, K0, K1 and WK_UP - Mini-AB connector .. image:: img/black_f407ve.jpg :align: center :alt: BLACK_F407VE See also board descriptions at `STM32-base website`_, `STM32F407VET6 black board`_ and `MCUDev Black STM32F407VET6`_ .. warning:: The +5V pins on this board are directly connected to the +5V pin of the USB connector. There is no protection in place. Do not power this board through USB and an external power supply at the same time. Hardware ******** BLACK_F407VE board provides the following hardware components: - STM32F407VET6 in LQFP100 package - ARM |reg| 32-bit Cortex |reg| -M4 CPU with FPU - 168 MHz max CPU frequency - VDD from 1.8 V to 3.6 V - 8MHz system crystal - 32.768KHz RTC crystal - JTAG/SWD header - 512 kB Flash - 192+4 KB SRAM including 64-Kbyte of core coupled memory - GPIO with external interrupt capability - 3x12-bit ADC with 24 channels - 2x12-bit D/A converters - RTC battery CR1220 - Advanced-control Timer (2) - General Purpose Timers (12) - Watchdog Timers (2) - USART (3), UART (2) - I2C (3) - I2S (2) - SPI (3) - SDIO (1) - CAN (2) - USB 2.0 OTG FS with on-chip PHY - USB 2.0 OTG HS/FS with dedicated DMA, on-chip full-speed PHY and ULPI - 10/100 Ethernet MAC with dedicated DMA - CRC calculation unit - True random number generator - DMA Controller - Micro SD - 1x 10/100 Ethernet MAC - 1x 8 to 12-bit Parallel Camera interface - Micro USB for power and comms - 2x jumpers for bootloader selection - 2x16 FMSC LCD Interface - NRF24L01 socket - Dimensions: 85.1mm x 72.45mm More information about STM32F407VE SOC can be found here: - `STM32F407VE on www.st.com`_ Supported Features ================== The Zephyr black_f407ve board configuration supports the following hardware features: +-----------+------------+-------------------------------------+ | Interface | Controller | Driver/Component | +===========+============+=====================================+ | NVIC | on-chip | nested vector interrupt controller | +-----------+------------+-------------------------------------+ | UART | on-chip | serial port-polling; | | | | serial port-interrupt | +-----------+------------+-------------------------------------+ | PINMUX | on-chip | pinmux | +-----------+------------+-------------------------------------+ | GPIO | on-chip | gpio | +-----------+------------+-------------------------------------+ | PWM | on-chip | pwm | +-----------+------------+-------------------------------------+ | USB | on-chip | usb | +-----------+------------+-------------------------------------+ | CAN | on-chip | CAN controller | +-----------+------------+-------------------------------------+ | SPI | on-chip | spi | +-----------+------------+-------------------------------------+ .. note:: CAN feature requires CAN transceiver. Zephyr default configuration uses CAN_2 exclusively, as simultaneous use of CAN_1 and CAN_2 is not yet supported. Other hardware features are not yet supported on Zephyr porting. The default configuration can be found in :zephyr_file:`boards/others/black_f407ve/black_f407ve_defconfig` Pin Mapping =========== BLACK_F407VE has 5 GPIO controllers. These controllers are responsible for pin muxing, input/output, pull-up, etc. .. image:: img/stm32f407vet6_left02.jpg :align: center :alt: left pins .. image:: img/stm32f407vet6_right01.jpg :align: center :alt: right pins .. image:: img/stm32f407vet6_st-link02.jpg :align: center :alt: bottom and top pins Default Zephyr Peripheral Mapping: ---------------------------------- .. rst-class:: rst-columns - UART_1_TX : PA9 - UART_1_RX : PA10 - UART_2_TX : PA2 - UART_2_RX : PA3 - USER_PB : PA0 - LD3 : PD13 - LD4 : PD12 - LD5 : PD14 - LD6 : PD15 - USB DM : PA11 - USB DP : PA12 - CAN1_RX : PD0 - CAN1_TX : PD1 - CAN2_RX : PB12 - CAN2_TX : PB13 - SPI1 MISO : PB4 - SPI1 MOSI : PB5 - SPI1 SCK : PB3 - SPI1 Flash CS : PB0 - SPI2 MISO : PC2 - SPI2 MOSI : PC3 - SPI2 SCK : PB10 System Clock ============ BLACK_F407VE System Clock could be driven by internal or external oscillator, as well as main PLL clock. By default System clock is driven by PLL clock at 168MHz, driven by 8MHz high speed external clock. Serial Port =========== BLACK_F407VE has up to 6 UARTs. The Zephyr console output is assigned to UART1. Default settings are 115200 8N1. Please note that ST-Link Virtual Com Port is not wired to chip serial port. In order to enable console output you should use a serial cable and connect it to UART1 pins (PA9/PA10). Programming and Debugging ************************* Applications for the ``black_f407ve`` board configuration can be built and flashed in the usual way (see :ref:`build_an_application` and :ref:`application_run` for more details). Flashing ======== BLACK_F407VE board includes an ST-LINK/V2 embedded debug tool interface. This interface is supported by the openocd version included in Zephyr SDK. Flashing an application to BLACK_F407VE --------------------------------------- Here is an example for the :zephyr:code-sample:`blinky` application. Run a serial host program to connect with your board: .. code-block:: console $ minicom -D /dev/ttyACM0 Build and flash the application: .. zephyr-app-commands:: :zephyr-app: samples/basic/blinky :board: black_f407ve :goals: build flash You should see user led "LD1" blinking. Debugging ========= You can debug an application in the usual way. Here is an example for the :ref:`hello_world` application. .. zephyr-app-commands:: :zephyr-app: samples/hello_world :board: black_f407ve :maybe-skip-config: :goals: debug .. _STM32-base website: https://stm32-base.org/boards/STM32F407VET6-STM32-F4VE-V2.0.html .. _STM32F407VE on www.st.com: https://www.st.com/en/microcontrollers/stm32f407ve.html .. _STM32F407VET6 black board: https://os.mbed.com/users/hudakz/code/STM32F407VET6_Hello/ .. _MCUDev Black STM32F407VET6: https://github.com/mcauser/BLACK_F407VE