1
0
mirror of https://github.com/bitdefender/bddisasm.git synced 2025-01-18 11:00:57 +00:00

Merge remote-tracking branch 'bitdefender-public/master'

This commit is contained in:
Ionel-Cristinel ANICHITEI 2020-11-20 15:59:52 +02:00
commit b93bb94e16
2 changed files with 42 additions and 24 deletions

View File

@ -55,7 +55,6 @@ add_dependencies(bdshemu bddisasm)
include_directories( include_directories(
inc inc
inc/bdshemu
bddisasm/include bddisasm/include
) )
@ -65,7 +64,7 @@ else ()
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O0 -D_DEBUG -DDEBUG") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O0 -D_DEBUG -DDEBUG")
endif () endif ()
add_compile_options( set(BDDISASM_COMPILE_OPTIONS
"$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>" "$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>"
"$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>" "$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>"
-Wall -Wall
@ -78,14 +77,10 @@ add_compile_options(
-Wwrite-strings -Wwrite-strings
-Wshadow -Wshadow
-Winit-self -Winit-self
-Wswitch-default
-Wmissing-variable-declarations
-Wused-but-marked-unused
-Wswitch-enum
-Wno-unused-function -Wno-unused-function
-Wno-multichar -Wno-multichar
-Wno-incompatible-pointer-types -Wno-incompatible-pointer-types
-Wcast-qual -Wno-discarded-qualifiers
-Wnull-dereference -Wnull-dereference
-Wduplicated-cond -Wduplicated-cond
-Werror=format-security -Werror=format-security
@ -103,6 +98,9 @@ add_compile_options(
-march=nehalem -march=nehalem
) )
target_compile_options(bddisasm PRIVATE ${BDDISASM_COMPILE_OPTIONS})
target_compile_options(bdshemu PRIVATE ${BDDISASM_COMPILE_OPTIONS})
include(GNUInstallDirs) include(GNUInstallDirs)
set(CMAKE_SKIP_BUILD_RPATH TRUE) set(CMAKE_SKIP_BUILD_RPATH TRUE)
@ -156,3 +154,19 @@ install(FILES ${PROJECT_BINARY_DIR}/bddisasmConfig.cmake ${PROJECT_BINARY_DIR}/b
INSTALL(FILES "${PROJECT_SOURCE_DIR}/${CMAKE_STATIC_LIBRARY_PREFIX}bddisasm.pc" INSTALL(FILES "${PROJECT_SOURCE_DIR}/${CMAKE_STATIC_LIBRARY_PREFIX}bddisasm.pc"
DESTINATION "${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_LIBDIR}/pkgconfig" DESTINATION "${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_LIBDIR}/pkgconfig"
) )
if (NOT CPACK_GENERATOR)
set(CPACK_GENERATOR "DEB")
endif()
set(CPACK_DEBIAN_PACKAGE_MAINTAINER "Bitdefender HVI Team <hvmi-oss@bitdefender.com>")
set(CPACK_DEBIAN_PACKAGE_DEPENDS "")
set(CPACK_DEBIAN_PACKAGE_ARCHITECTURE "amd64")
set(CPACK_DEBIAN_PACKAGE_SECTION "devel")
if (INCLUDE_TOOL)
add_subdirectory("disasmtool_lix")
add_dependencies(disasmtool bdshemu)
endif()
include(CPack)

View File

@ -27,9 +27,6 @@ set(disasmtool_src_files
dumpers.cpp dumpers.cpp
) )
find_library(DISASM_LIB bddisasm PATHS "${DISASM_DIRECTORY}/${DISASM_BUILD_PREFIX}/${CMAKE_BUILD_TYPE}" NO_DEFAULT_PATH)
message(STATUS "Disasm lib used: ${DISASM_LIB}")
find_package(RapidJSON) find_package(RapidJSON)
if (RapidJSON_FOUND) if (RapidJSON_FOUND)
@ -41,7 +38,11 @@ else()
message(FATAL_ERROR "Dependency: rapidjson not found") message(FATAL_ERROR "Dependency: rapidjson not found")
endif() endif()
add_compile_options(
add_executable(${PROJECT_NAME} ${disasmtool_src_files})
target_compile_options(${PROJECT_NAME} PRIVATE
"$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>" "$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>"
"$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>" "$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>"
-Wall -Wall
@ -81,7 +82,7 @@ set(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_SHARED_LINKER_FLAGS_RELEASE} -Wl,
if (CMAKE_COMPILER_IS_GNUCXX) if (CMAKE_COMPILER_IS_GNUCXX)
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 6.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 6.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wshift-overflow=2 -Wshift-overflow=2
-Wnull-dereference -Wnull-dereference
-Wduplicated-cond -Wduplicated-cond
@ -91,7 +92,7 @@ if (CMAKE_COMPILER_IS_GNUCXX)
endif() endif()
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 7.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 7.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wdangling-else -Wdangling-else
-Wshadow=global -Wshadow=global
-Walloc-zero -Walloc-zero
@ -99,7 +100,7 @@ if (CMAKE_COMPILER_IS_GNUCXX)
endif() endif()
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 8.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 8.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wmultistatement-macros -Wmultistatement-macros
-Warray-bounds=2 -Warray-bounds=2
-Wformat-overflow=2 -Wformat-overflow=2
@ -127,7 +128,7 @@ if (CMAKE_COMPILER_IS_GNUCXX)
endif() endif()
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 9.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 9.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wcatch-value=2 -Wcatch-value=2
-Wduplicated-branches -Wduplicated-branches
-Wextra-semi -Wextra-semi
@ -140,12 +141,12 @@ if (CMAKE_COMPILER_IS_GNUCXX)
) )
endif() endif()
elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wno-missing-braces -Wno-missing-braces
) )
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 6.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 6.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Wshift-overflow -Wshift-overflow
-Wnull-dereference -Wnull-dereference
-Wvla -Wvla
@ -157,7 +158,7 @@ elseif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
endif() endif()
if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 10.0)) if (NOT (CMAKE_CXX_COMPILER_VERSION LESS 10.0))
add_compile_options( target_compile_options(${PROJECT_NAME} PRIVATE
-Warray-bounds-pointer-arithmetic -Warray-bounds-pointer-arithmetic
-Wassign-enum -Wassign-enum
-Watomic-implicit-seq-cst -Watomic-implicit-seq-cst
@ -251,20 +252,18 @@ else()
message(FATAL_ERROR "Unsupported compiler!") message(FATAL_ERROR "Unsupported compiler!")
endif() endif()
include_directories( target_include_directories(${PROJECT_NAME} PRIVATE
${DISASM_DIRECTORY}/inc ${DISASM_DIRECTORY}/inc
${DISASM_DIRECTORY}/bddisasm/include ${DISASM_DIRECTORY}/bddisasm/include
) )
add_executable(${CMAKE_PROJECT_NAME} ${disasmtool_src_files})
if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release") if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
include(CheckIPOSupported) include(CheckIPOSupported)
check_ipo_supported(RESULT USE_IPO) check_ipo_supported(RESULT USE_IPO)
set_target_properties(${CMAKE_PROJECT_NAME} PROPERTIES INTERPROCEDURAL_OPTIMIZATION True) set_target_properties(${PROJECT_NAME} PROPERTIES INTERPROCEDURAL_OPTIMIZATION True)
endif() endif()
set_target_properties(${CMAKE_PROJECT_NAME} set_target_properties(${PROJECT_NAME}
PROPERTIES PROPERTIES
POSITION_INDEPENDENT_CODE ON POSITION_INDEPENDENT_CODE ON
CXX_STANDARD 17 CXX_STANDARD 17
@ -272,6 +271,11 @@ set_target_properties(${CMAKE_PROJECT_NAME}
CXX_EXTENSIONS ON CXX_EXTENSIONS ON
) )
target_link_libraries(${CMAKE_PROJECT_NAME} ${DISASM_LIB}) target_link_directories(${PROJECT_NAME} PRIVATE "${DISASM_DIRECTORY}/bin/x64/${CMAKE_BUILD_TYPE}")
target_link_libraries(${PROJECT_NAME} PRIVATE bddisasm bdshemu)
INSTALL(TARGETS disasmtool
RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_BINDIR}"
)
unset(DISASM_LIB CACHE) unset(DISASM_LIB CACHE)