From 906978d7f2880faad4d3c2956ae1192eaa6603c5 Mon Sep 17 00:00:00 2001 From: Jamie Smith Date: Sun, 15 Sep 2024 11:18:22 -0700 Subject: [PATCH] STM32H7: Fix wrong address for DTCM in linker script --- platform/source/mbed_board.c | 3 +- .../TARGET_STM32H723xG/cmsis_nvic.h | 32 +---------------- .../TARGET_STM32H725xE/cmsis_nvic.h | 32 +---------------- .../TARGET_STM32H735xG/cmsis_nvic.h | 21 ------------ .../TOOLCHAIN_GCC_ARM/STM32H743xI.ld | 2 +- .../TARGET_STM32H743xI/cmsis_nvic.h | 34 +------------------ .../TARGET_STM32H750xB/cmsis_nvic.h | 18 +--------- .../TARGET_STM32H753xI/cmsis_nvic.h | 34 +------------------ .../TARGET_STM32H7A3xIQ/cmsis_nvic.h | 18 +--------- .../TARGET_STM32H7B3xIQ/cmsis_nvic.h | 18 +--------- tools/cmake/CheckPythonPackage.cmake | 4 ++- tools/cmake/mbed_set_linker_script.cmake | 5 +++ 12 files changed, 18 insertions(+), 203 deletions(-) diff --git a/platform/source/mbed_board.c b/platform/source/mbed_board.c index 47c92e06145..f12c49e7990 100644 --- a/platform/source/mbed_board.c +++ b/platform/source/mbed_board.c @@ -28,8 +28,9 @@ WEAK MBED_NORETURN void mbed_die(void) #if !defined(TARGET_EFM32) core_util_critical_section_enter(); #endif - gpio_t led_err; + #ifdef LED1 + gpio_t led_err; gpio_init_out(&led_err, LED1); #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H723xG/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H723xG/cmsis_nvic.h index 161c860e7a8..65a1d222020 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H723xG/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H723xG/cmsis_nvic.h @@ -17,36 +17,6 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x100000 // 1 MB -#endif - -// 0x20000000 - 0x2001FFFF 128K DTCM -// 0x24000000 - 0x2404FFFF 320K AXI SRAM -// 0x30000000 - 0x30003FFF 16K SRAM1 -// 0x30004000 - 0x30007FFF 16K SRAM2 -// 0x38000000 - 0x38003FFF 16K SRAM4 - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x20000000 -#endif - -#if !defined(MBED_RAM_SIZE) -#define MBED_RAM_SIZE 0x20000 // 128 KB -#endif - -#if !defined(MBED_RAM1_START) -#define MBED_RAM1_START 0x24000000 -#endif - -#if !defined(MBED_RAM1_SIZE) -#define MBED_RAM1_SIZE 0x50000 // 320 KB -#endif - #define NVIC_NUM_VECTORS 180 -#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H725xE/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H725xE/cmsis_nvic.h index dc67d2ab07c..05a41ecee71 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H725xE/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H725xE/cmsis_nvic.h @@ -17,37 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x80000 // 512 KB -#endif - -// 0x38000000 - 0x38003FFF 16K SRAM4 -// 0x30004000 - 0x30007FFF 16K SRAM2 -// 0x30000000 - 0x30003FFF 16K SRAM1 -// 0x24000000 - 0x2404FFFF 320K AXI SRAM -// 0x20000000 - 0x2001FFFF 128K DTCM - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x20000000 -#endif - -#if !defined(MBED_RAM_SIZE) -#define MBED_RAM_SIZE 0x20000 // 128 KB -#endif - -#if !defined(MBED_RAM1_START) -#define MBED_RAM1_START 0x24000000 -#endif - -#if !defined(MBED_RAM1_SIZE) -#define MBED_RAM1_SIZE 0x50000 // 320 KB -#endif - #define NVIC_NUM_VECTORS 180 -#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H735xG/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H735xG/cmsis_nvic.h index e981df8aaa0..7a89564f452 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H735xG/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H735xG/cmsis_nvic.h @@ -17,27 +17,6 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x100000 // 1 MB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x24000000 -#endif - -#if !defined(MBED_RAM_SIZE) -// 0x38000000 - 0x38003FFF 16K SRAM4 -// 0x30004000 - 0x30007FFF 16K SRAM2 -// 0x30000000 - 0x30003FFF 16K SRAM1 -// 0x24000000 - 0x2404FFFF 320K AXI SRAM -// 0x20000000 - 0x2001FFFF 128K DTCM -#define MBED_RAM_SIZE 0x50000 // 320 KB -#endif - #define NVIC_NUM_VECTORS 180 #define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/TOOLCHAIN_GCC_ARM/STM32H743xI.ld b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/TOOLCHAIN_GCC_ARM/STM32H743xI.ld index 10f50e391cb..62fadc887a3 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/TOOLCHAIN_GCC_ARM/STM32H743xI.ld +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/TOOLCHAIN_GCC_ARM/STM32H743xI.ld @@ -119,7 +119,7 @@ SECTIONS __etext = .; _sidata = .; - + .crash_data_ram : { . = ALIGN(8); diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/cmsis_nvic.h index 05f9eacac71..9eb1b99bead 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H743xI/cmsis_nvic.h @@ -17,39 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -// 0x0x08000000-0x080FFFFF Bank1 (8 x 128K sectors) -// 0x0x08100000-0x081FFFFF Bank2 (8 x 128K sectors) -#define MBED_ROM_SIZE 0x200000 // 2.0 MB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x20000000 -#endif - -#if !defined(MBED_RAM_SIZE) -// 0x38000000 - 0x3800FFFF 64K SRAM4 -// 0x30040000 - 0x30047FFF 32K SRAM3 -// 0x30020000 - 0x3003FFFF 128K SRAM2 -// 0x30000000 - 0x3001FFFF 128K SRAM1 -// 0x24000000 - 0x2407FFFF 512K AXI SRAM -// 0x20000000 - 0x2001FFFF 128K DTCM -#define MBED_RAM_SIZE 0x20000 // 128 KB -#endif - -#if !defined(MBED_RAM1_START) -#define MBED_RAM1_START 0x24000000 -#endif - -#if !defined(MBED_RAM1_SIZE) -#define MBED_RAM1_SIZE 0x80000 // 512 KB -#endif - #define NVIC_NUM_VECTORS 166 -#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H750xB/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H750xB/cmsis_nvic.h index 8615c071bc6..c4ef5a9a05f 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H750xB/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H750xB/cmsis_nvic.h @@ -17,23 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x20000 // 128 KB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x24000000 -#endif - -#if !defined(MBED_RAM_SIZE) -#define MBED_RAM_SIZE 0x80000 // 512 KB -#endif - #define NVIC_NUM_VECTORS 168 -#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H753xI/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H753xI/cmsis_nvic.h index 05f9eacac71..9eb1b99bead 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H753xI/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H753xI/cmsis_nvic.h @@ -17,39 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -// 0x0x08000000-0x080FFFFF Bank1 (8 x 128K sectors) -// 0x0x08100000-0x081FFFFF Bank2 (8 x 128K sectors) -#define MBED_ROM_SIZE 0x200000 // 2.0 MB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x20000000 -#endif - -#if !defined(MBED_RAM_SIZE) -// 0x38000000 - 0x3800FFFF 64K SRAM4 -// 0x30040000 - 0x30047FFF 32K SRAM3 -// 0x30020000 - 0x3003FFFF 128K SRAM2 -// 0x30000000 - 0x3001FFFF 128K SRAM1 -// 0x24000000 - 0x2407FFFF 512K AXI SRAM -// 0x20000000 - 0x2001FFFF 128K DTCM -#define MBED_RAM_SIZE 0x20000 // 128 KB -#endif - -#if !defined(MBED_RAM1_START) -#define MBED_RAM1_START 0x24000000 -#endif - -#if !defined(MBED_RAM1_SIZE) -#define MBED_RAM1_SIZE 0x80000 // 512 KB -#endif - #define NVIC_NUM_VECTORS 166 -#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_START +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7A3xIQ/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7A3xIQ/cmsis_nvic.h index 9f347d3fda1..48f9503974e 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7A3xIQ/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7A3xIQ/cmsis_nvic.h @@ -17,23 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x200000 // 2.0 MB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x24000000 -#endif - -#if !defined(MBED_RAM_SIZE) -#define MBED_RAM_SIZE 0x100000 // 1.0 MB -#endif - #define NVIC_NUM_VECTORS 172 -#define NVIC_RAM_VECTOR_ADDRESS 0x20000000 +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7B3xIQ/cmsis_nvic.h b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7B3xIQ/cmsis_nvic.h index 9f347d3fda1..48f9503974e 100644 --- a/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7B3xIQ/cmsis_nvic.h +++ b/targets/TARGET_STM/TARGET_STM32H7/TARGET_STM32H7B3xIQ/cmsis_nvic.h @@ -17,23 +17,7 @@ #ifndef MBED_CMSIS_NVIC_H #define MBED_CMSIS_NVIC_H -#if !defined(MBED_ROM_START) -#define MBED_ROM_START 0x8000000 -#endif - -#if !defined(MBED_ROM_SIZE) -#define MBED_ROM_SIZE 0x200000 // 2.0 MB -#endif - -#if !defined(MBED_RAM_START) -#define MBED_RAM_START 0x24000000 -#endif - -#if !defined(MBED_RAM_SIZE) -#define MBED_RAM_SIZE 0x100000 // 1.0 MB -#endif - #define NVIC_NUM_VECTORS 172 -#define NVIC_RAM_VECTOR_ADDRESS 0x20000000 +#define NVIC_RAM_VECTOR_ADDRESS MBED_RAM_BANK_SRAM_DTC_START #endif diff --git a/tools/cmake/CheckPythonPackage.cmake b/tools/cmake/CheckPythonPackage.cmake index 9a886dc6086..71f3b9ed85e 100644 --- a/tools/cmake/CheckPythonPackage.cmake +++ b/tools/cmake/CheckPythonPackage.cmake @@ -27,7 +27,9 @@ function(check_python_package PACKAGENAME OUTPUT_VAR) set(PY_INTERP_FOR_${OUTPUT_VAR} ${Python3_EXECUTABLE} CACHE INTERNAL "The python interpreter used to run the ${OUTPUT_VAR} check" FORCE) execute_process( - COMMAND ${Python3_EXECUTABLE} -c "import ${PACKAGENAME}" RESULT_VARIABLE PACKAGECHECK_RESULT + COMMAND ${Python3_EXECUTABLE} -c "import ${PACKAGENAME}" + RESULT_VARIABLE PACKAGECHECK_RESULT + ERROR_QUIET ) if(${PACKAGECHECK_RESULT} EQUAL 0) diff --git a/tools/cmake/mbed_set_linker_script.cmake b/tools/cmake/mbed_set_linker_script.cmake index 5ab3a821f6f..8c48e0bd2ca 100644 --- a/tools/cmake/mbed_set_linker_script.cmake +++ b/tools/cmake/mbed_set_linker_script.cmake @@ -29,6 +29,11 @@ function(mbed_setup_linker_script mbed_os_target mbed_baremetal_target target_de # Find the path to the desired linker script # (the property should be set on both the OS and baremetal targets in a sane world) + get_property(RAW_LINKER_SCRIPT_PATHS_SET TARGET ${mbed_baremetal_target} PROPERTY INTERFACE_MBED_LINKER_SCRIPT SET) + if(NOT RAW_LINKER_SCRIPT_PATHS_SET) + message(FATAL_ERROR "No linker script has been set for the Mbed target. Ensure that code is calling mbed_set_linker_script() for the mbed- target or one of its parents") + endif() + get_property(RAW_LINKER_SCRIPT_PATHS TARGET ${mbed_baremetal_target} PROPERTY INTERFACE_MBED_LINKER_SCRIPT) # Check if two (or more) different linker scripts got used