2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-19 10:08:04 +03:00

HookChains refactoring.

Added API functions for getting all net message buffers.
Added callback for file hash checking.
Fixed tests passing if sse 4+ doesn't supported.
This commit is contained in:
asmodai 2015-07-18 16:31:42 +03:00
parent c04b30a7fb
commit 04afd94aa7
16 changed files with 204 additions and 121 deletions

View File

@ -998,7 +998,7 @@ void Cmd_ExecuteString(char *text, cmd_source_t src)
}
IGameClient* cl = (src == src_client) ? GetRehldsApiClient(host_client) : NULL;
if (!g_RehldsHookchains.m_ValidateCommand.callChain(ValidateCmd_API, false, cmd_argv[0], src, cl))
if (!g_RehldsHookchains.m_ValidateCommand.callChain(ValidateCmd_API, cmd_argv[0], src, cl))
return;
g_RehldsHookchains.m_ExecuteServerStringCmd.callChain(Cmd_ExecuteString_internal, cmd_argv[0], src, cl);

View File

@ -1307,7 +1307,7 @@ bool EXT_FUNC NET_GetPacketPreprocessor(uint8* data, unsigned int len, const net
qboolean NET_GetPacket(netsrc_t sock) {
qboolean getRes = NET_GetPacket_internal(sock);
while (getRes) {
bool pass = g_RehldsHookchains.m_PreprocessPacket.callChain(NET_GetPacketPreprocessor, FALSE, net_message.data, net_message.cursize, net_from);
bool pass = g_RehldsHookchains.m_PreprocessPacket.callChain(NET_GetPacketPreprocessor, net_message.data, net_message.cursize, net_from);
if (pass) {
return 1;
}

View File

@ -1781,7 +1781,7 @@ qboolean EXT_FUNC SV_FilterUser(USERID_t *userid)
int SV_CheckProtocol(netadr_t *adr, int nProtocol)
{
return g_RehldsHookchains.m_SV_CheckProtocol.callChain(SV_CheckProtocol_internal, 0, adr, nProtocol);
return g_RehldsHookchains.m_SV_CheckProtocol.callChain(SV_CheckProtocol_internal, adr, nProtocol);
}
/* <a7396> ../engine/sv_main.c:2302 */
@ -1868,7 +1868,7 @@ int SV_CheckChallenge(netadr_t *adr, int nChallengeValue)
int SV_CheckIPRestrictions(netadr_t *adr, int nAuthProtocol)
{
return g_RehldsHookchains.m_SV_CheckIPRestrictions.callChain(SV_CheckIPRestrictions_internal, 0, adr, nAuthProtocol);
return g_RehldsHookchains.m_SV_CheckIPRestrictions.callChain(SV_CheckIPRestrictions_internal, adr, nAuthProtocol);
}
/* <a743d> ../engine/sv_main.c:2393 */
@ -1909,7 +1909,7 @@ int SV_CheckIPConnectionReuse(netadr_t *adr)
int SV_FinishCertificateCheck(netadr_t *adr, int nAuthProtocol, char *szRawCertificate, char *userinfo)
{
return g_RehldsHookchains.m_SV_FinishCertificateCheck.callChain(SV_FinishCertificateCheck_internal, 0, adr, nAuthProtocol, szRawCertificate, userinfo);
return g_RehldsHookchains.m_SV_FinishCertificateCheck.callChain(SV_FinishCertificateCheck_internal, adr, nAuthProtocol, szRawCertificate, userinfo);
}
/* <a74f4> ../engine/sv_main.c:2461 */
@ -1950,7 +1950,7 @@ int EXT_FUNC SV_FinishCertificateCheck_internal(netadr_t *adr, int nAuthProtocol
int SV_CheckKeyInfo(netadr_t *adr, char *protinfo, short unsigned int *port, int *pAuthProtocol, char *pszRaw, char *cdkey)
{
return g_RehldsHookchains.m_SV_CheckKeyInfo.callChain(SV_CheckKeyInfo_internal, 0, adr, protinfo, port, pAuthProtocol, pszRaw, cdkey);
return g_RehldsHookchains.m_SV_CheckKeyInfo.callChain(SV_CheckKeyInfo_internal, adr, protinfo, port, pAuthProtocol, pszRaw, cdkey);
}
/* <a7584> ../engine/sv_main.c:2527 */
@ -7124,7 +7124,7 @@ void SV_Shutdown(void)
qboolean SV_CompareUserID(USERID_t *id1, USERID_t *id2)
{
return g_RehldsHookchains.m_SV_CompareUserID.callChain(SV_CompareUserID_internal, 0, id1, id2);
return g_RehldsHookchains.m_SV_CompareUserID.callChain(SV_CompareUserID_internal, id1, id2);
}
/* <a5ef9> ../engine/sv_main.c:9585 */
@ -7153,7 +7153,7 @@ qboolean EXT_FUNC SV_CompareUserID_internal(USERID_t *id1, USERID_t *id2)
char* SV_GetIDString(USERID_t *id)
{
return g_RehldsHookchains.m_SV_GetIDString.callChain(SV_GetIDString_internal, 0, id);
return g_RehldsHookchains.m_SV_GetIDString.callChain(SV_GetIDString_internal, id);
}
/* <aad82> ../engine/sv_main.c:9625 */

View File

@ -687,7 +687,7 @@ qboolean EXT_FUNC Steam_NotifyClientConnect_api(IGameClient *cl, const void *pvS
qboolean Steam_NotifyClientConnect(client_t *cl, const void *pvSteam2Key, unsigned int ucbSteam2Key)
{
return g_RehldsHookchains.m_Steam_NotifyClientConnect
.callChain(Steam_NotifyClientConnect_api, FALSE, GetRehldsApiClient(cl), pvSteam2Key, ucbSteam2Key);
.callChain(Steam_NotifyClientConnect_api, GetRehldsApiClient(cl), pvSteam2Key, ucbSteam2Key);
}
/* <f1884> ../engine/sv_steam3.cpp:914 */
@ -707,7 +707,7 @@ qboolean EXT_FUNC Steam_NotifyBotConnect_api(IGameClient* cl)
qboolean Steam_NotifyBotConnect(client_t *cl)
{
return g_RehldsHookchains.m_Steam_NotifyBotConnect.callChain(Steam_NotifyBotConnect_api, FALSE, GetRehldsApiClient(cl));
return g_RehldsHookchains.m_Steam_NotifyBotConnect.callChain(Steam_NotifyBotConnect_api, GetRehldsApiClient(cl));
}
/* <f18cf> ../engine/sv_steam3.cpp:924 */

View File

@ -142,7 +142,10 @@ void SV_ParseConsistencyResponse(client_t *pSenderClient)
Q_memcpy(resbuffer, r->rguc_reserved, sizeof(resbuffer));
if (!Q_memcmp(resbuffer, nullbuffer, sizeof(resbuffer)))
{
if (MSG_ReadBits(32) != *(uint32 *)&r->rgucMD5_hash[0])
uint32 hash = MSG_ReadBits(32);
g_RehldsHookchains.m_GenericFileConsistencyResponce.callChain(NULL, GetRehldsApiClient(pSenderClient), r, hash);
if (hash != *(uint32 *)&r->rgucMD5_hash[0])
c = idx + 1;
}
else

View File

@ -30,12 +30,22 @@
template<typename t_ret, typename ...t_args>
class IHookChain {
protected:
virtual ~IHookChain() { }
virtual ~IHookChain() {}
public:
virtual t_ret callNext(t_args... args) = 0;
virtual t_ret getOriginalReturnResult() = 0;
virtual bool isOriginalCalled() = 0;
virtual t_ret callOriginal(t_args... args) = 0;
};
template<typename ...t_args>
class IVoidHookChain
{
protected:
virtual ~IVoidHookChain() {}
public:
virtual void callNext(t_args... args) = 0;
virtual void callOriginal(t_args... args) = 0;
};
// Hook chain registry(for hooks [un]registration)
@ -48,16 +58,6 @@ public:
virtual void unregisterHook(hookfunc_t hook) = 0;
};
template<typename ...t_args>
class IVoidHookChain {
public:
virtual void callNext(t_args... args) = 0;
virtual bool isOriginalCalled() = 0;
};
// Hook chain registry(for hooks [un]registration)
template<typename ...t_args>
class IVoidHookChainRegistry {

View File

@ -34,8 +34,8 @@
#include "interface.h"
#include "model.h"
#define REHLDS_API_VERSION_MAJOR 1
#define REHLDS_API_VERSION_MINOR 3
#define REHLDS_API_VERSION_MAJOR 2
#define REHLDS_API_VERSION_MINOR 0
//Steam_NotifyClientConnect hook
typedef IHookChain<qboolean, IGameClient*, const void*, unsigned int> IRehldsHook_Steam_NotifyClientConnect;
@ -141,6 +141,10 @@ typedef IVoidHookChainRegistry<edict_t *, int, const char *, float, float, int,
typedef IVoidHookChain<IGameClient *, char *, size_t, sizebuf_t *, IGameClient *> IRehldsHook_SV_WriteFullClientUpdate;
typedef IVoidHookChainRegistry<IGameClient *, char *, size_t, sizebuf_t *, IGameClient *> IRehldsHookRegistry_SV_WriteFullClientUpdate;
//SV_GenericFileConsistencyResponce hook
typedef IVoidHookChain<IGameClient *, resource_t *, uint32> IRehldsHook_GenericFileConsistencyResponce;
typedef IVoidHookChainRegistry<IGameClient *, resource_t *, uint32> IRehldsHookRegistry_GenericFileConsistencyResponce;
class IRehldsHookchains {
public:
virtual ~IRehldsHookchains() { }
@ -171,6 +175,7 @@ public:
virtual IRehldsHookRegistry_PF_Remove_I* PF_Remove_I() = 0;
virtual IRehldsHookRegistry_PF_BuildSoundMsg_I* PF_BuildSoundMsg_I() = 0;
virtual IRehldsHookRegistry_SV_WriteFullClientUpdate* SV_WriteFullClientUpdate() = 0;
virtual IRehldsHookRegistry_GenericFileConsistencyResponce* GenericFileConsistencyResponce() = 0;
};
struct RehldsFuncs_t {

View File

@ -77,6 +77,7 @@ public:
class INetChan {
public:
virtual const netadr_t* GetRemoteAdr() = 0;
virtual sizebuf_t* GetMessageBuf() = 0;
// this must be the last virtual function in class
@ -108,6 +109,8 @@ public:
virtual const char* GetName() = 0;
virtual uint32 GetWorldmapCrc() = 0;
virtual uint8* GetClientDllMd5() = 0;
virtual sizebuf_t* GetDatagram() = 0;
virtual sizebuf_t* GetReliableDatagram() = 0;
virtual void SetModelName(const char* modelname) = 0;
};

View File

@ -17,26 +17,7 @@
*/
#include "precompiled.h"
AbstractHookChain::AbstractHookChain() {
memset(m_Hooks, 0, sizeof(m_Hooks));
m_NumHooks = 0;
m_CurHook = 0;
m_bOriginalCalled = false;
m_OriginalFunc = NULL;
}
void* AbstractHookChain::nextHook() {
return (m_CurHook < m_NumHooks) ? m_Hooks[m_CurHook++] : NULL;
}
void AbstractHookChain::init(void* origFunc, void* hooks, int numHooks) {
m_OriginalFunc = origFunc;
m_NumHooks = numHooks;
m_CurHook = 0;
m_bOriginalCalled = false;
memcpy(m_Hooks, hooks, numHooks * sizeof(size_t));
}
#include "hookchains_impl.h"
AbstractHookChainRegistry::AbstractHookChainRegistry()
{

View File

@ -28,96 +28,82 @@
#pragma once
#include "hookchains.h"
#define MAX_HOOKS_IN_CHAIN 64
class AbstractHookChain {
protected:
void* m_Hooks[MAX_HOOKS_IN_CHAIN];
void* m_OriginalFunc;
int m_CurHook;
int m_NumHooks;
bool m_bOriginalCalled;
AbstractHookChain();
void* nextHook();
public:
void init(void* origFunc, void* hooks, int numHooks);
};
#define MAX_HOOKS_IN_CHAIN 63
// Implementation for chains in modules
template<typename t_ret, typename ...t_args>
class IHookChainImpl : public IHookChain<t_ret, t_args...>, public AbstractHookChain {
class IHookChainImpl : public IHookChain<t_ret, t_args...> {
public:
typedef t_ret(*hookfunc_t)(IHookChain<t_ret, t_args...>*, t_args...);
typedef t_ret(*origfunc_t)(t_args...);
private:
t_ret m_OriginalReturnResult;
public:
virtual ~IHookChainImpl() { }
IHookChainImpl(t_ret defaultResult) {
m_OriginalReturnResult = defaultResult;
IHookChainImpl(void** hooks, origfunc_t orig) : m_Hooks(hooks), m_OriginalFunc(orig)
{
if (orig == NULL)
rehlds_syserror("Non-void HookChain without original function.");
}
virtual ~IHookChainImpl() {}
virtual t_ret callNext(t_args... args) {
void* nextvhook = nextHook();
if (nextvhook) {
hookfunc_t nexthook = (hookfunc_t)nextvhook;
return nexthook(this, args...);
hookfunc_t nexthook = (hookfunc_t)m_Hooks[0];
if (nexthook)
{
IHookChainImpl nextChain(m_Hooks + 1, m_OriginalFunc);
return nexthook(&nextChain, args...);
}
origfunc_t origfunc = (origfunc_t)m_OriginalFunc;
m_OriginalReturnResult = origfunc(args...);
m_bOriginalCalled = true;
return m_OriginalReturnResult;
return m_OriginalFunc(args...);
}
virtual t_ret getOriginalReturnResult() {
return m_OriginalReturnResult;
virtual t_ret callOriginal(t_args... args) {
return m_OriginalFunc(args...);
}
virtual bool isOriginalCalled() {
return m_bOriginalCalled;
}
private:
void** m_Hooks;
origfunc_t m_OriginalFunc;
};
// Implementation for void chains in modules
template<typename ...t_args>
class IVoidHookChainImpl : public IVoidHookChain<t_args...>, public AbstractHookChain {
class IVoidHookChainImpl : public IVoidHookChain<t_args...> {
public:
typedef void(*hookfunc_t)(IVoidHookChain<t_args...>*, t_args...);
typedef void(*origfunc_t)(t_args...);
virtual ~IVoidHookChainImpl() { }
IVoidHookChainImpl(void** hooks, origfunc_t orig) : m_Hooks(hooks), m_OriginalFunc(orig) {}
virtual ~IVoidHookChainImpl() {}
virtual void callNext(t_args... args) {
void* nextvhook = nextHook();
if (nextvhook) {
hookfunc_t nexthook = (hookfunc_t)nextvhook;
nexthook(this, args...);
return;
}
hookfunc_t nexthook = (hookfunc_t)m_Hooks[0];
if (nexthook)
{
IVoidHookChainImpl nextChain(m_Hooks + 1, m_OriginalFunc);
nexthook(&nextChain, args...);
}
else
{
if (m_OriginalFunc)
m_OriginalFunc(args...);
}
}
virtual void callOriginal(t_args... args) {
origfunc_t origfunc = (origfunc_t)m_OriginalFunc;
if (origfunc) {
origfunc(args...);
}
m_bOriginalCalled = true;
origfunc(args...);
}
virtual bool isOriginalCalled() {
return m_bOriginalCalled;
}
private:
void** m_Hooks;
origfunc_t m_OriginalFunc;
};
class AbstractHookChainRegistry {
protected:
void* m_Hooks[MAX_HOOKS_IN_CHAIN];
void* m_Hooks[MAX_HOOKS_IN_CHAIN + 1]; // +1 for null
int m_NumHooks;
protected:
@ -136,9 +122,8 @@ public:
virtual ~IHookChainRegistryImpl() { }
t_ret callChain(origfunc_t origFunc, t_ret defaultResult, t_args... args) {
IHookChainImpl<t_ret, t_args...> chain(defaultResult);
chain.init((void*)origFunc, m_Hooks, m_NumHooks);
t_ret callChain(origfunc_t origFunc, t_args... args) {
IHookChainImpl<t_ret, t_args...> chain(m_Hooks, origFunc);
return chain.callNext(args...);
}
@ -159,14 +144,14 @@ public:
virtual ~IVoidHookChainRegistryImpl() { }
void callChain(origfunc_t origFunc, t_args... args) {
IVoidHookChainImpl<t_args...> chain;
chain.init((void*)origFunc, m_Hooks, m_NumHooks);
IVoidHookChainImpl<t_args...> chain(m_Hooks, origFunc);
chain.callNext(args...);
}
virtual void registerHook(hookfunc_t hook) {
addHook((void*)hook);
}
virtual void unregisterHook(hookfunc_t hook) {
removeHook((void*)hook);
}

View File

@ -253,6 +253,10 @@ IRehldsHookRegistry_SV_WriteFullClientUpdate* CRehldsHookchains::SV_WriteFullCli
return &m_SV_WriteFullClientUpdate;
}
IRehldsHookRegistry_GenericFileConsistencyResponce* CRehldsHookchains::GenericFileConsistencyResponce() {
return &m_GenericFileConsistencyResponce;
}
int EXT_FUNC CRehldsApi::GetMajorVersion()
{
return REHLDS_API_VERSION_MAJOR;

View File

@ -135,6 +135,10 @@ typedef IVoidHookChainRegistryImpl<edict_t *, int, const char *, float, float, i
typedef IVoidHookChainImpl<IGameClient *, char *, size_t, sizebuf_t *, IGameClient *> CRehldsHook_SV_WriteFullClientUpdate;
typedef IVoidHookChainRegistryImpl<IGameClient *, char *, size_t, sizebuf_t *, IGameClient *> CRehldsHookRegistry_SV_WriteFullClientUpdate;
//SV_WriteFullClientUpdate hook
typedef IVoidHookChainImpl<IGameClient *, resource_t *, uint32> CRehldsHook_GenericFileConsistencyResponce;
typedef IVoidHookChainRegistryImpl<IGameClient *, resource_t *, uint32> CRehldsHookRegistry_GenericFileConsistencyResponce;
class CRehldsHookchains : public IRehldsHookchains {
public:
CRehldsHookRegistry_Steam_NotifyClientConnect m_Steam_NotifyClientConnect;
@ -163,6 +167,7 @@ public:
CRehldsHookRegistry_PF_Remove_I m_PF_Remove_I;
CRehldsHookRegistry_PF_BuildSoundMsg_I m_PF_BuildSoundMsg_I;
CRehldsHookRegistry_SV_WriteFullClientUpdate m_SV_WriteFullClientUpdate;
CRehldsHookRegistry_GenericFileConsistencyResponce m_GenericFileConsistencyResponce;
public:
virtual IRehldsHookRegistry_Steam_NotifyClientConnect* Steam_NotifyClientConnect();
@ -191,6 +196,7 @@ public:
virtual IRehldsHookRegistry_PF_Remove_I* PF_Remove_I();
virtual IRehldsHookRegistry_PF_BuildSoundMsg_I* PF_BuildSoundMsg_I();
virtual IRehldsHookRegistry_SV_WriteFullClientUpdate* SV_WriteFullClientUpdate();
virtual IRehldsHookRegistry_GenericFileConsistencyResponce* GenericFileConsistencyResponce();
};
extern CRehldsHookchains g_RehldsHookchains;

View File

@ -111,6 +111,11 @@ const netadr_t* EXT_FUNC CNetChan::GetRemoteAdr()
return &m_pNetChan->remote_address;
}
sizebuf_t* EXT_FUNC CNetChan::GetMessageBuf()
{
return &m_pNetChan->message;
}
netchan_t* EXT_FUNC CNetChan::GetChan()
{
return m_pNetChan;
@ -178,6 +183,14 @@ uint8* EXT_FUNC CRehldsServerData::GetClientDllMd5() {
return g_psv.clientdllmd5;
}
sizebuf_t* EXT_FUNC CRehldsServerData::GetDatagram() {
return &g_psv.datagram;
}
sizebuf_t* EXT_FUNC CRehldsServerData::GetReliableDatagram() {
return &g_psv.reliable_datagram;
}
void Rehlds_Interfaces_FreeClients()
{
if (g_GameClients == NULL)

View File

@ -39,8 +39,7 @@ public:
CNetChan(netchan_t* chan);
virtual const netadr_t* GetRemoteAdr();
virtual sizebuf_t* GetMessageBuf();
virtual netchan_t* GetChan();
};
@ -96,6 +95,8 @@ public:
virtual const char* GetName();
virtual uint32 GetWorldmapCrc();
virtual uint8* GetClientDllMd5();
virtual sizebuf_t* GetDatagram();
virtual sizebuf_t* GetReliableDatagram();
virtual void SetModelName(const char* modelname);
};

View File

@ -1,11 +1,20 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
#include <iostream>
TEST(CRC32C_Hash, CRC32C, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.2 Support", cpuinfo.sse4_2);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_2)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.2 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
const char* src;

View File

@ -1,10 +1,19 @@
#include "precompiled.h"
#include "rehlds_tests_shared.h"
#include "cppunitlite/TestHarness.h"
#include <iostream>
TEST(AngleVectorsTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t angles;
@ -41,7 +50,15 @@ TEST(AngleVectorsTest, MathLib, 1000) {
TEST(AngleVectorsTransposeTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t angles;
@ -78,7 +95,15 @@ TEST(AngleVectorsTransposeTest, MathLib, 1000) {
TEST(AngleMatrixTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t angles;
@ -120,7 +145,15 @@ TEST(AngleMatrixTest, MathLib, 1000) {
TEST(DotProductTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t v1;
@ -146,7 +179,15 @@ TEST(DotProductTest, MathLib, 1000) {
TEST(CrossProductTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t v1;
@ -176,7 +217,15 @@ TEST(CrossProductTest, MathLib, 1000) {
TEST(LengthTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t v;
@ -201,7 +250,15 @@ TEST(LengthTest, MathLib, 1000) {
TEST(Length2DTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t v;
@ -226,7 +283,15 @@ TEST(Length2DTest, MathLib, 1000) {
TEST(VectorNormalizeTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t vecIn;
@ -257,7 +322,15 @@ TEST(VectorNormalizeTest, MathLib, 1000) {
TEST(VectorAnglesTest, MathLib, 1000) {
Sys_CheckCpuInstructionsSupport();
CHECK("SSE4.1 Support", cpuinfo.sse4_1);
//CHECK("SSE4.1 Support", cpuinfo.sse4_1);
if (!cpuinfo.sse4_1)
{
std::stringstream ss;
ss << "Test '" __FUNCTION__ "' not runned: sse 4.1 doesn't supported";
std::cout << ss.str() << std::endl;
std::cout.flush();
return;
}
struct testdata_t {
vec3_t forward;