diff --git a/cmake/modules/CompilerFlags.cmake b/cmake/modules/CompilerFlags.cmake index 62ed575810a..f5d5e142e3a 100644 --- a/cmake/modules/CompilerFlags.cmake +++ b/cmake/modules/CompilerFlags.cmake @@ -23,6 +23,9 @@ endif() string(TOLOWER "${CMAKE_BUILD_TYPE}" CMAKE_BUILD_TYPE) if(CMAKE_BUILD_TYPE STREQUAL "debug") set(KBUILD_FLAGS "${FALCO_EXTRA_DEBUG_FLAGS} ${FALCO_EXTRA_FEATURE_FLAGS}") +elseif(CMAKE_BUILD_TYPE STREQUAL "relwithdebinfo") + set(KBUILD_FLAGS "${FALCO_EXTRA_FEATURE_FLAGS}") + add_definitions(-DBUILD_TYPE_RELWITHDEBINFO) else() set(CMAKE_BUILD_TYPE "release") set(KBUILD_FLAGS "${FALCO_EXTRA_FEATURE_FLAGS}") @@ -85,6 +88,17 @@ if(NOT MSVC) set(CMAKE_C_FLAGS_RELEASE "-O3 -fno-strict-aliasing -DNDEBUG") set(CMAKE_CXX_FLAGS_RELEASE "-O3 -fno-strict-aliasing -DNDEBUG") + set(CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELEASE} -g") + set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELEASE} -g") + + # Add linker flags to generate separate debug files + set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO + "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO} -Wl,--build-id" + ) + set(CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO + "${CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO} -Wl,--build-id" + ) + else() # MSVC set(MINIMAL_BUILD ON) set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$:Debug>") @@ -99,6 +113,13 @@ else() # MSVC set(FALCOSECURITY_LIBS_COMMON_FLAGS "/EHsc /W3 /Zi /std:c++17") set(FALCOSECURITY_LIBS_DEBUG_FLAGS "/MTd /Od") set(FALCOSECURITY_LIBS_RELEASE_FLAGS "/MT") + set(FALCOSECURITY_LIBS_RELWITHDEBINFO_FLAGS "/MT /Zi") + + # Ensure linker generates PDB files for MSVC + set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO} /DEBUG") + set(CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO + "${CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO} /DEBUG" + ) set(CMAKE_C_FLAGS "${FALCOSECURITY_LIBS_COMMON_FLAGS}") set(CMAKE_CXX_FLAGS "${FALCOSECURITY_LIBS_COMMON_FLAGS}") @@ -109,4 +130,7 @@ else() # MSVC set(CMAKE_C_FLAGS_RELEASE "${FALCOSECURITY_LIBS_RELEASE_FLAGS}") set(CMAKE_CXX_FLAGS_RELEASE "${FALCOSECURITY_LIBS_RELEASE_FLAGS}") + set(CMAKE_C_FLAGS_RELWITHDEBINFO "${FALCOSECURITY_LIBS_RELWITHDEBINFO_FLAGS}") + set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${FALCOSECURITY_LIBS_RELWITHDEBINFO_FLAGS}") + endif() diff --git a/userspace/falco/CMakeLists.txt b/userspace/falco/CMakeLists.txt index d6c399059e1..60cf976de35 100644 --- a/userspace/falco/CMakeLists.txt +++ b/userspace/falco/CMakeLists.txt @@ -194,6 +194,24 @@ if(MUSL_OPTIMIZED_BUILD AND CMAKE_BUILD_TYPE STREQUAL "release") ) endif() +if(CMAKE_BUILD_TYPE STREQUAL "relwithdebinfo" AND NOT WIN32) + find_program(OBJCOPY_EXECUTABLE NAMES objcopy) + if(OBJCOPY_EXECUTABLE) + add_custom_command( + TARGET falco + POST_BUILD + COMMAND ${OBJCOPY_EXECUTABLE} --only-keep-debug $ + $.debug + COMMAND ${OBJCOPY_EXECUTABLE} --strip-debug --strip-unneeded $ + COMMAND ${OBJCOPY_EXECUTABLE} --add-gnu-debuglink=$.debug + $ + COMMENT "Generating separate debug file for falco" + ) + else() + message(WARNING "objcopy not found; separate debug files will not be generated.") + endif() +endif() + if(EMSCRIPTEN) install( FILES "$/falco.js" "$/falco.wasm"