mirror of
https://github.com/espressif/esp-idf.git
synced 2025-07-30 18:57:19 +02:00
gcov: Fixes not linked gcov rtio functions
This commit is contained in:
@ -1,4 +1,4 @@
|
|||||||
set(srcs
|
set(srcs
|
||||||
"app_trace.c"
|
"app_trace.c"
|
||||||
"app_trace_util.c"
|
"app_trace_util.c"
|
||||||
"host_file_io.c"
|
"host_file_io.c"
|
||||||
@ -12,7 +12,7 @@ if(CONFIG_SYSVIEW_ENABLE)
|
|||||||
sys_view/SEGGER
|
sys_view/SEGGER
|
||||||
sys_view/Sample/OS)
|
sys_view/Sample/OS)
|
||||||
|
|
||||||
list(APPEND srcs
|
list(APPEND srcs
|
||||||
"sys_view/SEGGER/SEGGER_SYSVIEW.c"
|
"sys_view/SEGGER/SEGGER_SYSVIEW.c"
|
||||||
"sys_view/Sample/Config/SEGGER_SYSVIEW_Config_FreeRTOS.c"
|
"sys_view/Sample/Config/SEGGER_SYSVIEW_Config_FreeRTOS.c"
|
||||||
"sys_view/Sample/OS/SEGGER_SYSVIEW_FreeRTOS.c"
|
"sys_view/Sample/OS/SEGGER_SYSVIEW_FreeRTOS.c"
|
||||||
@ -30,7 +30,14 @@ idf_component_register(SRCS "${srcs}"
|
|||||||
PRIV_REQUIRES soc
|
PRIV_REQUIRES soc
|
||||||
LDFRAGMENTS linker.lf)
|
LDFRAGMENTS linker.lf)
|
||||||
|
|
||||||
# disable --coverage for this component, as it is used as transport
|
|
||||||
# for gcov
|
if(CONFIG_ESP32_GCOV_ENABLE)
|
||||||
target_compile_options(${COMPONENT_LIB} PRIVATE "-fno-profile-arcs" "-fno-test-coverage")
|
# disable --coverage for this component, as it is used as transport
|
||||||
target_link_libraries(${COMPONENT_LIB} PUBLIC gcov ${LIBC} ${LIBM} gcc)
|
# for gcov
|
||||||
|
target_compile_options(${COMPONENT_LIB} PRIVATE "-fno-profile-arcs" "-fno-test-coverage")
|
||||||
|
|
||||||
|
# Force app_trace to also appear later than gcov in link line
|
||||||
|
idf_component_get_property(app_trace app_trace COMPONENT_LIB)
|
||||||
|
target_link_libraries(${COMPONENT_LIB} INTERFACE
|
||||||
|
"-Wl,--undefined=gcov_rtio_atexit" $<TARGET_FILE:${app_trace}> gcov $<TARGET_FILE:${app_trace}> c)
|
||||||
|
endif()
|
||||||
|
@ -8,11 +8,7 @@ COMPONENT_ADD_INCLUDEDIRS = include
|
|||||||
|
|
||||||
COMPONENT_ADD_LDFLAGS = -lapp_trace
|
COMPONENT_ADD_LDFLAGS = -lapp_trace
|
||||||
|
|
||||||
# do not produce gcov info for this module, it is used as transport for gcov
|
|
||||||
CFLAGS := $(subst --coverage,,$(CFLAGS))
|
|
||||||
|
|
||||||
ifdef CONFIG_SYSVIEW_ENABLE
|
ifdef CONFIG_SYSVIEW_ENABLE
|
||||||
|
|
||||||
COMPONENT_ADD_INCLUDEDIRS += \
|
COMPONENT_ADD_INCLUDEDIRS += \
|
||||||
sys_view/Config \
|
sys_view/Config \
|
||||||
sys_view/SEGGER \
|
sys_view/SEGGER \
|
||||||
@ -26,7 +22,12 @@ COMPONENT_SRCDIRS += \
|
|||||||
sys_view/esp32 \
|
sys_view/esp32 \
|
||||||
sys_view/ext
|
sys_view/ext
|
||||||
else
|
else
|
||||||
|
ifdef CONFIG_ESP32_GCOV_ENABLE
|
||||||
|
# do not produce gcov info for this module, it is used as transport for gcov
|
||||||
|
CFLAGS := $(subst --coverage,,$(CFLAGS))
|
||||||
|
COMPONENT_ADD_LDFLAGS += -Wl,--undefined=gcov_rtio_atexit
|
||||||
COMPONENT_SRCDIRS += gcov
|
COMPONENT_SRCDIRS += gcov
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
COMPONENT_ADD_LDFRAGMENTS += linker.lf
|
COMPONENT_ADD_LDFRAGMENTS += linker.lf
|
||||||
|
Reference in New Issue
Block a user