git: d94972174560 - main - zfs: merge openzfs/zfs@a170134fe

From: Martin Matuska <mm_at_FreeBSD.org>
Date: Sat, 06 Jun 2026 20:49:26 UTC
The branch main has been updated by mm:

URL: https://cgit.FreeBSD.org/src/commit/?id=d9497217456002b0ddad3cd319570d0b098daa29

commit d9497217456002b0ddad3cd319570d0b098daa29
Merge: 4a299ef19c7e a170134febea
Author:     Martin Matuska <mm@FreeBSD.org>
AuthorDate: 2026-06-06 20:48:32 +0000
Commit:     Martin Matuska <mm@FreeBSD.org>
CommitDate: 2026-06-06 20:48:32 +0000

    zfs: merge openzfs/zfs@a170134fe
    
    Notable upstream pull request merges:
     #18372 eaaea55b6 Consistently encode DRR_BEGIN packed nvlist payloads with
                      NV_ENCODE_XDR
     #18410 891e379d0 Fix failfast default and usage
     #18470 a2d053329 zdb: Add some more file layout output, triggered by -v
     #18472 d50f5b6d0 dsl_dir: avoid dd_lock during snapshots_changed updates
     #18493 d65015938 Vdev allocation bias/class change
     #18497 8fdc86675 zfs: annotate nested dd_lock in reservation sync
                      accounting
     #18494 956deba27 zdb: detect BRT and DDT leaks during block traversal
     #18499 c7cfe0805 zarcstat: detect attached L2ARC device with no data
     #18503 439b802e7 sa: fix sa_add_projid lock ordering
     #18508 968f4db03 zpool-attach.8: add EXAMPLES section
     #18513 45dddc452 zfs.4: Fix documentation of zfs_arc_dnode_reduce_percent
     #18516 8ff64005a zap: split implementation out into more files
     #18520 181e1b522 Fix double free for blocks cloned after DDT prune
     #18535 -multiple zstream: fix crashes when refcount tracking enabled
     #18536 -multiple refcount tag fixups
     #18541 a65ed7afd zpool/zfs: accept --help and -? after a subcommand
     #18544 6fb72fda0 zio_ddt_write: compute have_dvas after taking dde_io_lock
     #18546 -multiple zap: internal locking uplift
     #18550 40a87651d zap_impl: use flex array field for mzap_phys_t.mz_chunks
     #18551 -multiple zap: make the _by_dnode() op variants be the primary
                      implementation
     #18570 112b0131b zpl_xattr: stop heap-allocating prefixed xattr names
     #18578 4bc8c39b6 zed: Prefer dRAID distributed spares to regular ones
     #18596 e30ab5fa4 FreeBSD: Make it possible to build openzfs.ko with
                      sanitizers
     #18597 472ddca11 zed: Prefer spares with matching rotational and size
     #18599 c90dc2808 enforce exact decompressed length for lz4, gzip, and zstd
     #18603 -multiple zap: add zap_cursor_init_by_dnode; cursor unit tests;
                      mock dnode refcounts
     #18604 59dc88602 nvpair: Check for un-terminated strings in packed nvlist
     #18606 ef6f26145 When reading a vdev label skip libzfs_core_init()
     #18613 0aa4088dc sharenfs: Check for invalid characters
     #18615 80fb85b80 Fix the integer type in zfs_ioc_userspace_many()
     #18616 e199f6d98 Fix uninitialized variable warning in vdev_prop_get()
     #18617 7de42602c Extend dataset zfs_ioc_set_prop() secpolicy
     #18622 5fea0c838 Parallelize metaslab_sync_done() calls
     #18623 cab50d5ad Add additional verification of size fields and strings
     #18630 -multiple zap: misc function removal / uplift / tests
     #18633 a8ef128da Fix uninitialized variable warning in zil_parse()
    
    Obtained from:  OpenZFS
    OpenZFS commit: a170134febea405c6b6f5ed51724cdcfb6d8e726

 cddl/lib/libzpool/Makefile                         |    2 +
 sys/conf/files                                     |    2 +
 sys/contrib/openzfs/.github/workflows/README.md    |  129 +-
 .../openzfs/.github/workflows/checkstyle.yaml      |    2 +-
 sys/contrib/openzfs/.github/workflows/codeql.yml   |    8 +-
 .../.github/workflows/scripts/generate-ci-type.py  |   23 +
 .../.github/workflows/scripts/qemu-1-setup.sh      |    2 +
 .../.github/workflows/scripts/qemu-2-start.sh      |   53 +-
 .../.github/workflows/scripts/qemu-3-deps-vm.sh    |   38 +-
 .../.github/workflows/scripts/qemu-3-deps.sh       |   18 +-
 .../.github/workflows/scripts/qemu-4-build-vm.sh   |   34 +-
 .../workflows/scripts/qemu-6-lustre-tests-vm.sh    |    8 +-
 .../.github/workflows/scripts/qemu-6-tests.sh      |    8 +
 sys/contrib/openzfs/.github/workflows/smatch.yml   |    9 +
 sys/contrib/openzfs/.github/workflows/zfs-arm.yml  |   51 +-
 .../.github/workflows/zfs-qemu-packages.yml        |   14 +-
 sys/contrib/openzfs/.github/workflows/zfs-qemu.yml |   31 +-
 sys/contrib/openzfs/.github/workflows/zloop.yml    |    8 +
 sys/contrib/openzfs/Makefile.am                    |    1 +
 sys/contrib/openzfs/README.md                      |    4 +-
 sys/contrib/openzfs/cmd/Makefile.am                |    1 -
 sys/contrib/openzfs/cmd/zarcstat.in                |    6 +-
 sys/contrib/openzfs/cmd/zarcsummary                |    5 +-
 sys/contrib/openzfs/cmd/zdb/zdb.c                  |  229 +-
 sys/contrib/openzfs/cmd/zed/Makefile.am            |    1 -
 sys/contrib/openzfs/cmd/zed/agents/zfs_retire.c    |   96 +-
 sys/contrib/openzfs/cmd/zfs/zfs_main.c             |   12 +
 sys/contrib/openzfs/cmd/zpool/zpool_main.c         |   12 +
 sys/contrib/openzfs/cmd/zstream/zstream.c          |   36 +
 sys/contrib/openzfs/cmd/zstream/zstream_dump.c     |   14 +
 .../openzfs/cmd/zstream/zstream_recompress.c       |    2 +
 sys/contrib/openzfs/config/Rules.am                |    2 +
 sys/contrib/openzfs/config/ax_pthread.m4           |  523 +++++
 sys/contrib/openzfs/config/kernel-fs-parse.m4      |   34 +
 sys/contrib/openzfs/config/kernel.m4               |  116 +-
 sys/contrib/openzfs/config/zfs-build.m4            |   12 +
 sys/contrib/openzfs/configure.ac                   |    1 +
 sys/contrib/openzfs/contrib/debian/not-installed   |    1 -
 .../openzfs/contrib/pam_zfs_key/pam_zfs_key.c      |   25 +-
 sys/contrib/openzfs/copy-builtin                   |   11 +
 sys/contrib/openzfs/etc/Makefile.am                |    8 -
 sys/contrib/openzfs/etc/sudoers.d/zfs              |    9 -
 .../openzfs/include/os/freebsd/zfs/sys/arc_os.h    |    1 -
 .../openzfs/include/os/linux/spl/sys/rwlock.h      |  132 +-
 sys/contrib/openzfs/include/sys/arc.h              |    3 +-
 sys/contrib/openzfs/include/sys/arc_impl.h         |    5 +-
 sys/contrib/openzfs/include/sys/fs/zfs.h           |   14 +
 sys/contrib/openzfs/include/sys/metaslab_impl.h    |    2 +-
 sys/contrib/openzfs/include/sys/vdev_impl.h        |    9 +-
 sys/contrib/openzfs/include/sys/zap.h              |  236 +-
 sys/contrib/openzfs/include/sys/zap_impl.h         |  110 +-
 sys/contrib/openzfs/include/sys/zio_impl.h         |   13 +-
 sys/contrib/openzfs/lib/libspl/Makefile.am         |    4 -
 sys/contrib/openzfs/lib/libzfs/Makefile.am         |    4 +-
 sys/contrib/openzfs/lib/libzfs/libzfs.abi          |    9 +-
 sys/contrib/openzfs/lib/libzfs/libzfs_changelist.c |   15 +-
 sys/contrib/openzfs/lib/libzfs/libzfs_pool.c       |   61 +-
 sys/contrib/openzfs/lib/libzfs/libzfs_share.c      |    8 +
 sys/contrib/openzfs/lib/libzfs_core/Makefile.am    |    4 +-
 sys/contrib/openzfs/lib/libzpool/Makefile.am       |    6 +-
 sys/contrib/openzfs/man/man4/zfs.4                 |   68 +-
 sys/contrib/openzfs/man/man7/vdevprops.7           |   22 +-
 sys/contrib/openzfs/man/man8/zdb.8                 |    7 +-
 sys/contrib/openzfs/man/man8/zpool-attach.8        |   31 +-
 sys/contrib/openzfs/man/man8/zpool-events.8        |   10 +-
 sys/contrib/openzfs/man/man8/zpool-iostat.8        |    5 +-
 sys/contrib/openzfs/man/man8/zpool.8               |    1 +
 sys/contrib/openzfs/module/Kbuild.in               |   13 +-
 sys/contrib/openzfs/module/Makefile.bsd            |   10 +-
 sys/contrib/openzfs/module/nvpair/nvpair.c         |   49 +-
 sys/contrib/openzfs/module/os/freebsd/zfs/arc_os.c |    3 -
 .../openzfs/module/os/freebsd/zfs/sysctl_os.c      |   24 +-
 sys/contrib/openzfs/module/os/linux/spl/spl-kmem.c |    6 +
 sys/contrib/openzfs/module/os/linux/zfs/arc_os.c   |   18 +
 .../openzfs/module/os/linux/zfs/vdev_disk.c        |    8 +-
 .../openzfs/module/os/linux/zfs/zfs_vfsops.c       |   45 +-
 .../openzfs/module/os/linux/zfs/zfs_vnops_os.c     |   38 +-
 .../openzfs/module/os/linux/zfs/zpl_super.c        |   63 +-
 .../openzfs/module/os/linux/zfs/zpl_xattr.c        |   92 +-
 sys/contrib/openzfs/module/zcommon/zfs_valstr.c    |    2 +-
 sys/contrib/openzfs/module/zcommon/zpool_prop.c    |   27 +-
 sys/contrib/openzfs/module/zfs/arc.c               |   30 +-
 sys/contrib/openzfs/module/zfs/ddt_log.c           |    4 +-
 sys/contrib/openzfs/module/zfs/dmu_objset.c        |    2 +-
 sys/contrib/openzfs/module/zfs/dmu_recv.c          |   44 +-
 sys/contrib/openzfs/module/zfs/dmu_send.c          |   37 +-
 sys/contrib/openzfs/module/zfs/dsl_bookmark.c      |    2 +-
 sys/contrib/openzfs/module/zfs/dsl_dir.c           |   91 +-
 sys/contrib/openzfs/module/zfs/dsl_scan.c          |    1 +
 sys/contrib/openzfs/module/zfs/gzip.c              |    8 +-
 sys/contrib/openzfs/module/zfs/lz4_zfs.c           |   15 +-
 sys/contrib/openzfs/module/zfs/metaslab.c          |   31 +-
 sys/contrib/openzfs/module/zfs/sa.c                |    4 +-
 sys/contrib/openzfs/module/zfs/spa.c               |   29 +-
 sys/contrib/openzfs/module/zfs/vdev.c              |  188 +-
 sys/contrib/openzfs/module/zfs/vdev_label.c        |   14 +
 .../zfs/vdev_raidz_math_aarch64_neon_common.h      |   18 +-
 sys/contrib/openzfs/module/zfs/zap.c               | 2306 ++++++++----------
 sys/contrib/openzfs/module/zfs/zap_fat.c           | 1458 ++++++++++++
 sys/contrib/openzfs/module/zfs/zap_impl.c          |  558 +++++
 sys/contrib/openzfs/module/zfs/zap_micro.c         | 1639 +------------
 sys/contrib/openzfs/module/zfs/zfs_ioctl.c         |   40 +-
 sys/contrib/openzfs/module/zfs/zfs_quota.c         |    8 +-
 sys/contrib/openzfs/module/zfs/zil.c               |    2 +-
 sys/contrib/openzfs/module/zfs/zio.c               |   47 +-
 sys/contrib/openzfs/module/zstd/zfs_zstd.c         |    9 +
 sys/contrib/openzfs/rpm/generic/zfs.spec.in        |    1 -
 sys/contrib/openzfs/scripts/Makefile.am            |    1 +
 sys/contrib/openzfs/scripts/coverage_report.pl     |  392 ++++
 sys/contrib/openzfs/tests/Makefile.am              |    1 +
 sys/contrib/openzfs/tests/runfiles/common.run      |   38 +-
 sys/contrib/openzfs/tests/runfiles/linux.run       |    3 +-
 sys/contrib/openzfs/tests/runfiles/sanity.run      |   37 +-
 .../openzfs/tests/test-runner/bin/zts-report.py.in |    4 +-
 sys/contrib/openzfs/tests/unit/.gitignore          |    4 +
 sys/contrib/openzfs/tests/unit/Makefile.am         |  110 +
 sys/contrib/openzfs/tests/unit/README.md           |  217 ++
 sys/contrib/openzfs/tests/unit/mock_dmu.c          |  409 ++++
 sys/contrib/openzfs/tests/unit/mock_dmu.h          |   50 +
 sys/contrib/openzfs/tests/unit/munit.c             | 2458 ++++++++++++++++++++
 sys/contrib/openzfs/tests/unit/munit.h             |  575 +++++
 sys/contrib/openzfs/tests/unit/test_zap.c          | 1170 ++++++++++
 sys/contrib/openzfs/tests/unit/unit.c              |  105 +
 sys/contrib/openzfs/tests/unit/unit.h              |   64 +
 .../openzfs/tests/zfs-tests/cmd/Makefile.am        |    5 -
 .../tests/zfs-tests/cmd/libzfs_input_check.c       |  172 +-
 .../openzfs/tests/zfs-tests/tests/Makefile.am      |   30 +
 .../functional/alloc_class/alloc_class.kshlib      |   34 +
 .../functional/alloc_class/alloc_class_012_pos.ksh |   35 -
 .../functional/alloc_class/alloc_class_014_pos.ksh |  109 +
 .../functional/alloc_class/alloc_class_015_neg.ksh |   91 +
 .../bclone/bclone_crossfs_corner_cases.ksh         |    3 +
 .../functional/bclone/bclone_crossfs_data.ksh      |    3 +
 .../bclone/bclone_samefs_corner_cases.ksh          |    3 +
 .../tests/functional/bclone/bclone_samefs_data.ksh |    3 +
 .../block_cloning_after_device_removal.ksh         |    4 +
 .../block_cloning_lwb_buffer_overflow.ksh          |    3 +
 .../block_cloning/block_cloning_replay.ksh         |    3 +
 .../block_cloning_replay_encrypted.ksh             |    3 +
 .../cli_root/zdb/zdb_file_layout_001.ksh           |   78 +
 .../cli_root/zdb/zdb_file_layout_002.ksh           |   78 +
 .../cli_root/zdb/zdb_file_layout_003.ksh           |   78 +
 .../cli_root/zdb/zdb_file_layout_neg.ksh           |   57 +
 .../functional/cli_root/zfs_mount/zfs_mount.kshlib |  128 +
 .../cli_root/zfs_mount/zfs_mount_remount.ksh       |  103 +-
 .../cli_root/zfs_mount/zfs_mount_ro_rw.ksh         |  130 ++
 .../cli_root/zhack/zhack_metaslab_leak.ksh         |    4 +-
 .../functional/cli_root/zinject/zinject_args.ksh   |  140 +-
 .../cli_root/zpool_expand/zpool_expand_005_pos.ksh |    2 +-
 .../functional/cli_root/zpool_get/vdev_get.cfg     |    1 +
 .../zpool_import/zpool_import_parallel_pos.ksh     |    4 +-
 .../cli_root/zpool_set/zpool_set_inherit.ksh       |  115 +
 .../cli_root/zpool_trim/zpool_trim_partial.ksh     |   18 +-
 .../cli_user/zpool_iostat/zpool_iostat_002_pos.ksh |    8 +-
 .../tests/functional/dedup/dedup_bclone.ksh        |  120 +
 .../tests/functional/dedup/dedup_bclone_pruned.ksh |  152 ++
 .../tests/functional/dedup/dedup_fdt_create.ksh    |    8 +-
 .../tests/functional/dedup/dedup_fdt_import.ksh    |    6 +-
 .../tests/functional/dedup/dedup_fdt_pacing.ksh    |    6 +-
 .../tests/functional/dedup/dedup_legacy_create.ksh |    8 +-
 .../functional/dedup/dedup_legacy_fdt_mixed.ksh    |    6 +-
 .../functional/dedup/dedup_legacy_fdt_upgrade.ksh  |    8 +-
 .../tests/functional/dedup/dedup_legacy_import.ksh |    6 +-
 .../tests/functional/dedup/dedup_prune.ksh         |    5 +-
 .../tests/functional/dedup/dedup_zap_shrink.ksh    |    2 +
 .../tests/functional/devices/devices_common.kshlib |   12 +-
 .../tests/functional/fault/auto_spare_multiple.ksh |    8 +-
 .../functional/fault/auto_spare_rotational.ksh     |   84 +
 .../tests/functional/redundancy/redundancy.kshlib  |   22 +-
 .../functional/removal/removal_with_export.ksh     |    2 +-
 .../tests/functional/send_xdr_encoding/cleanup.ksh |   27 +
 .../send_xdr_encoding/send_xdr_encoding.cfg        |   25 +
 .../send_xdr_encoding/send_xdr_encoding.kshlib     |   71 +
 .../tests/functional/send_xdr_encoding/setup.ksh   |   29 +
 .../send_xdr_encoding/xdr_bookmark_raw.ksh         |   93 +
 .../xdr_bookmark_raw_with_write.ksh                |  107 +
 .../send_xdr_encoding/xdr_incr_from_bookmark.ksh   |   88 +
 .../send_xdr_encoding/xdr_incr_from_redacted.ksh   |   96 +
 .../tests/functional/send_xdr_encoding/xdr_raw.ksh |   67 +
 .../send_xdr_encoding/xdr_redacted_full.ksh        |   72 +
 .../send_xdr_encoding/xdr_redacted_received.ksh    |   84 +
 .../xdr_redacted_received_raw.ksh                  |   97 +
 .../send_xdr_encoding/xdr_replication.ksh          |   90 +
 .../functional/send_xdr_encoding/xdr_resume.ksh    |   73 +
 .../send_xdr_encoding/xdr_resume_bookmark_raw.ksh  |  103 +
 .../xdr_resume_bookmark_raw_with_write.ksh         |  116 +
 .../send_xdr_encoding/xdr_resume_raw.ksh           |   79 +
 .../send_xdr_encoding/xdr_resume_redacted.ksh      |   86 +
 .../tests/functional/snapshot/snapshot_002_pos.ksh |    2 +-
 .../tests/functional/snapshot/snapshot_006_pos.ksh |    2 +-
 .../tests/functional/stat/statx_dioalign.ksh       |   11 +-
 .../functional/vdev_zaps/vdev_zaps_008_pos.ksh     |   90 +
 .../functional/zvol/zvol_stress/zvol_stress.ksh    |    2 +-
 sys/modules/zfs/Makefile                           |    3 +
 sys/modules/zfs/zfs_config.h                       |   17 +-
 sys/modules/zfs/zfs_gitrev.h                       |    2 +-
 196 files changed, 14574 insertions(+), 3861 deletions(-)

