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