CMake: add ASAN build configuration

Add ASAN build configuration, based on debug with ASAN
enabled. This might help finding crashes like in
https://github.com/OpenVPN/openvpn-gui/issues/548

Signed-off-by: Lev Stipakov <lev@openvpn.net>
pull/652/head
Lev Stipakov 1 year ago committed by Lev Stipakov
parent ab3c42b75e
commit 441280a8ff

@ -31,6 +31,9 @@ jobs:
strategy: strategy:
matrix: matrix:
arch: [x86, x64, arm64] arch: [x86, x64, arm64]
conf:
- name: ""
value: "release"
ovpn3: ovpn3:
- preset: "" - preset: ""
name: "" name: ""
@ -38,8 +41,13 @@ jobs:
- preset: -ovpn3 - preset: -ovpn3
name: "- ovpn3" name: "- ovpn3"
upload_name: "_ovpn3" upload_name: "_ovpn3"
include:
- conf:
name: " ASAN"
value: "asan"
arch: x64
name: 'msvc - ${{matrix.arch}} ${{ matrix.ovpn3.name }}' name: 'msvc - ${{matrix.arch}} ${{ matrix.ovpn3.name }}${{ matrix.conf.name }}'
runs-on: windows-latest runs-on: windows-latest
steps: steps:
- uses: actions/checkout@v3 - uses: actions/checkout@v3
@ -55,14 +63,14 @@ jobs:
uses: lukka/run-cmake@v10 uses: lukka/run-cmake@v10
with: with:
configurePreset: '${{ matrix.arch }}${{ matrix.ovpn3.preset }}' configurePreset: '${{ matrix.arch }}${{ matrix.ovpn3.preset }}'
buildPreset: '${{ matrix.arch }}-release${{ matrix.ovpn3.preset }}' buildPreset: '${{ matrix.arch }}-${{ matrix.conf.value }}${{ matrix.ovpn3.preset }}'
- uses: actions/upload-artifact@v3 - uses: actions/upload-artifact@v3
with: with:
name: openvpn-gui_${{ matrix.arch }}${{ matrix.ovpn3.upload_name }} name: openvpn-gui_${{ matrix.arch }}_${{ matrix.conf }}${{ matrix.ovpn3.upload_name }}
path: | path: |
out/build/${{ matrix.arch }}${{ matrix.ovpn3.preset }}/Release/*.dll out/build/${{ matrix.arch }}${{ matrix.ovpn3.preset }}/${{ matrix.conf.value }}/*.dll
out/build/${{ matrix.arch }}${{ matrix.ovpn3.preset }}/Release/*.exe out/build/${{ matrix.arch }}${{ matrix.ovpn3.preset }}/${{ matrix.conf.value }}/*.exe
mingw: mingw:
strategy: strategy:
@ -107,4 +115,3 @@ jobs:
- name: make - name: make
run: make run: make
working-directory: openvpn-gui working-directory: openvpn-gui

@ -28,8 +28,24 @@ add_executable(${PROJECT_NAME} WIN32
res/openvpn-gui-res.rc) res/openvpn-gui-res.rc)
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DDEBUG") set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DDEBUG")
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS} /guard:cf /Qspectre")
if(MSVC)
list(APPEND CMAKE_CONFIGURATION_TYPES Asan)
endif(MSVC)
set(CMAKE_C_FLAGS_ASAN
"${CMAKE_C_FLAGS_DEBUG} /fsanitize=address" CACHE STRING
"Flags used by the C compiler during AddressSanitizer builds." FORCE)
set(CMAKE_EXE_LINKER_FLAGS_ASAN
"${CMAKE_EXE_LINKER_FLAGS_DEBUG}" CACHE STRING
"Flags used by the linker during AddressSanitizer builds." FORCE)
set(CMAKE_SHARED_LINKER_FLAGS_ASAN
"${CMAKE_SHARED_LINKER_FLAGS_DEBUG}" CACHE STRING
"Flags used by the linker during AddressSanitizer builds." FORCE)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /guard:cf /Qspectre")
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /guard:cf /DYNAMICBASE") set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /guard:cf /DYNAMICBASE")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /wd4996 /wd4267 /wd4244") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /wd4996 /wd4267 /wd4244")
@ -160,5 +176,6 @@ if(MSVC)
"$<$<CONFIG:Release>:/OPT:ICF>") "$<$<CONFIG:Release>:/OPT:ICF>")
endif(MSVC) endif(MSVC)
set_target_properties(${TEST_PLAP_EXE} PROPERTIES target_link_options(${TEST_PLAP_EXE} PRIVATE
LINK_FLAGS " /MANIFEST:EMBED /MANIFESTINPUT:${CMAKE_SOURCE_DIR}/plap/test-plap.manifest ") "/MANIFEST:EMBED"
"/MANIFESTINPUT:${CMAKE_SOURCE_DIR}/plap/test-plap.manifest")

@ -76,6 +76,11 @@
"configurePreset": "x64", "configurePreset": "x64",
"configuration": "Debug" "configuration": "Debug"
}, },
{
"name": "x64-asan",
"configurePreset": "x64",
"configuration": "Asan"
},
{ {
"name": "x86-debug", "name": "x86-debug",
"configurePreset": "x86", "configurePreset": "x86",

Loading…
Cancel
Save