xref: /freebsd/sys/modules/Makefile (revision 685a78570b359eb2bd4d8c28dde22de54d55b8ec)
1SYSDIR?=${SRCTOP}/sys
2.include "${SYSDIR}/conf/kern.opts.mk"
3
4SUBDIR_PARALLEL=
5
6# Modules that include binary-only blobs of microcode should be selectable by
7# MK_SOURCELESS_UCODE option (see below).
8
9.include "${SYSDIR}/conf/config.mk"
10
11.if defined(MODULES_OVERRIDE) && !defined(ALL_MODULES)
12SUBDIR=${MODULES_OVERRIDE}
13.else
14SUBDIR=	\
15	${_3dfx} \
16	${_3dfx_linux} \
17	${_aac} \
18	${_aacraid} \
19	accf_data \
20	accf_dns \
21	accf_http \
22	accf_tls \
23	acl_nfs4 \
24	acl_posix1e \
25	${_acpi} \
26	ae \
27	${_aesni} \
28	age \
29	${_agp} \
30	ahci \
31	aic7xxx \
32	alc \
33	ale \
34	alq \
35	${_amd_ecc_inject} \
36	${_amdgpio} \
37	${_amdsmu} \
38	${_amdsbwd} \
39	${_amdsmn} \
40	${_amdtemp} \
41	${_aout} \
42	${_arcmsr} \
43	${_allwinner} \
44	${_armv8crypto} \
45	${_armv8_rng} \
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	${_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	${_cfi} \
86	${_chromebook_platform} \
87	${_ciss} \
88	${_coretemp} \
89	${_cpsw} \
90	${_cpuctl} \
91	${_cpufreq} \
92	${_crypto} \
93	${_cryptodev} \
94	ctl \
95	${_cxgb} \
96	${_cxgbe} \
97	dc \
98	dcons \
99	dcons_crom \
100	${_dpaa2} \
101	${_dpdk_lpm4} \
102	${_dpdk_lpm6} \
103	${_dpms} \
104	dummymbuf \
105	dummynet \
106	${_dwwdt} \
107	e6000sw \
108	${_efirt} \
109	${_em} \
110	${_ena} \
111	${_enic} \
112	${_enetc} \
113	${_et} \
114	etherswitch \
115	evdev \
116	${_exca} \
117	ext2fs \
118	fdc \
119	fdescfs \
120	${_felix} \
121	${_ffec} \
122	${_fib_dxr} \
123	filemon \
124	firewire \
125	firmware \
126	flash \
127	${_ftgpio} \
128	${_ftwd} \
129	fusefs \
130	${_fxp} \
131	gem \
132	geom \
133	${_glxiic} \
134	${_glxsb} \
135	gpio \
136	${_gve} \
137	hid \
138	${_hpt27xx} \
139	${_hptiop} \
140	${_hptmv} \
141	${_hptnr} \
142	${_hptrr} \
143	hwpmc \
144	${_hwt} \
145	${_hyperv} \
146	i2c \
147	${_iavf} \
148        ${_ibcore} \
149	${_ichwd} \
150	${_ice} \
151	${_ice_ddp} \
152	${_irdma} \
153	${_ida} \
154	if_bridge \
155	${_if_cgem} \
156	if_disc \
157	if_edsc \
158	${_if_enc} \
159	if_epair \
160	${_genet} \
161	${_if_gif} \
162	${_if_gre} \
163	${_if_me} \
164	if_infiniband \
165	if_lagg \
166	if_ovpn \
167	${_if_stf} \
168	if_tuntap \
169	if_vlan \
170	if_vxlan \
171	${_if_wg} \
172	iflib \
173	${_igc} \
174	imgact_binmisc \
175	${_imx} \
176	${_intelspi} \
177	${_io} \
178	${_ioat} \
179        ${_ipoib} \
180	ipdivert \
181	${_ipfilter} \
182	${_ipfw} \
183	ipfw_nat \
184	${_ipfw_nat64} \
185	${_ipfw_nptv6} \
186	${_ipfw_pmod} \
187	${_ipmi} \
188	ip6_mroute_mod \
189	ip_mroute_mod \
190	${_ips} \
191	${_ipsec} \
192	${_ipw} \
193	${_ipwfw} \
194	${_isci} \
195	${_iser} \
196	isp \
197	${_ispfw} \
198	${_itwd} \
199	${_iwi} \
200	${_iwifw} \
201	${_iwlwifi} \
202	${_iwm} \
203	${_iwn} \
204	${_iwnfw} \
205	${_iwx} \
206	${_ix} \
207	${_ixv} \
208	${_ixl} \
209	jme \
210	kbdmux \
211	kgssapi \
212	kgssapi_krb5 \
213	khelp \
214	krpc \
215	ksyms \
216	le \
217	lge \
218	libalias \
219	libiconv \
220	libmchain \
221	lindebugfs \
222	linuxkpi \
223	linuxkpi_hdmi \
224	linuxkpi_video \
225	linuxkpi_wlan \
226	${_lio} \
227	lpt \
228	${_mac_biba} \
229	${_mac_bsdextended} \
230	${_mac_ddb} \
231	${_mac_do} \
232	${_mac_ifoff} \
233	${_mac_ipacl} \
234	${_mac_lomac} \
235	${_mac_mls} \
236	${_mac_none} \
237	${_mac_ntpd} \
238	${_mac_partition} \
239	${_mac_pimd} \
240	${_mac_portacl} \
241	${_mac_priority} \
242	${_mac_seeotheruids} \
243	${_mac_stub} \
244	${_mac_test} \
245	${_mac_veriexec} \
246	${_mac_veriexec_sha1} \
247	${_mac_veriexec_sha256} \
248	${_mac_veriexec_sha384} \
249	${_mac_veriexec_sha512} \
250	${_malo} \
251	${_mana} \
252	md \
253	mdio \
254	${_mgb} \
255	mem \
256	mfi \
257	mii \
258	miiproxy \
259	mlx \
260	mlxfw \
261	${_mlx4} \
262	${_mlx4ib} \
263	${_mlx4en} \
264	${_mlx5} \
265	${_mlx5en} \
266	${_mlx5ib} \
267	mmc \
268	mmcsd \
269	${_mpi3mr} \
270	${_mpr} \
271	${_mps} \
272	mpt \
273	mqueue \
274	mrsas \
275	msdosfs \
276	msdosfs_iconv \
277	msk \
278	${_mthca} \
279	mvs \
280	mwl \
281	${_mwlfw} \
282	mxge \
283	my \
284	${_nctgpio} \
285	${_ncthwm} \
286	${_neta} \
287	netlink \
288	${_netgraph} \
289	${_nfe} \
290	nfscl \
291	nfscommon \
292	nfsd \
293	nfslockd \
294	nfssvc \
295	nlsysevent \
296	nge \
297	nmdm \
298	nullfs \
299	${_ntb} \
300	nvd \
301	${_nvdimm} \
302	nvme \
303	nvmf \
304	${_nvram} \
305	oce \
306	${_ocs_fc} \
307	${_ossl} \
308	otus \
309	${_otusfw} \
310	ow \
311	p9fs \
312	${_padlock} \
313	${_padlock_rng} \
314	${_pchtherm} \
315	${_pcfclock} \
316	${_pf} \
317	${_pflog} \
318	${_pflow} \
319	${_pfsync} \
320	plip \
321	${_pms} \
322	ppbus \
323	ppc \
324	ppi \
325	pps \
326	procfs \
327	proto \
328	pseudofs \
329	${_pst} \
330	${_pt} \
331	pty  \
332	puc \
333	pwm \
334	${_qat} \
335	${_qatfw} \
336	${_qat_c2xxx} \
337	${_qat_c2xxxfw} \
338	${_qlxge} \
339	${_qlxgb} \
340	${_qlxgbe} \
341	${_qlnx} \
342	ral \
343	${_ralfw} \
344	${_random_fortuna} \
345	${_random_other} \
346	rc4 \
347	${_rdma} \
348	${_rdrand_rng} \
349	${_rdseed_rng} \
350	re \
351	rl \
352	${_rockchip} \
353	rtsx \
354	${_rtw88} \
355	${_rtw89} \
356	rtwn \
357	rtwn_pci \
358	rtwn_usb \
359	${_rtwnfw} \
360	${_s3} \
361	${_safe} \
362	safexcel \
363	${_sbni} \
364	scc \
365	${_sctp} \
366	sdhci \
367	${_sdhci_acpi} \
368	${_sdhci_fdt} \
369	sdhci_pci \
370	sdio \
371	${_sff} \
372	sem \
373	send \
374	${_sfxge} \
375	sge \
376	${_sgx} \
377	${_sgx_linux} \
378	siftr \
379	siis \
380	sis \
381	sk \
382	${_smartpqi} \
383	smbfs \
384	snp \
385	sound \
386	${_speaker} \
387	spi \
388	${_splash} \
389	ste \
390	stge \
391	${_sume} \
392	${_superio} \
393	${_p2sb} \
394	sym \
395	${_syscons} \
396	sysvipc \
397	tarfs \
398	tcp \
399	${_thunderbolt} \
400	${_ti} \
401	tmpfs \
402	${_toecore} \
403	tpm \
404	tws \
405	uart \
406	udf \
407	udf_iconv \
408	ufs \
409	${_ufshci} \
410	uinput \
411	unionfs \
412	usb \
413	${_vesa} \
414	${_vf_i2c} \
415	virtio \
416	vge \
417	${_viawd} \
418	videomode \
419	vkbd \
420	${_vmd} \
421	${_vmm} \
422	${_vmware} \
423	vr \
424	vte \
425	${_wbwd} \
426	${_wdatwd} \
427	wlan \
428	wlan_acl \
429	wlan_amrr \
430	wlan_ccmp \
431	wlan_gcmp \
432	wlan_rssadapt \
433	wlan_tkip \
434	wlan_wep \
435	wlan_xauth \
436	${_wpi} \
437	${_wpifw} \
438	${_wtap} \
439	${_x86bios} \
440	xdr \
441	xl \
442	xz \
443	zlib
444
445.if ${MK_AUTOFS} != "no" || defined(ALL_MODULES)
446_autofs=	autofs
447.endif
448
449.if ${MK_DTRACE} != "no" || defined(ALL_MODULES)
450.if ${KERN_OPTS:MKDTRACE_HOOKS}
451SUBDIR+=	dtrace
452.endif
453SUBDIR+=	opensolaris
454.endif
455
456.if !${MACHINE_ABI:Mlong32}
457_bnxt=		bnxt
458.endif
459
460.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
461.if exists(${SRCTOP}/sys/opencrypto)
462_crypto=	crypto
463_cryptodev=	cryptodev
464_random_fortuna=random_fortuna
465_random_other=	random_other
466.endif
467.endif
468
469.if ${MK_CUSE} != "no" || defined(ALL_MODULES)
470SUBDIR+=	cuse
471.endif
472
473.if ${MK_EFI} != "no"
474.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
475_efirt=		efirt
476.endif
477.endif
478
479.if (${MK_INET_SUPPORT} != "no" || ${MK_INET6_SUPPORT} != "no") || \
480	defined(ALL_MODULES)
481_carp=		carp
482_toecore=	toecore
483_if_enc=	if_enc
484_if_gif=	if_gif
485_if_gre=	if_gre
486.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
487_if_wg=		if_wg
488.endif
489_ipfw_pmod=	ipfw_pmod
490.if ${KERN_OPTS:MIPSEC_SUPPORT} && !${KERN_OPTS:MIPSEC}
491_ipsec=		ipsec
492.endif
493.if ${KERN_OPTS:MSCTP_SUPPORT} || ${KERN_OPTS:MSCTP}
494_sctp=		sctp
495.endif
496.endif
497
498.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
499	defined(ALL_MODULES)
500_if_stf=	if_stf
501.endif
502
503.if (${KERN_OPTS:MINET} && ${MK_INET_SUPPORT} != "no") || defined(ALL_MODULES)
504_if_me=		if_me
505_ipfw=		ipfw
506.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
507_ipfw_nat64=	ipfw_nat64
508.endif
509.endif
510
511.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
512_ipfw_nptv6=	ipfw_nptv6
513.endif
514
515.if ${MK_IPFILTER} != "no" || defined(ALL_MODULES)
516_ipfilter=	ipfilter
517.endif
518
519.if ${MK_INET_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO} && ${KERN_OPTS:MINET}
520_dpdk_lpm4=	dpdk_lpm4
521_fib_dxr=	fib_dxr
522.endif
523
524.if ${MK_INET6_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
525_dpdk_lpm6=	dpdk_lpm6
526.endif
527
528.if ${MK_ISCSI} != "no" || defined(ALL_MODULES)
529SUBDIR+=	cfiscsi
530SUBDIR+=	iscsi
531.endif
532
533.if !empty(OPT_FDT)
534SUBDIR+=	fdt
535.endif
536
537# Linuxulator
538.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
539    ${MACHINE_CPUARCH} == "i386"
540SUBDIR+=	linprocfs
541SUBDIR+=	linsysfs
542.endif
543.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
544SUBDIR+=	linux
545.endif
546.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
547SUBDIR+=	linux64
548SUBDIR+=	linux_common
549.endif
550
551.if ${MACHINE_CPUARCH} != "arm"
552.if ${MK_OFED} != "no" || defined(ALL_MODULES)
553_ibcore=	ibcore
554_ipoib=		ipoib
555_iser=		iser
556_mthca=		mthca
557_rdma=		rdma
558.endif
559.endif
560
561.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
562    ${MACHINE_CPUARCH} == "i386" || ${MACHINE_ARCH:Mpowerpc64*} != ""
563_ipmi=		ipmi
564_mlx4=		mlx4
565_mlx5=		mlx5
566.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
567	defined(ALL_MODULES)
568_mlx4en=	mlx4en
569_mlx5en=	mlx5en
570.endif
571.if ${MK_OFED} != "no" || defined(ALL_MODULES)
572_mlx4ib=	mlx4ib
573_mlx5ib=	mlx5ib
574.endif
575.endif
576
577.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
578    ${MACHINE_CPUARCH} == "i386"
579_ena=		ena
580_gve=		gve
581_igc=		igc
582# gcc13 and earlier lack __builtin_bitcountg used by linux emulation
583.if !(${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} < 140000)
584_iwlwifi=	iwlwifi
585.endif
586_rtw88=		rtw88
587_rtw89=		rtw89
588_vmware=	vmware
589.endif
590
591.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
592    ${MACHINE_CPUARCH} == "i386" || ${MACHINE_ARCH} == "armv7" || \
593	${MACHINE_ARCH:Mpowerpc64*} != ""
594_ossl=		ossl
595.endif
596
597# MAC framework
598.if ${KERN_OPTS:MMAC} || defined(ALL_MODULES)
599_mac_biba=	mac_biba
600_mac_bsdextended= mac_bsdextended
601.if ${KERN_OPTS:MDDB} || defined(ALL_MODULES)
602_mac_ddb=	mac_ddb
603.endif
604_mac_do=	mac_do
605_mac_ifoff=	mac_ifoff
606_mac_ipacl=	mac_ipacl
607_mac_lomac=	mac_lomac
608_mac_mls=	mac_mls
609_mac_none=	mac_none
610_mac_ntpd=	mac_ntpd
611_mac_partition=	mac_partition
612_mac_pimd=	mac_pimd
613_mac_portacl=	mac_portacl
614_mac_priority=	mac_priority
615_mac_seeotheruids= mac_seeotheruids
616_mac_stub=	mac_stub
617_mac_test=	mac_test
618.if ${MK_VERIEXEC} != "no" || defined(ALL_MODULES)
619_mac_veriexec=	mac_veriexec
620_mac_veriexec_sha1= mac_veriexec_sha1
621_mac_veriexec_sha256= mac_veriexec_sha256
622_mac_veriexec_sha384= mac_veriexec_sha384
623_mac_veriexec_sha512= mac_veriexec_sha512
624.endif
625.endif
626
627.if ${MK_NETGRAPH} != "no" || defined(ALL_MODULES)
628_netgraph=	netgraph
629.endif
630
631.if (${MK_PF} != "no" && (${MK_INET_SUPPORT} != "no" || \
632	${MK_INET6_SUPPORT} != "no")) || defined(ALL_MODULES)
633_pf=		pf
634_pflog=		pflog
635_pflow=		pflow
636.if ${MK_INET_SUPPORT} != "no"
637_pfsync=	pfsync
638.endif
639.endif
640
641.if ${MK_SOURCELESS_UCODE} != "no"
642_bce=		bce
643_fxp=		fxp
644_ispfw=		ispfw
645_ti=		ti
646_mwlfw=		mwlfw
647_otusfw=	otusfw
648_ralfw=		ralfw
649_rtwnfw=	rtwnfw
650.endif
651
652.if ${MK_SOURCELESS_UCODE} != "no" && ${MACHINE_CPUARCH} != "arm" && \
653	${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
654	${MACHINE_CPUARCH} != "riscv"
655_cxgbe=		cxgbe
656.endif
657
658# This has only been tested on amd64 and arm64
659.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64"
660_mpi3mr=mpi3mr
661.endif
662
663# Specific to the Raspberry Pi.
664.if ${MACHINE_CPUARCH} == "aarch64"
665_genet=		genet
666.endif
667
668.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64" || \
669	${MACHINE_ARCH:Mpowerpc64*}
670_ice=		ice
671.if ${MK_SOURCELESS_UCODE} != "no"
672_ice_ddp=	ice_ddp
673.endif
674.if ${MK_OFED} != "no" || defined(ALL_MODULES)
675.if ${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no"
676_irdma=		irdma
677.endif
678.endif
679.endif
680
681.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm" || \
682	${MACHINE_CPUARCH} == "riscv"
683.if !empty(OPT_FDT)
684_allwinner=	allwinner
685_if_cgem=	if_cgem
686_sdhci_fdt=	sdhci_fdt
687.endif
688.endif
689
690# These rely on 64bit atomics
691.if ${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
692_mps=		mps
693_mpr=		mpr
694.endif
695
696.if ${MK_TESTS} != "no" || defined(ALL_MODULES)
697SUBDIR+=	ktest
698SUBDIR+=	tests
699.endif
700
701.if ${MK_ZFS} != "no" || defined(ALL_MODULES)
702SUBDIR+=	zfs
703.endif
704
705.if ${MK_SOURCELESS_UCODE} != "no"
706_cxgb=		cxgb
707.endif
708
709.if ${MACHINE_CPUARCH} == "aarch64"
710_armv8crypto=	armv8crypto
711_armv8_rng=	armv8_rng
712_dpaa2=		dpaa2
713_sff=		sff
714_em=		em
715_hyperv=  hyperv
716_vf_i2c=	vf_i2c
717
718.if !empty(OPT_FDT)
719_dwwdt=		dwwdt
720_enetc=		enetc
721_felix=		felix
722_rockchip=	rockchip
723.endif
724.endif
725
726.if ${MACHINE_CPUARCH} == "arm"
727_imx=		imx
728.endif
729
730.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
731_agp=		agp
732.if ${MACHINE_CPUARCH} == "i386" || !empty(COMPAT_FREEBSD32_ENABLED)
733_aout=		aout
734.endif
735_bios=		bios
736.if ${MK_SOURCELESS_UCODE} != "no"
737_bxe=		bxe
738.endif
739_cardbus=	cardbus
740_cbb=		cbb
741_cpuctl=	cpuctl
742_cpufreq=	cpufreq
743_dpms=		dpms
744_em=		em
745_et=		et
746_ftgpio=	ftgpio
747_ftwd=		ftwd
748_exca=		exca
749_io=		io
750_itwd=		itwd
751_ix=		ix
752_ixv=		ixv
753.if ${MK_SOURCELESS_UCODE} != "no"
754_lio=		lio
755.endif
756_mana=		mana
757_mgb=		mgb
758_nctgpio=	nctgpio
759_ncthwm=	ncthwm
760_ntb=		ntb
761_ocs_fc=	ocs_fc
762_p2sb=		p2sb
763_qat_c2xxx=	qat_c2xxx
764_qat_c2xxxfw=	qat_c2xxxfw
765_safe=		safe
766_speaker=	speaker
767_splash=	splash
768_syscons=	syscons
769_wbwd=		wbwd
770_wdatwd=	wdatwd
771
772_aac=		aac
773_aacraid=	aacraid
774_acpi=		acpi
775.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
776_aesni=		aesni
777.endif
778_amd_ecc_inject=amd_ecc_inject
779_amdsmu=	amdsmu
780_amdsbwd=	amdsbwd
781_amdsmn=	amdsmn
782_amdtemp=	amdtemp
783_arcmsr=	arcmsr
784_asmc=		asmc
785.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
786_blake2=	blake2
787.endif
788_bytgpio=	bytgpio
789_chvgpio=	chvgpio
790_ciss=		ciss
791_chromebook_platform=	chromebook_platform
792_coretemp=	coretemp
793.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
794_hpt27xx=	hpt27xx
795.endif
796_hptiop=	hptiop
797.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
798_hptmv=		hptmv
799_hptnr=		hptnr
800_hptrr=		hptrr
801.endif
802_hyperv=	hyperv
803_ichwd=		ichwd
804_ida=		ida
805_intelspi=	intelspi
806_ips=		ips
807_isci=		isci
808_ipw=		ipw
809_iwi=		iwi
810_iwm=		iwm
811_iwn=		iwn
812.if ${MK_SOURCELESS_UCODE} != "no"
813_ipwfw=		ipwfw
814_iwifw=		iwifw
815_iwnfw=		iwnfw
816.endif
817_nfe=		nfe
818_nvram=		nvram
819.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
820_padlock=	padlock
821_rdrand_rng=	rdrand_rng
822_rdseed_rng=	rdseed_rng
823.endif
824_pchtherm = pchtherm
825_s3=		s3
826_sdhci_acpi=	sdhci_acpi
827_superio=	superio
828_vesa=		vesa
829_viawd=		viawd
830_vmd=		vmd
831_wpi=		wpi
832.if ${MK_SOURCELESS_UCODE} != "no"
833_wpifw=		wpifw
834.endif
835.if ${KERN_OPTS:MVIMAGE}
836_wtap=		wtap
837.endif
838_x86bios=	x86bios
839.endif
840
841.if ${MACHINE_CPUARCH} == "amd64"
842_amdgpio=	amdgpio
843_ccp=		ccp
844_enic=		enic
845_iavf=		iavf
846_ioat=		ioat
847_iwx=		iwx
848_ixl=		ixl
849_nvdimm=	nvdimm
850_pms=		pms
851_pt=		pt
852_qat=		qat
853.if ${MK_SOURCELESS_UCODE} != "no"
854_qatfw=		qatfw
855.endif
856_qlxge=		qlxge
857_qlxgb=		qlxgb
858_sume=		sume
859.if ${MK_SOURCELESS_UCODE} != "no"
860_qlxgbe=	qlxgbe
861_qlnx=		qlnx
862.endif
863_sfxge=		sfxge
864_sgx=		sgx
865_sgx_linux=	sgx_linux
866_smartpqi=	smartpqi
867_p2sb=		p2sb
868.endif
869
870.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
871_hwt=		hwt
872.endif
873
874.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
875    ${MACHINE_CPUARCH} == "riscv"
876.if ${MK_BHYVE} != "no" || defined(ALL_MODULES)
877.if ${KERN_OPTS:MSMP}
878_vmm=		vmm
879.endif
880.endif
881.endif
882
883.if ${MACHINE_CPUARCH} == "i386"
884# XXX some of these can move to the general case when de-i386'ed
885# XXX some of these can move now, but are untested on other architectures.
886_3dfx=		3dfx
887_3dfx_linux=	3dfx_linux
888_glxiic=	glxiic
889_glxsb=		glxsb
890_pcfclock=	pcfclock
891_pst=		pst
892_sbni=		sbni
893.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
894_padlock_rng=	padlock_rng
895.endif
896.endif
897
898.if ${MACHINE_ARCH} == "armv7"
899_cfi=		cfi
900_cpsw=		cpsw
901.endif
902
903.if ${MACHINE_CPUARCH} == "powerpc"
904_aacraid=	aacraid
905_agp=		agp
906_an=		an
907_cardbus=	cardbus
908_cbb=		cbb
909_cfi=		cfi
910_cpufreq=	cpufreq
911_exca=		exca
912_ffec=		ffec
913.endif
914
915.if ${MACHINE_ARCH:Mpowerpc64*} != ""
916_ixl=		ixl
917_nvram=		opal_nvram
918.endif
919
920.if ${MACHINE_CPUARCH} == "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
921# Don't build powermac_nvram for powerpcspe, it's never supported.
922_nvram+=	powermac_nvram
923.endif
924
925.if ${MACHINE_CPUARCH} == "arm" || ${MACHINE_CPUARCH} == "aarch64"
926_bcm283x_clkman=  bcm283x_clkman
927_bcm283x_pwm=	bcm283x_pwm
928_neta=		neta
929.endif
930
931.if ${MACHINE_CPUARCH} == "amd64"
932_thunderbolt=	thunderbolt
933.endif
934
935.if !(${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} < 110000)
936# LLVM 10 crashes when building if_malo_pci.c, fixed in LLVM11:
937# https://bugs.llvm.org/show_bug.cgi?id=44351
938_malo=	malo
939.endif
940
941.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64"
942_ufshci=ufshci
943.endif
944
945SUBDIR+=${MODULES_EXTRA}
946
947.for reject in ${WITHOUT_MODULES}
948SUBDIR:= ${SUBDIR:N${reject}}
949.endfor
950
951.endif # MODULES_OVERRIDE -- Keep last
952
953# Calling kldxref(8) for each module is expensive.
954.if !defined(NO_XREF)
955.MAKEFLAGS+=	-DNO_XREF
956afterinstall: .PHONY
957	${KLDXREF_CMD} ${DESTDIR}${KMODDIR}
958.if defined(NO_ROOT) && defined(METALOG)
959	echo ".${DISTBASE}${KMODDIR}/linker.hints type=file mode=0644 uname=root gname=wheel" | \
960	    cat -l >> ${METALOG}
961.endif
962.endif
963
964SUBDIR:= ${SUBDIR:u:O}
965
966.include <bsd.subdir.mk>
967