Help with "generic setter" / shared code functions

Memory scanning, code injection, debugger internals and other gamemodding related discussion
Post Reply
User avatar
dennisab
Noobzor
Noobzor
Posts: 7
Joined: Sat Mar 24, 2018 7:11 am
Reputation: 5

Help with "generic setter" / shared code functions

Post by dennisab »

I'm having difficulties with game functions that write to hundreds of different addresses and I am not referring to those that write to multiple health addresses but functions that I swear seems to be used for almost everything in the game, sometimes including UI stuff or other lower-level stuff which gets called thousands of times per second.

Some of the time, this is straightforward to work around and inject custom logic because one of the registers may hold some kind of indexing information for example:

original game code:

Code: Select all

mov ecx,[eax+ecx*4] // where ECX could be 0x8 if writing to health, or 0xC if mana
mov [ecx+4],ebx // update value
where I'll usually do something like:

Code: Select all

...
healthEntryPoint:
  cmp ecx,8
  jne manaEntryPoint
  mov ebx,[customHealthValue]
  jmp code

manaEntryPoint:
  cmp ecx,C
  jne origCode
  mov ebx,[customManaValue]

origCode:
  mov [ecx+4],eb
...


There are also times that this is not the case, so I just look at the stack trace and decide to just use the calling function as my entry point; however, I've also found that many times, 5 functions in the stack are also generic and it can get really challenging to come up with a reliable conditional check to do a specific thing like modify health. I've found this to be the case in games that use "in-house" game engines and almost every Java game. I know how to use the structure compare/dissect tool to determine other things so I can, for example, only target player units on the map instead of enemies. The problem I have is figuring out what exactly the function is doing given the register values at the time of invocation.

Any tips to on how to approach this in general? I'm looking for more ideas or if there is a another tool within CE that can help with these scenarios.

Post Reply

Who is online

Users browsing this forum: No registered users