1
0
mirror of https://github.com/bitdefender/bddisasm.git synced 2025-01-03 03:40:54 +00:00

Merge pull request #78 from ianichitei/master

Fix `clang-cl` and `mingw` builds
This commit is contained in:
Anichitei Ionel-Cristinel 2022-12-05 14:25:25 +01:00 committed by GitHub
commit 102b43dd00
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 22 additions and 19 deletions

View File

@ -35,7 +35,9 @@ if (NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
endif () endif ()
# These are shared by bddisasm and bdshemu. # These are shared by bddisasm and bdshemu.
if (NOT MSVC) if (MSVC OR "${CMAKE_C_COMPILER_FRONTEND_VARIANT}" STREQUAL "MSVC")
set(BDDISASM_COMMON_COMPILE_OPTIONS /W4 /WX)
else ()
set(BDDISASM_COMMON_COMPILE_OPTIONS set(BDDISASM_COMMON_COMPILE_OPTIONS
"$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>" "$<$<CONFIG:Release>:-U_FORTIFY_SOURCE>"
"$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>" "$<$<CONFIG:Release>:-D_FORTIFY_SOURCE=2>"
@ -68,8 +70,6 @@ if (NOT MSVC)
-gdwarf-4 -gdwarf-4
-grecord-gcc-switches -grecord-gcc-switches
-march=westmere) -march=westmere)
else ()
set(BDDISASM_COMMON_COMPILE_OPTIONS /W4 /WX)
endif () endif ()
set(BDDISASM_PUBLIC_HEADERS set(BDDISASM_PUBLIC_HEADERS
@ -91,6 +91,7 @@ set(BDDISASM_INSTALL_INCLUDE_DIR
include(CheckFunctionExists) include(CheckFunctionExists)
include(CheckSymbolExists) include(CheckSymbolExists)
include(CheckCCompilerFlag)
add_library( add_library(
bddisasm STATIC bddisasm STATIC
@ -171,7 +172,9 @@ target_include_directories(bddisasm PUBLIC $<BUILD_INTERFACE:${CMAKE_CURRENT_SOU
target_link_libraries(bdshemu PUBLIC bddisasm) target_link_libraries(bdshemu PUBLIC bddisasm)
target_compile_options(bdshemu PRIVATE ${BDDISASM_COMMON_COMPILE_OPTIONS}) target_compile_options(bdshemu PRIVATE ${BDDISASM_COMMON_COMPILE_OPTIONS})
if (NOT MSVC)
check_c_compiler_flag(-maes HAS_MAES)
if (HAS_MAES)
target_compile_options(bdshemu PRIVATE -maes) target_compile_options(bdshemu PRIVATE -maes)
endif () endif ()

View File

@ -3550,7 +3550,7 @@ cleanup_and_exit:
// //
// NdGetVectorLength // NdGetVectorLength
// //
static __forceinline NDSTATUS static inline NDSTATUS
NdGetVectorLength( NdGetVectorLength(
INSTRUX *Instrux INSTRUX *Instrux
) )
@ -3605,7 +3605,7 @@ NdGetVectorLength(
// //
// NdGetAddrAndOpMode // NdGetAddrAndOpMode
// //
static __forceinline NDSTATUS static inline NDSTATUS
NdGetAddrAndOpMode( NdGetAddrAndOpMode(
INSTRUX *Instrux INSTRUX *Instrux
) )
@ -3636,7 +3636,7 @@ NdGetAddrAndOpMode(
// //
// NdGetEffectiveOpMode // NdGetEffectiveOpMode
// //
static __forceinline NDSTATUS static inline NDSTATUS
NdGetEffectiveOpMode( NdGetEffectiveOpMode(
INSTRUX *Instrux INSTRUX *Instrux
) )
@ -3792,7 +3792,7 @@ NdPostProcessEvex(
// //
// NdValidateInstruction // NdValidateInstruction
// //
static __forceinline NDSTATUS static inline NDSTATUS
NdValidateInstruction( NdValidateInstruction(
INSTRUX *Instrux INSTRUX *Instrux
) )

View File

@ -11,10 +11,6 @@
#define UNREFERENCED_PARAMETER(P) ((void)(P)) #define UNREFERENCED_PARAMETER(P) ((void)(P))
#endif #endif
#if !defined(_MSC_VER)
# define __forceinline inline __attribute__((always_inline))
#endif // _MSC_VER
// By default, an integrator is expected to provide nd_vsnprintf_s and nd_strcat_s. // By default, an integrator is expected to provide nd_vsnprintf_s and nd_strcat_s.
// bddisasm needs both for NdToText, while bdshemu needs nd_vsnprintf_s for emulation tracing. // bddisasm needs both for NdToText, while bdshemu needs nd_vsnprintf_s for emulation tracing.
// If BDDISASM_NO_FORMAT is defined at compile time these requirements are removed. Instruction formatting will no // If BDDISASM_NO_FORMAT is defined at compile time these requirements are removed. Instruction formatting will no

View File

@ -27,14 +27,21 @@ if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
endif () endif ()
endif () endif ()
if (NOT MSVC) if (MSVC OR "${CMAKE_C_COMPILER_FRONTEND_VARIANT}" STREQUAL "MSVC")
target_compile_options(disasmtool PRIVATE /W4 /WX)
if ("${CMAKE_C_COMPILER_ID}" STREQUAL "Clang")
target_compile_options(disasmtool PRIVATE -Wno-format)
endif ()
else ()
target_compile_options( target_compile_options(
disasmtool disasmtool
PRIVATE -Wall PRIVATE -Wall
-Wno-unknown-pragmas -Wno-unknown-pragmas
-Wextra -Wextra
-Wshadow -Wshadow
-Wformat-security -Wno-format
-Wno-cast-function-type
-Wstrict-overflow=2 -Wstrict-overflow=2
-Wstrict-prototypes -Wstrict-prototypes
-Wwrite-strings -Wwrite-strings
@ -46,7 +53,6 @@ if (NOT MSVC)
-Wno-discarded-qualifiers -Wno-discarded-qualifiers
-Wnull-dereference -Wnull-dereference
-Wduplicated-cond -Wduplicated-cond
-Werror=format-security
-Werror=implicit-function-declaration -Werror=implicit-function-declaration
-pipe -pipe
-fwrapv -fwrapv
@ -59,6 +65,4 @@ if (NOT MSVC)
-gdwarf-4 -gdwarf-4
-grecord-gcc-switches -grecord-gcc-switches
-march=westmere) -march=westmere)
else ()
target_compile_options(disasmtool PRIVATE /W4 /WX)
endif () endif ()

View File

@ -594,7 +594,7 @@ INT32 regstr_to_idx(
"r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15" "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
}; };
for (INT32 i = 0; i < ARRAYSIZE(reg64); i++) for (INT32 i = 0; i < (INT32)ARRAYSIZE(reg64); i++)
{ {
if (!_stricmp(Reg, reg64[i])) if (!_stricmp(Reg, reg64[i]))
{ {
@ -1417,7 +1417,7 @@ void set_shemuctx_file(
// first element is the register // first element is the register
regIdx = regstr_to_idx(regStr); regIdx = regstr_to_idx(regStr);
if (regIdx < 0 || regIdx >= ARRAYSIZE(Options->ShemuRegs)) if (regIdx < 0 || regIdx >= (INT32)ARRAYSIZE(Options->ShemuRegs))
{ {
if (!_stricmp(regStr, "rip")) if (!_stricmp(regStr, "rip"))
{ {