diff --cc cddl/lib/libzpool/Makefile
index 0c997e38d373,000000000000..0c2030faa3d6
mode 100644,000000..100644
--- a/cddl/lib/libzpool/Makefile
+++ b/cddl/lib/libzpool/Makefile
@@@ -1,348 -1,0 +1,350 @@@
 +.PATH: ${ZFSTOP}/lib/libzpool
 +
 +# ZFS_COMMON_SRCS
 +.PATH: ${ZFSTOP}/module/zfs
 +.PATH: ${ZFSTOP}/module/zcommon
 +.PATH: ${ZFSTOP}/module/unicode
 +# LUA_SRCS
 +.PATH: ${ZFSTOP}/module/lua
 +# ZSTD_SRCS
 +.PATH: ${ZFSTOP}/module/zstd
 +.PATH: ${ZFSTOP}/module/zstd/lib/common
 +.PATH: ${ZFSTOP}/module/zstd/lib/compress
 +.PATH: ${ZFSTOP}/module/zstd/lib/decompress
 +
 +.if exists(${SRCTOP}/sys/cddl/contrib/opensolaris/common/atomic/${MACHINE_ARCH}/opensolaris_atomic.S)
 +.PATH: ${SRCTOP}/sys/cddl/contrib/opensolaris/common/atomic/${MACHINE_ARCH}
 +ATOMIC_SRCS=	opensolaris_atomic.S
 +ACFLAGS+=	-Wa,--noexecstack
 +.else
 +.PATH: ${SRCTOP}/sys/cddl/compat/opensolaris/kern
 +ATOMIC_SRCS=	opensolaris_atomic.c
 +.endif
 +
 +.if ${MACHINE_ARCH} == "powerpc"
 +# Don't waste GOT entries on small data.
 +PICFLAG=	-fPIC
 +.endif
 +
 +PACKAGE=	zfs
 +LIB_PACKAGE=
 +
 +LIB=		zpool
 +
 +USER_C = \
 +	arc_os.c \
 +	kernel.c \
 +	util.c \
 +	zfs_debug.c
 +
 +.PATH: ${ZFSTOP}/module/os/linux/zfs
 +
 +KERNEL_C = \
 +	simd_stat.c \
 +	zfeature_common.c \
 +	zfs_comutil.c \
 +	zfs_deleg.c \
 +	zfs_fletcher.c \
 +	zfs_fletcher_superscalar.c \
 +	zfs_fletcher_superscalar4.c \
 +	zfs_namecheck.c \
 +	zfs_prop.c \
 +	zfs_zstd.c \
 +	zpool_prop.c \
 +	zprop_common.c \
 +	abd.c \
 +	abd_os.c \
 +	aggsum.c \
 +	arc.c \
 +        blake3_zfs.c \
 +	blkptr.c \
 +	bplist.c \
 +	bpobj.c \
 +	bptree.c \
 +	bqueue.c \
 +	btree.c \
 +	brt.c \
 +	cityhash.c \
 +	dbuf.c \
 +	dbuf_stats.c \
 +	ddt.c \
 +	ddt_log.c \
 +	ddt_stats.c \
 +	ddt_zap.c \
 +	dmu.c \
 +	dmu_diff.c \
 +	dmu_direct.c \
 +	dmu_object.c \
 +	dmu_objset.c \
 +	dmu_recv.c \
 +	dmu_redact.c \
 +	dmu_send.c \
 +	dmu_traverse.c \
 +	dmu_tx.c \
 +	dmu_zfetch.c \
 +	dnode.c \
 +	dnode_sync.c \
 +	dsl_bookmark.c \
 +	dsl_dataset.c \
 +	dsl_deadlist.c \
 +	dsl_deleg.c \
 +	dsl_dir.c \
 +	dsl_crypt.c \
 +	dsl_pool.c \
 +	dsl_prop.c \
 +	dsl_scan.c \
 +	dsl_synctask.c \
 +	dsl_destroy.c \
 +	dsl_userhold.c \
 +	edonr_zfs.c \
 +	entropy_common.c \
 +	error_private.c \
 +	fm.c \
 +	fse_compress.c \
 +	fse_decompress.c \
 +	gzip.c \
 +	hist.c \
 +	hkdf.c \
 +	huf_compress.c \
 +	huf_decompress.c \
 +	lzjb.c \
 +	lz4.c \
 +	lz4_zfs.c \
 +	metaslab.c \
 +	mmp.c \
 +	multilist.c \
 +	objlist.c \
 +	pathname.c \
 +	pool.c \
 +	range_tree.c \
 +	refcount.c \
 +	rrwlock.c \
 +	sa.c \
 +	sha2_zfs.c \
 +	skein_zfs.c \
 +	spa.c \
 +	spa_checkpoint.c \
 +	spa_config.c \
 +	spa_errlog.c \
 +	spa_history.c \
 +	spa_log_spacemap.c \
 +	spa_misc.c \
 +	spa_stats.c \
 +	space_map.c \
 +	space_reftree.c \
 +	txg.c \
 +	u8_textprep.c \
 +	trace.c \
 +	uberblock.c \
 +	unique.c \
 +	vdev.c \
 +	vdev_draid.c \
 +	vdev_draid_rand.c \
 +	vdev_file.c \
 +	vdev_indirect_births.c \
 +	vdev_indirect.c \
 +	vdev_indirect_mapping.c \
 +	vdev_initialize.c \
 +	vdev_label.c \
 +	vdev_label_os.c \
 +	vdev_mirror.c \
 +	vdev_missing.c \
 +	vdev_queue.c \
 +	vdev_raidz.c \
 +	vdev_raidz_math_aarch64_neon.c \
 +	vdev_raidz_math_aarch64_neonx2.c \
 +	vdev_raidz_math_avx2.c \
 +	vdev_raidz_math_avx512bw.c \
 +	vdev_raidz_math_avx512f.c \
 +	vdev_raidz_math.c \
 +	vdev_raidz_math_scalar.c \
 +	vdev_rebuild.c \
 +	vdev_removal.c \
 +	vdev_root.c \
 +	vdev_trim.c \
 +	zap.c \
