| Autor |
Nachricht |
Thuruk
Mitglied
Benutzerprofil
Anmeldungsdatum: 26.01.2012
Beiträge: 132
|
Thuruk Mitglied
00:05:16 24.02.2012 Titel: |
NOP nach JMP |
Zitieren |
Was genau bewirkt die no operation-Anweisung nach einem Sprung?
| Assembler: | jmp codestart
nop | |
Konnte mit Google keine Erklärung finden. |
|
|
|
 |
EOP
Mitglied
Benutzerprofil
Anmeldungsdatum: 15.09.2007
Beiträge: 809
|
EOP Mitglied
00:39:26 24.02.2012 Titel: |
|
Zitieren |
Das was sie immer bewirkt: gar nix.
0x90 bedeutet: nix passiert hier.
Wird oft beim cracken von Programmen benutzt um Teile des codes zu löschen.
http://en.wikipedia.org/wiki/NOP |
Zuletzt bearbeitet von EOP am 00:47:01 24.02.2012, insgesamt 2-mal bearbeitet |
|
 |
nachtfeuer
Moderator
Benutzerprofil
Anmeldungsdatum: 08.04.2010
Beiträge: 1432
|
nachtfeuer Moderator
00:41:30 24.02.2012 Titel: |
|
Zitieren |
Komische Frage, gar nix, denn du springst ja immer wieder zurück an die alte Adresse.
Ein paar 90909090909090 hintereinander geben aber gewisse Sicherheit, falls man mal irgendwie in diesen Bereich hineinspringen will, falls man die Adresse nicht haargenau kennt.
Assembler benutzen nops auch für Alignements oder Platzhalter für spätere Befehle und solche Sachen.
http://en.wikipedia.org/wiki/NOP |
_________________ HhxV9rU5D8o236dZF7bMQ4Dys1_TuUmI4mZM.d2qD15ERi_0dgcHP0UViL3e-4WUi0nXXNwDYqA10sLEgjBVtdhE
tpehI7qHRZESiO_7LhPZFMQWNoiVrJDsEGD26n.H0lV8wOwYAe8UsbUJe5m65NyPaghnSoMzROo2gJ6nTeVSkxLk
a6hvNe11r9U7xddV9mq6NEi_V0C9k4augEKVSW3PV8LgCYum7KaXc9Ijq_ZT7zhspI.=-
|
|
 |
EOP
Mitglied
Benutzerprofil
Anmeldungsdatum: 15.09.2007
Beiträge: 809
|
EOP Mitglied
00:49:38 24.02.2012 Titel: |
|
Zitieren |
| nachtfeuer schrieb: | | Ein paar 90909090909090 hintereinander geben aber gewisse Sicherheit, falls man mal irgendwie in diesen Bereich hineinspringen will, falls man die Adresse nicht haargenau kennt. | nop sleds
Würde hier aber zu weit führen. |
|
|
|
 |
Thuruk
Mitglied
Benutzerprofil
Anmeldungsdatum: 26.01.2012
Beiträge: 132
|
Thuruk Mitglied
00:50:56 24.02.2012 Titel: |
|
Zitieren |
|
 |
Patrickssj6
Mitglied
Benutzerprofil
Anmeldungsdatum: 08.01.2012
Beiträge: 100
|
Patrickssj6 Mitglied
00:58:14 24.02.2012 Titel: |
|
Zitieren |
Passiert manchmal wenn man beim cracken nen long zum short macht...oder die Person wollte sich einfach die Möglichkeit offen halten selber irgendwann mal nen short zum long jump zu machen |
|
|
|
 |
EOP
Mitglied
Benutzerprofil
Anmeldungsdatum: 15.09.2007
Beiträge: 809
|
EOP Mitglied
01:00:44 24.02.2012 Titel: |
|
Zitieren |
| Thuruk schrieb: | http://snipplr.com/view/7518/bootloader-fat12/
http://board.flatassembler.net/topic.php?t=11774
Kommt aus irgendeinem Grund bei etlichen Bootloadern vor. Ich würde einfach jmp short schreiben, was 2 Bytes lang wäre. jmp + nop wird von nasm zu jmp short + nop übersetzt, was 3 Bytes lang ist. | Wird wohl was mit alignment zu tun haben. |
|
|
|
 |
Thuruk
Mitglied
Benutzerprofil
Anmeldungsdatum: 26.01.2012
Beiträge: 132
|
Thuruk Mitglied
01:06:23 24.02.2012 Titel: |
|
Zitieren |
Bei FAT passen zwar nur 3 Bytes vor den Parameterblock, aber ich finde es seltsam da nop zu schreiben statt den Platz für eine Variable zu nutzen.
Dann nehme ich mal an, dass Zufall oder Abschreiben zur Häufigkeit geführt haben, und verwende es nicht. |
|
|
|
 |
nachtfeuer
Moderator
Benutzerprofil
Anmeldungsdatum: 08.04.2010
Beiträge: 1432
|
nachtfeuer Moderator
08:17:31 24.02.2012 Titel: |
|
Zitieren |
http://de.uncyclopedia.org/wiki/NOP |
_________________ HhxV9rU5D8o236dZF7bMQ4Dys1_TuUmI4mZM.d2qD15ERi_0dgcHP0UViL3e-4WUi0nXXNwDYqA10sLEgjBVtdhE
tpehI7qHRZESiO_7LhPZFMQWNoiVrJDsEGD26n.H0lV8wOwYAe8UsbUJe5m65NyPaghnSoMzROo2gJ6nTeVSkxLk
a6hvNe11r9U7xddV9mq6NEi_V0C9k4augEKVSW3PV8LgCYum7KaXc9Ijq_ZT7zhspI.=-
|
|
 |
__username
Mitglied
Benutzerprofil
Anmeldungsdatum: 10.02.2012
Beiträge: 79
|
__username Mitglied
14:35:48 24.02.2012 Titel: |
|
Zitieren |
Beim Bootloader kommt es meines Wissens nach vor, um seine größe auf 512kb aufzurunden. Und nop wird einfach verwendet, weil es absolut nichts bewirkt (streng genommen ist es ja "xchg eax, eax").
Vielleicht wird es in dem Beispiel
| Assembler: | jmp codestart
nop | |
auch als Platzhalter genutzt?
EDIT:
Wobei mir einfällt, dass es auch genutzt wird nach "Wait-Loops" um größere Verzögerungen durch Speicherfehler zu vermeiden; hab ich jedenfalls mal so gelesen. |
Zuletzt bearbeitet von __username am 14:37:36 24.02.2012, insgesamt 1-mal bearbeitet |
|
 |