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