Go to the documentation of this file.
   32 #include <sys/syscall.h> 
   55             warn(
"Unknown operating system; assuming Linux.");
 
   79     process->Process::syscall(tc);
 
   90     strcpy(
name->sysname, 
"Linux");
 
   91     strcpy(
name->nodename,
"sim.gem5.org");
 
   92     strcpy(
name->release, process->release.c_str());
 
   93     strcpy(
name->version, 
"#1 Mon Aug 18 11:32:15 EDT 2003");
 
   94     strcpy(
name->machine, 
"mips");
 
  104                    unsigned bufPtr, 
unsigned nbytes)
 
  116         std::cerr << 
"sys_getsysinfo: unknown op " << 
op << std::endl;
 
  127                    VPtr<> bufPtr, 
unsigned nbytes)
 
  136             DPRINTFR(SyscallVerbose, 
"sys_setsysinfo(SSI_IEEE_FP_CONTROL): " 
  137                    " setting FPCR to 0x%x\n", 
letoh(*fpcr));
 
  141         std::cerr << 
"sys_setsysinfo: unknown op " << 
op << std::endl;
 
  160     { 4003, 
"read", readFunc<MipsLinux> },
 
  161     { 4004, 
"write", writeFunc<MipsLinux> },
 
  162     { 4005, 
"open", openFunc<MipsLinux> },
 
  172     { 4015, 
"chmod", chmodFunc<MipsLinux> },
 
  175     { 4018, 
"unused#18" },
 
  185     { 4028, 
"unused#28" },
 
  211     { 4054, 
"ioctl", ioctlFunc<MipsLinux> },
 
  216     { 4059, 
"unused#59" },
 
  224     { 4067, 
"sigaction" },
 
  225     { 4068, 
"sgetmask" },
 
  226     { 4069, 
"ssetmask" },
 
  227     { 4070, 
"setreuid" },
 
  228     { 4071, 
"setregid" },
 
  229     { 4072, 
"sigsuspend" },
 
  230     { 4073, 
"sigpending" },
 
  232     { 4075, 
"setrlimit" },
 
  233     { 4076, 
"getrlimit" },
 
  234     { 4077, 
"getrusage", getrusageFunc<MipsLinux> },
 
  235     { 4078, 
"gettimeofday" },
 
  236     { 4079, 
"settimeofday" },
 
  237     { 4080, 
"getgroups" },
 
  238     { 4081, 
"setgroups" },
 
  239     { 4082, 
"reserved#82" },
 
  241     { 4084, 
"unused#84" },
 
  247     { 4090, 
"mmap", mmapFunc<MipsLinux> },
 
  251     { 4094, 
"fchmod", fchmodFunc<MipsLinux> },
 
  253     { 4096, 
"getpriority" },
 
  254     { 4097, 
"setpriority" },
 
  259     { 4102, 
"socketcall" },
 
  261     { 4104, 
"setitimer" },
 
  262     { 4105, 
"getitimer" },
 
  263     { 4106, 
"stat",  statFunc<MipsLinux> },
 
  265     { 4108, 
"fstat", fstatFunc<MipsLinux> },
 
  266     { 4109, 
"unused#109" },
 
  273     { 4116, 
"sysinfo", sysinfoFunc<MipsLinux> },
 
  276     { 4119, 
"sigreturn" },
 
  278     { 4121, 
"setdomainname" },
 
  280     { 4123, 
"modify_ldt" },
 
  281     { 4124, 
"adjtimex" },
 
  283     { 4126, 
"sigprocmask" },
 
  284     { 4127, 
"create_module" },
 
  285     { 4128, 
"init_module" },
 
  286     { 4129, 
"delete_module" },
 
  287     { 4130, 
"get_kernel_syms" },
 
  288     { 4131, 
"quotactl" },
 
  293     { 4136, 
"personality" },
 
  294     { 4137, 
"afs_syscall" },
 
  295     { 4138, 
"setfsuid" },
 
  296     { 4139, 
"setfsgid" },
 
  298     { 4141, 
"getdents" },
 
  299     { 4142, 
"newselect" },
 
  303     { 4146, 
"writev", writevFunc<MipsLinux> },
 
  304     { 4147, 
"cacheflush" },
 
  305     { 4148, 
"cachectl" },
 
  307     { 4150, 
"unused#150" },
 
  309     { 4152, 
"fdatasync" },
 
  313     { 4156, 
"mlockall" },
 
  314     { 4157, 
"munlockall" },
 
  315     { 4158, 
"sched_setparam" },
 
  316     { 4159, 
"sched_getparam" },
 
  317     { 4160, 
"sched_setscheduler" },
 
  318     { 4161, 
"sched_getscheduler" },
 
  319     { 4162, 
"sched_yield" },
 
  320     { 4163, 
"sched_get_prioritymax" },
 
  321     { 4164, 
"sched_get_priority_min" },
 
  322     { 4165, 
"sched_rr_get_interval" },
 
  323     { 4166, 
"nanosleep" },
 
  324     { 4167, 
"mremap", mremapFunc<MipsLinux> },
 
  328     { 4171, 
"getpeername" },
 
  329     { 4172, 
"getsockname" },
 
  330     { 4173, 
"getsockopt" },
 
  337     { 4180, 
"setsockopt" },
 
  338     { 4181, 
"shutdown" },
 
  339     { 4182, 
"unknown #182" },
 
  341     { 4184, 
"socketpair" },
 
  342     { 4185, 
"setresuid" },
 
  343     { 4186, 
"getresuid" },
 
  344     { 4187, 
"query_module" },
 
  346     { 4189, 
"nfsservctl" },
 
  347     { 4190, 
"setresgid" },
 
  348     { 4191, 
"getresgid" },
 
  350     { 4193, 
"rt_sigreturn" },
 
  351     { 4194, 
"rt_sigaction" },
 
  352     { 4195, 
"rt_sigprocmask" },
 
  353     { 4196, 
"rt_sigpending" },
 
  354     { 4197, 
"rt_sigtimedwait" },
 
  356     { 4199, 
"rt_sigsuspend" },
 
  358     { 4201, 
"pwrite64" },
 
  363     { 4206, 
"sigalstack" },
 
  364     { 4207, 
"sendfile" },
 
  368     { 4211, 
"truncate64" },
 
  369     { 4212, 
"ftruncate64" },
 
  371     { 4214, 
"lstat64", lstat64Func<MipsLinux> },
 
  372     { 4215, 
"fstat64", fstat64Func<MipsLinux> },
 
  373     { 4216, 
"pivot_root" },
 
  376     { 4219, 
"getdents64" },
 
  378     { 4221, 
"reserved#221" },
 
  380     { 4223, 
"readahead" },
 
  381     { 4224, 
"setxattr" },
 
  382     { 4225, 
"lsetxattr" },
 
  383     { 4226, 
"fsetxattr" },
 
  384     { 4227, 
"getxattr" },
 
  385     { 4228, 
"lgetxattr" },
 
  386     { 4229, 
"fgetxattr" },
 
  387     { 4230, 
"listxattr" },
 
  388     { 4231, 
"llistxattr" },
 
  389     { 4232, 
"flistxattr" },
 
  390     { 4233, 
"removexattr" },
 
  391     { 4234, 
"lremovexattr" },
 
  394     { 4237, 
"sendfile64" },
 
  396     { 4239, 
"sched_setaffinity" },
 
  397     { 4240, 
"sched_getaffinity" },
 
  398     { 4241, 
"io_setup" },
 
  399     { 4242, 
"io_destroy" },
 
  400     { 4243, 
"io_getevents" },
 
  401     { 4244, 
"io_submit" },
 
  402     { 4245, 
"io_cancel" },
 
  404     { 4247, 
"lookup_dcookie" },
 
  405     { 4248, 
"epoll_create" },
 
  406     { 4249, 
"epoll_ctl" },
 
  407     { 4250, 
"epoll_wait" },
 
  408     { 4251, 
"remap_file_pages" },
 
  409     { 4252, 
"set_tid_address" },
 
  410     { 4253, 
"restart_syscall" },
 
  411     { 4254, 
"fadvise64" },
 
  412     { 4255, 
"statfs64" },
 
  413     { 4256, 
"fstafs64" },
 
  416     { 4259, 
"timer_gettime" },
 
  417     { 4260, 
"timer_getoverrun" },
 
  418     { 4261, 
"timer_delete" },
 
  419     { 4262, 
"clock_settime" },
 
  420     { 4263, 
"clock_gettime" },
 
  421     { 4264, 
"clock_getres" },
 
  422     { 4265, 
"clock_nanosleep" },
 
  426     { 4269, 
"get_mempolicy" },
 
  427     { 4270, 
"set_mempolicy" },
 
  429     { 4272, 
"mq_unlink" },
 
  430     { 4273, 
"mq_timedsend" },
 
  431     { 4274, 
"mq_timedreceive" },
 
  432     { 4275, 
"mq_notify" },
 
  433     { 4276, 
"mq_getsetattr" },
 
  436     { 4279, 
"unknown #279" },
 
  438     { 4281, 
"request_key" },
 
  441     { 4284, 
"inotify_init" },
 
  442     { 4285, 
"inotify_add_watch" },
 
  443     { 4286, 
"inotify_rm_watch" },
 
  444     { 4287, 
"migrate_pages" },
 
  448     { 4291, 
"fchownat" },
 
  449     { 4292, 
"futimesat" },
 
  450     { 4293, 
"fstatat64" },
 
  451     { 4294, 
"unlinkat" },
 
  452     { 4295, 
"renameat" },
 
  454     { 4297, 
"symlinkat" },
 
  455     { 4298, 
"readlinkat" },
 
  456     { 4299, 
"fchmodat" },
 
  457     { 4300, 
"faccessat" },
 
  458     { 4301, 
"pselect6" },
 
  462     { 4305, 
"sync_file_range" },
 
  464     { 4307, 
"vmsplice" },
 
  465     { 4308, 
"move_pages" },
 
  466     { 4309, 
"set_robust_list" },
 
  467     { 4310, 
"get_robust_list" },
 
  468     { 4311, 
"kexec_load" },
 
  470     { 4313, 
"epoll_pwait" },
 
  471     { 4314, 
"ioprio_set" },
 
  472     { 4315, 
"ioprio_get" },
 
  473     { 4316, 
"utimensat" },
 
  474     { 4317, 
"signalfd" },
 
  
SyscallReturn geteuidFunc(SyscallDesc *desc, ThreadContext *tc)
Target geteuid() handler.
Each instance of a Loader subclass will have a chance to try to load an object file when tryLoaders i...
SyscallReturn brkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> new_brk)
Target brk() handler: set brk address.
SyscallReturn ignoreFunc(SyscallDesc *desc, ThreadContext *tc)
Handler for unimplemented syscalls that we never intend to implement (signal handling,...
SyscallReturn chownFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, uint32_t owner, uint32_t group)
Target chown() handler.
static SyscallReturn sys_getsysinfoFunc(SyscallDesc *desc, ThreadContext *tc, unsigned op, unsigned bufPtr, unsigned nbytes)
Target sys_getsysyinfo() handler.
SyscallReturn getpagesizeFunc(SyscallDesc *desc, ThreadContext *tc)
Target getpagesize() handler.
SyscallReturn mkdirFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, mode_t mode)
Target mkdir() handler.
SyscallReturn gethostnameFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> buf_ptr, int name_len)
Target gethostname() handler.
SyscallReturn readlinkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr<> buf_ptr, size_t bufsiz)
Target readlink() handler.
static SyscallReturn sys_setsysinfoFunc(SyscallDesc *desc, ThreadContext *tc, unsigned op, VPtr<> bufPtr, unsigned nbytes)
Target sys_setsysinfo() handler.
SyscallReturn getegidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getegid() handler.
virtual Process * getProcessPtr()=0
SyscallReturn ftruncateFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, off_t length)
Target ftruncate() handler.
SyscallReturn umaskFunc(SyscallDesc *desc, ThreadContext *tc)
Target umask() handler.
SyscallReturn lseekFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, uint64_t offs, int whence)
Target lseek() handler.
SyscallReturn munmapFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> start, size_t length)
Target munmap() handler.
SyscallReturn exitFunc(SyscallDesc *desc, ThreadContext *tc, int status)
Target exit() handler: terminate current context.
SyscallReturn getpidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getpid() handler.
SyscallReturn fchownFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, uint32_t owner, uint32_t group)
Target fchown() handler.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
static SyscallDescTable< SyscallABI > syscallDescs
Syscall descriptors, indexed by call number.
This class represents the return value from an emulated system call, including any errno setting.
const std::string & name()
void doSyscall(ThreadContext *tc)
Interface for invoking the system call funcion pointer.
SyscallReturn truncateFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, off_t length)
Target truncate() handler.
static SyscallReturn setThreadAreaFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> addr)
SyscallReturn fcntlFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int cmd, GuestABI::VarArgs< int > varargs)
Target fcntl() handler.
SyscallReturn getuidFunc(SyscallDesc *desc, ThreadContext *tc)
static SyscallReturn unameFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< Linux::utsname > name)
Target uname() handler.
SyscallReturn unlinkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname)
Target unlink() handler.
SyscallReturn closeFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd)
Target close() handler.
virtual Process * load(const ProcessParams ¶ms, ::Loader::ObjectFile *obj_file)=0
Each subclass needs to implement this method.
SyscallReturn getcwdFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> buf_ptr, unsigned long size)
Target getcwd() handler.
SyscallReturn fcntl64Func(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int cmd)
Target fcntl64() handler.
virtual void setMiscRegNoEffect(RegIndex misc_reg, RegVal val)=0
SyscallDesc * get(int num, bool fatal_if_missing=true)
virtual RegVal readIntReg(RegIndex reg_idx) const =0
SyscallReturn getgidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getgid() handler.
SyscallReturn pipePseudoFunc(SyscallDesc *desc, ThreadContext *tc)
Pseudo Funcs - These functions use a different return convension, returning a second value in a regis...
void syscall(ThreadContext *tc) override
This class provides the wrapper interface for the system call implementations which are defined in th...
Generated on Tue Jun 22 2021 15:28:20 for gem5 by  doxygen 1.8.17