121 lines
3.3 KiB
Makefile
121 lines
3.3 KiB
Makefile
# $NetBSD: bsd.kmodule.mk,v 1.24 2010/01/18 23:39:07 jmmv Exp $
|
|
|
|
# We are not building this with PIE
|
|
MKPIE=no
|
|
|
|
.include <bsd.init.mk>
|
|
.include <bsd.klinks.mk>
|
|
.include <bsd.sys.mk>
|
|
|
|
##### Basic targets
|
|
clean: cleankmod
|
|
realinstall: kmodinstall
|
|
|
|
KERN= $S/kern
|
|
|
|
CFLAGS+= -ffreestanding ${COPTS}
|
|
CPPFLAGS+= -nostdinc -I. -I${.CURDIR} -isystem $S -isystem $S/arch
|
|
CPPFLAGS+= -isystem ${S}/../common/include
|
|
CPPFLAGS+= -D_KERNEL -D_LKM -D_MODULE
|
|
|
|
# XXX until the kernel is fixed again...
|
|
.if (defined(HAVE_GCC) && ${HAVE_GCC} == 4) || defined(HAVE_PCC)
|
|
CFLAGS+= -fno-strict-aliasing -Wno-pointer-sign
|
|
.endif
|
|
|
|
# XXX This is a workaround for platforms that have relative relocations
|
|
# that, when relocated by the module loader, result in addresses that
|
|
# overflow the size of the relocation (e.g. R_PPC_REL24 in powerpc).
|
|
# The real solution to this involves generating trampolines for those
|
|
# relocations inside the loader and removing this workaround, as the
|
|
# resulting code would be much faster.
|
|
.if ${MACHINE_CPU} == "arm"
|
|
CFLAGS+= -mlong-calls
|
|
.elif ${MACHINE_CPU} == "powerpc"
|
|
CFLAGS+= -mlongcall
|
|
.endif
|
|
|
|
_YKMSRCS= ${SRCS:M*.[ly]:C/\..$/.c/} ${YHEADER:D${SRCS:M*.y:.y=.h}}
|
|
DPSRCS+= ${_YKMSRCS}
|
|
CLEANFILES+= ${_YKMSRCS}
|
|
|
|
.if exists($S/../sys/modules/xldscripts/kmodule)
|
|
KMODSCRIPT= $S/../sys/modules/xldscripts/kmodule
|
|
.else
|
|
KMODSCRIPT= ${DESTDIR}/usr/libdata/ldscripts/kmodule
|
|
.endif
|
|
|
|
OBJS+= ${SRCS:N*.h:N*.sh:R:S/$/.o/g}
|
|
PROG?= ${KMOD}.kmod
|
|
|
|
##### Build rules
|
|
realall: ${PROG}
|
|
|
|
${OBJS} ${LOBJS}: ${DPSRCS}
|
|
|
|
${PROG}: ${OBJS} ${DPADD}
|
|
${_MKTARGET_LINK}
|
|
${CC} ${LDFLAGS} -nostdlib -r -Wl,-T,${KMODSCRIPT},-d \
|
|
-o ${.TARGET} ${OBJS}
|
|
|
|
##### Install rules
|
|
.if !target(kmodinstall)
|
|
.if !defined(KMODULEDIR)
|
|
_OSRELEASE!= ${HOST_SH} $S/conf/osrelease.sh
|
|
# Ensure these are recorded properly in METALOG on unprived installes:
|
|
_INST_DIRS= ${DESTDIR}/stand/${MACHINE}
|
|
_INST_DIRS+= ${DESTDIR}/stand/${MACHINE}/${_OSRELEASE}
|
|
_INST_DIRS+= ${DESTDIR}/stand/${MACHINE}/${_OSRELEASE}/modules
|
|
KMODULEDIR= ${DESTDIR}/stand/${MACHINE}/${_OSRELEASE}/modules/${KMOD}
|
|
.endif
|
|
_PROG:= ${KMODULEDIR}/${PROG} # installed path
|
|
|
|
.if ${MKUPDATE} == "no"
|
|
${_PROG}! ${PROG} # install rule
|
|
.if !defined(BUILD) && !make(all) && !make(${PROG})
|
|
${_PROG}! .MADE # no build at install
|
|
.endif
|
|
.else
|
|
${_PROG}: ${PROG} # install rule
|
|
.if !defined(BUILD) && !make(all) && !make(${PROG})
|
|
${_PROG}: .MADE # no build at install
|
|
.endif
|
|
.endif
|
|
${_MKTARGET_INSTALL}
|
|
dirs=${_INST_DIRS:Q}; \
|
|
for d in $$dirs; do \
|
|
${INSTALL_DIR} $$d; \
|
|
done
|
|
${INSTALL_DIR} ${KMODULEDIR}
|
|
${INSTALL_FILE} -o ${KMODULEOWN} -g ${KMODULEGRP} -m ${KMODULEMODE} \
|
|
${.ALLSRC} ${.TARGET}
|
|
|
|
kmodinstall:: ${_PROG}
|
|
.PHONY: kmodinstall
|
|
.PRECIOUS: ${_PROG} # keep if install fails
|
|
|
|
.undef _PROG
|
|
.endif # !target(kmodinstall)
|
|
|
|
##### Clean rules
|
|
cleankmod: .PHONY
|
|
rm -f a.out [Ee]rrs mklog core *.core \
|
|
${PROG} ${OBJS} ${LOBJS} ${CLEANFILES}
|
|
|
|
##### Custom rules
|
|
lint: ${LOBJS}
|
|
.if defined(LOBJS) && !empty(LOBJS)
|
|
${LINT} ${LINTFLAGS} ${LDFLAGS:C/-L[ ]*/-L/Wg:M-L*} ${LOBJS} ${LDADD}
|
|
.endif
|
|
|
|
##### Pull in related .mk logic
|
|
LINKSOWN?= ${KMODULEOWN}
|
|
LINKSGRP?= ${KMODULEGRP}
|
|
LINKSMODE?= ${KMODULEMODE}
|
|
.include <bsd.man.mk>
|
|
.include <bsd.links.mk>
|
|
.include <bsd.dep.mk>
|
|
|
|
.-include "$S/arch/${MACHINE_CPU}/include/Makefile.inc"
|
|
.-include "$S/arch/${MACHINE}/include/Makefile.inc"
|