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