xref: /freebsd/sys/contrib/openzfs/module/Makefile.bsd (revision 187d8a3ce55a4e2d41fbe61465d5ff4ac0fc6bd5)
1.if !defined(WITH_CTF)
2WITH_CTF=1
3.endif
4
5.include <bsd.sys.mk>
6
7SRCDIR=${.CURDIR}
8INCDIR=${.CURDIR:H}/include
9
10KMOD=	openzfs
11
12.PATH:	${SRCDIR}/avl \
13	${SRCDIR}/lua \
14	${SRCDIR}/nvpair \
15	${SRCDIR}/icp/algs/blake3 \
16	${SRCDIR}/icp/algs/edonr \
17	${SRCDIR}/icp/algs/sha2 \
18	${SRCDIR}/icp/asm-aarch64/blake3 \
19	${SRCDIR}/icp/asm-aarch64/sha2 \
20	${SRCDIR}/icp/asm-arm/sha2 \
21	${SRCDIR}/icp/asm-ppc64/sha2 \
22	${SRCDIR}/icp/asm-ppc64/blake3 \
23	${SRCDIR}/icp/asm-x86_64/blake3 \
24	${SRCDIR}/icp/asm-x86_64/sha2 \
25	${SRCDIR}/os/freebsd/spl \
26	${SRCDIR}/os/freebsd/zfs \
27	${SRCDIR}/unicode \
28	${SRCDIR}/zcommon \
29	${SRCDIR}/zfs \
30	${SRCDIR}/zstd \
31	${SRCDIR}/zstd/lib/common \
32	${SRCDIR}/zstd/lib/compress \
33	${SRCDIR}/zstd/lib/decompress
34
35CFLAGS+= -I${INCDIR}
36CFLAGS+= -I${SRCDIR}/icp/include
37CFLAGS+= -I${INCDIR}/os/freebsd
38CFLAGS+= -I${INCDIR}/os/freebsd/spl
39CFLAGS+= -I${INCDIR}/os/freebsd/zfs
40CFLAGS+= -I${SRCDIR}/zstd/include
41CFLAGS+= -include ${INCDIR}/sys/simd_config.h
42CFLAGS+= -include ${INCDIR}/os/freebsd/spl/sys/ccompile.h
43CFLAGS+= -I${.CURDIR}
44
45CFLAGS+= -D__KERNEL__ -DFREEBSD_NAMECACHE -DBUILDING_ZFS -D__BSD_VISIBLE=1 \
46	-DHAVE_UIO_ZEROCOPY -DWITHOUT_NETDUMP -D__KERNEL -D_SYS_CONDVAR_H_ \
47	-D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DCOMPAT_FREEBSD11
48
49.if ${MACHINE_ARCH} == "amd64"
50CFLAGS+= -D__x86_64 -DHAVE_TOOLCHAIN_SSE2 -DHAVE_TOOLCHAIN_SSSE3 \
51	-DHAVE_TOOLCHAIN_SSE4_1 -DHAVE_TOOLCHAIN_AVX -DHAVE_TOOLCHAIN_AVX2 \
52	-DHAVE_TOOLCHAIN_AVX512F -DHAVE_TOOLCHAIN_AVX512VL \
53	-DHAVE_TOOLCHAIN_AVX512BW
54.endif
55
56.if defined(WITH_DEBUG) && ${WITH_DEBUG} == "true"
57CFLAGS+= -DZFS_DEBUG -g
58.if defined(WITH_INVARIANTS) && ${WITH_INVARIANTS} == "true"
59 CFLAGS+= -DINVARIANTS -DWITNESS -DOPENSOLARIS_WITNESS
60.endif
61.if defined(WITH_O0) && ${WITH_O0} == "true"
62 CFLAGS+= -O0
63.endif
64.else
65CFLAGS += -DNDEBUG
66.endif
67
68.if defined(WITH_GCOV) && ${WITH_GCOV} == "true"
69CFLAGS+=	 -fprofile-arcs -ftest-coverage
70.endif
71
72DEBUG_FLAGS=-g
73
74.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
75	${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
76CFLAGS+= -DBITS_PER_LONG=32
77.else
78CFLAGS+= -DBITS_PER_LONG=64
79.endif
80
81SRCS=	vnode_if.h device_if.h bus_if.h
82
83#avl
84SRCS+=	avl.c
85
86#icp/algs/blake3
87SRCS+=	blake3.c \
88	blake3_generic.c \
89	blake3_impl.c
90
91.if ${MACHINE_ARCH} == "aarch64"
92#icp/asm-aarch64/blake3
93SRCS+=	b3_aarch64_sse2.S \
94	b3_aarch64_sse41.S
95.endif
96
97.if ${MACHINE_ARCH} == "powerpc64le"
98#icp/asm-ppc64/blake3
99SRCS+=	b3_ppc64le_sse2.S \
100	b3_ppc64le_sse41.S
101.endif
102
103.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
104#icp/asm-x86_64/blake3
105SRCS+=	blake3_avx2.S \
106	blake3_avx512.S \
107	blake3_sse2.S \
108	blake3_sse41.S
109.endif
110
111#icp/algs/edonr
112SRCS+=	edonr.c
113
114#icp/algs/sha2
115SRCS+=	sha256_impl.c \
116	sha2_generic.c \
117	sha512_impl.c
118
119.if ${MACHINE_ARCH} == "armv7"
120#icp/asm-arm/sha2
121SRCS+=	sha256-armv7.S \
122	sha512-armv7.S
123.endif
124
125.if ${MACHINE_ARCH} == "aarch64"
126#icp/asm-aarch64/sha2
127SRCS+=	sha256-armv8.S \
128	sha512-armv8.S
129.endif
130
131.if ${MACHINE_ARCH} == "powerpc64" || ${MACHINE_ARCH} == "powerpc64le"
132#icp/asm-ppc64/sha2
133SRCS+=	sha256-p8.S \
134	sha256-ppc.S \
135	sha512-p8.S \
136	sha512-ppc.S
137.endif
138
139.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
140#icp/asm-x86_64/sha2
141SRCS+=	sha256-x86_64.S \
142	sha512-x86_64.S
143.endif
144
145#lua
146SRCS+=	lapi.c \
147	lauxlib.c \
148	lbaselib.c \
149	lcode.c \
150	lcompat.c \
151	lcorolib.c \
152	lctype.c \
153	ldebug.c \
154	ldo.c \
155	lfunc.c \
156	lgc.c \
157	llex.c \
158	lmem.c \
159	lobject.c \
160	lopcodes.c \
161	lparser.c \
162	lstate.c \
163	lstring.c \
164	lstrlib.c \
165	ltable.c \
166	ltablib.c \
167	ltm.c \
168	lvm.c \
169	lzio.c
170
171#nvpair
172SRCS+=	fnvpair.c \
173	nvpair.c \
174	nvpair_alloc_fixed.c \
175	nvpair_alloc_spl.c
176
177#os/freebsd/spl
178SRCS+=	acl_common.c \
179	callb.c \
180	list.c \
181	spl_acl.c \
182	spl_cmn_err.c \
183	spl_dtrace.c \
184	spl_kmem.c \
185	spl_kstat.c \
186	spl_misc.c \
187	spl_policy.c \
188	spl_procfs_list.c \
189	spl_string.c \
190	spl_sunddi.c \
191	spl_sysevent.c \
192	spl_taskq.c \
193	spl_uio.c \
194	spl_vfs.c \
195	spl_vm.c \
196	spl_zlib.c \
197	spl_zone.c
198
199.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
200	${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
201SRCS+= spl_atomic.c
202.endif
203
204#os/freebsd/zfs
205SRCS+=	abd_os.c \
206	arc_os.c \
207	crypto_os.c \
208	dmu_os.c \
209	event_os.c \
210	hkdf.c \
211	kmod_core.c \
212	spa_os.c \
213	sysctl_os.c \
214	vdev_geom.c \
215	vdev_label_os.c \
216	zfs_acl.c \
217	zfs_ctldir.c \
218	zfs_crrd.c \
219	zfs_debug.c \
220	zfs_dir.c \
221	zfs_file_os.c \
222	zfs_ioctl_compat.c \
223	zfs_ioctl_os.c \
224	zfs_racct.c \
225	zfs_vfsops.c \
226	zfs_vnops_os.c \
227	zfs_znode_os.c \
228	zio_crypt.c \
229	zvol_os.c
230
231#zcommon
232SRCS+=	cityhash.c \
233	zfeature_common.c \
234	zfs_comutil.c \
235	zfs_deleg.c \
236	zfs_fletcher_avx512.c \
237	zfs_fletcher.c \
238	zfs_fletcher_intel.c \
239	zfs_fletcher_sse.c \
240	zfs_fletcher_superscalar4.c \
241	zfs_fletcher_superscalar.c \
242	zfs_namecheck.c \
243	zfs_prop.c \
244	zfs_valstr.c \
245	zpool_prop.c \
246	zprop_common.c
247
248#zfs
249SRCS+=	abd.c \
250	aggsum.c \
251	arc.c \
252	blake3_zfs.c \
253	blkptr.c \
254	bplist.c \
255	bpobj.c \
256	bptree.c \
257	bqueue.c \
258	brt.c \
259	btree.c \
260	dataset_kstats.c \
261	dbuf.c \
262	dbuf_stats.c \
263	ddt.c \
264	ddt_log.c \
265	ddt_stats.c \
266	ddt_zap.c \
267	dmu.c \
268	dmu_direct.c \
269	dmu_diff.c \
270	dmu_object.c \
271	dmu_objset.c \
272	dmu_recv.c \
273	dmu_redact.c \
274	dmu_send.c \
275	dmu_traverse.c \
276	dmu_tx.c \
277	dmu_zfetch.c \
278	dnode.c \
279	dnode_sync.c \
280	dsl_bookmark.c \
281	dsl_crypt.c \
282	dsl_dataset.c \
283	dsl_deadlist.c \
284	dsl_deleg.c \
285	dsl_destroy.c \
286	dsl_dir.c \
287	dsl_pool.c \
288	dsl_prop.c \
289	dsl_scan.c \
290	dsl_synctask.c \
291	dsl_userhold.c \
292	edonr_zfs.c \
293	fm.c \
294	gzip.c \
295	lz4.c \
296	lz4_zfs.c \
297	lzjb.c \
298	metaslab.c \
299	mmp.c \
300	multilist.c \
301	objlist.c \
302	pathname.c \
303	range_tree.c \
304	refcount.c \
305	rrwlock.c \
306	sa.c \
307	sha2_zfs.c \
308	skein_zfs.c \
309	spa.c \
310	space_map.c \
311	space_reftree.c \
312	spa_checkpoint.c \
313	spa_config.c \
314	spa_errlog.c \
315	spa_history.c \
316	spa_log_spacemap.c \
317	spa_misc.c \
318	spa_stats.c \
319	txg.c \
320	u8_textprep.c \
321	uberblock.c \
322	unique.c \
323	vdev.c \
324	vdev_draid.c \
325	vdev_draid_rand.c \
326	vdev_file.c \
327	vdev_indirect_births.c \
328	vdev_indirect.c \
329	vdev_indirect_mapping.c \
330	vdev_initialize.c \
331	vdev_label.c \
332	vdev_mirror.c \
333	vdev_missing.c \
334	vdev_queue.c \
335	vdev_raidz.c \
336	vdev_raidz_math_avx2.c \
337	vdev_raidz_math_avx512bw.c \
338	vdev_raidz_math_avx512f.c \
339	vdev_raidz_math.c \
340	vdev_raidz_math_scalar.c \
341	vdev_raidz_math_sse2.c \
342	vdev_raidz_math_ssse3.c \
343	vdev_rebuild.c \
344	vdev_removal.c \
345	vdev_root.c \
346	vdev_trim.c \
347	zap.c \
348	zap_leaf.c \
349	zap_micro.c \
350	zcp.c \
351	zcp_get.c \
352	zcp_global.c \
353	zcp_iter.c \
354	zcp_set.c \
355	zcp_synctask.c \
356	zfeature.c \
357	zfs_byteswap.c \
358	zfs_chksum.c \
359	zfs_fm.c \
360	zfs_fuid.c \
361	zfs_impl.c \
362	zfs_ioctl.c \
363	zfs_log.c \
364	zfs_onexit.c \
365	zfs_quota.c \
366	zfs_ratelimit.c \
367	zfs_replay.c \
368	zfs_rlock.c \
369	zfs_sa.c \
370	zfs_vnops.c \
371	zfs_znode.c \
372	zil.c \
373	zio.c \
374	zio_checksum.c \
375	zio_compress.c \
376	zio_inject.c \
377	zle.c \
378	zrlock.c \
379	zthr.c \
380	zvol.c
381
382#zstd
383SRCS+=	zfs_zstd.c
384
385#zstd/common
386SRCS+=	entropy_common.c \
387	error_private.c \
388	fse_decompress.c \
389	pool.c \
390	zstd_common.c \
391
392#zstd/compress
393SRCS+=	fse_compress.c \
394	hist.c \
395	huf_compress.c \
396	zstd_compress.c \
397	zstd_compress_literals.c \
398	zstd_compress_sequences.c \
399	zstd_compress_superblock.c \
400	zstd_double_fast.c \
401	zstd_fast.c \
402	zstd_lazy.c \
403	zstd_ldm.c \
404	zstd_opt.c \
405	zstd_preSplit.c
406
407#zstd/decompress
408SRCS+=	huf_decompress.c \
409	zstd_ddict.c \
410	zstd_decompress_block.c \
411	zstd_decompress.c
412
413beforeinstall:
414.if ${MK_DEBUG_FILES} != "no"
415	mtree -eu \
416	    -f /etc/mtree/BSD.debug.dist \
417	    -p ${DESTDIR}/usr/lib
418.endif
419
420.include <bsd.kmod.mk>
421
422# Generated binary search code is particularly bad with this optimization.
423# Oddly, range_tree.c is not affected when unrolling is not done and dsl_scan.c
424# is not affected when unrolling is done.
425# Disable it until the following upstream issue is resolved:
426# https://github.com/llvm/llvm-project/issues/62790
427.if ${CC} == "clang"
428.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
429CFLAGS.dsl_scan.c= -mllvm -x86-cmov-converter=false
430CFLAGS.metaslab.c= -mllvm -x86-cmov-converter=false
431CFLAGS.range_tree.c= -mllvm -x86-cmov-converter=false
432CFLAGS.zap_micro.c= -mllvm -x86-cmov-converter=false
433.endif
434.endif
435
436CFLAGS.sysctl_os.c= -include ../zfs_config.h
437CFLAGS.xxhash.c+= -include ${SYSDIR}/sys/_null.h
438
439CFLAGS.gcc+= -Wno-pointer-to-int-cast
440
441CFLAGS.abd.c= -Wno-cast-qual
442CFLAGS.ddt.c= -Wno-cast-qual
443CFLAGS.ddt_log.c= -Wno-cast-qual -Wno-pointer-arith
444CFLAGS.ddt_zap.c= -Wno-cast-qual
445CFLAGS.dmu.c= -Wno-cast-qual
446CFLAGS.dmu_traverse.c= -Wno-cast-qual
447CFLAGS.dnode.c= ${NO_WUNUSED_BUT_SET_VARIABLE}
448CFLAGS.dsl_deadlist.c= -Wno-cast-qual
449CFLAGS.dsl_dir.c= -Wno-cast-qual
450CFLAGS.dsl_prop.c= -Wno-cast-qual
451CFLAGS.edonr.c= -Wno-cast-qual
452CFLAGS.fm.c= -Wno-cast-qual
453CFLAGS.hist.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
454CFLAGS.lapi.c= -Wno-cast-qual
455CFLAGS.lcompat.c= -Wno-cast-qual
456CFLAGS.ldo.c= ${NO_WINFINITE_RECURSION}
457CFLAGS.lobject.c= -Wno-cast-qual
458CFLAGS.ltable.c= -Wno-cast-qual
459CFLAGS.lvm.c= -Wno-cast-qual
460CFLAGS.lz4.c= -Wno-cast-qual
461CFLAGS.lz4_zfs.c= -Wno-cast-qual
462CFLAGS.nvpair.c= -Wno-cast-qual -DHAVE_RPC_TYPES ${NO_WSTRINGOP_OVERREAD}
463CFLAGS.pool.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
464CFLAGS.pool.c= -U__BMI__ -fno-tree-vectorize
465CFLAGS.spa.c= -Wno-cast-qual
466CFLAGS.spa_misc.c= -Wno-cast-qual
467CFLAGS.spl_string.c= -Wno-cast-qual
468CFLAGS.spl_vm.c= -Wno-cast-qual
469CFLAGS.spl_zlib.c= -Wno-cast-qual
470CFLAGS.u8_textprep.c= -Wno-cast-qual
471CFLAGS.vdev_draid.c= -Wno-cast-qual
472CFLAGS.vdev_raidz.c= -Wno-cast-qual
473CFLAGS.vdev_raidz_math.c= -Wno-cast-qual
474CFLAGS.vdev_raidz_math_avx2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
475CFLAGS.vdev_raidz_math_avx512f.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
476CFLAGS.vdev_raidz_math_scalar.c= -Wno-cast-qual
477CFLAGS.vdev_raidz_math_sse2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
478CFLAGS.zap_leaf.c= -Wno-cast-qual
479CFLAGS.zap_micro.c= -Wno-cast-qual
480CFLAGS.zcp.c= -Wno-cast-qual
481CFLAGS.zfs_fletcher.c= -Wno-cast-qual -Wno-pointer-arith
482CFLAGS.zfs_fletcher_avx512.c= -Wno-cast-qual -Wno-pointer-arith
483CFLAGS.zfs_fletcher_intel.c= -Wno-cast-qual -Wno-pointer-arith
484CFLAGS.zfs_fletcher_sse.c= -Wno-cast-qual -Wno-pointer-arith
485CFLAGS.zfs_fm.c= -Wno-cast-qual ${NO_WUNUSED_BUT_SET_VARIABLE}
486CFLAGS.zfs_ioctl.c= -Wno-cast-qual
487CFLAGS.zfs_log.c= -Wno-cast-qual
488CFLAGS.zfs_vnops_os.c= -Wno-pointer-arith
489CFLAGS.zfs_zstd.c= -Wno-cast-qual -Wno-pointer-arith
490CFLAGS.zil.c= -Wno-cast-qual
491CFLAGS.zio.c= -Wno-cast-qual
492CFLAGS.zprop_common.c= -Wno-cast-qual
493CFLAGS.zrlock.c= -Wno-cast-qual
494
495#zstd
496CFLAGS.entropy_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
497CFLAGS.error_private.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
498CFLAGS.fse_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
499CFLAGS.fse_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
500CFLAGS.huf_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
501CFLAGS.huf_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
502CFLAGS.xxhash.c+= -U__BMI__ -fno-tree-vectorize
503CFLAGS.xxhash.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
504CFLAGS.zstd.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
505CFLAGS.zstd_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
506CFLAGS.zstd_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
507CFLAGS.zstd_compress_literals.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
508CFLAGS.zstd_compress_sequences.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
509CFLAGS.zstd_compress_superblock.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
510CFLAGS.zstd_ddict.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
511CFLAGS.zstd_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
512CFLAGS.zstd_decompress_block.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
513CFLAGS.zstd_double_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
514CFLAGS.zstd_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
515CFLAGS.zstd_lazy.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
516CFLAGS.zstd_ldm.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
517CFLAGS.zstd_opt.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
518
519.if ${MACHINE_ARCH} == "aarch64"
520
521sha256-armv8.o: sha256-armv8.S
522	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
523	     -o ${.TARGET}
524	${CTFCONVERT_CMD}
525
526sha512-armv8.o: sha512-armv8.S
527	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
528	     -o ${.TARGET}
529	${CTFCONVERT_CMD}
530
531b3_aarch64_sse2.o: b3_aarch64_sse2.S
532	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
533	     -o ${.TARGET}
534	${CTFCONVERT_CMD}
535
536b3_aarch64_sse41.o: b3_aarch64_sse41.S
537	${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
538	     -o ${.TARGET}
539	${CTFCONVERT_CMD}
540
541.endif
542