glibcでシステムコールを実行するコードをチェックしたかったのです。私はこのようなものを見つけた。syscallはx86_64の命令ですか?
ENTRY (syscall)
movq %rdi, %rax /* Syscall number -> rax. */
movq %rsi, %rdi /* shift arg1 - arg5. */
movq %rdx, %rsi
movq %rcx, %rdx
movq %r8, %r10
movq %r9, %r8
movq 8(%rsp),%r9 /* arg6 is on the stack. */
syscall /* Do the system call. */
cmpq $-4095, %rax /* Check %rax for error. */
jae SYSCALL_ERROR_LABEL /* Jump to error handler if error. */
L(pseudo_end):
ret /* Return to caller. */
私の質問は、(cmpq
命令の前の)syscallが命令の場合ですか?第二に、それが命令の場合、ENTRY(システムコール)の意味は何ですか? ENTRY(ENTRYが何であるかわからない)とインストラクションの同じ名前ですか?第二に、L(pseudo_end)とは何ですか?
です。それはx86の 'int 0x80'と同じです。 – Dave
通常、システムコールごとに特殊なコードが使用され、定数から '%rax'を設定し(レジスタを保存する)、未使用の引数の設定をスキップすることに注意してください。 – o11c