xref: /freebsd/sys/modules/Makefile (revision 399188a2c60caffe496d03f8ddd6c1b1c34dc3ed)
1# $FreeBSD$
2
3SYSDIR?=${SRCTOP}/sys
4.include "${SYSDIR}/conf/kern.opts.mk"
5
6SUBDIR_PARALLEL=
7
8# Modules that include binary-only blobs of microcode should be selectable by
9# MK_SOURCELESS_UCODE option (see below).
10
11.include "${SYSDIR}/conf/config.mk"
12
13.if defined(MODULES_OVERRIDE) && !defined(ALL_MODULES)
14SUBDIR=${MODULES_OVERRIDE}
15.else
16SUBDIR=	\
17	${_3dfx} \
18	${_3dfx_linux} \
19	${_aac} \
20	${_aacraid} \
21	accf_data \
22	accf_dns \
23	accf_http \
24	acl_nfs4 \
25	acl_posix1e \
26	${_acpi} \
27	ae \
28	${_aesni} \
29	age \
30	${_agp} \
31	ahci \
32	aic7xxx \
33	alc \
34	ale \
35	alq \
36	${_amd_ecc_inject} \
37	${_amdgpio} \
38	${_amdsbwd} \
39	${_amdsmn} \
40	${_amdtemp} \
41	amr \
42	${_aout} \
43	${_arcmsr} \
44	${_allwinner} \
45	${_armv8crypto} \
46	${_asmc} \
47	ata \
48	ath \
49	ath_dfs \
50	ath_hal \
51	ath_hal_ar5210 \
52	ath_hal_ar5211 \
53	ath_hal_ar5212 \
54	ath_hal_ar5416 \
55	ath_hal_ar9300 \
56	ath_main \
57	ath_rate \
58	ath_pci \
59	${_autofs} \
60	axgbe \
61	backlight \
62	${_bce} \
63	${_bcm283x_clkman} \
64	${_bcm283x_pwm} \
65	bfe \
66	bge \
67	bhnd \
68	${_bxe} \
69	${_bios} \
70	${_blake2} \
71	bnxt \
72	bridgestp \
73	bwi \
74	bwn \
75	${_bytgpio} \
76	${_chvgpio} \
77	cam \
78	${_cardbus} \
79	${_carp} \
80	cas \
81	${_cbb} \
82	cc \
83	${_ccp} \
84	cd9660 \
85	cd9660_iconv \
86	${_ce} \
87	${_cfi} \
88	${_chromebook_platform} \
89	${_ciss} \
90	${_coretemp} \
91	${_cp} \
92	${_cpsw} \
93	${_cpuctl} \
94	${_cpufreq} \
95	${_crypto} \
96	${_cryptodev} \
97	ctl \
98	${_cxgb} \
99	${_cxgbe} \
100	dc \
101	dcons \
102	dcons_crom \
103	${_dpdk_lpm4} \
104	${_dpdk_lpm6} \
105	${_dpms} \
106	dummynet \
107	${_dwwdt} \
108	${_e6000sw} \
109	${_efirt} \
110	${_em} \
111	${_ena} \
112	${_enetc} \
113	esp \
114	${_et} \
115	evdev \
116	${_exca} \
117	ext2fs \
118	fdc \
119	fdescfs \
120	${_felix} \
121	${_ffec} \
122	${_fib_dxr} \
123	filemon \
124	firewire \
125	firmware \
126	${_ftwd} \
127	fusefs \
128	${_fxp} \
129	gem \
130	geom \
131	${_glxiic} \
132	${_glxsb} \
133	gpio \
134	hid \
135	hifn \
136	${_hpt27xx} \
137	${_hptiop} \
138	${_hptmv} \
139	${_hptnr} \
140	${_hptrr} \
141	hwpmc \
142	${_hwpmc_mips24k} \
143	${_hwpmc_mips74k} \
144	${_hyperv} \
145	i2c \
146	${_iavf} \
147        ${_ibcore} \
148	${_ichwd} \
149	${_ice} \
150	${_ice_ddp} \
151	${_ida} \
152	if_bridge \
153	if_disc \
154	if_edsc \
155	${_if_enc} \
156	if_epair \
157	${_if_gif} \
158	${_if_gre} \
159	${_if_me} \
160	if_infiniband \
161	if_lagg \
162	${_if_stf} \
163	if_tuntap \
164	if_vlan \
165	if_vxlan \
166	iflib \
167	${_igc} \
168	imgact_binmisc \
169	${_intelspi} \
170	${_io} \
171	${_ioat} \
172        ${_ipoib} \
173	${_ipdivert} \
174	${_ipfilter} \
175	${_ipfw} \
176	ipfw_nat \
177	${_ipfw_nat64} \
178	${_ipfw_nptv6} \
179	${_ipfw_pmod} \
180	${_ipmi} \
181	ip6_mroute_mod \
182	ip_mroute_mod \
183	${_ips} \
184	${_ipsec} \
185	${_ipw} \
186	${_ipwfw} \
187	${_isci} \
188	${_iser} \
189	isp \
190	${_ispfw} \
191	${_itwd} \
192	${_iwi} \
193	${_iwifw} \
194	${_iwm} \
195	${_iwmfw} \
196	${_iwn} \
197	${_iwnfw} \
198	${_ix} \
199	${_ixv} \
200	${_ixl} \
201	jme \
202	kbdmux \
203	kgssapi \
204	kgssapi_krb5 \
205	khelp \
206	krpc \
207	ksyms \
208	le \
209	lge \
210	libalias \
211	libiconv \
212	libmchain \
213	lindebugfs \
214	linuxkpi \
215	${_lio} \
216	lpt \
217	mac_biba \
218	mac_bsdextended \
219	mac_ifoff \
220	mac_lomac \
221	mac_mls \
222	mac_none \
223	mac_ntpd \
224	mac_partition \
225	mac_portacl \
226	mac_seeotheruids \
227	mac_stub \
228	mac_test \
229	${_malo} \
230	${_mana} \
231	md \
232	mdio \
233	${_mgb} \
234	mem \
235	mfi \
236	mii \
237	mlx \
238	mlxfw \
239	${_mlx4} \
240	${_mlx4ib} \
241	${_mlx4en} \
242	${_mlx5} \
243	${_mlx5en} \
244	${_mlx5ib} \
245	mmc \
246	mmcsd \
247	${_mpr} \
248	${_mps} \
249	mpt \
250	mqueue \
251	mrsas \
252	msdosfs \
253	msdosfs_iconv \
254	msk \
255	${_mthca} \
256	mvs \
257	mwl \
258	${_mwlfw} \
259	mxge \
260	my \
261	${_nctgpio} \
262	${_neta} \
263	${_netgraph} \
264	${_nfe} \
265	nfscl \
266	nfscommon \
267	nfsd \
268	nfslockd \
269	nfssvc \
270	nge \
271	nmdm \
272	nullfs \
273	${_ntb} \
274	${_nvd} \
275	${_nvdimm} \
276	${_nvme} \
277	${_nvram} \
278	oce \
279	${_ocs_fc} \
280	${_ossl} \
281	otus \
282	${_otusfw} \
283	ow \
284	${_padlock} \
285	${_padlock_rng} \
286	${_pchtherm} \
287	${_pcfclock} \
288	${_pf} \
289	${_pflog} \
290	${_pfsync} \
291	plip \
292	${_pms} \
293	ppbus \
294	ppc \
295	ppi \
296	pps \
297	procfs \
298	proto \
299	pseudofs \
300	${_pst} \
301	pty  \
302	puc \
303	pwm \
304	${_qat} \
305	${_qatfw} \
306	${_qlxge} \
307	${_qlxgb} \
308	${_qlxgbe} \
309	${_qlnx} \
310	ral \
311	${_ralfw} \
312	${_random_fortuna} \
313	${_random_other} \
314	rc4 \
315	${_rdma} \
316	${_rdrand_rng} \
317	re \
318	rl \
319	${_rockchip} \
320	rtsx \
321	rtwn \
322	rtwn_pci \
323	rtwn_usb \
324	${_rtwnfw} \
325	${_s3} \
326	${_safe} \
327	safexcel \
328	${_sbni} \
329	scc \
330	${_sctp} \
331	sdhci \
332	${_sdhci_acpi} \
333	${_sdhci_fdt} \
334	sdhci_pci \
335	sdio \
336	sem \
337	send \
338	${_sfxge} \
339	sge \
340	${_sgx} \
341	${_sgx_linux} \
342	siftr \
343	siis \
344	sis \
345	sk \
346	${_smartpqi} \
347	smbfs \
348	snp \
349	sound \
350	${_speaker} \
351	spi \
352	${_splash} \
353	ste \
354	stge \
355	${_sume} \
356	${_superio} \
357	${_p2sb} \
358	${_sym} \
359	${_syscons} \
360	sysvipc \
361	tcp \
362	${_ti} \
363	tmpfs \
364	${_toecore} \
365	${_tpm} \
366	${_twa} \
367	twe \
368	tws \
369	uart \
370	udf \
371	udf_iconv \
372	ufs \
373	uinput \
374	unionfs \
375	usb \
376	${_vesa} \
377	virtio \
378	vge \
379	${_viawd} \
380	videomode \
381	vkbd \
382	${_vmd} \
383	${_vmm} \
384	${_vmware} \
385	vr \
386	vte \
387	${_wbwd} \
388	wlan \
389	wlan_acl \
390	wlan_amrr \
391	wlan_ccmp \
392	wlan_rssadapt \
393	wlan_tkip \
394	wlan_wep \
395	wlan_xauth \
396	${_wpi} \
397	${_wpifw} \
398	${_x86bios} \
399	xdr \
400	xl \
401	xz \
402	zlib
403
404.if ${MK_AUTOFS} != "no" || defined(ALL_MODULES)
405_autofs=	autofs
406.endif
407
408.if ${MK_CDDL} != "no" || defined(ALL_MODULES)
409.if (${MACHINE_CPUARCH} != "arm" || ${MACHINE_ARCH:Marmv[67]*} != "") && \
410	${MACHINE_CPUARCH} != "mips"
411.if ${KERN_OPTS:MKDTRACE_HOOKS}
412SUBDIR+=	dtrace
413.endif
414.endif
415SUBDIR+=	opensolaris
416.endif
417
418.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
419.if exists(${SRCTOP}/sys/opencrypto)
420_crypto=	crypto
421_cryptodev=	cryptodev
422_random_fortuna=random_fortuna
423_random_other=	random_other
424.endif
425.endif
426
427.if ${MK_CUSE} != "no" || defined(ALL_MODULES)
428SUBDIR+=	cuse
429.endif
430
431.if ${MK_EFI} != "no"
432.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
433_efirt=		efirt
434.endif
435.endif
436
437.if (${MK_INET_SUPPORT} != "no" || ${MK_INET6_SUPPORT} != "no") || \
438	defined(ALL_MODULES)
439_carp=		carp
440_toecore=	toecore
441_if_enc=	if_enc
442_if_gif=	if_gif
443_if_gre=	if_gre
444_ipfw_pmod=	ipfw_pmod
445.if ${KERN_OPTS:MIPSEC_SUPPORT} && !${KERN_OPTS:MIPSEC}
446_ipsec=		ipsec
447.endif
448.if ${KERN_OPTS:MSCTP_SUPPORT} || ${KERN_OPTS:MSCTP}
449_sctp=		sctp
450.endif
451.endif
452
453.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
454	defined(ALL_MODULES)
455_if_stf=	if_stf
456.endif
457
458.if ${MK_INET_SUPPORT} != "no" || defined(ALL_MODULES)
459_if_me=		if_me
460_ipdivert=	ipdivert
461_ipfw=		ipfw
462.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
463_ipfw_nat64=	ipfw_nat64
464.endif
465.endif
466
467.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
468_ipfw_nptv6=	ipfw_nptv6
469.endif
470
471.if ${MK_IPFILTER} != "no" || defined(ALL_MODULES)
472_ipfilter=	ipfilter
473.endif
474
475.if ${MK_INET_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
476_dpdk_lpm4=	dpdk_lpm4
477_fib_dxr=	fib_dxr
478.endif
479
480.if ${MK_INET6_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
481_dpdk_lpm6=	dpdk_lpm6
482.endif
483
484.if ${MK_ISCSI} != "no" || defined(ALL_MODULES)
485SUBDIR+=	cfiscsi
486SUBDIR+=	iscsi
487.endif
488
489.if !empty(OPT_FDT)
490SUBDIR+=	fdt
491.endif
492
493# Linuxulator
494.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
495    ${MACHINE_CPUARCH} == "i386"
496SUBDIR+=	linprocfs
497SUBDIR+=	linsysfs
498.endif
499.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
500SUBDIR+=	linux
501.endif
502.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
503SUBDIR+=	linux64
504SUBDIR+=	linux_common
505.endif
506
507.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
508    ${MACHINE_CPUARCH} == "i386"
509_ena=		ena
510.if ${MK_OFED} != "no" || defined(ALL_MODULES)
511_ibcore=	ibcore
512_ipoib=		ipoib
513_iser=		iser
514.endif
515_ipmi=		ipmi
516_mlx4=		mlx4
517_mlx5=		mlx5
518.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
519	defined(ALL_MODULES)
520_mlx4en=	mlx4en
521_mlx5en=	mlx5en
522.endif
523.if ${MK_OFED} != "no" || defined(ALL_MODULES)
524_mthca=		mthca
525_mlx4ib=	mlx4ib
526_mlx5ib=	mlx5ib
527.endif
528_ossl=		ossl
529_vmware=	vmware
530.endif
531
532.if ${MK_NETGRAPH} != "no" || defined(ALL_MODULES)
533_netgraph=	netgraph
534.endif
535
536.if (${MK_PF} != "no" && (${MK_INET_SUPPORT} != "no" || \
537	${MK_INET6_SUPPORT} != "no")) || defined(ALL_MODULES)
538_pf=		pf
539_pflog=		pflog
540.if ${MK_INET_SUPPORT} != "no"
541_pfsync=	pfsync
542.endif
543.endif
544
545.if ${MK_SOURCELESS_UCODE} != "no"
546_bce=		bce
547_fxp=		fxp
548_ispfw=		ispfw
549_ti=		ti
550
551.if ${MACHINE_CPUARCH} != "mips"
552_mwlfw=		mwlfw
553_otusfw=	otusfw
554_ralfw=		ralfw
555_rtwnfw=	rtwnfw
556.endif
557.endif
558
559.if ${MK_SOURCELESS_UCODE} != "no" && ${MACHINE_CPUARCH} != "arm" && \
560	${MACHINE_CPUARCH} != "mips" && \
561	${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
562	${MACHINE_CPUARCH} != "riscv"
563_cxgbe=		cxgbe
564.endif
565
566.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "arm64"
567_ice=		ice
568.if ${MK_SOURCELESS_UCODE} != "no"
569_ice_ddp=	ice_ddp
570.endif
571.endif
572
573# These rely on 64bit atomics
574.if ${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
575	${MACHINE_CPUARCH} != "mips"
576_mps=		mps
577_mpr=		mpr
578.endif
579
580.if ${MK_TESTS} != "no" || defined(ALL_MODULES)
581SUBDIR+=	tests
582.endif
583
584.if ${MK_ZFS} != "no" || (defined(ALL_MODULES)  && ${MACHINE_CPUARCH} != "powerpc")
585SUBDIR+=	zfs
586.endif
587
588.if (${MACHINE_CPUARCH} == "mips" && ${MACHINE_ARCH:Mmips64} == "")
589_hwpmc_mips24k=	hwpmc_mips24k
590_hwpmc_mips74k=	hwpmc_mips74k
591.endif
592
593.if ${MACHINE_CPUARCH} != "aarch64" && ${MACHINE_CPUARCH} != "arm" && \
594	${MACHINE_CPUARCH} != "mips" && ${MACHINE_CPUARCH} != "powerpc" && \
595	${MACHINE_CPUARCH} != "riscv"
596_syscons=	syscons
597.endif
598
599.if ${MACHINE_CPUARCH} != "mips"
600# no BUS_SPACE_UNSPECIFIED
601# No barrier instruction support (specific to this driver)
602_sym=		sym
603# intr_disable() is a macro, causes problems
604.if ${MK_SOURCELESS_UCODE} != "no"
605_cxgb=		cxgb
606.endif
607.endif
608
609.if ${MACHINE_CPUARCH} == "aarch64"
610_allwinner=	allwinner
611_armv8crypto=	armv8crypto
612_dwwdt=		dwwdt
613_em=		em
614_enetc=		enetc
615_felix=		felix
616_rockchip=	rockchip
617.endif
618
619.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm"
620_sdhci_fdt=	sdhci_fdt
621_e6000sw=	e6000sw
622_neta=		neta
623.endif
624
625.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
626_agp=		agp
627_aout=		aout
628_bios=		bios
629.if ${MK_SOURCELESS_UCODE} != "no"
630_bxe=		bxe
631.endif
632_cardbus=	cardbus
633_cbb=		cbb
634_cpuctl=	cpuctl
635_cpufreq=	cpufreq
636_dpms=		dpms
637_em=		em
638_et=		et
639_ftwd=		ftwd
640_exca=		exca
641_igc=		igc
642_io=		io
643_itwd=		itwd
644_ix=		ix
645_ixv=		ixv
646.if ${MK_SOURCELESS_UCODE} != "no"
647_lio=		lio
648.endif
649_mana=		mana
650_mgb=		mgb
651_nctgpio=	nctgpio
652_ntb=		ntb
653_ocs_fc=	ocs_fc
654_qat=		qat
655_qatfw=		qatfw
656.if ${MK_OFED} != "no" || defined(ALL_MODULES)
657_rdma=		rdma
658.endif
659_safe=		safe
660_speaker=	speaker
661_splash=	splash
662_p2sb=		p2sb
663_wbwd=		wbwd
664
665_aac=		aac
666_aacraid=	aacraid
667_acpi=		acpi
668.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
669_aesni=		aesni
670.endif
671_amd_ecc_inject=amd_ecc_inject
672_amdsbwd=	amdsbwd
673_amdsmn=	amdsmn
674_amdtemp=	amdtemp
675_arcmsr=	arcmsr
676_asmc=		asmc
677.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
678_blake2=	blake2
679.endif
680_bytgpio=	bytgpio
681_chvgpio=	chvgpio
682_ciss=		ciss
683_chromebook_platform=	chromebook_platform
684_coretemp=	coretemp
685.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
686_hpt27xx=	hpt27xx
687.endif
688_hptiop=	hptiop
689.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
690_hptmv=		hptmv
691_hptnr=		hptnr
692_hptrr=		hptrr
693.endif
694_hyperv=	hyperv
695_ichwd=		ichwd
696_ida=		ida
697_intelspi=	intelspi
698_ips=		ips
699_isci=		isci
700_ipw=		ipw
701_iwi=		iwi
702_iwm=		iwm
703_iwn=		iwn
704.if ${MK_SOURCELESS_UCODE} != "no"
705_ipwfw=		ipwfw
706_iwifw=		iwifw
707_iwmfw=		iwmfw
708_iwnfw=		iwnfw
709.endif
710_nfe=		nfe
711_nvd=		nvd
712_nvme=		nvme
713_nvram=		nvram
714.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
715_padlock=	padlock
716_padlock_rng=	padlock_rng
717_rdrand_rng=	rdrand_rng
718.endif
719_pchtherm = pchtherm
720_s3=		s3
721_sdhci_acpi=	sdhci_acpi
722_superio=	superio
723_tpm=		tpm
724_twa=		twa
725_vesa=		vesa
726_viawd=		viawd
727_vmd=		vmd
728_wpi=		wpi
729.if ${MK_SOURCELESS_UCODE} != "no"
730_wpifw=		wpifw
731.endif
732_x86bios=	x86bios
733.endif
734
735.if ${MACHINE_CPUARCH} == "amd64"
736_amdgpio=	amdgpio
737_ccp=		ccp
738_iavf=		iavf
739_ioat=		ioat
740_ixl=		ixl
741_nvdimm=	nvdimm
742_pms=		pms
743_qlxge=		qlxge
744_qlxgb=		qlxgb
745_sume=		sume
746.if ${MK_SOURCELESS_UCODE} != "no"
747_qlxgbe=	qlxgbe
748_qlnx=		qlnx
749.endif
750_sfxge=		sfxge
751_sgx=		sgx
752_sgx_linux=	sgx_linux
753_smartpqi=	smartpqi
754_p2sb=		p2sb
755
756.if ${MK_BHYVE} != "no" || defined(ALL_MODULES)
757.if ${KERN_OPTS:MSMP}
758_vmm=		vmm
759.endif
760.endif
761.endif
762
763.if ${MACHINE_CPUARCH} == "i386"
764# XXX some of these can move to the general case when de-i386'ed
765# XXX some of these can move now, but are untested on other architectures.
766_3dfx=		3dfx
767_3dfx_linux=	3dfx_linux
768.if ${MK_SOURCELESS_HOST} != "no"
769_ce=		ce
770.endif
771.if ${MK_SOURCELESS_HOST} != "no"
772_cp=		cp
773.endif
774_glxiic=	glxiic
775_glxsb=		glxsb
776_pcfclock=	pcfclock
777_pst=		pst
778_sbni=		sbni
779.endif
780
781.if ${MACHINE_ARCH} == "armv7"
782_cfi=		cfi
783_cpsw=		cpsw
784.endif
785
786.if ${MACHINE_CPUARCH} == "powerpc"
787_aacraid=	aacraid
788_agp=		agp
789_an=		an
790_cardbus=	cardbus
791_cbb=		cbb
792_cfi=		cfi
793_cpufreq=	cpufreq
794_exca=		exca
795_ffec=		ffec
796_nvd=		nvd
797_nvme=		nvme
798.endif
799
800.if ${MACHINE_ARCH:Mpowerpc64*} != ""
801_ipmi=		ipmi
802_ixl=		ixl
803_nvram=		opal_nvram
804.endif
805.if ${MACHINE_CPUARCH} == "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
806# Don't build powermac_nvram for powerpcspe, it's never supported.
807_nvram+=	powermac_nvram
808.endif
809
810.endif
811
812.if ${MACHINE_ARCH:Marmv[67]*} != "" || ${MACHINE_CPUARCH} == "aarch64"
813_bcm283x_clkman=  bcm283x_clkman
814_bcm283x_pwm=  bcm283x_pwm
815.endif
816
817.if !(${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} < 110000)
818# LLVM 10 crashes when building if_malo_pci.c, fixed in LLVM11:
819# https://bugs.llvm.org/show_bug.cgi?id=44351
820_malo=	malo
821.endif
822
823SUBDIR+=${MODULES_EXTRA}
824
825.for reject in ${WITHOUT_MODULES}
826SUBDIR:= ${SUBDIR:N${reject}}
827.endfor
828
829# Calling kldxref(8) for each module is expensive.
830.if !defined(NO_XREF)
831.MAKEFLAGS+=	-DNO_XREF
832afterinstall: .PHONY
833	@if type kldxref >/dev/null 2>&1; then \
834		${ECHO} ${KLDXREF_CMD} ${DESTDIR}${KMODDIR}; \
835		${KLDXREF_CMD} ${DESTDIR}${KMODDIR}; \
836	fi
837.endif
838
839SUBDIR:= ${SUBDIR:u:O}
840
841.include <bsd.subdir.mk>
842