2016-05-12 17:56:32 +02:00
|
|
|
|
README
|
|
|
|
|
======
|
|
|
|
|
|
2016-05-19 18:03:51 +02:00
|
|
|
|
This README discusses issues unique to NuttX configurations for the STMicro
|
|
|
|
|
Nucleo-144 board. See
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-19 18:03:51 +02:00
|
|
|
|
http://www.st.com/content/ccc/resource/technical/document/data_brief/group0/7b/df/1d/e9/64/55/43/8d/DM00247910/files/DM00247910.pdf/jcr:content/translations/en.DM00247910.pdf
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-05-19 18:20:40 +02:00
|
|
|
|
Contents
|
|
|
|
|
========
|
|
|
|
|
|
|
|
|
|
- Nucleo-144 Boards
|
|
|
|
|
- Nucleo F746ZG
|
2016-06-08 15:52:19 +02:00
|
|
|
|
- Nucleo F767ZI
|
2016-05-19 18:20:40 +02:00
|
|
|
|
- Development Environment
|
|
|
|
|
- IDEs
|
|
|
|
|
- Basic configuaration & build steps
|
|
|
|
|
- Hardware
|
|
|
|
|
- Button
|
|
|
|
|
- LED
|
|
|
|
|
- U[S]ARTs and Serial Consoles
|
2016-06-08 15:52:19 +02:00
|
|
|
|
- SPI
|
|
|
|
|
- SDIO - MMC
|
2016-06-14 15:30:28 +02:00
|
|
|
|
- SPI Test
|
2016-05-19 18:20:40 +02:00
|
|
|
|
- Configurations
|
2016-06-08 15:52:19 +02:00
|
|
|
|
f7xx-nsh
|
|
|
|
|
f7xx-evalos
|
2016-05-19 18:20:40 +02:00
|
|
|
|
|
|
|
|
|
Nucleo-144 Boards:
|
|
|
|
|
=================
|
|
|
|
|
|
2016-05-19 18:03:51 +02:00
|
|
|
|
The Nucleo-144 is a standard board for use with several STM32 parts in the
|
|
|
|
|
LQFP144 package. Variants include
|
|
|
|
|
|
|
|
|
|
STM32 Part Board Variant Name
|
|
|
|
|
------------- ------------------
|
|
|
|
|
STM32F207ZGT6 NUCLEO-F207ZG
|
|
|
|
|
STM32F303ZET6 NUCLEO-F303ZE
|
|
|
|
|
STM32F429ZIT6 NUCLEO-F429ZI
|
|
|
|
|
STM32F446ZET6 NUCLEO-F446ZE
|
|
|
|
|
STM32F746ZGT6 NUCLEO-F746ZG
|
|
|
|
|
STM32F767ZIT6 NUCLEO-F767ZI
|
|
|
|
|
------------- ------------------
|
|
|
|
|
|
|
|
|
|
This directory is intended to support all Nucleo-144 variants since the
|
|
|
|
|
boards are identical, differing only in the installed part. This common
|
|
|
|
|
board design provides uniformity in the documentation from ST and should
|
|
|
|
|
allow us to quickly change configurations by just cloning a configuration
|
|
|
|
|
and changing the CPU choice and board initialization. Unfortunately for
|
|
|
|
|
the developer, the CPU specific information must be extracted from the
|
|
|
|
|
common information in the documentation.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Please read the User Manaul UM1727: Getting started with STM32 Nucleo board
|
|
|
|
|
software development tools and take note of the Powering options for the
|
|
|
|
|
board (6.3 Power supply and power selection) and the Solder bridges based
|
|
|
|
|
hardware configuration changes that are configurable (6.11 Solder bridges).
|
|
|
|
|
|
2016-05-19 18:20:40 +02:00
|
|
|
|
Common Board Features:
|
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
|
|
Peripherals: 8 leds, 2 push button (3 LEDs, 1 button) under software
|
|
|
|
|
control
|
|
|
|
|
Debug: STLINK/V2-1 debugger/programmer Uses a STM32F103CB to
|
|
|
|
|
provide a ST-Link for programming, debug similar to the
|
|
|
|
|
OpenOcd FTDI function - USB to JTAG front-end.
|
|
|
|
|
|
2016-05-19 22:09:00 +02:00
|
|
|
|
Expansion I/F: ST Zio and Extended Ardino and Morpho Headers
|
2016-05-19 18:20:40 +02:00
|
|
|
|
|
|
|
|
|
Nucleo F746ZG
|
|
|
|
|
=============
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
ST Nucleo F746ZG board from ST Micro is supported. See
|
2016-05-19 18:03:51 +02:00
|
|
|
|
|
|
|
|
|
http://www.st.com/content/st_com/en/products/evaluation-tools/product-evaluation-tools/mcu-eval-tools/stm32-mcu-eval-tools/stm32-mcu-nucleo/nucleo-f746zg.html
|
|
|
|
|
|
|
|
|
|
The Nucleo F746ZG order part number is NUCLEO-F746ZG. It is one member of
|
|
|
|
|
the STM32 Nucleo-144 board family.
|
|
|
|
|
|
2016-05-19 18:20:40 +02:00
|
|
|
|
NUCLEO-F746ZG Features:
|
|
|
|
|
----------------------
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Microprocessor: STM32F746ZGT6 Core: ARM 32-bit Cortex®-M7 CPU with FPU,
|
|
|
|
|
L1-cache: 4KB data cache and 4KB instruction cache, up to
|
|
|
|
|
216 MHz, MPU, and DSP instructions.
|
|
|
|
|
Memory: 1024 KB Flash 320KB of SRAM (including 64KB of data TCM RAM)
|
|
|
|
|
+ 16KB of instruction TCM RAM + 4KB of backup SRAM
|
2016-05-12 20:26:56 +02:00
|
|
|
|
ADC: 3×12-bit, 2.4 MSPS ADC: up to 24 channels and 7.2 MSPS in
|
2016-05-12 17:56:32 +02:00
|
|
|
|
triple interleaved mode
|
2016-06-08 15:52:19 +02:00
|
|
|
|
DMA: 2 X 16-stream DMA controllers with FIFOs and burst support
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Timers: Up to 18 timers: up to thirteen 16-bit (1x 16-bit lowpower),
|
|
|
|
|
two 32-bit timers, 2x watchdogs, SysTick
|
|
|
|
|
GPIO: 114 I/O ports with interrupt capability
|
2016-05-12 20:26:56 +02:00
|
|
|
|
LCD: LCD-TFT Controllerwith (DMA2D), Parallel interface
|
2016-05-12 17:56:32 +02:00
|
|
|
|
I2C: 4 × I2C interfaces (SMBus/PMBus)
|
|
|
|
|
U[S]ARTs: 4 USARTs, 4 UARTs (27 Mbit/s, ISO7816 interface, LIN, IrDA,
|
|
|
|
|
modem control)
|
2016-05-12 20:26:56 +02:00
|
|
|
|
SPI/12Ss: 6/3 (simplex) (up to 50 Mbit/s), 3 with muxed simplex I2S
|
|
|
|
|
for audio class accuracy via internal audio PLL or external
|
2016-05-12 17:56:32 +02:00
|
|
|
|
clock
|
|
|
|
|
QSPI: Dual mode Quad-SPI
|
|
|
|
|
SAIs: 2 Serial Audio Interfaces
|
2016-05-19 18:20:40 +02:00
|
|
|
|
CAN: 2 X CAN interface
|
2016-05-12 17:56:32 +02:00
|
|
|
|
SDMMC interface
|
|
|
|
|
SPDIFRX interface
|
2016-05-12 20:26:56 +02:00
|
|
|
|
USB: USB 2.0 full-speed device/host/OTG controller with on-chip
|
2016-05-12 17:56:32 +02:00
|
|
|
|
PHY
|
2016-05-12 20:26:56 +02:00
|
|
|
|
10/100 Ethernet: MAC with dedicated DMA: supports IEEE 1588v2 hardware,
|
2016-05-19 18:20:40 +02:00
|
|
|
|
MII/RMII
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Camera Interface: 8/14 Bit
|
|
|
|
|
CRC calculation unit
|
|
|
|
|
TRG: True random number generator
|
|
|
|
|
RTC
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
See https://developer.mbed.org/platforms/ST-Nucleo-F746ZG for additional
|
2016-05-19 18:03:51 +02:00
|
|
|
|
information about this board.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
Nucleo F767ZI
|
|
|
|
|
=============
|
|
|
|
|
|
|
|
|
|
ST Nucleo F7467ZI board from ST Micro is supported. See
|
|
|
|
|
|
|
|
|
|
http://www.st.com/content/st_com/en/products/evaluation-tools/product-evaluation-tools/mcu-eval-tools/stm32-mcu-eval-tools/stm32-mcu-nucleo/nucleo-f767zi.html
|
|
|
|
|
|
|
|
|
|
The Nucleo F767ZI order part number is NUCLEO-F767ZI. It is one member of
|
|
|
|
|
the STM32 Nucleo-144 board family.
|
|
|
|
|
|
|
|
|
|
NUCLEO-F767ZI Features:
|
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
|
|
Microprocessor: STM32F767ZIT6 Core: ARM 32-bit Cortex®-M7 CPU with DPFPU,
|
|
|
|
|
L1-cache: 16KB data cache and 16KB instruction cache, up to
|
|
|
|
|
216 MHz, MPU, and DSP instructions.
|
|
|
|
|
Memory: 2048 KB Flash 512KB of SRAM (including 128KB of data TCM RAM)
|
|
|
|
|
+ 16KB of instruction TCM RAM + 4KB of backup SRAM
|
|
|
|
|
ADC: 3×12-bit, 2.4 MSPS ADC: up to 24 channels and 7.2 MSPS in
|
|
|
|
|
triple interleaved mode
|
|
|
|
|
DMA: 2 X 16-stream DMA controllers with FIFOs and burst support
|
|
|
|
|
Timers: Up to 18 timers: up to thirteen 16-bit (1x 16-bit lowpower),
|
|
|
|
|
two 32-bit timers, 2x watchdogs, SysTick
|
|
|
|
|
GPIO: 114 I/O ports with interrupt capability
|
|
|
|
|
LCD: LCD-TFT Controllerwith (DMA2D), Parallel interface
|
|
|
|
|
I2C: 4 × I2C interfaces (SMBus/PMBus)
|
|
|
|
|
U[S]ARTs: 4 USARTs, 4 UARTs (27 Mbit/s, ISO7816 interface, LIN, IrDA,
|
|
|
|
|
modem control)
|
|
|
|
|
SPI/12Ss: 6/3 (simplex) (up to 50 Mbit/s), 3 with muxed simplex I2S
|
|
|
|
|
for audio class accuracy via internal audio PLL or external
|
|
|
|
|
clock
|
|
|
|
|
QSPI: Dual mode Quad-SPI
|
|
|
|
|
SAIs: 2 Serial Audio Interfaces
|
|
|
|
|
CAN: 3 X CAN interface
|
|
|
|
|
SDMMC interface
|
|
|
|
|
SPDIFRX interface
|
|
|
|
|
USB: USB 2.0 full/High-speed device/host/OTG controller with on-chip
|
|
|
|
|
PHY
|
|
|
|
|
10/100 Ethernet: MAC with dedicated DMA: supports IEEE 1588v2 hardware,
|
|
|
|
|
MII/RMII
|
|
|
|
|
Camera Interface: 8/14 Bit
|
|
|
|
|
CRC calculation unit
|
|
|
|
|
TRG: True random number generator
|
|
|
|
|
RTC subsecond accuracy, hardware calendar
|
|
|
|
|
|
|
|
|
|
As of this writting the NUCLEO-F767ZI is not available on developer.mbed.org
|
|
|
|
|
However, See https://developer.mbed.org/platforms/ST-Nucleo-F746ZG for additional
|
|
|
|
|
useful information.
|
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Development Environment
|
|
|
|
|
=======================
|
|
|
|
|
|
|
|
|
|
Either Linux or Cygwin on Windows can be used for the development environment.
|
|
|
|
|
The source has been built only using the GNU toolchain (see below). Other
|
|
|
|
|
toolchains will likely cause problems.
|
|
|
|
|
|
|
|
|
|
All testing has been conducted using the GNU toolchain from ARM for Linux.
|
|
|
|
|
found here https://launchpad.net/gcc-arm-embedded/4.9/4.9-2015-q3-update/+download/gcc-arm-none-eabi-4_9-2015q3-20150921-linux.tar.bz2
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2017-04-26 18:28:37 +02:00
|
|
|
|
If you change the default toolchain, then you may also have to modify the
|
|
|
|
|
PATH environment variable to include the path to the toolchain binaries.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
IDEs
|
|
|
|
|
====
|
|
|
|
|
|
|
|
|
|
NuttX is built using command-line make. It can be used with an IDE, but some
|
|
|
|
|
effort will be required to create the project.
|
|
|
|
|
|
|
|
|
|
Makefile Build
|
|
|
|
|
--------------
|
|
|
|
|
Under Eclipse, it is pretty easy to set up an "empty makefile project" and
|
|
|
|
|
simply use the NuttX makefile to build the system. That is almost for free
|
|
|
|
|
under Linux. Under Windows, you will need to set up the "Cygwin GCC" empty
|
|
|
|
|
makefile project in order to work with Windows (Google for "Eclipse Cygwin" -
|
|
|
|
|
there is a lot of help on the internet).
|
|
|
|
|
|
|
|
|
|
Basic configuration & build steps
|
|
|
|
|
==================================
|
|
|
|
|
|
2017-04-26 18:12:13 +02:00
|
|
|
|
A GNU GCC-based toolchain is assumed. The PATH environment variable should
|
2016-05-12 17:56:32 +02:00
|
|
|
|
be modified to point to the correct path to the Cortex-M7 GCC toolchain (if
|
|
|
|
|
different from the default in your PATH variable).
|
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
- Configures nuttx creating .config file in the nuttx directory.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
$ cd tools && ./configure.sh nucleo-f746zg/nsh && cd ..
|
2016-05-20 14:55:30 +02:00
|
|
|
|
- Refreshes the .config file with the latest available configurations.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
$ make oldconfig
|
|
|
|
|
- Select the features you want in the build.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
$ make menuconfig
|
|
|
|
|
- Builds Nuttx with the features you selected.
|
|
|
|
|
$ make
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Hardware
|
|
|
|
|
========
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
GPIO - there are 144 I/O lines on the STM32F7xxZxT6 with various pins pined out
|
|
|
|
|
on the Nucleo 144.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
See https://developer.mbed.org/platforms/ST-Nucleo-F746ZG/ for slick graphic
|
|
|
|
|
pinouts.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Keep in mind that:
|
|
|
|
|
1) The I/O is 3.3 Volt not 5 Volt like on the Arduino products.
|
|
|
|
|
2) The Nucleo-144 board family has 3 pages of Solder Bridges AKA Solder
|
|
|
|
|
Blobs (SB) that can alter the factory configuration. We will note SB
|
|
|
|
|
in effect but will assume the facitory defualt settings.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Our main concern is establishing a console and LED utilization for
|
|
|
|
|
debugging. Because so many pins can be multiplexed with so many functions,
|
2016-06-08 15:52:19 +02:00
|
|
|
|
the above mentioned graphic may be helpful in indentifying a serial port.
|
|
|
|
|
|
|
|
|
|
There are 4 choices that can be made from the menuconfig:
|
|
|
|
|
|
|
|
|
|
CONFIG_NUCLEO_CONSOLE_ARDUINO or CONFIG_NUCLEO_CONSOLE_MORPHO or
|
|
|
|
|
CONFIG_NUCLEO_CONSOLE_VIRTUAL or CONFIG_NUCLEO_CONSOLE_NONE
|
|
|
|
|
|
|
|
|
|
The CONFIG_NUCLEO_CONSOLE_NONE makes no preset for the console. YOu shuld still visit
|
|
|
|
|
the U[S]ART selection and Device Drivers to disable any U[S]ART reamaing.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
The CONFIG_NUCLEO_CONSOLE_ARDUINO configurations assume that you are using a
|
|
|
|
|
standard Arduio RS-232 shield with the serial interface with RX on pin D0 and
|
|
|
|
|
TX on pin D1 from USART6:
|
|
|
|
|
|
|
|
|
|
-------- ---------------
|
|
|
|
|
STM32F7
|
|
|
|
|
ARDUIONO FUNCTION GPIO
|
|
|
|
|
-- ----- --------- -----
|
|
|
|
|
DO RX USART6_RX PG9
|
|
|
|
|
D1 TX USART6_TX PG14
|
|
|
|
|
-- ----- --------- -----
|
|
|
|
|
|
|
|
|
|
The CONFIG_NUCLEO_CONSOLE_MORPHO configurations uses Serial Port 8 (USART8)
|
|
|
|
|
with TX on PE1 and RX on PE0.
|
|
|
|
|
Serial
|
|
|
|
|
------
|
|
|
|
|
SERIAL_RX PE_0
|
|
|
|
|
SERIAL_TX PE_1
|
|
|
|
|
|
|
|
|
|
The CONFIG_NUCLEO_CONSOLE_VIRTUAL configurations uses Serial Port 3 (USART3)
|
|
|
|
|
with TX on PD8 and RX on PD9.
|
|
|
|
|
Serial
|
|
|
|
|
------
|
|
|
|
|
SERIAL_RX PD9
|
|
|
|
|
SERIAL_TX PD8
|
|
|
|
|
|
|
|
|
|
These signals are internalaly connected to the on board ST-Link
|
|
|
|
|
|
|
|
|
|
Of course if your design has used those pins you can choose a completely
|
|
|
|
|
different U[S]ART to use as the console. In that Case, you will need to edit
|
|
|
|
|
the include/board.h to select different U[S]ART and / or pin selections.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Buttons
|
|
|
|
|
-------
|
|
|
|
|
B1 USER: the user button is connected to the I/O PC13 (Tamper support, SB173
|
2016-05-12 20:26:56 +02:00
|
|
|
|
ON and SB180 OFF)
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
LEDs
|
|
|
|
|
----
|
|
|
|
|
The Board provides a 3 user LEDs, LD1-LD3
|
2016-05-12 20:26:56 +02:00
|
|
|
|
LED1 (Green) PB_0 (SB120 ON and SB119 OFF)
|
2016-05-12 17:56:32 +02:00
|
|
|
|
LED2 (Blue) PB_7 (SB139 ON)
|
|
|
|
|
LED3 (Red) PB_14 (SP118 ON)
|
|
|
|
|
|
|
|
|
|
- When the I/O is HIGH value, the LEDs are on.
|
|
|
|
|
- When the I/O is LOW, the LEDs are off.
|
|
|
|
|
|
|
|
|
|
These LEDs are not used by the board port unless CONFIG_ARCH_LEDS is
|
|
|
|
|
defined. In that case, the usage by the board port is defined in
|
|
|
|
|
include/board.h and src/stm32_autoleds.c. The LEDs are used to encode OS
|
|
|
|
|
related events as follows when the LEDs are available:
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
SYMBOL Meaning RED GREEN BLUE
|
|
|
|
|
------------------- ----------------------- --- ----- ----
|
|
|
|
|
|
|
|
|
|
LED_STARTED NuttX has been started OFF OFF OFF
|
|
|
|
|
LED_HEAPALLOCATE Heap has been allocated OFF OFF ON
|
|
|
|
|
LED_IRQSENABLED Interrupts enabled OFF ON OFF
|
|
|
|
|
LED_STACKCREATED Idle stack created OFF ON ON
|
|
|
|
|
LED_INIRQ In an interrupt NC NC ON (momentary)
|
|
|
|
|
LED_SIGNAL In a signal handler NC ON OFF (momentary)
|
|
|
|
|
LED_ASSERTION An assertion failed ON NC ON (momentary)
|
|
|
|
|
LED_PANIC The system has crashed ON OFF OFF (flashing 2Hz)
|
|
|
|
|
LED_IDLE MCU is is sleep mode ON OFF OFF
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
OFF - means that the OS is still initializing. Initialization is very fast
|
|
|
|
|
so if you see this at all, it probably means that the system is
|
|
|
|
|
hanging up somewhere in the initialization phases.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
GREEN - This means that the OS completed initialization.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
BLUE - Whenever and interrupt or signal handler is entered, the BLUE LED is
|
|
|
|
|
illuminated and extinguished when the interrupt or signal handler
|
|
|
|
|
exits.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
VIOLET - If a recovered assertion occurs, the RED and blue LED will be
|
|
|
|
|
illuminated briefly while the assertion is handled. You will
|
|
|
|
|
probably never see this.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
|
|
|
|
Flashing RED - In the event of a fatal crash, all other LEDs will be
|
2016-06-08 15:52:19 +02:00
|
|
|
|
extinguished and RED LED will FLASH at a 2Hz rate.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
|
|
|
|
Thus if the GREEN LED is lit, NuttX has successfully booted and is,
|
|
|
|
|
apparently, running normally. If the RED LED is flashing at
|
2016-05-12 17:56:32 +02:00
|
|
|
|
approximately 2Hz, then a fatal error has been detected and the system has
|
|
|
|
|
halted.
|
|
|
|
|
|
|
|
|
|
Serial Consoles
|
|
|
|
|
===============
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
USART6 (CONFIG_NUCLEO_CONSOLE_ARDUINO)
|
2016-05-12 17:56:32 +02:00
|
|
|
|
------
|
2016-06-08 15:52:19 +02:00
|
|
|
|
STM32F7
|
|
|
|
|
ARDUIONO FUNCTION GPIO
|
|
|
|
|
-- ----- --------- -----
|
|
|
|
|
DO RX USART6_RX PG9
|
|
|
|
|
D1 TX USART6_TX PG14
|
|
|
|
|
-- ----- --------- -----
|
|
|
|
|
|
|
|
|
|
You must use a 3.3 TTL to RS-232 converter or a USB to 3.3V TTL
|
|
|
|
|
|
|
|
|
|
Nucleo 144 FTDI TTL-232R-3V3
|
|
|
|
|
------------- -------------------
|
|
|
|
|
TXD - D1-TXD - RXD - Pin 5 (Yellow)
|
|
|
|
|
RXD - D0-RXD - TXD - Pin 4 (Orange)
|
|
|
|
|
GND GND - GND Pin 1 (Black)
|
|
|
|
|
------------- -------------------
|
|
|
|
|
|
|
|
|
|
*Note you will be reverse RX/TX
|
|
|
|
|
|
|
|
|
|
Use make menuconfig to configure USART6 as the console:
|
|
|
|
|
|
|
|
|
|
CONFIG_STM32F7_USART6=y
|
|
|
|
|
CONFIG_USARTs_SERIALDRIVER=y
|
|
|
|
|
CONFIG_USARTS_SERIAL_CONSOLE=y
|
|
|
|
|
CONFIG_USART6_RXBUFSIZE=256
|
|
|
|
|
CONFIG_USART6_TXBUFSIZE=256
|
|
|
|
|
CONFIG_USART6_BAUD=115200
|
|
|
|
|
CONFIG_USART6_BITS=8
|
|
|
|
|
CONFIG_USART6_PARITY=0
|
|
|
|
|
CONFIG_USART6_2STOP=0
|
|
|
|
|
|
|
|
|
|
USART8 (CONFIG_NUCLEO_CONSOLE_MORPHO)
|
|
|
|
|
------
|
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Pins and Connectors:
|
2016-06-08 15:52:19 +02:00
|
|
|
|
FUNC GPIO Connector
|
|
|
|
|
Pin NAME
|
|
|
|
|
---- --- ------- ----
|
|
|
|
|
TXD: PE1 CN11-61, PE1
|
|
|
|
|
RXD: PE0 CN12-64, PE0
|
|
|
|
|
CN10-33, D34
|
|
|
|
|
---- --- ------- ----
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
You must use a 3.3 TTL to RS-232 converter or a USB to 3.3V TTL
|
|
|
|
|
|
2016-05-12 20:26:56 +02:00
|
|
|
|
Nucleo 144 FTDI TTL-232R-3V3
|
2016-06-08 15:52:19 +02:00
|
|
|
|
------------- -------------------
|
|
|
|
|
TXD - CN11-61 - RXD - Pin 5 (Yellow)
|
|
|
|
|
RXD - CN12-64 - TXD - Pin 4 (Orange)
|
|
|
|
|
GND CN12-63 - GND Pin 1 (Black)
|
|
|
|
|
------------- -------------------
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-12 20:26:56 +02:00
|
|
|
|
*Note you will be reverse RX/TX
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Use make menuconfig to configure USART8 as the console:
|
|
|
|
|
|
|
|
|
|
CONFIG_STM32F7_UART8=y
|
2016-06-08 15:52:19 +02:00
|
|
|
|
CONFIG_UART8_SERIALDRIVER=y
|
|
|
|
|
CONFIG_UART8_SERIAL_CONSOLE=y
|
2016-05-12 17:56:32 +02:00
|
|
|
|
CONFIG_UART8_RXBUFSIZE=256
|
|
|
|
|
CONFIG_UART8_TXBUFSIZE=256
|
|
|
|
|
CONFIG_UART8_BAUD=115200
|
|
|
|
|
CONFIG_UART8_BITS=8
|
|
|
|
|
CONFIG_UART8_PARITY=0
|
|
|
|
|
CONFIG_UART8_2STOP=0
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
Virtual COM Port (CONFIG_NUCLEO_CONSOLE_VIRTUAL)
|
2016-05-12 17:56:32 +02:00
|
|
|
|
----------------
|
|
|
|
|
Yet another option is to use USART3 and the USB virtual COM port. This
|
|
|
|
|
option may be more convenient for long term development, but is painful
|
|
|
|
|
to use during board bring-up.
|
|
|
|
|
|
|
|
|
|
Solder Bridges. This configuration requires:
|
|
|
|
|
|
2016-05-12 20:26:56 +02:00
|
|
|
|
PD8 USART3 TX SB5 ON and SB7 OFF (Default)
|
|
|
|
|
PD9 USART3 RX SB6 ON and SB4 OFF (Default)
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
|
|
|
|
Configuring USART3 is the same as given above but add the S and #3.
|
|
|
|
|
|
|
|
|
|
Question: What BAUD should be configure to interface with the Virtual
|
|
|
|
|
COM port? 115200 8N1?
|
|
|
|
|
|
|
|
|
|
Default
|
|
|
|
|
-------
|
|
|
|
|
As shipped, SB4 and SB7 are open and SB5 and SB6 closed, so the
|
|
|
|
|
virtual COM port is enabled.
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
|
|
|
|
|
SPI
|
|
|
|
|
---
|
|
|
|
|
Since this board is so generic, having a quick way to vet the SPI
|
|
|
|
|
configuration seams in order. So the board provides a quick test
|
|
|
|
|
that can be selected vi CONFIG_NUCLEO_SPI_TEST that will initalise
|
|
|
|
|
the selected buses (SPI1-SPI3) and send some text on the bus at
|
|
|
|
|
application initalization time board_app_initialize.
|
|
|
|
|
|
|
|
|
|
SDIO
|
|
|
|
|
----
|
|
|
|
|
To test the SD performace one can use a SparkFun microSD Sniffer
|
|
|
|
|
from https://www.sparkfun.com/products/9419 or similar board
|
|
|
|
|
and connect it as follows:
|
|
|
|
|
|
|
|
|
|
VCC V3.3 CN11 16
|
|
|
|
|
GND GND CN11-8
|
|
|
|
|
CMD PD2 CN11-4
|
|
|
|
|
CLK PC12 CN11-3
|
|
|
|
|
DAT0 - PC8 CN12-2
|
|
|
|
|
DAT1 - PC9 CN12-1
|
|
|
|
|
DAT2 PC10 CN11-1
|
|
|
|
|
CD PC11 CN11-2
|
|
|
|
|
|
2016-06-14 15:30:28 +02:00
|
|
|
|
SPI Test
|
|
|
|
|
========
|
|
|
|
|
|
|
|
|
|
The builtin SPI test facility can be enabled with the following settings:
|
|
|
|
|
|
|
|
|
|
+CONFIG_STM32F7_SPI=y
|
|
|
|
|
+CONFIG_STM32F7_SPI1=y
|
|
|
|
|
+CONFIG_STM32F7_SPI2=y
|
|
|
|
|
+CONFIG_STM32F7_SPI3=y
|
|
|
|
|
|
|
|
|
|
+# CONFIG_STM32F7_SPI_INTERRUPTS is not set
|
|
|
|
|
+# CONFIG_STM32F7_SPI_DMA is not set
|
|
|
|
|
# CONFIG_STM32F7_CUSTOM_CLOCKCONFIG is not set
|
|
|
|
|
|
|
|
|
|
+CONFIG_NUCLEO_SPI_TEST=y
|
|
|
|
|
+CONFIG_NUCLEO_SPI_TEST_MESSAGE="Hello World"
|
|
|
|
|
+CONFIG_NUCLEO_SPI1_TEST=y
|
|
|
|
|
+CONFIG_NUCLEO_SPI1_TEST_FREQ=1000000
|
|
|
|
|
+CONFIG_NUCLEO_SPI1_TEST_BITS=8
|
|
|
|
|
+CONFIG_NUCLEO_SPI1_TEST_MODE3=y
|
|
|
|
|
|
|
|
|
|
+CONFIG_NUCLEO_SPI2_TEST=y
|
|
|
|
|
+CONFIG_NUCLEO_SPI2_TEST_FREQ=12000000
|
|
|
|
|
+CONFIG_NUCLEO_SPI2_TEST_BITS=8
|
|
|
|
|
+CONFIG_NUCLEO_SPI2_TEST_MODE3=y
|
|
|
|
|
|
|
|
|
|
+CONFIG_NUCLEO_SPI3_TEST=y
|
|
|
|
|
+CONFIG_NUCLEO_SPI3_TEST_FREQ=40000000
|
|
|
|
|
+CONFIG_NUCLEO_SPI3_TEST_BITS=8
|
|
|
|
|
+CONFIG_NUCLEO_SPI3_TEST_MODE3=y
|
|
|
|
|
|
|
|
|
|
+CONFIG_LIB_BOARDCTL=y
|
|
|
|
|
+CONFIG_NSH_ARCHINIT=y
|
|
|
|
|
|
2016-05-12 17:56:32 +02:00
|
|
|
|
Configurations
|
|
|
|
|
==============
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
f7xx-nsh:
|
2016-05-20 15:44:56 +02:00
|
|
|
|
----
|
2016-05-20 14:55:30 +02:00
|
|
|
|
Configures the NuttShell (nsh) located at apps/examples/nsh for the
|
|
|
|
|
Nucleo-144 boards. The Configuration enables the serial interfaces
|
2016-06-08 15:52:19 +02:00
|
|
|
|
on USART6. Support for builtin applications is enabled, but in the base
|
2016-05-20 14:55:30 +02:00
|
|
|
|
configuration no builtin applications are selected (see NOTES below).
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
NOTES:
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
1. This configuration uses the mconf-based configuration tool. To
|
|
|
|
|
change this configuration using that tool, you should:
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
a. Build and install the kconfig-mconf tool. See nuttx/README.txt
|
|
|
|
|
see additional README.txt files in the NuttX tools repository.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
b. If this is the intall configuration then Execute
|
|
|
|
|
'cd tools && ./configure.sh nucleo-144/nsh && cd ..'
|
|
|
|
|
in nuttx/ in order to start configuration process.
|
|
|
|
|
Caution: Doing this step more than once will overwrite .config with
|
|
|
|
|
the contents of the nucleo-144/nsh/defconfig file.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
c. Execute 'make oldconfig' in nuttx/ in order to refresh the
|
|
|
|
|
configuration.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
d. Execute 'make menuconfig' in nuttx/ in order to start the
|
|
|
|
|
reconfiguration process.
|
2016-05-12 20:26:56 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
e. Save the .config file to reuse it in the future starting at step d.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
2. By default, this configuration uses the ARM GNU toolchain
|
|
|
|
|
for Linux. That can easily be reconfigured, of course.
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
CONFIG_HOST_LINUX=y : Builds under Linux
|
|
|
|
|
CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL=y : ARM GNU for Linux
|
2016-05-12 17:56:32 +02:00
|
|
|
|
|
2016-05-20 14:55:30 +02:00
|
|
|
|
3. Although the default console is USART3 (which would correspond to
|
|
|
|
|
the Virtual COM port) I have done all testing with the console
|
|
|
|
|
device configured for UART8 (see instruction above under "Serial
|
|
|
|
|
Consoles).
|
|
|
|
|
|
2016-06-08 15:52:19 +02:00
|
|
|
|
f7xx-evalos:
|
2016-05-20 15:44:56 +02:00
|
|
|
|
-------
|
2016-05-20 14:55:30 +02:00
|
|
|
|
This configuration is designed to test the features of the board.
|
|
|
|
|
- Configures the NuttShell (nsh) located at apps/examples/nsh for the
|
|
|
|
|
Nucleo-144 boards. The console is available on serial interface USART3,
|
|
|
|
|
which is accessible over the USB ST-Link interface.
|
|
|
|
|
- Configures nsh with advanced features such as autocompletion.
|
|
|
|
|
- Configures the on-board LEDs to work with the 'leds' example app.
|
|
|
|
|
- Configures the 'helloxx' example app.
|
|
|
|
|
|
|
|
|
|
NOTES:
|
|
|
|
|
|
|
|
|
|
1. This configuration uses the mconf-based configuration tool. To
|
|
|
|
|
change this configuration using that tool, you should:
|
|
|
|
|
|
|
|
|
|
a. Build and install the kconfig-mconf tool. See nuttx/README.txt
|
|
|
|
|
see additional README.txt files in the NuttX tools repository.
|
|
|
|
|
|
|
|
|
|
b. If this is the intall configuration then Execute
|
|
|
|
|
'cd tools && ./configure.sh nucleo-144/evalos && cd ..'
|
|
|
|
|
in nuttx/ in order to start configuration process.
|
|
|
|
|
Caution: Doing this step more than once will overwrite .config with
|
|
|
|
|
the contents of the nucleo-144/evalos/defconfig file.
|
|
|
|
|
|
|
|
|
|
c. Execute 'make oldconfig' in nuttx/ in order to refresh the
|
|
|
|
|
configuration.
|
|
|
|
|
|
|
|
|
|
d. Execute 'make menuconfig' in nuttx/ in order to start the
|
|
|
|
|
reconfiguration process.
|
|
|
|
|
|
|
|
|
|
e. Save the .config file to reuse it in the future starting at step d.
|
|
|
|
|
|
|
|
|
|
2. By default, this configuration uses the ARM GNU toolchain
|
|
|
|
|
for Linux. That can easily be reconfigured, of course.
|
|
|
|
|
|
|
|
|
|
CONFIG_HOST_LINUX=y : Builds under Linux
|
|
|
|
|
CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL=y : ARM GNU for Linux
|