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 \
315 vdev_indirect_births.c \
316 vdev_indirect_mapping.c \
324 vdev_raidz_math_scalar.c \
325 vdev_raidz_math_avx2.c \
326 vdev_raidz_math_avx512bw.c \
327 vdev_raidz_math_avx512f.c \
328 vdev_raidz_math_sse2.c \
329 vdev_raidz_math_ssse3.c \
382 zstd_compress_literals.c \
383 zstd_compress_sequences.c \
384 zstd_compress_superblock.c \
387 zstd_decompress_block.c \
395 .if ${MK_DEBUG_FILES} != "no"
397 -f /etc/mtree/BSD.debug.dist \
398 -p ${DESTDIR}/usr/lib
401 .include <bsd.kmod.mk>
403 CFLAGS.sysctl_os.c= -include ../zfs_config.h
404 CFLAGS.xxhash.c+= -include ${SYSDIR}/sys/_null.h
406 CFLAGS.gcc+= -Wno-pointer-to-int-cast
408 CFLAGS.abd.c= -Wno-cast-qual
409 CFLAGS.ddt.c= -Wno-cast-qual
410 CFLAGS.dmu.c= -Wno-cast-qual
411 CFLAGS.dmu_traverse.c= -Wno-cast-qual
412 CFLAGS.dnode.c= ${NO_WUNUSED_BUT_SET_VARIABLE}
413 CFLAGS.dsl_deadlist.c= -Wno-cast-qual
414 CFLAGS.dsl_dir.c= -Wno-cast-qual
415 CFLAGS.dsl_prop.c= -Wno-cast-qual
416 CFLAGS.edonr.c= -Wno-cast-qual
417 CFLAGS.fm.c= -Wno-cast-qual
418 CFLAGS.hist.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
419 CFLAGS.lapi.c= -Wno-cast-qual
420 CFLAGS.lcompat.c= -Wno-cast-qual
421 CFLAGS.ldo.c= ${NO_WINFINITE_RECURSION}
422 CFLAGS.lobject.c= -Wno-cast-qual
423 CFLAGS.ltable.c= -Wno-cast-qual
424 CFLAGS.lvm.c= -Wno-cast-qual
425 CFLAGS.lz4.c= -Wno-cast-qual
426 CFLAGS.lz4_zfs.c= -Wno-cast-qual
427 CFLAGS.nvpair.c= -Wno-cast-qual -DHAVE_RPC_TYPES ${NO_WSTRINGOP_OVERREAD}
428 CFLAGS.pool.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
429 CFLAGS.pool.c= -U__BMI__ -fno-tree-vectorize
430 CFLAGS.spa.c= -Wno-cast-qual
431 CFLAGS.spa_misc.c= -Wno-cast-qual
432 CFLAGS.spl_string.c= -Wno-cast-qual
433 CFLAGS.spl_vm.c= -Wno-cast-qual
434 CFLAGS.spl_zlib.c= -Wno-cast-qual
435 CFLAGS.u8_textprep.c= -Wno-cast-qual
436 CFLAGS.vdev_draid.c= -Wno-cast-qual
437 CFLAGS.vdev_raidz.c= -Wno-cast-qual
438 CFLAGS.vdev_raidz_math.c= -Wno-cast-qual
439 CFLAGS.vdev_raidz_math_avx2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
440 CFLAGS.vdev_raidz_math_avx512f.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
441 CFLAGS.vdev_raidz_math_scalar.c= -Wno-cast-qual
442 CFLAGS.vdev_raidz_math_sse2.c= -Wno-cast-qual -Wno-duplicate-decl-specifier
443 CFLAGS.zap_leaf.c= -Wno-cast-qual
444 CFLAGS.zap_micro.c= -Wno-cast-qual
445 CFLAGS.zcp.c= -Wno-cast-qual
446 CFLAGS.zfs_fletcher.c= -Wno-cast-qual -Wno-pointer-arith
447 CFLAGS.zfs_fletcher_avx512.c= -Wno-cast-qual -Wno-pointer-arith
448 CFLAGS.zfs_fletcher_intel.c= -Wno-cast-qual -Wno-pointer-arith
449 CFLAGS.zfs_fletcher_sse.c= -Wno-cast-qual -Wno-pointer-arith
450 CFLAGS.zfs_fm.c= -Wno-cast-qual ${NO_WUNUSED_BUT_SET_VARIABLE}
451 CFLAGS.zfs_ioctl.c= -Wno-cast-qual
452 CFLAGS.zfs_log.c= -Wno-cast-qual
453 CFLAGS.zfs_vnops_os.c= -Wno-pointer-arith
454 CFLAGS.zfs_zstd.c= -Wno-cast-qual -Wno-pointer-arith
455 CFLAGS.zil.c= -Wno-cast-qual
456 CFLAGS.zio.c= -Wno-cast-qual
457 CFLAGS.zprop_common.c= -Wno-cast-qual
458 CFLAGS.zrlock.c= -Wno-cast-qual
461 CFLAGS.entropy_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
462 CFLAGS.error_private.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
463 CFLAGS.fse_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
464 CFLAGS.fse_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
465 CFLAGS.huf_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
466 CFLAGS.huf_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
467 CFLAGS.xxhash.c+= -U__BMI__ -fno-tree-vectorize
468 CFLAGS.xxhash.c+= ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
469 CFLAGS.zstd.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
470 CFLAGS.zstd_common.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
471 CFLAGS.zstd_compress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
472 CFLAGS.zstd_compress_literals.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
473 CFLAGS.zstd_compress_sequences.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
474 CFLAGS.zstd_compress_superblock.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL} ${NO_WUNUSED_BUT_SET_VARIABLE}
475 CFLAGS.zstd_ddict.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
476 CFLAGS.zstd_decompress.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
477 CFLAGS.zstd_decompress_block.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
478 CFLAGS.zstd_double_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
479 CFLAGS.zstd_fast.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
480 CFLAGS.zstd_lazy.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
481 CFLAGS.zstd_ldm.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
482 CFLAGS.zstd_opt.c= -U__BMI__ -fno-tree-vectorize ${NO_WBITWISE_INSTEAD_OF_LOGICAL}
484 .if ${MACHINE_CPUARCH} == "aarch64"
485 __ZFS_ZSTD_AARCH64_FLAGS= -include ${SRCDIR}/zstd/include/aarch64_compat.h
486 CFLAGS.zstd.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
487 CFLAGS.entropy_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
488 CFLAGS.error_private.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
489 CFLAGS.fse_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
490 CFLAGS.fse_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
491 CFLAGS.hist.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
492 CFLAGS.huf_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
493 CFLAGS.huf_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
494 CFLAGS.pool.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
495 CFLAGS.xxhash.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
496 CFLAGS.zstd_common.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
497 CFLAGS.zstd_compress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
498 CFLAGS.zstd_compress_literals.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
499 CFLAGS.zstd_compress_sequences.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
500 CFLAGS.zstd_compress_superblock.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
501 CFLAGS.zstd_ddict.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
502 CFLAGS.zstd_decompress.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
503 CFLAGS.zstd_decompress_block.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
504 CFLAGS.zstd_double_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
505 CFLAGS.zstd_fast.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
506 CFLAGS.zstd_lazy.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
507 CFLAGS.zstd_ldm.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
508 CFLAGS.zstd_opt.c+= ${__ZFS_ZSTD_AARCH64_FLAGS}
510 sha256-armv8.o: sha256-armv8.S
511 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
515 sha512-armv8.o: sha512-armv8.S
516 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
520 b3_aarch64_sse2.o: b3_aarch64_sse2.S
521 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \
525 b3_aarch64_sse41.o: b3_aarch64_sse41.S
526 ${CC} -c ${CFLAGS:N-mgeneral-regs-only} ${WERROR} ${.IMPSRC} \