Makefile.rump revision 1.42
1#	$NetBSD: Makefile.rump,v 1.42 2009/11/17 16:17:06 pooka Exp $
2#
3
4WARNS?=		3	# XXX: src/sys won't compile with -Wsign-compare yet
5NOLINT=		# kernel code
6
7.include <bsd.own.mk>
8
9# use kernel ABI instead of rump ABI (needs md code)
10.ifndef RUMPKMOD
11CPPFLAGS:=	-I${RUMPTOP}/include ${CPPFLAGS}
12.endif
13
14CFLAGS+=	-ffreestanding -fno-strict-aliasing
15CWARNFLAGS+=	-Wno-format-zero-length
16CPPFLAGS+=	-D_RUMPKERNEL
17CPPFLAGS+=	-D_KERNEL -DMULTIPROCESSOR -D_MODULE -DMODULAR
18CPPFLAGS+=	-DMAXUSERS=32
19CPPFLAGS+=	-DDIAGNOSTIC
20CPPFLAGS+=	-DCOMPAT_50
21CPPFLAGS+=	-DDEBUGPRINT
22CPPFLAGS+=	-I${.CURDIR} -I.
23CPPFLAGS+=	-I${RUMPTOP}/../../common/include -I${RUMPTOP}/../arch
24CPPFLAGS+=	-I${RUMPTOP}/include
25CPPFLAGS+=	-I${RUMPTOP}/librump/rumpkern/opt
26CPPFLAGS+=	-nostdinc -I${RUMPTOP}/..
27#CPPFLAGS+=	-DDEBUG
28
29# kernel libs should not get linked against libc
30LDFLAGS+=	-nodefaultlibs
31
32# make sure __NetBSD__ gets defined (for builds on non-NetBSD)
33CPPFLAGS+=	-D__NetBSD__
34
35RUMPKERNEL=	This is NetBSD and I am the rump.  Good evening.
36
37# workaround: evbppc is not a well-defined arch
38.if (${MACHINE} == "evbppc")
39CPPFLAGS+=	-DPPC_OEA
40.endif
41
42# If this file changes, we need a full rebuild
43DPSRCS+=	${RUMPTOP}/Makefile.rump
44
45.ifdef RUMP_ISMODULE
46.PATH:		${RUMPTOP}/librump
47SRCS+=		rump_module.c
48.endif
49.ifdef RUMP_ISDOMAIN
50.PATH:		${RUMPTOP}/librump
51SRCS+=		rump_domain.c
52.endif
53
54#
55# Rename library symbols before use.  If a symbol does not already belong
56# to a rump namespace ("rump" or "RUMP"), prefix it with "rumpns".  This
57# avoids accidentally linking any kernel symbol against host platform
58# libraries.  The only non-renamed symbols are linkset delimiters and
59# the GOT, which are more a property of the compiler than the kernel.
60#
61# Some toolchains generate unresolved symbols which are supposed to be
62# satisfied by the toolchain itself when the program is linked.
63# Unfortunately, we do not know which of the symbols are generated by
64# the toolchain.  Worse, they vary from platform to platform and
65# toolchain to toolchain.  The good news, however, is that this will
66# be detected by a compile-time failure, so we can fairly easily manage
67# a quirktable here.
68.if ${MACHINE_CPU} == "mips"
69_SYMQUIRK='|_gp_disp'
70.elif ${MACHINE_CPU} == "hppa"
71_SYMQUIRK='|\$$\$$'
72.endif
73__archivebuild: .USE
74	${_MKTARGET_BUILD}
75	rm -f ${.TARGET}
76	${AR} ${_ARFL} ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`
77	${NM} -go ${.TARGET} | ${TOOL_AWK} '	\
78	    $$NF!~/^(rump|RUMP|__|_GLOBAL_OFFSET_TABLE'${_SYMQUIRK}')/ \
79	      {printf "%s rumpns_%s\n", $$NF, $$NF}' \
80	    | sort | uniq  > renametab.${.TARGET}
81	${OBJCOPY} --preserve-dates --redefine-syms \
82	    renametab.${.TARGET} ${.TARGET}
83	rm -f renametab.${.TARGET}
84	${AR} ${_ARRANFL} ${.TARGET}
85