Hallo Zusammen,
ich möchte gerne für ein Loggingsystem ermitteln welche Methoden/Units für die einzelnen Einträge verantwortlich sind.
Mein Grundgedanke war, die physischen Adressen der Aufrufer in virtuelle umzuwandeln und anschließend in der passenden Map Datei nachzuschlagen (ggf. nicht live sondern nachträgliche Bearbeitung des Logs).
Das umrechnen der Adressen und nachschlagen in der Map Datei hat bereits damit funktioniert:
Code:
var
aCaller: LongWord;
.
.
asm
mov eax,[ebp+4] // top stack
mov aCaller,eax
end;
// minus offset aus der map datei, #401000
VirtualAddress := (aCaller - 4198400).ToHexString;
Das Problem ist nur das ich keine Ahnung habe wie ich jetzt den Aufrufer des Aufrufers usw. ermitteln kann. Bin mit Assembler alles andere als fit und mehr habe ich nach einen Tutorial nicht hinbekommen. Mir ist auch bewusst das dieses Problem in MadExcept und JCL bereits irgendwie gelöst wurde, jedoch möchte ich zuerst eine einfache eigene Lösung haben.