xref: /freebsd/sys/modules/Makefile (revision 473957941922d17be72089e385e2e2a995fd0e1c)
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	amr \
42	${_an} \
43	${_aout} \
44	${_apm} \
45	${_arcmsr} \
46	${_allwinner} \
47	${_armv8crypto} \
48	${_asmc} \
49	ata \
50	ath \
51	ath_dfs \
52	ath_hal \
53	ath_hal_ar5210 \
54	ath_hal_ar5211 \
55	ath_hal_ar5212 \
56	ath_hal_ar5416 \
57	ath_hal_ar9300 \
58	ath_main \
59	ath_rate \
60	ath_pci \
61	${_autofs} \
62	${_bce} \
63	${_bcm283x_clkman} \
64	${_bcm283x_pwm} \
65	bfe \
66	bge \
67	bhnd \
68	${_bxe} \
69	${_bios} \
70	${_bktr} \
71	${_blake2} \
72	bnxt \
73	bridgestp \
74	bwi \
75	bwn \
76	${_bytgpio} \
77	${_chvgpio} \
78	cam \
79	${_cardbus} \
80	${_carp} \
81	cas \
82	${_cbb} \
83	cc \
84	${_ccp} \
85	cd9660 \
86	cd9660_iconv \
87	${_ce} \
88	${_cfi} \
89	${_chromebook_platform} \
90	${_ciss} \
91	cloudabi \
92	${_cloudabi32} \
93	${_cloudabi64} \
94	${_cmx} \
95	${_coretemp} \
96	${_cp} \
97	${_cpsw} \
98	${_cpuctl} \
99	${_cpufreq} \
100	${_crypto} \
101	${_cryptodev} \
102	${_ctau} \
103	ctl \
104	${_cxgb} \
105	${_cxgbe} \
106	dc \
107	dcons \
108	dcons_crom \
109	${_dpms} \
110	dummynet \
111	${_efirt} \
112	${_em} \
113	${_ena} \
114	esp \
115	${_et} \
116	evdev \
117	${_exca} \
118	ext2fs \
119	fdc \
120	fdescfs \
121	${_ffec} \
122	filemon \
123	firewire \
124	firmware \
125	fusefs \
126	${_fxp} \
127	gem \
128	geom \
129	${_glxiic} \
130	${_glxsb} \
131	gpio \
132	hifn \
133	hme \
134	${_hpt27xx} \
135	${_hptiop} \
136	${_hptmv} \
137	${_hptnr} \
138	${_hptrr} \
139	hwpmc \
140	${_hwpmc_mips24k} \
141	${_hwpmc_mips74k} \
142	${_hyperv} \
143	i2c \
144	${_iavf} \
145        ${_ibcore} \
146	${_ichwd} \
147	${_ida} \
148	if_bridge \
149	if_disc \
150	if_edsc \
151	${_if_enc} \
152	if_epair \
153	${_if_gif} \
154	${_if_gre} \
155	${_if_me} \
156	if_lagg \
157	${_if_ndis} \
158	${_if_stf} \
159	if_tuntap \
160	if_vlan \
161	if_vxlan \
162	iflib \
163	${_iir} \
164	imgact_binmisc \
165	${_intelspi} \
166	${_io} \
167	${_ioat} \
168        ${_ipoib} \
169	${_ipdivert} \
170	${_ipfilter} \
171	${_ipfw} \
172	ipfw_nat \
173	${_ipfw_nat64} \
174	${_ipfw_nptv6} \
175	${_ipfw_pmod} \
176	${_ipmi} \
177	ip6_mroute_mod \
178	ip_mroute_mod \
179	${_ips} \
180	${_ipsec} \
181	${_ipw} \
182	${_ipwfw} \
183	${_isci} \
184	${_iser} \
185	isp \
186	${_ispfw} \
187	${_itwd} \
188	${_iwi} \
189	${_iwifw} \
190	${_iwm} \
191	${_iwmfw} \
192	${_iwn} \
193	${_iwnfw} \
194	${_ix} \
195	${_ixv} \
196	${_ixl} \
197	jme \
198	kbdmux \
199	kgssapi \
200	kgssapi_krb5 \
201	khelp \
202	krpc \
203	ksyms \
204	${_ktls_ocf} \
205	le \
206	lge \
207	libalias \
208	libiconv \
209	libmchain \
210	lindebugfs \
211	linuxkpi \
212	${_lio} \
213	lpt \
214	mac_biba \
215	mac_bsdextended \
216	mac_ifoff \
217	mac_lomac \
218	mac_mls \
219	mac_none \
220	mac_ntpd \
221	mac_partition \
222	mac_portacl \
223	mac_seeotheruids \
224	mac_stub \
225	mac_test \
226	malo \
227	md \
228	mdio \
229	mem \
230	mfi \
231	mii \
232	mlx \
233	mlxfw \
234	${_mlx4} \
235	${_mlx4ib} \
236	${_mlx4en} \
237	${_mlx5} \
238	${_mlx5en} \
239	${_mlx5ib} \
240	${_mly} \
241	mmc \
242	mmcsd \
243	${_mpr} \
244	${_mps} \
245	mpt \
246	mqueue \
247	mrsas \
248	msdosfs \
249	msdosfs_iconv \
250	msk \
251	${_mthca} \
252	mvs \
253	mwl \
254	${_mwlfw} \
255	mxge \
256	my \
257	${_nctgpio} \
258	${_ndis} \
259	${_netgraph} \
260	${_nfe} \
261	nfscl \
262	nfscommon \
263	nfsd \
264	nfslock \
265	nfslockd \
266	nfssvc \
267	nge \
268	nmdm \
269	nullfs \
270	${_ntb} \
271	${_nvd} \
272	${_nvdimm} \
273	${_nvme} \
274	${_nvram} \
275	oce \
276	${_ocs_fc} \
277	otus \
278	${_otusfw} \
279	ow \
280	${_padlock} \
281	${_padlock_rng} \
282	${_pccard} \
283	${_pcfclock} \
284	${_pf} \
285	${_pflog} \
286	${_pfsync} \
287	plip \
288	${_pms} \
289	ppbus \
290	ppc \
291	ppi \
292	pps \
293	procfs \
294	proto \
295	pseudofs \
296	${_pst} \
297	pty  \
298	puc \
299	pwm \
300	${_qlxge} \
301	${_qlxgb} \
302	${_qlxgbe} \
303	${_qlnx} \
304	ral \
305	${_ralfw} \
306	${_random_fortuna} \
307	${_random_other} \
308	rc4 \
309	${_rdma} \
310	${_rdrand_rng} \
311	re \
312	rl \
313	${_rockchip} \
314	rtwn \
315	rtwn_pci \
316	rtwn_usb \
317	${_rtwnfw} \
318	${_s3} \
319	${_safe} \
320	${_sbni} \
321	scc \
322	sdhci \
323	${_sdhci_acpi} \
324	sdhci_pci \
325	sdio \
326	sem \
327	send \
328	${_sfxge} \
329	sge \
330	${_sgx} \
331	${_sgx_linux} \
332	siftr \
333	siis \
334	sis \
335	sk \
336	${_smartpqi} \
337	smbfs \
338	snp \
339	sound \
340	${_speaker} \
341	spi \
342	${_splash} \
343	${_sppp} \
344	ste \
345	stge \
346	${_superio} \
347	${_sym} \
348	${_syscons} \
349	sysvipc \
350	tcp \
351	${_ti} \
352	tmpfs \
353	${_toecore} \
354	${_tpm} \
355	${_twa} \
356	twe \
357	tws \
358	uart \
359	ubsec \
360	udf \
361	udf_iconv \
362	ufs \
363	uinput \
364	unionfs \
365	usb \
366	${_vesa} \
367	${_virtio} \
368	vge \
369	${_viawd} \
370	videomode \
371	vkbd \
372	${_vmd} \
373	${_vmm} \
374	${_vmware} \
375	vr \
376	vte \
377	${_wbwd} \
378	${_wi} \
379	wlan \
380	wlan_acl \
381	wlan_amrr \
382	wlan_ccmp \
383	wlan_rssadapt \
384	wlan_tkip \
385	wlan_wep \
386	wlan_xauth \
387	${_wpi} \
388	${_wpifw} \
389	${_x86bios} \
390	xl \
391	xz \
392	zlib
393
394.if ${MK_AUTOFS} != "no" || defined(ALL_MODULES)
395_autofs=	autofs
396.endif
397
398.if ${MK_CDDL} != "no" || defined(ALL_MODULES)
399.if (${MACHINE_CPUARCH} != "arm" || ${MACHINE_ARCH:Marmv[67]*} != "") && \
400	${MACHINE_CPUARCH} != "mips"
401.if ${KERN_OPTS:MKDTRACE_HOOKS}
402SUBDIR+=	dtrace
403.endif
404.endif
405SUBDIR+=	opensolaris
406.endif
407
408.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
409.if exists(${SRCTOP}/sys/opencrypto)
410_crypto=	crypto
411_cryptodev=	cryptodev
412_random_fortuna=random_fortuna
413_random_other=	random_other
414_ktls_ocf=	ktls_ocf
415.endif
416.endif
417
418.if ${MK_CUSE} != "no" || defined(ALL_MODULES)
419SUBDIR+=	cuse
420.endif
421
422.if (${MK_INET_SUPPORT} != "no" || ${MK_INET6_SUPPORT} != "no") || \
423	defined(ALL_MODULES)
424_carp=		carp
425_toecore=	toecore
426_if_enc=	if_enc
427_if_gif=	if_gif
428_if_gre=	if_gre
429_ipfw_pmod=	ipfw_pmod
430.if ${MK_IPSEC_SUPPORT} != "no"
431_ipsec=		ipsec
432.endif
433.endif
434
435.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
436	defined(ALL_MODULES)
437_if_stf=	if_stf
438.endif
439
440.if ${MK_INET_SUPPORT} != "no" || defined(ALL_MODULES)
441_if_me=		if_me
442_ipdivert=	ipdivert
443_ipfw=		ipfw
444.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
445_ipfw_nat64=	ipfw_nat64
446.endif
447.endif
448
449.if ${MK_INET6_SUPPORT} != "no" || defined(ALL_MODULES)
450_ipfw_nptv6=	ipfw_nptv6
451.endif
452
453.if ${MK_IPFILTER} != "no" || defined(ALL_MODULES)
454_ipfilter=	ipfilter
455.endif
456
457.if ${MK_ISCSI} != "no" || defined(ALL_MODULES)
458SUBDIR+=	cfiscsi
459SUBDIR+=	iscsi
460SUBDIR+=	iscsi_initiator
461.endif
462
463.if !empty(OPT_FDT)
464SUBDIR+=	fdt
465.endif
466
467# Linuxulator
468.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
469    ${MACHINE_CPUARCH} == "i386"
470SUBDIR+=	linprocfs
471SUBDIR+=	linsysfs
472.endif
473.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
474SUBDIR+=	linux
475.endif
476.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
477SUBDIR+=	linux64
478SUBDIR+=	linux_common
479.endif
480
481.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
482    ${MACHINE_CPUARCH} == "i386"
483_ena=		ena
484.if ${MK_OFED} != "no" || defined(ALL_MODULES)
485_ibcore=	ibcore
486_ipoib=		ipoib
487_iser=		iser
488.endif
489_mlx4=		mlx4
490_mlx5=		mlx5
491.if (${MK_INET_SUPPORT} != "no" && ${MK_INET6_SUPPORT} != "no") || \
492	defined(ALL_MODULES)
493_mlx4en=	mlx4en
494_mlx5en=	mlx5en
495.endif
496.if ${MK_OFED} != "no" || defined(ALL_MODULES)
497_mthca=		mthca
498_mlx4ib=	mlx4ib
499_mlx5ib=	mlx5ib
500.endif
501.endif
502
503.if ${MK_NETGRAPH} != "no" || defined(ALL_MODULES)
504_netgraph=	netgraph
505.endif
506
507.if (${MK_PF} != "no" && (${MK_INET_SUPPORT} != "no" || \
508	${MK_INET6_SUPPORT} != "no")) || defined(ALL_MODULES)
509_pf=		pf
510_pflog=		pflog
511.if ${MK_INET_SUPPORT} != "no"
512_pfsync=	pfsync
513.endif
514.endif
515
516.if ${MK_SOURCELESS_UCODE} != "no"
517_bce=		bce
518_fxp=		fxp
519_ispfw=		ispfw
520_ti=		ti
521
522.if ${MACHINE_CPUARCH} != "mips"
523_mwlfw=		mwlfw
524_otusfw=	otusfw
525_ralfw=		ralfw
526_rtwnfw=	rtwnfw
527.endif
528.endif
529
530.if ${MK_SOURCELESS_UCODE} != "no" && ${MACHINE_CPUARCH} != "arm" && \
531	${MACHINE_CPUARCH} != "mips" && \
532	${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
533	${MACHINE_CPUARCH} != "riscv"
534_cxgbe=		cxgbe
535.endif
536
537# These rely on 64bit atomics
538.if ${MACHINE_ARCH} != "powerpc" && ${MACHINE_ARCH} != "powerpcspe" && \
539	${MACHINE_CPUARCH} != "mips"
540_mps=		mps
541_mpr=		mpr
542.endif
543
544.if ${MK_TESTS} != "no" || defined(ALL_MODULES)
545SUBDIR+=	tests
546.endif
547
548.if ${MK_ZFS} != "no" || defined(ALL_MODULES)
549SUBDIR+=	zfs
550.endif
551
552.if (${MACHINE_CPUARCH} == "mips" && ${MACHINE_ARCH:Mmips64} == "")
553_hwpmc_mips24k=	hwpmc_mips24k
554_hwpmc_mips74k=	hwpmc_mips74k
555.endif
556
557.if ${MACHINE_CPUARCH} != "aarch64" && ${MACHINE_CPUARCH} != "arm" && \
558	${MACHINE_CPUARCH} != "mips" && ${MACHINE_CPUARCH} != "powerpc" && \
559	${MACHINE_CPUARCH} != "riscv"
560_syscons=	syscons
561.endif
562
563.if ${MACHINE_CPUARCH} != "mips"
564# no BUS_SPACE_UNSPECIFIED
565# No barrier instruction support (specific to this driver)
566_sym=		sym
567# intr_disable() is a macro, causes problems
568.if ${MK_SOURCELESS_UCODE} != "no"
569_cxgb=		cxgb
570.endif
571.endif
572
573.if ${MACHINE_CPUARCH} == "aarch64"
574_allwinner=	allwinner
575_armv8crypto=	armv8crypto
576_efirt=		efirt
577_em=		em
578_rockchip=	rockchip
579.endif
580
581.if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
582_agp=		agp
583_an=		an
584_aout=		aout
585_bios=		bios
586_bktr=		bktr
587.if ${MK_SOURCELESS_UCODE} != "no"
588_bxe=		bxe
589.endif
590_cardbus=	cardbus
591_cbb=		cbb
592_cpuctl=	cpuctl
593_cpufreq=	cpufreq
594_dpms=		dpms
595_em=		em
596_et=		et
597_exca=		exca
598_if_ndis=	if_ndis
599_io=		io
600_itwd=		itwd
601_ix=		ix
602_ixv=		ixv
603.if ${MK_SOURCELESS_UCODE} != "no"
604_lio=		lio
605.endif
606_nctgpio=	nctgpio
607_ndis=		ndis
608_ntb=		ntb
609_ocs_fc=	ocs_fc
610_pccard=	pccard
611.if ${MK_OFED} != "no" || defined(ALL_MODULES)
612_rdma=		rdma
613.endif
614_safe=		safe
615_speaker=	speaker
616_splash=	splash
617_sppp=		sppp
618_vmware=	vmware
619_wbwd=		wbwd
620_wi=		wi
621
622_aac=		aac
623_aacraid=	aacraid
624_acpi=		acpi
625.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
626.if ${COMPILER_TYPE} != "gcc" || ${COMPILER_VERSION} > 40201
627_aesni=		aesni
628.endif
629.endif
630_amd_ecc_inject=amd_ecc_inject
631_amdsbwd=	amdsbwd
632_amdsmn=	amdsmn
633_amdtemp=	amdtemp
634_arcmsr=	arcmsr
635_asmc=		asmc
636.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
637_blake2=	blake2
638.endif
639_bytgpio=	bytgpio
640_chvgpio=	chvgpio
641_ciss=		ciss
642_chromebook_platform=	chromebook_platform
643_cmx=		cmx
644_coretemp=	coretemp
645.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
646_hpt27xx=	hpt27xx
647.endif
648_hptiop=	hptiop
649.if ${MK_SOURCELESS_HOST} != "no" && empty(KCSAN_ENABLED)
650_hptmv=		hptmv
651_hptnr=		hptnr
652_hptrr=		hptrr
653.endif
654_hyperv=	hyperv
655_ichwd=		ichwd
656_ida=		ida
657_iir=		iir
658_intelspi=	intelspi
659_ipmi=		ipmi
660_ips=		ips
661_isci=		isci
662_ipw=		ipw
663_iwi=		iwi
664_iwm=		iwm
665_iwn=		iwn
666.if ${MK_SOURCELESS_UCODE} != "no"
667_ipwfw=		ipwfw
668_iwifw=		iwifw
669_iwmfw=		iwmfw
670_iwnfw=		iwnfw
671.endif
672_mly=		mly
673_nfe=		nfe
674_nvd=		nvd
675_nvme=		nvme
676_nvram=		nvram
677.if ${MK_CRYPT} != "no" || defined(ALL_MODULES)
678_padlock=	padlock
679_padlock_rng=	padlock_rng
680_rdrand_rng=	rdrand_rng
681.endif
682_s3=		s3
683_sdhci_acpi=	sdhci_acpi
684_superio=	superio
685_tpm=		tpm
686_twa=		twa
687_vesa=		vesa
688_viawd=		viawd
689_virtio=	virtio
690_wpi=		wpi
691.if ${MK_SOURCELESS_UCODE} != "no"
692_wpifw=		wpifw
693.endif
694_x86bios=	x86bios
695.endif
696
697.if ${MACHINE_CPUARCH} == "amd64"
698_amdgpio=	amdgpio
699_ccp=		ccp
700_efirt=		efirt
701_iavf=		iavf
702_ioat=		ioat
703_ixl=		ixl
704_nvdimm=	nvdimm
705_pms=		pms
706_qlxge=		qlxge
707_qlxgb=		qlxgb
708_vmd=		vmd
709.if ${MK_SOURCELESS_UCODE} != "no"
710_qlxgbe=	qlxgbe
711_qlnx=		qlnx
712.endif
713_sfxge=		sfxge
714_sgx=		sgx
715_sgx_linux=	sgx_linux
716_smartpqi=	smartpqi
717
718.if ${MK_BHYVE} != "no" || defined(ALL_MODULES)
719.if ${KERN_OPTS:MSMP}
720_vmm=		vmm
721.endif
722.endif
723.endif
724
725.if ${MACHINE_CPUARCH} == "i386"
726# XXX some of these can move to the general case when de-i386'ed
727# XXX some of these can move now, but are untested on other architectures.
728_3dfx=		3dfx
729_3dfx_linux=	3dfx_linux
730_apm=		apm
731.if ${MK_SOURCELESS_HOST} != "no"
732_ce=		ce
733.endif
734.if ${MK_SOURCELESS_UCODE} != "no"
735_cp=		cp
736.endif
737_glxiic=	glxiic
738_glxsb=		glxsb
739_pcfclock=	pcfclock
740_pst=		pst
741_sbni=		sbni
742.if ${MK_SOURCELESS_UCODE} != "no"
743_ctau=		ctau
744.endif
745.endif
746
747.if ${MACHINE_CPUARCH} == "arm"
748_cfi=		cfi
749_cpsw=		cpsw
750.endif
751
752.if ${MACHINE_CPUARCH} == "powerpc"
753_agp=		agp
754_an=		an
755_cardbus=	cardbus
756_cbb=		cbb
757_cfi=		cfi
758_cpufreq=	cpufreq
759_exca=		exca
760_ffec=		ffec
761_nvd=		nvd
762_nvme=		nvme
763_pccard=	pccard
764_wi=		wi
765_virtio=	virtio
766.endif
767
768.if ${MACHINE_ARCH} == "powerpc64"
769_ipmi=		ipmi
770_nvram=		opal_nvram
771.endif
772.if ${MACHINE_ARCH} == "powerpc64" || ${MACHINE_ARCH} == "powerpc"
773# Don't build powermac_nvram for powerpcspe, it's never supported.
774_nvram+=	powermac_nvram
775.endif
776
777.if (${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64" || \
778     ${MACHINE_ARCH:Marmv[67]*} != "" || ${MACHINE_CPUARCH} == "i386")
779_cloudabi32=	cloudabi32
780.endif
781.if ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "amd64"
782_cloudabi64=	cloudabi64
783.endif
784
785.endif
786
787.if ${MACHINE_ARCH:Marmv[67]*} != "" || ${MACHINE_CPUARCH} == "aarch64"
788_bcm283x_clkman=  bcm283x_clkman
789_bcm283x_pwm=  bcm283x_pwm
790.endif
791
792SUBDIR+=${MODULES_EXTRA}
793
794.for reject in ${WITHOUT_MODULES}
795SUBDIR:= ${SUBDIR:N${reject}}
796.endfor
797
798# Calling kldxref(8) for each module is expensive.
799.if !defined(NO_XREF)
800.MAKEFLAGS+=	-DNO_XREF
801afterinstall: .PHONY
802	@if type kldxref >/dev/null 2>&1; then \
803		${ECHO} ${KLDXREF_CMD} ${DESTDIR}${KMODDIR}; \
804		${KLDXREF_CMD} ${DESTDIR}${KMODDIR}; \
805	fi
806.endif
807
808SUBDIR:= ${SUBDIR:u:O}
809
810.include <bsd.subdir.mk>
811