Makefile.rumpkern revision 1.81
11.81Spooka#	$NetBSD: Makefile.rumpkern,v 1.81 2010/04/26 23:17:13 pooka Exp $
21.1Spooka#
31.1Spooka
41.1Spooka.include "${RUMPTOP}/Makefile.rump"
51.1Spooka
61.1SpookaLIB=		rump
71.1Spooka
81.1Spooka.PATH:	${RUMPTOP}/librump/rumpkern				\
91.31Spooka	${RUMPTOP}/../kern					\
101.55Spooka	${RUMPTOP}/../uvm					\
111.31Spooka	${RUMPTOP}/../conf					\
121.43Spooka	${RUMPTOP}/../dev					\
131.50Selad	${RUMPTOP}/../secmodel/suser
141.1Spooka
151.11Spooka#
161.14Spooka# Source modules, first the ones specifically implemented for librump.
171.11Spooka# 
181.81SpookaSRCS=	rump.c rumpcopy.c emul.c intr.c kobj_rename.c locks.c	\
191.81Spooka	ltsleep.c memalloc.c scheduler.c signals.c sleepq.c	\
201.78Spooka	sysproxy_socket.c threads.c vm.c
211.20Spooka
221.69Spookavers.c: ${RUMPTOP}/../conf/newvers.sh ${RUMPTOP}/../conf/osrelease.sh
231.69Spooka	${_MKMSG_CREATE} vers.c
241.70Spooka	${HOST_SH} ${RUMPTOP}/../conf/newvers.sh -i RUMP-ROAST -n
251.69SpookaSRCS+=		vers.c
261.69SpookaCLEANFILES+=	vers.c version
271.69Spooka
281.14Spooka# stubs
291.20Spooka#
301.62SpookaSRCS+=	pmap_stub.c
311.20Spooka
321.20Spooka# autogenerated
331.20Spooka#
341.56SpookaSRCS+=	rump_syscalls.c rumpkern_if_wrappers.c
351.1Spooka
361.11Spooka#
371.11Spooka# Rest are from the std kernel sources.
381.11Spooka#
391.1Spooka# sys/kern
401.48SpookaSRCS+=	init_sysctl_base.c kern_auth.c kern_descrip.c kern_event.c	\
411.72Spooka	kern_hook.c kern_ksyms.c kern_malloc_stdtype.c kern_module.c	\
421.79Spooka	kern_mutex_obj.c kern_ntptime.c kern_rate.c kern_resource.c	\
431.79Spooka	kern_stub.c kern_syscall.c kern_sysctl.c kern_tc.c		\
441.79Spooka	kern_timeout.c kern_uidinfo.c param.c sys_descrip.c		\
451.80Spooka	sys_generic.c sys_module.c sys_pipe.c sys_select.c syscalls.c
461.11Spooka
471.11Spooka# sys/kern subr (misc)
481.73SpookaSRCS+=	subr_devsw.c subr_callback.c subr_copy.c subr_device.c		\
491.73Spooka	subr_evcnt.c subr_extent.c subr_hash.c subr_humanize.c		\
501.75Spooka	subr_iostat.c subr_kobj.c subr_log.c subr_lwp_specificdata.c	\
511.75Spooka	subr_once.c subr_prf.c subr_specificdata.c subr_time.c		\
521.75Spooka	subr_workqueue.c subr_xcall.c
531.11Spooka
541.55Spooka# sys/uvm
551.55SpookaSRCS+=	uvm_readahead.c
561.55Spooka
571.43Spooka# 4.4BSD secmodel.  selection is hardcoded for now
581.50SeladSRCS+=	secmodel_suser.c
591.43Spooka
601.20Spooka# the funny bit.  this doesn't really belong here, but helps with the
611.20Spooka# needs of kern_descrip.c.  And since it's a fully dynamic interface,
621.20Spooka# it doesn't pull in other gunk.
631.20SpookaSRCS+=	vnode_if.c
641.1Spooka
651.11Spooka# sys/dev
661.11SpookaSRCS+=	clock_subr.c
671.11Spooka
681.65Spooka# Flip the comment to the other line if you want to use malloc(3)
691.65Spooka# directly instead of the kernel allocators backed by malloc(3)/mmap(2).
701.65Spooka# Libc malloc is a few percent faster, but doesn't emulate all kernel
711.65Spooka# corner cases as well (not to mention if you want to debug the
721.65Spooka# allocators themselves).
731.65Spooka#CPPFLAGS+=	-DRUMP_USE_UNREAL_ALLOCATORS
741.71SpookaSRCS+=		subr_kmem.c subr_percpu.c subr_pool.c subr_vmem.c
751.6Spooka
761.1Spooka# no shlib_version because this is automatically in sync with lib/librump
771.1SpookaSHLIB_MAJOR=    0
781.1SpookaSHLIB_MINOR=    0
791.1Spooka
801.47SpookaCPPFLAGS+=	-I${RUMPTOP}/librump/rumpkern -I${RUMPTOP}/librump/rumpvfs
811.47SpookaCPPFLAGS+=	-I${RUMPTOP}/librump/rumpnet -I${RUMPTOP}/librump/rumpdev
821.32SpookaAFLAGS+=	-D_LOCORE -Wa,-fatal-warnings
831.1Spooka
841.27Spooka#
851.27Spooka# If archdir exists, it is required to provide:
861.27Spooka# 1) kobj_reloc() and kobj_machdep()
871.52Spooka# 2) rump_cpu_bootstrap()
881.52Spooka# 3) ...?
891.52Spooka# 4) PROFIT!
901.27Spooka#
911.30Spooka
921.30Spooka#
931.34Spooka# Check if we are building compat.  In compat mode we need to provide
941.34Spooka# the kernel of our compat target (amd64->i386 & sparc64->sparc), so
951.34Spooka# take MD stuff from the right arch.
961.30Spooka#
971.67Smrg.ifdef MLIBDIR
981.67SmrgARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MLIBDIR}
991.67SmrgLIBKERN_ARCH=	${MLIBDIR}
1001.68Smatt.elif exists(${RUMPTOP}/librump/rumpkern/arch/${MACHINE_CPU})
1011.68SmattARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MACHINE_CPU}
1021.30Spooka.else
1031.24SpookaARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MACHINE_ARCH}
1041.30Spooka.endif
1051.24Spooka.if exists(${ARCHDIR})
1061.24Spooka.include "${ARCHDIR}/Makefile.inc"
1071.24Spooka.PATH:	${ARCHDIR}
1081.27Spooka.else
1091.52SpookaSRCS+=	kobj_stubs.c rumpcpu_generic.c
1101.24Spooka.endif
1111.24Spooka
1121.31Spooka# include libkern source files
1131.31SpookaKERNDIR=${RUMPTOP}/../lib/libkern
1141.31Spooka.include "${RUMPTOP}/../lib/libkern/Makefile.libkern"
1151.31Spooka
1161.36Spooka# Some architectures require a little special massage with atomic
1171.36Spooka# compare-and-swap.  This is because the kernel version is using
1181.36Spooka# instructions or routines unavailable to us in userspace.  We
1191.36Spooka# use effectively the multiprocessor version of the userspace ops.
1201.36Spooka#
1211.36Spooka.if ${MACHINE_CPU} == "arm" || ${MACHINE_CPU} == "hppa" \
1221.37Spooka    || ${MACHINE_CPU} == "mips" || ${MACHINE_CPU} == "sh3" \
1231.54Schristos    || ${MACHINE_CPU} == "vax" || ${MACHINE_ARCH} == "m68000"
1241.36SpookaCPPFLAGS+=	-I${RUMPTOP}/../../common/lib/libc/atomic
1251.36SpookaSRCS+=		atomic_cas_generic.c
1261.36Spooka.endif
1271.36Spooka
1281.1Spooka.include <bsd.lib.mk>
1291.1Spooka.include <bsd.klinks.mk>
130