xref: /freebsd/sys/modules/Makefile (revision 68f185ccc9f8f9498d536f4737d888b37cf11882)
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	${_spe} \
387	${_speaker} \
388	spi \
389	${_splash} \
390	ste \
391	stge \
392	${_sume} \
393	${_superio} \
394	${_p2sb} \
395	sym \
396	${_syscons} \
397	sysvipc \
398	tarfs \
399	tcp \
400	${_thunderbolt} \
401	${_ti} \
402	tmpfs \
403	${_toecore} \
404	tpm \
405	tws \
406	uart \
407	udf \
408	udf_iconv \
409	ufs \
410	${_ufshci} \
411	uinput \
412	unionfs \
413	usb \
414	${_vesa} \
415	${_vf_i2c} \
416	virtio \
417	vge \
418	${_viawd} \
419	videomode \
420	vkbd \
421	${_vmd} \
422	${_vmm} \
423	${_vmware} \
424	vr \
425	vte \
426	${_wbwd} \
427	${_wdatwd} \
428	wlan \
429	wlan_acl \
430	wlan_amrr \
431	wlan_ccmp \
432	wlan_gcmp \
433	wlan_rssadapt \
434	wlan_tkip \
435	wlan_wep \
436	wlan_xauth \
437	${_wpi} \
438	${_wpifw} \
439	${_wtap} \
440	${_x86bios} \
441	xdr \
442	xl \
443	xz \
444	zlib
445
446.if ${MK_AUTOFS} != "no" || defined(ALL_MODULES)
447_autofs=	autofs
448.endif
449
450.if ${MK_DTRACE} != "no" || defined(ALL_MODULES)
451.if ${KERN_OPTS:MKDTRACE_HOOKS}
452SUBDIR+=	dtrace
453.endif
454SUBDIR+=	opensolaris
455.endif
456
457.if !${MACHINE_ABI:Mlong32}
458_bnxt=		bnxt
459.endif
460
461.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
462.if exists(${SRCTOP}/sys/opencrypto)
463_crypto=	crypto
464_cryptodev=	cryptodev
465_random_fortuna=random_fortuna
466_random_other=	random_other
467.endif
468.endif
469
470.if ${MK_CUSE} != "no" || defined(ALL_MODULES)
471SUBDIR+=	cuse
472.endif
473
474.if ${MK_EFI} != "no"
475.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
476_efirt=		efirt
477.endif
478.endif
479
480.if (${MK_INET_SUPPORT} != "no" || ${MK_INET6_SUPPORT} != "no") || \
481	defined(ALL_MODULES)
482_carp=		carp
483_toecore=	toecore
484_if_enc=	if_enc
485_if_gif=	if_gif
486_if_gre=	if_gre
487.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
488_if_wg=		if_wg
489.endif
490_ipfw_pmod=	ipfw_pmod
491.if ${KERN_OPTS:MIPSEC_SUPPORT} && !${KERN_OPTS:MIPSEC}
492_ipsec=		ipsec
493.endif
494.if ${KERN_OPTS:MSCTP_SUPPORT} || ${KERN_OPTS:MSCTP}
495_sctp=		sctp
496.endif
497.endif
498
499.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
500	defined(ALL_MODULES)
501_if_stf=	if_stf
502.endif
503
504.if (${KERN_OPTS:MINET} && ${MK_INET_SUPPORT} != "no") || defined(ALL_MODULES)
505_if_me=		if_me
506_ipfw=		ipfw
507.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
508_ipfw_nat64=	ipfw_nat64
509.endif
510.endif
511
512.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
513_ipfw_nptv6=	ipfw_nptv6
514.endif
515
516.if ${MK_IPFILTER} != "no" || defined(ALL_MODULES)
517_ipfilter=	ipfilter
518.endif
519
520.if ${MK_INET_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO} && ${KERN_OPTS:MINET}
521_dpdk_lpm4=	dpdk_lpm4
522_fib_dxr=	fib_dxr
523.endif
524
525.if ${MK_INET6_SUPPORT} != "no" && ${KERN_OPTS:MFIB_ALGO}
526_dpdk_lpm6=	dpdk_lpm6
527.endif
528
529.if ${MK_ISCSI} != "no" || defined(ALL_MODULES)
530SUBDIR+=	cfiscsi
531SUBDIR+=	iscsi
532.endif
533
534.if !empty(OPT_FDT)
535SUBDIR+=	fdt
536.endif
537
538# Linuxulator
539.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
540    ${MACHINE_CPUARCH} == "i386"
541SUBDIR+=	linprocfs
542SUBDIR+=	linsysfs
543.endif
544.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
545SUBDIR+=	linux
546.endif
547.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
548SUBDIR+=	linux64
549SUBDIR+=	linux_common
550.endif
551
552.if ${MACHINE_CPUARCH} != "arm"
553.if ${MK_OFED} != "no" || defined(ALL_MODULES)
554_ibcore=	ibcore
555_ipoib=		ipoib
556_iser=		iser
557_mthca=		mthca
558_rdma=		rdma
559.endif
560.endif
561
562.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
563    ${MACHINE_CPUARCH} == "i386" || ${MACHINE_ARCH:Mpowerpc64*} != ""
564_ipmi=		ipmi
565_mlx4=		mlx4
566_mlx5=		mlx5
567.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
568	defined(ALL_MODULES)
569_mlx4en=	mlx4en
570_mlx5en=	mlx5en
571.endif
572.if ${MK_OFED} != "no" || defined(ALL_MODULES)
573_mlx4ib=	mlx4ib
574_mlx5ib=	mlx5ib
575.endif
576.endif
577
578.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
579    ${MACHINE_CPUARCH} == "i386"
580_ena=		ena
581_gve=		gve
582_igc=		igc
583# gcc13 and earlier lack __builtin_bitcountg used by linux emulation
584.if !(${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} < 140000)
585_iwlwifi=	iwlwifi
586.endif
587_rtw88=		rtw88
588_rtw89=		rtw89
589_vmware=	vmware
590.endif
591
592.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
593    ${MACHINE_CPUARCH} == "i386" || ${MACHINE_ARCH} == "armv7" || \
594	${MACHINE_ARCH:Mpowerpc64*} != ""
595_ossl=		ossl
596.endif
597
598# MAC framework
599.if ${KERN_OPTS:MMAC} || defined(ALL_MODULES)
600_mac_biba=	mac_biba
601_mac_bsdextended= mac_bsdextended
602.if ${KERN_OPTS:MDDB} || defined(ALL_MODULES)
603_mac_ddb=	mac_ddb
604.endif
605_mac_do=	mac_do
606_mac_ifoff=	mac_ifoff
607_mac_ipacl=	mac_ipacl
608_mac_lomac=	mac_lomac
609_mac_mls=	mac_mls
610_mac_none=	mac_none
611_mac_ntpd=	mac_ntpd
612_mac_partition=	mac_partition
613_mac_pimd=	mac_pimd
614_mac_portacl=	mac_portacl
615_mac_priority=	mac_priority
616_mac_seeotheruids= mac_seeotheruids
617_mac_stub=	mac_stub
618_mac_test=	mac_test
619.if ${MK_VERIEXEC} != "no" || defined(ALL_MODULES)
620_mac_veriexec=	mac_veriexec
621_mac_veriexec_sha1= mac_veriexec_sha1
622_mac_veriexec_sha256= mac_veriexec_sha256
623_mac_veriexec_sha384= mac_veriexec_sha384
624_mac_veriexec_sha512= mac_veriexec_sha512
625.endif
626.endif
627
628.if ${MK_NETGRAPH} != "no" || defined(ALL_MODULES)
629_netgraph=	netgraph
630.endif
631
632.if (${MK_PF} != "no" && (${MK_INET_SUPPORT} != "no" || \
633	${MK_INET6_SUPPORT} != "no")) || defined(ALL_MODULES)
634_pf=		pf
635_pflog=		pflog
636_pflow=		pflow
637.if ${MK_INET_SUPPORT} != "no"
638_pfsync=	pfsync
639.endif
640.endif
641
642.if ${MK_SOURCELESS_UCODE} != "no"
643_bce=		bce
644_fxp=		fxp
645_ispfw=		ispfw
646_ti=		ti
647_mwlfw=		mwlfw
648_otusfw=	otusfw
649_ralfw=		ralfw
650_rtwnfw=	rtwnfw
651.endif
652
653.if ${MK_SOURCELESS_UCODE} != "no" && ${MACHINE_CPUARCH} != "arm" && \
654	${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
655	${MACHINE_CPUARCH} != "riscv"
656_cxgbe=		cxgbe
657.endif
658
659# This has only been tested on amd64 and arm64
660.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64"
661_mpi3mr=mpi3mr
662.endif
663
664# Specific to the Raspberry Pi.
665.if ${MACHINE_CPUARCH} == "aarch64"
666_genet=		genet
667.endif
668
669.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64" || \
670	${MACHINE_ARCH:Mpowerpc64*}
671_ice=		ice
672.if ${MK_SOURCELESS_UCODE} != "no"
673_ice_ddp=	ice_ddp
674.endif
675.if ${MK_OFED} != "no" || defined(ALL_MODULES)
676.if ${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no"
677_irdma=		irdma
678.endif
679.endif
680.endif
681
682.if ${MACHINE_CPUARCH} == "aarch64"
683_spe=		spe
684.endif
685
686.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm" || \
687	${MACHINE_CPUARCH} == "riscv"
688.if !empty(OPT_FDT)
689_allwinner=	allwinner
690_if_cgem=	if_cgem
691_sdhci_fdt=	sdhci_fdt
692.endif
693.endif
694
695# These rely on 64bit atomics
696.if ${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
697_mps=		mps
698_mpr=		mpr
699.endif
700
701.if ${MK_TESTS} != "no" || defined(ALL_MODULES)
702SUBDIR+=	ktest
703SUBDIR+=	tests
704.endif
705
706.if ${MK_ZFS} != "no" || defined(ALL_MODULES)
707SUBDIR+=	zfs
708.endif
709
710.if ${MK_SOURCELESS_UCODE} != "no"
711_cxgb=		cxgb
712.endif
713
714.if ${MACHINE_CPUARCH} == "aarch64"
715_armv8crypto=	armv8crypto
716_armv8_rng=	armv8_rng
717_dpaa2=		dpaa2
718_sff=		sff
719_em=		em
720_hyperv=  hyperv
721_vf_i2c=	vf_i2c
722
723.if !empty(OPT_FDT)
724_dwwdt=		dwwdt
725_enetc=		enetc
726_felix=		felix
727_rockchip=	rockchip
728.endif
729.endif
730
731.if ${MACHINE_CPUARCH} == "arm"
732_imx=		imx
733.endif
734
735.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
736_agp=		agp
737.if ${MACHINE_CPUARCH} == "i386" || !empty(COMPAT_FREEBSD32_ENABLED)
738_aout=		aout
739.endif
740_bios=		bios
741.if ${MK_SOURCELESS_UCODE} != "no"
742_bxe=		bxe
743.endif
744_cardbus=	cardbus
745_cbb=		cbb
746_cpuctl=	cpuctl
747_cpufreq=	cpufreq
748_dpms=		dpms
749_em=		em
750_et=		et
751_ftgpio=	ftgpio
752_ftwd=		ftwd
753_exca=		exca
754_io=		io
755_itwd=		itwd
756_ix=		ix
757_ixv=		ixv
758.if ${MK_SOURCELESS_UCODE} != "no"
759_lio=		lio
760.endif
761_mana=		mana
762_mgb=		mgb
763_nctgpio=	nctgpio
764_ncthwm=	ncthwm
765_ntb=		ntb
766_ocs_fc=	ocs_fc
767_p2sb=		p2sb
768_qat_c2xxx=	qat_c2xxx
769_qat_c2xxxfw=	qat_c2xxxfw
770_safe=		safe
771_speaker=	speaker
772_splash=	splash
773_syscons=	syscons
774_wbwd=		wbwd
775_wdatwd=	wdatwd
776
777_aac=		aac
778_aacraid=	aacraid
779_acpi=		acpi
780.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
781_aesni=		aesni
782.endif
783_amd_ecc_inject=amd_ecc_inject
784_amdsmu=	amdsmu
785_amdsbwd=	amdsbwd
786_amdsmn=	amdsmn
787_amdtemp=	amdtemp
788_arcmsr=	arcmsr
789_asmc=		asmc
790.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
791_blake2=	blake2
792.endif
793_bytgpio=	bytgpio
794_chvgpio=	chvgpio
795_ciss=		ciss
796_chromebook_platform=	chromebook_platform
797_coretemp=	coretemp
798.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
799_hpt27xx=	hpt27xx
800.endif
801_hptiop=	hptiop
802.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
803_hptmv=		hptmv
804_hptnr=		hptnr
805_hptrr=		hptrr
806.endif
807_hyperv=	hyperv
808_ichwd=		ichwd
809_ida=		ida
810_intelspi=	intelspi
811_ips=		ips
812_isci=		isci
813_ipw=		ipw
814_iwi=		iwi
815_iwm=		iwm
816_iwn=		iwn
817.if ${MK_SOURCELESS_UCODE} != "no"
818_ipwfw=		ipwfw
819_iwifw=		iwifw
820_iwnfw=		iwnfw
821.endif
822_nfe=		nfe
823_nvram=		nvram
824.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
825_padlock=	padlock
826_rdrand_rng=	rdrand_rng
827_rdseed_rng=	rdseed_rng
828.endif
829_pchtherm = pchtherm
830_s3=		s3
831_sdhci_acpi=	sdhci_acpi
832_superio=	superio
833_vesa=		vesa
834_viawd=		viawd
835_vmd=		vmd
836_wpi=		wpi
837.if ${MK_SOURCELESS_UCODE} != "no"
838_wpifw=		wpifw
839.endif
840.if ${KERN_OPTS:MVIMAGE}
841_wtap=		wtap
842.endif
843_x86bios=	x86bios
844.endif
845
846.if ${MACHINE_CPUARCH} == "amd64"
847_amdgpio=	amdgpio
848_ccp=		ccp
849_enic=		enic
850_iavf=		iavf
851_ioat=		ioat
852_iwx=		iwx
853_ixl=		ixl
854_nvdimm=	nvdimm
855_pms=		pms
856_pt=		pt
857_qat=		qat
858.if ${MK_SOURCELESS_UCODE} != "no"
859_qatfw=		qatfw
860.endif
861_qlxge=		qlxge
862_qlxgb=		qlxgb
863_sume=		sume
864.if ${MK_SOURCELESS_UCODE} != "no"
865_qlxgbe=	qlxgbe
866_qlnx=		qlnx
867.endif
868_sfxge=		sfxge
869_sgx=		sgx
870_sgx_linux=	sgx_linux
871_smartpqi=	smartpqi
872_p2sb=		p2sb
873.endif
874
875.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
876_hwt=		hwt
877.endif
878
879.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
880    ${MACHINE_CPUARCH} == "riscv"
881.if ${MK_BHYVE} != "no" || defined(ALL_MODULES)
882.if ${KERN_OPTS:MSMP}
883_vmm=		vmm
884.endif
885.endif
886.endif
887
888.if ${MACHINE_CPUARCH} == "i386"
889# XXX some of these can move to the general case when de-i386'ed
890# XXX some of these can move now, but are untested on other architectures.
891_3dfx=		3dfx
892_3dfx_linux=	3dfx_linux
893_glxiic=	glxiic
894_glxsb=		glxsb
895_pcfclock=	pcfclock
896_pst=		pst
897_sbni=		sbni
898.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
899_padlock_rng=	padlock_rng
900.endif
901.endif
902
903.if ${MACHINE_ARCH} == "armv7"
904_cfi=		cfi
905_cpsw=		cpsw
906.endif
907
908.if ${MACHINE_CPUARCH} == "powerpc"
909_aacraid=	aacraid
910_agp=		agp
911_an=		an
912_cardbus=	cardbus
913_cbb=		cbb
914_cfi=		cfi
915_cpufreq=	cpufreq
916_exca=		exca
917_ffec=		ffec
918.endif
919
920.if ${MACHINE_ARCH:Mpowerpc64*} != ""
921_ixl=		ixl
922_nvram=		opal_nvram
923.endif
924
925.if ${MACHINE_CPUARCH} == "powerpc" && ${MACHINE_ARCH} != "powerpcspe"
926# Don't build powermac_nvram for powerpcspe, it's never supported.
927_nvram+=	powermac_nvram
928.endif
929
930.if ${MACHINE_CPUARCH} == "arm" || ${MACHINE_CPUARCH} == "aarch64"
931_bcm283x_clkman=  bcm283x_clkman
932_bcm283x_pwm=	bcm283x_pwm
933_neta=		neta
934.endif
935
936.if ${MACHINE_CPUARCH} == "amd64"
937_thunderbolt=	thunderbolt
938.endif
939
940.if !(${COMPILER_TYPE} == "clang" && ${COMPILER_VERSION} < 110000)
941# LLVM 10 crashes when building if_malo_pci.c, fixed in LLVM11:
942# https://bugs.llvm.org/show_bug.cgi?id=44351
943_malo=	malo
944.endif
945
946.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "aarch64"
947_ufshci=ufshci
948.endif
949
950SUBDIR+=${MODULES_EXTRA}
951
952.for reject in ${WITHOUT_MODULES}
953SUBDIR:= ${SUBDIR:N${reject}}
954.endfor
955
956.endif # MODULES_OVERRIDE -- Keep last
957
958# Calling kldxref(8) for each module is expensive.
959.if !defined(NO_XREF)
960.MAKEFLAGS+=	-DNO_XREF
961afterinstall: .PHONY
962	${KLDXREF_CMD} ${DESTDIR}${KMODDIR}
963.if defined(NO_ROOT) && defined(METALOG)
964	echo ".${DISTBASE}${KMODDIR}/linker.hints type=file mode=0644 uname=root gname=wheel" | \
965	    cat -l >> ${METALOG}
966.endif
967.endif
968
969SUBDIR:= ${SUBDIR:u:O}
970
971.include <bsd.subdir.mk>
972