This is an automated email from the ASF dual-hosted git repository.
xiaoxiang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/nuttx.git
The following commit(s) were added to refs/heads/master by this push:
new 44a924ab427 boards/stm32h7: add Arduino Portenta H7
44a924ab427 is described below
commit 44a924ab427c33968141814be38d74503168d217
Author: raiden00pl <[email protected]>
AuthorDate: Sat Nov 8 18:44:40 2025 +0100
boards/stm32h7: add Arduino Portenta H7
Add initial support for Arduino Portenta H7.
For now only CM7 core is supported.
Signed-off-by: raiden00pl <[email protected]>
---
.../arm/stm32h7/boards/portenta-h7/index.rst | 114 +++++++
boards/Kconfig | 11 +
boards/arm/stm32h7/portenta-h7/CMakeLists.txt | 23 ++
boards/arm/stm32h7/portenta-h7/Kconfig | 17 +
.../portenta-h7/configs/jumbo_cm7/defconfig | 70 ++++
.../stm32h7/portenta-h7/configs/nsh_cm7/defconfig | 48 +++
boards/arm/stm32h7/portenta-h7/include/board.h | 363 +++++++++++++++++++++
boards/arm/stm32h7/portenta-h7/scripts/Make.defs | 46 +++
boards/arm/stm32h7/portenta-h7/scripts/flash.ld | 160 +++++++++
boards/arm/stm32h7/portenta-h7/scripts/flash_m4.ld | 126 +++++++
boards/arm/stm32h7/portenta-h7/src/CMakeLists.txt | 40 +++
boards/arm/stm32h7/portenta-h7/src/Makefile | 35 ++
boards/arm/stm32h7/portenta-h7/src/portenta-h7.h | 92 ++++++
.../stm32h7/portenta-h7/src/stm32_appinitialize.c | 78 +++++
.../arm/stm32h7/portenta-h7/src/stm32_autoleds.c | 175 ++++++++++
boards/arm/stm32h7/portenta-h7/src/stm32_boot.c | 81 +++++
boards/arm/stm32h7/portenta-h7/src/stm32_bringup.c | 155 +++++++++
17 files changed, 1634 insertions(+)
diff --git a/Documentation/platforms/arm/stm32h7/boards/portenta-h7/index.rst
b/Documentation/platforms/arm/stm32h7/boards/portenta-h7/index.rst
new file mode 100644
index 00000000000..0de6327c96d
--- /dev/null
+++ b/Documentation/platforms/arm/stm32h7/boards/portenta-h7/index.rst
@@ -0,0 +1,114 @@
+===================
+Arduino Portenta H7
+===================
+
+This page discusses issues unique to NuttX configurations for the
+Arduino Portenta H7 board. This port applies to all versions of
+Portenta H7:
+
+* Portenta H7
+* Portenta H7 Little
+* Portenta H7 Little Connected
+
+Features
+========
+
+Arduino Portenta H7 boards come with:
+
+* STM32H747 dual-core processor
+* 8 MB SDRAM
+* 16 MB NOR Flash
+* 10/100 Ethernet Phy
+* PMIC MC34PF1550A0EP
+* Fuel Gauge Bat MAX1726
+* USB HS
+* Secure element: NXP SE0502 (Portenta H7) or Microchip ATECC608 (H7 Little and
+ H7 Little Connected)
+* Wi-Fi/Bluetooth Module (except H7 Lite)
+* DisplayPort over USB-C (Portenta H7 only)
+
+Documentation: https://docs.arduino.cc/hardware/portenta-h7/
+
+Status
+======
+
+- NSH works on USART1.
+
+Pin Mapping
+===========
+
+====== ============ ============== ================== =================
+Pin Pin Arduino Signal Arduino Signal STM32 Notes
+====== ============ ============== ================== =================
+J1-33 D14 UART1_TX USART1_TX (PA10) Default Console
+J1-35 D13 UART1_RX USART1_RX (PA9) Default Console
+J1-34 N/A UART0_TX UART4_TX (PA0)
+J1-36 N/A UART0_RX UART4_RX (PI9)
+J1-43 N/A I2C1_SDA I2C1_SDA (PB7)
+J1-45 N/A I2C1_SCL I2C1_SCL (PB6)
+J1-44 D11 I2C0_SDA I2C3_SDA (PH8)
+J1-46 D12 I2C0_SDL I2C3_SDC (PH7)
+I2-40 D10 SPI1_CIPO SPI2_MISO (PC2)
+I2-38 D9 SPI1_CK SPI2_SCK (PI1)
+I2-42 D8 SPI1_COPI SPI2_MOSI (PC3)
+I2-36 D7 SPI1_CS SPI2_NSS (PI0)
+J1-49 N/A CAN1_TX FDCAN1_TX (PH13)
+J1-51 N/A CAN1_RX FDCAN1_RX (PH13)
+====== ============ ============== ================== =================
+
+Flashing
+========
+
+.. note::
+ The on-board PMIC isn't supported yet, so we rely on the Arduino bootloader.
+ DO NOT ERASE the default bootloader, or you'll brick the board!
+
+Flashing with dfu-utils
+-----------------------
+
+1. Press the reset button twice. The green LED should start flashing rapidly.
+ You can check if dfu works with the ``dfu-util -l`` command. It should
return::
+
+ Found DFU: [2341:035b] ver=0200, devnum=75, cfg=1, intf=0, path="3-6.3",
alt=3, name="@Arduino boot v.25 /0x00000000/0*4Kg",
serial="003D00473133511137323532"
+ Found DFU: [2341:035b] ver=0200, devnum=75, cfg=1, intf=0, path="3-6.3",
alt=2, name="@Ext File Flash 0MB /0x00000000/0*4Kg",
serial="003D00473133511137323532"
+ Found DFU: [2341:035b] ver=0200, devnum=75, cfg=1, intf=0, path="3-6.3",
alt=1, name="@Ext RAW Flash 16MB /0x90000000/4096*4Kg",
serial="003D00473133511137323532"
+ Found DFU: [2341:035b] ver=0200, devnum=75, cfg=1, intf=0, path="3-6.3",
alt=0, name="@Internal Flash 2MB /0x08000000/01*128Ka,15*128Kg",
serial="003D00473133511137323532"
+
+2. Flash firmware after bootloader code (offset = 0x08040000)::
+
+ dfu-util --device 0x2341:0x035b -D nuttx.bin -a0
--dfuse-address=0x08040000:leave
+
+Flashing with debugger
+----------------------
+
+To connect an external debugger to Portent H7 you need Portenta Breakout and
+20-pin MIPI connector. Another option is to solder directly to the test pins
+on the board.
+
+OpenOCD works with ``target/stm32h7x_dual_bank.cfg``.
+
+Configurations
+==============
+
+Each portenta-h7 configuration is maintained in a sub-directory and
+can be selected as follow::
+
+ tools/configure.sh portenta-h7:<subdir>
+
+Where <subdir> is one of the following:
+
+nsh_cm7
+-------
+
+Configures the NuttShell (nsh) located at apps/examples/nsh. This
+configuration enables a serial console on UART1.
+Configuration dedicated for CM7 core.
+
+jumbo_cm7
+---------
+
+This configuration enables many Apache NuttX features. This is
+mostly to help provide additional code coverage in CI, but also
+allows for user to see a wide range of features that are
+supported by the OS.
+Configuration dedicated for CM7 core.
diff --git a/boards/Kconfig b/boards/Kconfig
index 19265611da7..bd3f8391439 100644
--- a/boards/Kconfig
+++ b/boards/Kconfig
@@ -1934,6 +1934,13 @@ config ARCH_BOARD_OPENH743I
---help---
Waveshare OpenH743I board based on the STMicro STM32H743II MCU.
+config ARCH_BOARD_PORTENTA_H7
+ bool "Arduino Portenta H7"
+ depends on ARCH_CHIP_STM32H747XI
+ select ARCH_HAVE_LEDS
+ ---help---
+ Arduino Portenta H7 board based on STMicro STM32H747XI MCU.
+
config ARCH_BOARD_NUCLEO_L152RE
bool "STM32L152 Nucleo L152RE"
depends on ARCH_CHIP_STM32L152RE
@@ -3658,6 +3665,7 @@ config ARCH_BOARD
default "stm32h750b-dk" if ARCH_BOARD_STM32H750B_DK
default "linum-stm32h753bi" if ARCH_BOARD_LINUM_STM32H753BI
default "openh743i" if ARCH_BOARD_OPENH743I
+ default "portenta-h7" if ARCH_BOARD_PORTENTA_H7
default "nucleo-l073rz" if ARCH_BOARD_NUCLEO_L073RZ
default "nucleo-l152re" if ARCH_BOARD_NUCLEO_L152RE
default "nucleo-l432kc" if ARCH_BOARD_NUCLEO_L432KC
@@ -4401,6 +4409,9 @@ endif
if ARCH_BOARD_OPENH743I
source "boards/arm/stm32h7/openh743i/Kconfig"
endif
+if ARCH_BOARD_PORTENTA_H7
+source "boards/arm/stm32h7/portenta-h7/Kconfig"
+endif
if ARCH_BOARD_B_L475E_IOT01A
source "boards/arm/stm32l4/b-l475e-iot01a/Kconfig"
endif
diff --git a/boards/arm/stm32h7/portenta-h7/CMakeLists.txt
b/boards/arm/stm32h7/portenta-h7/CMakeLists.txt
new file mode 100644
index 00000000000..0b32fcc63a5
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/CMakeLists.txt
@@ -0,0 +1,23 @@
+#
##############################################################################
+# boards/arm/stm32h7/portenta-h7/CMakeLists.txt
+#
+# SPDX-License-Identifier: Apache-2.0
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
contributor
+# license agreements. See the NOTICE file distributed with this work for
+# additional information regarding copyright ownership. The ASF licenses this
+# file to you under the Apache License, Version 2.0 (the "License"); you may
not
+# use this file except in compliance with the License. You may obtain a copy
of
+# the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations under
+# the License.
+#
+#
##############################################################################
+
+add_subdirectory(src)
diff --git a/boards/arm/stm32h7/portenta-h7/Kconfig
b/boards/arm/stm32h7/portenta-h7/Kconfig
new file mode 100644
index 00000000000..f7d6a70e2f1
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/Kconfig
@@ -0,0 +1,17 @@
+#
+# For a description of the syntax of this configuration file,
+# see the file kconfig-language.txt in the NuttX tools repository.
+#
+
+if ARCH_BOARD_PORTENTA_H7
+
+config PORTENTAH7_ARDUINO_BOOTLOADER
+ bool "Use Arduino bootloader"
+ default y
+ ---help---
+ Use the Arduino bootloader to load the NuttX binary.
+ Don't disable this option unless you know exactly what you're
doing!
+ It may cause the boards to brick because the bootloader
initializes
+ PMIC (problem known as "orange LED of death").
+
+endif # ARCH_BOARD_PORTENTA_H7
diff --git a/boards/arm/stm32h7/portenta-h7/configs/jumbo_cm7/defconfig
b/boards/arm/stm32h7/portenta-h7/configs/jumbo_cm7/defconfig
new file mode 100644
index 00000000000..3ef7ff5d7e4
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/configs/jumbo_cm7/defconfig
@@ -0,0 +1,70 @@
+#
+# This file is autogenerated: PLEASE DO NOT EDIT IT.
+#
+# You can use "make menuconfig" to make any modifications to the installed
.config file.
+# You can then do "make savedefconfig" to generate a new defconfig file that
includes your
+# modifications.
+#
+# CONFIG_STANDARD_SERIAL is not set
+# CONFIG_STM32H7_USE_LEGACY_PINMAP is not set
+CONFIG_ARCH="arm"
+CONFIG_ARCH_BOARD="portenta-h7"
+CONFIG_ARCH_BOARD_PORTENTA_H7=y
+CONFIG_ARCH_CHIP="stm32h7"
+CONFIG_ARCH_CHIP_STM32H747XI=y
+CONFIG_ARCH_CHIP_STM32H7=y
+CONFIG_ARCH_CHIP_STM32H7_CORTEXM7=y
+CONFIG_ARCH_STACKDUMP=y
+CONFIG_ARMV7M_DCACHE=y
+CONFIG_ARMV7M_DCACHE_WRITETHROUGH=y
+CONFIG_ARMV7M_DTCM=y
+CONFIG_ARMV7M_ICACHE=y
+CONFIG_BOARD_LATE_INITIALIZE=y
+CONFIG_BOARD_LOOPSPERMSEC=43103
+CONFIG_BUILTIN=y
+CONFIG_DEBUG_ASSERTIONS=y
+CONFIG_DEBUG_ASSERTIONS_EXPRESSION=y
+CONFIG_DEBUG_FEATURES=y
+CONFIG_DEBUG_SYMBOLS=y
+CONFIG_EVENT_FD=y
+CONFIG_FS_NOTIFY=y
+CONFIG_FS_PROCFS=y
+CONFIG_FS_PROCFS_REGISTER=y
+CONFIG_FS_TMPFS=y
+CONFIG_HAVE_CXX=y
+CONFIG_HAVE_CXXINITIALIZE=y
+CONFIG_I2C=y
+CONFIG_INIT_ENTRYPOINT="nsh_main"
+CONFIG_INTELHEX_BINARY=y
+CONFIG_LIBC_MEMFD_ERROR=y
+CONFIG_LINE_MAX=64
+CONFIG_MM_REGIONS=4
+CONFIG_NDEBUG=y
+CONFIG_NSH_BUILTIN_APPS=y
+CONFIG_NSH_DISABLE_IFUPDOWN=y
+CONFIG_NSH_FILEIOSIZE=512
+CONFIG_NSH_PROMPT_STRING="nsh-cm7> "
+CONFIG_NSH_READLINE=y
+CONFIG_PREALLOC_TIMERS=4
+CONFIG_PSEUDOFS_ATTRIBUTES=y
+CONFIG_PSEUDOFS_FILE=y
+CONFIG_PSEUDOFS_SOFTLINKS=y
+CONFIG_RAM_SIZE=245760
+CONFIG_RAM_START=0x20010000
+CONFIG_RAW_BINARY=y
+CONFIG_RR_INTERVAL=200
+CONFIG_SCHED_WAITPID=y
+CONFIG_SIGNAL_FD=y
+CONFIG_START_DAY=6
+CONFIG_START_MONTH=12
+CONFIG_START_YEAR=2011
+CONFIG_STM32H7_I2C1=y
+CONFIG_STM32H7_I2C3=y
+CONFIG_STM32H7_USART1=y
+CONFIG_SYSTEM_CLE=y
+CONFIG_SYSTEM_CUTERM=y
+CONFIG_SYSTEM_I2CTOOL=y
+CONFIG_SYSTEM_NSH=y
+CONFIG_TESTING_OSTEST=y
+CONFIG_TIMER_FD=y
+CONFIG_USART1_SERIAL_CONSOLE=y
diff --git a/boards/arm/stm32h7/portenta-h7/configs/nsh_cm7/defconfig
b/boards/arm/stm32h7/portenta-h7/configs/nsh_cm7/defconfig
new file mode 100644
index 00000000000..a4d13d2dd23
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/configs/nsh_cm7/defconfig
@@ -0,0 +1,48 @@
+#
+# This file is autogenerated: PLEASE DO NOT EDIT IT.
+#
+# You can use "make menuconfig" to make any modifications to the installed
.config file.
+# You can then do "make savedefconfig" to generate a new defconfig file that
includes your
+# modifications.
+#
+# CONFIG_NSH_DISABLE_IFCONFIG is not set
+# CONFIG_NSH_DISABLE_PS is not set
+# CONFIG_STANDARD_SERIAL is not set
+# CONFIG_STM32H7_USE_LEGACY_PINMAP is not set
+CONFIG_ARCH="arm"
+CONFIG_ARCH_BOARD="portenta-h7"
+CONFIG_ARCH_BOARD_PORTENTA_H7=y
+CONFIG_ARCH_CHIP="stm32h7"
+CONFIG_ARCH_CHIP_STM32H747XI=y
+CONFIG_ARCH_CHIP_STM32H7=y
+CONFIG_ARCH_CHIP_STM32H7_CORTEXM7=y
+CONFIG_ARCH_STACKDUMP=y
+CONFIG_ARMV7M_DCACHE=y
+CONFIG_ARMV7M_DCACHE_WRITETHROUGH=y
+CONFIG_ARMV7M_DTCM=y
+CONFIG_ARMV7M_ICACHE=y
+CONFIG_BOARD_LOOPSPERMSEC=43103
+CONFIG_BUILTIN=y
+CONFIG_DEBUG_SYMBOLS=y
+CONFIG_HAVE_CXX=y
+CONFIG_HAVE_CXXINITIALIZE=y
+CONFIG_INIT_ENTRYPOINT="nsh_main"
+CONFIG_INTELHEX_BINARY=y
+CONFIG_LINE_MAX=64
+CONFIG_MM_REGIONS=4
+CONFIG_NSH_BUILTIN_APPS=y
+CONFIG_NSH_FILEIOSIZE=512
+CONFIG_NSH_PROMPT_STRING="nsh-cm7> "
+CONFIG_NSH_READLINE=y
+CONFIG_PREALLOC_TIMERS=4
+CONFIG_RAM_SIZE=245760
+CONFIG_RAM_START=0x20010000
+CONFIG_RAW_BINARY=y
+CONFIG_RR_INTERVAL=200
+CONFIG_SCHED_WAITPID=y
+CONFIG_START_DAY=6
+CONFIG_START_MONTH=12
+CONFIG_START_YEAR=2011
+CONFIG_STM32H7_USART1=y
+CONFIG_SYSTEM_NSH=y
+CONFIG_USART1_SERIAL_CONSOLE=y
diff --git a/boards/arm/stm32h7/portenta-h7/include/board.h
b/boards/arm/stm32h7/portenta-h7/include/board.h
new file mode 100644
index 00000000000..cd0a990f028
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/include/board.h
@@ -0,0 +1,363 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/include/board.h
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+#ifndef __BOARDS_ARM_STM32H7_PORTENTA_H7_INCLUDE_BOARD_H
+#define __BOARDS_ARM_STM32H7_PORTENTA_H7_INCLUDE_BOARD_H
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#ifndef __ASSEMBLY__
+# include <stdint.h>
+#endif
+
+/* Do not include STM32 H7 header files here */
+
+/****************************************************************************
+ * Pre-processor Definitions
+ ****************************************************************************/
+
+/* Clocking *****************************************************************/
+
+/* The Portenta-H7 board provides the following clock sources:
+ *
+ * U18: 25MHz HSE MEMS Oscillator
+ * Y1: 32768Hz LSE crystal oscillator
+ *
+ * So we have these clock sources available within the STM32
+ *
+ * HSI: 64 MHz RC factory-trimmed
+ * LSI: 32 KHz RC
+ * HSE: 27 MHz oscillator
+ * LSE: 32.768 kHz
+ */
+
+#define STM32_HSI_FREQUENCY 16000000ul
+#define STM32_LSI_FREQUENCY 32000
+#define STM32_HSE_FREQUENCY 25000000ul
+#define STM32_LSE_FREQUENCY 32768
+
+#define STM32_BOARD_USEHSE
+#define STM32_HSEBYP_ENABLE
+
+/* Main PLL Configuration.
+ *
+ * PLL source is HSE = 25,000,000
+ *
+ * When STM32_HSE_FREQUENCY / PLLM <= 2MHz VCOL must be selected.
+ * VCOH otherwise.
+ *
+ * PLL_VCOx = (STM32_HSE_FREQUENCY / PLLM) * PLLN
+ * Subject to:
+ *
+ * 1 <= PLLM <= 63
+ * 4 <= PLLN <= 512
+ * 150 MHz <= PLL_VCOL <= 420MHz
+ * 192 MHz <= PLL_VCOH <= 836MHz
+ *
+ * SYSCLK = PLL_VCO / PLLP
+ * CPUCLK = SYSCLK / D1CPRE
+ * Subject to
+ *
+ * PLLP1 = {2, 4, 6, 8, ..., 128}
+ * PLLP2,3 = {2, 3, 4, ..., 128}
+ * CPUCLK <= 480 MHz
+ */
+
+#define STM32_PLLCFG_PLLSRC RCC_PLLCKSELR_PLLSRC_HSE
+
+/* PLL1, wide 2 - 4 MHz input, enable DIVP, DIVQ, DIVR
+ *
+ * PLL1_VCO = (25,000,000 / 5) * 160 = 800 MHz
+ *
+ * PLL1P = PLL1_VCO/2 = 960 MHz / 2 = 400 MHz
+ * PLL1Q = PLL1_VCO/4 = 960 MHz / 4 = 200 MHz
+ * PLL1R = PLL1_VCO/8 = 960 MHz / 8 = 100 MHz
+ */
+
+#define STM32_PLLCFG_PLL1CFG (RCC_PLLCFGR_PLL1VCOSEL_WIDE | \
+ RCC_PLLCFGR_PLL1RGE_2_4_MHZ | \
+ RCC_PLLCFGR_DIVP1EN | \
+ RCC_PLLCFGR_DIVQ1EN | \
+ RCC_PLLCFGR_DIVR1EN)
+#define STM32_PLLCFG_PLL1M RCC_PLLCKSELR_DIVM1(5)
+#define STM32_PLLCFG_PLL1N RCC_PLL1DIVR_N1(160)
+#define STM32_PLLCFG_PLL1P RCC_PLL1DIVR_P1(2)
+#define STM32_PLLCFG_PLL1Q RCC_PLL1DIVR_Q1(4)
+#define STM32_PLLCFG_PLL1R RCC_PLL1DIVR_R1(8)
+
+#define STM32_VCO1_FREQUENCY ((STM32_HSE_FREQUENCY / 5) * 160)
+#define STM32_PLL1P_FREQUENCY (STM32_VCO1_FREQUENCY / 2)
+#define STM32_PLL1Q_FREQUENCY (STM32_VCO1_FREQUENCY / 4)
+#define STM32_PLL1R_FREQUENCY (STM32_VCO1_FREQUENCY / 8)
+
+/* PLL2 */
+
+#define STM32_PLLCFG_PLL2CFG (RCC_PLLCFGR_PLL2VCOSEL_WIDE | \
+ RCC_PLLCFGR_PLL2RGE_2_4_MHZ | \
+ RCC_PLLCFGR_DIVP2EN)
+#define STM32_PLLCFG_PLL2M RCC_PLLCKSELR_DIVM2(5)
+#define STM32_PLLCFG_PLL2N RCC_PLL2DIVR_N2(160)
+#define STM32_PLLCFG_PLL2P RCC_PLL2DIVR_P2(2)
+#define STM32_PLLCFG_PLL2Q RCC_PLL2DIVR_Q2(4)
+#define STM32_PLLCFG_PLL2R RCC_PLL2DIVR_R2(8)
+
+#define STM32_VCO2_FREQUENCY ((STM32_HSE_FREQUENCY / 5) * 160)
+#define STM32_PLL2P_FREQUENCY (STM32_VCO2_FREQUENCY / 2)
+#define STM32_PLL2Q_FREQUENCY (STM32_VCO2_FREQUENCY / 4)
+#define STM32_PLL2R_FREQUENCY (STM32_VCO2_FREQUENCY / 8)
+
+/* PLL3 */
+
+#define STM32_PLLCFG_PLL3CFG 0
+#define STM32_PLLCFG_PLL3M 0
+#define STM32_PLLCFG_PLL3N 0
+#define STM32_PLLCFG_PLL3P 0
+#define STM32_PLLCFG_PLL3Q 0
+#define STM32_PLLCFG_PLL3R 0
+
+#define STM32_VCO3_FREQUENCY
+#define STM32_PLL3P_FREQUENCY
+#define STM32_PLL3Q_FREQUENCY
+#define STM32_PLL3R_FREQUENCY
+
+/* SYSCLK = PLL1P = 400 MHz
+ * M7 CPUCLK = SYSCLK / 1 = 400 MHz
+ * M4 CPUCLK = HCLK / 1 = 200 MHz
+ */
+
+#define STM32_RCC_D1CFGR_D1CPRE (RCC_D1CFGR_D1CPRE_SYSCLK)
+#define STM32_SYSCLK_FREQUENCY (STM32_PLL1P_FREQUENCY)
+#ifdef CONFIG_ARCH_CHIP_STM32H7_CORTEXM7
+# define STM32_CPUCLK_FREQUENCY (STM32_SYSCLK_FREQUENCY / 1)
+#else
+# define STM32_CPUCLK_FREQUENCY (STM32_HCLK_FREQUENCY / 1)
+#endif
+
+/* Configure Clock Assignments */
+
+/* AHB clock (HCLK) is SYSCLK/2 (240 MHz max)
+ * HCLK1 = HCLK2 = HCLK3 = HCLK4
+ */
+
+#define STM32_RCC_D1CFGR_HPRE RCC_D1CFGR_HPRE_SYSCLKd2 /* HCLK =
SYSCLK / 2 */
+#define STM32_ACLK_FREQUENCY (STM32_SYSCLK_FREQUENCY / 2) /* ACLK in D1,
HCLK3 in D1 */
+#define STM32_HCLK_FREQUENCY (STM32_SYSCLK_FREQUENCY / 2) /* HCLK in D2,
HCLK4 in D3 */
+
+/* APB1 clock (PCLK1) is HCLK/4 */
+
+#define STM32_RCC_D2CFGR_D2PPRE1 RCC_D2CFGR_D2PPRE1_HCLKd4 /* PCLK1 =
HCLK / 4 */
+#define STM32_PCLK1_FREQUENCY (STM32_HCLK_FREQUENCY/4)
+
+/* APB2 clock (PCLK2) is HCLK/4 */
+
+#define STM32_RCC_D2CFGR_D2PPRE2 RCC_D2CFGR_D2PPRE2_HCLKd4 /* PCLK2 =
HCLK / 4 */
+#define STM32_PCLK2_FREQUENCY (STM32_HCLK_FREQUENCY/4)
+
+/* APB3 clock (PCLK3) is HCLK/4 */
+
+#define STM32_RCC_D1CFGR_D1PPRE RCC_D1CFGR_D1PPRE_HCLKd4 /* PCLK3 =
HCLK / 4 */
+#define STM32_PCLK3_FREQUENCY (STM32_HCLK_FREQUENCY/4)
+
+/* APB4 clock (PCLK4) is HCLK/4 */
+
+#define STM32_RCC_D3CFGR_D3PPRE RCC_D3CFGR_D3PPRE_HCLKd4 /* PCLK4 =
HCLK / 4 */
+#define STM32_PCLK4_FREQUENCY (STM32_HCLK_FREQUENCY/4)
+
+/* Timer clock frequencies */
+
+/* Timers driven from APB1 will be twice PCLK1 */
+
+#define STM32_APB1_TIM2_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM3_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM4_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM5_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM6_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM7_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM12_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM13_CLKIN (2*STM32_PCLK1_FREQUENCY)
+#define STM32_APB1_TIM14_CLKIN (2*STM32_PCLK1_FREQUENCY)
+
+/* Timers driven from APB2 will be twice PCLK2 */
+
+#define STM32_APB2_TIM1_CLKIN (2*STM32_PCLK2_FREQUENCY)
+#define STM32_APB2_TIM8_CLKIN (2*STM32_PCLK2_FREQUENCY)
+#define STM32_APB2_TIM15_CLKIN (2*STM32_PCLK2_FREQUENCY)
+#define STM32_APB2_TIM16_CLKIN (2*STM32_PCLK2_FREQUENCY)
+#define STM32_APB2_TIM17_CLKIN (2*STM32_PCLK2_FREQUENCY)
+
+/* Kernel Clock Configuration
+ *
+ * Note: look at Table 54 in ST Manual
+ */
+
+/* I2C123 clock source - HSI */
+
+#define STM32_RCC_D2CCIP2R_I2C123SRC RCC_D2CCIP2R_I2C123SEL_HSI
+
+/* I2C4 clock source - HSI */
+
+#define STM32_RCC_D3CCIPR_I2C4SRC RCC_D3CCIPR_I2C4SEL_HSI
+
+/* SPI123 clock source - PLL1Q */
+
+#define STM32_RCC_D2CCIP1R_SPI123SRC RCC_D2CCIP1R_SPI123SEL_PLL1
+
+/* SPI45 clock source - APB (PCLK2?) */
+
+#define STM32_RCC_D2CCIP1R_SPI45SRC RCC_D2CCIP1R_SPI45SEL_APB
+
+/* SPI6 clock source - APB (PCLK4) */
+
+#define STM32_RCC_D3CCIPR_SPI6SRC RCC_D3CCIPR_SPI6SEL_PCLK4
+
+/* USB 1 and 2 clock source - HSI48 */
+
+#define STM32_RCC_D2CCIP2R_USBSRC RCC_D2CCIP2R_USBSEL_HSI48
+
+/* ADC 1 2 3 clock source - pll2_pclk */
+
+#define STM32_RCC_D3CCIPR_ADCSRC RCC_D3CCIPR_ADCSEL_PLL2
+
+/* FLASH wait states
+ *
+ * ------------ ---------- -----------
+ * Vcore MAX ACLK WAIT STATES
+ * ------------ ---------- -----------
+ * 1.15-1.26 V 70 MHz 0
+ * (VOS1 level) 140 MHz 1
+ * 210 MHz 2
+ * 1.05-1.15 V 55 MHz 0
+ * (VOS2 level) 110 MHz 1
+ * 165 MHz 2
+ * 220 MHz 3
+ * 0.95-1.05 V 45 MHz 0
+ * (VOS3 level) 90 MHz 1
+ * 135 MHz 2
+ * 180 MHz 3
+ * 225 MHz 4
+ * ------------ ---------- -----------
+ */
+
+#define BOARD_FLASH_WAITSTATES 4
+
+/* LED definitions **********************************************************/
+
+/* LED index values for use with board_userled() */
+
+#define BOARD_LED1 0
+#define BOARD_LED2 1
+#define BOARD_LED3 2
+#define BOARD_NLEDS 3
+
+#define BOARD_LED_GREEN BOARD_LED1
+#define BOARD_LED_BLUE BOARD_LED2
+#define BOARD_LED_RED BOARD_LED3
+
+/* LED bits for use with board_userled_all() */
+
+#define BOARD_LED1_BIT (1 << BOARD_LED1)
+#define BOARD_LED2_BIT (1 << BOARD_LED2)
+#define BOARD_LED3_BIT (1 << BOARD_LED3)
+
+/* If CONFIG_ARCH_LEDS is defined, the usage by the board port is defined in
+ * include/board.h and src/stm32_leds.c.
+ * The LEDs are used to encode OS-related events as follows:
+ *
+ *
+ * SYMBOL Meaning LED state
+ * Red Green Blue
+ * ---------------------- -------------------------- ------ ------ ---
+ */
+
+#define LED_STARTED 0 /* NuttX has been started OFF OFF OFF */
+#define LED_HEAPALLOCATE 1 /* Heap has been allocated OFF OFF ON */
+#define LED_IRQSENABLED 2 /* Interrupts enabled OFF ON OFF */
+#define LED_STACKCREATED 3 /* Idle stack created OFF ON ON */
+#define LED_INIRQ 4 /* In an interrupt N/C N/C GLOW */
+#define LED_SIGNAL 5 /* In a signal handler N/C GLOW N/C */
+#define LED_ASSERTION 6 /* An assertion failed GLOW N/C GLOW */
+#define LED_PANIC 7 /* The system has crashed Blink OFF N/C */
+#define LED_IDLE 8 /* MCU is is sleep mode ON OFF OFF */
+
+/* Thus if the Green LED is statically on, NuttX has successfully booted and
+ * is, apparently, running normally. If the Red LED is flashing at
+ * approximately 2Hz, then a fatal error has been detected and the system
+ * has halted.
+ */
+
+/* Alternate function pin selections ****************************************/
+
+/* UART4 (Portenta UART0) */
+
+#define GPIO_UART4_TX (GPIO_UART4_TX_2) /* PA0 */
+#define GPIO_UART4_RX (GPIO_UART4_RX_7) /* PI9 */
+
+/* USART1 (Portenta UART1, Arduino connector) */
+
+#define GPIO_USART1_RX (GPIO_USART1_RX_2) /* PA10 */
+#define GPIO_USART1_TX (GPIO_USART1_TX_2) /* PA9 */
+
+/* I2C1 */
+
+#define GPIO_I2C1_SDA (GPIO_I2C1_SDA_1) /* PB7 (J1-43) */
+#define GPIO_I2C1_SCL (GPIO_I2C1_SCL_1) /* PB6 (J1-45) */
+
+/* I2C3 */
+
+#define GPIO_I2C3_SDA (GPIO_I2C3_SDA_2) /* PH8 (J1-44) */
+#define GPIO_I2C3_SCL (GPIO_I2C3_SCL_2) /* PH7 (J1-46) */
+
+/* CAN1 */
+
+#define GPIO_FDCAN1_TX (GPIO_FDCAN1_TX_4) /* PH13 (J1-49) */
+#define GPIO_FDCAN1_RX (GPIO_FDCAN1_RX_2) /* PB8 (J1-51) */
+
+/****************************************************************************
+ * Public Data
+ ****************************************************************************/
+
+#ifndef __ASSEMBLY__
+
+#undef EXTERN
+#if defined(__cplusplus)
+#define EXTERN extern "C"
+extern "C"
+{
+#else
+#define EXTERN extern
+#endif
+
+/****************************************************************************
+ * Public Function Prototypes
+ ****************************************************************************/
+
+#undef EXTERN
+#if defined(__cplusplus)
+}
+#endif
+
+#endif /* __ASSEMBLY__ */
+#endif /* __BOARDS_ARM_STM32H7_PORTENTA_H7_INCLUDE_BOARD_H */
diff --git a/boards/arm/stm32h7/portenta-h7/scripts/Make.defs
b/boards/arm/stm32h7/portenta-h7/scripts/Make.defs
new file mode 100644
index 00000000000..a97c2600de3
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/scripts/Make.defs
@@ -0,0 +1,46 @@
+############################################################################
+# boards/arm/stm32h7/portenta-h7/scripts/Make.defs
+#
+# SPDX-License-Identifier: Apache-2.0
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership. The
+# ASF licenses this file to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance with the
+# License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+############################################################################
+
+include $(TOPDIR)/.config
+include $(TOPDIR)/tools/Config.mk
+include $(TOPDIR)/arch/arm/src/armv7-m/Toolchain.defs
+
+ifeq ($(CONFIG_ARCH_CHIP_STM32H7_CORTEXM7),y)
+ LDSCRIPT = flash.ld
+else
+ LDSCRIPT = flash_m4.ld
+endif
+
+ARCHSCRIPT += $(BOARD_DIR)$(DELIM)scripts$(DELIM)$(LDSCRIPT)
+
+ARCHPICFLAGS = -fpic -msingle-pic-base -mpic-register=r10
+
+CFLAGS := $(ARCHCFLAGS) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS) $(ARCHINCLUDES)
$(ARCHDEFINES) $(EXTRAFLAGS)
+CPICFLAGS = $(ARCHPICFLAGS) $(CFLAGS)
+CXXFLAGS := $(ARCHCXXFLAGS) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS)
$(ARCHXXINCLUDES) $(ARCHDEFINES) $(EXTRAFLAGS)
+CXXPICFLAGS = $(ARCHPICFLAGS) $(CXXFLAGS)
+CPPFLAGS := $(ARCHINCLUDES) $(ARCHDEFINES) $(EXTRAFLAGS)
+AFLAGS := $(CFLAGS) -D__ASSEMBLY__
+
+NXFLATLDFLAGS1 = -r -d -warn-common
+NXFLATLDFLAGS2 = $(NXFLATLDFLAGS1)
-T$(TOPDIR)/binfmt/libnxflat/gnu-nxflat-pcrel.ld -no-check-sections
+LDNXFLATFLAGS = -e main -s 2048
diff --git a/boards/arm/stm32h7/portenta-h7/scripts/flash.ld
b/boards/arm/stm32h7/portenta-h7/scripts/flash.ld
new file mode 100644
index 00000000000..c290d19025c
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/scripts/flash.ld
@@ -0,0 +1,160 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/scripts/flash.ld
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#ifdef CONFIG_PORTENTAH7_ARDUINO_BOOTLOADER
+# define FLASH_START 0x08040000
+#else
+# define FLASH_START 0x08000000
+#endif
+
+#ifndef CONFIG_STM32H7_CORTEXM4_ENABLED
+MEMORY
+{
+ itcm (rwx) : ORIGIN = 0x00000000, LENGTH = 64K
+ flash (rx) : ORIGIN = FLASH_START, LENGTH = 2048K
+ dtcm1 (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
+ dtcm2 (rwx) : ORIGIN = 0x20010000, LENGTH = 64K
+ sram (rwx) : ORIGIN = 0x24000000, LENGTH = 512K
+ sram1 (rwx) : ORIGIN = 0x30000000, LENGTH = 128K
+ sram2 (rwx) : ORIGIN = 0x30020000, LENGTH = 128K
+ sram3 (rwx) : ORIGIN = 0x30040000, LENGTH = 32K
+ sram4 (rwx) : ORIGIN = 0x38000000, LENGTH = 64K
+ bbram (rwx) : ORIGIN = 0x38800000, LENGTH = 4K
+}
+#else
+MEMORY
+{
+ itcm (rwx) : ORIGIN = 0x00000000, LENGTH = 64K
+ flash (rx) : ORIGIN = FLASH_START, LENGTH =
CONFIG_STM32H7_CORTEXM7_FLASH_SIZE
+ dtcm1 (rwx) : ORIGIN = 0x20000000, LENGTH = 64K
+ dtcm2 (rwx) : ORIGIN = 0x20010000, LENGTH = 64K
+ sram (rwx) : ORIGIN = 0x24000000, LENGTH = 512K
+
+ /* shared memory on SRAM3 */
+
+ shmem (rwx) : ORIGIN = 0x30040000, LENGTH = 32K
+ sram4 (rwx) : ORIGIN = 0x38000000, LENGTH = 64K
+ bbram (rwx) : ORIGIN = 0x38800000, LENGTH = 4K
+}
+#endif
+
+OUTPUT_ARCH(arm)
+EXTERN(_vectors)
+ENTRY(_stext)
+SECTIONS
+{
+ .text :
+ {
+ _stext = ABSOLUTE(.);
+ *(.vectors)
+ *(.text .text.*)
+ *(.fixup)
+ *(.gnu.warning)
+ *(.rodata .rodata.*)
+ *(.gnu.linkonce.t.*)
+ *(.glue_7)
+ *(.glue_7t)
+ *(.got)
+ *(.gcc_except_table)
+ *(.gnu.linkonce.r.*)
+ _etext = ABSOLUTE(.);
+ } > flash
+
+ .init_section :
+ {
+ _sinit = ABSOLUTE(.);
+ KEEP(*(SORT_BY_INIT_PRIORITY(.init_array.*)
SORT_BY_INIT_PRIORITY(.ctors.*)))
+ KEEP(*(.init_array EXCLUDE_FILE(*crtbegin.o *crtbegin?.o *crtend.o
*crtend?.o) .ctors))
+ _einit = ABSOLUTE(.);
+ } > flash
+
+ .ARM.extab :
+ {
+ *(.ARM.extab*)
+ } > flash
+
+ __exidx_start = ABSOLUTE(.);
+ .ARM.exidx :
+ {
+ *(.ARM.exidx*)
+ } > flash
+ __exidx_end = ABSOLUTE(.);
+
+ _eronly = ABSOLUTE(.);
+
+ .data :
+ {
+ _sdata = ABSOLUTE(.);
+ *(.data .data.*)
+ *(.gnu.linkonce.d.*)
+ CONSTRUCTORS
+ . = ALIGN(4);
+ _edata = ABSOLUTE(.);
+ } > sram AT > flash
+
+ .bss :
+ {
+ _sbss = ABSOLUTE(.);
+ *(.bss .bss.*)
+ *(.gnu.linkonce.b.*)
+ *(COMMON)
+ . = ALIGN(4);
+ _ebss = ABSOLUTE(.);
+ } > sram
+
+ .shmem :
+ {
+ . = ALIGN(4);
+ *(.shmem);
+ KEEP(*(.shmem))
+ } > shmem
+
+ /* Emit the the D3 power domain section for locating BDMA data
+ *
+ * Static data with locate_data(".sram4") will be located
+ * at start of SRAM4; the rest of SRAM4 will be added to the heap.
+ */
+
+ .sram4_reserve (NOLOAD) :
+ {
+ *(.sram4)
+ . = ALIGN(4);
+ _sram4_heap_start = ABSOLUTE(.);
+ } > sram4
+
+ /* Stabs debugging sections. */
+
+ .stab 0 : { *(.stab) }
+ .stabstr 0 : { *(.stabstr) }
+ .stab.excl 0 : { *(.stab.excl) }
+ .stab.exclstr 0 : { *(.stab.exclstr) }
+ .stab.index 0 : { *(.stab.index) }
+ .stab.indexstr 0 : { *(.stab.indexstr) }
+ .comment 0 : { *(.comment) }
+ .debug_abbrev 0 : { *(.debug_abbrev) }
+ .debug_info 0 : { *(.debug_info) }
+ .debug_line 0 : { *(.debug_line) }
+ .debug_pubnames 0 : { *(.debug_pubnames) }
+ .debug_aranges 0 : { *(.debug_aranges) }
+}
diff --git a/boards/arm/stm32h7/portenta-h7/scripts/flash_m4.ld
b/boards/arm/stm32h7/portenta-h7/scripts/flash_m4.ld
new file mode 100644
index 00000000000..7ef0bee3c1b
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/scripts/flash_m4.ld
@@ -0,0 +1,126 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/scripts/flash_m4.ld
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#define STM32M4_FLASH_START (0x08000000 + CONFIG_STM32H7_CORTEXM7_FLASH_SIZE)
+
+#if CONFIG_STM32H7_CORTEXM7_FLASH_SIZE != 1048576
+# error TODO: not supported yet - BCM4_ADD0 must be configured
+#endif
+
+/* Use 0x1xxxxxxx SRAM1-3 mapping for Cortex-M4 */
+
+MEMORY
+{
+ flash (rx) :
+ ORIGIN = STM32M4_FLASH_START,
+ LENGTH = (2048K - CONFIG_STM32H7_CORTEXM7_FLASH_SIZE)
+
+ /* SRAM1 and SRAM2 */
+
+ sram (rwx) : ORIGIN = 0x10000000, LENGTH = 128K + 128K
+
+ /* shared memory on SRAM3 */
+
+ shmem (rwx) : ORIGIN = 0x10040000, LENGTH = 32K
+}
+
+OUTPUT_ARCH(arm)
+EXTERN(_vectors)
+ENTRY(_stext)
+SECTIONS
+{
+ .text :
+ {
+ _stext = ABSOLUTE(.);
+ *(.vectors)
+ *(.text .text.*)
+ *(.fixup)
+ *(.gnu.warning)
+ *(.rodata .rodata.*)
+ *(.gnu.linkonce.t.*)
+ *(.glue_7)
+ *(.glue_7t)
+ *(.got)
+ *(.gcc_except_table)
+ *(.gnu.linkonce.r.*)
+ _etext = ABSOLUTE(.);
+ } > flash
+
+ .init_section :
+ {
+ _sinit = ABSOLUTE(.);
+ KEEP(*(SORT_BY_INIT_PRIORITY(.init_array.*)
SORT_BY_INIT_PRIORITY(.ctors.*)))
+ KEEP(*(.init_array EXCLUDE_FILE(*crtbegin.o *crtbegin?.o *crtend.o
*crtend?.o) .ctors))
+ _einit = ABSOLUTE(.);
+ } > flash
+
+ .ARM.extab :
+ {
+ *(.ARM.extab*)
+ } > flash
+
+ __exidx_start = ABSOLUTE(.);
+ .ARM.exidx :
+ {
+ *(.ARM.exidx*)
+ } > flash
+ __exidx_end = ABSOLUTE(.);
+
+ _eronly = ABSOLUTE(.);
+
+ .data :
+ {
+ _sdata = ABSOLUTE(.);
+ *(.data .data.*)
+ *(.gnu.linkonce.d.*)
+ CONSTRUCTORS
+ . = ALIGN(4);
+ _edata = ABSOLUTE(.);
+ } > sram AT > flash
+
+ .bss :
+ {
+ _sbss = ABSOLUTE(.);
+ *(.bss .bss.*)
+ *(.gnu.linkonce.b.*)
+ *(COMMON)
+ . = ALIGN(4);
+ _ebss = ABSOLUTE(.);
+ } > sram
+
+ /* Stabs debugging sections. */
+
+ .stab 0 : { *(.stab) }
+ .stabstr 0 : { *(.stabstr) }
+ .stab.excl 0 : { *(.stab.excl) }
+ .stab.exclstr 0 : { *(.stab.exclstr) }
+ .stab.index 0 : { *(.stab.index) }
+ .stab.indexstr 0 : { *(.stab.indexstr) }
+ .comment 0 : { *(.comment) }
+ .debug_abbrev 0 : { *(.debug_abbrev) }
+ .debug_info 0 : { *(.debug_info) }
+ .debug_line 0 : { *(.debug_line) }
+ .debug_pubnames 0 : { *(.debug_pubnames) }
+ .debug_aranges 0 : { *(.debug_aranges) }
+}
diff --git a/boards/arm/stm32h7/portenta-h7/src/CMakeLists.txt
b/boards/arm/stm32h7/portenta-h7/src/CMakeLists.txt
new file mode 100644
index 00000000000..eab66ddce96
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/CMakeLists.txt
@@ -0,0 +1,40 @@
+#
##############################################################################
+# boards/arm/stm32h7/portenta-h7/src/CMakeLists.txt
+#
+# SPDX-License-Identifier: Apache-2.0
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
contributor
+# license agreements. See the NOTICE file distributed with this work for
+# additional information regarding copyright ownership. The ASF licenses this
+# file to you under the Apache License, Version 2.0 (the "License"); you may
not
+# use this file except in compliance with the License. You may obtain a copy
of
+# the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations under
+# the License.
+#
+#
##############################################################################
+
+set(SRCS stm32_boot.c stm32_bringup.c)
+
+if(CONFIG_ARCH_LEDS)
+ list(APPEND SRCS stm32_autoleds.c)
+endif()
+
+if(CONFIG_BOARDCTL)
+ list(APPEND SRCS stm32_appinitialize.c)
+endif()
+
+target_sources(board PRIVATE ${SRCS})
+
+if(CONFIG_ARCH_CHIP_STM32H7_CORTEXM7)
+ set_property(GLOBAL PROPERTY LD_SCRIPT "${NUTTX_BOARD_DIR}/scripts/flash.ld")
+else()
+ set_property(GLOBAL PROPERTY LD_SCRIPT
+ "${NUTTX_BOARD_DIR}/scripts/flash_m4.ld")
+endif()
diff --git a/boards/arm/stm32h7/portenta-h7/src/Makefile
b/boards/arm/stm32h7/portenta-h7/src/Makefile
new file mode 100644
index 00000000000..a1bb5920c3a
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/Makefile
@@ -0,0 +1,35 @@
+############################################################################
+# boards/arm/stm32h7/portenta-h7/src/Makefile
+#
+# SPDX-License-Identifier: Apache-2.0
+#
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership. The
+# ASF licenses this file to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance with the
+# License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+############################################################################
+
+include $(TOPDIR)/Make.defs
+
+CSRCS = stm32_boot.c stm32_bringup.c
+
+ifeq ($(CONFIG_ARCH_LEDS),y)
+CSRCS += stm32_autoleds.c
+endif
+
+ifeq ($(CONFIG_BOARDCTL),y)
+CSRCS += stm32_appinitialize.c
+endif
+
+include $(TOPDIR)/boards/Board.mk
diff --git a/boards/arm/stm32h7/portenta-h7/src/portenta-h7.h
b/boards/arm/stm32h7/portenta-h7/src/portenta-h7.h
new file mode 100644
index 00000000000..f6d9cda70ae
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/portenta-h7.h
@@ -0,0 +1,92 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/src/portenta-h7.h
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+#ifndef __BOARDS_ARM_STM32H7_PORTENTA_H7_SRC_PORTENTA_H7_H
+#define __BOARDS_ARM_STM32H7_PORTENTA_H7_SRC_PORTENTA_H7_H
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+#include <nuttx/compiler.h>
+
+#include <stdint.h>
+
+/****************************************************************************
+ * Pre-processor Definitions
+ ****************************************************************************/
+
+/* Configuration ************************************************************/
+
+/* procfs File System */
+
+#ifdef CONFIG_FS_PROCFS
+# ifdef CONFIG_NSH_PROC_MOUNTPOINT
+# define STM32_PROCFS_MOUNTPOINT CONFIG_NSH_PROC_MOUNTPOINT
+# else
+# define STM32_PROCFS_MOUNTPOINT "/proc"
+# endif
+#endif
+
+/* LED */
+
+#define GPIO_LD1 (GPIO_OUTPUT | GPIO_PUSHPULL | GPIO_SPEED_50MHz | \
+ GPIO_OUTPUT_CLEAR | GPIO_PORTK | GPIO_PIN5)
+#define GPIO_LD2 (GPIO_OUTPUT | GPIO_PUSHPULL | GPIO_SPEED_50MHz | \
+ GPIO_OUTPUT_CLEAR | GPIO_PORTK | GPIO_PIN6)
+#define GPIO_LD3 (GPIO_OUTPUT | GPIO_PUSHPULL | GPIO_SPEED_50MHz | \
+ GPIO_OUTPUT_CLEAR | GPIO_PORTK | GPIO_PIN7)
+
+#define GPIO_LED_RED GPIO_LD1
+#define GPIO_LED_GREEN GPIO_LD2
+#define GPIO_LED_BLUE GPIO_LD3
+
+/* PMIC - MC34PF1550A4EP */
+
+#define GPIO_PF1550_STBNY (GPIO_OUTPUT | GPIO_PUSHPULL | GPIO_SPEED_50MHz | \
+ GPIO_OUTPUT_CLEAR | GPIO_PORTJ | GPIO_PIN0)
+#define GPIO_PF1550_INT (GPIO_INPUT | GPIO_FLOAT | GPIO_EXTI | \
+ GPIO_PORTK | GPIO_PIN0)
+
+/****************************************************************************
+ * Public Function Prototypes
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: stm32_bringup
+ *
+ * Description:
+ * Perform architecture-specific initialization
+ *
+ * CONFIG_BOARD_LATE_INITIALIZE=y :
+ * Called from board_late_initialize().
+ *
+ * CONFIG_BOARD_LATE_INITIALIZE=n && CONFIG_BOARDCTL=y &&
+ * CONFIG_NSH_ARCHINIT:
+ * Called from the NSH library
+ *
+ ****************************************************************************/
+
+int stm32_bringup(void);
+
+#endif /* __BOARDS_ARM_STM32H7_PORTENTA_H7_SRC_PORTENTA_H7_H */
diff --git a/boards/arm/stm32h7/portenta-h7/src/stm32_appinitialize.c
b/boards/arm/stm32h7/portenta-h7/src/stm32_appinitialize.c
new file mode 100644
index 00000000000..05fc9961493
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/stm32_appinitialize.c
@@ -0,0 +1,78 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/src/stm32_appinitialize.c
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#include <sys/types.h>
+#include <nuttx/board.h>
+
+#include "portenta-h7.h"
+
+/****************************************************************************
+ * Pre-processor Definitions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Public Functions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: board_app_initialize
+ *
+ * Description:
+ * Perform application specific initialization. This function is never
+ * called directly from application code, but only indirectly via the
+ * (non-standard) boardctl() interface using the command BOARDIOC_INIT.
+ *
+ * Input Parameters:
+ * arg - The boardctl() argument is passed to the board_app_initialize()
+ * implementation without modification. The argument has no
+ * meaning to NuttX; the meaning of the argument is a contract
+ * between the board-specific initialization logic and the
+ * matching application logic. The value could be such things as a
+ * mode enumeration value, a set of DIP switch switch settings, a
+ * pointer to configuration data read from a file or serial FLASH,
+ * or whatever you would like to do with it. Every implementation
+ * should accept zero/NULL as a default configuration.
+ *
+ * Returned Value:
+ * Zero (OK) is returned on success; a negated errno value is returned on
+ * any failure to indicate the nature of the failure.
+ *
+ ****************************************************************************/
+
+int board_app_initialize(uintptr_t arg)
+{
+#ifdef CONFIG_BOARD_LATE_INITIALIZE
+ /* Board initialization already performed by board_late_initialize() */
+
+ return OK;
+#else
+ /* Perform board-specific initialization */
+
+ return stm32_bringup();
+#endif
+}
diff --git a/boards/arm/stm32h7/portenta-h7/src/stm32_autoleds.c
b/boards/arm/stm32h7/portenta-h7/src/stm32_autoleds.c
new file mode 100644
index 00000000000..33e06d34607
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/stm32_autoleds.c
@@ -0,0 +1,175 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/src/stm32_autoleds.c
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#include <stdbool.h>
+#include <debug.h>
+
+#include <sys/param.h>
+
+#include <nuttx/board.h>
+#include <arch/board/board.h>
+
+#include "stm32_gpio.h"
+#include "portenta-h7.h"
+
+#ifdef CONFIG_ARCH_LEDS
+
+#ifdef CONFIG_ARCH_CHIP_STM32H7_CORTEXM4
+# error autoleds not supported for M4 core now
+#endif
+
+/****************************************************************************
+ * Private Data
+ ****************************************************************************/
+
+/* Indexed by BOARD_LED_<color> */
+
+static const uint32_t g_ledmap[BOARD_NLEDS] =
+{
+ GPIO_LED_GREEN,
+ GPIO_LED_BLUE,
+ GPIO_LED_RED,
+};
+
+static bool g_initialized;
+
+/****************************************************************************
+ * Private Functions
+ ****************************************************************************/
+
+static void phy_set_led(int led, bool state)
+{
+ /* Active High */
+
+ stm32_gpiowrite(g_ledmap[led], state);
+}
+
+/****************************************************************************
+ * Public Functions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: board_autoled_initialize
+ ****************************************************************************/
+
+void board_autoled_initialize(void)
+{
+ int i;
+
+ /* Configure the LD1 GPIO for output. Initial state is OFF */
+
+ for (i = 0; i < nitems(g_ledmap); i++)
+ {
+ stm32_configgpio(g_ledmap[i]);
+ }
+}
+
+/****************************************************************************
+ * Name: board_autoled_on
+ ****************************************************************************/
+
+void board_autoled_on(int led)
+{
+ switch (led)
+ {
+ default:
+ break;
+
+ case LED_HEAPALLOCATE:
+ phy_set_led(BOARD_LED_BLUE, true);
+ break;
+
+ case LED_IRQSENABLED:
+ phy_set_led(BOARD_LED_BLUE, false);
+ phy_set_led(BOARD_LED_GREEN, true);
+ break;
+
+ case LED_STACKCREATED:
+ phy_set_led(BOARD_LED_GREEN, true);
+ phy_set_led(BOARD_LED_BLUE, true);
+ g_initialized = true;
+ break;
+
+ case LED_INIRQ:
+ phy_set_led(BOARD_LED_BLUE, true);
+ break;
+
+ case LED_SIGNAL:
+ phy_set_led(BOARD_LED_GREEN, true);
+ break;
+
+ case LED_ASSERTION:
+ phy_set_led(BOARD_LED_RED, true);
+ phy_set_led(BOARD_LED_BLUE, true);
+ break;
+
+ case LED_PANIC:
+ phy_set_led(BOARD_LED_RED, true);
+ break;
+
+ case LED_IDLE:
+ phy_set_led(BOARD_LED_RED, true);
+ break;
+ }
+}
+
+/****************************************************************************
+ * Name: board_autoled_off
+ ****************************************************************************/
+
+void board_autoled_off(int led)
+{
+ switch (led)
+ {
+ default:
+ break;
+
+ case LED_SIGNAL:
+ phy_set_led(BOARD_LED_GREEN, false);
+ break;
+
+ case LED_INIRQ:
+ phy_set_led(BOARD_LED_BLUE, false);
+ break;
+
+ case LED_ASSERTION:
+ phy_set_led(BOARD_LED_RED, false);
+ phy_set_led(BOARD_LED_BLUE, false);
+ break;
+
+ case LED_PANIC:
+ phy_set_led(BOARD_LED_RED, false);
+ break;
+
+ case LED_IDLE:
+ phy_set_led(BOARD_LED_RED, false);
+ break;
+ }
+}
+
+#endif /* CONFIG_ARCH_LEDS */
diff --git a/boards/arm/stm32h7/portenta-h7/src/stm32_boot.c
b/boards/arm/stm32h7/portenta-h7/src/stm32_boot.c
new file mode 100644
index 00000000000..8d6b03ff8f7
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/stm32_boot.c
@@ -0,0 +1,81 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/src/stm32_boot.c
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#include <debug.h>
+
+#include <nuttx/board.h>
+#include <arch/board/board.h>
+
+#include "arm_internal.h"
+#include "stm32_start.h"
+#include "portenta-h7.h"
+
+/****************************************************************************
+ * Public Functions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: stm32_boardinitialize
+ *
+ * Description:
+ * All STM32 architectures must provide the following entry point.
+ * This entry point is called early in the initialization -- after all
+ * memory has been configured and mapped but before any devices have been
+ * initialized.
+ *
+ ****************************************************************************/
+
+void stm32_boardinitialize(void)
+{
+#ifdef CONFIG_ARCH_LEDS
+ /* Configure on-board LEDs if LED support has been selected. */
+
+ board_autoled_initialize();
+#endif
+}
+
+/****************************************************************************
+ * Name: board_late_initialize
+ *
+ * Description:
+ * If CONFIG_BOARD_LATE_INITIALIZE is selected, then an additional
+ * initialization call will be performed in the boot-up sequence to a
+ * function called board_late_initialize(). board_late_initialize()
+ * will be called immediately after up_initialize() is called and just
+ * before the initial application is started. This additional
+ * initialization phase may be used, for example, to initialize board-
+ * specific device drivers.
+ *
+ ****************************************************************************/
+
+#ifdef CONFIG_BOARD_LATE_INITIALIZE
+void board_late_initialize(void)
+{
+ stm32_bringup();
+}
+#endif
diff --git a/boards/arm/stm32h7/portenta-h7/src/stm32_bringup.c
b/boards/arm/stm32h7/portenta-h7/src/stm32_bringup.c
new file mode 100644
index 00000000000..a2aefc772e2
--- /dev/null
+++ b/boards/arm/stm32h7/portenta-h7/src/stm32_bringup.c
@@ -0,0 +1,155 @@
+/****************************************************************************
+ * boards/arm/stm32h7/portenta-h7/src/stm32_bringup.c
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership. The
+ * ASF licenses this file to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the
+ * License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ ****************************************************************************/
+
+/****************************************************************************
+ * Included Files
+ ****************************************************************************/
+
+#include <nuttx/config.h>
+
+#include <sys/types.h>
+#include <syslog.h>
+#include <errno.h>
+
+#include "stm32_i2c.h"
+
+#include <arch/board/board.h>
+
+#include <nuttx/fs/fs.h>
+
+#include "portenta-h7.h"
+
+/****************************************************************************
+ * Private Functions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: stm32_i2c_register
+ *
+ * Description:
+ * Register one I2C drivers for the I2C tool.
+ *
+ ****************************************************************************/
+
+#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL)
+static void stm32_i2c_register(int bus)
+{
+ struct i2c_master_s *i2c;
+ int ret;
+
+ i2c = stm32_i2cbus_initialize(bus);
+ if (i2c == NULL)
+ {
+ syslog(LOG_ERR, "ERROR: Failed to get I2C%d interface\n", bus);
+ }
+ else
+ {
+ ret = i2c_register(i2c, bus);
+ if (ret < 0)
+ {
+ syslog(LOG_ERR, "ERROR: Failed to register I2C%d driver: %d\n",
+ bus, ret);
+ stm32_i2cbus_uninitialize(i2c);
+ }
+ }
+}
+#endif
+
+/****************************************************************************
+ * Name: stm32_i2ctool
+ *
+ * Description:
+ * Register I2C drivers for the I2C tool.
+ *
+ ****************************************************************************/
+
+#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL)
+static void stm32_i2ctool(void)
+{
+#ifdef CONFIG_STM32H7_I2C1
+ stm32_i2c_register(1);
+#endif
+#ifdef CONFIG_STM32H7_I2C2
+ stm32_i2c_register(2);
+#endif
+#ifdef CONFIG_STM32H7_I2C3
+ stm32_i2c_register(3);
+#endif
+#ifdef CONFIG_STM32H7_I2C4
+ stm32_i2c_register(4);
+#endif
+}
+#endif
+
+/****************************************************************************
+ * Public Functions
+ ****************************************************************************/
+
+/****************************************************************************
+ * Name: stm32_bringup
+ *
+ * Description:
+ * Perform architecture-specific initialization
+ *
+ * CONFIG_BOARD_LATE_INITIALIZE=y :
+ * Called from board_late_initialize().
+ *
+ * CONFIG_BOARD_LATE_INITIALIZE=n && CONFIG_BOARDCTL=y &&
+ * CONFIG_NSH_ARCHINIT:
+ * Called from the NSH library
+ *
+ ****************************************************************************/
+
+int stm32_bringup(void)
+{
+ int ret = OK;
+
+ UNUSED(ret);
+
+#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL)
+ stm32_i2ctool();
+#endif
+
+#ifdef CONFIG_FS_PROCFS
+ /* Mount the procfs file system */
+
+ ret = nx_mount(NULL, STM32_PROCFS_MOUNTPOINT, "procfs", 0, NULL);
+ if (ret < 0)
+ {
+ syslog(LOG_ERR,
+ "ERROR: Failed to mount the PROC filesystem: %d\n", ret);
+ }
+#endif
+
+#ifdef CONFIG_FS_TMPFS
+ /* Mount the tmpfs file system */
+
+ ret = nx_mount(NULL, CONFIG_LIBC_TMPDIR, "tmpfs", 0, NULL);
+ if (ret < 0)
+ {
+ syslog(LOG_ERR, "ERROR: Failed to mount tmpfs at %s: %d\n",
+ CONFIG_LIBC_TMPDIR, ret);
+ }
+#endif
+
+ return OK;
+}