Was tut dieser Assembly Code? (Anfängerfrage)
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Das ist genau das was ich die ganze Zeit mache.
Na dann.
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Aber Danke dennoch für den hilfreichen Kommentar.
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
aber was bezweckt das allozieren mit
subq $32, %rsp
?Ach so, Du willst wissen warum?
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
pushq %rbp movq %rsp, %rbp pushq %r12 pushq %r13 pushq %r14
Wie viele Bytes werden hier gepusht? (Es sind 4 QWORDs ...)
// edit:
WORD = 16 bit (2 bytes)
DWORD = 32 bit (4 bytes)
QWORD = 64 bit (8 bytes)auf heutzutage gängigen desktop-archtekturen. Und das letzte mal als ich nachgesehen habe war 8 x 4 = 32.
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@Swordfish sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
aber was bezweckt das allozieren mit subq $32, %rsp?
Es macht Platz für 32 Bytes auf dem Stack. Das ist genau das was ich die ganze Zeit meine, Beschäftige dich lieber erst mit den Basics.
Das ist genau das was ich die ganze Zeit mache. Aber Danke dennoch für den hilfreichen Kommentar.
Es ist halt schon irgendwie ein bisschen komisch, wie du die Sache angehst. Normalerweise würde man Assembler nicht anders lernen als jede andere Programmiersprache auch. Hello World, einfache Kontrollstrukturen, grundlegende Programmiermuster, und so weiter. Was ja allem Anschein nach auch das Ziel deiner Lehrveranstaltung ist. Du hingegen fängst hier mitten drin an mit Dingen, die du gar nicht verstehst. Nicht nur, dass du Spanisch lernst, wenn es um Französisch geht, du fängst zusätzlich auch noch mit dem Verstehen von Straßenslang an, anstatt mit "Hola, yo soy EinNutzer0".
-
@DirkB sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
assemblersprache ist ja grob gesagt auch nur die ersetzung der zahlenwerte der opcodes durch buchstabenkombinationen, die man sich besser merken kann.
Die ganze Adressberechnung für Sprungziele, Konstanten use. werden auch gemacht.
ja gut, aber prinzipiell kann man ja auch einfach code bzw. funktionen an adresse xy schreiben und bei konstanten auf adresse yz verweisen.
also eigentlich braucht man nur noch in sehr speziellen fällen inline assembler, und visual c++ sperrt sowas bei x64 sogar ganz und verweist auf intrin.h. angeblich kann der compiler das dann auch ganz toll optimieren.
mikrocontroller kannst du ja auch mit C programmieren und wenn du in den speicher schreiben willst, machst du halt sowas:
char *meinaddresszeiger = 0x0815; *meinadresszeiger = 4711;
also evtl. deklarierst du den zeiger noch als volatile, wenn du auslesen willst.
-
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
und visual c++ sperrt sowas bei x64 sogar ganz und verweist auf intrin.h
Der "sperrt" sowas nicht,
cl
ist schlicht unfähig. Sowohl für AMD64 als auch für ARM. Plan B:ml64
.
-
@Swordfish dann ist mein wissen wohl falsch oder veraltet. also mir hat man das damals als "erhöhung von sicherheit" verkauft. aber warum sollte man inline assembler verwenden, wenn es auch c-funktionen gibt, die dann optimiert werden? also C ist doch "genauso wie assembler".
-
@Wade1234 es ist für x64 in
cl
schlichtweg nicht implementiert.
-
@Swordfish ja aber warum sollte man sich dann die mühe machen, alle prozessor-spezifischen funktionen in C zu implementieren? also intrin.h ist da irgendwie schon sehr umfangreich......
-
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@DirkB sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
assemblersprache ist ja grob gesagt auch nur die ersetzung der zahlenwerte der opcodes durch buchstabenkombinationen, die man sich besser merken kann.
Die ganze Adressberechnung für Sprungziele, Konstanten use. werden auch gemacht.
ja gut, aber prinzipiell kann man ja auch einfach code bzw. funktionen an adresse xy schreiben und bei konstanten auf adresse yz verweisen.
also eigentlich braucht man nur noch in sehr speziellen fällen inline assembler, und visual c++ sperrt sowas bei x64 sogar ganz und verweist auf intrin.h. angeblich kann der compiler das dann auch ganz toll optimieren.
mikrocontroller kannst du ja auch mit C programmieren und wenn du in den speicher schreiben willst, machst du halt sowas:
char *meinaddresszeiger = 0x0815; *meinadresszeiger = 4711;
also evtl. deklarierst du den zeiger noch als volatile, wenn du auslesen willst.
So war das nicht gemeint.
Der Assembler übersetzt den Assemblercode in Opcodes. Da kannst du Sprungmarken, Konstanten, Variablen anlegen, fast wie in C.
Wo genau die dann im Speicher liegen, darum kümmert sich der Assembler.
Er übersetzt nicht nur die Mnemonics in den entsprechenden Wert.C ist halt portabler.
-
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@Swordfish ja aber warum sollte man sich dann die mühe machen, alle prozessor-spezifischen funktionen in C zu implementieren? also intrin.h ist da irgendwie schon sehr umfangreich......
intrinsics != inline assembler.
Mit inline assembler kann man viel mehr Sauereien machen.
-
Wie könnte man denn am einfachsten die Brücke schlagen zwischen dem Verstehen von asm und dem Verständnis von Binaries?
-
@Wade1234 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@Swordfish ja aber warum sollte man sich dann die mühe machen, alle prozessor-spezifischen funktionen in C zu implementieren? also intrin.h ist da irgendwie schon sehr umfangreich......
Es gibt so Fälle in denen Assembler noch immer signifikant schneller ist. Die MKL von Intel ist so ein Beispiel, sie implementiert unter anderem die DGEMM Routine, die zwei reelle Matrizen mit double Datatype multipliziert. Im Prinzip eine einfache Sache und die Komplexiztät ist mit O(N^3) für zwei quadratische Matrizen der Größe N auch bekannt. Du kannst aber gerne versuchen mit normalen C Code die Performance der MKL DGEMM Routine zu erreichen. Es wird sehr schwierig.
Für den Einstieg wäre ggf. Gotos Paper hilfreich.
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Und was war zuerst da, Asm oder C?
C ist erst bei der Implementation von UNIX Version 4 zum Einsatz gekommen (1973). Davor wurde UNIX in reinem Assembler implementiert, und C war nicht wirklich existent. Es gab Vorläufersprachen wie B und BCPL, die die Entwicklung von C maßgeblich beeinflusst haben. Diese UNIX Version 4 wurde dann 1973 öffentlich gemacht, und die Bell Labs haben es dann auf Grund spezieller Auflagen der Regierung lizenziert, weil sie es selbst nicht verkaufen durften. Danach begann der Siegeszug von C an den US Universitäten, da diese üblicherweise die DEC Systeme im Einsatz hatten, und UNIX die Möglichkeit bot direkt am Betriebssystem zu forschen. Als dann Mitte der 1980er die ersten potenteren Homecomputer bzw. PCs aufkamen, war C bereits an den Universtäten und in der Industrie fest etabliert. Die 8Bit Homecomputer wurden meisten noch in Assembler programmiert, Amiga (bis auf eine Library die war in BCPL geschrieben) und Atari ST wurden in C programmiert, Apple hatte zuerst ObjectPascal benutzt und dann System 6 in C und C++ reimplementiert. Das BIOS des PCs und PC/MS-DOS war auch in Assembler programmiert. Wobei für die Anwendungen C relativ schnell populär war. Windows wurde später bereits mit C und C++ entwickelt.
Es gab natürlich eine Computer Welt vor UNIX Version 4. Z.B. der erste Computer mit einem Betriebssystem IBMs S/360 aus dem Jahre 1964, oder den ersten Hochsprachen Compiler überhaupt (DirkB wies schon darauf hin), Fortran aus dem Jahren 1954. Ergo, Assembler ist bedeutend älter als C.
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Wie könnte man denn am einfachsten die Brücke schlagen zwischen dem Verstehen von asm und dem Verständnis von Binaries?
Was verstehst du unter Binaries?
-
0b101010?
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Wie könnte man denn am einfachsten die Brücke schlagen zwischen dem Verstehen von asm und dem Verständnis von Binaries?
Indem man sich das entsprechende Format anguckt? Du kannst hier starten: https://en.wikipedia.org/wiki/Comparison_of_executable_file_formats
(so habe ich die Frage zumindest verstanden)
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
Wie könnte man denn am einfachsten die Brücke schlagen zwischen dem Verstehen von asm und dem Verständnis von Binaries?
Was gibt's denn da noch groß zu Verstehen? Die beiden haben doch nahezu eine 1:1-Beziehung bis auf die von DirkB erwähnten Ausnahmen. Die simples Merken von Zahlen oder triviales Berechnen dieser Zahlen (so a la "Addition") sind. Aber ansonsten ist das einfach nur eine Übersetzungstabelle von der menschenlesbaren Repräsentation der Maschinenbefehle (
movq %rsp, %rbp
) in eine entsprechende Zahlenfolge, die für einen Computerprozessor verständlich ist (dh 07 a3 12
...).
-
also du könntest dir natürlich "rechnerarchitekturen" von andrew s. tanenbaum durchlesen. da lernst du dann, was die binaries eigentlich machen.
-
@SeppJ sagte in Was tut dieser Assembly Code? (Anfängerfrage):
in eine entsprechende Zahlenfolge, die für einen Computerprozessor verständlich ist
Danke, ja das meinte ich...
-
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@SeppJ sagte in Was tut dieser Assembly Code? (Anfängerfrage):
in eine entsprechende Zahlenfolge, die für einen Computerprozessor verständlich ist
Danke, ja das meinte ich...
Ja, aber willst du da noch speziell was wissen?
-
@SeppJ sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@EinNutzer0 sagte in Was tut dieser Assembly Code? (Anfängerfrage):
@SeppJ sagte in Was tut dieser Assembly Code? (Anfängerfrage):
in eine entsprechende Zahlenfolge, die für einen Computerprozessor verständlich ist
Danke, ja das meinte ich...
Ja, aber willst du da noch speziell was wissen?
Bis jetzt, aktuell, keine konkreten Fragen... Aber was nicht ist das kann in ein paar Tagen noch kommen! Vielen Dank.