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