Assembler: Adressberechnung mit Pointer |
Lena
Grünschnabel
Dabei seit: 02.06.2011
Beiträge: 1
|
|
Assembler: Adressberechnung mit Pointer |
|
Meine Frage:
Hallihallo!
Ich muss einen Assembler-Code verstehen und bin mir nun an einer Stelle sehr unsicher.
jmp *0x8049800(,% eax,4)
Ich habe folgendes ueber den Speicher herausgefunden:
(gdb) x /s *0x8049800
0x8048db2 <phase_3+113>: "\270\205\001"
Im Register % eax steht 3.
Meine Ideen:
Muss ich nun an die Stelle <phase_3+(4*3+113)> springen oder wie wird das berechnet?
Danke schonmal im Voraus,
Lena =)
|
|
02.06.2011 21:55 |
|
|
ed209
Routinier
Dabei seit: 07.09.2006
Beiträge: 324
|
|
Hallo Lena,
Die AT&T-Syntax die gdb verwendet ist mir nicht besonders vertraut, aber laut http://sig9.com/articles/att-syntax bedeutet die Instruktion, daß der Sprung an die Stelle geht, auf die bei 0x8049800 + 4 * EAX verwiesen wird.
So werden normalerweise switch-case-Anweisungen übersetzt. Bei 0x8049800 stände dann eine Tabelle mit Sprung-Adressen für die verschieden Fälle.
Gruß,
ED
|
|
02.06.2011 23:43 |
|
|
|