Makefile.rumpkern revision 1.79
11.79Spooka# $NetBSD: Makefile.rumpkern,v 1.79 2010/04/21 16:16:31 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.59SpookaSRCS= rump.c rumpcopy.c emul.c intr.c locks.c ltsleep.c \ 191.78Spooka 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.79Spooka sys_generic.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