Home | History | Annotate | Line # | Download | only in rumpkern
Makefile.rumpkern revision 1.52
      1  1.52  pooka #	$NetBSD: Makefile.rumpkern,v 1.52 2009/10/15 00:28:46 pooka 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.31  pooka 	${RUMPTOP}/../conf					\
     11  1.43  pooka 	${RUMPTOP}/../dev					\
     12  1.50   elad 	${RUMPTOP}/../secmodel/suser
     13   1.1  pooka 
     14  1.11  pooka #
     15  1.14  pooka # Source modules, first the ones specifically implemented for librump.
     16  1.11  pooka # 
     17  1.44  pooka SRCS=	rump.c emul.c intr.c locks.c ltsleep.c percpu.c pool.c	\
     18  1.52  pooka 	scheduler.c sleepq.c sysproxy_socket.c vm.c
     19  1.20  pooka 
     20  1.51  pooka SRCS+=	rumpkern_if_wrappers.c
     21  1.51  pooka 
     22  1.14  pooka # stubs
     23  1.20  pooka #
     24  1.20  pooka SRCS+=	misc_stub.c pmap_stub.c
     25  1.20  pooka 
     26  1.20  pooka # autogenerated
     27  1.20  pooka #
     28  1.20  pooka SRCS+=	rump_syscalls.c
     29   1.1  pooka 
     30  1.11  pooka #
     31  1.11  pooka # Rest are from the std kernel sources.
     32  1.11  pooka #
     33   1.1  pooka # sys/kern
     34  1.48  pooka SRCS+=	init_sysctl_base.c kern_auth.c kern_descrip.c kern_event.c	\
     35  1.48  pooka 	kern_ksyms.c kern_malloc_stdtype.c kern_module.c kern_rate.c	\
     36  1.48  pooka 	kern_stub.c kern_sysctl.c kern_timeout.c kern_uidinfo.c param.c	\
     37  1.46  pooka 	sys_descrip.c sys_generic.c syscalls.c
     38  1.11  pooka 
     39  1.11  pooka # sys/kern subr (misc)
     40  1.49  pooka SRCS+=	subr_devsw.c subr_callback.c subr_evcnt.c subr_extent.c		\
     41  1.49  pooka 	subr_hash.c subr_humanize.c subr_iostat.c subr_kobj.c		\
     42  1.49  pooka 	subr_log.c subr_once.c subr_prf.c subr_specificdata.c		\
     43  1.49  pooka 	subr_time.c subr_workqueue.c
     44  1.11  pooka 
     45  1.43  pooka # 4.4BSD secmodel.  selection is hardcoded for now
     46  1.50   elad SRCS+=	secmodel_suser.c
     47  1.43  pooka 
     48  1.20  pooka # the funny bit.  this doesn't really belong here, but helps with the
     49  1.20  pooka # needs of kern_descrip.c.  And since it's a fully dynamic interface,
     50  1.20  pooka # it doesn't pull in other gunk.
     51  1.20  pooka SRCS+=	vnode_if.c
     52   1.1  pooka 
     53  1.11  pooka # sys/dev
     54  1.11  pooka SRCS+=	clock_subr.c
     55  1.11  pooka 
     56  1.39  pooka # Comment these if you want to use malloc(3) directly instead of
     57  1.39  pooka # the kernel allocators.  It's a few percent faster, but doesn't
     58  1.39  pooka # emulate all kernel corner cases as well.
     59  1.40  pooka #CPPFLAGS+=	-DRUMP_USE_REAL_ALLOCATORS
     60  1.40  pooka #SRCS+=		subr_kmem.c subr_pool.c subr_vmem.c
     61   1.6  pooka 
     62   1.1  pooka # no shlib_version because this is automatically in sync with lib/librump
     63   1.1  pooka SHLIB_MAJOR=    0
     64   1.1  pooka SHLIB_MINOR=    0
     65   1.1  pooka 
     66  1.47  pooka CPPFLAGS+=	-I${RUMPTOP}/librump/rumpkern -I${RUMPTOP}/librump/rumpvfs
     67  1.47  pooka CPPFLAGS+=	-I${RUMPTOP}/librump/rumpnet -I${RUMPTOP}/librump/rumpdev
     68   1.1  pooka CFLAGS+=	-Wno-pointer-sign
     69  1.32  pooka AFLAGS+=	-D_LOCORE -Wa,-fatal-warnings
     70   1.1  pooka 
     71  1.27  pooka #
     72  1.27  pooka # If archdir exists, it is required to provide:
     73  1.27  pooka # 1) kobj_reloc() and kobj_machdep()
     74  1.52  pooka # 2) rump_cpu_bootstrap()
     75  1.52  pooka # 3) ...?
     76  1.52  pooka # 4) PROFIT!
     77  1.27  pooka #
     78  1.30  pooka 
     79  1.30  pooka #
     80  1.34  pooka # Check if we are building compat.  In compat mode we need to provide
     81  1.34  pooka # the kernel of our compat target (amd64->i386 & sparc64->sparc), so
     82  1.34  pooka # take MD stuff from the right arch.
     83  1.30  pooka #
     84  1.38     he .ifdef LD32DIR
     85  1.30  pooka ARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${LD32DIR}
     86  1.31  pooka LIBKERN_ARCH=	${LD32DIR}
     87  1.30  pooka .else
     88  1.24  pooka ARCHDIR=	${RUMPTOP}/librump/rumpkern/arch/${MACHINE_ARCH}
     89  1.30  pooka .endif
     90  1.24  pooka .if exists(${ARCHDIR})
     91  1.24  pooka .include "${ARCHDIR}/Makefile.inc"
     92  1.24  pooka .PATH:	${ARCHDIR}
     93  1.27  pooka .else
     94  1.52  pooka SRCS+=	kobj_stubs.c rumpcpu_generic.c
     95  1.24  pooka .endif
     96  1.24  pooka 
     97  1.31  pooka # include libkern source files
     98  1.31  pooka KERNDIR=${RUMPTOP}/../lib/libkern
     99  1.31  pooka .include "${RUMPTOP}/../lib/libkern/Makefile.libkern"
    100  1.31  pooka 
    101  1.36  pooka # Some architectures require a little special massage with atomic
    102  1.36  pooka # compare-and-swap.  This is because the kernel version is using
    103  1.36  pooka # instructions or routines unavailable to us in userspace.  We
    104  1.36  pooka # use effectively the multiprocessor version of the userspace ops.
    105  1.36  pooka #
    106  1.36  pooka .if ${MACHINE_CPU} == "arm" || ${MACHINE_CPU} == "hppa" \
    107  1.37  pooka     || ${MACHINE_CPU} == "mips" || ${MACHINE_CPU} == "sh3" \
    108  1.37  pooka     || ${MACHINE_CPU} == "vax"
    109  1.36  pooka CPPFLAGS+=	-I${RUMPTOP}/../../common/lib/libc/atomic
    110  1.36  pooka SRCS+=		atomic_cas_generic.c
    111  1.36  pooka .endif
    112  1.36  pooka 
    113   1.1  pooka .include <bsd.lib.mk>
    114   1.1  pooka .include <bsd.klinks.mk>
    115