mirror of
https://github.com/rehlds/rehlds.git
synced 2025-01-01 01:25:38 +03:00
CMakeLists.txt: Configure for more compat to older linux distros (Debian 7, Centoc 6 etc)
This commit is contained in:
parent
af4776487b
commit
f27be28abb
17
.github/workflows/build.yml
vendored
17
.github/workflows/build.yml
vendored
@ -117,6 +117,23 @@ jobs:
|
|||||||
mv build/rehlds/HLTV/Director/director.so publish/bin/linux32/valve/dlls/director.so
|
mv build/rehlds/HLTV/Director/director.so publish/bin/linux32/valve/dlls/director.so
|
||||||
mv build/rehlds/filesystem/FileSystem_Stdio/filesystem_stdio.so publish/bin/linux32/filesystem_stdio.so
|
mv build/rehlds/filesystem/FileSystem_Stdio/filesystem_stdio.so publish/bin/linux32/filesystem_stdio.so
|
||||||
|
|
||||||
|
- name: Run GLIBC/ABI version compat test
|
||||||
|
run: |
|
||||||
|
binaries=(
|
||||||
|
"publish/bin/linux32/engine_i486.so"
|
||||||
|
"publish/bin/linux32/hlds_linux"
|
||||||
|
"publish/bin/linux32/hltv"
|
||||||
|
"publish/bin/linux32/core.so"
|
||||||
|
"publish/bin/linux32/proxy.so"
|
||||||
|
"publish/bin/linux32/demoplayer.so"
|
||||||
|
"publish/bin/linux32/valve/dlls/director.so"
|
||||||
|
"publish/bin/linux32/filesystem_stdio.so"
|
||||||
|
)
|
||||||
|
bash ./rehlds/version/glibc_test.sh ${binaries[@]}
|
||||||
|
if [[ $? -ne 0 ]]; then
|
||||||
|
exit 1 # Assertion failed
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Deploy artifacts
|
- name: Deploy artifacts
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v2
|
||||||
id: upload-job
|
id: upload-job
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
cmake_minimum_required(VERSION 3.1)
|
cmake_minimum_required(VERSION 3.1)
|
||||||
project(bzip2 C)
|
project(bzip2 C)
|
||||||
|
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g0 -O1 -fno-stack-protector")
|
||||||
|
|
||||||
set(BZIP2_SRCS
|
set(BZIP2_SRCS
|
||||||
"src/blocksort.c"
|
"src/blocksort.c"
|
||||||
"src/bzlib.c"
|
"src/bzlib.c"
|
||||||
@ -18,4 +20,4 @@ include_directories(
|
|||||||
)
|
)
|
||||||
|
|
||||||
add_library(bzip2 STATIC ${BZIP2_SRCS})
|
add_library(bzip2 STATIC ${BZIP2_SRCS})
|
||||||
set_target_properties(bzip2 PROPERTIES COMPILE_FLAGS "-m32" POSITION_INDEPENDENT_CODE ON)
|
set_target_properties(bzip2 PROPERTIES COMPILE_FLAGS "-m32")
|
||||||
|
@ -17,7 +17,7 @@ elseif (USE_CLANG_COMPILER)
|
|||||||
set(CMAKE_CXX_COMPILER "/usr/bin/clang++")
|
set(CMAKE_CXX_COMPILER "/usr/bin/clang++")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -fno-rtti -fno-exceptions")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -fno-rtti -fno-plt -fno-exceptions")
|
||||||
|
|
||||||
# Remove noxref code and data
|
# Remove noxref code and data
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ffunction-sections -fdata-sections")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ffunction-sections -fdata-sections")
|
||||||
@ -34,7 +34,7 @@ if (USE_INTEL_COMPILER)
|
|||||||
|
|
||||||
if (NOT DEBUG)
|
if (NOT DEBUG)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -ipo")
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
@ -55,6 +55,10 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
|
endif()
|
||||||
|
|
||||||
if (NOT DEBUG AND USE_STATIC_LIBSTDC)
|
if (NOT DEBUG AND USE_STATIC_LIBSTDC)
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-gc-sections -Wl,--version-script=\"${PROJECT_SOURCE_DIR}/../version_script.lds\"")
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-gc-sections -Wl,--version-script=\"${PROJECT_SOURCE_DIR}/../version_script.lds\"")
|
||||||
endif()
|
endif()
|
||||||
@ -127,6 +131,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
@ -147,6 +152,6 @@ endif()
|
|||||||
|
|
||||||
add_library(engine SHARED ${appversion.sh} ${ENGINE_SRCS} ${COMMON_SRCS} ${PUBLIC_SRCS})
|
add_library(engine SHARED ${appversion.sh} ${ENGINE_SRCS} ${COMMON_SRCS} ${PUBLIC_SRCS})
|
||||||
set_property(TARGET engine PROPERTY LIBRARY_OUTPUT_NAME engine_i486)
|
set_property(TARGET engine PROPERTY LIBRARY_OUTPUT_NAME engine_i486)
|
||||||
set_target_properties(engine PROPERTIES PREFIX "" COMPILE_FLAGS "-m32" LINK_FLAGS "-m32" POSITION_INDEPENDENT_CODE ON)
|
set_target_properties(engine PROPERTIES PREFIX "" COMPILE_FLAGS "-m32" LINK_FLAGS "-m32" POSITION_INDEPENDENT_CODE OFF)
|
||||||
target_link_libraries(engine dl rt m aelf32 bzip2 steam_api)
|
target_link_libraries(engine dl rt m aelf32 bzip2 steam_api)
|
||||||
add_dependencies(engine appversion)
|
add_dependencies(engine appversion)
|
||||||
|
@ -40,9 +40,17 @@ if (USE_INTEL_COMPILER)
|
|||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result -Wno-unknown-pragmas -Wno-write-strings")
|
-Wno-unused-result -Wno-unknown-pragmas -Wno-write-strings")
|
||||||
|
|
||||||
|
if (NOT USE_CLANG_COMPILER AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-stringop-truncation -Wno-format-truncation")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
@ -86,6 +94,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -35,15 +35,23 @@ if (USE_INTEL_COMPILER)
|
|||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result -Wno-unknown-pragmas -Wno-unused-variable\
|
-Wno-unused-result -Wno-unknown-pragmas -Wno-unused-variable\
|
||||||
-Wno-sign-compare -Wno-write-strings -Wno-strict-aliasing")
|
-Wno-sign-compare -Wno-write-strings -Wno-strict-aliasing")
|
||||||
|
|
||||||
if (USE_CLANG_COMPILER)
|
if (USE_CLANG_COMPILER)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-private-field")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-private-field")
|
||||||
|
else()
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-stringop-truncation -Wno-format-truncation")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
"${PROJECT_SOURCE_DIR}/src"
|
"${PROJECT_SOURCE_DIR}/src"
|
||||||
@ -105,6 +113,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -35,12 +35,16 @@ if (USE_INTEL_COMPILER)
|
|||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result -Wno-unknown-pragmas\
|
-Wno-unused-result -Wno-unknown-pragmas\
|
||||||
-Wno-sign-compare -Wno-write-strings -Wno-strict-aliasing")
|
-Wno-sign-compare -Wno-write-strings -Wno-strict-aliasing")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
"${PROJECT_SOURCE_DIR}/src"
|
"${PROJECT_SOURCE_DIR}/src"
|
||||||
"${PROJECT_SOURCE_DIR}/../"
|
"${PROJECT_SOURCE_DIR}/../"
|
||||||
@ -84,6 +88,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -35,14 +35,14 @@ if (USE_INTEL_COMPILER)
|
|||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result -Wno-unknown-pragmas\
|
-Wno-unused-result -Wno-unknown-pragmas\
|
||||||
-Wno-write-strings -Wno-strict-aliasing")
|
-Wno-write-strings -Wno-strict-aliasing")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--wrap=expf")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
@ -90,6 +90,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -40,14 +40,9 @@ EXPOSE_SINGLE_INTERFACE(Director, IDirector, DIRECTOR_INTERFACE_VERSION);
|
|||||||
// Building go on GCC 8.3 or greater that have newest expf GLIBC.2.27 than
|
// Building go on GCC 8.3 or greater that have newest expf GLIBC.2.27 than
|
||||||
// available on the destination virtual machine, so we can downgrade GLIBC version
|
// available on the destination virtual machine, so we can downgrade GLIBC version
|
||||||
// for this function.
|
// for this function.
|
||||||
// Use for linker: -Wl,--wrap=expf
|
// NOTE: This workaround seem not compatible with -flto compile GCC option.
|
||||||
|
|
||||||
extern int expf(int __fd, int __cmd, ...);
|
|
||||||
__asm__(".symver expf,expf@GLIBC_" GLIBC_expf_VERSION);
|
__asm__(".symver expf,expf@GLIBC_" GLIBC_expf_VERSION);
|
||||||
DLL_EXPORT float __wrap_expf(float x)
|
|
||||||
{
|
|
||||||
return expf(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // #if defined(_WIN32)
|
#endif // #if defined(_WIN32)
|
||||||
|
|
||||||
@ -389,9 +384,9 @@ float Director::AddBestGenericCut()
|
|||||||
int seqNrMod = m_nextCutSeqnr % m_historyLength;
|
int seqNrMod = m_nextCutSeqnr % m_historyLength;
|
||||||
|
|
||||||
float sumTarget2Rank[MAX_CLIENTS];
|
float sumTarget2Rank[MAX_CLIENTS];
|
||||||
float bestTarget2Rank, bestRank = 0;
|
float bestTarget2Rank, bestRank = 0.0f;
|
||||||
float targetRankSum = 0;
|
float targetRankSum = 0;
|
||||||
int newTarget, newTarget2;
|
int newTarget = 0, newTarget2 = 0;
|
||||||
int bestTarget2;
|
int bestTarget2;
|
||||||
|
|
||||||
for (int i = 0; i < MAX_CLIENTS; i++)
|
for (int i = 0; i < MAX_CLIENTS; i++)
|
||||||
|
@ -16,7 +16,7 @@ elseif (USE_CLANG_COMPILER)
|
|||||||
set(CMAKE_CXX_COMPILER "/usr/bin/clang++")
|
set(CMAKE_CXX_COMPILER "/usr/bin/clang++")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -fno-exceptions")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -fno-plt -fno-exceptions")
|
||||||
|
|
||||||
if (DEBUG)
|
if (DEBUG)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g3 -O3 -ggdb")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g3 -O3 -ggdb")
|
||||||
@ -30,23 +30,27 @@ if (USE_INTEL_COMPILER)
|
|||||||
|
|
||||||
if (NOT DEBUG)
|
if (NOT DEBUG)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_CXX_FLAGS} -ipo")
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -ipo")
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result -Wno-unknown-pragmas -Wno-unused-variable\
|
-Wno-unused-result -Wno-unknown-pragmas -Wno-unused-variable\
|
||||||
-Wno-write-strings -Wno-strict-aliasing")
|
-Wno-write-strings -Wno-strict-aliasing")
|
||||||
|
|
||||||
if (USE_CLANG_COMPILER)
|
if (USE_CLANG_COMPILER)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-private-field")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-unused-private-field")
|
||||||
|
else()
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-stringop-truncation -Wno-format-truncation")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--wrap=expf")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
@ -112,6 +116,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -583,7 +583,7 @@ void DirectorCmd::WriteToStream(BitBuffer *stream)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char *DirectorCmd::ToString()
|
const char *DirectorCmd::ToString()
|
||||||
{
|
{
|
||||||
int i1, i2, i3;
|
int i1, i2, i3;
|
||||||
float f1, f2, f3, f4;
|
float f1, f2, f3, f4;
|
||||||
@ -592,7 +592,7 @@ char *DirectorCmd::ToString()
|
|||||||
char *t1 = m_CMD_Name[m_Type];
|
char *t1 = m_CMD_Name[m_Type];
|
||||||
char t2[1024];
|
char t2[1024];
|
||||||
|
|
||||||
static char s[1024];
|
static char s[2048];
|
||||||
Q_memset(s, 0, sizeof(s));
|
Q_memset(s, 0, sizeof(s));
|
||||||
|
|
||||||
switch (m_Type)
|
switch (m_Type)
|
||||||
|
@ -40,7 +40,7 @@ public:
|
|||||||
void Copy(DirectorCmd *cmd);
|
void Copy(DirectorCmd *cmd);
|
||||||
void Resize(int size);
|
void Resize(int size);
|
||||||
void FromString(char *string);
|
void FromString(char *string);
|
||||||
char *ToString();
|
const char *ToString();
|
||||||
void WriteToStream(BitBuffer *stream);
|
void WriteToStream(BitBuffer *stream);
|
||||||
bool ReadFromStream(BitBuffer *stream);
|
bool ReadFromStream(BitBuffer *stream);
|
||||||
int GetType();
|
int GetType();
|
||||||
|
@ -40,9 +40,17 @@ if (USE_INTEL_COMPILER)
|
|||||||
else()
|
else()
|
||||||
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
# Produce code optimized for the most common IA32/AMD64/EM64T processors.
|
||||||
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
# As new processors are deployed in the marketplace, the behavior of this option will change.
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3 -flto\
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mtune=generic -msse3\
|
||||||
-fpermissive -fno-sized-deallocation\
|
-fpermissive -fno-sized-deallocation\
|
||||||
-Wno-unused-result")
|
-Wno-unused-result")
|
||||||
|
|
||||||
|
if (NOT USE_CLANG_COMPILER AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-stringop-truncation -Wno-format-truncation")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
@ -87,6 +95,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
|
@ -597,6 +597,20 @@ double EXT_FUNC Sys_FloatTime(void)
|
|||||||
|
|
||||||
#else // not _WIN32
|
#else // not _WIN32
|
||||||
|
|
||||||
|
#if __GNUC__ >= 8
|
||||||
|
|
||||||
|
#define GLIBC_clock_gettime_VERSION "2.2"
|
||||||
|
|
||||||
|
//
|
||||||
|
// Building go on GCC 8.3 or greater that have newest clock_gettime GLIBC.2.17 than
|
||||||
|
// available on the destination virtual machine, so we can downgrade GLIBC version
|
||||||
|
// for this function.
|
||||||
|
// NOTE: This workaround seem not compatible with -flto compile GCC option.
|
||||||
|
|
||||||
|
__asm__(".symver clock_gettime,clock_gettime@GLIBC_" GLIBC_clock_gettime_VERSION);
|
||||||
|
|
||||||
|
#endif // #if __GNUC__ >= 8
|
||||||
|
|
||||||
double Sys_FloatTime(void)
|
double Sys_FloatTime(void)
|
||||||
{
|
{
|
||||||
static struct timespec start_time;
|
static struct timespec start_time;
|
||||||
|
@ -51,6 +51,10 @@ foreach(f ${WRAP_FUNCS_LIST})
|
|||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-wrap,${f}")
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-wrap,${f}")
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fcf-protection=none")
|
||||||
|
endif()
|
||||||
|
|
||||||
set(PROJECT_SRC_DIR
|
set(PROJECT_SRC_DIR
|
||||||
"${PROJECT_SOURCE_DIR}/src"
|
"${PROJECT_SOURCE_DIR}/src"
|
||||||
"${PROJECT_SOURCE_DIR}/../.."
|
"${PROJECT_SOURCE_DIR}/../.."
|
||||||
@ -80,6 +84,7 @@ add_definitions(
|
|||||||
-D_LINUX
|
-D_LINUX
|
||||||
-DLINUX
|
-DLINUX
|
||||||
-D_GLIBCXX_USE_CXX11_ABI=0
|
-D_GLIBCXX_USE_CXX11_ABI=0
|
||||||
|
-U_FORTIFY_SOURCE
|
||||||
-D_strdup=strdup
|
-D_strdup=strdup
|
||||||
-D_stricmp=strcasecmp
|
-D_stricmp=strcasecmp
|
||||||
-D_strnicmp=strncasecmp
|
-D_strnicmp=strncasecmp
|
||||||
|
71
rehlds/version/glibc_test.sh
Executable file
71
rehlds/version/glibc_test.sh
Executable file
@ -0,0 +1,71 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
main()
|
||||||
|
{
|
||||||
|
files=($@)
|
||||||
|
|
||||||
|
declare -A threshold_version
|
||||||
|
threshold_version[CXXABI]="1.3.5"
|
||||||
|
threshold_version[GLIBCXX]="3.4.15"
|
||||||
|
threshold_version[GLIBC]="2.7"
|
||||||
|
|
||||||
|
for k in "${!threshold_version[@]}"; do
|
||||||
|
for f in "${files[@]}"
|
||||||
|
do
|
||||||
|
:
|
||||||
|
version=$(readelf -sV $f | sed -n 's/.*@'$k'_//p' | sort -u -V | tail -1 | cut -d ' ' -f 1)
|
||||||
|
if [[ ! -z "$version" ]]; then
|
||||||
|
check_version_greater $version ${threshold_version[$k]}
|
||||||
|
if [[ $? -eq 1 ]]; then
|
||||||
|
echo -e "\033[0;31mAssertion failed:\033[0m Binary \033[0;32m${f}\033[0m has ${k}_\033[0;33m$version\033[0m greater than max version ${k}_\033[0;33m${threshold_version[$k]}\033[0m"
|
||||||
|
exit -1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo -e "[\033[0;32mOK\033[0m] ${k}_\033[0;33m${threshold_version[$k]}\033[0m"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
check_version_greater()
|
||||||
|
{
|
||||||
|
if [[ -z "$1" || $1 == $2 ]]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
local IFS=.
|
||||||
|
local i ver1=($1) ver2=($2)
|
||||||
|
|
||||||
|
# fill empty fields in ver1 with zeros
|
||||||
|
for ((i = ${#ver1[@]}; i < ${#ver2[@]}; i++))
|
||||||
|
do
|
||||||
|
ver1[i]=0
|
||||||
|
done
|
||||||
|
|
||||||
|
for ((i = 0; i < ${#ver1[@]}; i++))
|
||||||
|
do
|
||||||
|
if [[ -z ${ver2[i]} ]]
|
||||||
|
then
|
||||||
|
# fill empty fields in ver2 with zeros
|
||||||
|
ver2[i]=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ((10#${ver1[i]} > 10#${ver2[i]}))
|
||||||
|
then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ((10#${ver1[i]} < 10#${ver2[i]}))
|
||||||
|
then
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Initialize
|
||||||
|
main $*
|
||||||
|
|
||||||
|
# Exit normally
|
||||||
|
exit 0
|
Loading…
Reference in New Issue
Block a user