Home | History | Annotate | Line # | Download | only in rumpkern
Makefile.rumpkern revision 1.74.2.3
      1  1.74.2.3     rmind #	$NetBSD: Makefile.rumpkern,v 1.74.2.3 2011/03/05 20:56:14 rmind Exp $
      2       1.1     pooka #
      3       1.1     pooka 
      4       1.1     pooka .include "${RUMPTOP}/Makefile.rump"
      5       1.1     pooka 
      6       1.1     pooka LIB=		rump
      7       1.1     pooka 
      8       1.1     pooka .PATH:	${RUMPTOP}/librump/rumpkern				\
      9      1.31     pooka 	${RUMPTOP}/../kern					\
     10      1.55     pooka 	${RUMPTOP}/../uvm					\
     11      1.31     pooka 	${RUMPTOP}/../conf					\
     12      1.43     pooka 	${RUMPTOP}/../dev					\
     13  1.74.2.3     rmind 	${RUMPTOP}/../secmodel/suser				\
     14  1.74.2.3     rmind 	${RUMPTOP}/../compat/common
     15       1.1     pooka 
     16      1.11     pooka #
     17      1.14     pooka # Source modules, first the ones specifically implemented for librump.
     18      1.11     pooka # 
     19  1.74.2.3     rmind SRCS=	rump.c rumpcopy.c emul.c intr.c lwproc.c klock.c	\
     20  1.74.2.3     rmind 	kobj_rename.c ltsleep.c memalloc.c scheduler.c		\
     21  1.74.2.3     rmind 	signals.c sleepq.c threads.c vm.c
     22  1.74.2.1     rmind 
     23  1.74.2.1     rmind # Multiprocessor or uniprocessor locking.  TODO: select right
     24  1.74.2.1     rmind # locking at runtime.
     25  1.74.2.1     rmind SRCS+=	locks.c
     26  1.74.2.1     rmind #SRCS+=	locks_up.c
     27      1.20     pooka 
     28  1.74.2.3     rmind MKREPRO?=no
     29  1.74.2.3     rmind 
     30  1.74.2.3     rmind .if ${MKREPRO} == "yes"
     31  1.74.2.3     rmind _NVFLAGS=-r
     32  1.74.2.3     rmind .else
     33  1.74.2.3     rmind _NVFLAGS=
     34  1.74.2.3     rmind .endif
     35  1.74.2.3     rmind 
     36  1.74.2.2     rmind vers.c: ${RUMPTOP}/../conf/newvers.sh ${RUMPTOP}/../conf/osrelease.sh ${RUMPTOP}/../sys/param.h
     37      1.69     pooka 	${_MKMSG_CREATE} vers.c
     38  1.74.2.3     rmind 	${HOST_SH} ${RUMPTOP}/../conf/newvers.sh -i RUMP-ROAST -n ${_NVFLAGS}
     39      1.69     pooka SRCS+=		vers.c
     40      1.69     pooka CLEANFILES+=	vers.c version
     41      1.69     pooka 
     42  1.74.2.2     rmind # use MI pmap for archs not conforming to kernel ABI
     43  1.74.2.2     rmind .ifndef RUMPKMOD
     44      1.62     pooka SRCS+=	pmap_stub.c
     45  1.74.2.2     rmind .endif
     46      1.20     pooka 
     47      1.20     pooka # autogenerated
     48      1.20     pooka #
     49      1.56     pooka SRCS+=	rump_syscalls.c rumpkern_if_wrappers.c
     50       1.1     pooka 
     51  1.74.2.1     rmind # "auto"generated
     52  1.74.2.1     rmind SRCS+=	devsw.c
     53  1.74.2.1     rmind 
     54      1.11     pooka #
     55  1.74.2.3     rmind # std kernel sources
     56      1.11     pooka #
     57       1.1     pooka # sys/kern
     58  1.74.2.3     rmind SRCS+=	init_sysctl_base.c	\
     59  1.74.2.3     rmind 	kern_auth.c		\
     60  1.74.2.3     rmind 	kern_cfglock.c		\
     61  1.74.2.3     rmind 	kern_descrip.c		\
     62  1.74.2.3     rmind 	kern_event.c		\
     63  1.74.2.3     rmind 	kern_hook.c		\
     64  1.74.2.3     rmind 	kern_ksyms.c		\
     65  1.74.2.3     rmind 	kern_malloc_stdtype.c	\
     66  1.74.2.3     rmind 	kern_module.c		\
     67  1.74.2.3     rmind 	kern_mutex_obj.c	\
     68  1.74.2.3     rmind 	kern_ntptime.c		\
     69  1.74.2.3     rmind 	kern_proc.c		\
     70  1.74.2.3     rmind 	kern_prot.c		\
     71  1.74.2.3     rmind 	kern_rate.c		\
     72  1.74.2.3     rmind 	kern_resource.c		\
     73  1.74.2.3     rmind 	kern_stub.c		\
     74  1.74.2.3     rmind 	kern_syscall.c		\
     75  1.74.2.3     rmind 	kern_sysctl.c		\
     76  1.74.2.3     rmind 	kern_tc.c		\
     77  1.74.2.3     rmind 	kern_timeout.c		\
     78  1.74.2.3     rmind 	kern_uidinfo.c		\
     79  1.74.2.3     rmind 	kern_xxx.c		\
     80  1.74.2.3     rmind 	param.c			\
     81  1.74.2.3     rmind 	subr_devsw.c		\
     82  1.74.2.3     rmind 	subr_callback.c		\
     83  1.74.2.3     rmind 	subr_copy.c		\
     84  1.74.2.3     rmind 	subr_device.c		\
     85  1.74.2.3     rmind 	subr_evcnt.c		\
     86  1.74.2.3     rmind 	subr_extent.c		\
     87  1.74.2.3     rmind 	subr_hash.c		\
     88  1.74.2.3     rmind 	subr_humanize.c		\
     89  1.74.2.3     rmind 	subr_iostat.c		\
     90  1.74.2.3     rmind 	subr_kobj.c		\
     91  1.74.2.3     rmind 	subr_log.c		\
     92  1.74.2.3     rmind 	subr_lwp_specificdata.c	\
     93  1.74.2.3     rmind 	subr_once.c		\
     94  1.74.2.3     rmind 	subr_prf.c		\
     95  1.74.2.3     rmind 	subr_specificdata.c	\
     96  1.74.2.3     rmind 	subr_time.c		\
     97  1.74.2.3     rmind 	subr_workqueue.c	\
     98  1.74.2.3     rmind 	subr_xcall.c		\
     99  1.74.2.3     rmind 	sys_descrip.c		\
    100  1.74.2.3     rmind 	sys_generic.c		\
    101  1.74.2.3     rmind 	sys_module.c		\
    102  1.74.2.3     rmind 	sys_pipe.c		\
    103  1.74.2.3     rmind 	sys_select.c		\
    104  1.74.2.3     rmind 	syscalls.c
    105      1.11     pooka 
    106      1.55     pooka # sys/uvm
    107  1.74.2.3     rmind SRCS+=	uvm_aobj.c uvm_readahead.c
    108      1.55     pooka 
    109      1.43     pooka # 4.4BSD secmodel.  selection is hardcoded for now
    110      1.50      elad SRCS+=	secmodel_suser.c
    111      1.43     pooka 
    112      1.20     pooka # the funny bit.  this doesn't really belong here, but helps with the
    113      1.20     pooka # needs of kern_descrip.c.  And since it's a fully dynamic interface,
    114      1.20     pooka # it doesn't pull in other gunk.
    115      1.20     pooka SRCS+=	vnode_if.c
    116       1.1     pooka 
    117      1.11     pooka # sys/dev
    118      1.11     pooka SRCS+=	clock_subr.c
    119      1.11     pooka 
    120  1.74.2.3     rmind # compat
    121  1.74.2.3     rmind SRCS+=	kern_select_50.c
    122  1.74.2.3     rmind 
    123      1.65     pooka # Flip the comment to the other line if you want to use malloc(3)
    124      1.65     pooka # directly instead of the kernel allocators backed by malloc(3)/mmap(2).
    125      1.65     pooka # Libc malloc is a few percent faster, but doesn't emulate all kernel
    126      1.65     pooka # corner cases as well (not to mention if you want to debug the
    127      1.65     pooka # allocators themselves).
    128      1.65     pooka #CPPFLAGS+=	-DRUMP_USE_UNREAL_ALLOCATORS
    129      1.71     pooka SRCS+=		subr_kmem.c subr_percpu.c subr_pool.c subr_vmem.c
    130       1.6     pooka 
    131  1.74.2.3     rmind .ifdef RUMP_LOCKDEBUG
    132  1.74.2.3     rmind SRCS+=		subr_lockdebug.c
    133  1.74.2.3     rmind .endif
    134  1.74.2.3     rmind 
    135       1.1     pooka # no shlib_version because this is automatically in sync with lib/librump
    136       1.1     pooka SHLIB_MAJOR=    0
    137       1.1     pooka SHLIB_MINOR=    0
    138       1.1     pooka 
    139      1.47     pooka CPPFLAGS+=	-I${RUMPTOP}/librump/rumpkern -I${RUMPTOP}/librump/rumpvfs
    140      1.47     pooka CPPFLAGS+=	-I${RUMPTOP}/librump/rumpnet -I${RUMPTOP}/librump/rumpdev
    141      1.32     pooka AFLAGS+=	-D_LOCORE -Wa,-fatal-warnings
    142       1.1     pooka 
    143      1.27     pooka #
    144      1.27     pooka # If archdir exists, it is required to provide:
    145      1.27     pooka # 1) kobj_reloc() and kobj_machdep()
    146      1.52     pooka # 2) rump_cpu_bootstrap()
    147      1.52     pooka # 3) ...?
    148      1.52     pooka # 4) PROFIT!
    149      1.27     pooka #
    150      1.30     pooka 
    151      1.30     pooka #
    152      1.34     pooka # Check if we are building compat.  In compat mode we need to provide
    153      1.34     pooka # the kernel of our compat target (amd64->i386 & sparc64->sparc), so
    154      1.34     pooka # take MD stuff from the right arch.
    155      1.30     pooka #
    156      1.67       mrg .ifdef MLIBDIR
    157      1.67       mrg ARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MLIBDIR}
    158      1.67       mrg LIBKERN_ARCH=	${MLIBDIR}
    159      1.68      matt .elif exists(${RUMPTOP}/librump/rumpkern/arch/${MACHINE_CPU})
    160      1.68      matt ARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MACHINE_CPU}
    161      1.30     pooka .else
    162      1.24     pooka ARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MACHINE_ARCH}
    163      1.30     pooka .endif
    164      1.24     pooka .if exists(${ARCHDIR})
    165      1.24     pooka .include "${ARCHDIR}/Makefile.inc"
    166      1.24     pooka .PATH:	${ARCHDIR}
    167      1.27     pooka .else
    168      1.52     pooka SRCS+=	kobj_stubs.c rumpcpu_generic.c
    169      1.24     pooka .endif
    170      1.24     pooka 
    171  1.74.2.2     rmind .if ${MACHINE} == "sun3"
    172  1.74.2.2     rmind CPPFLAGS+=	-Dsun3
    173  1.74.2.2     rmind .endif
    174  1.74.2.2     rmind 
    175      1.31     pooka # include libkern source files
    176      1.31     pooka KERNDIR=${RUMPTOP}/../lib/libkern
    177  1.74.2.1     rmind .ifdef RUMPKMOD
    178  1.74.2.1     rmind KERNMISCCPPFLAGS+=	-D_RUMPKERNEL
    179  1.74.2.1     rmind .endif
    180      1.31     pooka .include "${RUMPTOP}/../lib/libkern/Makefile.libkern"
    181      1.31     pooka 
    182      1.36     pooka # Some architectures require a little special massage with atomic
    183      1.36     pooka # compare-and-swap.  This is because the kernel version is using
    184  1.74.2.3     rmind # instructions or routines unavailable to us in userspace.
    185      1.36     pooka #
    186      1.36     pooka .if ${MACHINE_CPU} == "arm" || ${MACHINE_CPU} == "hppa" \
    187      1.37     pooka     || ${MACHINE_CPU} == "mips" || ${MACHINE_CPU} == "sh3" \
    188      1.54  christos     || ${MACHINE_CPU} == "vax" || ${MACHINE_ARCH} == "m68000"
    189      1.36     pooka CPPFLAGS+=	-I${RUMPTOP}/../../common/lib/libc/atomic
    190      1.36     pooka SRCS+=		atomic_cas_generic.c
    191  1.74.2.3     rmind #SRCS+=		rump_atomic_cas_up.c
    192      1.36     pooka .endif
    193      1.36     pooka 
    194       1.1     pooka .include <bsd.lib.mk>
    195       1.1     pooka .include <bsd.klinks.mk>
    196