Makefile.rump revision 1.103
11.103Spooka#	$NetBSD: Makefile.rump,v 1.103 2014/12/02 01:59:10 pooka Exp $
21.1Spooka#
31.1Spooka
41.95Spooka.if !defined(_RUMP_MK)
51.95Spooka_RUMP_MK= #defined
61.95Spooka
71.33SlukemWARNS?=		3	# XXX: src/sys won't compile with -Wsign-compare yet
81.10SpookaNOLINT=		# kernel code
91.1Spooka
101.20Spooka.include <bsd.own.mk>
111.20Spooka
121.90Spooka# Use NetBSD kernel ABI by default on x86 archs.  Performance-related
131.90Spooka# compile-time options may override this at a later date.
141.92Spooka.if (${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64")
151.90Spooka_RUMP_NATIVEABI= yes
161.90SpookaCPPFLAGS+=	-D_RUMP_NATIVE_ABI
171.90Spooka.else
181.90Spooka_RUMP_NATIVEABI= no
191.18SpookaCPPFLAGS:=	-I${RUMPTOP}/include ${CPPFLAGS}
201.92SpookaCPPFLAGS+=	-D_RUMPKERNEL -I${RUMPTOP}/librump/rumpkern
211.18Spooka.endif
221.18Spooka
231.99Salnsn# Define baseline cpu for mips ports, required for
241.99Salnsn# rumpcomp_sync_icache() hypercall.
251.99Salnsn.if !empty(MACHINE_ARCH:Mmips*)
261.99Salnsn.if !empty(MACHINE_ARCH:Mmips64*)
271.99SalnsnCPPFLAGS+=	-DMIPS64=1
281.99Salnsn.else
291.99SalnsnCPPFLAGS+=	-DMIPS1=1
301.99Salnsn.endif
311.99Salnsn.endif
321.99Salnsn
331.66SpookaCPPFLAGS+=	-DMAXUSERS=32
341.84SpookaCPPFLAGS+=	-DCOMPAT_50=1 -DCOMPAT_60=1
351.66Spooka
361.66SpookaCPPFLAGS+=	-nostdinc
371.22SpookaCFLAGS+=	-ffreestanding -fno-strict-aliasing
381.66Spooka
391.50SpookaCWARNFLAGS+=	-Wno-format-zero-length -Wno-pointer-sign
401.23SpookaCPPFLAGS+=	-D_KERNEL -DMULTIPROCESSOR -D_MODULE -DMODULAR
411.38SpookaCPPFLAGS+=	-DDEBUGPRINT
421.15SpookaCPPFLAGS+=	-I${.CURDIR} -I.
431.65SpookaCPPFLAGS+=	-I${RUMPTOP}/../../common/include
441.18SpookaCPPFLAGS+=	-I${RUMPTOP}/include
451.21SpookaCPPFLAGS+=	-I${RUMPTOP}/librump/rumpkern/opt
461.65Spooka
471.103SpookaSHLIB_MAJOR?=	0
481.103SpookaSHLIB_MINOR?=	0
491.103Spooka
501.65Spooka.ifdef NEED_ISYSTEM
511.65SpookaCPPFLAGS+=	-isystem ${RUMPTOP}/../arch
521.65SpookaCPPFLAGS+=	-isystem ${RUMPTOP}/..
531.65Spooka.else
541.65SpookaCPPFLAGS+=	-I${RUMPTOP}/../arch
551.65SpookaCPPFLAGS+=	-I${RUMPTOP}/..
561.65Spooka.endif
571.65Spooka
581.93SpookaRUMP_LDSCRIPT?=	GNU
591.79Spooka.if ${RUMP_LDSCRIPT} != "no"
601.72Spooka# my ld or yours?
611.97Spooka.if ${RUMP_LDSCRIPT} == "sun"
621.72SpookaLDFLAGS+=	-Wl,-M ${RUMPTOP}/ldscript_sun.rump
631.72SpookaSRCS+=		linksyms_sun.c
641.74Spooka.PATH:		${RUMPTOP}
651.93Spooka.elif ${RUMP_LDSCRIPT} == "GNU"
661.93SpookaLDFLAGS+=	-Wl,-T,${RUMPTOP}/ldscript.rump
671.96Spooka.elif ${RUMP_LDSCRIPT} == "ctor"
681.96SpookaCPPFLAGS+=	-DRUMP_USE_CTOR
691.72Spooka.else
701.93Spooka.error Unknown ldscript ${RUMP_LDSCRIPT}
711.73Spooka.endif
721.79Spooka.endif
731.62Spooka
741.94Spooka.if defined(RUMP_CURLWP)
751.94Spooka.if   ${RUMP_CURLWP} == "hypercall"
761.94SpookaCPPFLAGS+=	-DRUMP_CURLWP=RUMP_CURLWP_HYPERCALL
771.94Spooka.elif ${RUMP_CURLWP} == "__thread"
781.94SpookaCPPFLAGS+=	-DRUMP_CURLWP=RUMP_CURLWP___THREAD
791.94Spooka.elif ${RUMP_CURLWP} == "register"
801.94SpookaCPPFLAGS+=	-DRUMP_CURLWP=RUMP_CURLWP_REGISTER
811.94Spooka.else
821.94Spooka.error Unsupported curlwp scheme: ${RUMP_CURLWP}
831.94Spooka.endif
841.94Spooka.endif
851.94Spooka
861.62SpookaRUMP_DIAGNOSTIC?=yes
871.62Spooka.if ${RUMP_DIAGNOSTIC} == "yes"
881.62SpookaCPPFLAGS+=	-DDIAGNOSTIC
891.62Spooka.endif
901.62Spooka
911.62Spooka.ifdef RUMP_DEBUG
921.62SpookaCPPFLAGS+=	-DDEBUG
931.62Spooka.endif
941.1Spooka
951.59Spooka.ifdef RUMP_LOCKDEBUG
961.59SpookaCPPFLAGS+=	-DLOCKDEBUG
971.59Spooka.endif
981.59Spooka
991.89SpookaRUMP_KTRACE?=yes
1001.89Spooka.if ${RUMP_KTRACE} == "yes"
1011.89SpookaCPPFLAGS+=	-DKTRACE
1021.89Spooka.endif
1031.89Spooka
1041.42Spooka# kernel libs should not get linked against libc
1051.43Spooka# XXX: actually, we would like to enable this but cannot, since it
1061.43Spooka# also leaves out libgcc, it causes problems on some platforms.
1071.43Spooka# revisit some day.
1081.43Spooka#LDFLAGS+=	-nodefaultlibs
1091.42Spooka
1101.39Spooka# make sure __NetBSD__ gets defined (for builds on non-NetBSD)
1111.67Spooka# also, give those builds a way to undef the local compiler's macros
1121.67SpookaCPPFLAGS+=	-D__NetBSD__ ${RUMPKERN_UNDEF}
1131.39Spooka
1141.11SpookaRUMPKERNEL=	This is NetBSD and I am the rump.  Good evening.
1151.11Spooka
1161.13Spooka# workaround: evbppc is not a well-defined arch
1171.13Spooka.if (${MACHINE} == "evbppc")
1181.16SpookaCPPFLAGS+=	-DPPC_OEA
1191.13Spooka.endif
1201.13Spooka
1211.25Spooka# If this file changes, we need a full rebuild
1221.25SpookaDPSRCS+=	${RUMPTOP}/Makefile.rump
1231.24Spooka
1241.24Spooka#
1251.69Spooka# Support for component-specific hypercalls
1261.69Spooka#
1271.69Spooka
1281.101Spooka# no easy way to get WARNS out of bsd.sys.mk
1291.102SpookaRUMPCOMP_USER_WARNFLAGS=	-Wall -Wextra -Wno-unused-parameter
1301.102SpookaRUMPCOMP_USER_WARNFLAGS+=	-Wstrict-prototypes -Wmissing-prototypes
1311.75Schristos
1321.91Spooka.ifdef RUMPCOMP_USER_SRCS && !defined(RUMPKERN_ONLY)
1331.75Schristos.if empty(DESTDIR)
1341.75SchristosDESTDIR=/
1351.75Schristos.endif
1361.75SchristosBUILDRUMP_CPPFLAGS ?= -isysroot ${DESTDIR}
1371.82SpookaRUMPCOMP_USER_WERROR = ${${_NOWERROR} == "no" :?-Werror:}
1381.91Spooka.for rcusrc in ${RUMPCOMP_USER_SRCS:R}
1391.91Spooka${rcusrc}.d: ${rcusrc}.c
1401.69Spooka	${_MKTARGET_CREATE}
1411.91Spooka	${MKDEP} -f ${.TARGET} -- ${MKDEPFLAGS} ${BUILDRUMP_CPPFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${.ALLSRC:O:u:M*${rcusrc}.c}
1421.69Spooka
1431.91Spooka${rcusrc}.o: ${rcusrc}.c
1441.69Spooka	${_MKTARGET_COMPILE}
1451.101Spooka	${CC} -o ${.TARGET} ${DBG} ${CWARNFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c}
1461.69Spooka
1471.91Spooka${rcusrc}.pico: ${rcusrc}.c
1481.69Spooka	${_MKTARGET_COMPILE}
1491.101Spooka	${CC} -o ${.TARGET} -fPIC -DPIC ${DBG} ${CWARNFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c}
1501.69Spooka
1511.91Spooka${rcusrc}.po: ${rcusrc}.c
1521.69Spooka	${_MKTARGET_COMPILE}
1531.101Spooka	${CC} -o ${.TARGET} ${PROFFLAGS} -pg ${DBG} ${CWARNFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c}
1541.69Spooka
1551.91SpookaRUMPOBJ_NORENAME+=${rcusrc}.o ${rcusrc}.pico ${rcusrc}.po
1561.91SpookaSRCS+=${rcusrc}.c
1571.91Spooka.endfor
1581.69Spooka.endif
1591.69Spooka
1601.69Spooka#
1611.24Spooka# Rename library symbols before use.  If a symbol does not already belong
1621.24Spooka# to a rump namespace ("rump" or "RUMP"), prefix it with "rumpns".  This
1631.24Spooka# avoids accidentally linking any kernel symbol against host platform
1641.24Spooka# libraries.  The only non-renamed symbols are linkset delimiters and
1651.24Spooka# the GOT, which are more a property of the compiler than the kernel.
1661.24Spooka#
1671.29Spooka# Some toolchains generate unresolved symbols which are supposed to be
1681.29Spooka# satisfied by the toolchain itself when the program is linked.
1691.29Spooka# Unfortunately, we do not know which of the symbols are generated by
1701.29Spooka# the toolchain.  Worse, they vary from platform to platform and
1711.29Spooka# toolchain to toolchain.  The good news, however, is that this will
1721.29Spooka# be detected by a compile-time failure, so we can fairly easily manage
1731.29Spooka# a quirktable here.
1741.46Spooka#
1751.46Spooka# We also allow calling ourselves externally with e.g.:
1761.46Spooka# make -f /sys/rump/Makefile.rump RUMP_SYMREN=ffs.kobj
1771.46Spooka#
1781.29Spooka.if ${MACHINE_CPU} == "mips"
1791.29Spooka_SYMQUIRK='|_gp_disp'
1801.29Spooka.elif ${MACHINE_CPU} == "hppa"
1811.29Spooka_SYMQUIRK='|\$$\$$'
1821.54Smrg.elif ${MACHINE_ARCH} == "powerpc64"
1831.55Smrg_SYMQUIRK="|PF_funcs"
1841.55Smrg.endif
1851.55Smrg
1861.55Smrg#
1871.55Smrg# Prefix quirks.  At least one toolchain generates global
1881.55Smrg# symbols with prefixes which really need to remain as prefixes
1891.55Smrg# (i.e. the '.' on the front of some ppc64 globals).  The
1901.55Smrg# way to know if you have the problem is if you get later
1911.55Smrg# complaints about symbols like 'rumpns_XrumpBLAH' or 'XrumpBLAH';
1921.55Smrg# the 'X' part was added by the toolchain and will need to
1931.55Smrg# be mentioned here.
1941.55Smrg# 
1951.55Smrg.if ${MACHINE_ARCH} == "powerpc64"
1961.55Smrg_PQ="\.?"
1971.55Smrg.else
1981.55Smrg_PQ=
1991.29Spooka.endif
2001.46Spooka
2011.46Spookarump_symren: __archivebuild
2021.46Spooka.if !defined(RUMP_SYMREN)
2031.46Spooka	@echo "Must supply RUMP_SYMREN for target rump_symren"
2041.46Spooka	@false
2051.46Spooka.endif
2061.46Spooka
2071.46Spooka# if we are called from lib build (RUMP_SYMREN is not specified),
2081.46Spooka# build the arrrrchive.  otherwise just rename symbols.
2091.24Spooka__archivebuild: .USE
2101.46Spooka.if defined(RUMP_SYMREN) && defined(RUMPTOP)
2111.46Spooka	@echo "ERROR: RUMP_SYMREN can only be used standalone"
2121.46Spooka	@false
2131.46Spooka.endif
2141.46Spooka.if defined(RUMP_SYMREN)
2151.46Spooka	${_MKMSG} " symbol rename " ${RUMP_SYMREN}
2161.46Spooka.else
2171.24Spooka	${_MKTARGET_BUILD}
2181.24Spooka	rm -f ${.TARGET}
2191.46Spooka.endif
2201.91Spooka	for renameobj in ${RUMP_SYMREN:U${.ALLSRC:C/(${RUMPOBJ_NORENAME:ts|})//g}}; do \
2211.91Spooka		${NM} -go $${renameobj} | ${TOOL_AWK} ' \
2221.98Spooka		    $$NF!~/^'${_PQ}'(rump|RUMP|__|_GLOBAL_OFFSET_TABLE'${_SYMQUIRK}'${RUMP_SYM_NORENAME:D|${RUMP_SYM_NORENAME}})/ \
2231.69Spooka		      {s=$$NF;sub(/^'${_PQ}'/, "&rumpns_", s); print $$NF, s}'\
2241.91Spooka		    | sort | uniq  > renametab.$${renameobj}; \
2251.69Spooka		${OBJCOPY} --preserve-dates --redefine-syms \
2261.91Spooka		    renametab.$${renameobj} $${renameobj}; \
2271.91Spooka		rm -f renametab.$${renameobj}; \
2281.69Spooka	done
2291.46Spooka.if !defined(RUMP_SYMREN)
2301.69Spooka	${AR} ${_ARFL} ${.TARGET} \
2311.69Spooka	    `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`
2321.46Spooka.endif
2331.47Spooka
2341.53Spooka_BSD_IOCONF_MK_USER_=1
2351.53Spooka.include <bsd.ioconf.mk>
2361.47Spooka
2371.44Spooka.-include "${NETBSDSRCDIR}/sys/arch/${MACHINE_CPU}/include/Makefile.inc"
2381.44Spooka.-include "${NETBSDSRCDIR}/sys/arch/${MACHINE}/include/Makefile.inc"
2391.95Spooka
2401.95Spooka.endif # _RUMP_MK
241