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