1 # $NetBSD: Makefile.inc,v 1.186 2008/02/09 02:41:07 mrg Exp $ 2 # @(#)Makefile.inc 8.3 (Berkeley) 10/24/94 3 4 # sys sources 5 .PATH: ${ARCHDIR}/sys ${.CURDIR}/sys 6 7 # modules with non-default implementations on at least one architecture: 8 SRCS+= __clone.S __vfork14.S brk.S exect.S fork.S pipe.S \ 9 getcontext.S \ 10 ptrace.S sbrk.S shmat.S \ 11 syscall.S __syscall.S __clone.S cerror.S 12 13 _LSRC+= Lint___clone.c Lint___vfork14.c Lint_brk.c Lint_clone.c \ 14 Lint_getcontext.c \ 15 Lint_exect.c Lint_pipe.c Lint_ptrace.c Lint_sbrk.c \ 16 Lint_syscall.c Lint___syscall.c \ 17 LintSysNormal.c LintSysNoerr.c LintSysPseudoNoerr.c 18 19 .if ${MKLINT} != "no" 20 LSRCS+= ${_LSRC} 21 DPSRCS+= ${_LSRC:MLintSys*.c} 22 CLEANFILES+= ${_LSRC:MLintSys*.c} 23 .endif 24 25 # glue to offer userland wrappers for some syscalls 26 SRCS+= posix_fadvise.c sigtimedwait.c sigwait.c sigwaitinfo.c statvfs.c \ 27 swapon.c 28 29 # glue to provide compatibility between GCC 1.X and 2.X and for compat 30 # with old syscall interfaces. 31 GLUE+= adjtime.c clock_settime.c ftruncate.c \ 32 lseek.c mmap.c ntp_adjtime.c pread.c preadv.c pwrite.c \ 33 pwritev.c settimeofday.c \ 34 truncate.c 35 36 # 'glue' files might .c or .S depending on the architecture 37 .for glue in ${GLUE} 38 . if exists(${glue:.c=.S}) 39 # Build the ASM glue file 40 SRCS+=${glue:.c=.S} 41 . else 42 . if exists(__${glue:.c=.S}) 43 SRCS+=__${glue:.c=.S} ${glue} 44 . else 45 # Build the C glue file 46 SRCS+= ${glue} 47 # and an asm entry for __<syscall> 48 ASM_GLUE+= __${glue:.c=.S} 49 . endif 50 . endif 51 .endfor 52 53 # glue to syscalls that may pass structs or unions, which cannot be 54 # handled portably and easily by the syscall interface. The glue 55 # converts structs and unions to pointers to them. 56 SRCS+= __semctl13.c 57 58 # namespace purity wrappers 59 SRCS+= _brk.c _fork.c _getcontext.c _pipe.c _sbrk.c 60 61 # modules with default implementations on all architectures: 62 ASM= access.S acct.S \ 63 bind.S \ 64 chdir.S chflags.S chmod.S chown.S chroot.S clock_getres.S \ 65 clock_gettime.S \ 66 dup.S dup2.S \ 67 extattrctl.S \ 68 extattr_delete_fd.S extattr_delete_file.S \ 69 extattr_delete_link.S extattr_get_fd.S extattr_get_file.S \ 70 extattr_get_link.S extattr_list_fd.S extattr_list_file.S \ 71 extattr_list_link.S extattr_set_fd.S extattr_set_file.S \ 72 extattr_set_link.S \ 73 fchdir.S fchflags.S fchmod.S fchown.S fchroot.S \ 74 __fhopen40.S __fhstat40.S __fhstatvfs140.S fktrace.S \ 75 flock.S fpathconf.S __fstat30.S fstatvfs1.S futimes.S \ 76 __getcwd.S __getdents30.S __getfh30.S getvfsstat.S getgroups.S getitimer.S \ 77 __getlogin.S getpeername.S getpgid.S getpgrp.S \ 78 getpriority.S getrlimit.S getrusage.S getsid.S getsockname.S \ 79 getsockopt.S gettimeofday.S \ 80 ioctl.S \ 81 kevent.S kqueue.S ktrace.S \ 82 _ksem_close.S _ksem_destroy.S _ksem_getvalue.S _ksem_init.S \ 83 _ksem_post.S _ksem_trywait.S _ksem_unlink.S _ksem_wait.S \ 84 _ksem_open.S \ 85 lchflags.S lchmod.S lchown.S lfs_bmapv.S lfs_markv.S lfs_segclean.S \ 86 lfs_segwait.S link.S listen.S __lstat30.S lutimes.S \ 87 _lwp_create.S _lwp_exit.S _lwp_kill.S _lwp_park.S \ 88 _lwp_self.S _lwp_wait.S _lwp_unpark.S _lwp_unpark_all.S \ 89 _lwp_suspend.S _lwp_continue.S _lwp_wakeup.S _lwp_detach.S \ 90 _lwp_setprivate.S \ 91 _lwp_setname.S _lwp_getname.S _lwp_ctl.S \ 92 madvise.S mincore.S minherit.S mkdir.S mkfifo.S mknod.S \ 93 mlock.S mlockall.S modctl.S __mount50.S mprotect.S __msgctl13.S \ 94 msgget.S munlock.S munlockall.S munmap.S \ 95 nfssvc.S __ntp_gettime30.S \ 96 pathconf.S pmc_get_info.S pmc_control.S __posix_chown.S \ 97 __posix_fadvise50.S \ 98 __posix_fchown.S __posix_lchown.S __posix_rename.S profil.S \ 99 quotactl.S \ 100 rasctl.S reboot.S recvfrom.S recvmsg.S rename.S revoke.S \ 101 rmdir.S \ 102 sa_register.S sa_stacks.S sa_enable.S sa_setconcurrency.S sa_yield.S \ 103 sa_preempt.S semconfig.S semget.S semop.S ____semctl13.S \ 104 sendmsg.S sendto.S setegid.S setcontext.S seteuid.S setgid.S \ 105 setgroups.S setitimer.S __setlogin.S setpgid.S setpriority.S \ 106 setregid.S setreuid.S setrlimit.S setsid.S setsockopt.S \ 107 setuid.S __shmctl13.S shmdt.S shmget.S shutdown.S \ 108 __sigaltstack14.S __sigpending14.S __sigaction_sigtramp.S \ 109 __sigtimedwait.S __socket30.S socketpair.S __stat30.S statvfs1.S \ 110 swapctl.S symlink.S __sysctl.S \ 111 timer_create.S timer_delete.S timer_gettime.S timer_getoverrun.S \ 112 timer_settime.S \ 113 umask.S undelete.S unlink.S unmount.S utimes.S utrace.S uuidgen.S \ 114 vadvise.S 115 116 # modules with potentially non default implementations 117 ASM_MD= _lwp_getprivate.S mremap.S 118 119 .for f in ${ASM_MD} 120 . if !exists(${f}) 121 ASM+= ${f} 122 . else 123 SRCS+= ${f} 124 . endif 125 .endfor 126 127 WEAKASM= accept.S aio_suspend.S close.S connect.S execve.S \ 128 fcntl.S fdatasync.S fsync.S fsync_range.S \ 129 kill.S mq_receive.S mq_send.S mq_timedreceive.S mq_timedsend.S \ 130 msgrcv.S msgsnd.S __msync13.S \ 131 nanosleep.S open.S poll.S pollts.S pselect.S read.S readlink.S readv.S \ 132 _sched_setparam.S _sched_getparam.S _sched_setaffinity.S \ 133 _sched_getaffinity.S sched_yield.S \ 134 select.S __sigprocmask14.S __sigsuspend14.S sysarch.S \ 135 wait4.S write.S writev.S 136 137 NOERR= getegid.S geteuid.S getgid.S getpid.S getppid.S getuid.S \ 138 issetugid.S sync.S 139 140 PSEUDONOERR= _exit.S 141 142 SRCS+= ${ASM} ${WEAKASM} ${NOERR} ${PSEUDONOERR} ${ASM_GLUE} 143 CLEANFILES+= ${ASM} ${WEAKASM} ${NOERR} ${PSEUDONOERR} ${ASM_GLUE} 144 145 ASMDEPS= ${.CURDIR}/sys/Makefile.inc ${ARCHDIR}/SYS.h \ 146 ${DESTDIR}/usr/include/sys/syscall.h 147 148 _LINTASM= ${ASM:Nsa_*.S} ${WEAKASM:Nsa_*.S} 149 150 ${ASM}: ${ASMDEPS} 151 ${_MKTARGET_CREATE} 152 printf '#include "SYS.h"\nRSYSCALL(${.PREFIX})\n' >${.TARGET} 153 154 ${ASM_GLUE}: ${ASMDEPS} 155 ${_MKTARGET_CREATE} 156 printf '#include "SYS.h"\nPSEUDO(${.PREFIX},${.PREFIX:S/__//})\n' >${.TARGET} 157 158 ${WEAKASM}: ${ASMDEPS} 159 ${_MKTARGET_CREATE} 160 printf '#include "SYS.h"\nWSYSCALL(${.PREFIX},_sys_${.PREFIX})\nWEAK_ALIAS(_${.PREFIX},_sys_${.PREFIX})\n' >${.TARGET} 161 162 ${NOERR}: ${ASMDEPS} 163 ${_MKTARGET_CREATE} 164 printf '#include "SYS.h"\nRSYSCALL_NOERROR(${.PREFIX})\n' >${.TARGET} 165 166 ${PSEUDONOERR}: ${ASMDEPS} 167 ${_MKTARGET_CREATE} 168 printf '#include "SYS.h"\nPSEUDO_NOERROR(${.PREFIX},${.PREFIX:S/_//})\n' >${.TARGET} 169 # add an _Exit alias to _exit 170 printf 'STRONG_ALIAS(${.PREFIX:S/e/E/},${.PREFIX})\n' >>${.TARGET} 171 172 LintSysNormal.c: ${.CURDIR}/sys/makelintstub \ 173 ${DESTDIR}/usr/include/sys/syscall.h 174 ${_MKTARGET_CREATE} 175 CPP=${CPP:Q} ${HOST_SH} ${.CURDIR}/sys/makelintstub -o ${.TARGET} \ 176 -s ${DESTDIR}/usr/include/sys/syscall.h ${_LINTASM} 177 178 LintSysNoerr.c: ${.CURDIR}/sys/makelintstub \ 179 ${DESTDIR}/usr/include/sys/syscall.h 180 ${_MKTARGET_CREATE} 181 CPP=${CPP:Q} ${HOST_SH} ${.CURDIR}/sys/makelintstub -o ${.TARGET} -n \ 182 -s ${DESTDIR}/usr/include/sys/syscall.h ${NOERR} 183 184 LintSysPseudoNoerr.c: ${.CURDIR}/sys/makelintstub \ 185 ${DESTDIR}/usr/include/sys/syscall.h 186 ${_MKTARGET_CREATE} 187 CPP=${CPP:Q} ${HOST_SH} ${.CURDIR}/sys/makelintstub -o ${.TARGET} -p \ 188 -s ${DESTDIR}/usr/include/sys/syscall.h ${PSEUDONOERR} 189 190 MAN+= accept.2 access.2 acct.2 adjtime.2 bind.2 brk.2 chdir.2 \ 191 chflags.2 chmod.2 chown.2 chroot.2 clock_settime.2 clone.2 close.2 \ 192 connect.2 dup.2 execve.2 _exit.2 extattr_get_file.2 \ 193 fcntl.2 fdatasync.2 fhopen.2 \ 194 flock.2 fork.2 fsync.2 getcontext.2 getdents.2 \ 195 getfh.2 getvfsstat.2 getgid.2 getgroups.2 \ 196 getitimer.2 getlogin.2 getpeername.2 getpgrp.2 getpid.2 \ 197 getpriority.2 getrlimit.2 getrusage.2 getsid.2 getsockname.2 \ 198 getsockopt.2 gettimeofday.2 getuid.2 intro.2 ioctl.2 issetugid.2 \ 199 kill.2 kqueue.2 ktrace.2 \ 200 lfs_bmapv.2 lfs_markv.2 lfs_segclean.2 lfs_segwait.2 \ 201 link.2 listen.2 lseek.2 \ 202 _lwp_create.2 _lwp_ctl.2 _lwp_detach.2 _lwp_exit.2 \ 203 _lwp_self.2 _lwp_setname.2 \ 204 _lwp_suspend.2 _lwp_wakeup.2 _lwp_wait.2 _lwp_kill.2 \ 205 _lwp_getname.2 _lwp_getprivate.2 \ 206 _lwp_park.2 _lwp_unpark.2 _lwp_unpark_all.2 \ 207 mkdir.2 mkfifo.2 mknod.2 \ 208 madvise.2 mincore.2 minherit.2 mlock.2 mlockall.2 mmap.2 mount.2 \ 209 mprotect.2 mremap.2 msgctl.2 msgget.2 msgrcv.2 msgsnd.2 msync.2 \ 210 munmap.2 nanosleep.2 nfssvc.2 ntp_adjtime.2 open.2 pathconf.2 pipe.2 \ 211 pmc_control.2 poll.2 posix_fadvise.2 profil.2 ptrace.2 quotactl.2 \ 212 rasctl.2 read.2 readlink.2 \ 213 reboot.2 recv.2 rename.2 revoke.2 rmdir.2 \ 214 select.2 semctl.2 \ 215 semget.2 semop.2 send.2 setgroups.2 setpgid.2 setregid.2 \ 216 setreuid.2 setsid.2 setuid.2 shmat.2 shmctl.2 shmget.2 \ 217 shutdown.2 sigaction.2 sigaltstack.2 sigpending.2 \ 218 sigprocmask.2 sigstack.2 sigsuspend.2 sigtimedwait.2 \ 219 socket.2 \ 220 socketpair.2 stat.2 statvfs.2 swapctl.2 swapon.3 symlink.2 \ 221 sync.2 sysarch.2 syscall.2 timer_create.2 timer_delete.2 \ 222 timer_settime.2 truncate.2 umask.2 undelete.2 \ 223 unlink.2 utimes.2 utrace.2 uuidgen.2 vfork.2 wait.2 write.2 224 225 MLINKS+=_exit.2 _Exit.2 226 MLINKS+=brk.2 sbrk.2 227 MLINKS+=clone.2 __clone.2 228 MLINKS+=dup.2 dup2.2 229 MLINKS+=chdir.2 fchdir.2 230 MLINKS+=chflags.2 fchflags.2 chflags.2 lchflags.2 231 MLINKS+=chmod.2 fchmod.2 chmod.2 lchmod.2 232 MLINKS+=chown.2 fchown.2 chown.2 lchown.2 233 MLINKS+=chroot.2 fchroot.2 234 MLINKS+=clock_settime.2 clock_gettime.2 235 MLINKS+=clock_settime.2 clock_getres.2 236 MLINKS+=extattr_get_file.2 extattr_set_file.2 \ 237 extattr_get_file.2 extattr_delete_file.2 \ 238 extattr_get_file.2 extattr_list_file.2 \ 239 extattr_get_file.2 extattr_get_fd.2 \ 240 extattr_get_file.2 extattr_set_fd.2 \ 241 extattr_get_file.2 extattr_delete_fd.2 \ 242 extattr_get_file.2 extattr_list_fd.2 \ 243 extattr_get_file.2 extattr_get_link.2 \ 244 extattr_get_file.2 extattr_set_link.2 \ 245 extattr_get_file.2 extattr_delete_link.2 \ 246 extattr_get_file.2 extattr_list_link.2 247 MLINKS+=fhopen.2 fhstat.2 fhopen.2 fhstatvfs.2 fhopen.2 fhstatvfs1.2 248 MLINKS+=fsync.2 fsync_range.2 249 MLINKS+=getcontext.2 setcontext.2 250 MLINKS+=getgid.2 getegid.2 251 MLINKS+=getitimer.2 setitimer.2 252 MLINKS+=getlogin.2 setlogin.2 253 MLINKS+=getpgrp.2 getpgid.2 254 MLINKS+=getpid.2 getppid.2 255 MLINKS+=getpriority.2 setpriority.2 256 MLINKS+=getrlimit.2 setrlimit.2 257 MLINKS+=getsockopt.2 setsockopt.2 258 MLINKS+=gettimeofday.2 settimeofday.2 259 MLINKS+=getuid.2 geteuid.2 260 MLINKS+=intro.2 errno.2 261 MLINKS+=kqueue.2 kevent.2 262 MLINKS+=ktrace.2 fktrace.2 263 MLINKS+=lseek.2 seek.2 264 MLINKS+=_lwp_suspend.2 _lwp_continue.2 265 MLINKS+=_lwp_getprivate.2 _lwp_setprivate.2 266 MLINKS+=mlock.2 munlock.2 267 MLINKS+=mlockall.2 munlockall.2 268 MLINKS+=mount.2 unmount.2 269 MLINKS+=ntp_adjtime.2 ntp_gettime.2 270 MLINKS+=pathconf.2 fpathconf.2 271 MLINKS+=pmc_control.2 pmc_get_info.2 272 MLINKS+=poll.2 pollts.2 273 MLINKS+=read.2 readv.2 read.2 pread.2 read.2 preadv.2 274 MLINKS+=recv.2 recvfrom.2 recv.2 recvmsg.2 275 MLINKS+=select.2 pselect.2 276 MLINKS+=send.2 sendmsg.2 send.2 sendto.2 277 MLINKS+=setpgid.2 setpgrp.2 278 MLINKS+=setuid.2 setegid.2 setuid.2 seteuid.2 setuid.2 setgid.2 279 MLINKS+=shmat.2 shmdt.2 280 MLINKS+=timer_settime.2 timer_gettime.2 timer_settime.2 timer_getoverrun.2 281 MLINKS+=sigtimedwait.2 sigwaitinfo.2 282 MLINKS+=sigtimedwait.2 sigwait.2 283 MLINKS+=stat.2 fstat.2 stat.2 lstat.2 284 MLINKS+=statvfs.2 fstatvfs.2 285 MLINKS+=statvfs.2 statvfs1.2 286 MLINKS+=statvfs.2 fstatvfs1.2 287 MLINKS+=syscall.2 __syscall.2 288 MLINKS+=truncate.2 ftruncate.2 289 MLINKS+=utimes.2 futimes.2 utimes.2 lutimes.2 290 MLINKS+=wait.2 wait3.2 wait.2 wait4.2 wait.2 waitpid.2 291 MLINKS+=write.2 writev.2 write.2 pwrite.2 write.2 pwritev.2 292