1 2# sys sources 3.PATH: ${LIBC_SRCTOP}/${LIBC_ARCH}/sys ${LIBC_SRCTOP}/sys 4 5# Include the generated makefile containing the *complete* list 6# of syscall names in MIASM. 7.include "${SRCTOP}/sys/sys/syscall.mk" 8 9# Include machine dependent definitions. 10# 11# MDASM names override the default syscall names in MIASM. 12# NOASM will prevent the default syscall code from being generated. 13# PSEUDO generates _<sys>() and __sys_<sys>() symbols, but not <sys>(). 14# 15# While historically machine dependent, all architectures have the following 16# declarations in common: 17# 18NOASM= exit.o \ 19 getlogin.o \ 20 yield.o 21PSEUDO= _exit.o \ 22 _getlogin.o 23.sinclude "${LIBC_SRCTOP}/${LIBC_ARCH}/sys/Makefile.inc" 24 25SRCS+= clock_gettime.c gettimeofday.c __vdso_gettimeofday.c 26NOASM+= clock_gettime.o gettimeofday.o 27PSEUDO+= _clock_gettime.o _gettimeofday.o 28 29# Sources common to both syscall interfaces: 30SRCS+= \ 31 __error.c \ 32 interposing_table.c 33 34SRCS+= getdents.c lstat.c mknod.c stat.c 35 36NOASM+= sched_getcpu.o 37PSEUDO+= _sched_getcpu.o 38 39SRCS+= brk.c 40SRCS+= closefrom.c 41SRCS+= pipe.c 42SRCS+= shm_open.c 43SRCS+= vadvise.c 44SRCS+= POSIX2x_Fork.c 45 46SRCS+= compat-stub.c 47 48INTERPOSED = \ 49 accept \ 50 accept4 \ 51 aio_suspend \ 52 clock_nanosleep \ 53 close \ 54 connect \ 55 fcntl \ 56 fdatasync \ 57 fsync \ 58 fork \ 59 kevent \ 60 msync \ 61 nanosleep \ 62 open \ 63 openat \ 64 pdfork \ 65 poll \ 66 ppoll \ 67 pselect \ 68 ptrace \ 69 read \ 70 readv \ 71 recvfrom \ 72 recvmsg \ 73 select \ 74 sendmsg \ 75 sendto \ 76 setcontext \ 77 sigaction \ 78 sigprocmask \ 79 sigsuspend \ 80 sigtimedwait \ 81 sigwait \ 82 sigwaitinfo \ 83 swapcontext \ 84 wait4 \ 85 wait6 \ 86 write \ 87 writev 88 89SRCS+= ${INTERPOSED:S/$/.c/} 90NOASM+= ${INTERPOSED:S/$/.o/} 91PSEUDO+= ${INTERPOSED:C/^.*$/_&.o/} 92 93# Add machine dependent asm sources: 94SRCS+=${MDASM} 95 96# Look though the complete list of syscalls (MIASM) for names that are 97# not defined with machine dependent implementations (MDASM) and are 98# not declared for no generation of default code (NOASM). Add each 99# syscall that satisfies these conditions to the ASM list. 100.for _asm in ${MIASM} 101.if !${MDASM:R:M${_asm:R}} && !${NOASM:R:M${_asm:R}} 102ASM+=$(_asm) 103.endif 104.endfor 105 106SASM= ${ASM:S/.o/.S/} 107 108SPSEUDO= ${PSEUDO:S/.o/.S/} 109 110SRCS+= ${SASM} ${SPSEUDO} 111 112SYM_MAPS+= ${LIBC_SRCTOP}/sys/Symbol.map 113 114# Generated files 115CLEANFILES+= ${SASM} ${SPSEUDO} 116 117.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386" || \ 118 ${MACHINE_CPUARCH} == "powerpc" || ${MACHINE_CPUARCH} == "arm" 119NOTE_GNU_STACK='\t.section .note.GNU-stack,"",%%progbits\n' 120.else 121NOTE_GNU_STACK='' 122.endif 123.if ${MACHINE_CPUARCH} == "aarch64" 124FEATURE_NOTE='\#include <sys/elf_common.h>\nGNU_PROPERTY_AARCH64_FEATURE_1_NOTE(GNU_PROPERTY_AARCH64_FEATURE_1_VAL)' 125.else 126FEATURE_NOTE='' 127.endif 128 129${SASM}: 130 printf '/* %sgenerated by libc/sys/Makefile.inc */\n' @ > ${.TARGET} 131 printf '#include "compat.h"\n' >> ${.TARGET} 132 printf '#include "SYS.h"\nRSYSCALL(${.PREFIX})\n' >> ${.TARGET} 133 printf ${NOTE_GNU_STACK} >>${.TARGET} 134 printf ${FEATURE_NOTE} >> ${.TARGET} 135 136${SPSEUDO}: 137 printf '/* %sgenerated by libc/sys/Makefile.inc */\n' @ > ${.TARGET} 138 printf '#include "compat.h"\n' >> ${.TARGET} 139 printf '#include "SYS.h"\nPSEUDO(${.PREFIX:S/_//})\n' \ 140 >> ${.TARGET} 141 printf ${NOTE_GNU_STACK} >>${.TARGET} 142 printf ${FEATURE_NOTE} >> ${.TARGET} 143 144MAN+= abort2.2 \ 145 accept.2 \ 146 access.2 \ 147 acct.2 \ 148 adjtime.2 \ 149 aio_cancel.2 \ 150 aio_error.2 \ 151 aio_fsync.2 \ 152 aio_mlock.2 \ 153 aio_read.2 \ 154 aio_return.2 \ 155 aio_suspend.2 \ 156 aio_waitcomplete.2 \ 157 aio_write.2 \ 158 bind.2 \ 159 bindat.2 \ 160 brk.2 \ 161 cap_enter.2 \ 162 cap_fcntls_limit.2 \ 163 cap_ioctls_limit.2 \ 164 cap_rights_limit.2 \ 165 chdir.2 \ 166 chflags.2 \ 167 chmod.2 \ 168 chown.2 \ 169 chroot.2 \ 170 clock_gettime.2 \ 171 close.2 \ 172 closefrom.2 \ 173 connect.2 \ 174 connectat.2 \ 175 copy_file_range.2 \ 176 cpuset.2 \ 177 cpuset_getaffinity.2 \ 178 cpuset_getdomain.2 \ 179 dup.2 \ 180 eventfd.2 \ 181 execve.2 \ 182 _exit.2 \ 183 extattr_get_file.2 \ 184 fcntl.2 \ 185 ffclock.2 \ 186 fhlink.2 \ 187 fhopen.2 \ 188 fhreadlink.2 \ 189 flock.2 \ 190 fork.2 \ 191 fspacectl.2 \ 192 fsync.2 \ 193 getdirentries.2 \ 194 getdtablesize.2 \ 195 getfh.2 \ 196 getfsstat.2 \ 197 getgid.2 \ 198 getgroups.2 \ 199 getitimer.2 \ 200 getlogin.2 \ 201 getloginclass.2 \ 202 getpeername.2 \ 203 getpgrp.2 \ 204 getpid.2 \ 205 getpriority.2 \ 206 getrandom.2 \ 207 getrlimit.2 \ 208 getrusage.2 \ 209 getsid.2 \ 210 getsockname.2 \ 211 getsockopt.2 \ 212 gettimeofday.2 \ 213 getuid.2 \ 214 intro.2 \ 215 ioctl.2 \ 216 issetugid.2 \ 217 jail.2 \ 218 kcmp.2 \ 219 kenv.2 \ 220 kill.2 \ 221 kldfind.2 \ 222 kldfirstmod.2 \ 223 kldload.2 \ 224 kldnext.2 \ 225 kldstat.2 \ 226 kldsym.2 \ 227 kldunload.2 \ 228 kqueue.2 \ 229 ktrace.2 \ 230 link.2 \ 231 lio_listio.2 \ 232 listen.2 \ 233 lseek.2 \ 234 madvise.2 \ 235 mincore.2 \ 236 minherit.2 \ 237 mkdir.2 \ 238 mkfifo.2 \ 239 mknod.2 \ 240 mlock.2 \ 241 mlockall.2 \ 242 mmap.2 \ 243 modfind.2 \ 244 modnext.2 \ 245 modstat.2 \ 246 mount.2 \ 247 mprotect.2 \ 248 mq_close.2 \ 249 mq_getattr.2 \ 250 mq_notify.2 \ 251 mq_open.2 \ 252 mq_receive.2 \ 253 mq_send.2 \ 254 mq_setattr.2 \ 255 mq_unlink.2 \ 256 msgctl.2 \ 257 msgget.2 \ 258 msgrcv.2 \ 259 msgsnd.2 \ 260 msync.2 \ 261 munmap.2 \ 262 nanosleep.2 \ 263 nfssvc.2 \ 264 ntp_adjtime.2 \ 265 open.2 \ 266 pathconf.2 \ 267 pdfork.2 \ 268 pipe.2 \ 269 poll.2 \ 270 posix_fadvise.2 \ 271 posix_fallocate.2 \ 272 posix_openpt.2 \ 273 procctl.2 \ 274 profil.2 \ 275 pselect.2 \ 276 ptrace.2 \ 277 quotactl.2 \ 278 rctl_add_rule.2 \ 279 read.2 \ 280 readlink.2 \ 281 reboot.2 \ 282 recv.2 \ 283 rename.2 \ 284 revoke.2 \ 285 rfork.2 \ 286 rmdir.2 \ 287 rtprio.2 \ 288 sched_get_priority_max.2 \ 289 sched_setparam.2 \ 290 sched_setscheduler.2 \ 291 sched_yield.2 \ 292 sctp_generic_recvmsg.2 \ 293 sctp_generic_sendmsg.2 \ 294 sctp_peeloff.2 \ 295 select.2 \ 296 semctl.2 \ 297 semget.2 \ 298 semop.2 \ 299 send.2 \ 300 setfib.2 \ 301 sendfile.2 \ 302 setgroups.2 \ 303 setpgid.2 \ 304 setregid.2 \ 305 setresuid.2 \ 306 setreuid.2 \ 307 setsid.2 \ 308 setuid.2 \ 309 shmat.2 \ 310 shmctl.2 \ 311 shmget.2 \ 312 shm_open.2 \ 313 shutdown.2 \ 314 sigaction.2 \ 315 sigaltstack.2 \ 316 sigfastblock.2 \ 317 sigpending.2 \ 318 sigprocmask.2 \ 319 sigqueue.2 \ 320 sigreturn.2 \ 321 sigstack.2 \ 322 sigsuspend.2 \ 323 sigwait.2 \ 324 sigwaitinfo.2 \ 325 socket.2 \ 326 socketpair.2 \ 327 stat.2 \ 328 statfs.2 \ 329 swapon.2 \ 330 symlink.2 \ 331 sync.2 \ 332 sysarch.2 \ 333 syscall.2 \ 334 thr_exit.2 \ 335 thr_kill.2 \ 336 thr_new.2 \ 337 thr_self.2 \ 338 thr_set_name.2 \ 339 thr_suspend.2 \ 340 thr_wake.2 \ 341 timer_create.2 \ 342 timer_delete.2 \ 343 timer_settime.2 \ 344 timerfd.2 \ 345 truncate.2 \ 346 umask.2 \ 347 undelete.2 \ 348 unlink.2 \ 349 utimensat.2 \ 350 utimes.2 \ 351 utrace.2 \ 352 uuidgen.2 \ 353 vfork.2 \ 354 wait.2 \ 355 write.2 \ 356 _umtx_op.2 357 358MLINKS+=aio_read.2 aio_readv.2 359MLINKS+=aio_write.2 aio_writev.2 360MLINKS+=accept.2 accept4.2 361MLINKS+=access.2 eaccess.2 \ 362 access.2 faccessat.2 363MLINKS+=brk.2 sbrk.2 364MLINKS+=cap_enter.2 cap_getmode.2 365MLINKS+=cap_fcntls_limit.2 cap_fcntls_get.2 366MLINKS+=cap_ioctls_limit.2 cap_ioctls_get.2 367MLINKS+=chdir.2 fchdir.2 368MLINKS+=chflags.2 chflagsat.2 \ 369 chflags.2 fchflags.2 \ 370 chflags.2 lchflags.2 371MLINKS+=chmod.2 fchmod.2 \ 372 chmod.2 fchmodat.2 \ 373 chmod.2 lchmod.2 374MLINKS+=chown.2 fchown.2 \ 375 chown.2 fchownat.2 \ 376 chown.2 lchown.2 377MLINKS+=clock_gettime.2 clock_getres.2 \ 378 clock_gettime.2 clock_settime.2 379MLINKS+=closefrom.2 close_range.2 380MLINKS+=nanosleep.2 clock_nanosleep.2 381MLINKS+=cpuset.2 cpuset_getid.2 \ 382 cpuset.2 cpuset_setid.2 383MLINKS+=cpuset_getaffinity.2 cpuset_setaffinity.2 384MLINKS+=cpuset_getdomain.2 cpuset_setdomain.2 385MLINKS+=dup.2 dup2.2 386MLINKS+=eventfd.2 eventfd_read.3 \ 387 eventfd.2 eventfd_write.3 388MLINKS+=execve.2 fexecve.2 389MLINKS+=extattr_get_file.2 extattr.2 \ 390 extattr_get_file.2 extattr_delete_fd.2 \ 391 extattr_get_file.2 extattr_delete_file.2 \ 392 extattr_get_file.2 extattr_delete_link.2 \ 393 extattr_get_file.2 extattr_get_fd.2 \ 394 extattr_get_file.2 extattr_get_link.2 \ 395 extattr_get_file.2 extattr_list_fd.2 \ 396 extattr_get_file.2 extattr_list_file.2 \ 397 extattr_get_file.2 extattr_list_link.2 \ 398 extattr_get_file.2 extattr_set_fd.2 \ 399 extattr_get_file.2 extattr_set_file.2 \ 400 extattr_get_file.2 extattr_set_link.2 401MLINKS+=ffclock.2 ffclock_getcounter.2 \ 402 ffclock.2 ffclock_getestimate.2 \ 403 ffclock.2 ffclock_setestimate.2 404MLINKS+=fhlink.2 fhlinkat.2 405MLINKS+=fhopen.2 fhstat.2 fhopen.2 fhstatfs.2 406MLINKS+=fork.2 _Fork.2 407MLINKS+=fsync.2 fdatasync.2 408MLINKS+=getdirentries.2 getdents.2 409MLINKS+=getfh.2 lgetfh.2 \ 410 getfh.2 getfhat.2 411MLINKS+=getgid.2 getegid.2 412MLINKS+=getitimer.2 setitimer.2 413MLINKS+=getlogin.2 getlogin_r.3 414MLINKS+=getlogin.2 setlogin.2 415MLINKS+=getloginclass.2 setloginclass.2 416MLINKS+=getpgrp.2 getpgid.2 417MLINKS+=getpid.2 getppid.2 418MLINKS+=getpriority.2 setpriority.2 419MLINKS+=getrlimit.2 setrlimit.2 420MLINKS+=getsockopt.2 setsockopt.2 421MLINKS+=gettimeofday.2 settimeofday.2 422MLINKS+=getuid.2 geteuid.2 423MLINKS+=intro.2 errno.2 424MLINKS+=jail.2 jail_attach.2 \ 425 jail.2 jail_get.2 \ 426 jail.2 jail_remove.2 \ 427 jail.2 jail_set.2 428MLINKS+=kldunload.2 kldunloadf.2 429MLINKS+=kqueue.2 kevent.2 \ 430 kqueue.2 kqueuex.2 \ 431 kqueue.2 EV_SET.3 432MLINKS+=link.2 linkat.2 433MLINKS+=madvise.2 posix_madvise.2 434MLINKS+=mkdir.2 mkdirat.2 435MLINKS+=mkfifo.2 mkfifoat.2 436MLINKS+=mknod.2 mknodat.2 437MLINKS+=mlock.2 munlock.2 438MLINKS+=mlockall.2 munlockall.2 439MLINKS+=modnext.2 modfnext.2 440MLINKS+=mount.2 nmount.2 \ 441 mount.2 unmount.2 442MLINKS+=mq_receive.2 mq_timedreceive.2 443MLINKS+=mq_send.2 mq_timedsend.2 444MLINKS+=ntp_adjtime.2 ntp_gettime.2 445MLINKS+=open.2 openat.2 446MLINKS+=pathconf.2 fpathconf.2 447MLINKS+=pathconf.2 lpathconf.2 448MLINKS+=pdfork.2 pdgetpid.2\ 449 pdfork.2 pdkill.2 450MLINKS+=pipe.2 pipe2.2 451MLINKS+=poll.2 ppoll.2 452MLINKS+=rctl_add_rule.2 rctl_get_limits.2 \ 453 rctl_add_rule.2 rctl_get_racct.2 \ 454 rctl_add_rule.2 rctl_get_rules.2 \ 455 rctl_add_rule.2 rctl_remove_rule.2 456MLINKS+=read.2 pread.2 \ 457 read.2 preadv.2 \ 458 read.2 readv.2 459MLINKS+=readlink.2 readlinkat.2 460MLINKS+=recv.2 recvfrom.2 \ 461 recv.2 recvmsg.2 462MLINKS+=rename.2 renameat.2 463MLINKS+=rtprio.2 rtprio_thread.2 464MLINKS+=sched_get_priority_max.2 sched_get_priority_min.2 \ 465 sched_get_priority_max.2 sched_rr_get_interval.2 466MLINKS+=sched_setparam.2 sched_getparam.2 467MLINKS+=sched_setscheduler.2 sched_getscheduler.2 468MLINKS+=sctp_generic_sendmsg.2 sctp_generic_sendmsg_iov.2 469MLINKS+=select.2 FD_CLR.3 \ 470 select.2 FD_ISSET.3 \ 471 select.2 FD_SET.3 \ 472 select.2 FD_ZERO.3 473MLINKS+=send.2 sendmsg.2 \ 474 send.2 sendto.2 475MLINKS+=setpgid.2 setpgrp.2 476MLINKS+=setresuid.2 getresgid.2 \ 477 setresuid.2 getresuid.2 \ 478 setresuid.2 setresgid.2 479MLINKS+=setuid.2 setegid.2 \ 480 setuid.2 seteuid.2 \ 481 setuid.2 setgid.2 482MLINKS+=shmat.2 shmdt.2 483MLINKS+=shm_open.2 memfd_create.3 \ 484 shm_open.2 shm_create_largepage.3 \ 485 shm_open.2 shm_unlink.2 \ 486 shm_open.2 shm_rename.2 487MLINKS+=sigwaitinfo.2 sigtimedwait.2 488MLINKS+=stat.2 fstat.2 \ 489 stat.2 fstatat.2 \ 490 stat.2 lstat.2 491MLINKS+=statfs.2 fstatfs.2 492MLINKS+=swapon.2 swapoff.2 493MLINKS+=symlink.2 symlinkat.2 494MLINKS+=syscall.2 __syscall.2 495MLINKS+=timer_settime.2 timer_getoverrun.2 \ 496 timer_settime.2 timer_gettime.2 497MLINKS+=timerfd.2 timerfd_create.2 \ 498 timerfd.2 timerfd_gettime.2 \ 499 timerfd.2 timerfd_settime.2 500MLINKS+=thr_kill.2 thr_kill2.2 501MLINKS+=truncate.2 ftruncate.2 502MLINKS+=unlink.2 unlinkat.2 503MLINKS+=unlink.2 funlinkat.2 504MLINKS+=utimensat.2 futimens.2 505MLINKS+=utimes.2 futimes.2 \ 506 utimes.2 futimesat.2 \ 507 utimes.2 lutimes.2 508MLINKS+=wait.2 wait3.2 \ 509 wait.2 wait4.2 \ 510 wait.2 waitpid.2 \ 511 wait.2 waitid.2 \ 512 wait.2 wait6.2 513MLINKS+=write.2 pwrite.2 \ 514 write.2 pwritev.2 \ 515 write.2 writev.2 516