++	zap_fat.c \
++	zap_impl.c \
 +	zap_leaf.c \
 +	zap_micro.c \
 +	zcp.c \
 +	zcp_get.c \
 +	zcp_global.c \
 +	zcp_iter.c \
 +	zcp_set.c \
 +	zcp_synctask.c \
 +	zfeature.c \
 +	zfs_byteswap.c \
 +        zfs_chksum.c \
 +	zfs_crrd.c \
 +	zfs_debug_common.c \
 +	zfs_file_os.c \
 +	zfs_fm.c \
 +	zfs_fuid.c \
 +	zfs_impl.c \
 +	zfs_sa.c \
 +	zfs_znode.c \
 +	zfs_racct.c \
 +	zfs_ratelimit.c \
 +	zfs_rlock.c \
 +	zil.c \
 +	zio.c \
 +	zio_checksum.c \
 +	zio_compress.c \
 +	zio_crypt.c \
 +	zio_inject.c \
 +	zle.c \
 +	zrlock.c \
 +	zstd_common.c \
 +	zstd_compress.c \
 +	zstd_compress_literals.c \
 +	zstd_compress_sequences.c \
 +	zstd_compress_superblock.c \
 +	zstd_ddict.c \
 +	zstd_decompress.c \
 +	zstd_decompress_block.c \
 +	zstd_double_fast.c \
 +	zstd_fast.c \
 +	zstd_lazy.c \
 +	zstd_ldm.c \
 +	zstd_opt.c \
 +	zstd_preSplit.c \
 +	zthr.c
 +
 +ARCH_C =
 +.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
 +ARCH_C += 	vdev_raidz_math_sse2.c \
 +		vdev_raidz_math_ssse3.c \
 +		zfs_fletcher_intel.c \
 +		zfs_fletcher_sse.c 
 +CFLAGS +=  -DHAVE_SSE2 	-DHAVE_SSE3
 +.endif
 +.if ${MACHINE_ARCH} == "amd64"
 +ARCH_C +=	zfs_fletcher_avx512.c
 +CFLAGS+= -DHAVE_AVX2 -DHAVE_AVX -D__x86_64 -DHAVE_AVX512F \
 +	-DHAVE_AVX512BW
 +.endif
 +.if ${MACHINE_CPUARCH} == "aarch64"
 +ARCH_C +=	zfs_fletcher_aarch64_neon.c
 +.endif
 +
 +LUA_C = \
 +	lapi.c \
 +	lauxlib.c \
 +	lbaselib.c \
 +	lcode.c \
 +	lcompat.c \
 +	lcorolib.c \
 +	lctype.c \
 +	ldebug.c \
 +	ldo.c \
 +	lfunc.c \
 +	lgc.c \
 +	llex.c \
 +	lmem.c \
 +	lobject.c \
 +	lopcodes.c \
 +	lparser.c \
 +	lstate.c \
 +	lstring.c \
 +	lstrlib.c \
 +	ltable.c \
 +	ltablib.c \
 +	ltm.c \
 +	lvm.c \
 +	lzio.c
 +
 +SRCS+=		${USER_C} ${KERNEL_C} ${LUA_C} ${ARCH_C}
 +
 +
 +WARNS?=		2
 +CFLAGS+= \
 +	-DIN_BASE \
 +	-I${ZFSTOP}/include \
 +	-I${ZFSTOP}/lib/libspl/include \
 +	-I${ZFSTOP}/lib/libspl/include/os/freebsd \
 +	-I${ZFSTOP}/lib/libzpool/include \
 +	-I${SRCTOP}/sys \
 +	-I${SRCTOP}/cddl/compat/opensolaris/include \
 +	-I${ZFSTOP}/module/icp/include \
 +	-I${SRCTOP}/compat/linuxkpi/common/include/linux \
 +	-include ${ZFSTOP}/include/sys/simd_config.h \
 +	-include ${ZFSTOP}/include/os/freebsd/spl/sys/ccompile.h \
 +	-DHAVE_ISSETUGID \
 +	-include ${SRCTOP}/sys/modules/zfs/zfs_config.h \
 +	-I${SRCTOP}/sys/modules/zfs \
 +	-I${ZFSTOP}/include/os/freebsd/zfs \
 +	-DLIB_ZPOOL_BUILD -DZFS_DEBUG -DXXH_INLINE_ALL \
 +
 +# XXX: pthread doesn't have mutex_owned() equivalent, so we need to look
 +#      into libthr private structures. That's sooo evil, but it's only for
 +#      ZFS debugging tools needs.
 +CFLAGS+=	-DWANTS_MUTEX_OWNED
 +CFLAGS+=	-I${SRCTOP}/lib/libpthread/thread
 +CFLAGS+=	-I${SRCTOP}/lib/libpthread/sys
 +CFLAGS+=	-I${SRCTOP}/lib/libthr/arch/${MACHINE_CPUARCH}/include
 +
 +LIBADD=		md pthread z spl icp nvpair avl umem
 +
 +CSTD=	c99
 +
 +# Since there are many asserts in this library, it makes no sense to compile
 +# it without debugging.
 +
 +CFLAGS+=	-g -DDEBUG=1
 +
 +CFLAGS.gcc+=	-Wno-pointer-to-int-cast
 +
 +# Some versions of LLVM contain duplicate typedefs in the <*intrin.h> headers,
 +# which are not allowed prior to C11; since libzpool is built with C99, make
 +# this not be an error.
 +CFLAGS.clang+=	-Wno-error=typedef-redefinition
 +
 +# Pointer values are used as debugging "tags" to mark reference count
 +# ownerships and in some cases the tag reference is dropped after an
 +# object is freed.
 +CFLAGS.dbuf.c=			${NO_WUSE_AFTER_FREE}
 +CFLAGS.entropy_common.c=	-fno-tree-vectorize
 +CFLAGS.entropy_common.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.error_private.c=		-fno-tree-vectorize
 +CFLAGS.error_private.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.fse_compress.c=		-fno-tree-vectorize
 +CFLAGS.fse_compress.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.fse_decompress.c=	-fno-tree-vectorize
 +CFLAGS.fse_decompress.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.hist.c=			-fno-tree-vectorize
 +CFLAGS.hist.c+=			${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.huf_compress.c=		-fno-tree-vectorize
 +CFLAGS.huf_compress.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.huf_decompress.c=	-fno-tree-vectorize
 +CFLAGS.huf_decompress.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.pool.c=			-fno-tree-vectorize
 +CFLAGS.pool.c+=			${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.xxhash.c=		-fno-tree-vectorize
 +CFLAGS.xxhash.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_compress.c=		-fno-tree-vectorize
 +CFLAGS.zstd_compress.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_compress_literals.c=	-fno-tree-vectorize
 +CFLAGS.zstd_compress_literals.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_compress_sequences.c=	-fno-tree-vectorize
 +CFLAGS.zstd_compress_sequences.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_compress_superblock.c=	-fno-tree-vectorize
 +CFLAGS.zstd_compress_superblock.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_double_fast.c=	-fno-tree-vectorize
 +CFLAGS.zstd_double_fast.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_fast.c=		-fno-tree-vectorize
 +CFLAGS.zstd_fast.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_lazy.c=		-fno-tree-vectorize
 +CFLAGS.zstd_lazy.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_ldm.c=		-fno-tree-vectorize
 +CFLAGS.zstd_ldm.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_opt.c=		-fno-tree-vectorize
 +CFLAGS.zstd_opt.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_ddict.c=		-fno-tree-vectorize
 +CFLAGS.zstd_ddict.c+=		${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_decompress.c=	-fno-tree-vectorize
 +CFLAGS.zstd_decompress.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +CFLAGS.zstd_decompress_block.c=	-fno-tree-vectorize
 +CFLAGS.zstd_decompress_block.c+=	${NO_WBITWISE_INSTEAD_OF_LOGICAL}
 +
 +.include <bsd.lib.mk>
diff --cc sys/conf/files
index 379685d83713,000000000000..324ee35d490d
mode 100644,000000..100644
--- a/sys/conf/files
+++ b/sys/conf/files
@@@ -1,5390 -1,0 +1,5392 @@@
 +#
 +# The long compile-with and dependency lines are required because of
 +# limitations in config: backslash-newline doesn't work in strings, and
 +# dependency lines other than the first are silently ignored.
 +#
 +acpi_quirks.h			optional acpi				   \
 +	dependency	"$S/tools/acpi_quirks2h.awk $S/dev/acpica/acpi_quirks" \
 +	compile-with	"${AWK} -f $S/tools/acpi_quirks2h.awk $S/dev/acpica/acpi_quirks" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"acpi_quirks.h"
 +bhnd_nvram_map.h		optional bhnd				   \
 +	dependency	"$S/dev/bhnd/tools/nvram_map_gen.sh $S/dev/bhnd/tools/nvram_map_gen.awk $S/dev/bhnd/nvram/nvram_map" \
 +	compile-with	"sh $S/dev/bhnd/tools/nvram_map_gen.sh $S/dev/bhnd/nvram/nvram_map -h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"bhnd_nvram_map.h"
 +bhnd_nvram_map_data.h		optional bhnd				   \
 +	dependency	"$S/dev/bhnd/tools/nvram_map_gen.sh $S/dev/bhnd/tools/nvram_map_gen.awk $S/dev/bhnd/nvram/nvram_map" \
 +	compile-with	"sh $S/dev/bhnd/tools/nvram_map_gen.sh $S/dev/bhnd/nvram/nvram_map -d" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"bhnd_nvram_map_data.h"
 +fdt_static_dtb.h		optional fdt fdt_dtb_static \
 +	compile-with "sh -c 'MACHINE=${MACHINE} $S/tools/fdt/make_dtbh.sh ${FDT_DTS_FILE} ${.OBJDIR}'" \
 +	dependency	"${FDT_DTS_FILE:T:R}.dtb" \
 +	no-obj no-implicit-rule before-depend \
 +	clean		"fdt_static_dtb.h"
 +feeder_eq_gen.h			optional sound				   \
 +	dependency	"$S/tools/sound/feeder_eq_mkfilter.awk"		   \
 +	compile-with	"${AWK} -f $S/tools/sound/feeder_eq_mkfilter.awk -- ${FEEDER_EQ_PRESETS} > feeder_eq_gen.h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"feeder_eq_gen.h"
 +feeder_rate_gen.h		optional sound				   \
 +	dependency	"$S/tools/sound/feeder_rate_mkfilter.awk"	   \
 +	compile-with	"${AWK} -f $S/tools/sound/feeder_rate_mkfilter.awk -- ${FEEDER_RATE_PRESETS} > feeder_rate_gen.h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"feeder_rate_gen.h"
 +font.h				optional	sc_dflt_font		\
 +	compile-with	"uudecode < ${SRCTOP}/share/syscons/fonts/${SC_DFLT_FONT}-8x16.fnt && file2c 'u_char dflt_font_16[16*256] = {' '};' < ${SC_DFLT_FONT}-8x16 > font.h && uudecode < ${SRCTOP}/share/syscons/fonts/${SC_DFLT_FONT}-8x14.fnt && file2c 'u_char dflt_font_14[14*256] = {' '};' < ${SC_DFLT_FONT}-8x14 >> font.h && uudecode < ${SRCTOP}/share/syscons/fonts/${SC_DFLT_FONT}-8x8.fnt && file2c 'u_char dflt_font_8[8*256] = {' '};' < ${SC_DFLT_FONT}-8x8 >> font.h"									\
 +	no-obj no-implicit-rule before-depend				\
 +	clean		"font.h ${SC_DFLT_FONT}-8x14 ${SC_DFLT_FONT}-8x16 ${SC_DFLT_FONT}-8x8"
 +snd_fxdiv_gen.h			optional sound				   \
 +	dependency	"$S/tools/sound/snd_fxdiv_gen.awk"		   \
 +	compile-with	"${AWK} -f $S/tools/sound/snd_fxdiv_gen.awk -- > snd_fxdiv_gen.h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"snd_fxdiv_gen.h"
 +miidevs.h			optional miibus | mii			   \
 +	dependency	"$S/tools/miidevs2h.awk $S/dev/mii/miidevs"	   \
 +	compile-with	"${AWK} -f $S/tools/miidevs2h.awk $S/dev/mii/miidevs" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"miidevs.h"
 +kbdmuxmap.h			optional	kbdmux_dflt_keymap 	   \
 +	compile-with	"${KEYMAP} -L ${KBDMUX_DFLT_KEYMAP} | ${KEYMAP_FIX} > ${.TARGET}" \
 +	no-obj no-implicit-rule before-depend				\
 +	clean		"kbdmuxmap.h"
 +teken_state.h		optional sc | vt				   \
 +	dependency	"$S/teken/gensequences $S/teken/sequences" \
 +	compile-with	"${AWK} -f $S/teken/gensequences $S/teken/sequences > teken_state.h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"teken_state.h"
 +ukbdmap.h			optional	ukbd_dflt_keymap	\
 +	compile-with	"${KEYMAP} -L ${UKBD_DFLT_KEYMAP} | ${KEYMAP_FIX} > ${.TARGET}" \
 +	no-obj no-implicit-rule before-depend				\
 +	clean		"ukbdmap.h"
 +usbdevs.h			optional usb | hid			   \
 +	dependency	"$S/tools/usbdevs2h.awk $S/dev/usb/usbdevs" \
 +	compile-with	"${AWK} -f $S/tools/usbdevs2h.awk $S/dev/usb/usbdevs -h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"usbdevs.h"
 +usbdevs_data.h			optional usb				   \
 +	dependency	"$S/tools/usbdevs2h.awk $S/dev/usb/usbdevs" \
 +	compile-with	"${AWK} -f $S/tools/usbdevs2h.awk $S/dev/usb/usbdevs -d" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"usbdevs_data.h"
 +sdiodevs.h			optional mmccam				   \
 +	dependency	"$S/tools/sdiodevs2h.awk $S/dev/sdio/sdiodevs" \
 +	compile-with	"${AWK} -f $S/tools/sdiodevs2h.awk $S/dev/sdio/sdiodevs -h" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"sdiodevs.h"
 +sdiodevs_data.h			optional mmccam				   \
 +	dependency	"$S/tools/sdiodevs2h.awk $S/dev/sdio/sdiodevs" \
 +	compile-with	"${AWK} -f $S/tools/sdiodevs2h.awk $S/dev/sdio/sdiodevs -d" \
 +	no-obj no-implicit-rule before-depend				   \
 +	clean		"sdiodevs_data.h"
 +cam/cam.c			optional scbus
 +cam/cam_compat.c		optional scbus
 +cam/cam_iosched.c		optional scbus
 +cam/cam_periph.c		optional scbus
 +cam/cam_queue.c			optional scbus
 +cam/cam_sim.c			optional scbus
 +cam/cam_xpt.c			optional scbus
 +cam/ata/ata_all.c		optional scbus
 +cam/ata/ata_xpt.c		optional scbus
 +cam/ata/ata_pmp.c		optional scbus
 +cam/nvme/nvme_all.c		optional scbus
 +cam/nvme/nvme_da.c		optional nda | da
 +cam/nvme/nvme_xpt.c		optional scbus
 +cam/scsi/scsi_xpt.c		optional scbus
 +cam/scsi/scsi_all.c		optional scbus
 +cam/scsi/scsi_cd.c		optional cd
 +cam/scsi/scsi_ch.c		optional ch
 +cam/ata/ata_da.c		optional ada | da
 +cam/ctl/ctl.c			optional ctl
 +cam/ctl/ctl_backend.c		optional ctl
 +cam/ctl/ctl_backend_block.c	optional ctl
 +cam/ctl/ctl_backend_ramdisk.c	optional ctl
 +cam/ctl/ctl_cmd_table.c		optional ctl
 +cam/ctl/ctl_frontend.c		optional ctl
 +cam/ctl/ctl_frontend_cam_sim.c	optional ctl
 +cam/ctl/ctl_frontend_ioctl.c	optional ctl
 +cam/ctl/ctl_frontend_iscsi.c	optional ctl cfiscsi
 +cam/ctl/ctl_ha.c		optional ctl
 +cam/ctl/ctl_nvme_all.c		optional ctl
 +cam/ctl/ctl_nvme_cmd_table.c	optional ctl
 +cam/ctl/ctl_scsi_all.c		optional ctl
 +cam/ctl/ctl_tpc.c		optional ctl
 +cam/ctl/ctl_tpc_local.c		optional ctl
 +cam/ctl/ctl_error.c		optional ctl
 +cam/ctl/ctl_util.c		optional ctl
 +cam/ctl/scsi_ctl.c		optional ctl
 +cam/mmc/mmc_xpt.c		optional scbus mmccam
 +cam/mmc/mmc_sim.c		optional scbus mmccam
 +cam/mmc/mmc_sim_if.m		optional scbus mmccam
 +cam/mmc/mmc_da.c		optional scbus mmccam da
 +cam/scsi/scsi_da.c		optional da
 +cam/scsi/scsi_pass.c		optional pass
 +cam/scsi/scsi_pt.c		optional pt
 +cam/scsi/scsi_sa.c		optional sa
 +cam/scsi/scsi_enc.c		optional ses
 +cam/scsi/scsi_enc_ses.c		optional ses
 +cam/scsi/scsi_enc_safte.c	optional ses
 +cam/scsi/scsi_sg.c		optional sg
 +cam/scsi/scsi_targ_bh.c		optional targbh
 +cam/scsi/scsi_target.c		optional targ
 +cam/scsi/smp_all.c		optional scbus
 +
 +# shared between zfs and dtrace
 +cddl/compat/opensolaris/kern/opensolaris.c		optional dtrace compile-with "${CDDL_C}"
 +cddl/compat/opensolaris/kern/opensolaris_proc.c		optional zfs | dtrace compile-with "${CDDL_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_misc.c		optional zfs | dtrace compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_cmn_err.c		optional zfs | dtrace compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_taskq.c		optional zfs | dtrace compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_kmem.c		optional zfs | dtrace compile-with "${ZFS_C}"
 +
 +#zfs solaris portability layer
 +contrib/openzfs/module/os/freebsd/spl/acl_common.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/callb.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/list.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_acl.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_dtrace.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_kstat.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_policy.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_procfs_list.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_string.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_sunddi.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_uio.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_vfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_vm.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_zlib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/spl/spl_zone.c		optional zfs compile-with "${ZFS_C}"
 +
 +
 +
 +# zfs specific
 +
 +#zfs avl
 +contrib/openzfs/module/avl/avl.c				optional zfs compile-with "${ZFS_C}"
 +
 +# zfs lua support
 +contrib/openzfs/module/lua/lapi.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lauxlib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lbaselib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lcode.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lcompat.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lcorolib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lctype.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/ldebug.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/ldo.c			optional zfs compile-with "${ZFS_C} ${NO_WINFINITE_RECURSION}"
 +contrib/openzfs/module/lua/lfunc.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lgc.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/llex.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lmem.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lobject.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lopcodes.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lparser.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lstate.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lstring.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lstrlib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/ltable.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/ltablib.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/ltm.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lvm.c			optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/lua/lzio.c			optional zfs compile-with "${ZFS_C}"
 +
 +# zfs nvpair support
 +contrib/openzfs/module/nvpair/fnvpair.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/nvpair/nvpair.c		optional zfs compile-with "${ZFS_RPC_C} ${NO_WSTRINGOP_OVERREAD}"
 +contrib/openzfs/module/nvpair/nvpair_alloc_fixed.c	optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/nvpair/nvpair_alloc_spl.c	optional zfs compile-with "${ZFS_C}"
 +
 +#zfs platform compatibility code
 +contrib/openzfs/module/os/freebsd/zfs/abd_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/arc_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/crypto_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/dmu_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/event_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/hkdf.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/kmod_core.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/spa_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/sysctl_os.c		optional zfs compile-with "${ZFS_C}  -include $S/modules/zfs/zfs_config.h"
 +contrib/openzfs/module/os/freebsd/zfs/vdev_label_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/vdev_geom.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_ctldir.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_debug.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_dir.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_file_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_ioctl_compat.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_ioctl_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_racct.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_vfsops.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zfs_znode_os.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zio_crypt.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/os/freebsd/zfs/zvol_os.c		optional zfs compile-with "${ZFS_C}"
 +
 +#zfs checksums / zcommon
 +contrib/openzfs/module/zcommon/cityhash.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfeature_common.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_comutil.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_deleg.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_fletcher.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_fletcher_superscalar.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_fletcher_superscalar4.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_namecheck.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_prop.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zfs_valstr.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zpool_prop.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zcommon/zprop_common.c		optional zfs compile-with "${ZFS_C}"
 +
 +# zfs edon-r hash support
 +contrib/openzfs/module/icp/algs/edonr/edonr.c		optional zfs compile-with "${ZFS_C}"
 +
 +# zfs blake3 hash support
 +contrib/openzfs/module/icp/algs/blake3/blake3.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/icp/algs/blake3/blake3_generic.c	optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/icp/algs/blake3/blake3_impl.c	optional zfs compile-with "${ZFS_C}"
 +
 +# zfs sha2 hash support
 +contrib/openzfs/module/icp/algs/sha2/sha2_generic.c	optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/icp/algs/sha2/sha256_impl.c	optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/icp/algs/sha2/sha512_impl.c	optional zfs compile-with "${ZFS_C}"
 +
 +#zfs core common code
 +contrib/openzfs/module/zfs/abd.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/aggsum.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/arc.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/blake3_zfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/blkptr.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/bplist.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/bpobj.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/bptree.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/brt.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/btree.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/bqueue.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dbuf.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dbuf_stats.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dataset_kstats.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/ddt.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/ddt_log.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/ddt_stats.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/ddt_zap.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_direct.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_diff.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_object.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_objset.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_recv.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_redact.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_send.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_traverse.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_tx.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dmu_zfetch.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dnode.c		optional zfs compile-with "${ZFS_C} ${NO_WUNUSED_BUT_SET_VARIABLE}" \
 +	warning "kernel contains CDDL licensed ZFS filesystem"
 +contrib/openzfs/module/zfs/dnode_sync.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_bookmark.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_crypt.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_dataset.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_deadlist.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_deleg.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_destroy.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_dir.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_pool.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_prop.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_scan.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_synctask.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/dsl_userhold.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/edonr_zfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/fm.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/gzip.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/lzjb.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/lz4.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/lz4_zfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/metaslab.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/mmp.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/multilist.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/objlist.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/pathname.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/range_tree.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/refcount.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/rrwlock.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/sa.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/sha2_zfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/skein_zfs.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_checkpoint.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_config.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_errlog.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_history.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_log_spacemap.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_misc.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/spa_stats.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/space_map.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/space_reftree.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/txg.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/u8_textprep.c           optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/uberblock.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/unique.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_draid.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_draid_rand.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_file.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_indirect.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_indirect_births.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_indirect_mapping.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_initialize.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_label.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_mirror.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_missing.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_queue.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_raidz.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_raidz_math.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_raidz_math_scalar.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_rebuild.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_removal.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_root.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/vdev_trim.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zap.c		optional zfs compile-with "${ZFS_C}"
++contrib/openzfs/module/zfs/zap_fat.c		optional zfs compile-with "${ZFS_C}"
++contrib/openzfs/module/zfs/zap_impl.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zap_leaf.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zap_micro.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp_get.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp_global.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp_iter.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp_set.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zcp_synctask.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfeature.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_byteswap.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_chksum.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_crrd.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_fm.c		optional zfs compile-with "${ZFS_C} ${NO_WUNUSED_BUT_SET_VARIABLE}"
 +contrib/openzfs/module/zfs/zfs_fuid.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_impl.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_ioctl.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_log.c		optional zfs compile-with "${ZFS_C}"
 +contrib/openzfs/module/zfs/zfs_onexit.c		optional zfs compile-with "${ZFS_C}"
*** 14849 LINES SKIPPED ***