xref: /dragonfly/lib/libc/sys/Makefile.inc (revision acea3a2a)
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