Disassemblierung

Disassemblierung

Ein Disassembler ist ein Computerprogramm, das die binär kodierte Maschinensprache eines ausführbaren Programmes in eine für Menschen lesbarere Assemblersprache umwandelt. Er ist also ein spezieller Übersetzer, der den umgekehrten Arbeitsvorgang eines Assemblers durchführt.

Inhaltsverzeichnis

Funktionsweise

Zu jedem Prozessorbefehl existiert ein gleichwertiger Assemblerbefehl, ein so genannter Mnemonic. Auch die einzelnen Argumente der Prozessorbefehle, wie Registernummern und Speicheradressen lassen sich eins zu eins in Assemblercode übertragen. Ein Disassembler macht also nichts anderes, als die binären Repräsentationen der Prozessorbefehle durch für Menschen lesbare zu ersetzen.

Auch, wenn das Programm direkt in Assembler geschrieben wurde, lässt sich im Allgemeinen nicht der ursprüngliche Code wiederherstellen. Pseudobefehle, Labels und Kommentare haben keine oder zumindest keine direkte, d. h. umkehrbar eindeutige Entsprechung im Maschinencode, was die Rekonstruktion derselben sehr schwer oder gar unmöglich macht. Ist das Programm hingegen in einer höheren Programmiersprache geschrieben, so hat der Compiler meist diverse Optimierungen vorgenommen, was das Programm schneller, aber den Maschinencode komplexer macht.

Ein reines Diassemblat ist damit also oft deutlich schlechter lesbar als der ursprüngliche (Assembler-)Code.

Nutzen

Der Zweck eines Disassemblers liegt meistens darin, die Diagnose und das Auffinden von potenziellen Fehlern in einem Programm zu erleichtern oder die Ausgabe eines Compilers zu überprüfen. Gelegentlich wird er auch zum Reverse Engineering benutzt.

Rechtliche Aspekte

Proprietäre Software steht oft unter einer EULA, die das Disassemblieren sowie Dekompilieren untersagt. Dies ist jedoch in Deutschland nur in seltenen Fällen rechtlich bindend. Auch ist Reverse-Engineering zur Herstellung von Kompatibilität mit der Software dritter ausdrücklich gesetzlich gesichert erlaubt – und damit nicht durch einen Lizenzvertrag zu unterbinden. [1]

Die Tätigkeit des Disassemblierens ist bei urheberrechtlich geschützten Programmen allerdings in einigen Ländern durch gesetzliche Bestimmungen reglementiert, da das Disassemblieren die Möglichkeit eröffnet, den Code zu ändern und danach wieder in ein Programm zu assemblieren. So könnte z. B. von erfahrenen Assembler-Programmierern und Crackern eine Passwortabfrage entfernt, eine aus lizenzrechtlichen Gründen abgeschaltete Funktion aktiviert, oder ein Virus unbemerkt in das Programm eingeschleust werden. Ausführliche Erläuterungen zu diesem Aspekt von Disassemblern und vergleichbaren Werkzeugen finden sich im Artikel Reverse Engineering.

Sonstiges

Nahezu alle Debugger enthalten einen Disassembler. Auch Programme zur Inspektion von Binärdateien enthalten oftmals einen Disassembler. Manche Assembler beinhalten auch einen Disassembler. Ein bekannter und häufig eingesetzter Disassembler ist zum Beispiel IDA von Ilfak Guilfanov, da er Assemblercode strukturiert anzeigen kann. Weitere Software zum disassemblieren ist eine Kombination aus W32DASM und SoftICE.

Der Vorgang des Disassemblierens wird in der deutschsprachigen Fachliteratur teilweise auch mit den Begriffen entassemblieren oder entkompilieren bezeichnet, was aber das gleiche meint.

Quellen

  1. In Deutschland gemäß § 69e UrhG (Dekompilierung)

Weblinks


Wikimedia Foundation.

Игры ⚽ Поможем решить контрольную работу

Schlagen Sie auch in anderen Wörterbüchern nach:

  • AmiBlitz — ist die Open Source Variante des ehemals für den Amiga geschriebenen, kommerziellen BASIC Compilers BlitzBasic. Als Acid Software dem Amigamarkt im Jahre 2001 den Rücken kehrte, um BlitzBasic2 auf anderen Betriebssystemen zu vermarkten,… …   Deutsch Wikipedia

  • Amiblitz — ist die Open Source Variante des ehemals für den Amiga geschriebenen, kommerziellen BASIC Compilers BlitzBasic. Als Acid Software dem Amigamarkt im Jahre 2001 den Rücken kehrte, um BlitzBasic2 auf anderen Betriebssystemen zu vermarkten,… …   Deutsch Wikipedia

  • Assembler-Code — Eine Assemblersprache ist eine spezielle Programmiersprache, welche die Maschinensprache einer spezifischen Prozessorarchitektur in einer für den Menschen lesbaren Form repräsentiert. Jede Computerarchitektur hat folglich ihre eigene… …   Deutsch Wikipedia

  • Assemblersprache — Eine Assemblersprache (oft abgekürzt als ASM bzw. asm) ist eine spezielle Programmiersprache, welche die Maschinensprache einer spezifischen Prozessorarchitektur in einer für den Menschen lesbaren Form repräsentiert. Jede Computerarchitektur hat… …   Deutsch Wikipedia

  • Assemblersprachen — Eine Assemblersprache ist eine spezielle Programmiersprache, welche die Maschinensprache einer spezifischen Prozessorarchitektur in einer für den Menschen lesbaren Form repräsentiert. Jede Computerarchitektur hat folglich ihre eigene… …   Deutsch Wikipedia

  • Assembley — Eine Assemblersprache ist eine spezielle Programmiersprache, welche die Maschinensprache einer spezifischen Prozessorarchitektur in einer für den Menschen lesbaren Form repräsentiert. Jede Computerarchitektur hat folglich ihre eigene… …   Deutsch Wikipedia

  • Assembley Language — Eine Assemblersprache ist eine spezielle Programmiersprache, welche die Maschinensprache einer spezifischen Prozessorarchitektur in einer für den Menschen lesbaren Form repräsentiert. Jede Computerarchitektur hat folglich ihre eigene… …   Deutsch Wikipedia

  • Benedict Torvalds — Linus Torvalds 2004 Linus Benedict Torvalds ( [ˈliːnɵs ˈtuːrvalds] ?/Info/IPA; * 28. Dezember 1969 in Helsinki, Finnland) ist ein finnischer Programmierer und Initiator des Kernels …   Deutsch Wikipedia

  • Hsp70 — Heat shock 70 kDa protein 1A Vorhandene Strukturdaten …   Deutsch Wikipedia

  • Linus Benedict Torvalds — Linus Torvalds 2004 Linus Benedict Torvalds ( [ˈliːnɵs ˈtuːrvalds] ?/Info/IPA; * 28. Dezember 1969 in Helsinki, Finnland) ist ein finnischer Programmierer und Initiator des Kernels …   Deutsch Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”