From b35c745c4f1bd148c95cada8a927ed37ee3ac58b Mon Sep 17 00:00:00 2001 From: Renz Bagaporo Date: Fri, 31 Aug 2018 17:32:24 +0800 Subject: [PATCH 1/2] ulp: check assembler version --- components/ulp/cmake/CMakeLists.txt | 24 +++++++++++++++++++++++- components/ulp/component_ulp_common.mk | 10 ++++++++++ components/ulp/toolchain_ulp_version.mk | 1 + 3 files changed, 34 insertions(+), 1 deletion(-) create mode 100644 components/ulp/toolchain_ulp_version.mk diff --git a/components/ulp/cmake/CMakeLists.txt b/components/ulp/cmake/CMakeLists.txt index c18867e1f9..7eeef033e8 100644 --- a/components/ulp/cmake/CMakeLists.txt +++ b/components/ulp/cmake/CMakeLists.txt @@ -3,6 +3,28 @@ cmake_minimum_required(VERSION 3.5) include(${IDF_PATH}/tools/cmake/utilities.cmake) project(${ULP_APP_NAME} ASM C) +set(version_pattern "[a-z0-9\.-]+") + +# Check assembler version +execute_process( + COMMAND ${CMAKE_ASM_COMPILER} --version + OUTPUT_VARIABLE as_output + ERROR_QUIET) + +string(REGEX MATCH "GNU assembler \\(GNU Binutils\\) (${version_pattern})" as_version ${as_output}) +set(as_version ${CMAKE_MATCH_1}) + +# Check the supported assembler version +file(STRINGS ${IDF_PATH}/components/ulp/toolchain_ulp_version.mk version_file_contents) +string(REGEX MATCH "SUPPORTED_ULP_ASSEMBLER_VERSION = (${version_pattern})" as_supported_version ${version_file_contents}) +set(as_supported_version ${CMAKE_MATCH_1}) + +if(NOT as_version STREQUAL as_supported_version) + message(WARNING "WARNING: ULP assembler version ${as_version} is not supported. Expected to see version: \ + ${as_supported_version}. Please check ESP-IDF ULP setup instructions and update \ + the toolchain, or proceed at your own risk.") +endif() + set(ULP_MAP_GEN ${IDF_PATH}/components/ulp/esp32ulp_mapgen.py) set(ULP_LD_TEMPLATE ${IDF_PATH}/components/ulp/ld/esp32.ulp.ld) @@ -71,7 +93,7 @@ add_custom_command( OUTPUT ${ULP_APP_NAME}.ld ${ULP_APP_NAME}.h # ULP files being built. add_custom_target(build DEPENDS ${ULP_APP_NAME} ${ULP_APP_NAME}.bin ${ULP_APP_NAME}.sym - ${CMAKE_CURRENT_BINARY_DIR}/${ULP_APP_NAME}.ld + ${CMAKE_CURRENT_BINARY_DIR}/${ULP_APP_NAME}.ld ${CMAKE_CURRENT_BINARY_DIR}/${ULP_APP_NAME}.h WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}) diff --git a/components/ulp/component_ulp_common.mk b/components/ulp/component_ulp_common.mk index e051af0789..ba566e9df1 100644 --- a/components/ulp/component_ulp_common.mk +++ b/components/ulp/component_ulp_common.mk @@ -24,6 +24,16 @@ ULP_PREPROCESSOR_ARGS := \ -include $(ULP_DEP) +# Check the assembler version +include $(IDF_PATH)/components/ulp/toolchain_ulp_version.mk +ULP_AS_VER := $(shell $(ULP_AS) --version | sed -E -n 's|GNU assembler \(GNU Binutils\) ([a-z0-9\.-]+)|\1|gp') + +ifeq (,$(findstring $(ULP_AS_VER), $(SUPPORTED_ULP_ASSEMBLER_VERSION))) +$(info WARNING: ULP assembler version $(ULP_AS_VER) is not supported.) +$(info Expected to see version: $(SUPPORTED_ULP_ASSEMBLER_VERSION)) +$(info Please check ESP-IDF ULP setup instructions and update the toolchain, or proceed at your own risk.) +endif + # Preprocess LD script used to link ULP program $(ULP_LD_SCRIPT): $(ULP_LD_TEMPLATE) $(summary) CPP $(patsubst $(PWD)/%,%,$(CURDIR))/$@ diff --git a/components/ulp/toolchain_ulp_version.mk b/components/ulp/toolchain_ulp_version.mk new file mode 100644 index 0000000000..1ca859c894 --- /dev/null +++ b/components/ulp/toolchain_ulp_version.mk @@ -0,0 +1 @@ +SUPPORTED_ULP_ASSEMBLER_VERSION = 2.28.51.20170517 \ No newline at end of file From bec3bb3ba44a4bf713379ebed90944a1bf4607c4 Mon Sep 17 00:00:00 2001 From: Renz Christian Bagaporo Date: Tue, 27 Nov 2018 19:31:46 +0800 Subject: [PATCH 2/2] make, cmake: display ulp assembler version --- components/ulp/cmake/CMakeLists.txt | 3 +++ components/ulp/component_ulp_common.mk | 3 +++ 2 files changed, 6 insertions(+) diff --git a/components/ulp/cmake/CMakeLists.txt b/components/ulp/cmake/CMakeLists.txt index 7eeef033e8..b4cfcd4baf 100644 --- a/components/ulp/cmake/CMakeLists.txt +++ b/components/ulp/cmake/CMakeLists.txt @@ -14,6 +14,9 @@ execute_process( string(REGEX MATCH "GNU assembler \\(GNU Binutils\\) (${version_pattern})" as_version ${as_output}) set(as_version ${CMAKE_MATCH_1}) +message(STATUS "Building ULP app ${ULP_APP_NAME}") +message(STATUS "ULP assembler version: ${as_version}") + # Check the supported assembler version file(STRINGS ${IDF_PATH}/components/ulp/toolchain_ulp_version.mk version_file_contents) string(REGEX MATCH "SUPPORTED_ULP_ASSEMBLER_VERSION = (${version_pattern})" as_supported_version ${version_file_contents}) diff --git a/components/ulp/component_ulp_common.mk b/components/ulp/component_ulp_common.mk index ba566e9df1..a4174d1e1d 100644 --- a/components/ulp/component_ulp_common.mk +++ b/components/ulp/component_ulp_common.mk @@ -28,6 +28,9 @@ ULP_PREPROCESSOR_ARGS := \ include $(IDF_PATH)/components/ulp/toolchain_ulp_version.mk ULP_AS_VER := $(shell $(ULP_AS) --version | sed -E -n 's|GNU assembler \(GNU Binutils\) ([a-z0-9\.-]+)|\1|gp') +$(info Building ULP app $(ULP_APP_NAME)) +$(info ULP assembler version: $(ULP_AS_VER)) + ifeq (,$(findstring $(ULP_AS_VER), $(SUPPORTED_ULP_ASSEMBLER_VERSION))) $(info WARNING: ULP assembler version $(ULP_AS_VER) is not supported.) $(info Expected to see version: $(SUPPORTED_ULP_ASSEMBLER_VERSION))