AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

x86-Asm: ModR/M-Byte

Ein Thema von Namenloser · begonnen am 24. Feb 2013 · letzter Beitrag vom 27. Feb 2013
Antwort Antwort
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#1

x86-Asm: ModR/M-Byte

  Alt 24. Feb 2013, 21:44
Hallo,

ich programmier grad aus Interesse einen kleinen Disassembler in Delphi, auf Basis von dieser Datenbank (genauergesagt hab ich ein ziemlich hässliches Ruby-Script zusammengehackt, das den Delphi-Code generiert, aber das sieht ja zum Glück keiner ).

Der Disassembler funktioniert zum Teil auch schon, aber mir bereitet mal wieder das ModR/M-Byte von x86 Kopfzerbrechen. Das letzte mal hatte ich damit bei meinem Brainfuck-Compiler zu tun, aber da ging die Übersetzung in die andere Richtung und die Anzahl der Instruktionen war außerdem stark eingeschränkt. Das Disassemblieren erweist sich als deutlich problematischer...

Und zwar ist mir nicht klar, woran ich erkennen soll, ob bei einer bestimmten Instruktion die 16- oder die 32-Bit-Variante des ModR/M-Bytes zum Einsatz kommt. In der HTML-Version der Tabelle steht auch meistens nur „r/m/16/32“. Es gibt zwar noch ausführlichere Versionen der Tabelle, die näher an der XML-Quelldatei sind, aber daraus werde ich leider ebenfalls nicht schlau...

Ich finde einfach nirgends Dokumentation dazu, nach welchen Kriterien das eine oder das andere anzuwenden ist. Auch das Intel-Handbuch (zumindest das was ich gefunden habe) war leider nicht aufschlussreich...

Ich weiß, dass die Frage ziemlich speziell ist, aber vielleicht kennt sich ja jemand damit aus...

Danke im Voraus

Achja, mich interessiert nur 32Bit-x86... mit 64Bit kann mein 32Bit-Windows eh nichts anfangen... und mein Delphi auch nicht.
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#2

AW: x86-Asm: ModR/M-Byte

  Alt 27. Feb 2013, 06:42
Also offensichtlich ist es tatsächlich so, dass immer die 32-bit-Variante verwendet wird. Genauergesagt ist anscheinend pro Code-Segment festgelegt, ob standardmäßig von 16- oder 32-Bit-OpCodes ausgegangen werden soll. Sagt zumindest Wikipedia:
Zitat von Wikipedia:
To provide backward compatibility, segments with executable code can be marked as containing either 16-bit or 32-bit instructions. Special prefixes allow inclusion of 32-bit instructions in a 16-bit segment or vice versa.
Ich betrachte meine Frage hiermit vorläufig als beantwortet...
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

AW: x86-Asm: ModR/M-Byte

  Alt 27. Feb 2013, 08:16
Hast du das Problem dann nicht theoretisch auch mit anderen Befehlen?

Dass man in Assembler Segmente mit (in nasm z.B.) [BITS 16] anlegen kann hätte ich dir auch sagen können :-X
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Namenloser

Registriert seit: 7. Jun 2006
Ort: Karlsruhe
3.724 Beiträge
 
FreePascal / Lazarus
 
#4

AW: x86-Asm: ModR/M-Byte

  Alt 27. Feb 2013, 09:30
Was meinst du mit „andere Befehle“? Ich hab mich doch gar nicht auf einen bestimmten eingeschränkt

Außerdem sind nasm und Co. gegen das, was ich hier mache, noch high level
  Mit Zitat antworten Zitat
mentaltec

Registriert seit: 28. Sep 2012
60 Beiträge
 
#5

AW: x86-Asm: ModR/M-Byte

  Alt 27. Feb 2013, 11:22
Ha,

endlich mal ne Frage, bei der ich mein HAndbuch des unnützen Wissens auspacken kann:

die verwendete Operandensize bestimmt sich einmal aus dem CodeSegment(Default-Bit im Code Segment Descriptor), aus dem der Befehl stammt und andererseits aus dem eventuell dem Befehl vorauseilenden "Operandensizeverwurschtelungsprefix" 066h

dieser Prefix erlaubt 16bit-Zugriffe aus 32bit-Segmenten bzw. umgekehrt

einen "Adressizeverwurschtelungsprefix" gibts dann auch noch 067h
und bei 64bit-Adressing gibts dann wiederum die REX.B und REX.X Bits, die Einfluss auf die Dekodierung haben

und dann soll es noch einen 64bit Mode geben - aber das war nach meiner Zeit

am Besten [und am Kompliziertesten] ist es, Du lädst Dir direkt bei AMD oder Intel die entsprechende Doku runter imho um die 1500 Seiten

http://developer.amd.com/documentati...t.aspx#manuals
http://support.amd.com/us/Processor_...594_APM_v3.pdf

mfg und viel Spass

http://www.intel.com/products/processor/manuals/
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:04 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz