Unformatierte Pseudooperationen
Aktualisiert: November 2007
In diesem Thema werden die Pseudooperationen aufgelistet.
Hinweise
Pseudooperation |
Beschreibung |
---|---|
PROC FRAME [:ehandler] |
Veranlasst MASM, einen Funktionstabelleneintrag in .pdata und Entladeinformationen in .xdata für das Entladeverhalten bei der strukturierten Ausnahmebehandlung zu erzeugen. Wenn ehandler vorhanden ist, wird dieser proc als sprachspezifischer Handler in .xdata eingetragen. Wenn das FRAME-Attribut verwendet wird, muss ihm eine .ENDPROLOG-Direktive folgen. Wenn die Funktion eine Endfunktion (wie in Funktionstypen definiert) ist, werden das FRAME-Attribut und die übrigen Pseudooperationen nicht benötigt. |
.PUSHREG reg |
Erzeugt einen UWOP_PUSH_NONVOL-Entladecodeeintrag für die angegebene Registernummer mit dem aktuellen Offset im Prolog. Dies sollte nur bei nicht flüchtigen Ganzzahlregistern verwendet werden. Verwenden Sie für push-Anweisungen flüchtiger Register stattdessen einen .ALLOCSTACK 8. |
.SETFRAME reg, Offset |
Füllt das Frameregisterfeld und den Offset in den Entladeinformationen mit den angegebenen Registern und Offsets. Der Offset muss ein Vielfaches von 16 und kleiner oder gleich 240 sein. Diese Direktive generiert auch einen UWOP_SET_FPREG-Entladecodeeintrag für das angegebene Register mit dem aktuellen Prologoffset. |
.ALLOCSTACK Größe |
Erzeugt einen UWOP_ALLOC_SMALL oder einen UWOP_ALLOC_LARGE mit der angegebenen Größe für den aktuellen Offset im Prolog. Der Größenoperand muss ein Vielfaches von 8 sein. |
.SAVEREG reg, Offset |
Erzeugt entweder einen UWOP_SAVE_NONVOL- oder einen UWOP_SAVE_NONVOL_FAR-Entladecodeeintrag für das angegebene Register und den angegebenen Offset mit dem aktuellen Prologoffset. Von MASM wird die effizienteste Codierung ausgewählt. Der Offset muss positiv und ein Vielfaches von 8 sein. Der Offset bezieht sich auf die Basis des Prozedurrahmens, der sich im Allgemeinen in RSP oder bei Verwendung eines Framezeigers im unskalierten Framezeiger befindet. |
.SAVEXMM128 reg, Offset |
Erzeugt entweder einen UWOP_SAVE_XMM128- oder einen UWOP_SAVE_XMM128_FAR-Entladecodeeintrag für das angegebene XXM-Register und den angegebenen Offset mit dem aktuellen Prologoffset. Von MASM wird die effizienteste Codierung ausgewählt. Der Offset muss positiv und ein Vielfaches von 16 sein. Der Offset bezieht sich auf die Basis des Prozedurrahmens, der sich im Allgemeinen in RSP oder bei Verwendung eines Framezeigers im unskalierten Framezeiger befindet. |
.PUSHFRAME [Code] |
Erzeugt einen UWOP_PUSH_MACHFRAME-Entladecodeeintrag. Wenn der optionale Code angegeben wird, erhält der Entladecodeeintrag den Modifizierer 1. Andernfalls ist der Modifizierer 0. |
.ENDPROLOG |
Signalisiert das Ende der Prologdeklarationen. Muss in den ersten 255 Byte der Funktion auftreten. |
Im Folgenden finden Sie ein Beispielfunktionsprolog mit richtiger Verwendung der meisten Opcodes:
sample PROC FRAME
db 048h; emit a REX prefix, to enable hot-patching
push rbp
.pushreg rbp
sub rsp, 040h
.allocstack 040h
lea rbp, [rsp+020h]
.setframe rbp, 020h
movdqa [rbp], xmm7
.savexmm128 xmm7, 020h;the offset is from the base of the frame
;not the scaled offset of the frame
mov [rbp+018h], rsi
.savereg rsi, 038h
mov [rsp+010h], rdi
.savereg rdi, 010h; you can still use RSP as the base of the frame
; or any other register you choose
.endprolog
; you can modify the stack pointer outside of the prologue (similar to alloca)
; because we have a frame pointer.
; if we didn’t have a frame pointer, this would be illegal
; if we didn’t make this modification,
; there would be no need for a frame pointer
sub rsp, 060h
; we can unwind from the following AV because of the frame pointer
mov rax, 0
mov rax, [rax] ; AV!
; restore the registers that weren’t saved with a push
; this isn’t part of the official epilog, as described in section 2.5
movdqa xmm7, [rbp]
mov rsi, [rbp+018h]
mov rdi, [rbp-010h]
; Here’s the official epilog
lea rsp, [rbp-020h]
pop rbp
ret
sample ENDP