Home | History | Annotate | Line # | Download | only in mk
bsd.kmodule.mk revision 1.30
      1  1.30      mrg #	$NetBSD: bsd.kmodule.mk,v 1.30 2011/06/20 07:44:00 mrg 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.30      mrg .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