8 INCDIR=${.CURDIR:H}/include
12 .PATH: ${SRCDIR}/avl \
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 \
31 ${SRCDIR}/zstd/lib/common \
32 ${SRCDIR}/zstd/lib/compress \
33 ${SRCDIR}/zstd/lib/decompress
36 CFLAGS+= -I${SRCDIR}/icp/include
37 CFLAGS+= -I${INCDIR}/os/freebsd
38 CFLAGS+= -I${INCDIR}/os/freebsd/spl
39 CFLAGS+= -I${INCDIR}/os/freebsd/zfs
40 CFLAGS+= -I${SRCDIR}/zstd/include
41 CFLAGS+= -include ${INCDIR}/os/freebsd/spl/sys/ccompile.h
44 CFLAGS+= -D__KERNEL__ -DFREEBSD_NAMECACHE -DBUILDING_ZFS -D__BSD_VISIBLE=1 \
45 -DHAVE_UIO_ZEROCOPY -DWITHOUT_NETDUMP -D__KERNEL -D_SYS_CONDVAR_H_ \
46 -D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DCOMPAT_FREEBSD11
48 .if ${MACHINE_ARCH} == "amd64"
49 CFLAGS+= -D__x86_64 -DHAVE_SSE2 -DHAVE_SSSE3 -DHAVE_SSE4_1 -DHAVE_SSE4_2 \
50 -DHAVE_AVX -DHAVE_AVX2 -DHAVE_AVX512F -DHAVE_AVX512VL -DHAVE_AVX512BW
53 .if defined(WITH_DEBUG) && ${WITH_DEBUG} == "true"
54 CFLAGS+= -DZFS_DEBUG -g
55 .if defined(WITH_INVARIANTS) && ${WITH_INVARIANTS} == "true"
56 CFLAGS+= -DINVARIANTS -DWITNESS -DOPENSOLARIS_WITNESS
58 .if defined(WITH_O0) && ${WITH_O0} == "true"
65 .if defined(WITH_VFS_DEBUG) && ${WITH_VFS_DEBUG} == "true"
66 # kernel must also be built with this option for this to work
67 CFLAGS+= -DDEBUG_VFS_LOCKS
70 .if defined(WITH_GCOV) && ${WITH_GCOV} == "true"
71 CFLAGS+= -fprofile-arcs -ftest-coverage
76 .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
77 ${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
78 CFLAGS+= -DBITS_PER_LONG=32
80 CFLAGS+= -DBITS_PER_LONG=64
83 SRCS= vnode_if.h device_if.h bus_if.h
96 #icp/asm-aarch64/blake3
97 SRCS+= b3_aarch64_sse2.S \
100 #icp/asm-ppc64/blake3
101 SRCS+= b3_ppc64le_sse2.S \
104 #icp/asm-x86_64/blake3
105 SRCS+= blake3_avx2.S \
111 SRCS+= sha2_generic.c \
116 SRCS+= sha256-armv7.S \
119 #icp/asm-aarch64/sha2
120 SRCS+= sha256-armv8.S \
130 SRCS+= sha256-x86_64.S \
166 SRCS+= acl_common.c \
188 .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "powerpc" || \
189 ${MACHINE_ARCH} == "powerpcspe" || ${MACHINE_ARCH} == "arm"
224 SRCS+= zfeature_common.c \
228 zfs_fletcher_avx512.c \
229 zfs_fletcher_intel.c \
231 zfs_fletcher_superscalar.c \
232 zfs_fletcher_superscalar4.c \
314 vdev_indirect_births.c \
315 vdev_indirect_mapping.c \
323 vdev_raidz_math_scalar.c \
324 vdev_raidz_math_avx2.c \
325 vdev_raidz_math_avx512bw.c \
326 vdev_raidz_math_avx512f.c \
327 vdev_raidz_math_sse2.c \
328 vdev_raidz_math_ssse3.c \
381 zstd_compress_literals.c \
382 zstd_compress_sequences.c \
383 zstd_compress_superblock.c \
386 zstd_decompress_block.c \
394 .if ${MK_DEBUG_FILES} != "no"
396 -f /etc/mtree/BSD.debug.dist \
397 -p ${DESTDIR}/usr/lib
400 .include <bsd.kmod.mk>
402 # Generated binary search code is particularly bad with this optimization.
403 # Oddly, range_tree.c is not affected when unrolling is not done and dsl_scan.c
404 # is not affected when unrolling is done.
405 # Disable it until the following upstream issue is resolved:
406 # https://github.com/llvm/llvm-project/issues/62790
408 .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "amd64"
409 CFLAGS.dsl_scan.c= -mllvm -x86-cmov-converter=false
410 CFLAGS.metaslab.c= -mllvm -x86-cmov-converter=false
411 CFLAGS.range_tree.c= -mllvm -x86-cmov-converter=false
412 CFLAGS.zap_micro.c= -mllvm -x86-cmov-converter=false
416 CFLAGS.sysctl_os.c= -include ../zfs_config.h
417 CFLAGS.xxhash.c+= -include ${SYSDIR}/sys/_null.h
419 CFLAGS.gcc+= -Wno-pointer-to-int-cast
421 CFLAGS.abd.c= -Wno-cast-qual
422 CFLAGS.ddt.c= -Wno-cast-qual
423 CFLAGS.dmu.c= -Wno-cast-qual
424 CFLAGS.dmu_traverse.c= -Wno-cast-qual
425 CFLAGS.dnode.c= ${NO_WUNUSED_BUT_SET_VARIABLE}
426 CFLAGS.dsl_deadlist.c= -Wno-cast-qual
427 CFLAGS.dsl_dir.c= -Wno-cast-qual
428 CFLAGS.dsl_prop.c= -Wno-cast-qual
429 CFLAGS.edonr.c= -Wno-cast-qual
430 CFLAGS.fm.c= -Wno-cast-qual
431 CFLAGS.hist.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
432 CFLAGS.lapi.c= -Wno-cast-qual
433 CFLAGS.lcompat.c= -Wno-cast-qual
434 CFLAGS.ldo.c= ${NO_WINFINITE_RECURSION}
435 CFLAGS.lobject.c= -Wno-cast-qual
436 CFLAGS.ltable.c= -Wno-cast-qual
437 CFLAGS.lvm.c= -Wno-cast-qual
438 CFLAGS.lz4.c= -Wno-cast-qual
439 CFLAGS.lz4_zfs.c= -Wno-cast-qual
440 CFLAGS.nvpair.c= -Wno-cast-qual -DHAVE_RPC_TYPES ${NO_WSTRINGOP_OVERREAD}
441 CFLAGS.pool.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
442 CFLAGS.pool.c= -U__BMI__ -fno-tree-vectorize
443 CFLAGS.spa.c= -Wno-cast-qual
444 CFLAGS.spa_misc.c= -Wno-cast-qual
445 CFLAGS.spl_string.c= -Wno-cast-qual
446 CFLAGS.spl_vm.c= -Wno-cast-qual
447 CFLAGS.spl_zlib.c= -Wno-cast-qual
448 CFLAGS.u8_textprep.c= -Wno-cast-qual
449 CFLAGS.vdev_draid.c= -Wno-cast-qual
450 CFLAGS.vdev_raidz.c= -Wno-cast-qual
451 CFLAGS.vdev_raidz_math.c= -Wno-cast-qual
452 CFLAGS.vdev_raidz_math_avx2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
453 CFLAGS.vdev_raidz_math_avx512f.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
454 CFLAGS.vdev_raidz_math_scalar.c= -Wno-cast-qual
455 CFLAGS.vdev_raidz_math_sse2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
456 CFLAGS.zap_leaf.c= -Wno-cast-qual
457 CFLAGS.zap_micro.c= -Wno-cast-qual
458 CFLAGS.zcp.c= -Wno-cast-qual
459 CFLAGS.zfs_fletcher.c= -Wno-cast-qual -Wno-pointer-arith
460 CFLAGS.zfs_fletcher_avx512.c= -Wno-cast-qual -Wno-pointer-arith
461 CFLAGS.zfs_fletcher_intel.c= -Wno-cast-qual -Wno-pointer-arith
462 CFLAGS.zfs_fletcher_sse.c= -Wno-cast-qual -Wno-pointer-arith
463 CFLAGS.zfs_fm.c= -Wno-cast-qual ${NO_WUNUSED_BUT_SET_VARIABLE}
464 CFLAGS.zfs_ioctl.c= -Wno-cast-qual
465 CFLAGS.zfs_log.c= -Wno-cast-qual
466 CFLAGS.zfs_vnops_os.c= -Wno-pointer-arith
467 CFLAGS.zfs_zstd.c= -Wno-cast-qual -Wno-pointer-arith
468 CFLAGS.zil.c= -Wno-cast-qual
469 CFLAGS.zio.c= -Wno-cast-qual
470 CFLAGS.zprop_common.c= -Wno-cast-qual
471 CFLAGS.zrlock.c= -Wno-cast-qual
474 CFLAGS.entropy_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
475 CFLAGS.error_private.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
476 CFLAGS.fse_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
477 CFLAGS.fse_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
478 CFLAGS.huf_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
479 CFLAGS.huf_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
480 CFLAGS.xxhash.c+= -U__BMI__ -fno-tree-vectorize
481 CFLAGS.xxhash.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
482 CFLAGS.zstd.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
483 CFLAGS.zstd_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
484 CFLAGS.zstd_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
485 CFLAGS.zstd_compress_literals.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
486 CFLAGS.zstd_compress_sequences.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
487 CFLAGS.zstd_compress_superblock.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
488 CFLAGS.zstd_ddict.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
489 CFLAGS.zstd_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
490 CFLAGS.zstd_decompress_block.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
491 CFLAGS.zstd_double_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
492 CFLAGS.zstd_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
493 CFLAGS.zstd_lazy.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
494 CFLAGS.zstd_ldm.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
495 CFLAGS.zstd_opt.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
497 .if ${MACHINE_CPUARCH} == "aarch64"
498 __ZFS_ZSTD_AARCH64_FLAGS= -include ${SRCDIR}/zstd/include/aarch64_compat.h
499 CFLAGS.zstd.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
500 CFLAGS.entropy_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
501 CFLAGS.error_private.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
502 CFLAGS.fse_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
503 CFLAGS.fse_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
504 CFLAGS.hist.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
505 CFLAGS.huf_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
506 CFLAGS.huf_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
507 CFLAGS.pool.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
508 CFLAGS.xxhash.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
509 CFLAGS.zstd_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
510 CFLAGS.zstd_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
511 CFLAGS.zstd_compress_literals.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
512 CFLAGS.zstd_compress_sequences.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
513 CFLAGS.zstd_compress_superblock.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
514 CFLAGS.zstd_ddict.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
515 CFLAGS.zstd_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
516 CFLAGS.zstd_decompress_block.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
517 CFLAGS.zstd_double_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
518 CFLAGS.zstd_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
519 CFLAGS.zstd_lazy.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
520 CFLAGS.zstd_ldm.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
521 CFLAGS.zstd_opt.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
523 sha256-armv8.o: sha256-armv8.S
524 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
528 sha512-armv8.o: sha512-armv8.S
529 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
533 b3_aarch64_sse2.o: b3_aarch64_sse2.S
534 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
538 b3_aarch64_sse41.o: b3_aarch64_sse41.S
539 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \