From 7059f5b3b980f1e4addfd81054d815a64cc0e3c5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Valentin=20Gr=C3=BCnbacher?= Date: Thu, 11 Jun 2015 16:08:46 +0200 Subject: [PATCH] Engine: Detour LightStyle to catch all calls, restores set_lights() functionality --- modules/engine/AMBuilder | 3 ++ modules/engine/Makefile | 5 ++- modules/engine/amxxapi.cpp | 44 +++++++++++++++++--- modules/engine/engine.cpp | 17 +++++--- modules/engine/engine.h | 3 ++ modules/engine/forwards.cpp | 7 ---- modules/engine/moduleconfig.h | 2 +- modules/engine/msvc12/engine.vcxproj | 9 +++- modules/engine/msvc12/engine.vcxproj.filters | 30 +++++++++++++ public/amtl | 2 +- 10 files changed, 99 insertions(+), 23 deletions(-) diff --git a/modules/engine/AMBuilder b/modules/engine/AMBuilder index e94a3797..12715fb0 100644 --- a/modules/engine/AMBuilder +++ b/modules/engine/AMBuilder @@ -14,6 +14,9 @@ binary.sources = [ 'entity.cpp', 'globals.cpp', 'forwards.cpp', + '../../public/memtools/MemoryUtils.cpp', + '../../public/memtools/CDetour/detours.cpp', + '../../public/memtools/CDetour/asm/asm.c', ] if builder.target_platform == 'windows': diff --git a/modules/engine/Makefile b/modules/engine/Makefile index c7044492..1797f04b 100644 --- a/modules/engine/Makefile +++ b/modules/engine/Makefile @@ -30,7 +30,7 @@ CPP_OSX = clang LINK = -INCLUDE = -I. -I$(PUBLIC_ROOT) -I$(PUBLIC_ROOT)/sdk -I$(PUBLIC_ROOT)/amtl \ +INCLUDE = -I. -I$(PUBLIC_ROOT) -I$(PUBLIC_ROOT)/sdk -I$(PUBLIC_ROOT)/memtools -I$(PUBLIC_ROOT)/memtools/CDetour -I$(PUBLIC_ROOT)/memtools/CDetour/asm -I$(PUBLIC_ROOT)/amtl \ -I$(HLSDK) -I$(HLSDK)/public -I$(HLSDK)/common -I$(HLSDK)/dlls -I$(HLSDK)/engine -I$(HLSDK)/game_shared -I$(HLSDK)/pm_shared\ -I$(MM_ROOT) @@ -108,6 +108,9 @@ $(BIN_DIR)/%.o: %.cpp all: mkdir -p $(BIN_DIR) ln -sf $(PUBLIC_ROOT)/sdk/amxxmodule.cpp + ln -sf $(PUBLIC_ROOT)/memtools/MemoryUtils.cpp + ln -sf $(PUBLIC_ROOT)/memtools/CDetour/detours.cpp + ln -sf $(PUBLIC_ROOT)/memtools/CDetour/asm/asm.c $(MAKE) -f $(MAKEFILE_NAME) $(PROJECT) $(PROJECT): $(OBJ_BIN) diff --git a/modules/engine/amxxapi.cpp b/modules/engine/amxxapi.cpp index 259978e2..3be75992 100644 --- a/modules/engine/amxxapi.cpp +++ b/modules/engine/amxxapi.cpp @@ -14,6 +14,10 @@ #include "engine.h" BOOL CheckForPublic(const char *publicname); +void CreateDetours(); +void DestroyDetours(); + +CDetour *LightStyleDetour = NULL; edict_t *g_player_edicts[33]; @@ -58,6 +62,13 @@ void OnAmxxAttach() memset(glinfo.szLastLights, 0x0, 128); memset(glinfo.szRealLights, 0x0, 128); glinfo.bCheckLights = false; + + CreateDetours(); +} + +void OnAmxxDetach() +{ + DestroyDetours(); } void OnPluginsLoaded() @@ -209,7 +220,6 @@ void ServerDeactivate() g_pFunctionTable->pfnThink=NULL; // "pfn_think", "register_think" g_pFunctionTable->pfnStartFrame=NULL; // "server_frame","ServerFrame" g_pFunctionTable->pfnTouch=NULL; // "pfn_touch","vexd_pfntouch" - g_pFunctionTable_Post->pfnStartFrame = NULL; // "set_lights" ClearHooks(); @@ -224,15 +234,27 @@ void ServerActivate(edict_t *pEdictList, int edictCount, int clientMax) RETURN_META(MRES_IGNORED); } -void LightStyle_Post(int style, const char *val) { +DETOUR_DECL_STATIC2(LightStyle, void, int, style, const char *, val) // void (*pfnLightStyle) (int style, const char* val); +{ + DETOUR_STATIC_CALL(LightStyle)(style, val); + if (!style && strcmp(val, glinfo.szRealLights)) { memset(glinfo.szRealLights, 0x0, 128); - memcpy(glinfo.szRealLights, val, min(strlen(val), 127)); - - if (glinfo.bCheckLights && strcmp(val, glinfo.szLastLights)) - g_pFunctionTable_Post->pfnStartFrame = StartFrame_Post; + memcpy(glinfo.szRealLights, val, ke::Min(strlen(val), (size_t)127)); } + if (glinfo.bCheckLights && strcmp(val, glinfo.szLastLights)) + g_pFunctionTable_Post->pfnStartFrame = StartFrame_Post; +} + +void StartFrame_Post() +{ + g_pFunctionTable_Post->pfnStartFrame = NULL; + + LightStyleDetour->DisableDetour(); + LIGHT_STYLE(0, glinfo.szLastLights); + LightStyleDetour->EnableDetour(); + RETURN_META(MRES_IGNORED); } @@ -256,3 +278,13 @@ BOOL CheckForPublic(const char *publicname) return FALSE; // no public found in any loaded script } + +void CreateDetours() +{ + LightStyleDetour = DETOUR_CREATE_STATIC_FIXED(LightStyle, (void*)(g_engfuncs.pfnLightStyle)); +} + +void DestroyDetours() +{ + LightStyleDetour->Destroy(); +} \ No newline at end of file diff --git a/modules/engine/engine.cpp b/modules/engine/engine.cpp index 71df442f..666d1f9a 100644 --- a/modules/engine/engine.cpp +++ b/modules/engine/engine.cpp @@ -300,8 +300,9 @@ static cell AMX_NATIVE_CALL trace_normal(AMX *amx, cell *params) static cell AMX_NATIVE_CALL trace_line(AMX *amx, cell *params) { int iEnt = params[1]; - if (iEnt != -1) + if (iEnt != -1) { CHECK_ENTITY(iEnt); + } cell *cStart = MF_GetAmxAddr(amx, params[2]); cell *cEnd = MF_GetAmxAddr(amx, params[3]); @@ -370,8 +371,9 @@ static cell AMX_NATIVE_CALL get_info_keybuffer(AMX *amx, cell *params) { int iEnt = params[1]; - if (iEnt != -1) + if (iEnt != -1) { CHECK_ENTITY(iEnt); + } char *info = GETINFOKEYBUFFER((iEnt == -1) ? NULL : INDEXENT2(iEnt)); @@ -546,7 +548,6 @@ static cell AMX_NATIVE_CALL set_lights(AMX *amx, cell *params) { if (FStrEq(szLights, "#OFF")) { glinfo.bCheckLights = false; - g_pFunctionTable_Post->pfnStartFrame = NULL; memset(glinfo.szLastLights, 0x0, 128); LIGHT_STYLE(0, glinfo.szRealLights); return 1; @@ -556,9 +557,11 @@ static cell AMX_NATIVE_CALL set_lights(AMX *amx, cell *params) { //Reset LastLights and store custom lighting memset(glinfo.szLastLights, 0x0, 128); - memcpy(glinfo.szLastLights, szLights, min(iLength, 127)); + memcpy(glinfo.szLastLights, szLights, ke::Min(iLength, 127)); + LightStyleDetour->DisableDetour(); LIGHT_STYLE(0, szLights); + LightStyleDetour->EnableDetour(); // These make it so that players/weaponmodels look like whatever the lighting is // at. otherwise it would color players under the skybox to these values. @@ -573,8 +576,9 @@ static cell AMX_NATIVE_CALL set_lights(AMX *amx, cell *params) { static cell AMX_NATIVE_CALL trace_hull(AMX *amx,cell *params) { int iEnt = params[3]; - if (iEnt > 0) + if (iEnt > 0) { CHECK_ENTITY(iEnt); + } int iResult=0; Vector vStart; @@ -950,8 +954,9 @@ static cell AMX_NATIVE_CALL trace_forward(AMX *amx, cell *params) cell *cAngles = MF_GetAmxAddr(amx, params[2]); REAL fGive = amx_ctof(params[3]); int iIgnoreEnt = params[4]; - if (iIgnoreEnt != -1) + if (iIgnoreEnt != -1) { CHECK_ENTITY(iIgnoreEnt); + } cell *hitX = MF_GetAmxAddr(amx, params[5]); cell *hitY = MF_GetAmxAddr(amx, params[6]); diff --git a/modules/engine/engine.h b/modules/engine/engine.h index e48d93bc..1b5337d5 100644 --- a/modules/engine/engine.h +++ b/modules/engine/engine.h @@ -25,6 +25,7 @@ #include "entity_state.h" #include #include +#include "CDetour/detours.h" extern DLL_FUNCTIONS *g_pFunctionTable; extern DLL_FUNCTIONS *g_pFunctionTable_Post; @@ -47,6 +48,8 @@ extern int DispatchUseForward; extern int VexdTouchForward; extern int VexdServerForward; +extern CDetour *LightStyleDetour; + #define AMS_OFFSET 0.01 #define GETINFOKEYBUFFER (*g_engfuncs.pfnGetInfoKeyBuffer) diff --git a/modules/engine/forwards.cpp b/modules/engine/forwards.cpp index 34faf6c4..5c1f3c64 100644 --- a/modules/engine/forwards.cpp +++ b/modules/engine/forwards.cpp @@ -118,13 +118,6 @@ void StartFrame() RETURN_META(MRES_IGNORED); } -void StartFrame_Post() -{ - g_pFunctionTable_Post->pfnStartFrame = NULL; - LIGHT_STYLE(0, glinfo.szLastLights); - RETURN_META(MRES_IGNORED); -} - void CmdStart(const edict_t *player, const struct usercmd_s *_cmd, unsigned int random_seed) { unsigned int i = 0; diff --git a/modules/engine/moduleconfig.h b/modules/engine/moduleconfig.h index 72e5796f..170e03e5 100644 --- a/modules/engine/moduleconfig.h +++ b/modules/engine/moduleconfig.h @@ -389,7 +389,7 @@ // #define FN_ServerExecute_Post ServerExecute_Post // #define FN_engClientCommand_Post engClientCommand_Post // #define FN_ParticleEffect_Post ParticleEffect_Post -#define FN_LightStyle_Post LightStyle_Post +// #define FN_LightStyle_Post LightStyle_Post // #define FN_DecalIndex_Post DecalIndex_Post // #define FN_PointContents_Post PointContents_Post // #define FN_MessageBegin_Post MessageBegin_Post diff --git a/modules/engine/msvc12/engine.vcxproj b/modules/engine/msvc12/engine.vcxproj index 88b4f687..84e647d0 100644 --- a/modules/engine/msvc12/engine.vcxproj +++ b/modules/engine/msvc12/engine.vcxproj @@ -54,7 +54,7 @@ Disabled - ..\;..\..\..\public;..\..\..\public\sdk; ..\..\..\public\amtl\include;..\..\third_party;..\..\third_party\hashing;$(METAMOD)\metamod;$(HLSDK)\common;$(HLSDK)\engine;$(HLSDK)\dlls;$(HLSDK)\pm_shared;$(HLSDK)\public;%(AdditionalIncludeDirectories) + ..\;..\..\..\public;..\..\..\public\memtools;..\..\..\public\sdk;..\..\..\public\amtl\include;..\..\third_party;..\..\third_party\hashing;$(METAMOD)\metamod;$(HLSDK)\common;$(HLSDK)\engine;$(HLSDK)\dlls;$(HLSDK)\pm_shared;$(HLSDK)\public;%(AdditionalIncludeDirectories) WIN32;NDEBUG;_WINDOWS;_USRDLL;ENGINE_EXPORTS;HAVE_STDINT_H;%(PreprocessorDefinitions) true EnableFastChecks @@ -98,6 +98,9 @@ + + + @@ -106,6 +109,10 @@ + + + + diff --git a/modules/engine/msvc12/engine.vcxproj.filters b/modules/engine/msvc12/engine.vcxproj.filters index b062f64c..5e439186 100644 --- a/modules/engine/msvc12/engine.vcxproj.filters +++ b/modules/engine/msvc12/engine.vcxproj.filters @@ -18,6 +18,15 @@ {e7f2c5c2-cba9-4712-a576-ceb676c94b36} + + {ca6abf66-eee2-4d06-813e-792d82d6e846} + + + {59354b8c-0925-4d8b-bb2b-684f6638de6b} + + + {6c2c3c74-4dc3-45bf-b3a5-6224971eee69} + @@ -38,6 +47,15 @@ Module SDK\SDK Base + + Memtools + + + Memtools\CDetour + + + Memtools\CDetour\asm + @@ -55,6 +73,18 @@ Module SDK\SDK Base + + Memtools + + + Memtools\CDetour + + + Memtools\CDetour + + + Memtools\CDetour\asm + diff --git a/public/amtl b/public/amtl index 9b1cb728..1bb5196c 160000 --- a/public/amtl +++ b/public/amtl @@ -1 +1 @@ -Subproject commit 9b1cb728c931c0b42a23b96a3c0909470769a72f +Subproject commit 1bb5196ce39ff3ed59445e51f9223734d4bcf886