• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 307
  • Last Modified:

Memory Address cheating

Hi
I've been trying to create my own trainers for games but whenever I find the memory addresses where certain values are stored, when i restart the game the memory address changes. Is this suppost to happen?
Thanx
0
social_suicide
Asked:
social_suicide
1 Solution
 
Jase-CoderCommented:
Other things maybe using memory at the same time so it the space your game once occupied maybe taken up by another program.
0
 
lexicon_dominusCommented:
In my opinion what you have to do is, your trainer should locate the game in memory and use relative addressing. As for an example; suppose that you money is kept in DS:ESI register pair which is for the first run of the game 0010:032F; the second run 002F:032F etc.. All you have to do is to find the Data Segment starting address if the values are kept in there...
0
 
str_ekCommented:
well if you're trying it for win32 just remember that we have abstract address spaces here

and just one more tip.. if you try to hack some realy big apps you're may be out of luck , cos the memory fragmentation due to lack of garbage collector makes some non-one-time-alloced-globals to just "travel aroud" depending on the allocation history... in that case you must form an regular expresion to search for, or retrack manualy, by value chnges
0
Cloud Class® Course: Amazon Web Services - Basic

Are you thinking about creating an Amazon Web Services account for your business? Not sure where to start? In this course you’ll get an overview of the history of AWS and take a tour of their user interface.

 
teratomaCommented:
I'm assuming an Intel processor.  

Given a variable that lives the whole lifetime of the program, there are 3 places where it can be stored: static data, stack, and heap.  If it's just some temporary variable, you don't stand much chance of pegging it.

The only way stack data will survive the whole program run is if it's allocated within maybe one or two calls deep from main, in which case it might as well be static because its offset in memory will only depend on load-time parameters.  Therefore, either the data is at a fixed offset from the start of the program's data, in which case you can predict its location per lexicon's strategy, or it's dynamically allocated, in which case you can't.

Garbage collection has nothing to do with this topic, only whether the variable is allocated on the heap.  Even a one-time allocation from the heap will tend to vary with each run of the program because this memory can be allocated from anywhere within system RAM by the operating system.  
0
 
lexicon_dominusCommented:
Hello again;
You can find tutorials about game trainers here:
http://www.gamehacking.com/sites/beginner.php
Another useful site about the subject :
http://programmers-corner.com/viewTutorial.php/30
Another site (You can find general information here and also there is a tutorial about starcraft trainer)
http://win32assembly.online.fr/tutorials.html

Hope these helps...
0
 
social_suicideAuthor Commented:
Thanx for all the comments. I think ill just give up trainer making and leave it 2 the experts. Thanx for the help.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now