PROC
label という名前のプロシージャ ブロックの開始と終了を示します。ブロック内のステートメントは、CALL 命令または INVOKE ディレクティブで呼び出すことができます。
label PROC [[distance]] [[langtype]] [[visibility]] [[<prologuearg>]]
[[USES reglist]] [[, parameter [[:tag]]]]...
[FRAME [:ehandler-address] ]
statements
label ENDP
解説
[FRAME [:ehandler-address] ] は、ml64.exe でのみ有効で、これにより MASM は、関数の構造化例外処理アンワインド動作として、.pdata に関数テーブル エントリを、.xdata にアンワインド情報を生成します。
FRAME 属性を使用する場合、.ENDPROLOG ディレクティブの前に置く必要があります。
ml64.exe の使い方の詳細については、「x64 用 MASM (ml64.exe)」を参照してください。
使用例
; ml64 ex1.asm /link /entry:Example1 /SUBSYSTEM:CONSOLE
_text SEGMENT
Example1 PROC FRAME
push r10
.pushreg r10
push r15
.pushreg r15
push rbx
.pushreg rbx
push rsi
.pushreg rsi
.endprolog
; rest of function ...
ret
Example1 ENDP
_text ENDS
END
上記のコードにより、以下の関数テーブルとアンワインド情報が生成されます。
FileHeader->Machine 34404
Dumping Unwind Information for file ex2.exe
.pdata entry 1 0x00001000 0x00001023
Unwind data: 0x00002000
Unwind version: 1
Unwind Flags: None
Size of prologue: 0x08
Count of codes: 3
Frame register: rbp
Frame offset: 0x0
Unwind codes:
Code offset: 0x08, SET_FPREG, register=rbp, offset=0x00
Code offset: 0x05, ALLOC_SMALL, size=0x10
Code offset: 0x01, PUSH_NONVOL, register=rbp