aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBryan Drewery <bdrewery@FreeBSD.org>2016-05-26 23:20:01 +0000
committerBryan Drewery <bdrewery@FreeBSD.org>2016-05-26 23:20:01 +0000
commit016448a507cd2381f34b4cb7f7de42487b79dc6d (patch)
tree702a58f47759a8286170f410407c6e9af4447a8b
parent2d86a958e239b646c95dc74e80a7d7b649656a7b (diff)
downloadsrc-016448a507cd2381f34b4cb7f7de42487b79dc6d.tar.gz
src-016448a507cd2381f34b4cb7f7de42487b79dc6d.zip
WITH_META_MODE: Move the kernel support to kern.pre.mk.
This allows using META_MODE directly from the kernel build directory. This also allows removing a hack from the DIRDEPS_BUILD kernel target. Sponsored by: EMC / Isilon Storage Division
Notes
Notes: svn path=/head/; revision=300795
-rw-r--r--Makefile.inc15
-rw-r--r--sys/conf/kern.pre.mk5
-rw-r--r--targets/pseudo/kernel/Makefile4
3 files changed, 6 insertions, 8 deletions
diff --git a/Makefile.inc1 b/Makefile.inc1
index 770773daf62d..2a32e364cf04 100644
--- a/Makefile.inc1
+++ b/Makefile.inc1
@@ -591,11 +591,6 @@ IMAKE_MTREE= MTREE_CMD="mtree ${MTREEFLAGS}"
# kernel stage
KMAKEENV= ${WMAKEENV}
KMAKE= ${KMAKEENV} ${MAKE} ${.MAKEFLAGS} ${KERNEL_FLAGS} KERNEL=${INSTKERNNAME}
-.if ${MK_META_MODE} == "yes"
-# meta mode normally is disallowed when building from curdir==objdir, but we
-# want to allow it for the kernel build.
-KMAKEENV+= META_MODE="${.MAKE.MODE} curdirOk=yes"
-.endif
#
# buildworld
diff --git a/sys/conf/kern.pre.mk b/sys/conf/kern.pre.mk
index 591c988004c1..d5781dba6ddd 100644
--- a/sys/conf/kern.pre.mk
+++ b/sys/conf/kern.pre.mk
@@ -19,6 +19,11 @@ _srcconf_included_:
.include <bsd.compiler.mk>
.include "kern.opts.mk"
+# The kernel build always occurs in the object directory which is .CURDIR.
+.if ${.MAKE.MODE:Unormal:Mmeta}
+.MAKE.MODE+= curdirOk=yes
+.endif
+
# Can be overridden by makeoptions or /etc/make.conf
KERNEL_KO?= kernel
KERNEL?= kernel
diff --git a/targets/pseudo/kernel/Makefile b/targets/pseudo/kernel/Makefile
index 8783d358750e..e135b22e01cf 100644
--- a/targets/pseudo/kernel/Makefile
+++ b/targets/pseudo/kernel/Makefile
@@ -15,10 +15,8 @@ ${KERNCONF}.config: .MAKE ${META_DEPS}
(cd ${KERN_CONFDIR} && \
${CONFIG} ${CONFIGARGS} -d ${KERN_OBJDIR} ${KERNCONF})
-# we need to pass curdirOk=yes to meta mode, since we want .meta files
-# in ${KERN_OBJDIR}
${KERNCONF}.build: .MAKE ${KERNCONF}.config
- (cd ${KERN_OBJDIR} && META_MODE="${.MAKE.MODE} curdirOk=yes" ${.MAKE})
+ (cd ${KERN_OBJDIR} && ${.MAKE})
.if ${.MAKE.LEVEL} > 0
all: ${KERNCONF}.build