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