syscalls_arm64.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. //go:build linux && arm64
  2. package nodejs_syscall
  3. import "syscall"
  4. var ALLOW_SYSCALLS = []int{
  5. // file
  6. syscall.SYS_CLOSE, syscall.SYS_WRITE, syscall.SYS_READ,
  7. syscall.SYS_FSTAT, syscall.SYS_FCNTL,
  8. syscall.SYS_READLINKAT, syscall.SYS_OPENAT,
  9. // process
  10. syscall.SYS_GETPID, syscall.SYS_TGKILL, syscall.SYS_FUTEX, syscall.SYS_IOCTL,
  11. syscall.SYS_EXIT, syscall.SYS_EXIT_GROUP,
  12. syscall.SYS_SET_ROBUST_LIST, syscall.SYS_NANOSLEEP, syscall.SYS_SCHED_GETAFFINITY,
  13. syscall.SYS_SCHED_YIELD,
  14. // memory
  15. syscall.SYS_RT_SIGPROCMASK, syscall.SYS_SIGALTSTACK, syscall.SYS_RT_SIGACTION,
  16. syscall.SYS_MMAP, syscall.SYS_MUNMAP, syscall.SYS_MADVISE, syscall.SYS_MPROTECT,
  17. syscall.SYS_RT_SIGRETURN, syscall.SYS_BRK,
  18. //user/group
  19. syscall.SYS_SETUID, syscall.SYS_SETGID, syscall.SYS_GETTID,
  20. syscall.SYS_GETUID, syscall.SYS_GETGID,
  21. // epoll
  22. syscall.SYS_EPOLL_CTL, syscall.SYS_EPOLL_PWAIT,
  23. }
  24. var ALLOW_ERROR_SYSCALLS = []int{
  25. syscall.SYS_CLONE, 293,
  26. }
  27. var ALLOW_NETWORK_SYSCALLS = []int{
  28. syscall.SYS_SOCKET, syscall.SYS_CONNECT, syscall.SYS_BIND, syscall.SYS_LISTEN, syscall.SYS_ACCEPT,
  29. syscall.SYS_SENDTO, syscall.SYS_RECVFROM,
  30. syscall.SYS_GETSOCKNAME, syscall.SYS_SETSOCKOPT, syscall.SYS_GETSOCKOPT,
  31. syscall.SYS_SENDMMSG, syscall.SYS_RECVMSG,
  32. syscall.SYS_GETPEERNAME, syscall.SYS_PPOLL, syscall.SYS_UNAME,
  33. syscall.SYS_FSTATAT, syscall.SYS_LSEEK,
  34. syscall.SYS_FSTATFS,
  35. }