Я хотел проверить код для выполнения системных вызовов в glibc. Я нашел что-то подобное.
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
) инструкцией? Во-вторых, если это инструкция, что означает ВХОД (системный вызов)? Одно и то же имя для ЗАПИСИ (я не знаю, что такое ЗАПИСЬ) и инструкции? Во-вторых, что такое L (pseudo_end)?
int 0x80
в x86. - person Dave   schedule 14.05.2012%rax
из константы (сохранение регистра) и пропустить настройку неиспользуемых аргументов. - person o11c   schedule 31.08.2017