Makefile.mdset revision 1.36
11.36Smlelstv#	$NetBSD: Makefile.mdset,v 1.36 2013/01/13 14:43:23 mlelstv Exp $
21.1Slukem#
31.22Slukem# Makefile snippet to ${TOOL_MDSETIMAGE} file system images into kernels
41.1Slukem#
51.1Slukem
61.1Slukem#
71.1Slukem# Required variables:
81.10Slukem#	NETBSDSRCDIR	Top level of src tree (set by <bsd.own.mk>)
91.22Slukem#	MDSETTARGETS	List of images to ${TOOL_MDSETIMAGE} into kernels,
101.7Slukem#			containing one or more tuples of the form:
111.4Slukem#				KERNEL	IMAGE	FILENAME
121.7Slukem#
131.22Slukem#			The kernel is ${TOOL_MDSETIMAGE} with ${IMAGE},
141.13Slukem#			${STRIP}ped (after the symbols are stored in
151.7Slukem#			${FILENAME}.symbols.gz), and gzipped into
161.7Slukem#			${FILENAME}.gz.
171.7Slukem#
181.20Slukem#			If KERNEL does not contain a `/', use
191.20Slukem#			${KERNOBJDIR}/KERNEL/netbsd as the kernel.
201.20Slukem#
211.18Slukem#			If FILENAME is "-", use "netbsd-${KERNEL}" as
221.20Slukem#			the target name.  This may not be a sensible
231.20Slukem#			name if KERNEL contains a `/'.
241.1Slukem#
251.1Slukem# Optional variables:
261.11Slukem#	MDSET_RELEASEDIR		Where to install release kernels.
271.7Slukem#
281.27Slukem#	MDSET_NOGZIP			If defined, don't gzip any kernels.
291.27Slukem#
301.27Slukem#	MDSET_NOGZIP.${FILENAME}	If defined, don't gzip ${FILENAME}
311.27Slukem#
321.35Sjym#	MDSET_NOIMAGE.${FILENAME}	If defined, don't add ${IMAGE} to
331.35Sjym#					${FILENAME}
341.35Sjym#
351.23Slukem#	MDSET_NOSTRIP			If defined, don't strip any kernels.
361.23Slukem#
371.16Slukem#	MDSET_NOSTRIP.${FILENAME}	If defined, don't strip ${FILENAME}
381.16Slukem#
391.23Slukem#	MDSET_NOSYMBOLS			If defined, don't generate *.symbols.gz
401.23Slukem#
411.15Slukem#	MDSET_NOSYMBOLS.${FILENAME}	If defined, don't generate
421.13Slukem#					${FILENAME}.symbols.gz
431.13Slukem#
441.27Slukem#	MDSET_POST			For each kernel,
451.27Slukem#					execute this after ${NM} / ${STRIP}.
461.27Slukem#					Kernel is available as "${.TARGET}"
471.27Slukem#
481.15Slukem#	MDSET_POST.${FILENAME}		For each kernel named ${FILENAME},
491.6Slukem#					execute this after ${NM} / ${STRIP}.
501.15Slukem#					Kernel is available as "${.TARGET}"
511.15Slukem#
521.15Slukem#	MDSET_SUFFIXES.${FILENAME}	List of extra install kernel suffixes
531.15Slukem#					and build commands to create from
541.15Slukem#					${FILENAME} after its created by
551.22Slukem#					${TOOL_MDSETIMAGE} ; ${NM} ; ${STRIP}:
561.15Slukem#						SUFFIX	COMMANDVAR
571.15Slukem#					"${.TARGET}" is "${FILENAME}.${SUFFIX}"
581.15Slukem#					COMMANDVAR is the name of the variable
591.15Slukem#					containing the command to build
601.15Slukem#					${.TARGET}.
611.3Slukem#
621.3Slukem# Variables modified by this:
631.4Slukem#	KERNELS			List of kernel .gz files to build
641.13Slukem#	KERNELSYMS		List of kernel .symbol.gz files to build
651.1Slukem#
661.1Slukem
671.21Slukem.if !defined(_MAKEFILE_MDSET_)
681.21Slukem_MAKEFILE_MDSET_=1
691.21Slukem
701.1Slukem.include <bsd.kernobj.mk>
711.1Slukem
721.36SmlelstvALL_KERNELS?= "+"
731.6Slukem.for _K _I _F in ${MDSETTARGETS}			# {
741.36Smlelstv.for currentsel in ${ALL_KERNELS}			# {
751.36Smlelstv.if ${currentsel} == "+" || ${_K} == ${currentsel}
761.20Slukem
771.20Slukem_KERNEL:=${_K}			# (work around obscure issue in make(1))
781.20Slukem.if (${_KERNEL:M*/*} != "")
791.20Slukem_KERNNAME.${_K}.${_F}:=	${_K}
801.20Slukem.else
811.20Slukem_KERNNAME.${_K}.${_F}:=	${KERNOBJDIR}/${_K}/netbsd
821.20Slukem.endif
831.20Slukem
841.20Slukem_FILENAME:=${_F}		# (work around obscure issue in make(1))
851.6Slukem.if ${_FILENAME} == "-"
861.18Slukem_KERNEL.${_K}.${_F}:=	netbsd-${_K}
871.28Sbouyer_FILENAME:=		${_KERNEL.${_K}.${_F}}
881.4Slukem.else
891.17Slukem_KERNEL.${_K}.${_F}:=	${_F}
901.4Slukem.endif
911.1Slukem
921.29She.for _S _C in ${MDSET_SUFFIXES.${_F}}		# {
931.17SlukemCLEANFILES+=	${_KERNEL.${_K}.${_F}}.${_S}
941.15Slukem
951.17Slukem${_KERNEL.${_K}.${_F}}.${_S}: ${_KERNEL.${_K}.${_F}}
961.15Slukem.if defined(${_C})
971.15Slukem	${${_C}}
981.15Slukem.else
991.15Slukem	@echo "No such variable \"${_C}\""
1001.15Slukem	false
1011.15Slukem.endif
1021.15Slukem
1031.27Slukem.if defined(MDSET_NOGZIP.${_FILENAME}) && defined(MDSET_NOGZIP)
1041.27SlukemKERNELS+=	${_KERNEL.${_K}.${_F}}.${_S}
1051.27Slukem.else							# {
1061.27SlukemKERNELS+=	${_KERNEL.${_K}.${_F}}.${_S}.gz
1071.27Slukem
1081.17Slukem${_KERNEL.${_K}.${_F}}.${_S}.gz: ${_KERNEL.${_K}.${_F}}.${_S}
1091.25Slukem	${_MKTARGET_CREATE}
1101.15Slukem	-rm -f ${.TARGET}
1111.34Sperry	gzip -9nc ${.ALLSRC} > ${.TARGET}
1121.27Slukem.endif							# }
1131.15Slukem
1141.15Slukem.endfor							# }
1151.15Slukem
1161.23Slukem.if !defined(MDSET_NOSYMBOLS.${_FILENAME}) && !defined(MDSET_NOSYMBOLS)
1171.17SlukemKERNELSYMS+=	${_KERNEL.${_K}.${_F}}.symbols.gz
1181.13Slukem.endif
1191.1Slukem
1201.30Schris.if defined(MDSET_POST.${_FILENAME})
1211.30Schris_POST.${_KERNEL.${_K}.${_F}}:= ${MDSET_POST.${_FILENAME}}
1221.30Schris.elif defined(MDSET_POST)
1231.30Schris_POST.${_KERNEL.${_K}.${_F}}:= ${MDSET_POST}
1241.6Slukem.endif
1251.6Slukem
1261.27Slukem
1271.27SlukemCLEANFILES+=	${_KERNEL.${_K}.${_F}}
1281.27Slukem
1291.31Sad.if defined(MDSET_NOIMAGE.${_FILENAME})
1301.31Sad${_I}=
1311.31Sad.endif
1321.31Sad
1331.33Sagc# Darwin requires a special hack - this is documented in
1341.33Sagc# doc/HACKS, and just works around the problems described more
1351.33Sagc# fully in http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html
1361.33SagcOPSYS!= uname -s
1371.33Sagc.if ${OPSYS} == "Darwin"
1381.33SagcMDSETIMAGEFLAGS=
1391.33Sagc.else
1401.33SagcMDSETIMAGEFLAGS=-v
1411.33Sagc.endif
1421.33Sagc
1431.20Slukem${_KERNEL.${_K}.${_F}}: .NOTMAIN ${_KERNNAME.${_K}.${_F}} ${_I}
1441.25Slukem	${_MKTARGET_CREATE} "(from: ${.ALLSRC})"
1451.24Sdsl	@rm -f ${.TARGET} ${.TARGET}.tmp ${.TARGET}.symbols.gz
1461.24Sdsl	@cp ${_KERNNAME.${_K}.${_F}} ${.TARGET}.tmp
1471.31Sad.if !defined(MDSET_NOIMAGE.${_FILENAME})
1481.33Sagc	${TOOL_MDSETIMAGE} ${MDSETIMAGEFLAGS} ${.TARGET}.tmp ${_I}
1491.31Sad.endif
1501.23Slukem.if !defined(MDSET_NOSYMBOLS.${_FILENAME}) && !defined(MDSET_NOSYMBOLS)
1511.34Sperry	${NM} ${.TARGET}.tmp | gzip -9n > ${.TARGET}.symbols.gz
1521.1Slukem.endif
1531.23Slukem.if !defined(MDSET_NOSTRIP.${_FILENAME}) && !defined(MDSET_NOSTRIP)
1541.26Sdsl	${STRIP} -R .comment -R .ident ${.TARGET}.tmp
1551.16Slukem.endif
1561.24Sdsl	@mv ${.TARGET}.tmp ${.TARGET}
1571.27Slukem.if defined(MDSET_POST.${_FILENAME}) || defined(MDSET_POST)
1581.15Slukem	${_POST.${.TARGET}}
1591.15Slukem.endif
1601.15Slukem
1611.27Slukem.if defined(MDSET_NOGZIP.${_FILENAME}) || defined(MDSET_NOGZIP)
1621.27SlukemKERNELS+=	${_KERNEL.${_K}.${_F}}
1631.27Slukem.else							# {
1641.27SlukemKERNELS+=	${_KERNEL.${_K}.${_F}}.gz
1651.27Slukem
1661.17Slukem${_KERNEL.${_K}.${_F}}.gz: ${_KERNEL.${_K}.${_F}}
1671.25Slukem	${_MKTARGET_CREATE}
1681.15Slukem	-rm -f ${.TARGET}
1691.34Sperry	gzip -9nc ${.ALLSRC} > ${.TARGET}
1701.27Slukem.endif							# }
1711.1Slukem
1721.36Smlelstv.endif
1731.36Smlelstv.endfor							# }
1741.1Slukem.endfor							# }
1751.1Slukem
1761.12SlukemCLEANFILES+=	${KERNELS} ${KERNELSYMS}
1771.1Slukem
1781.12Slukemrealall: ${KERNELS}
1791.1Slukem
1801.11Slukem.if defined(MDSET_RELEASEDIR)
1811.14Slukemrelease:: check_RELEASEDIR .WAIT ${KERNELS}
1821.36Smlelstv	test -z "${KERNELS}" || \
1831.11Slukem	${RELEASE_INSTALL} ${KERNELS} ${KERNELSYMS} \
1841.32Smatt	    ${RELEASEDIR}/${RELEASEMACHINEDIR}/${MDSET_RELEASEDIR}
1851.1Slukem.endif
1861.21Slukem
1871.21Slukem
1881.21Slukem.endif	# _MAKEFILE_MDSET_
189