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