xref: /freebsd/sys/modules/Makefile (revision bd001d86d679e10d179ef00b9866f0e65b6fa7fd)
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	${_aout} \
42	${_arcmsr} \
43	${_allwinner} \
44	${_armv8crypto} \
45	${_asmc} \
46	ata \
47	ath \
48	ath_dfs \
49	ath_hal \
50	ath_hal_ar5210 \
51	ath_hal_ar5211 \
52	ath_hal_ar5212 \
53	ath_hal_ar5416 \
54	ath_hal_ar9300 \
55	ath_main \
56	ath_rate \
57	ath_pci \
58	${_autofs} \
59	axgbe \
60	backlight \
61	${_bce} \
62	${_bcm283x_clkman} \
63	${_bcm283x_pwm} \
64	bfe \
65	bge \
66	bhnd \
67	${_bxe} \
68	${_bios} \
69	${_blake2} \
70	bnxt \
71	bridgestp \
72	bwi \
73	bwn \
74	${_bytgpio} \
75	${_chvgpio} \
76	cam \
77	${_cardbus} \
78	${_carp} \
79	cas \
80	${_cbb} \
81	cc \
82	${_ccp} \
83	cd9660 \
84	cd9660_iconv \
85	${_ce} \
86	${_cfi} \
87	${_chromebook_platform} \
88	${_ciss} \
89	${_coretemp} \
90	${_cp} \
91	${_cpsw} \
92	${_cpuctl} \
93	${_cpufreq} \
94	${_crypto} \
95	${_cryptodev} \
96	ctl \
97	${_cxgb} \
98	${_cxgbe} \
99	dc \
100	dcons \
101	dcons_crom \
102	${_dpdk_lpm4} \
103	${_dpdk_lpm6} \
104	${_dpms} \
105	dummynet \
106	${_dwwdt} \
107	${_e6000sw} \
108	${_efirt} \
109	${_em} \
110	${_ena} \
111	${_enetc} \
112	${_et} \
113	evdev \
114	${_exca} \
115	ext2fs \
116	fdc \
117	fdescfs \
118	${_felix} \
119	${_ffec} \
120	${_fib_dxr} \
121	filemon \
122	firewire \
123	firmware \
124	flash \
125	${_ftwd} \
126	fusefs \
127	${_fxp} \
128	gem \
129	geom \
130	${_glxiic} \
131	${_glxsb} \
132	gpio \
133	hid \
134	hifn \
135	${_hpt27xx} \
136	${_hptiop} \
137	${_hptmv} \
138	${_hptnr} \
139	${_hptrr} \
140	hwpmc \
141	${_hyperv} \
142	i2c \
143	${_iavf} \
144        ${_ibcore} \
145	${_ichwd} \
146	${_ice} \
147	${_ice_ddp} \
148	${_ida} \
149	if_bridge \
150	${_if_cgem} \
151	if_disc \
152	if_edsc \
153	${_if_enc} \
154	if_epair \
155	${_if_gif} \
156	${_if_gre} \
157	${_if_me} \
158	if_infiniband \
159	if_lagg \
160	${_if_stf} \
161	if_tuntap \
162	if_vlan \
163	if_vxlan \
164	iflib \
165	${_igc} \
166	imgact_binmisc \
167	${_intelspi} \
168	${_io} \
169	${_ioat} \
170        ${_ipoib} \
171	${_ipdivert} \
172	${_ipfilter} \
173	${_ipfw} \
174	ipfw_nat \
175	${_ipfw_nat64} \
176	${_ipfw_nptv6} \
177	${_ipfw_pmod} \
178	${_ipmi} \
179	ip6_mroute_mod \
180	ip_mroute_mod \
181	${_ips} \
182	${_ipsec} \
183	${_ipw} \
184	${_ipwfw} \
185	${_isci} \
186	${_iser} \
187	isp \
188	${_ispfw} \
189	${_itwd} \
190	${_iwi} \
191	${_iwifw} \
192	${_iwlwifi} \
193	${_iwlwififw} \
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	linuxkpi_wlan \
216	${_lio} \
217	lpt \
218	mac_biba \
219	mac_bsdextended \
220	mac_ifoff \
221	mac_lomac \
222	mac_mls \
223	mac_none \
224	mac_ntpd \
225	mac_partition \
226	mac_pimd \
227	mac_portacl \
228	mac_priority \
229	mac_seeotheruids \
230	mac_stub \
231	mac_test \
232	${_malo} \
233	${_mana} \
234	md \
235	mdio \
236	${_mgb} \
237	mem \
238	mfi \
239	mii \
240	mlx \
241	mlxfw \
242	${_mlx4} \
243	${_mlx4ib} \
244	${_mlx4en} \
245	${_mlx5} \
246	${_mlx5en} \
247	${_mlx5ib} \
248	mmc \
249	mmcsd \
250	${_mpr} \
251	${_mps} \
252	mpt \
253	mqueue \
254	mrsas \
255	msdosfs \
256	msdosfs_iconv \
257	msk \
258	${_mthca} \
259	mvs \
260	mwl \
261	${_mwlfw} \
262	mxge \
263	my \
264	${_nctgpio} \
265	${_neta} \
266	${_netgraph} \
267	${_nfe} \
268	nfscl \
269	nfscommon \
270	nfsd \
271	nfslockd \
272	nfssvc \
273	nge \
274	nmdm \
275	nullfs \
276	${_ntb} \
277	${_nvd} \
278	${_nvdimm} \
279	${_nvme} \
280	${_nvram} \
281	oce \
282	${_ocs_fc} \
283	${_ossl} \
284	otus \
285	${_otusfw} \
286	ow \
287	${_padlock} \
288	${_padlock_rng} \
289	${_pchtherm} \
290	${_pcfclock} \
291	${_pf} \
292	${_pflog} \
293	${_pfsync} \
294	plip \
295	${_pms} \
296	ppbus \
297	ppc \
298	ppi \
299	pps \
300	procfs \
301	proto \
302	pseudofs \
303	${_pst} \
304	pty  \
305	puc \
306	pwm \
307	${_qat} \
308	${_qatfw} \
309	${_qlxge} \
310	${_qlxgb} \
311	${_qlxgbe} \
312	${_qlnx} \
313	ral \
314	${_ralfw} \
315	${_random_fortuna} \
316	${_random_other} \
317	rc4 \
318	${_rdma} \
319	${_rdrand_rng} \
320	re \
321	rl \
322	${_rockchip} \
323	rtsx \
324	${_rtw88} \
325	${_rtw88fw} \
326	rtwn \
327	rtwn_pci \
328	rtwn_usb \
329	${_rtwnfw} \
330	${_s3} \
331	${_safe} \
332	safexcel \
333	${_sbni} \
334	scc \
335	${_sctp} \
336	sdhci \
337	${_sdhci_acpi} \
338	${_sdhci_fdt} \
339	sdhci_pci \
340	sdio \
341	sem \
342	send \
343	${_sfxge} \
344	sge \
345	${_sgx} \
346	${_sgx_linux} \
347	siftr \
348	siis \
349	sis \
350	sk \
351	${_smartpqi} \
352	smbfs \
353	snp \
354	sound \
355	${_speaker} \
356	spi \
357	${_splash} \
358	ste \
359	stge \
360	${_sume} \
361	${_superio} \
362	${_p2sb} \
363	sym \
364	${_syscons} \
365	sysvipc \
366	tcp \
367	${_ti} \
368	tmpfs \
369	${_toecore} \
370	${_tpm} \
371	twe \
372	tws \
373	uart \
374	udf \
375	udf_iconv \
376	ufs \
377	uinput \
378	unionfs \
379	usb \
380	${_vesa} \
381	virtio \
382	vge \
383	${_viawd} \
384	videomode \
385	vkbd \
386	${_vmd} \
387	${_vmm} \
388	${_vmware} \
389	vr \
390	vte \
391	${_wbwd} \
392	wlan \
393	wlan_acl \
394	wlan_amrr \
395	wlan_ccmp \
396	wlan_rssadapt \
397	wlan_tkip \
398	wlan_wep \
399	wlan_xauth \
400	${_wpi} \
401	${_wpifw} \
402	${_x86bios} \
403	xdr \
404	xl \
405	xz \
406	zlib
407
408.if ${MK_AUTOFS} != "no" || defined(ALL_MODULES)
409_autofs=	autofs
410.endif
411
412.if ${MK_CDDL} != "no" || defined(ALL_MODULES)
413.if ${MACHINE_CPUARCH} != "arm" || ${MACHINE_ARCH:Marmv[67]*} != ""
414.if ${KERN_OPTS:MKDTRACE_HOOKS}
415SUBDIR+=	dtrace
416.endif
417.endif
418SUBDIR+=	opensolaris
419.endif
420
421.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
422.if exists(${SRCTOP}/sys/opencrypto)
423_crypto=	crypto
424_cryptodev=	cryptodev
425_random_fortuna=random_fortuna
426_random_other=	random_other
427.endif
428.endif
429
430.if ${MK_CUSE} != "no" || defined(ALL_MODULES)
431SUBDIR+=	cuse
432.endif
433
434.if ${MK_EFI} != "no"
435.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
436_efirt=		efirt
437.endif
438.endif
439
440.if (${MK_INET_SUPPORT} != "no" || ${MK_INET6_SUPPORT} != "no") || \
441	defined(ALL_MODULES)
442_carp=		carp
443_toecore=	toecore
444_if_enc=	if_enc
445_if_gif=	if_gif
446_if_gre=	if_gre
447_ipfw_pmod=	ipfw_pmod
448.if ${KERN_OPTS:MIPSEC_SUPPORT} && !${KERN_OPTS:MIPSEC}
449_ipsec=		ipsec
450.endif
451.if ${KERN_OPTS:MSCTP_SUPPORT} || ${KERN_OPTS:MSCTP}
452_sctp=		sctp
453.endif
454.endif
455
456.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
457	defined(ALL_MODULES)
458_if_stf=	if_stf
459.endif
460
461.if ${MK_INET_SUPPORT} != "no" || defined(ALL_MODULES)
462_if_me=		if_me
463_ipdivert=	ipdivert
464_ipfw=		ipfw
465.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
466_ipfw_nat64=	ipfw_nat64
467.endif
468.endif
469
470.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
471_ipfw_nptv6=	ipfw_nptv6
472.endif
473
474.if ${MK_IPFILTER} != "no" || defined(ALL_MODULES)
475_ipfilter=	ipfilter
476.endif
477
478.if ${MK_INET_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
479_dpdk_lpm4=	dpdk_lpm4
480_fib_dxr=	fib_dxr
481.endif
482
483.if ${MK_INET6_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
484_dpdk_lpm6=	dpdk_lpm6
485.endif
486
487.if ${MK_ISCSI} != "no" || defined(ALL_MODULES)
488SUBDIR+=	cfiscsi
489SUBDIR+=	iscsi
490.endif
491
492.if !empty(OPT_FDT)
493SUBDIR+=	fdt
494.endif
495
496# Linuxulator
497.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
498    ${MACHINE_CPUARCH} == "i386"
499SUBDIR+=	linprocfs
500SUBDIR+=	linsysfs
501.endif
502.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
503SUBDIR+=	linux
504.endif
505.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
506SUBDIR+=	linux64
507SUBDIR+=	linux_common
508.endif
509
510.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
511    ${MACHINE_CPUARCH} == "i386"
512_ena=		ena
513.if ${MK_OFED} != "no" || defined(ALL_MODULES)
514_ibcore=	ibcore
515_ipoib=		ipoib
516_iser=		iser
517.endif
518_ipmi=		ipmi
519_iwlwifi=	iwlwifi
520.if ${MK_SOURCELESS_UCODE} != "no"
521_iwlwififw=	iwlwififw
522.endif
523_mlx4=		mlx4
524_mlx5=		mlx5
525.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
526	defined(ALL_MODULES)
527_mlx4en=	mlx4en
528_mlx5en=	mlx5en
529.endif
530.if ${MK_OFED} != "no" || defined(ALL_MODULES)
531_mthca=		mthca
532_mlx4ib=	mlx4ib
533_mlx5ib=	mlx5ib
534.endif
535_ossl=		ossl
536_rtw88=		rtw88
537.if ${MK_SOURCELESS_UCODE} != "no"
538_rtw88fw=	rtw88fw
539.endif
540_vmware=	vmware
541.endif
542
543.if ${MK_NETGRAPH} != "no" || defined(ALL_MODULES)
544_netgraph=	netgraph
545.endif
546
547.if (${MK_PF} != "no" && (${MK_INET_SUPPORT} != "no" || \
548	${MK_INET6_SUPPORT} != "no")) || defined(ALL_MODULES)
549_pf=		pf
550_pflog=		pflog
551.if ${MK_INET_SUPPORT} != "no"
552_pfsync=	pfsync
553.endif
554.endif
555
556.if ${MK_SOURCELESS_UCODE} != "no"
557_bce=		bce
558_fxp=		fxp
559_ispfw=		ispfw
560_ti=		ti
561_mwlfw=		mwlfw
562_otusfw=	otusfw
563_ralfw=		ralfw
564_rtwnfw=	rtwnfw
565.endif
566
567.if ${MK_SOURCELESS_UCODE} != "no" && ${MACHINE_CPUARCH} != "arm" && \
568	${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
569	${MACHINE_CPUARCH} != "riscv"
570_cxgbe=		cxgbe
571.endif
572
573.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "arm64" || ${MACHINE_ARCH:Mpowerpc64*}
574_ice=		ice
575.if ${MK_SOURCELESS_UCODE} != "no"
576_ice_ddp=	ice_ddp
577.endif
578.endif
579
580.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm" || \
581	${MACHINE_CPUARCH} == "riscv"
582_if_cgem=	if_cgem
583.endif
584
585# These rely on 64bit atomics
586.if ${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
587_mps=		mps
588_mpr=		mpr
589.endif
590
591.if ${MK_TESTS} != "no" || defined(ALL_MODULES)
592SUBDIR+=	tests
593.endif
594
595.if ${MK_ZFS} != "no" || (defined(ALL_MODULES)  && ${MACHINE_CPUARCH} != "powerpc")
596SUBDIR+=	zfs
597.endif
598
599.if ${MACHINE_CPUARCH} != "aarch64" && ${MACHINE_CPUARCH} != "arm" && \
600	${MACHINE_CPUARCH} != "powerpc" && ${MACHINE_CPUARCH} != "riscv"
601_syscons=	syscons
602.endif
603
604.if ${MK_SOURCELESS_UCODE} != "no"
605_cxgb=		cxgb
606.endif
607
608.if ${MACHINE_CPUARCH} == "aarch64"
609_allwinner=	allwinner
610_armv8crypto=	armv8crypto
611_dwwdt=		dwwdt
612_em=		em
613_enetc=		enetc
614_felix=		felix
615_rockchip=	rockchip
616.endif
617
618.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm"
619_sdhci_fdt=	sdhci_fdt
620_e6000sw=	e6000sw
621_neta=		neta
622.endif
623
624.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
625_agp=		agp
626.if ${MACHINE_CPUARCH} == "i386" || !empty(COMPAT_FREEBSD32_ENABLED)
627_aout=		aout
628.endif
629_bios=		bios
630.if ${MK_SOURCELESS_UCODE} != "no"
631_bxe=		bxe
632.endif
633_cardbus=	cardbus
634_cbb=		cbb
635_cpuctl=	cpuctl
636_cpufreq=	cpufreq
637_dpms=		dpms
638_em=		em
639_et=		et
640_ftwd=		ftwd
641_exca=		exca
642_igc=		igc
643_io=		io
644_itwd=		itwd
645_ix=		ix
646_ixv=		ixv
647.if ${MK_SOURCELESS_UCODE} != "no"
648_lio=		lio
649.endif
650_mana=		mana
651_mgb=		mgb
652_nctgpio=	nctgpio
653_ntb=		ntb
654_ocs_fc=	ocs_fc
655_qat=		qat
656_qatfw=		qatfw
657.if ${MK_OFED} != "no" || defined(ALL_MODULES)
658_rdma=		rdma
659.endif
660_safe=		safe
661_speaker=	speaker
662_splash=	splash
663_p2sb=		p2sb
664_wbwd=		wbwd
665
666_aac=		aac
667_aacraid=	aacraid
668_acpi=		acpi
669.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
670_aesni=		aesni
671.endif
672_amd_ecc_inject=amd_ecc_inject
673_amdsbwd=	amdsbwd
674_amdsmn=	amdsmn
675_amdtemp=	amdtemp
676_arcmsr=	arcmsr
677_asmc=		asmc
678.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
679_blake2=	blake2
680.endif
681_bytgpio=	bytgpio
682_chvgpio=	chvgpio
683_ciss=		ciss
684_chromebook_platform=	chromebook_platform
685_coretemp=	coretemp
686.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
687_hpt27xx=	hpt27xx
688.endif
689_hptiop=	hptiop
690.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
691_hptmv=		hptmv
692_hptnr=		hptnr
693_hptrr=		hptrr
694.endif
695_hyperv=	hyperv
696_ichwd=		ichwd
697_ida=		ida
698_intelspi=	intelspi
699_ips=		ips
700_isci=		isci
701_ipw=		ipw
702_iwi=		iwi
703_iwm=		iwm
704_iwn=		iwn
705.if ${MK_SOURCELESS_UCODE} != "no"
706_ipwfw=		ipwfw
707_iwifw=		iwifw
708_iwmfw=		iwmfw
709_iwnfw=		iwnfw
710.endif
711_nfe=		nfe
712_nvd=		nvd
713_nvme=		nvme
714_nvram=		nvram
715.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
716_padlock=	padlock
717_padlock_rng=	padlock_rng
718_rdrand_rng=	rdrand_rng
719.endif
720_pchtherm = pchtherm
721_s3=		s3
722_sdhci_acpi=	sdhci_acpi
723_superio=	superio
724_tpm=		tpm
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