Vedo un sacco di persone che fanno riferimento online
arch/x86/entry/syscalls/syscall_64.tbl
per la tabella syscall, che funziona benissimo. Ma molti altri fanno riferimento
/include/uapi/asm-generic/unistd.h
che si trova comunemente nel pacchetto delle intestazioni. Come mai syscall_64.tbl
spettacoli,
0 common read sys_read
La risposta giusta e unistd.h
mostra
#define __NR_io_setup 0
__SC_COMP(__NR_io_setup, sys_io_setup, compat_sys_io_setup)
E poi mostra __NR_read
come
#define __NR_read 63
__SYSCALL(__NR_read, sys_read)
Perché è 63, e non 1? Come posso dare un senso al di fuori /include/uapi/asm-generic/unistd.h
? /usr/include/asm/
C'è ancora dentro
/usr/include/asm/unistd_x32.h
#define __NR_read (__X32_SYSCALL_BIT + 0)
#define __NR_write (__X32_SYSCALL_BIT + 1)
#define __NR_open (__X32_SYSCALL_BIT + 2)
#define __NR_close (__X32_SYSCALL_BIT + 3)
#define __NR_stat (__X32_SYSCALL_BIT + 4)
/usr/include/asm/unistd_64.h
#define __NR_read 0
#define __NR_write 1
#define __NR_open 2
#define __NR_close 3
#define __NR_stat 4
/usr/include/asm/unistd_32.h
#define __NR_restart_syscall 0
#define __NR_exit 1
#define __NR_fork 2
#define __NR_read 3
#define __NR_write 4
Qualcuno potrebbe dirmi la differenza tra questi unistd
file. Spiegare come unistd.h
funziona? E qual è il metodo migliore per trovare la tabella syscall?