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