Makefile.rump revision 1.41
1#	$NetBSD: Makefile.rump,v 1.41 2009/09/13 22:51:41 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# make sure __NetBSD__ gets defined (for builds on non-NetBSD)
30CPPFLAGS+=	-D__NetBSD__
31
32RUMPKERNEL=	This is NetBSD and I am the rump.  Good evening.
33
34# workaround: evbppc is not a well-defined arch
35.if (${MACHINE} == "evbppc")
36CPPFLAGS+=	-DPPC_OEA
37.endif
38
39# If this file changes, we need a full rebuild
40DPSRCS+=	${RUMPTOP}/Makefile.rump
41
42.ifdef RUMP_ISMODULE
43.PATH:		${RUMPTOP}/librump
44SRCS+=		rump_module.c
45.endif
46.ifdef RUMP_ISDOMAIN
47.PATH:		${RUMPTOP}/librump
48SRCS+=		rump_domain.c
49.endif
50
51#
52# Rename library symbols before use.  If a symbol does not already belong
53# to a rump namespace ("rump" or "RUMP"), prefix it with "rumpns".  This
54# avoids accidentally linking any kernel symbol against host platform
55# libraries.  The only non-renamed symbols are linkset delimiters and
56# the GOT, which are more a property of the compiler than the kernel.
57#
58# Some toolchains generate unresolved symbols which are supposed to be
59# satisfied by the toolchain itself when the program is linked.
60# Unfortunately, we do not know which of the symbols are generated by
61# the toolchain.  Worse, they vary from platform to platform and
62# toolchain to toolchain.  The good news, however, is that this will
63# be detected by a compile-time failure, so we can fairly easily manage
64# a quirktable here.
65.if ${MACHINE_CPU} == "mips"
66_SYMQUIRK='|_gp_disp'
67.elif ${MACHINE_CPU} == "hppa"
68_SYMQUIRK='|\$$\$$'
69.endif
70__archivebuild: .USE
71	${_MKTARGET_BUILD}
72	rm -f ${.TARGET}
73	${AR} ${_ARFL} ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`
74	${NM} -go ${.TARGET} | ${TOOL_AWK} '	\
75	    $$NF!~/^(rump|RUMP|__|_GLOBAL_OFFSET_TABLE'${_SYMQUIRK}')/ \
76	      {printf "%s rumpns_%s\n", $$NF, $$NF}' \
77	    | sort | uniq  > renametab.${.TARGET}
78	${OBJCOPY} --preserve-dates --redefine-syms \
79	    renametab.${.TARGET} ${.TARGET}
80	rm -f renametab.${.TARGET}
81	${AR} ${_ARRANFL} ${.TARGET}
82