1# @(#)Makefile.inc 8.3 (Berkeley) 10/24/94 2# $FreeBSD: src/lib/libc/sys/Makefile.inc,v 1.75.2.7 2003/04/22 17:31:18 trhodes Exp $ 3# $DragonFly: src/lib/libc/sys/Makefile.inc,v 1.10 2005/02/21 21:41:01 dillon Exp $ 4 5# sys sources 6.PATH: ${.CURDIR}/../libc/${MACHINE_ARCH}/sys ${.CURDIR}/../libc/sys 7 8# Include the generated makefile containing the *complete* list 9# of syscall names in MIASM. 10.include "${.CURDIR}/../../sys/sys/syscall.mk" 11 12# Include machine dependent definitions. 13# 14# MDASM names override the default syscall names in MIASM. 15# NOASM will prevent the default syscall code from being generated. 16# 17.include "${.CURDIR}/../libc/${MACHINE_ARCH}/sys/Makefile.inc" 18 19# Sources common to both syscall interfaces: 20SRCS+= ftruncate.c lseek.c mmap.c pread.c pwrite.c truncate.c 21 22# Build __error() into libc, but not libc_r which has its own: 23.if ${LIB} == "c" 24SRCS+= __error.c 25.endif 26 27# Add machine dependent asm sources: 28SRCS+=${MDASM} 29 30# Add stack dependant asm sources: 31SRCS+= stack_protector.c 32 33# Look through the complete list of syscalls (MIASM) for names that are 34# not defined with machine dependent implementations (MDASM) and are 35# not declared for no generation of default code (NOASM). If the 36# syscall is not hidden, add it to the ASM list, otherwise add it 37# to the ASMR list. 38.for _asm in ${MIASM} 39.if (${MDASM:R:M${_asm:R}} == "") 40.if (${NOASM:R:M${_asm:R}} == "") 41.if (${HIDDEN_SYSCALLS:R:M${_asm:R}} == "") 42ASM+=$(_asm) 43.else 44ASMR+=$(_asm) 45.endif 46.endif 47.endif 48.endfor 49 50OBJS+= ${ASM} ${ASMR} ${PSEUDO} ${PSEUDOR} 51 52SASM= ${ASM:S/.o/.S/} 53 54SASMR= ${ASMR:S/.o/.S/} 55 56SPSEUDO= ${PSEUDO:S/.o/.S/} 57 58SPSEUDOR= ${PSEUDOR:S/.o/.S/} 59 60SRCS+= ${SASM} ${SASMR} ${SPSEUDO} ${SPSEUDOR} 61 62# Generated files 63CLEANFILES+= ${SASM} ${SASMR} ${SPSEUDO} ${SPSEUDOR} 64 65# Generate the syscalls source-files 66${SASM}: 67 printf '#include "SYS.h"\nRSYSCALL(${.PREFIX})\n' > ${.TARGET} 68 69${SASMR}: 70 printf '#include "SYS.h"\nPRSYSCALL(${.PREFIX})\n' > ${.TARGET} 71 72${SPSEUDO}: 73 printf '#include "SYS.h"\nPSEUDO(${.PREFIX},${.PREFIX:S/_//})\n' \ 74 > ${.TARGET} 75 76${SPSEUDOR}: 77 printf '#include "SYS.h"\nPPSEUDO(${.PREFIX},${.PREFIX:S/_//})\n' \ 78 > ${.TARGET} 79 80.if ${LIB} == "c" 81MAN+= _exit.2 accept.2 access.2 acct.2 adjtime.2 \ 82 aio_cancel.2 aio_error.2 aio_read.2 aio_return.2 \ 83 aio_suspend.2 aio_waitcomplete.2 aio_write.2 \ 84 bind.2 brk.2 sys_checkpoint.2 chdir.2 chflags.2 \ 85 chmod.2 chown.2 chroot.2 clock_gettime.2 close.2 \ 86 connect.2 dup.2 execve.2 \ 87 fcntl.2 fhopen.2 flock.2 fork.2 fsync.2 \ 88 getdirentries.2 getdtablesize.2 \ 89 getfh.2 getfsstat.2 getgid.2 getgroups.2 getitimer.2 getlogin.2 \ 90 getpeername.2 getpgrp.2 getpid.2 getpriority.2 getrlimit.2 \ 91 getrusage.2 getsid.2 getsockname.2 \ 92 getsockopt.2 gettimeofday.2 getuid.2 \ 93 intro.2 ioctl.2 issetugid.2 jail.2 jail_attach.2 kill.2 \ 94 kldfind.2 kldfirstmod.2 kldload.2 kldnext.2 kldstat.2 kldsym.2 \ 95 kldunload.2 ktrace.2 kqueue.2 link.2 listen.2 lseek.2 \ 96 madvise.2 mincore.2 minherit.2 mkdir.2 mkfifo.2 mknod.2 mlock.2 mmap.2 \ 97 modfind.2 modnext.2 modstat.2 \ 98 mount.2 mprotect.2 msync.2 munmap.2 nanosleep.2 \ 99 nfssvc.2 ntp_adjtime.2 ntp_gettime.2 \ 100 open.2 pathconf.2 pipe.2 poll.2 profil.2 ptrace.2 quotactl.2 \ 101 read.2 readlink.2 reboot.2 recv.2 rename.2 revoke.2 rfork.2 rmdir.2 \ 102 rtprio.2 select.2 semctl.2 semget.2 semop.2 send.2 sendfile.2 \ 103 setgroups.2 setpgid.2 setregid.2 setresuid.2 setreuid.2 setsid.2 \ 104 setuid.2 shmat.2 shmctl.2 shmget.2 shutdown.2 \ 105 sigaction.2 sigaltstack.2 sigpending.2 sigprocmask.2 sigreturn.2 \ 106 sigstack.2 sigsuspend.2 socket.2 socketpair.2 stat.2 statfs.2 \ 107 swapon.2 symlink.2 sync.2 sysarch.2 syscall.2 \ 108 truncate.2 tls.2 umask.2 umtx.2 undelete.2 \ 109 unlink.2 utimes.2 upc_register.2 vfork.2 wait.2 write.2 110.if !defined(NO_P1003_1B) 111MAN+= sched_get_priority_max.2 sched_setparam.2 \ 112 sched_setscheduler.2 sched_yield.2 113.endif 114 115MLINKS+=brk.2 sbrk.2 116MLINKS+=chdir.2 fchdir.2 117MLINKS+=chflags.2 fchflags.2 118MLINKS+=chmod.2 fchmod.2 chmod.2 lchmod.2 119MLINKS+=chown.2 fchown.2 chown.2 lchown.2 120MLINKS+=clock_gettime.2 clock_getres.2 clock_gettime.2 clock_settime.2 121MLINKS+=dup.2 dup2.2 122MLINKS+=fhopen.2 fhstat.2 fhopen.2 fhstatfs.2 123MLINKS+=getdirentries.2 getdents.2 124MLINKS+=getgid.2 getegid.2 125MLINKS+=getitimer.2 setitimer.2 126MLINKS+=getlogin.2 getlogin_r.3 127MLINKS+=getlogin.2 setlogin.2 128MLINKS+=getpgrp.2 getpgid.2 129MLINKS+=getpid.2 getppid.2 130MLINKS+=getpriority.2 setpriority.2 131MLINKS+=getrlimit.2 setrlimit.2 132MLINKS+=getsockopt.2 setsockopt.2 133MLINKS+=gettimeofday.2 settimeofday.2 134MLINKS+=getuid.2 geteuid.2 135MLINKS+=intro.2 errno.2 136MLINKS+=kqueue.2 kevent.2 137MLINKS+=lseek.2 seek.2 138MLINKS+=mlock.2 munlock.2 139MLINKS+=modnext.2 modfnext.2 140MLINKS+=mount.2 unmount.2 141MLINKS+=pathconf.2 fpathconf.2 142MLINKS+=read.2 pread.2 read.2 readv.2 143MLINKS+=recv.2 recvfrom.2 recv.2 recvmsg.2 144MLINKS+=send.2 sendmsg.2 send.2 sendto.2 145MLINKS+=setpgid.2 setpgrp.2 146MLINKS+=setresuid.2 setresgid.2 147MLINKS+=setuid.2 setegid.2 setuid.2 seteuid.2 setuid.2 setgid.2 148MLINKS+=shmat.2 shmdt.2 149MLINKS+=stat.2 fstat.2 stat.2 lstat.2 150MLINKS+=statfs.2 fstatfs.2 151MLINKS+=syscall.2 __syscall.2 152MLINKS+=truncate.2 ftruncate.2 153MLINKS+=utimes.2 futimes.2 utimes.2 lutimes.2 154MLINKS+=wait.2 wait3.2 wait.2 wait4.2 wait.2 waitpid.2 155MLINKS+=write.2 pwrite.2 write.2 writev.2 156.if !defined(NO_P1003_1B) 157MLINKS+=sched_get_priority_max.2 sched_get_priority_min.2 \ 158 sched_get_priority_max.2 sched_rr_get_interval.2 159MLINKS+=sched_setparam.2 sched_getparam.2 160MLINKS+=sched_setscheduler.2 sched_getscheduler.2 161MLINKS+=tls.2 sys_set_tls_area.2 tls.2 sys_get_tls_area.2 162MLINKS+=umtx.2 umtx_sleep.2 umtx.2 umtx_wakeup.2 163.endif 164.endif 165