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