gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
syscall_tbl64.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 Arm Limited
3 *
4 * The license below extends only to copyright in the software and shall
5 * not be construed as granting a license to any other intellectual
6 * property including but not limited to intellectual property relating
7 * to a hardware implementation of the functionality of the software
8 * licensed hereunder. You may use the software subject to the license
9 * terms below provided that you ensure that this notice is replicated
10 * unmodified and in its entirety in all distributions of the software,
11 * modified or unmodified, in source code or in binary form.
12 *
13 * Copyright 2020 Google Inc.
14 *
15 * Redistribution and use in source and binary forms, with or without
16 * modification, are permitted provided that the following conditions are
17 * met: redistributions of source code must retain the above copyright
18 * notice, this list of conditions and the following disclaimer;
19 * redistributions in binary form must reproduce the above copyright
20 * notice, this list of conditions and the following disclaimer in the
21 * documentation and/or other materials provided with the distribution;
22 * neither the name of the copyright holders nor the names of its
23 * contributors may be used to endorse or promote products derived from
24 * this software without specific prior written permission.
25 *
26 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37 */
38
39#include <sys/syscall.h>
40
44#include "sim/syscall_emul.hh"
45
46namespace gem5
47{
48
49namespace X86ISA
50{
51
52SyscallDescTable<EmuLinux::SyscallABI64> EmuLinux::syscallDescs64 = {
53 { 0, "read", readFunc<X86Linux64> },
54 { 1, "write", writeFunc<X86Linux64> },
55 { 2, "open", openFunc<X86Linux64> },
56 { 3, "close", closeFunc },
57 { 4, "stat", stat64Func<X86Linux64> },
58 { 5, "fstat", fstat64Func<X86Linux64> },
59 { 6, "lstat", lstat64Func<X86Linux64> },
60 { 7, "poll", pollFunc<X86Linux64> },
61 { 8, "lseek", lseekFunc<X86Linux64> },
62 { 9, "mmap", mmapFunc<X86Linux64> },
63 { 10, "mprotect", ignoreFunc },
64 { 11, "munmap", munmapFunc<X86Linux64> },
65 { 12, "brk", brkFunc },
66 { 13, "rt_sigaction", ignoreWarnOnceFunc },
67 { 14, "rt_sigprocmask", ignoreWarnOnceFunc },
68 { 15, "rt_sigreturn" },
69 { 16, "ioctl", ioctlFunc<X86Linux64> },
70 { 17, "pread64", pread64Func<X86Linux64> },
71 { 18, "pwrite64", pwrite64Func<X86Linux64> },
72 { 19, "readv", readvFunc<X86Linux64> },
73 { 20, "writev", writevFunc<X86Linux64> },
74 { 21, "access", accessFunc },
75 { 22, "pipe", pipeFunc },
76 { 23, "select", selectFunc<X86Linux64> },
77 { 24, "sched_yield", ignoreWarnOnceFunc },
78 { 25, "mremap", mremapFunc<X86Linux64> },
79 { 26, "msync" },
80 { 27, "mincore" },
81 { 28, "madvise", ignoreFunc },
82 { 29, "shmget" },
83 { 30, "shmat" },
84 { 31, "shmctl" },
85 { 32, "dup", dupFunc },
86 { 33, "dup2", dup2Func },
87 { 34, "pause" },
88 { 35, "nanosleep", ignoreWarnOnceFunc },
89 { 36, "getitimer" },
90 { 37, "alarm" },
91 { 38, "setitimer" },
92 { 39, "getpid", getpidFunc },
93 { 40, "sendfile" },
94 { 41, "socket", socketFunc<X86Linux64> },
95 { 42, "connect", connectFunc },
96 { 43, "accept", acceptFunc<X86Linux64> },
97 { 44, "sendto", sendtoFunc<X86Linux64> },
98 { 45, "recvfrom", recvfromFunc<X86Linux64> },
99 { 46, "sendmsg", sendmsgFunc },
100 { 47, "recvmsg", recvmsgFunc },
101 { 48, "shutdown", shutdownFunc },
102 { 49, "bind", bindFunc },
103 { 50, "listen", listenFunc },
104 { 51, "getsockname", getsocknameFunc },
105 { 52, "getpeername", getpeernameFunc },
106 { 53, "socketpair", socketpairFunc<X86Linux64> },
107 { 54, "setsockopt", setsockoptFunc },
108 { 55, "getsockopt", getsockoptFunc },
109 { 56, "clone", cloneFunc<X86Linux64> },
110 { 57, "fork" },
111 { 58, "vfork" },
112 { 59, "execve", execveFunc<X86Linux64> },
113 { 60, "exit", exitFunc },
114 { 61, "wait4", wait4Func<X86Linux64> },
115 { 62, "kill" },
116 { 63, "uname", unameFunc },
117 { 64, "semget" },
118 { 65, "semop" },
119 { 66, "semctl" },
120 { 67, "shmdt" },
121 { 68, "msgget" },
122 { 69, "msgsnd" },
123 { 70, "msgrcv" },
124 { 71, "msgctl" },
125 { 72, "fcntl", fcntlFunc },
126 { 73, "flock" },
127 { 74, "fsync" },
128 { 75, "fdatasync", ignoreFunc },
129 { 76, "truncate", truncateFunc<X86Linux64> },
130 { 77, "ftruncate", ftruncateFunc<X86Linux64> },
131#if defined(SYS_getdents)
132 { 78, "getdents", getdentsFunc },
133#else
134 { 78, "getdents" },
135#endif
136 { 79, "getcwd", getcwdFunc<X86Linux64> },
137 { 80, "chdir", chdirFunc },
138 { 81, "fchdir" },
139 { 82, "rename", renameFunc },
140 { 83, "mkdir", mkdirFunc },
141 { 84, "rmdir", rmdirFunc },
142 { 85, "creat" },
143 { 86, "link", linkFunc },
144 { 87, "unlink", unlinkFunc },
145 { 88, "symlink", symlinkFunc },
146 { 89, "readlink", readlinkFunc<X86Linux64> },
147 { 90, "chmod", chmodFunc<X86Linux64> },
148 { 91, "fchmod", fchmodFunc<X86Linux64> },
149 { 92, "chown", chownFunc },
150 { 93, "fchown", fchownFunc },
151 { 94, "lchown" },
152 { 95, "umask", umaskFunc },
153 { 96, "gettimeofday", gettimeofdayFunc<X86Linux64> },
154 { 97, "getrlimit", getrlimitFunc<X86Linux64> },
155 { 98, "getrusage", getrusageFunc<X86Linux64> },
156 { 99, "sysinfo", sysinfoFunc<X86Linux64> },
157 { 100, "times", timesFunc<X86Linux64> },
158 { 101, "ptrace" },
159 { 102, "getuid", getuidFunc },
160 { 103, "syslog" },
161 { 104, "getgid", getgidFunc },
162 { 105, "setuid" },
163 { 106, "setgid" },
164 { 107, "geteuid", geteuidFunc },
165 { 108, "getegid", getegidFunc },
166 { 109, "setpgid", setpgidFunc },
167 { 110, "getppid", getppidFunc },
168 { 111, "getpgrp", getpgrpFunc },
169 { 112, "setsid" },
170 { 113, "setreuid" },
171 { 114, "setregid" },
172 { 115, "getgroups" },
173 { 116, "setgroups" },
174 { 117, "setresuid", ignoreFunc },
175 { 118, "getresuid" },
176 { 119, "setresgid" },
177 { 120, "getresgid" },
178 { 121, "getpgid" },
179 { 122, "setfsuid" },
180 { 123, "setfsgid" },
181 { 124, "getsid" },
182 { 125, "capget" },
183 { 126, "capset" },
184 { 127, "rt_sigpending" },
185 { 128, "rt_sigtimedwait" },
186 { 129, "rt_sigqueueinfo" },
187 { 130, "rt_sigsuspend" },
188 { 131, "sigaltstack", ignoreFunc },
189 { 132, "utime" },
190 { 133, "mknod", mknodFunc },
191 { 134, "uselib" },
192 { 135, "personality" },
193 { 136, "ustat" },
194 { 137, "statfs", statfsFunc<X86Linux64> },
195 { 138, "fstatfs", fstatfsFunc<X86Linux64> },
196 { 139, "sysfs" },
197 { 140, "getpriority" },
198 { 141, "setpriority", ignoreFunc },
199 { 142, "sched_setparam" },
200 { 143, "sched_getparam", sched_getparamFunc },
201 { 144, "sched_setscheduler" },
202 { 145, "sched_getscheduler", ignoreFunc },
203 { 146, "sched_get_priority_max", ignoreFunc },
204 { 147, "sched_get_priority_min", ignoreFunc },
205 { 148, "sched_rr_get_interval" },
206 { 149, "mlock" },
207 { 150, "munlock" },
208 { 151, "mlockall", ignoreFunc },
209 { 152, "munlockall" },
210 { 153, "vhangup" },
211 { 154, "modify_ldt", ignoreFunc },
212 { 155, "pivot_root" },
213 { 156, "_sysctl" },
214 { 157, "prctl", ignoreFunc },
215 { 158, "arch_prctl", archPrctlFunc },
216 { 159, "adjtimex" },
217 { 160, "setrlimit", ignoreFunc },
218 { 161, "chroot" },
219 { 162, "sync" },
220 { 163, "acct" },
221 { 164, "settimeofday" },
222 { 165, "mount" },
223 { 166, "umount2" },
224 { 167, "swapon" },
225 { 168, "swapoff" },
226 { 169, "reboot" },
227 { 170, "sethostname" },
228 { 171, "setdomainname" },
229 { 172, "iopl" },
230 { 173, "ioperm" },
231 { 174, "create_module" },
232 { 175, "init_module" },
233 { 176, "delete_module" },
234 { 177, "get_kernel_syms" },
235 { 178, "query_module" },
236 { 179, "quotactl" },
237 { 180, "nfsservctl" },
238 { 181, "getpmsg" },
239 { 182, "putpmsg" },
240 { 183, "afs_syscall" },
241 { 184, "tuxcall" },
242 { 185, "security" },
243 { 186, "gettid", gettidFunc },
244 { 187, "readahead" },
245 { 188, "setxattr" },
246 { 189, "lsetxattr" },
247 { 190, "fsetxattr" },
248 { 191, "getxattr" },
249 { 192, "lgetxattr" },
250 { 193, "fgetxattr" },
251 { 194, "listxattr" },
252 { 195, "llistxattr" },
253 { 196, "flistxattr" },
254 { 197, "removexattr" },
255 { 198, "lremovexattr" },
256 { 199, "fremovexattr" },
257 { 200, "tkill" },
258 { 201, "time", timeFunc<X86Linux64> },
259 { 202, "futex", futexFunc<X86Linux64> },
260 { 203, "sched_setaffinity", ignoreFunc },
261 { 204, "sched_getaffinity", schedGetaffinityFunc<X86Linux64> },
262 { 205, "set_thread_area" },
263 { 206, "io_setup" },
264 { 207, "io_destroy" },
265 { 208, "io_getevents" },
266 { 209, "io_submit" },
267 { 210, "io_cancel" },
268 { 211, "get_thread_area" },
269 { 212, "lookup_dcookie" },
270 { 213, "epoll_create" },
271 { 214, "epoll_ctl_old" },
272 { 215, "epoll_wait_old" },
273 { 216, "remap_file_pages" },
274#if defined(SYS_getdents64)
275 { 217, "getdents64", getdents64Func },
276#else
277 { 217, "getdents64" },
278#endif
279 { 218, "set_tid_address", setTidAddressFunc },
280 { 219, "restart_syscall" },
281 { 220, "semtimedop" },
282 { 221, "fadvise64", ignoreFunc },
283 { 222, "timer_create" },
284 { 223, "timer_settime" },
285 { 224, "timer_gettime" },
286 { 225, "timer_getoverrun" },
287 { 226, "timer_delete" },
288 { 227, "clock_settime" },
289 { 228, "clock_gettime", clock_gettimeFunc<X86Linux64> },
290 { 229, "clock_getres", clock_getresFunc<X86Linux64> },
291 { 230, "clock_nanosleep" },
292 { 231, "exit_group", exitGroupFunc },
293 { 232, "epoll_wait" },
294 { 233, "epoll_ctl" },
295 { 234, "tgkill", tgkillFunc<X86Linux64> },
296 { 235, "utimes", utimesFunc<X86Linux64> },
297 { 236, "vserver" },
298 { 237, "mbind", ignoreFunc },
299 { 238, "set_mempolicy" },
300 { 239, "get_mempolicy", ignoreFunc },
301 { 240, "mq_open" },
302 { 241, "mq_unlink" },
303 { 242, "mq_timedsend" },
304 { 243, "mq_timedreceive" },
305 { 244, "mq_notify" },
306 { 245, "mq_getsetattr" },
307 { 246, "kexec_load" },
308 { 247, "waitid" },
309 { 248, "add_key" },
310 { 249, "request_key" },
311 { 250, "keyctl" },
312 { 251, "ioprio_set" },
313 { 252, "ioprio_get" },
314 { 253, "inotify_init" },
315 { 254, "inotify_add_watch" },
316 { 255, "inotify_rm_watch" },
317 { 256, "migrate_pages" },
318 { 257, "openat", openatFunc<X86Linux64> },
319 { 258, "mkdirat", mkdiratFunc<X86Linux64> },
320 { 259, "mknodat", mknodatFunc<X86Linux64> },
321 { 260, "fchownat", fchownatFunc<X86Linux64> },
322 { 261, "futimesat", futimesatFunc<X86Linux64> },
323 { 262, "newfstatat", newfstatatFunc<X86Linux64> },
324 { 263, "unlinkat", unlinkatFunc<X86Linux64> },
325 { 264, "renameat", renameatFunc<X86Linux64> },
326 { 265, "linkat" },
327 { 266, "symlinkat" },
328 { 267, "readlinkat", readlinkatFunc<X86Linux64> },
329 { 268, "fchmodat", fchmodatFunc<X86Linux64> },
330 { 269, "faccessat", faccessatFunc<X86Linux64> },
331 { 270, "pselect6" },
332 { 271, "ppoll" },
333 { 272, "unshare" },
334 { 273, "set_robust_list", ignoreFunc },
335 { 274, "get_robust_list" },
336 { 275, "splice" },
337 { 276, "tee" },
338 { 277, "sync_file_range" },
339 { 278, "vmsplice" },
340 { 279, "move_pages" },
341 { 280, "utimensat" },
342 { 281, "epoll_pwait" },
343 { 282, "signalfd" },
344 { 283, "timerfd_create" },
345 { 284, "eventfd", eventfdFunc<X86Linux64> },
346 { 285, "fallocate", fallocateFunc<X86Linux64> },
347 { 286, "timerfd_settime" },
348 { 287, "timerfd_gettime" },
349 { 288, "accept4" },
350 { 289, "signalfd4" },
351 { 290, "eventfd2", eventfdFunc<X86Linux64> },
352 { 291, "epoll_create1" },
353 { 292, "dup3" },
354 { 293, "pipe2", pipe2Func },
355 { 294, "inotify_init1" },
356 { 295, "preadv" },
357 { 296, "pwritev" },
358 { 297, "rt_tgsigqueueinfo" },
359 { 298, "perf_event_open" },
360 { 299, "recvmmsg" },
361 { 300, "fanotify_init" },
362 { 301, "fanotify_mark" },
363 { 302, "prlimit64", prlimitFunc<X86Linux64> },
364 { 303, "name_to_handle_at" },
365 { 304, "open_by_handle_at" },
366 { 305, "clock_adjtime" },
367 { 306, "syncfs" },
368 { 307, "sendmmsg" },
369 { 308, "setns" },
370 { 309, "getcpu", getcpuFunc },
371 { 310, "proess_vm_readv" },
372 { 311, "proess_vm_writev" },
373 { 312, "kcmp" },
374 { 313, "finit_module" },
375 { 318, "getrandom", getrandomFunc<X86Linux64> },
376 { 319, "memfd_create" },
377 { 320, "kexec_file_load" },
378 { 321, "bpf" },
379 { 322, "execveat" },
380 { 323, "userfaultfd" },
381 { 324, "membarrier" },
382 { 325, "mlock2" },
383 { 326, "copy_file_range" },
384 { 327, "preadv2" },
385 { 328, "pwritev2" },
386 { 329, "pkey_mprotect" },
387 { 330, "pkey_alloc" },
388 { 331, "pkey_free" },
389 { 332, "statx", statxFunc<X86Linux64> },
390 { 333, "io_pgetevents" },
391 { 334, "rseq", ignoreFunc },
392 { 424, "pidfd_send_signal" },
393 { 425, "io_uring_setup" },
394 { 426, "io_uring_enter" },
395 { 427, "io_uring_register" },
396 { 428, "open_tree" },
397 { 429, "move_mount" },
398 { 430, "fsopen" },
399 { 431, "fsconfig" },
400 { 432, "fsmount" },
401 { 433, "fspick" },
402 { 434, "pidfd_open" },
403 { 435, "clone3", clone3Func<X86Linux64> },
404 { 436, "close_range" },
405 { 437, "openat2" },
406 { 438, "pidfd_getfd" },
407 { 439, "faccessat2" },
408 { 440, "process_madvise" },
409 { 441, "epoll_pwait2" },
410 { 442, "mount_setattr" },
411 { 443, "quotactl_fd" },
412 { 444, "landlock_create_ruleset" },
413 { 445, "landlock_add_rule" },
414 { 446, "landlock_restrict_self" },
415 { 447, "memfd_secret" },
416 { 448, "process_mrelease" },
417 { 449, "futex_waitv" },
418 { 450, "set_mempolicy_home_node" }
419};
420
421} // namespace X86ISA
422} // namespace gem5
static SyscallDescTable< SyscallABI64 > syscallDescs64
This is exposed globally, independent of the ISA.
Definition tlb.cc:65
SyscallReturn unameFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< Linux::utsname > name)
Target uname() handler.
Definition syscalls.cc:49
SyscallReturn archPrctlFunc(SyscallDesc *desc, ThreadContext *tc, int code, uint64_t addr)
Definition syscalls.cc:63
Copyright (c) 2024 Arm Limited All rights reserved.
Definition binary32.hh:36
SyscallReturn linkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr<> new_pathname)
Target link() handler.
SyscallReturn getppidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getppid() handler.
SyscallReturn exitGroupFunc(SyscallDesc *desc, ThreadContext *tc, int status)
Target exit_group() handler: terminate simulation. (exit all threads)
SyscallReturn gettidFunc(SyscallDesc *desc, ThreadContext *tc)
Target gettid() handler.
SyscallReturn getrandomFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> buf_ptr, typename OS::size_t count, unsigned int flags)
SyscallReturn recvmsgFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> msgPtr, int flags)
SyscallReturn fstat64Func(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr< typename OS::tgt_stat64 > tgt_stat)
Target fstat64() handler.
SyscallReturn wait4Func(SyscallDesc *desc, ThreadContext *tc, pid_t pid, VPtr<> statPtr, int options, VPtr<> rusagePtr)
SyscallReturn clock_gettimeFunc(SyscallDesc *desc, ThreadContext *tc, int clk_id, VPtr< typename OS::timespec > tp)
Target clock_gettime() function.
SyscallReturn brkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> new_brk)
Target brk() handler: set brk address.
SyscallReturn mmapFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> start, typename OS::size_t length, int prot, int tgt_flags, int tgt_fd, typename OS::off_t offset)
Target mmap() handler.
SyscallReturn pipe2Func(SyscallDesc *desc, ThreadContext *tc, VPtr<> tgt_addr, int flags)
Target pipe() handler.
SyscallReturn getpidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getpid() handler.
SyscallReturn chdirFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname)
Target chdir() handler.
SyscallReturn getuidFunc(SyscallDesc *desc, ThreadContext *tc)
SyscallReturn pwrite64Func(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> bufPtr, typename OS::size_t nbytes, typename OS::off_t offset)
SyscallReturn getrusageFunc(SyscallDesc *desc, ThreadContext *tc, int who, VPtr< typename OS::rusage > rup)
Target getrusage() function.
SyscallReturn cloneFunc(SyscallDesc *desc, ThreadContext *tc, RegVal flags, RegVal newStack, VPtr<> ptidPtr, VPtr<> ctidPtr, VPtr<> tlsPtr)
SyscallReturn recvfromFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, typename OS::size_t buf_len, int flags, VPtr<> addr_ptr, VPtr<> addrlen_ptr)
SyscallReturn selectFunc(SyscallDesc *desc, ThreadContext *tc, int nfds, VPtr< typename OS::fd_set > readfds, VPtr< typename OS::fd_set > writefds, VPtr< typename OS::fd_set > errorfds, VPtr< typename OS::timeval > timeout)
SyscallReturn utimesFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr< typename OS::timeval[2]> tp)
Target utimes() handler.
SyscallReturn socketFunc(SyscallDesc *desc, ThreadContext *tc, int domain, int type, int prot)
SyscallReturn chownFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, uint32_t owner, uint32_t group)
Target chown() handler.
SyscallReturn writeFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, typename OS::size_t nbytes)
SyscallReturn writevFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> tiov_base, typename OS::size_t count)
Target writev() handler.
SyscallReturn chmodFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, mode_t mode)
Target chmod() handler.
SyscallReturn renameFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> oldpath, VPtr<> newpath)
Target rename() handler.
SyscallReturn mknodFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, mode_t mode, dev_t dev)
Target mknod() handler.
SyscallReturn setpgidFunc(SyscallDesc *desc, ThreadContext *tc, int pid, int pgid)
Target setpgid() handler.
SyscallReturn truncateFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, typename OS::off_t length)
Target truncate() handler.
SyscallReturn geteuidFunc(SyscallDesc *desc, ThreadContext *tc)
Target geteuid() handler.
SyscallReturn symlinkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr<> new_pathname)
Target symlink() handler.
SyscallReturn unlinkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname)
Target unlink() handler.
SyscallReturn lseekFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, typename OS::off_t offs, int whence)
Target lseek() handler.
SyscallReturn sysinfoFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< typename OS::tgt_sysinfo > sysinfo)
Target sysinfo() handler.
SyscallReturn fchownatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, uint32_t owner, uint32_t group, int flags)
Target fchownat() handler.
SyscallReturn gettimeofdayFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< typename OS::timeval > tp, VPtr<> tz_ptr)
Target gettimeofday() handler.
SyscallReturn unlinkatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, int flags)
Target unlinkat() handler.
SyscallReturn pipeFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> tgt_addr)
Target pipe() handler.
SyscallReturn prlimitFunc(SyscallDesc *desc, ThreadContext *tc, int pid, int resource, VPtr<> n, VPtr< typename OS::rlimit > rlp)
SyscallReturn clock_getresFunc(SyscallDesc *desc, ThreadContext *tc, int clk_id, VPtr< typename OS::timespec > tp)
Target clock_getres() function.
SyscallReturn faccessatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, int mode)
Target facessat() handler.
SyscallReturn getsockoptFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int level, int optname, VPtr<> valPtr, VPtr<> lenPtr)
SyscallReturn getrlimitFunc(SyscallDesc *desc, ThreadContext *tc, unsigned resource, VPtr< typename OS::rlimit > rlp)
Target getrlimit() handler.
SyscallReturn mknodatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, mode_t mode, dev_t dev)
Target mknodat() handler.
SyscallReturn fallocateFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int mode, typename OS::off_t offset, typename OS::off_t len)
SyscallReturn futimesatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, VPtr< typename OS::timeval[2]> tp)
Target futimesat() handler.
SyscallReturn ignoreWarnOnceFunc(SyscallDesc *desc, ThreadContext *tc)
Like above, but only prints a warning once per syscall desc it's used with.
SyscallReturn socketpairFunc(SyscallDesc *desc, ThreadContext *tc, int domain, int type, int prot, VPtr<> svPtr)
SyscallReturn ftruncateFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, typename OS::off_t length)
Target ftruncate() handler.
SyscallReturn statfsFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr< typename OS::tgt_statfs > tgt_stat)
Target statfs() handler.
SyscallReturn setsockoptFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int level, int optname, VPtr<> valPtr, socklen_t len)
SyscallReturn rmdirFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname)
SyscallReturn mkdirFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, mode_t mode)
Target mkdir() handler.
SyscallReturn readlinkatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, VPtr<> buf_ptr, typename OS::size_t bufsiz)
Target readlinkat() handler.
SyscallReturn getpgrpFunc(SyscallDesc *desc, ThreadContext *tc)
Target getpgrpFunc() handler.
SyscallReturn eventfdFunc(SyscallDesc *desc, ThreadContext *tc, unsigned initval, int in_flags)
Target eventfd() function.
SyscallReturn dupFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd)
FIXME: The file description is not shared among file descriptors created with dup.
SyscallReturn listenFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int backlog)
SyscallReturn readvFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> tiov_base, typename OS::size_t count)
Target readv() handler.
SyscallReturn getcwdFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> buf_ptr, typename OS::size_t size)
Target getcwd() handler.
SyscallReturn fchmodatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, mode_t mode)
Target chmod() handler.
SyscallReturn openatFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_dirfd, VPtr<> pathname, int tgt_flags, int mode)
Target open() handler.
SyscallReturn fchownFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, uint32_t owner, uint32_t group)
Target fchown() handler.
SyscallReturn munmapFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> start, typename OS::size_t length)
Target munmap() handler.
SyscallReturn readlinkFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr<> buf_ptr, typename OS::size_t bufsiz)
Target readlink() handler.
SyscallReturn pread64Func(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> bufPtr, typename OS::size_t nbytes, typename OS::off_t offset)
SyscallReturn setTidAddressFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> tidPtr)
Target set_tid_address() handler.
SyscallReturn timesFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< typename OS::tms > bufp)
Target times() function.
SyscallReturn fcntlFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int cmd, guest_abi::VarArgs< int > varargs)
Target fcntl() handler.
SyscallReturn openFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, int tgt_flags, int mode)
Target open() handler.
SyscallReturn schedGetaffinityFunc(SyscallDesc *desc, ThreadContext *tc, pid_t pid, typename OS::size_t cpusetsize, VPtr<> cpu_set_mask)
Target sched_getaffinity.
SyscallReturn bindFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, int addrlen)
SyscallReturn pollFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> fdsPtr, int nfds, int tmout)
SyscallReturn getegidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getegid() handler.
SyscallReturn timeFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> taddr)
Target time() function.
SyscallReturn newfstatatFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, VPtr< typename OS::tgt_stat64 > tgt_stat, int flags)
Target newfstatat() handler.
SyscallReturn fchmodFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, uint32_t mode)
Target fchmod() handler.
SyscallReturn shutdownFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, int how)
Target shutdown() handler.
SyscallReturn renameatFunc(SyscallDesc *desc, ThreadContext *tc, int olddirfd, VPtr<> oldpath, int newdirfd, VPtr<> newpath)
Target renameat() handler.
SyscallReturn getcpuFunc(SyscallDesc *desc, ThreadContext *tc, VPtr< uint32_t > cpu, VPtr< uint32_t > node, VPtr< uint32_t > tcache)
SyscallReturn getsocknameFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> addrPtr, VPtr<> lenPtr)
SyscallReturn clone3Func(SyscallDesc *desc, ThreadContext *tc, VPtr< typename OS::tgt_clone_args > cl_args, RegVal size)
SyscallReturn ioctlFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, unsigned req, VPtr<> addr)
Target ioctl() handler.
SyscallReturn getpeernameFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> sockAddrPtr, VPtr<> addrlenPtr)
SyscallReturn accessFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, mode_t mode)
Target access() handler.
SyscallReturn tgkillFunc(SyscallDesc *desc, ThreadContext *tc, int tgid, int tid, int sig)
SyscallReturn sendmsgFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> msgPtr, int flags)
SyscallReturn lstat64Func(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr< typename OS::tgt_stat64 > tgt_stat)
Target lstat64() handler.
SyscallReturn ignoreFunc(SyscallDesc *desc, ThreadContext *tc)
Handler for unimplemented syscalls that we never intend to implement (signal handling,...
SyscallReturn acceptFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> addrPtr, VPtr<> lenPtr)
SyscallReturn futexFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> uaddr, int op, int val, int timeout, VPtr<> uaddr2, int val3)
Futex system call Implemented by Daniel Sanchez Used by printf's in multi-threaded apps.
SyscallReturn fstatfsFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr< typename OS::tgt_statfs > tgt_stat)
Target fstatfs() handler.
SyscallReturn statxFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, int flags, unsigned int mask, VPtr< typename OS::tgt_statx > tgt_statx)
Target statx() handler.
SyscallReturn mremapFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> start, typename OS::size_t old_length, typename OS::size_t new_length, int flags, guest_abi::VarArgs< uint64_t > varargs)
Target mremap() handler.
SyscallReturn stat64Func(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr< typename OS::tgt_stat64 > tgt_stat)
Target stat64() handler.
SyscallReturn connectFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, int addrlen)
SyscallReturn execveFunc(SyscallDesc *desc, ThreadContext *tc, VPtr<> pathname, VPtr<> argv_mem_loc, VPtr<> envp_mem_loc)
SyscallReturn sched_getparamFunc(SyscallDesc *desc, ThreadContext *tc, int pid, VPtr< int > paramPtr)
SyscallReturn exitFunc(SyscallDesc *desc, ThreadContext *tc, int status)
Target exit() handler: terminate current context.
SyscallReturn dup2Func(SyscallDesc *desc, ThreadContext *tc, int old_tgt_fd, int new_tgt_fd)
Target dup2() handler.
SyscallReturn getgidFunc(SyscallDesc *desc, ThreadContext *tc)
Target getgid() handler.
SyscallReturn readFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, typename OS::size_t nbytes)
SyscallReturn closeFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd)
Target close() handler.
SyscallReturn umaskFunc(SyscallDesc *desc, ThreadContext *tc)
Target umask() handler.
SyscallReturn sendtoFunc(SyscallDesc *desc, ThreadContext *tc, int tgt_fd, VPtr<> buf_ptr, typename OS::size_t buf_len, int flags, VPtr<> addr_ptr, socklen_t addr_len)
SyscallReturn mkdiratFunc(SyscallDesc *desc, ThreadContext *tc, int dirfd, VPtr<> pathname, mode_t mode)
Target mkdirat() handler.
This file defines objects used to emulate syscalls from the target application on the host machine.

Generated on Mon May 26 2025 09:19:06 for gem5 by doxygen 1.13.2