Registrierung Kalender Mitgliederliste Teammitglieder Suche Häufig gestellte Fragen Zur Startseite

Informatiker Board » Themengebiete » Technische Informatik » Assembler: Adressberechnung mit Pointer » Antwort erstellen » Hallo Gast [Anmelden|Registrieren]

Antwort erstellen
Benutzername: (du bist nicht eingeloggt!)
Thema:
Nachricht:

HTML ist nicht erlaubt
BBCode ist erlaubt
Smilies sind erlaubt
Bilder sind erlaubt

Smilies: 21 von 33
smileWinkDaumen hoch
verwirrtAugenzwinkerngeschockt
Mit ZungeGottunglücklich
Forum Kloppebösegroßes Grinsen
TanzentraurigProst
TeufelSpamWillkommen
LehrerLOL HammerZunge raus
Hilfe 
aktuellen Tag schließen
alle Tags schließen
fettgedruckter Textkursiver Textunterstrichener Text zentrierter Text Hyperlink einfügenE-Mail-Adresse einfügenBild einfügen Zitat einfügenListe erstellen CODE einfügenPHP CODE farbig hervorheben
Spamschutz:
Text aus Bild eingeben
Spamschutz

Die letzten 2 Beiträge
ed209

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
Lena 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 =)