Makefile.rump revision 1.128
11.128Skamil# $NetBSD: Makefile.rump,v 1.128 2020/05/29 00:05:26 kamil 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.90Spooka.else 171.90Spooka_RUMP_NATIVEABI= no 181.18SpookaCPPFLAGS:= -I${RUMPTOP}/include ${CPPFLAGS} 191.92SpookaCPPFLAGS+= -D_RUMPKERNEL -I${RUMPTOP}/librump/rumpkern 201.18Spooka.endif 211.18Spooka 221.124Schristos# We are compiling the kernel code with no-delete-null-pointer-checks, 231.124Schristos# and compiling without it, causes issues at least on sh3 by adding 241.124Schristos# aborts after kern_assert on NULL pointer checks. 251.127SkamilCFLAGS+= ${${ACTIVE_CC} == "gcc":? -fno-delete-null-pointer-checks :} 261.124Schristos 271.128Skamil# NULL + 0 arithmetic raises LLVM UBSan warnings, specially in sys/pslist.h 281.128Skamil# in the type-safe macros _PSLIST_VALIDATE_PTRS and _PSLIST_VALIDATE_CONTAINER. 291.128Skamil.if ${MKSANITIZER:Uno} == "yes" || ${MKLIBCSANITIZER:Uno} == "yes" 301.128SkamilCFLAGS+= ${${ACTIVE_CC} == "clang":? -fno-delete-null-pointer-checks :} 311.128Skamil.endif 321.128Skamil 331.99Salnsn# Define baseline cpu for mips ports, required for 341.99Salnsn# rumpcomp_sync_icache() hypercall. 351.99Salnsn.if !empty(MACHINE_ARCH:Mmips*) 361.99Salnsn.if !empty(MACHINE_ARCH:Mmips64*) 371.99SalnsnCPPFLAGS+= -DMIPS64=1 381.99Salnsn.else 391.99SalnsnCPPFLAGS+= -DMIPS1=1 401.99Salnsn.endif 411.99Salnsn.endif 421.99Salnsn 431.112Spooka# which NetBSD compat to build 441.113SpookaRUMP_NBCOMPAT?=default 451.113Spooka.if ${RUMP_NBCOMPAT} == "all" || ${RUMP_NBCOMPAT} == "default" 461.123SmrgRUMP_NBCOMPAT= 50 60 70 80 471.112Spooka.endif 481.112Spooka.if ${RUMP_NBCOMPAT} == "none" 491.112SpookaRUMP_NBCOMPAT= 501.112Spooka.endif 511.110SpookaRUMP_NBCOMPAT:= ${RUMP_NBCOMPAT:S/,/ /g} 521.110SpookaCPPFLAGS+= ${RUMP_NBCOMPAT:C/[1-9]0/-DCOMPAT_&/g} 531.104Spooka 541.66SpookaCPPFLAGS+= -nostdinc 551.22SpookaCFLAGS+= -ffreestanding -fno-strict-aliasing 561.66Spooka 571.50SpookaCWARNFLAGS+= -Wno-format-zero-length -Wno-pointer-sign 581.114Spooka 591.114SpookaCPPFLAGS+= -imacros ${RUMPTOP}/include/opt/opt_rumpkernel.h 601.115Spooka.ifdef BUILDRUMP_IMACROS 611.115SpookaCPPFLAGS+= -imacros ${BUILDRUMP_IMACROS} 621.115Spooka.endif 631.114Spooka 641.15SpookaCPPFLAGS+= -I${.CURDIR} -I. 651.65SpookaCPPFLAGS+= -I${RUMPTOP}/../../common/include 661.18SpookaCPPFLAGS+= -I${RUMPTOP}/include 671.117SpookaCPPFLAGS+= -I${RUMPTOP}/include/opt 681.65Spooka 691.103SpookaSHLIB_MAJOR?= 0 701.103SpookaSHLIB_MINOR?= 0 711.103Spooka 721.65Spooka.ifdef NEED_ISYSTEM 731.65SpookaCPPFLAGS+= -isystem ${RUMPTOP}/../arch 741.65SpookaCPPFLAGS+= -isystem ${RUMPTOP}/.. 751.65Spooka.else 761.65SpookaCPPFLAGS+= -I${RUMPTOP}/../arch 771.65SpookaCPPFLAGS+= -I${RUMPTOP}/.. 781.65Spooka.endif 791.65Spooka 801.93SpookaRUMP_LDSCRIPT?= GNU 811.79Spooka.if ${RUMP_LDSCRIPT} != "no" 821.72Spooka# my ld or yours? 831.97Spooka.if ${RUMP_LDSCRIPT} == "sun" 841.72SpookaLDFLAGS+= -Wl,-M ${RUMPTOP}/ldscript_sun.rump 851.72SpookaSRCS+= linksyms_sun.c 861.74Spooka.PATH: ${RUMPTOP} 871.93Spooka.elif ${RUMP_LDSCRIPT} == "GNU" 881.93SpookaLDFLAGS+= -Wl,-T,${RUMPTOP}/ldscript.rump 891.96Spooka.elif ${RUMP_LDSCRIPT} == "ctor" 901.96SpookaCPPFLAGS+= -DRUMP_USE_CTOR 911.72Spooka.else 921.93Spooka.error Unknown ldscript ${RUMP_LDSCRIPT} 931.73Spooka.endif 941.79Spooka.endif 951.62Spooka 961.94Spooka.if defined(RUMP_CURLWP) 971.94Spooka.if ${RUMP_CURLWP} == "hypercall" 981.94SpookaCPPFLAGS+= -DRUMP_CURLWP=RUMP_CURLWP_HYPERCALL 991.94Spooka.elif ${RUMP_CURLWP} == "__thread" 1001.94SpookaCPPFLAGS+= -DRUMP_CURLWP=RUMP_CURLWP___THREAD 1011.94Spooka.elif ${RUMP_CURLWP} == "register" 1021.94SpookaCPPFLAGS+= -DRUMP_CURLWP=RUMP_CURLWP_REGISTER 1031.94Spooka.else 1041.94Spooka.error Unsupported curlwp scheme: ${RUMP_CURLWP} 1051.94Spooka.endif 1061.94Spooka.endif 1071.94Spooka 1081.62SpookaRUMP_DIAGNOSTIC?=yes 1091.62Spooka.if ${RUMP_DIAGNOSTIC} == "yes" 1101.62SpookaCPPFLAGS+= -DDIAGNOSTIC 1111.62Spooka.endif 1121.62Spooka 1131.62Spooka.ifdef RUMP_DEBUG 1141.62SpookaCPPFLAGS+= -DDEBUG 1151.62Spooka.endif 1161.1Spooka 1171.59Spooka.ifdef RUMP_LOCKDEBUG 1181.59SpookaCPPFLAGS+= -DLOCKDEBUG 1191.59Spooka.endif 1201.59Spooka 1211.89SpookaRUMP_KTRACE?=yes 1221.89Spooka.if ${RUMP_KTRACE} == "yes" 1231.89SpookaCPPFLAGS+= -DKTRACE 1241.89Spooka.endif 1251.89Spooka 1261.42Spooka# kernel libs should not get linked against libc 1271.43Spooka# XXX: actually, we would like to enable this but cannot, since it 1281.43Spooka# also leaves out libgcc, it causes problems on some platforms. 1291.43Spooka# revisit some day. 1301.43Spooka#LDFLAGS+= -nodefaultlibs 1311.42Spooka 1321.39Spooka# make sure __NetBSD__ gets defined (for builds on non-NetBSD) 1331.67Spooka# also, give those builds a way to undef the local compiler's macros 1341.114SpookaCPPFLAGS+= ${RUMPKERN_UNDEF} 1351.39Spooka 1361.11SpookaRUMPKERNEL= This is NetBSD and I am the rump. Good evening. 1371.11Spooka 1381.13Spooka# workaround: evbppc is not a well-defined arch 1391.13Spooka.if (${MACHINE} == "evbppc") 1401.16SpookaCPPFLAGS+= -DPPC_OEA 1411.13Spooka.endif 1421.13Spooka 1431.114Spooka# If any of these files change, we need a full rebuild 1441.25SpookaDPSRCS+= ${RUMPTOP}/Makefile.rump 1451.24Spooka 1461.24Spooka# 1471.69Spooka# Support for component-specific hypercalls 1481.69Spooka# 1491.69Spooka 1501.101Spooka# no easy way to get WARNS out of bsd.sys.mk 1511.102SpookaRUMPCOMP_USER_WARNFLAGS= -Wall -Wextra -Wno-unused-parameter 1521.102SpookaRUMPCOMP_USER_WARNFLAGS+= -Wstrict-prototypes -Wmissing-prototypes 1531.75Schristos 1541.91Spooka.ifdef RUMPCOMP_USER_SRCS && !defined(RUMPKERN_ONLY) 1551.75Schristos.if empty(DESTDIR) 1561.75SchristosDESTDIR=/ 1571.75Schristos.endif 1581.75SchristosBUILDRUMP_CPPFLAGS ?= -isysroot ${DESTDIR} 1591.82SpookaRUMPCOMP_USER_WERROR = ${${_NOWERROR} == "no" :?-Werror:} 1601.91Spooka.for rcusrc in ${RUMPCOMP_USER_SRCS:R} 1611.91Spooka${rcusrc}.d: ${rcusrc}.c 1621.69Spooka ${_MKTARGET_CREATE} 1631.122Sjoerg ${MKDEP} -f ${.TARGET} -- ${MKDEPFLAGS} ${CPUFLAGS} ${REPROFLAGS} ${BUILDRUMP_CPPFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${.ALLSRC:O:u:M*${rcusrc}.c} 1641.69Spooka 1651.91Spooka${rcusrc}.o: ${rcusrc}.c 1661.69Spooka ${_MKTARGET_COMPILE} 1671.122Sjoerg ${CC} -o ${.TARGET} ${DBG} ${CWARNFLAGS} ${CPUFLAGS} ${REPROFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c} 1681.69Spooka 1691.91Spooka${rcusrc}.pico: ${rcusrc}.c 1701.69Spooka ${_MKTARGET_COMPILE} 1711.122Sjoerg ${CC} -o ${.TARGET} -fPIC -DPIC ${DBG} ${CWARNFLAGS} ${CPUFLAGS} ${REPROFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c} 1721.69Spooka 1731.91Spooka${rcusrc}.po: ${rcusrc}.c 1741.69Spooka ${_MKTARGET_COMPILE} 1751.122Sjoerg ${CC} -o ${.TARGET} ${PROFFLAGS} -pg ${DBG} ${CWARNFLAGS} ${CPUFLAGS} ${REPROFLAGS} ${RUMPCOMP_USER_WERROR} ${RUMPCOMP_USER_WARNFLAGS} ${BUILDRUMP_CPPFLAGS} ${BUILDRUMP_CFLAGS} ${RUMPCOMP_USER_CPPFLAGS} ${RUMPCOMP_USER_CFLAGS} -c ${.ALLSRC:O:u:M*${rcusrc}.c} 1761.69Spooka 1771.91SpookaRUMPOBJ_NORENAME+=${rcusrc}.o ${rcusrc}.pico ${rcusrc}.po 1781.91SpookaSRCS+=${rcusrc}.c 1791.91Spooka.endfor 1801.69Spooka.endif 1811.69Spooka 1821.69Spooka# 1831.24Spooka# Rename library symbols before use. If a symbol does not already belong 1841.24Spooka# to a rump namespace ("rump" or "RUMP"), prefix it with "rumpns". This 1851.24Spooka# avoids accidentally linking any kernel symbol against host platform 1861.24Spooka# libraries. The only non-renamed symbols are linkset delimiters and 1871.24Spooka# the GOT, which are more a property of the compiler than the kernel. 1881.24Spooka# 1891.29Spooka# Some toolchains generate unresolved symbols which are supposed to be 1901.29Spooka# satisfied by the toolchain itself when the program is linked. 1911.29Spooka# Unfortunately, we do not know which of the symbols are generated by 1921.29Spooka# the toolchain. Worse, they vary from platform to platform and 1931.29Spooka# toolchain to toolchain. The good news, however, is that this will 1941.29Spooka# be detected by a compile-time failure, so we can fairly easily manage 1951.29Spooka# a quirktable here. 1961.46Spooka# 1971.46Spooka# We also allow calling ourselves externally with e.g.: 1981.46Spooka# make -f /sys/rump/Makefile.rump RUMP_SYMREN=ffs.kobj 1991.46Spooka# 2001.29Spooka.if ${MACHINE_CPU} == "mips" 2011.29Spooka_SYMQUIRK='|_gp_disp' 2021.29Spooka.elif ${MACHINE_CPU} == "hppa" 2031.29Spooka_SYMQUIRK='|\$$\$$' 2041.54Smrg.elif ${MACHINE_ARCH} == "powerpc64" 2051.55Smrg_SYMQUIRK="|PF_funcs" 2061.55Smrg.endif 2071.55Smrg 2081.55Smrg# 2091.55Smrg# Prefix quirks. At least one toolchain generates global 2101.55Smrg# symbols with prefixes which really need to remain as prefixes 2111.55Smrg# (i.e. the '.' on the front of some ppc64 globals). The 2121.55Smrg# way to know if you have the problem is if you get later 2131.55Smrg# complaints about symbols like 'rumpns_XrumpBLAH' or 'XrumpBLAH'; 2141.55Smrg# the 'X' part was added by the toolchain and will need to 2151.55Smrg# be mentioned here. 2161.55Smrg# 2171.55Smrg.if ${MACHINE_ARCH} == "powerpc64" 2181.55Smrg_PQ="\.?" 2191.55Smrg.else 2201.55Smrg_PQ= 2211.29Spooka.endif 2221.46Spooka 2231.46Spookarump_symren: __archivebuild 2241.46Spooka.if !defined(RUMP_SYMREN) 2251.46Spooka @echo "Must supply RUMP_SYMREN for target rump_symren" 2261.46Spooka @false 2271.46Spooka.endif 2281.46Spooka 2291.46Spooka# if we are called from lib build (RUMP_SYMREN is not specified), 2301.46Spooka# build the arrrrchive. otherwise just rename symbols. 2311.24Spooka__archivebuild: .USE 2321.46Spooka.if defined(RUMP_SYMREN) && defined(RUMPTOP) 2331.46Spooka @echo "ERROR: RUMP_SYMREN can only be used standalone" 2341.46Spooka @false 2351.46Spooka.endif 2361.46Spooka.if defined(RUMP_SYMREN) 2371.46Spooka ${_MKMSG} " symbol rename " ${RUMP_SYMREN} 2381.46Spooka.else 2391.24Spooka ${_MKTARGET_BUILD} 2401.24Spooka rm -f ${.TARGET} 2411.46Spooka.endif 2421.91Spooka for renameobj in ${RUMP_SYMREN:U${.ALLSRC:C/(${RUMPOBJ_NORENAME:ts|})//g}}; do \ 2431.91Spooka ${NM} -go $${renameobj} | ${TOOL_AWK} ' \ 2441.125Sjoerg $$NF!~/^'${_PQ}'(rump|RUMP|__|_GLOBAL_OFFSET_TABLE|\.TOC\.'${_SYMQUIRK}'${RUMP_SYM_NORENAME:D|${RUMP_SYM_NORENAME}})/ \ 2451.69Spooka {s=$$NF;sub(/^'${_PQ}'/, "&rumpns_", s); print $$NF, s}'\ 2461.91Spooka | sort | uniq > renametab.$${renameobj}; \ 2471.69Spooka ${OBJCOPY} --preserve-dates --redefine-syms \ 2481.91Spooka renametab.$${renameobj} $${renameobj}; \ 2491.91Spooka rm -f renametab.$${renameobj}; \ 2501.69Spooka done 2511.46Spooka.if !defined(RUMP_SYMREN) 2521.69Spooka ${AR} ${_ARFL} ${.TARGET} \ 2531.69Spooka `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}` 2541.46Spooka.endif 2551.47Spooka 2561.119SpookaCOMMENT?= (no description) 2571.120Spookarumpdescribe: .PHONY 2581.119Spooka @printf '%-24s %s\n' '${LIB}' '${COMMENT}' 2591.119Spooka 2601.53Spooka_BSD_IOCONF_MK_USER_=1 2611.53Spooka.include <bsd.ioconf.mk> 2621.47Spooka 2631.44Spooka.-include "${NETBSDSRCDIR}/sys/arch/${MACHINE_CPU}/include/Makefile.inc" 2641.44Spooka.-include "${NETBSDSRCDIR}/sys/arch/${MACHINE}/include/Makefile.inc" 2651.95Spooka 2661.95Spooka.endif # _RUMP_MK 267