nuttx/boards/arm/stm32/nucleo-g474re
cuiziwei 25eb09c3bb nuttx/boards:add KEEP to *(.init_array .init_array.*)
replace *(.init_array .init_array.*) with KEEP(*(.init_array .init_array.*)).

The KEEP statement within a linker script will instruct the linker to keep the specified section, even if no symbols inside it are referenced. This statement is used within the SECTIONS section of the linker script. This becomes relevant when garbage collection is performed at link time, enabled by passing the --gc-sections switch to the linker. The KEEP statement instructs the linker to use the specified section as a root node when creating a dependency graph, looking for unused sections. Essentially forcing the section to be marked as used.

Signed-off-by: cuiziwei <cuiziwei@xiaomi.com>
2023-08-05 05:02:25 -07:00
..
configs
include
scripts nuttx/boards:add KEEP to *(.init_array .init_array.*) 2023-08-05 05:02:25 -07:00
src cmake: port more stm32 boards and format already ported stm32 boards 2023-07-25 06:08:54 -07:00
CMakeLists.txt
Kconfig Kconfig: Simplify the conditional default statement 2023-07-16 14:39:20 -03:00
README.txt

README
======

This is the README file for a port of NuttX to the ST Micro Nucleo G474RE
board with STM32G474RE MCU. For more information about this board, see:

  https://www.st.com/en/evaluation-tools/nucleo-g474re.html

Contents
========

  - Status
  - Development Environment
    - Toolchains
    - Debugging
  - Hardware
    - MCU Clocking
    - GPIOs
    - Buttons
    - LEDs
  - Serial Consoles
  - FLASH Bootloader Support
  - Configurations

Status
======

  This port boots NuttX through to a functional NSH prompt.

Development Environment
=======================

  Toolchains
  ----------
  An appropriate ARM toolchain is needed, such as the one built with the
  customized NuttX buildroot or the ready-made GNU Tools for Arm Embedded
  Processors.

  Debugging
  ---------
  The board incorporates a STLINK-V3E programmer/debugger accessible via the
  Micro-USB Type B connector.

  To debug with OpenOCD and arm-nuttx-eabi-gdb:

  * Use 'make menuconfig' to set CONFIG_DEBUG_SYMBOLS and CONFIG_DEBUG_NOOPT.
    To see debug output, e.g., the "ABCDE" printed in __start(), also set
    CONFIG_DEBUG_FEATURES.

  * Build NuttX.

  * Flash the code using:
    $ openocd -f interface/stlink.cfg -f target/stm32g4x.cfg -c init \
      -c "reset halt" -c "flash write_image erase nuttx.bin 0x08000000"

  * Start GDB with:
    $ arm-nuttx-eabi-gdb -tui nuttx

  * In GDB:
    (gdb) target remote localhost:3333
    (gdb) monitor reset halt
    (gdb) load

Hardware
========

  MCU Clocking
  ------------
  By default, the MCU on this board is clocked from the MCU's internal HSI
  clock, and only this option is supported by software at this time.

  If software support is added for it, the MCU could be clocked from the
  following other sources: a 24 MHz oscillator on X2, MCO from STLINK-V3E, or
  external clock from connector CN9, pin 26.

  GPIOs
  -----

  Buttons
  -------
  The board has 1 user button.

  LEDs
  ----
  The board has 1 user LED.

Serial Consoles
===============

  The MCU's USART3 is exposed to the pin 1 and 2 of the "Morpho connector" CN7
  on the board.

FLASH Bootloader Support
========================

  If implementing a FLASH bootloader, turn on Kconfig option CONFIG_STM32_DFU.
  This option activates an alternate linker script, scripts/ld.script.dfu,
  which causes NuttX to leave a gap at the start of FLASH, leaving that space
  for the FLASH bootloader. See scripts/ld.script.dfu for details. It also
  causes NuttX to relocate its vector table and possibly make other
  adjustments.

  One possible bootloader is STmicro's OpenBootloader "middleware" supplied
  with STM32CubeG4 version 1.3.0. On the host (PC), it should be possible to
  use STmicro's STM32CubeProgrammer or the stm32loader.py script from
  https://github.com/jsnyder/stm32loader. That script can be invoked with
  parameters such as:

    stm32loader.py -p /dev/ttyACM0 -a 0x08006000 -e -w -v -g 0x08006000 nuttx.bin

  where the given address (0x08006000 in this case) must match the starting
  address in scripts/ld.script.dfu.

Configurations
==============

  nsh
  ---