Home | History | Annotate | Line # | Download | only in mk
bsd.kmodule.mk revision 1.31
      1  1.31     matt #	$NetBSD: bsd.kmodule.mk,v 1.31 2011/07/14 18:12:35 matt 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.31     matt .elif ${MACHINE_CPU} == "vax"
     37  1.31     matt CFLAGS+=	-fno-pic
     38  1.24     jmmv .endif
     39  1.24     jmmv 
     40  1.28      mrg # evbppc needs some special help
     41  1.28      mrg .if ${MACHINE} == "evbppc"
     42  1.28      mrg 
     43  1.28      mrg . ifndef PPC_INTR_IMPL
     44  1.28      mrg PPC_INTR_IMPL=\"powerpc/intr.h\"
     45  1.28      mrg . endif
     46  1.28      mrg . ifndef PPC_PCI_MACHDEP_IMPL
     47  1.28      mrg PPC_PCI_MACHDEP_IMPL=\"powerpc/pci_machdep.h\"
     48  1.28      mrg . endif
     49  1.28      mrg CPPFLAGS+=      -DPPC_INTR_IMPL=${PPC_INTR_IMPL}
     50  1.28      mrg CPPFLAGS+=      -DPPC_PCI_MACHDEP_IMPL=${DPPC_PCI_MACHDEP_IMPL}
     51  1.28      mrg 
     52  1.28      mrg . ifdef PPC_IBM4XX
     53  1.28      mrg CPPFLAGS+=      -DPPC_IBM4XX
     54  1.28      mrg . elifdef PPC_BOOKE
     55  1.28      mrg CPPFLAGS+=      -DPPC_BOOKE
     56  1.28      mrg . else
     57  1.28      mrg CPPFLAGS+=      -DPPC_OEA
     58  1.28      mrg . endif
     59  1.28      mrg 
     60  1.28      mrg .endif
     61  1.28      mrg 
     62  1.28      mrg 
     63   1.1       ad _YKMSRCS=	${SRCS:M*.[ly]:C/\..$/.c/} ${YHEADER:D${SRCS:M*.y:.y=.h}}
     64   1.1       ad DPSRCS+=	${_YKMSRCS}
     65   1.1       ad CLEANFILES+=	${_YKMSRCS}
     66   1.7       ad 
     67  1.21    skrll .if exists($S/../sys/modules/xldscripts/kmodule)
     68  1.21    skrll KMODSCRIPT=	$S/../sys/modules/xldscripts/kmodule
     69   1.7       ad .else
     70  1.12      mrg KMODSCRIPT=	${DESTDIR}/usr/libdata/ldscripts/kmodule
     71   1.7       ad .endif
     72   1.1       ad 
     73   1.1       ad OBJS+=		${SRCS:N*.h:N*.sh:R:S/$/.o/g}
     74   1.1       ad PROG?=		${KMOD}.kmod
     75   1.1       ad 
     76   1.1       ad ##### Build rules
     77   1.1       ad realall:	${PROG}
     78   1.1       ad 
     79   1.1       ad ${OBJS} ${LOBJS}: ${DPSRCS}
     80   1.1       ad 
     81   1.1       ad ${PROG}: ${OBJS} ${DPADD}
     82   1.1       ad 	${_MKTARGET_LINK}
     83  1.26   martin 	${CC} ${LDFLAGS} -nostdlib -r -Wl,-T,${KMODSCRIPT},-d \
     84  1.22     matt 		-o ${.TARGET} ${OBJS}
     85   1.1       ad 
     86   1.1       ad ##### Install rules
     87   1.1       ad .if !target(kmodinstall)
     88   1.7       ad .if !defined(KMODULEDIR)
     89   1.7       ad _OSRELEASE!=	${HOST_SH} $S/conf/osrelease.sh
     90   1.9       he # Ensure these are recorded properly in METALOG on unprived installes:
     91  1.28      mrg KMODULEARCHDIR?= ${MACHINE}
     92  1.28      mrg _INST_DIRS=	${DESTDIR}/stand/${KMODULEARCHDIR}
     93  1.28      mrg _INST_DIRS+=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}
     94  1.28      mrg _INST_DIRS+=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}/modules
     95  1.28      mrg KMODULEDIR=	${DESTDIR}/stand/${KMODULEARCHDIR}/${_OSRELEASE}/modules/${KMOD}
     96  1.10   dyoung .endif
     97  1.10   dyoung _PROG:=		${KMODULEDIR}/${PROG} # installed path
     98   1.1       ad 
     99   1.1       ad .if ${MKUPDATE} == "no"
    100   1.1       ad ${_PROG}! ${PROG}					# install rule
    101   1.1       ad .if !defined(BUILD) && !make(all) && !make(${PROG})
    102   1.1       ad ${_PROG}!	.MADE					# no build at install
    103   1.1       ad .endif
    104   1.1       ad .else
    105   1.1       ad ${_PROG}: ${PROG}					# install rule
    106   1.1       ad .if !defined(BUILD) && !make(all) && !make(${PROG})
    107   1.1       ad ${_PROG}:	.MADE					# no build at install
    108   1.1       ad .endif
    109   1.1       ad .endif
    110   1.1       ad 	${_MKTARGET_INSTALL}
    111  1.16  hubertf 	dirs=${_INST_DIRS:Q}; \
    112  1.16  hubertf 	for d in $$dirs; do \
    113   1.9       he 		${INSTALL_DIR} $$d; \
    114   1.9       he 	done
    115   1.7       ad 	${INSTALL_DIR} ${KMODULEDIR}
    116  1.15       ad 	${INSTALL_FILE} -o ${KMODULEOWN} -g ${KMODULEGRP} -m ${KMODULEMODE} \
    117   1.1       ad 		${.ALLSRC} ${.TARGET}
    118   1.1       ad 
    119   1.1       ad kmodinstall::	${_PROG}
    120   1.1       ad .PHONY:		kmodinstall
    121   1.1       ad .PRECIOUS:	${_PROG}				# keep if install fails
    122   1.1       ad 
    123   1.1       ad .undef _PROG
    124   1.1       ad .endif # !target(kmodinstall)
    125   1.1       ad 
    126   1.1       ad ##### Clean rules
    127   1.1       ad cleankmod: .PHONY
    128   1.1       ad 	rm -f a.out [Ee]rrs mklog core *.core \
    129   1.1       ad 		${PROG} ${OBJS} ${LOBJS} ${CLEANFILES}
    130   1.1       ad 
    131   1.1       ad ##### Custom rules
    132   1.1       ad lint: ${LOBJS}
    133   1.1       ad .if defined(LOBJS) && !empty(LOBJS)
    134   1.1       ad 	${LINT} ${LINTFLAGS} ${LDFLAGS:C/-L[  ]*/-L/Wg:M-L*} ${LOBJS} ${LDADD}
    135   1.1       ad .endif
    136   1.1       ad 
    137   1.1       ad ##### Pull in related .mk logic
    138  1.19      apb LINKSOWN?= ${KMODULEOWN}
    139  1.19      apb LINKSGRP?= ${KMODULEGRP}
    140  1.19      apb LINKSMODE?= ${KMODULEMODE}
    141   1.1       ad .include <bsd.man.mk>
    142   1.1       ad .include <bsd.links.mk>
    143   1.1       ad .include <bsd.dep.mk>
    144   1.1       ad 
    145   1.1       ad .-include "$S/arch/${MACHINE_CPU}/include/Makefile.inc"
    146   1.1       ad .-include "$S/arch/${MACHINE}/include/Makefile.inc"
    147