syscalls_amd64.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. //go:build linux && amd64
  2. package nodejs_syscall
  3. import "syscall"
  4. const (
  5. //334
  6. SYS_RSEQ = 334
  7. // 435
  8. SYS_CLONE3 = 435
  9. )
  10. var ALLOW_SYSCALLS = []int{
  11. syscall.SYS_OPEN, syscall.SYS_WRITE, syscall.SYS_CLOSE, syscall.SYS_READ,
  12. syscall.SYS_OPENAT, syscall.SYS_NEWFSTATAT, syscall.SYS_IOCTL, syscall.SYS_LSEEK,
  13. syscall.SYS_FSTAT,
  14. syscall.SYS_MPROTECT, syscall.SYS_MMAP, syscall.SYS_MUNMAP,
  15. syscall.SYS_MREMAP,
  16. syscall.SYS_BRK,
  17. syscall.SYS_RT_SIGACTION, syscall.SYS_RT_SIGPROCMASK,
  18. syscall.SYS_MADVISE, syscall.SYS_GETPID, syscall.SYS_GETUID,
  19. syscall.SYS_FCNTL, syscall.SYS_SIGALTSTACK, syscall.SYS_RT_SIGRETURN,
  20. syscall.SYS_FUTEX,
  21. syscall.SYS_EXIT_GROUP,
  22. syscall.SYS_EPOLL_CTL,
  23. syscall.SYS_EPOLL_PWAIT,
  24. syscall.SYS_SCHED_YIELD, syscall.SYS_EXIT,
  25. syscall.SYS_SCHED_GETAFFINITY, syscall.SYS_SET_ROBUST_LIST,
  26. SYS_RSEQ,
  27. syscall.SYS_SETUID, syscall.SYS_SETGID, syscall.SYS_GETTID,
  28. syscall.SYS_CLOCK_GETTIME, syscall.SYS_GETTIMEOFDAY, syscall.SYS_NANOSLEEP,
  29. syscall.SYS_TIME,
  30. syscall.SYS_TGKILL,
  31. syscall.SYS_READLINK,
  32. syscall.SYS_DUP3,
  33. }
  34. var ALLOW_ERROR_SYSCALLS = []int{
  35. syscall.SYS_CLONE, SYS_CLONE3,
  36. }
  37. var ALLOW_NETWORK_SYSCALLS = []int{
  38. syscall.SYS_SOCKET, syscall.SYS_CONNECT, syscall.SYS_BIND, syscall.SYS_LISTEN, syscall.SYS_ACCEPT, syscall.SYS_SENDTO, syscall.SYS_RECVFROM,
  39. syscall.SYS_GETSOCKNAME, syscall.SYS_RECVMSG, syscall.SYS_GETPEERNAME, syscall.SYS_SETSOCKOPT, syscall.SYS_PPOLL, syscall.SYS_UNAME,
  40. syscall.SYS_SENDMSG, syscall.SYS_GETSOCKOPT,
  41. syscall.SYS_FCNTL, syscall.SYS_FSTATFS,
  42. }