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