Home | History | Annotate | Line # | Download | only in mk
bsd.kmodule.mk revision 1.29.2.1
      1  1.29.2.1   cherry #	$NetBSD: bsd.kmodule.mk,v 1.29.2.1 2011/06/23 14:18:46 cherry Exp $
      2      1.14     elad 
      3      1.14     elad # We are not building this with PIE
      4      1.14     elad MKPIE=no
      5       1.1       ad 
      6       1.1       ad .include <bsd.init.mk>
      7       1.1       ad .include <bsd.klinks.mk>
      8       1.7       ad .include <bsd.sys.mk>
      9       1.1       ad 
     10       1.1       ad ##### Basic targets
     11       1.1       ad clean:		cleankmod
     12       1.1       ad realinstall:	kmodinstall
     13       1.1       ad 
     14       1.1       ad KERN=		$S/kern
     15       1.1       ad 
     16       1.6       ad CFLAGS+=	-ffreestanding ${COPTS}
     17       1.1       ad CPPFLAGS+=	-nostdinc -I. -I${.CURDIR} -isystem $S -isystem $S/arch
     18       1.1       ad CPPFLAGS+=	-isystem ${S}/../common/include
     19       1.1       ad CPPFLAGS+=	-D_KERNEL -D_LKM -D_MODULE
     20       1.1       ad 
     21       1.1       ad # XXX until the kernel is fixed again...
     22  1.29.2.1   cherry .if defined(HAVE_GCC) || defined(HAVE_PCC)
     23       1.1       ad CFLAGS+=	-fno-strict-aliasing -Wno-pointer-sign
     24       1.1       ad .endif
     25       1.1       ad 
     26      1.24     jmmv # XXX This is a workaround for platforms that have relative relocations
     27      1.24     jmmv # that, when relocated by the module loader, result in addresses that
     28      1.24     jmmv # overflow the size of the relocation (e.g. R_PPC_REL24 in powerpc).
     29      1.24     jmmv # The real solution to this involves generating trampolines for those
     30      1.24     jmmv # relocations inside the loader and removing this workaround, as the
     31      1.24     jmmv # resulting code would be much faster.
     32      1.24     jmmv .if ${MACHINE_CPU} == "arm"
     33      1.24     jmmv CFLAGS+=	-mlong-calls
     34      1.24     jmmv .elif ${MACHINE_CPU} == "powerpc"
     35      1.24     jmmv CFLAGS+=	-mlongcall
     36      1.24     jmmv .endif
     37      1.24     jmmv 
     38      1.28      mrg # evbppc needs some special help
     39      1.28      mrg .if ${MACHINE} == "evbppc"
     40      1.28      mrg 
     41      1.28      mrg . ifndef PPC_INTR_IMPL
     42      1.28      mrg PPC_INTR_IMPL=\"powerpc/intr.h\"
     43      1.28      mrg . endif
     44      1.28      mrg . ifndef PPC_PCI_MACHDEP_IMPL
     45      1.28      mrg PPC_PCI_MACHDEP_IMPL=\"powerpc/pci_machdep.h\"
     46      1.28      mrg . endif
     47      1.28      mrg CPPFLAGS+=      -DPPC_INTR_IMPL=${PPC_INTR_IMPL}
     48      1.28      mrg CPPFLAGS+=      -DPPC_PCI_MACHDEP_IMPL=${DPPC_PCI_MACHDEP_IMPL}
     49      1.28      mrg 
     50      1.28      mrg . ifdef PPC_IBM4XX
     51      1.28      mrg CPPFLAGS+=      -DPPC_IBM4XX
     52      1.28      mrg . elifdef PPC_BOOKE
     53      1.28      mrg CPPFLAGS+=      -DPPC_BOOKE
     54      1.28      mrg . else
     55      1.28      mrg CPPFLAGS+=      -DPPC_OEA
     56      1.28      mrg . endif
     57      1.28      mrg 
     58      1.28      mrg .endif
     59      1.28      mrg 
     60      1.28      mrg 
     61       1.1       ad _YKMSRCS=	${SRCS:M*.[ly]:C/\..$/.c/} ${YHEADER:D${SRCS:M*.y:.y=.h}}
     62       1.1       ad DPSRCS+=	${_YKMSRCS}
     63       1.1       ad CLEANFILES+=	${_YKMSRCS}
     64       1.7       ad 
     65      1.21    skrll .if exists($S/../sys/modules/xldscripts/kmodule)
     66      1.21    skrll KMODSCRIPT=	$S/../sys/modules/xldscripts/kmodule
     67       1.7       ad .else
     68      1.12      mrg KMODSCRIPT=	${DESTDIR}/usr/libdata/ldscripts/kmodule
     69       1.7       ad .endif
     70       1.1       ad 
     71       1.1       ad OBJS+=		${SRCS:N*.h:N*.sh:R:S/$/.o/g}
     72       1.1       ad PROG?=		${KMOD}.kmod
     73       1.1       ad 
     74       1.1       ad ##### Build rules
     75       1.1       ad realall:	${PROG}
     76       1.1       ad 
     77       1.1       ad ${OBJS} ${LOBJS}: ${DPSRCS}
     78       1.1       ad 
     79       1.1       ad ${PROG}: ${OBJS} ${DPADD}
     80       1.1       ad 	${_MKTARGET_LINK}
     81      1.26   martin 	${CC} ${LDFLAGS} -nostdlib -r -Wl,-T,${KMODSCRIPT},-d \
     82      1.22     matt 		-o ${.TARGET} ${OBJS}
     83       1.1       ad 
     84       1.1       ad ##### Install rules
     85       1.1       ad .if !target(kmodinstall)
     86       1.7       ad .if !defined(KMODULEDIR)
     87       1.7       ad _OSRELEASE!=	${HOST_SH} $S/conf/osrelease.sh
     88       1.9       he # Ensure these are recorded properly in METALOG on unprived installes:
     89      1.28      mrg KMODULEARCHDIR?= ${MACHINE}
     90      1.28      mrg _INST_DIRS=	${DESTDIR}/stand/${KMODULEARCHDIR}
     91      1.28      mrg _INST_DIRS+=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}
     92      1.28      mrg _INST_DIRS+=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}/modules
     93      1.28      mrg KMODULEDIR=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}/modules/${KMOD}
     94      1.10   dyoung .endif
     95      1.10   dyoung _PROG:=		${KMODULEDIR}/${PROG} # installed path
     96       1.1       ad 
     97       1.1       ad .if ${MKUPDATE} == "no"
     98       1.1       ad ${_PROG}! ${PROG}					# install rule
     99       1.1       ad .if !defined(BUILD) && !make(all) && !make(${PROG})
    100       1.1       ad ${_PROG}!	.MADE					# no build at install
    101       1.1       ad .endif
    102       1.1       ad .else
    103       1.1       ad ${_PROG}: ${PROG}					# install rule
    104       1.1       ad .if !defined(BUILD) && !make(all) && !make(${PROG})
    105       1.1       ad ${_PROG}:	.MADE					# no build at install
    106       1.1       ad .endif
    107       1.1       ad .endif
    108       1.1       ad 	${_MKTARGET_INSTALL}
    109      1.16  hubertf 	dirs=${_INST_DIRS:Q}; \
    110      1.16  hubertf 	for d in $$dirs; do \
    111       1.9       he 		${INSTALL_DIR} $$d; \
    112       1.9       he 	done
    113       1.7       ad 	${INSTALL_DIR} ${KMODULEDIR}
    114      1.15       ad 	${INSTALL_FILE} -o ${KMODULEOWN} -g ${KMODULEGRP} -m ${KMODULEMODE} \
    115       1.1       ad 		${.ALLSRC} ${.TARGET}
    116       1.1       ad 
    117       1.1       ad kmodinstall::	${_PROG}
    118       1.1       ad .PHONY:		kmodinstall
    119       1.1       ad .PRECIOUS:	${_PROG}				# keep if install fails
    120       1.1       ad 
    121       1.1       ad .undef _PROG
    122       1.1       ad .endif # !target(kmodinstall)
    123       1.1       ad 
    124       1.1       ad ##### Clean rules
    125       1.1       ad cleankmod: .PHONY
    126       1.1       ad 	rm -f a.out [Ee]rrs mklog core *.core \
    127       1.1       ad 		${PROG} ${OBJS} ${LOBJS} ${CLEANFILES}
    128       1.1       ad 
    129       1.1       ad ##### Custom rules
    130       1.1       ad lint: ${LOBJS}
    131       1.1       ad .if defined(LOBJS) && !empty(LOBJS)
    132       1.1       ad 	${LINT} ${LINTFLAGS} ${LDFLAGS:C/-L[  ]*/-L/Wg:M-L*} ${LOBJS} ${LDADD}
    133       1.1       ad .endif
    134       1.1       ad 
    135       1.1       ad ##### Pull in related .mk logic
    136      1.19      apb LINKSOWN?= ${KMODULEOWN}
    137      1.19      apb LINKSGRP?= ${KMODULEGRP}
    138      1.19      apb LINKSMODE?= ${KMODULEMODE}
    139       1.1       ad .include <bsd.man.mk>
    140       1.1       ad .include <bsd.links.mk>
    141       1.1       ad .include <bsd.dep.mk>
    142       1.1       ad 
    143       1.1       ad .-include "$S/arch/${MACHINE_CPU}/include/Makefile.inc"
    144       1.1       ad .-include "$S/arch/${MACHINE}/include/Makefile.inc"
    145