Я хотел проверить код для выполнения системных вызовов в 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
инструкции) является инструкцией? Во-вторых, если это инструкция, в чем смысл ENTRY (syscall)? Одно и то же имя для входа (я не знаю, что такое ENTRY) и инструкции? Во-вторых, что такое L (pseudo_end)?
Это так. Он делает то же самое, что и 'int 0x80' в x86. – Dave
Обратите внимание, что для каждого системного вызова обычно используется специализированный код, чтобы установить '% rax' из константы (сохранение регистра) и пропустить настройку неиспользуемых аргументов. – o11c