Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 29 Mar 2022 07:41:05 -0800
From:      Rob Wing <rob.fx907@gmail.com>
To:        Martin Matuska <mm@freebsd.org>
Cc:        src-committers@freebsd.org, dev-commits-src-all@freebsd.org,  dev-commits-src-branches@freebsd.org
Subject:   Re: git: 99c3f1577459 - releng/13.1 - zfs: merge openzfs/zfs@52bad4f23 (zfs-2.1-release) into stable/13
Message-ID:  <CAF3%2Bn_e%2BM=3K6EMcN6XJvpC3f8cuSFbM25dqY=xthpzdDy%2B-yw@mail.gmail.com>
In-Reply-To: <202203291353.22TDr3cf008660@gitrepo.freebsd.org>
References:  <202203291353.22TDr3cf008660@gitrepo.freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
--0000000000009d978a05db5d4121
Content-Type: text/plain; charset="UTF-8"

Martin,

Is there any reason not to cherry-pick this commit in:
https://github.com/openzfs/zfs/commit/4a1195ca5041cbff2a6b025a31937fef84876c52
?

I bring it up because a few users have expressed interest in it.
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=260160


On Tue, Mar 29, 2022 at 5:53 AM Martin Matuska <mm@freebsd.org> wrote:

> The branch releng/13.1 has been updated by mm:
>
> URL:
> https://cgit.FreeBSD.org/src/commit/?id=99c3f15774595c1163ecec87aa8cb157ccdc7d96
>
> commit 99c3f15774595c1163ecec87aa8cb157ccdc7d96
> Author:     Martin Matuska <mm@FreeBSD.org>
> AuthorDate: 2022-03-29 10:41:53 +0000
> Commit:     Martin Matuska <mm@FreeBSD.org>
> CommitDate: 2022-03-29 13:50:47 +0000
>
>     zfs: merge openzfs/zfs@52bad4f23 (zfs-2.1-release) into stable/13
>
>     OpenZFS release 2.1.4
>
>     Notable upstream pull request merges:
>       #13219 FreeBSD: add missing replay check to an assert in
> zfs_xvattr_set
>       #13220 module: freebsd: avoid a taking a destroyed lock in
> zfs_zevent bits
>       #13221 Fix ACL checks for NFS kernel server
>
>     Obtained from:  OpenZFS
>     OpenZFS tag:    zfs-2.1.4
>     OpenZFS commit: 52bad4f23daaa5f827f802c8d05785a27b80275d
>     Relnotes:       yes
>     Approved by:    re (gjb)
>
>     (cherry picked from commit c088e4d539e4cc947896a3b156646b831d932539)
> ---
>  sys/conf/kern.pre.mk                               |   2 +-
>  sys/contrib/openzfs/META                           |   4 +-
>  sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c       | 179
> +++++++++++++++++++--
>  sys/contrib/openzfs/cmd/zed/zed_disk_event.c       |  10 ++
>  .../openzfs/include/os/freebsd/spl/sys/Makefile.am |   1 -
>  .../openzfs/include/os/freebsd/spl/sys/cred.h      | 136 ++--------------
>  .../openzfs/include/os/freebsd/spl/sys/kidmap.h    |  41 -----
>  .../openzfs/include/os/freebsd/spl/sys/sid.h       |  25 ---
>  .../include/os/linux/kernel/linux/simd_x86.h       |   4 +-
>  .../openzfs/include/os/linux/spl/sys/cred.h        |   5 -
>  sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c     |   1 -
>  .../lib/libzutil/os/linux/zutil_device_path_os.c   |  28 ++--
>  sys/contrib/openzfs/module/Makefile.bsd            |   2 +-
>  .../openzfs/module/os/freebsd/spl/spl_sysevent.c   |  12 +-
>  .../openzfs/module/os/freebsd/zfs/zfs_acl.c        |   6 +-
>  .../openzfs/module/os/freebsd/zfs/zfs_vnops_os.c   |  19 +--
>  .../openzfs/module/os/freebsd/zfs/zfs_znode.c      |   4 +-
>  sys/contrib/openzfs/module/os/linux/spl/spl-cred.c |  42 +----
>  sys/contrib/openzfs/module/os/linux/zfs/policy.c   |  10 +-
>  .../openzfs/module/os/linux/zfs/zpl_inode.c        |   4 +-
>  .../openzfs/module/os/linux/zfs/zpl_xattr.c        |   4 +-
>  sys/contrib/openzfs/module/zfs/arc.c               |   2 +-
>  sys/modules/zfs/Makefile                           |   2 +-
>  sys/modules/zfs/zfs_config.h                       |   8 +-
>  sys/modules/zfs/zfs_gitrev.h                       |   3 +-
>  25 files changed, 242 insertions(+), 312 deletions(-)
>
> diff --git a/sys/conf/kern.pre.mk b/sys/conf/kern.pre.mk
> index d6ab5e17a82a..6be49642b04e 100644
> --- a/sys/conf/kern.pre.mk
> +++ b/sys/conf/kern.pre.mk
> @@ -262,7 +262,7 @@ CDDL_C=             ${CC} -c ${CDDL_CFLAGS} ${WERROR}
> ${PROF} ${.IMPSRC}
>  # Special flags for managing the compat compiles for ZFS
>  ZFS_CFLAGS+=   ${CDDL_CFLAGS} -DBUILDING_ZFS -DHAVE_UIO_ZEROCOPY \
>         -DWITH_NETDUMP -D__KERNEL__ -D_SYS_CONDVAR_H_ -DSMP \
> -       -DIN_FREEBSD_BASE -DHAVE_KSID
> +       -DIN_FREEBSD_BASE
>
>  .if ${MACHINE_ARCH} == "amd64"
>  ZFS_CFLAGS+= -DHAVE_AVX2 -DHAVE_AVX -D__x86_64 -DHAVE_SSE2 -DHAVE_AVX512F
> \
> diff --git a/sys/contrib/openzfs/META b/sys/contrib/openzfs/META
> index 0437224b403f..76e59a42074c 100644
> --- a/sys/contrib/openzfs/META
> +++ b/sys/contrib/openzfs/META
> @@ -1,10 +1,10 @@
>  Meta:          1
>  Name:          zfs
>  Branch:        1.0
> -Version:       2.1.3
> +Version:       2.1.4
>  Release:       1
>  Release-Tags:  relext
>  License:       CDDL
>  Author:        OpenZFS
> -Linux-Maximum: 5.16
> +Linux-Maximum: 5.17
>  Linux-Minimum: 3.10
> diff --git a/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c
> b/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c
> index 3bcdf6e1d718..a510d646e1f9 100644
> --- a/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c
> +++ b/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c
> @@ -183,14 +183,14 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>         nvlist_t *nvroot, *newvd;
>         pendingdev_t *device;
>         uint64_t wholedisk = 0ULL;
> -       uint64_t offline = 0ULL;
> +       uint64_t offline = 0ULL, faulted = 0ULL;
>         uint64_t guid = 0ULL;
>         char *physpath = NULL, *new_devid = NULL, *enc_sysfs_path = NULL;
>         char rawpath[PATH_MAX], fullpath[PATH_MAX];
>         char devpath[PATH_MAX];
>         int ret;
> -       boolean_t is_dm = B_FALSE;
>         boolean_t is_sd = B_FALSE;
> +       boolean_t is_mpath_wholedisk = B_FALSE;
>         uint_t c;
>         vdev_stat_t *vs;
>
> @@ -211,15 +211,73 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>             &enc_sysfs_path);
>         (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_WHOLE_DISK,
> &wholedisk);
>         (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_OFFLINE, &offline);
> +       (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_FAULTED, &faulted);
> +
>         (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_GUID, &guid);
>
> -       if (offline)
> -               return;  /* don't intervene if it was taken offline */
> +       /*
> +        * Special case:
> +        *
> +        * We've seen times where a disk won't have a
> ZPOOL_CONFIG_PHYS_PATH
> +        * entry in their config. For example, on this force-faulted disk:
> +        *
> +        *      children[0]:
> +        *         type: 'disk'
> +        *         id: 0
> +        *         guid: 14309659774640089719
> +        *        path: '/dev/disk/by-vdev/L28'
> +        *        whole_disk: 0
> +        *        DTL: 654
> +        *        create_txg: 4
> +        *        com.delphix:vdev_zap_leaf: 1161
> +        *        faulted: 1
> +        *        aux_state: 'external'
> +        *      children[1]:
> +        *        type: 'disk'
> +        *        id: 1
> +        *        guid: 16002508084177980912
> +        *        path: '/dev/disk/by-vdev/L29'
> +        *        devid: 'dm-uuid-mpath-35000c500a61d68a3'
> +        *        phys_path: 'L29'
> +        *        vdev_enc_sysfs_path: '/sys/class/enclosure/0:0:1:0/SLOT
> 30 32'
> +        *        whole_disk: 0
> +        *        DTL: 1028
> +        *        create_txg: 4
> +        *        com.delphix:vdev_zap_leaf: 131
> +        *
> +        * If the disk's path is a /dev/disk/by-vdev/ path, then we can
> infer
> +        * the ZPOOL_CONFIG_PHYS_PATH from the by-vdev disk name.
> +        */
> +       if (physpath == NULL && path != NULL) {
> +               /* If path begins with "/dev/disk/by-vdev/" ... */
> +               if (strncmp(path, DEV_BYVDEV_PATH,
> +                   strlen(DEV_BYVDEV_PATH)) == 0) {
> +                       /* Set physpath to the char after
> "/dev/disk/by-vdev" */
> +                       physpath = &path[strlen(DEV_BYVDEV_PATH)];
> +               }
> +       }
> +
> +       /*
> +        * We don't want to autoreplace offlined disks.  However, we do
> want to
> +        * replace force-faulted disks (`zpool offline -f`).  Force-faulted
> +        * disks have both offline=1 and faulted=1 in the nvlist.
> +        */
> +       if (offline && !faulted) {
> +               zed_log_msg(LOG_INFO, "%s: %s is offline, skip
> autoreplace",
> +                   __func__, path);
> +               return;
> +       }
>
> -       is_dm = zfs_dev_is_dm(path);
> +       is_mpath_wholedisk = is_mpath_whole_disk(path);
>         zed_log_msg(LOG_INFO, "zfs_process_add: pool '%s' vdev '%s', phys
> '%s'"
> -           " wholedisk %d, %s dm (guid %llu)", zpool_get_name(zhp), path,
> -           physpath ? physpath : "NULL", wholedisk, is_dm ? "is" : "not",
> +           " %s blank disk, %s mpath blank disk, %s labeled, enc sysfs
> '%s', "
> +           "(guid %llu)",
> +           zpool_get_name(zhp), path,
> +           physpath ? physpath : "NULL",
> +           wholedisk ? "is" : "not",
> +           is_mpath_wholedisk? "is" : "not",
> +           labeled ? "is" : "not",
> +           enc_sysfs_path,
>             (long long unsigned int)guid);
>
>         /*
> @@ -253,8 +311,9 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>             ZFS_ONLINE_CHECKREMOVE | ZFS_ONLINE_UNSPARE, &newstate) == 0 &&
>             (newstate == VDEV_STATE_HEALTHY ||
>             newstate == VDEV_STATE_DEGRADED)) {
> -               zed_log_msg(LOG_INFO, "  zpool_vdev_online: vdev %s is %s",
> -                   fullpath, (newstate == VDEV_STATE_HEALTHY) ?
> +               zed_log_msg(LOG_INFO,
> +                   "  zpool_vdev_online: vdev '%s' ('%s') is "
> +                   "%s", fullpath, physpath, (newstate ==
> VDEV_STATE_HEALTHY) ?
>                     "HEALTHY" : "DEGRADED");
>                 return;
>         }
> @@ -271,11 +330,12 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>          * vdev online to trigger a FMA fault by posting an ereport.
>          */
>         if (!zpool_get_prop_int(zhp, ZPOOL_PROP_AUTOREPLACE, NULL) ||
> -           !(wholedisk || is_dm) || (physpath == NULL)) {
> +           !(wholedisk || is_mpath_wholedisk) || (physpath == NULL)) {
>                 (void) zpool_vdev_online(zhp, fullpath,
> ZFS_ONLINE_FORCEFAULT,
>                     &newstate);
>                 zed_log_msg(LOG_INFO, "Pool's autoreplace is not enabled
> or "
> -                   "not a whole disk for '%s'", fullpath);
> +                   "not a blank disk for '%s' ('%s')", fullpath,
> +                   physpath);
>                 return;
>         }
>
> @@ -287,7 +347,7 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>         (void) snprintf(rawpath, sizeof (rawpath), "%s%s",
>             is_sd ? DEV_BYVDEV_PATH : DEV_BYPATH_PATH, physpath);
>
> -       if (realpath(rawpath, devpath) == NULL && !is_dm) {
> +       if (realpath(rawpath, devpath) == NULL && !is_mpath_wholedisk) {
>                 zed_log_msg(LOG_INFO, "  realpath: %s failed (%s)",
>                     rawpath, strerror(errno));
>
> @@ -303,12 +363,14 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev,
> boolean_t labeled)
>         if ((vs->vs_state != VDEV_STATE_DEGRADED) &&
>             (vs->vs_state != VDEV_STATE_FAULTED) &&
>             (vs->vs_state != VDEV_STATE_CANT_OPEN)) {
> +               zed_log_msg(LOG_INFO, "  not autoreplacing since disk
> isn't in "
> +                   "a bad state (currently %d)", vs->vs_state);
>                 return;
>         }
>
>         nvlist_lookup_string(vdev, "new_devid", &new_devid);
>
> -       if (is_dm) {
> +       if (is_mpath_wholedisk) {
>                 /* Don't label device mapper or multipath disks. */
>         } else if (!labeled) {
>                 /*
> @@ -522,8 +584,11 @@ zfs_iter_vdev(zpool_handle_t *zhp, nvlist_t *nvl,
> void *data)
>                  * the dp->dd_compare value.
>                  */
>                 if (nvlist_lookup_string(nvl, dp->dd_prop, &path) != 0 ||
> -                   strcmp(dp->dd_compare, path) != 0)
> +                   strcmp(dp->dd_compare, path) != 0) {
> +                       zed_log_msg(LOG_INFO, "  %s: no match (%s != vdev
> %s)",
> +                           __func__, dp->dd_compare, path);
>                         return;
> +               }
>
>                 zed_log_msg(LOG_INFO, "  zfs_iter_vdev: matched %s on %s",
>                     dp->dd_prop, path);
> @@ -571,6 +636,8 @@ zfs_iter_pool(zpool_handle_t *zhp, void *data)
>                             ZPOOL_CONFIG_VDEV_TREE, &nvl);
>                         zfs_iter_vdev(zhp, nvl, data);
>                 }
> +       } else {
> +               zed_log_msg(LOG_INFO, "%s: no config\n", __func__);
>         }
>
>         /*
> @@ -619,6 +686,72 @@ devphys_iter(const char *physical, const char *devid,
> zfs_process_func_t func,
>         return (data.dd_found);
>  }
>
> +/*
> + * Given a device identifier, find any vdevs with a matching by-vdev
> + * path.  Normally we shouldn't need this as the comparison would be
> + * made earlier in the devphys_iter().  For example, if we were replacing
> + * /dev/disk/by-vdev/L28, normally devphys_iter() would match the
> + * ZPOOL_CONFIG_PHYS_PATH of "L28" from the old disk config to "L28"
> + * of the new disk config.  However, we've seen cases where
> + * ZPOOL_CONFIG_PHYS_PATH was not in the config for the old disk.  Here's
> + * an example of a real 2-disk mirror pool where one disk was force
> + * faulted:
> + *
> + *       com.delphix:vdev_zap_top: 129
> + *           children[0]:
> + *               type: 'disk'
> + *               id: 0
> + *               guid: 14309659774640089719
> + *               path: '/dev/disk/by-vdev/L28'
> + *               whole_disk: 0
> + *               DTL: 654
> + *               create_txg: 4
> + *               com.delphix:vdev_zap_leaf: 1161
> + *               faulted: 1
> + *               aux_state: 'external'
> + *           children[1]:
> + *               type: 'disk'
> + *               id: 1
> + *               guid: 16002508084177980912
> + *               path: '/dev/disk/by-vdev/L29'
> + *               devid: 'dm-uuid-mpath-35000c500a61d68a3'
> + *               phys_path: 'L29'
> + *               vdev_enc_sysfs_path: '/sys/class/enclosure/0:0:1:0/SLOT
> 30 32'
> + *               whole_disk: 0
> + *               DTL: 1028
> + *               create_txg: 4
> + *               com.delphix:vdev_zap_leaf: 131
> + *
> + * So in the case above, the only thing we could compare is the path.
> + *
> + * We can do this because we assume by-vdev paths are authoritative as
> physical
> + * paths.  We could not assume this for normal paths like /dev/sda since
> the
> + * physical location /dev/sda points to could change over time.
> + */
> +static boolean_t
> +by_vdev_path_iter(const char *by_vdev_path, const char *devid,
> +    zfs_process_func_t func, boolean_t is_slice)
> +{
> +       dev_data_t data = { 0 };
> +
> +       data.dd_compare = by_vdev_path;
> +       data.dd_func = func;
> +       data.dd_prop = ZPOOL_CONFIG_PATH;
> +       data.dd_found = B_FALSE;
> +       data.dd_islabeled = is_slice;
> +       data.dd_new_devid = devid;
> +
> +       if (strncmp(by_vdev_path, DEV_BYVDEV_PATH,
> +           strlen(DEV_BYVDEV_PATH)) != 0) {
> +               /* by_vdev_path doesn't start with "/dev/disk/by-vdev/" */
> +               return (B_FALSE);
> +       }
> +
> +       (void) zpool_iter(g_zfshdl, zfs_iter_pool, &data);
> +
> +       return (data.dd_found);
> +}
> +
>  /*
>   * Given a device identifier, find any vdevs with a matching devid.
>   * On Linux we can match devid directly which is always a whole disk.
> @@ -683,15 +816,17 @@ guid_iter(uint64_t pool_guid, uint64_t vdev_guid,
> const char *devid,
>  static int
>  zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)
>  {
> -       char *devpath = NULL, *devid;
> +       char *devpath = NULL, *devid = NULL;
>         uint64_t pool_guid = 0, vdev_guid = 0;
>         boolean_t is_slice;
>
>         /*
>          * Expecting a devid string and an optional physical location and
> guid
>          */
> -       if (nvlist_lookup_string(nvl, DEV_IDENTIFIER, &devid) != 0)
> +       if (nvlist_lookup_string(nvl, DEV_IDENTIFIER, &devid) != 0) {
> +               zed_log_msg(LOG_INFO, "%s: no dev identifier\n", __func__);
>                 return (-1);
> +       }
>
>         (void) nvlist_lookup_string(nvl, DEV_PHYS_PATH, &devpath);
>         (void) nvlist_lookup_uint64(nvl, ZFS_EV_POOL_GUID, &pool_guid);
> @@ -707,6 +842,8 @@ zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)
>          * 1. ZPOOL_CONFIG_DEVID (identifies the unique disk)
>          * 2. ZPOOL_CONFIG_PHYS_PATH (identifies disk physical location).
>          * 3. ZPOOL_CONFIG_GUID (identifies unique vdev).
> +        * 4. ZPOOL_CONFIG_PATH for /dev/disk/by-vdev devices only (since
> +        *    by-vdev paths represent physical paths).
>          */
>         if (devid_iter(devid, zfs_process_add, is_slice))
>                 return (0);
> @@ -717,6 +854,16 @@ zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)
>                 (void) guid_iter(pool_guid, vdev_guid, devid,
> zfs_process_add,
>                     is_slice);
>
> +       if (devpath != NULL) {
> +               /* Can we match a /dev/disk/by-vdev/ path? */
> +               char by_vdev_path[MAXPATHLEN];
> +               snprintf(by_vdev_path, sizeof (by_vdev_path),
> +                   "/dev/disk/by-vdev/%s", devpath);
> +               if (by_vdev_path_iter(by_vdev_path, devid, zfs_process_add,
> +                   is_slice))
> +                       return (0);
> +       }
> +
>         return (0);
>  }
>
> diff --git a/sys/contrib/openzfs/cmd/zed/zed_disk_event.c
> b/sys/contrib/openzfs/cmd/zed/zed_disk_event.c
> index 94e24236063c..52b80d8c4c93 100644
> --- a/sys/contrib/openzfs/cmd/zed/zed_disk_event.c
> +++ b/sys/contrib/openzfs/cmd/zed/zed_disk_event.c
> @@ -215,6 +215,11 @@ zed_udev_monitor(void *arg)
>                 if (type != NULL && type[0] != '\0' &&
>                     strcmp(type, "disk") == 0 &&
>                     part != NULL && part[0] != '\0') {
> +                       zed_log_msg(LOG_INFO,
> +                           "%s: skip %s since it has a %s partition
> already",
> +                           __func__,
> +                           udev_device_get_property_value(dev, "DEVNAME"),
> +                           part);
>                         /* skip and wait for partition event */
>                         udev_device_unref(dev);
>                         continue;
> @@ -229,6 +234,11 @@ zed_udev_monitor(void *arg)
>                         sectors = udev_device_get_sysattr_value(dev,
> "size");
>                 if (sectors != NULL &&
>                     strtoull(sectors, NULL, 10) < MINIMUM_SECTORS) {
> +                       zed_log_msg(LOG_INFO,
> +                           "%s: %s sectors %s < %llu (minimum)",
> +                           __func__,
> +                           udev_device_get_property_value(dev, "DEVNAME"),
> +                           sectors, MINIMUM_SECTORS);
>                         udev_device_unref(dev);
>                         continue;
>                 }
> diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am
> b/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am
> index 232aaf569fa2..7488e56c7649 100644
> --- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am
> +++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am
> @@ -22,7 +22,6 @@ KERNEL_H = \
>         inttypes.h \
>         isa_defs.h \
>         kmem_cache.h \
> -       kidmap.h \
>         kmem.h \
>         kstat.h \
>         list_impl.h \
> diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h
> b/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h
> index 86f79011d6da..db986af57bf5 100644
> --- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h
> +++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h
> @@ -48,138 +48,20 @@ extern "C" {
>  typedef struct ucred cred_t;
>
>  #define        CRED()          curthread->td_ucred
> -#define        kcred   (thread0.td_ucred)
> -
> -#define        KUID_TO_SUID(x)         (x)
> -#define        KGID_TO_SGID(x)         (x)
> -#define        crgetuid(cred)          ((cred)->cr_uid)
> -#define        crgetruid(cred)         ((cred)->cr_ruid)
> -#define        crgetgid(cred)          ((cred)->cr_gid)
> -#define        crgetgroups(cred)       ((cred)->cr_groups)
> -#define        crgetngroups(cred)      ((cred)->cr_ngroups)
> -#define        crgetsid(cred, i)       (NULL)
>
> -struct proc;                           /* cred.h is included in proc.h */
> -struct prcred;
> -struct ksid;
> -struct ksidlist;
> -struct credklpd;
> -struct credgrp;
> -
> -struct auditinfo_addr;                 /* cred.h is included in audit.h */
> -
> -extern int ngroups_max;
>  /*
>   * kcred is used when you need all privileges.
>   */
> +#define        kcred   (thread0.td_ucred)
>
> -extern void cred_init(void);
> -extern void crfree(cred_t *);
> -extern cred_t *cralloc(void);          /* all but ref uninitialized */
> -extern cred_t *cralloc_ksid(void);     /* cralloc() + ksid alloc'ed */
> -extern cred_t *crget(void);            /* initialized */
> -extern void crcopy_to(cred_t *, cred_t *);
> -extern cred_t *crdup(cred_t *);
> -extern void crdup_to(cred_t *, cred_t *);
> -extern cred_t *crgetcred(void);
> -extern void crset(struct proc *, cred_t *);
> -extern void crset_zone_privall(cred_t *);
> -extern int supgroupmember(gid_t, const cred_t *);
> -extern int hasprocperm(const cred_t *, const cred_t *);
> -extern int prochasprocperm(struct proc *, struct proc *, const cred_t *);
> -extern int crcmp(const cred_t *, const cred_t *);
> -extern cred_t *zone_kcred(void);
> -
> -extern gid_t crgetrgid(const cred_t *);
> -extern gid_t crgetsgid(const cred_t *);
> -
> -#define        crgetzoneid(cr) ((cr)->cr_prison->pr_id)
> -extern projid_t crgetprojid(const cred_t *);
> -
> -extern cred_t *crgetmapped(const cred_t *);
> -
> -
> -extern const struct auditinfo_addr *crgetauinfo(const cred_t *);
> -extern struct auditinfo_addr *crgetauinfo_modifiable(cred_t *);
> -
> -extern uint_t crgetref(const cred_t *);
> -
> -extern const gid_t *crgetggroups(const struct credgrp *);
> -
> -
> -/*
> - * Sets real, effective and/or saved uid/gid;
> - * -1 argument accepted as "no change".
> - */
> -extern int crsetresuid(cred_t *, uid_t, uid_t, uid_t);
> -extern int crsetresgid(cred_t *, gid_t, gid_t, gid_t);
> -
> -/*
> - * Sets real, effective and saved uids/gids all to the same
> - * values.  Both values must be non-negative and <= MAXUID
> - */
> -extern int crsetugid(cred_t *, uid_t, gid_t);
> -
> -/*
> - * Functions to handle the supplemental group list.
> - */
> -extern struct credgrp *crgrpcopyin(int, gid_t *);
> -extern void crgrprele(struct credgrp *);
> -extern void crsetcredgrp(cred_t *, struct credgrp *);
> -
> -/*
> - * Private interface for setting zone association of credential.
> - */
> -struct zone;
> -extern void crsetzone(cred_t *, struct zone *);
> -extern struct zone *crgetzone(const cred_t *);
> -
> -/*
> - * Private interface for setting project id in credential.
> - */
> -extern void crsetprojid(cred_t *, projid_t);
> -
> -/*
> - * Private interface for nfs.
> - */
> -extern cred_t *crnetadjust(cred_t *);
> -
> -/*
> - * Private interface for procfs.
> - */
> -extern void cred2prcred(const cred_t *, struct prcred *);
> -
> -/*
> - * Private interfaces for Rampart Trusted Solaris.
> - */
> -struct ts_label_s;
> -extern struct ts_label_s *crgetlabel(const cred_t *);
> -extern boolean_t crisremote(const cred_t *);
> -
> -/*
> - * Private interfaces for ephemeral uids.
> - */
> -#define        VALID_UID(id, zn)                                       \
> -       ((id) <= MAXUID || valid_ephemeral_uid((zn), (id)))
> -
> -#define        VALID_GID(id, zn)                                       \
> -       ((id) <= MAXUID || valid_ephemeral_gid((zn), (id)))
> -
> -extern boolean_t valid_ephemeral_uid(struct zone *, uid_t);
> -extern boolean_t valid_ephemeral_gid(struct zone *, gid_t);
> -
> -extern int eph_uid_alloc(struct zone *, int, uid_t *, int);
> -extern int eph_gid_alloc(struct zone *, int, gid_t *, int);
> -
> -extern void crsetsid(cred_t *, struct ksid *, int);
> -extern void crsetsidlist(cred_t *, struct ksidlist *);
> -
> -extern struct ksidlist *crgetsidlist(const cred_t *);
> -
> -extern int crsetpriv(cred_t *, ...);
> -
> -extern struct credklpd *crgetcrklpd(const cred_t *);
> -extern void crsetcrklpd(cred_t *, struct credklpd *);
> +#define        KUID_TO_SUID(x)         (x)
> +#define        KGID_TO_SGID(x)         (x)
> +#define        crgetuid(cr)            ((cr)->cr_uid)
> +#define        crgetruid(cr)           ((cr)->cr_ruid)
> +#define        crgetgid(cr)            ((cr)->cr_gid)
> +#define        crgetgroups(cr)         ((cr)->cr_groups)
> +#define        crgetngroups(cr)        ((cr)->cr_ngroups)
> +#define        crgetzoneid(cr)         ((cr)->cr_prison->pr_id)
>
>  #ifdef __cplusplus
>  }
> diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h
> b/sys/contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h
> deleted file mode 100644
> index dc0cf5988a42..000000000000
> --- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h
> +++ /dev/null
> @@ -1,41 +0,0 @@
> -/*
> - * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org>
> - * All rights reserved.
> - *
> - * Redistribution and use in source and binary forms, with or without
> - * modification, are permitted provided that the following conditions
> - * are met:
> - * 1. Redistributions of source code must retain the above copyright
> - *    notice, this list of conditions and the following disclaimer.
> - * 2. Redistributions in binary form must reproduce the above copyright
> - *    notice, this list of conditions and the following disclaimer in the
> - *    documentation and/or other materials provided with the distribution.
> - *
> - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
> - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
> - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
> PURPOSE
> - * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE
> LIABLE
> - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
> CONSEQUENTIAL
> - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
> - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
> - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
> STRICT
> - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
> WAY
> - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
> - * SUCH DAMAGE.
> - *
> - * $FreeBSD$
> - */
> -
> -#ifndef _OPENSOLARIS_SYS_KIDMAP_H_
> -#define        _OPENSOLARIS_SYS_KIDMAP_H_
> -
> -#include <sys/idmap.h>
> -
> -typedef int32_t        idmap_stat;
> -typedef void   idmap_get_handle_t;
> -
> -#define        kidmap_get_create()             (NULL)
> -#define        kidmap_get_destroy(hdl)         do { } while (0)
> -#define        kidmap_get_mappings(hdl)        (NULL)
> -
> -#endif /* _OPENSOLARIS_SYS_KIDMAP_H_ */
> diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h
> b/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h
> index d3fab8b24744..f249d05d55a0 100644
> --- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h
> +++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h
> @@ -29,7 +29,6 @@
>  #ifndef _OPENSOLARIS_SYS_SID_H_
>  #define        _OPENSOLARIS_SYS_SID_H_
>  #include <sys/idmap.h>
> -#include <sys/kidmap.h>
>
>  typedef struct ksiddomain {
>         char    *kd_name;       /* Domain part of SID */
> @@ -59,28 +58,4 @@ ksiddomain_rele(ksiddomain_t *kd)
>         kmem_free(kd, sizeof (*kd));
>  }
>
> -static __inline uint_t
> -ksid_getid(ksid_t *ks)
> -{
> -
> -       panic("%s has been unexpectedly called", __func__);
> -}
> -
> -static __inline const char *
> -ksid_getdomain(ksid_t *ks)
> -{
> -
> -       panic("%s has been unexpectedly called", __func__);
> -}
> -
> -static __inline uint_t
> -ksid_getrid(ksid_t *ks)
> -{
> -
> -       panic("%s has been unexpectedly called", __func__);
> -}
> -
> -#define        kidmap_getsidbyuid(zone, uid, sid_prefix, rid)  (1)
> -#define        kidmap_getsidbygid(zone, gid, sid_prefix, rid)  (1)
> -
>  #endif /* _OPENSOLARIS_SYS_SID_H_ */
> diff --git a/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h
> b/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h
> index 6d4c7a09fe82..0f6a222ba667 100644
> --- a/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h
> +++ b/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h
> @@ -420,9 +420,9 @@ kfpu_end(void)
>         if (static_cpu_has(X86_FEATURE_XSAVE)) {
>                 kfpu_do_xrstor("xrstor", &state->xsave, ~0);
>         } else if (static_cpu_has(X86_FEATURE_FXSR)) {
> -               kfpu_save_fxsr(&state->fxsave);
> +               kfpu_restore_fxsr(&state->fxsave);
>         } else {
> -               kfpu_save_fsave(&state->fsave);
> +               kfpu_restore_fsave(&state->fsave);
>         }
>  out:
>         local_irq_enable();
> diff --git a/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h
> b/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h
> index 9cc85deb5c8a..b7d3f38d70bb 100644
> --- a/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h
> +++ b/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h
> @@ -49,12 +49,7 @@ extern void crhold(cred_t *cr);
>  extern void crfree(cred_t *cr);
>  extern uid_t crgetuid(const cred_t *cr);
>  extern uid_t crgetruid(const cred_t *cr);
> -extern uid_t crgetsuid(const cred_t *cr);
> -extern uid_t crgetfsuid(const cred_t *cr);
>  extern gid_t crgetgid(const cred_t *cr);
> -extern gid_t crgetrgid(const cred_t *cr);
> -extern gid_t crgetsgid(const cred_t *cr);
> -extern gid_t crgetfsgid(const cred_t *cr);
>  extern int crgetngroups(const cred_t *cr);
>  extern gid_t *crgetgroups(const cred_t *cr);
>  extern int groupmember(gid_t gid, const cred_t *cr);
> diff --git a/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c
> b/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c
> index 644dd26859f1..f77becd6a5c1 100644
> --- a/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c
> +++ b/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c
> @@ -606,7 +606,6 @@ get_key_material_https(libzfs_handle_t *hdl, const
> char *uri,
>  kfdok:
>         if ((key = fdopen(kfd, "r+")) == NULL) {
>                 ret = errno;
> -               free(path);
>                 (void) close(kfd);
>                 zfs_error_aux(hdl, dgettext(TEXT_DOMAIN,
>                     "Couldn't reopen temporary file: %s"), strerror(ret));
> diff --git
> a/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c
> b/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c
> index 13f8bd031612..45a6f6f5935b 100644
> --- a/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c
> +++ b/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c
> @@ -527,7 +527,7 @@ zfs_dev_is_dm(const char *dev_name)
>  boolean_t
>  zfs_dev_is_whole_disk(const char *dev_name)
>  {
> -       struct dk_gpt *label;
> +       struct dk_gpt *label = NULL;
>         int fd;
>
>         if ((fd = open(dev_name, O_RDONLY | O_DIRECT | O_CLOEXEC)) < 0)
> @@ -613,22 +613,24 @@ zfs_get_underlying_path(const char *dev_name)
>  /*
>   * A disk is considered a multipath whole disk when:
>   *     DEVNAME key value has "dm-"
> - *     DM_NAME key value has "mpath" prefix
> - *     DM_UUID key exists
> + *     DM_UUID key exists and starts with 'mpath-'
>   *     ID_PART_TABLE_TYPE key does not exist or is not gpt
> + *     ID_FS_LABEL key does not exist (disk isn't labeled)
>   */
>  static boolean_t
> -udev_mpath_whole_disk(struct udev_device *dev)
> +is_mpath_udev_sane(struct udev_device *dev)
>  {
> -       const char *devname, *type, *uuid;
> +       const char *devname, *type, *uuid, *label;
>
>         devname = udev_device_get_property_value(dev, "DEVNAME");
>         type = udev_device_get_property_value(dev, "ID_PART_TABLE_TYPE");
>         uuid = udev_device_get_property_value(dev, "DM_UUID");
> +       label = udev_device_get_property_value(dev, "ID_FS_LABEL");
>
>         if ((devname != NULL && strncmp(devname, "/dev/dm-", 8) == 0) &&
>             ((type == NULL) || (strcmp(type, "gpt") != 0)) &&
> -           (uuid != NULL)) {
> +           ((uuid != NULL) && (strncmp(uuid, "mpath-", 6) == 0)) &&
> +           (label == NULL)) {
>                 return (B_TRUE);
>         }
>
> @@ -636,7 +638,11 @@ udev_mpath_whole_disk(struct udev_device *dev)
>  }
>
>  /*
> - * Check if a disk is effectively a multipath whole disk
> + * Check if a disk is a multipath "blank" disk:
> + *
> + * 1. The disk has udev values that suggest it's a multipath disk
> + * 2. The disk is not currently labeled with a filesystem of any type
> + * 3. There are no partitions on the disk
>   */
>  boolean_t
>  is_mpath_whole_disk(const char *path)
> @@ -645,7 +651,6 @@ is_mpath_whole_disk(const char *path)
>         struct udev_device *dev = NULL;
>         char nodepath[MAXPATHLEN];
>         char *sysname;
> -       boolean_t wholedisk = B_FALSE;
>
>         if (realpath(path, nodepath) == NULL)
>                 return (B_FALSE);
> @@ -660,10 +665,11 @@ is_mpath_whole_disk(const char *path)
>                 return (B_FALSE);
>         }
>
> -       wholedisk = udev_mpath_whole_disk(dev);
> -
> +       /* Sanity check some udev values */
> +       boolean_t is_sane = is_mpath_udev_sane(dev);
>         udev_device_unref(dev);
> -       return (wholedisk);
> +
> +       return (is_sane);
>  }
>
>  #else /* HAVE_LIBUDEV */
> diff --git a/sys/contrib/openzfs/module/Makefile.bsd
> b/sys/contrib/openzfs/module/Makefile.bsd
> index 8aa4ed22275e..dc6cc2b74243 100644
> --- a/sys/contrib/openzfs/module/Makefile.bsd
> +++ b/sys/contrib/openzfs/module/Makefile.bsd
> @@ -32,7 +32,7 @@ CFLAGS+= -include ${INCDIR}/os/freebsd/spl/sys/ccompile.h
>
>  CFLAGS+= -D__KERNEL__ -DFREEBSD_NAMECACHE -DBUILDING_ZFS
> -D__BSD_VISIBLE=1 \
>          -DHAVE_UIO_ZEROCOPY -DWITHOUT_NETDUMP -D__KERNEL
> -D_SYS_CONDVAR_H_ \
> -        -D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DSMP -DHAVE_KSID
> -DCOMPAT_FREEBSD11
> +        -D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DSMP -DCOMPAT_FREEBSD11
>
>  .if ${MACHINE_ARCH} == "amd64"
>  CFLAGS+= -DHAVE_AVX2 -DHAVE_AVX -D__x86_64 -DHAVE_SSE2 -DHAVE_AVX512F
> -DHAVE_SSSE3
> diff --git a/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c
> b/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c
> index d5d50080fafd..16188c71b53d 100644
> --- a/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c
> +++ b/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c
> @@ -250,7 +250,17 @@ sysevent_worker(void *arg __unused)
>                         nvlist_free(event);
>                 }
>         }
> -       zfs_zevent_destroy(ze);
> +
> +       /*
> +        * We avoid zfs_zevent_destroy() here because we're otherwise
> racing
> +        * against fm_fini() destroying the zevent_lock.
> zfs_zevent_destroy()
> +        * will currently only clear `ze->ze_zevent` from an event list
> then
> +        * free `ze`, so just inline the free() here -- events have already
> +        * been drained.
> +        */
> +       VERIFY3P(ze->ze_zevent, ==, NULL);
> +       kmem_free(ze, sizeof (zfs_zevent_t));
> +
>         kthread_exit();
>  }
>
> diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c
> b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c
> index ae758bcefe21..fe0f69132321 100644
> --- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c
> +++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c
> @@ -1653,8 +1653,10 @@ zfs_acl_ids_create(znode_t *dzp, int flag, vattr_t
> *vap, cred_t *cr,
>                     ZFS_GROUP, &acl_ids->z_fuidp);
>                 gid = vap->va_gid;
>         } else {
> -               acl_ids->z_fuid = zfs_fuid_create_cred(zfsvfs, ZFS_OWNER,
> -                   cr, &acl_ids->z_fuidp);
> +               uid_t id = crgetuid(cr);
> +               if (IS_EPHEMERAL(id))
> +                       id = UID_NOBODY;
> +               acl_ids->z_fuid = (uint64_t)id;
>                 acl_ids->z_fgid = 0;
>                 if (vap->va_mask & AT_GID)  {
>                         acl_ids->z_fgid = zfs_fuid_create(zfsvfs,
> diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c
> b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c
> index 7bcf80bf5a94..b2cc3d063f9c 100644
> --- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c
> +++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c
> @@ -1060,8 +1060,7 @@ zfs_create(znode_t *dzp, const char *name, vattr_t
> *vap, int excl, int mode,
>         objset_t        *os;
>         dmu_tx_t        *tx;
>         int             error;
> -       ksid_t          *ksid;
> -       uid_t           uid;
> +       uid_t           uid = crgetuid(cr);
>         gid_t           gid = crgetgid(cr);
>         uint64_t        projid = ZFS_DEFAULT_PROJID;
>         zfs_acl_ids_t   acl_ids;
> @@ -1075,13 +1074,6 @@ zfs_create(znode_t *dzp, const char *name, vattr_t
> *vap, int excl, int mode,
>          * If we have an ephemeral id, ACL, or XVATTR then
>          * make sure file system is at proper version
>          */
> -
> -       ksid = crgetsid(cr, KSID_OWNER);
> -       if (ksid)
> -               uid = ksid_getid(ksid);
> -       else
> -               uid = crgetuid(cr);
> -
>         if (zfsvfs->z_use_fuids == B_FALSE &&
>             (vsecp || (vap->va_mask & AT_XVATTR) ||
>             IS_EPHEMERAL(uid) || IS_EPHEMERAL(gid)))
> @@ -1415,8 +1407,7 @@ zfs_mkdir(znode_t *dzp, const char *dirname, vattr_t
> *vap, znode_t **zpp,
>         uint64_t        txtype;
>         dmu_tx_t        *tx;
>         int             error;
> -       ksid_t          *ksid;
> -       uid_t           uid;
> +       uid_t           uid = crgetuid(cr);
>         gid_t           gid = crgetgid(cr);
>         zfs_acl_ids_t   acl_ids;
>         boolean_t       fuid_dirtied;
> @@ -1427,12 +1418,6 @@ zfs_mkdir(znode_t *dzp, const char *dirname,
> vattr_t *vap, znode_t **zpp,
>          * If we have an ephemeral id, ACL, or XVATTR then
>          * make sure file system is at proper version
>          */
> -
> -       ksid = crgetsid(cr, KSID_OWNER);
> -       if (ksid)
> -               uid = ksid_getid(ksid);
> -       else
> -               uid = crgetuid(cr);
>         if (zfsvfs->z_use_fuids == B_FALSE &&
>             ((vap->va_mask & AT_XVATTR) ||
>             IS_EPHEMERAL(uid) || IS_EPHEMERAL(gid)))
> diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c
> b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c
> index d14df9d88a35..8a2773ac7971 100644
> --- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c
> +++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c
> @@ -839,7 +839,9 @@ zfs_xvattr_set(znode_t *zp, xvattr_t *xvap, dmu_tx_t
> *tx)
>         xoap = xva_getxoptattr(xvap);
>         ASSERT3P(xoap, !=, NULL);
>
> -       ASSERT_VOP_IN_SEQC(ZTOV(zp));
> +       if (zp->z_zfsvfs->z_replay == B_FALSE) {
> +               ASSERT_VOP_IN_SEQC(ZTOV(zp));
> +       }
>
>         if (XVA_ISSET_REQ(xvap, XAT_CREATETIME)) {
>                 uint64_t times[2];
> diff --git a/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c
> b/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c
> index 8fe1cc30ba99..f81b9540a639 100644
> --- a/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c
> +++ b/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c
> @@ -128,7 +128,7 @@ groupmember(gid_t gid, const cred_t *cr)
>  uid_t
>  crgetuid(const cred_t *cr)
>  {
> -       return (KUID_TO_SUID(cr->euid));
> +       return (KUID_TO_SUID(cr->fsuid));
>  }
>
>  /* Return the real user id */
> @@ -138,44 +138,9 @@ crgetruid(const cred_t *cr)
>         return (KUID_TO_SUID(cr->uid));
>  }
>
> -/* Return the saved user id */
> -uid_t
> -crgetsuid(const cred_t *cr)
> -{
> -       return (KUID_TO_SUID(cr->suid));
> -}
> -
> -/* Return the filesystem user id */
> -uid_t
> -crgetfsuid(const cred_t *cr)
> -{
> -       return (KUID_TO_SUID(cr->fsuid));
> -}
> -
>  /* Return the effective group id */
>  gid_t
>  crgetgid(const cred_t *cr)
> -{
> -       return (KGID_TO_SGID(cr->egid));
> -}
> -
> -/* Return the real group id */
> -gid_t
> -crgetrgid(const cred_t *cr)
> -{
> -       return (KGID_TO_SGID(cr->gid));
> -}
> -
> -/* Return the saved group id */
> -gid_t
> -crgetsgid(const cred_t *cr)
> -{
> -       return (KGID_TO_SGID(cr->sgid));
> -}
> -
> -/* Return the filesystem group id */
> -gid_t
> -crgetfsgid(const cred_t *cr)
>  {
>         return (KGID_TO_SGID(cr->fsgid));
>  }
> @@ -184,12 +149,7 @@ EXPORT_SYMBOL(crhold);
>  EXPORT_SYMBOL(crfree);
>  EXPORT_SYMBOL(crgetuid);
>  EXPORT_SYMBOL(crgetruid);
> -EXPORT_SYMBOL(crgetsuid);
> -EXPORT_SYMBOL(crgetfsuid);
>  EXPORT_SYMBOL(crgetgid);
> -EXPORT_SYMBOL(crgetrgid);
> -EXPORT_SYMBOL(crgetsgid);
> -EXPORT_SYMBOL(crgetfsgid);
>  EXPORT_SYMBOL(crgetngroups);
>  EXPORT_SYMBOL(crgetgroups);
>  EXPORT_SYMBOL(groupmember);
> diff --git a/sys/contrib/openzfs/module/os/linux/zfs/policy.c
> b/sys/contrib/openzfs/module/os/linux/zfs/policy.c
> index bbccb2e572d9..5a52092bb90a 100644
> --- a/sys/contrib/openzfs/module/os/linux/zfs/policy.c
> +++ b/sys/contrib/openzfs/module/os/linux/zfs/policy.c
> @@ -121,7 +121,7 @@ secpolicy_vnode_access2(const cred_t *cr, struct inode
> *ip, uid_t owner,
>  int
>  secpolicy_vnode_any_access(const cred_t *cr, struct inode *ip, uid_t
> owner)
>  {
> -       if (crgetfsuid(cr) == owner)
> +       if (crgetuid(cr) == owner)
>                 return (0);
>
>         if (zpl_inode_owner_or_capable(kcred->user_ns, ip))
> @@ -147,7 +147,7 @@ secpolicy_vnode_any_access(const cred_t *cr, struct
> inode *ip, uid_t owner)
>  int
>  secpolicy_vnode_chown(const cred_t *cr, uid_t owner)
> *** 141 LINES SKIPPED ***
>

--0000000000009d978a05db5d4121
Content-Type: text/html; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable

<div dir=3D"ltr"><div>Martin,</div><div><br></div><div>Is there any reason =
not to cherry-pick this commit in: <a href=3D"https://github.com/openzfs/zf=
s/commit/4a1195ca5041cbff2a6b025a31937fef84876c52">https://github.com/openz=
fs/zfs/commit/4a1195ca5041cbff2a6b025a31937fef84876c52</a>?</div><div><br><=
/div><div>I bring it up because a few users have expressed interest in it. =
<a href=3D"https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=3D260160">http=
s://bugs.freebsd.org/bugzilla/show_bug.cgi?id=3D260160</a></div><div><br></=
div></div><br><div class=3D"gmail_quote"><div dir=3D"ltr" class=3D"gmail_at=
tr">On Tue, Mar 29, 2022 at 5:53 AM Martin Matuska &lt;<a href=3D"mailto:mm=
@freebsd.org">mm@freebsd.org</a>&gt; wrote:<br></div><blockquote class=3D"g=
mail_quote" style=3D"margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204=
,204,204);padding-left:1ex">The branch releng/13.1 has been updated by mm:<=
br>
<br>
URL: <a href=3D"https://cgit.FreeBSD.org/src/commit/?id=3D99c3f15774595c116=
3ecec87aa8cb157ccdc7d96" rel=3D"noreferrer" target=3D"_blank">https://cgit.=
FreeBSD.org/src/commit/?id=3D99c3f15774595c1163ecec87aa8cb157ccdc7d96</a><b=
r>
<br>
commit 99c3f15774595c1163ecec87aa8cb157ccdc7d96<br>
Author:=C2=A0 =C2=A0 =C2=A0Martin Matuska &lt;mm@FreeBSD.org&gt;<br>
AuthorDate: 2022-03-29 10:41:53 +0000<br>
Commit:=C2=A0 =C2=A0 =C2=A0Martin Matuska &lt;mm@FreeBSD.org&gt;<br>
CommitDate: 2022-03-29 13:50:47 +0000<br>
<br>
=C2=A0 =C2=A0 zfs: merge openzfs/zfs@52bad4f23 (zfs-2.1-release) into stabl=
e/13<br>
<br>
=C2=A0 =C2=A0 OpenZFS release 2.1.4<br>
<br>
=C2=A0 =C2=A0 Notable upstream pull request merges:<br>
=C2=A0 =C2=A0 =C2=A0 #13219 FreeBSD: add missing replay check to an assert =
in zfs_xvattr_set<br>
=C2=A0 =C2=A0 =C2=A0 #13220 module: freebsd: avoid a taking a destroyed loc=
k in zfs_zevent bits<br>
=C2=A0 =C2=A0 =C2=A0 #13221 Fix ACL checks for NFS kernel server<br>
<br>
=C2=A0 =C2=A0 Obtained from:=C2=A0 OpenZFS<br>
=C2=A0 =C2=A0 OpenZFS tag:=C2=A0 =C2=A0 zfs-2.1.4<br>
=C2=A0 =C2=A0 OpenZFS commit: 52bad4f23daaa5f827f802c8d05785a27b80275d<br>
=C2=A0 =C2=A0 Relnotes:=C2=A0 =C2=A0 =C2=A0 =C2=A0yes<br>
=C2=A0 =C2=A0 Approved by:=C2=A0 =C2=A0 re (gjb)<br>
<br>
=C2=A0 =C2=A0 (cherry picked from commit c088e4d539e4cc947896a3b156646b831d=
932539)<br>
---<br>
=C2=A0sys/conf/<a href=3D"http://kern.pre.mk" rel=3D"noreferrer" target=3D"=
_blank">kern.pre.mk</a>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A02 =
+-<br>
=C2=A0sys/contrib/openzfs/META=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A04 +-<br>
=C2=A0sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c=C2=A0 =C2=A0 =C2=A0 =C2=
=A0| 179 +++++++++++++++++++--<br>
=C2=A0sys/contrib/openzfs/cmd/zed/zed_disk_event.c=C2=A0 =C2=A0 =C2=A0 =C2=
=A0|=C2=A0 10 ++<br>
=C2=A0.../openzfs/include/os/freebsd/spl/sys/Makefile.am |=C2=A0 =C2=A01 -<=
br>
=C2=A0.../openzfs/include/os/freebsd/spl/sys/cred.h=C2=A0 =C2=A0 =C2=A0 | 1=
36 ++--------------<br>
=C2=A0.../openzfs/include/os/freebsd/spl/sys/kidmap.h=C2=A0 =C2=A0 |=C2=A0 =
41 -----<br>
=C2=A0.../openzfs/include/os/freebsd/spl/sys/sid.h=C2=A0 =C2=A0 =C2=A0 =C2=
=A0|=C2=A0 25 ---<br>
=C2=A0.../include/os/linux/kernel/linux/simd_x86.h=C2=A0 =C2=A0 =C2=A0 =C2=
=A0|=C2=A0 =C2=A04 +-<br>
=C2=A0.../openzfs/include/os/linux/spl/sys/cred.h=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 |=C2=A0 =C2=A05 -<br>
=C2=A0sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c=C2=A0 =C2=A0 =C2=A0|=
=C2=A0 =C2=A01 -<br>
=C2=A0.../lib/libzutil/os/linux/zutil_device_path_os.c=C2=A0 =C2=A0|=C2=A0 =
28 ++--<br>
=C2=A0sys/contrib/openzfs/module/Makefile.bsd=C2=A0 =C2=A0 =C2=A0 =C2=A0 =
=C2=A0 =C2=A0 |=C2=A0 =C2=A02 +-<br>
=C2=A0.../openzfs/module/os/freebsd/spl/spl_sysevent.c=C2=A0 =C2=A0|=C2=A0 =
12 +-<br>
=C2=A0.../openzfs/module/os/freebsd/zfs/zfs_acl.c=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 |=C2=A0 =C2=A06 +-<br>
=C2=A0.../openzfs/module/os/freebsd/zfs/zfs_vnops_os.c=C2=A0 =C2=A0|=C2=A0 =
19 +--<br>
=C2=A0.../openzfs/module/os/freebsd/zfs/zfs_znode.c=C2=A0 =C2=A0 =C2=A0 |=
=C2=A0 =C2=A04 +-<br>
=C2=A0sys/contrib/openzfs/module/os/linux/spl/spl-cred.c |=C2=A0 42 +----<b=
r>
=C2=A0sys/contrib/openzfs/module/os/linux/zfs/policy.c=C2=A0 =C2=A0|=C2=A0 =
10 +-<br>
=C2=A0.../openzfs/module/os/linux/zfs/zpl_inode.c=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 |=C2=A0 =C2=A04 +-<br>
=C2=A0.../openzfs/module/os/linux/zfs/zpl_xattr.c=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 |=C2=A0 =C2=A04 +-<br>
=C2=A0sys/contrib/openzfs/module/zfs/arc.c=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A02 +-<br>
=C2=A0sys/modules/zfs/Makefile=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A02 +-<br>
=C2=A0sys/modules/zfs/zfs_config.h=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A08 +-<br>
=C2=A0sys/modules/zfs/zfs_gitrev.h=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0|=C2=A0 =C2=A03 +-<br>
=C2=A025 files changed, 242 insertions(+), 312 deletions(-)<br>
<br>
diff --git a/sys/conf/<a href=3D"http://kern.pre.mk" rel=3D"noreferrer" tar=
get=3D"_blank">kern.pre.mk</a> b/sys/conf/<a href=3D"http://kern.pre.mk" re=
l=3D"noreferrer" target=3D"_blank">kern.pre.mk</a><br>
index d6ab5e17a82a..6be49642b04e 100644<br>
--- a/sys/conf/<a href=3D"http://kern.pre.mk" rel=3D"noreferrer" target=3D"=
_blank">kern.pre.mk</a><br>
+++ b/sys/conf/<a href=3D"http://kern.pre.mk" rel=3D"noreferrer" target=3D"=
_blank">kern.pre.mk</a><br>
@@ -262,7 +262,7 @@ CDDL_C=3D=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0${CC} -c ${CDDL_CFLAGS} ${WERROR} ${PROF} ${.IMPSRC}<br>
=C2=A0# Special flags for managing the compat compiles for ZFS<br>
=C2=A0ZFS_CFLAGS+=3D=C2=A0 =C2=A0${CDDL_CFLAGS} -DBUILDING_ZFS -DHAVE_UIO_Z=
EROCOPY \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 -DWITH_NETDUMP -D__KERNEL__ -D_SYS_CONDVAR_H_ -=
DSMP \<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0-DIN_FREEBSD_BASE -DHAVE_KSID<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0-DIN_FREEBSD_BASE<br>
<br>
=C2=A0.if ${MACHINE_ARCH} =3D=3D &quot;amd64&quot;<br>
=C2=A0ZFS_CFLAGS+=3D -DHAVE_AVX2 -DHAVE_AVX -D__x86_64 -DHAVE_SSE2 -DHAVE_A=
VX512F \<br>
diff --git a/sys/contrib/openzfs/META b/sys/contrib/openzfs/META<br>
index 0437224b403f..76e59a42074c 100644<br>
--- a/sys/contrib/openzfs/META<br>
+++ b/sys/contrib/openzfs/META<br>
@@ -1,10 +1,10 @@<br>
=C2=A0Meta:=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 1<br>
=C2=A0Name:=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 zfs<br>
=C2=A0Branch:=C2=A0 =C2=A0 =C2=A0 =C2=A0 1.0<br>
-Version:=C2=A0 =C2=A0 =C2=A0 =C2=A02.1.3<br>
+Version:=C2=A0 =C2=A0 =C2=A0 =C2=A02.1.4<br>
=C2=A0Release:=C2=A0 =C2=A0 =C2=A0 =C2=A01<br>
=C2=A0Release-Tags:=C2=A0 relext<br>
=C2=A0License:=C2=A0 =C2=A0 =C2=A0 =C2=A0CDDL<br>
=C2=A0Author:=C2=A0 =C2=A0 =C2=A0 =C2=A0 OpenZFS<br>
-Linux-Maximum: 5.16<br>
+Linux-Maximum: 5.17<br>
=C2=A0Linux-Minimum: 3.10<br>
diff --git a/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c b/sys/contrib/ope=
nzfs/cmd/zed/agents/zfs_mod.c<br>
index 3bcdf6e1d718..a510d646e1f9 100644<br>
--- a/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c<br>
+++ b/sys/contrib/openzfs/cmd/zed/agents/zfs_mod.c<br>
@@ -183,14 +183,14 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, =
boolean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 nvlist_t *nvroot, *newvd;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 pendingdev_t *device;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t wholedisk =3D 0ULL;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0uint64_t offline =3D 0ULL;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0uint64_t offline =3D 0ULL, faulted =3D 0ULL;<br=
>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t guid =3D 0ULL;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char *physpath =3D NULL, *new_devid =3D NULL, *=
enc_sysfs_path =3D NULL;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char rawpath[PATH_MAX], fullpath[PATH_MAX];<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char devpath[PATH_MAX];<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 int ret;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0boolean_t is_dm =3D B_FALSE;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 boolean_t is_sd =3D B_FALSE;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0boolean_t is_mpath_wholedisk =3D B_FALSE;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint_t c;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 vdev_stat_t *vs;<br>
<br>
@@ -211,15 +211,73 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, =
boolean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 &amp;enc_sysfs_path);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_=
WHOLE_DISK, &amp;wholedisk);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_=
OFFLINE, &amp;offline);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0(void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_=
FAULTED, &amp;faulted);<br>
+<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_=
GUID, &amp;guid);<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (offline)<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0return;=C2=A0 /* do=
n&#39;t intervene if it was taken offline */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0/*<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * Special case:<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * We&#39;ve seen times where a disk won&#39;t =
have a ZPOOL_CONFIG_PHYS_PATH<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * entry in their config. For example, on this =
force-faulted disk:<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 children[0]:<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0type: &#39;=
disk&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0id: 0<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0guid: 14309=
659774640089719<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 path: &#39;/dev/d=
isk/by-vdev/L28&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 whole_disk: 0<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 DTL: 654<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 create_txg: 4<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 com.delphix:vdev_=
zap_leaf: 1161<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 faulted: 1<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 aux_state: &#39;e=
xternal&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 children[1]:<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 type: &#39;disk&#=
39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 id: 1<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 guid: 16002508084=
177980912<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 path: &#39;/dev/d=
isk/by-vdev/L29&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 devid: &#39;dm-uu=
id-mpath-35000c500a61d68a3&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 phys_path: &#39;L=
29&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 vdev_enc_sysfs_pa=
th: &#39;/sys/class/enclosure/0:0:1:0/SLOT 30 32&#39;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 whole_disk: 0<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 DTL: 1028<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 create_txg: 4<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 =C2=A0 =C2=A0 com.delphix:vdev_=
zap_leaf: 131<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * If the disk&#39;s path is a /dev/disk/by-vde=
v/ path, then we can infer<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * the ZPOOL_CONFIG_PHYS_PATH from the by-vdev =
disk name.<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (physpath =3D=3D NULL &amp;&amp; path !=3D N=
ULL) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0/* If path begins w=
ith &quot;/dev/disk/by-vdev/&quot; ... */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0if (strncmp(path, D=
EV_BYVDEV_PATH,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0strle=
n(DEV_BYVDEV_PATH)) =3D=3D 0) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0/* Set physpath to the char after &quot;/dev/disk/by-vdev&quot; *=
/<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0physpath =3D &amp;path[strlen(DEV_BYVDEV_PATH)];<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0/*<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * We don&#39;t want to autoreplace offlined di=
sks.=C2=A0 However, we do want to<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * replace force-faulted disks (`zpool offline =
-f`).=C2=A0 Force-faulted<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * disks have both offline=3D1 and faulted=3D1 =
in the nvlist.<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (offline &amp;&amp; !faulted) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O, &quot;%s: %s is offline, skip autoreplace&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0__fun=
c__, path);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0return;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0is_dm =3D zfs_dev_is_dm(path);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0is_mpath_wholedisk =3D is_mpath_whole_disk(path=
);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 zed_log_msg(LOG_INFO, &quot;zfs_process_add: po=
ol &#39;%s&#39; vdev &#39;%s&#39;, phys &#39;%s&#39;&quot;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot; wholedisk %d, %s dm (guid =
%llu)&quot;, zpool_get_name(zhp), path,<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0physpath ? physpath : &quot;NULL&=
quot;, wholedisk, is_dm ? &quot;is&quot; : &quot;not&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot; %s blank disk, %s mpath bl=
ank disk, %s labeled, enc sysfs &#39;%s&#39;, &quot;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot;(guid %llu)&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zpool_get_name(zhp), path,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0physpath ? physpath : &quot;NULL&=
quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0wholedisk ? &quot;is&quot; : &quo=
t;not&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0is_mpath_wholedisk? &quot;is&quot=
; : &quot;not&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0labeled ? &quot;is&quot; : &quot;=
not&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0enc_sysfs_path,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (long long unsigned int)guid);<br=
>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 /*<br>
@@ -253,8 +311,9 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, bo=
olean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 ZFS_ONLINE_CHECKREMOVE | ZFS_ONLI=
NE_UNSPARE, &amp;newstate) =3D=3D 0 &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (newstate =3D=3D VDEV_STATE_HEALT=
HY ||<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 newstate =3D=3D VDEV_STATE_DEGRAD=
ED)) {<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O, &quot;=C2=A0 zpool_vdev_online: vdev %s is %s&quot;,<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0fullp=
ath, (newstate =3D=3D VDEV_STATE_HEALTHY) ?<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;=C2=A0 zpool_vdev_online: vdev &#39;%s&#39; (&#39;%s&#39;) is &quot;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;%s&quot;, fullpath, physpath, (newstate =3D=3D VDEV_STATE_HEALTHY) ?<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 &quot=
;HEALTHY&quot; : &quot;DEGRADED&quot;);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
@@ -271,11 +330,12 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, =
boolean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* vdev online to trigger a FMA fault by p=
osting an ereport.<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (!zpool_get_prop_int(zhp, ZPOOL_PROP_AUTOREP=
LACE, NULL) ||<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0!(wholedisk || is_dm) || (physpat=
h =3D=3D NULL)) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0!(wholedisk || is_mpath_wholedisk=
) || (physpath =3D=3D NULL)) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) zpool_vdev_o=
nline(zhp, fullpath, ZFS_ONLINE_FORCEFAULT,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 &amp;=
newstate);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 zed_log_msg(LOG_INF=
O, &quot;Pool&#39;s autoreplace is not enabled or &quot;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;not a whole disk for &#39;%s&#39;&quot;, fullpath);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;not a blank disk for &#39;%s&#39; (&#39;%s&#39;)&quot;, fullpath,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0physp=
ath);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
<br>
@@ -287,7 +347,7 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, bo=
olean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) snprintf(rawpath, sizeof (rawpath), &quo=
t;%s%s&quot;,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 is_sd ? DEV_BYVDEV_PATH : DEV_BYP=
ATH_PATH, physpath);<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (realpath(rawpath, devpath) =3D=3D NULL &amp=
;&amp; !is_dm) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (realpath(rawpath, devpath) =3D=3D NULL &amp=
;&amp; !is_mpath_wholedisk) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 zed_log_msg(LOG_INF=
O, &quot;=C2=A0 realpath: %s failed (%s)&quot;,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 rawpa=
th, strerror(errno));<br>
<br>
@@ -303,12 +363,14 @@ zfs_process_add(zpool_handle_t *zhp, nvlist_t *vdev, =
boolean_t labeled)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if ((vs-&gt;vs_state !=3D VDEV_STATE_DEGRADED) =
&amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (vs-&gt;vs_state !=3D VDEV_STATE_=
FAULTED) &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (vs-&gt;vs_state !=3D VDEV_STATE_=
CANT_OPEN)) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O, &quot;=C2=A0 not autoreplacing since disk isn&#39;t in &quot;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;a bad state (currently %d)&quot;, vs-&gt;vs_state);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 nvlist_lookup_string(vdev, &quot;new_devid&quot=
;, &amp;new_devid);<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (is_dm) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (is_mpath_wholedisk) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 /* Don&#39;t label =
device mapper or multipath disks. */<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 } else if (!labeled) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 /*<br>
@@ -522,8 +584,11 @@ zfs_iter_vdev(zpool_handle_t *zhp, nvlist_t *nvl, void=
 *data)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* the dp-&gt;=
dd_compare value.<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 if (nvlist_lookup_s=
tring(nvl, dp-&gt;dd_prop, &amp;path) !=3D 0 ||<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0strcm=
p(dp-&gt;dd_compare, path) !=3D 0)<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0strcm=
p(dp-&gt;dd_compare, path) !=3D 0) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0zed_log_msg(LOG_INFO, &quot;=C2=A0 %s: no match (%s !=3D vdev %s)=
&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0__func__, dp-&gt;dd_compare, path);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 return;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 zed_log_msg(LOG_INF=
O, &quot;=C2=A0 zfs_iter_vdev: matched %s on %s&quot;,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 dp-&g=
t;dd_prop, path);<br>
@@ -571,6 +636,8 @@ zfs_iter_pool(zpool_handle_t *zhp, void *data)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 ZPOOL_CONFIG_VDEV_TREE, &amp;nvl);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 zfs_iter_vdev(zhp, nvl, data);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0} else {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O, &quot;%s: no config\n&quot;, __func__);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 /*<br>
@@ -619,6 +686,72 @@ devphys_iter(const char *physical, const char *devid, =
zfs_process_func_t func,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 return (data.dd_found);<br>
=C2=A0}<br>
<br>
+/*<br>
+ * Given a device identifier, find any vdevs with a matching by-vdev<br>
+ * path.=C2=A0 Normally we shouldn&#39;t need this as the comparison would=
 be<br>
+ * made earlier in the devphys_iter().=C2=A0 For example, if we were repla=
cing<br>
+ * /dev/disk/by-vdev/L28, normally devphys_iter() would match the<br>
+ * ZPOOL_CONFIG_PHYS_PATH of &quot;L28&quot; from the old disk config to &=
quot;L28&quot;<br>
+ * of the new disk config.=C2=A0 However, we&#39;ve seen cases where<br>
+ * ZPOOL_CONFIG_PHYS_PATH was not in the config for the old disk.=C2=A0 He=
re&#39;s<br>
+ * an example of a real 2-disk mirror pool where one disk was force<br>
+ * faulted:<br>
+ *<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0com.delphix:vdev_zap_top: 129<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0children[0]:<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0type: &#39;disk&#=
39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0id: 0<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0guid: 14309659774=
640089719<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0path: &#39;/dev/d=
isk/by-vdev/L28&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0whole_disk: 0<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0DTL: 654<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0create_txg: 4<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0com.delphix:vdev_=
zap_leaf: 1161<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0faulted: 1<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0aux_state: &#39;e=
xternal&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0children[1]:<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0type: &#39;disk&#=
39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0id: 1<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0guid: 16002508084=
177980912<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0path: &#39;/dev/d=
isk/by-vdev/L29&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0devid: &#39;dm-uu=
id-mpath-35000c500a61d68a3&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0phys_path: &#39;L=
29&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0vdev_enc_sysfs_pa=
th: &#39;/sys/class/enclosure/0:0:1:0/SLOT 30 32&#39;<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0whole_disk: 0<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0DTL: 1028<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0create_txg: 4<br>
+ *=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0com.delphix:vdev_=
zap_leaf: 131<br>
+ *<br>
+ * So in the case above, the only thing we could compare is the path.<br>
+ *<br>
+ * We can do this because we assume by-vdev paths are authoritative as phy=
sical<br>
+ * paths.=C2=A0 We could not assume this for normal paths like /dev/sda si=
nce the<br>
+ * physical location /dev/sda points to could change over time.<br>
+ */<br>
+static boolean_t<br>
+by_vdev_path_iter(const char *by_vdev_path, const char *devid,<br>
+=C2=A0 =C2=A0 zfs_process_func_t func, boolean_t is_slice)<br>
+{<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0dev_data_t data =3D { 0 };<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_compare =3D by_vdev_path;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_func =3D func;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_prop =3D ZPOOL_CONFIG_PATH;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_found =3D B_FALSE;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_islabeled =3D is_slice;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0data.dd_new_devid =3D devid;<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (strncmp(by_vdev_path, DEV_BYVDEV_PATH,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0strlen(DEV_BYVDEV_PATH)) !=3D 0) =
{<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0/* by_vdev_path doe=
sn&#39;t start with &quot;/dev/disk/by-vdev/&quot; */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0return (B_FALSE);<b=
r>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0(void) zpool_iter(g_zfshdl, zfs_iter_pool, &amp=
;data);<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0return (data.dd_found);<br>
+}<br>
+<br>
=C2=A0/*<br>
=C2=A0 * Given a device identifier, find any vdevs with a matching devid.<b=
r>
=C2=A0 * On Linux we can match devid directly which is always a whole disk.=
<br>
@@ -683,15 +816,17 @@ guid_iter(uint64_t pool_guid, uint64_t vdev_guid, con=
st char *devid,<br>
=C2=A0static int<br>
=C2=A0zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)<br>
=C2=A0{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0char *devpath =3D NULL, *devid;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0char *devpath =3D NULL, *devid =3D NULL;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t pool_guid =3D 0, vdev_guid =3D 0;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 boolean_t is_slice;<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 /*<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* Expecting a devid string and an optiona=
l physical location and guid<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (nvlist_lookup_string(nvl, DEV_IDENTIFIER, &=
amp;devid) !=3D 0)<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (nvlist_lookup_string(nvl, DEV_IDENTIFIER, &=
amp;devid) !=3D 0) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0zed_log_msg(LOG_INF=
O, &quot;%s: no dev identifier\n&quot;, __func__);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (-1);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) nvlist_lookup_string(nvl, DEV_PHYS_PATH,=
 &amp;devpath);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) nvlist_lookup_uint64(nvl, ZFS_EV_POOL_GU=
ID, &amp;pool_guid);<br>
@@ -707,6 +842,8 @@ zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* 1. ZPOOL_CONFIG_DEVID (identifies the u=
nique disk)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* 2. ZPOOL_CONFIG_PHYS_PATH (identifies d=
isk physical location).<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* 3. ZPOOL_CONFIG_GUID (identifies unique=
 vdev).<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * 4. ZPOOL_CONFIG_PATH for /dev/disk/by-vdev d=
evices only (since<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 *=C2=A0 =C2=A0 by-vdev paths represent physica=
l paths).<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (devid_iter(devid, zfs_process_add, is_slice=
))<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (0);<br>
@@ -717,6 +854,16 @@ zfs_deliver_add(nvlist_t *nvl, boolean_t is_lofi)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) guid_iter(po=
ol_guid, vdev_guid, devid, zfs_process_add,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 is_sl=
ice);<br>
<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (devpath !=3D NULL) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0/* Can we match a /=
dev/disk/by-vdev/ path? */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0char by_vdev_path[M=
AXPATHLEN];<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0snprintf(by_vdev_pa=
th, sizeof (by_vdev_path),<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0&quot=
;/dev/disk/by-vdev/%s&quot;, devpath);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0if (by_vdev_path_it=
er(by_vdev_path, devid, zfs_process_add,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0is_sl=
ice))<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0return (0);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
+<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 return (0);<br>
=C2=A0}<br>
<br>
diff --git a/sys/contrib/openzfs/cmd/zed/zed_disk_event.c b/sys/contrib/ope=
nzfs/cmd/zed/zed_disk_event.c<br>
index 94e24236063c..52b80d8c4c93 100644<br>
--- a/sys/contrib/openzfs/cmd/zed/zed_disk_event.c<br>
+++ b/sys/contrib/openzfs/cmd/zed/zed_disk_event.c<br>
@@ -215,6 +215,11 @@ zed_udev_monitor(void *arg)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 if (type !=3D NULL =
&amp;&amp; type[0] !=3D &#39;\0&#39; &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 strcm=
p(type, &quot;disk&quot;) =3D=3D 0 &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 part =
!=3D NULL &amp;&amp; part[0] !=3D &#39;\0&#39;) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0zed_log_msg(LOG_INFO,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0&quot;%s: skip %s since it has a %s partition alrea=
dy&quot;,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0__func__,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0udev_device_get_property_value(dev, &quot;DEVNAME&q=
uot;),<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0part);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 /* skip and wait for partition event */<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 udev_device_unref(dev);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 continue;<br>
@@ -229,6 +234,11 @@ zed_udev_monitor(void *arg)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 sectors =3D udev_device_get_sysattr_value(dev, &quot;size&quot;)=
;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 if (sectors !=3D NU=
LL &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 strto=
ull(sectors, NULL, 10) &lt; MINIMUM_SECTORS) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0zed_log_msg(LOG_INFO,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0&quot;%s: %s sectors %s &lt; %llu (minimum)&quot;,<=
br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0__func__,<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0udev_device_get_property_value(dev, &quot;DEVNAME&q=
uot;),<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0sectors, MINIMUM_SECTORS);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 udev_device_unref(dev);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 continue;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am b/s=
ys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am<br>
index 232aaf569fa2..7488e56c7649 100644<br>
--- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am<br>
+++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/Makefile.am<br>
@@ -22,7 +22,6 @@ KERNEL_H =3D \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 inttypes.h \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 isa_defs.h \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 kmem_cache.h \<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0kidmap.h \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 kmem.h \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 kstat.h \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 list_impl.h \<br>
diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h b/sys/co=
ntrib/openzfs/include/os/freebsd/spl/sys/cred.h<br>
index 86f79011d6da..db986af57bf5 100644<br>
--- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h<br>
+++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/cred.h<br>
@@ -48,138 +48,20 @@ extern &quot;C&quot; {<br>
=C2=A0typedef struct ucred cred_t;<br>
<br>
=C2=A0#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 CRED()=C2=A0 =C2=A0 =C2=A0 =C2=A0 =
=C2=A0 curthread-&gt;td_ucred<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kcred=C2=A0 =C2=A0(thread0.td_ucred)<br=
>
-<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 KUID_TO_SUID(x)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0(x)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 KGID_TO_SGID(x)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0(x)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetuid(cred)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 ((cred)-&gt;cr_uid)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetruid(cred)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0((cred)-&gt;cr_ruid)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetgid(cred)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 ((cred)-&gt;cr_gid)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetgroups(cred)=C2=A0 =C2=A0 =C2=A0 =
=C2=A0((cred)-&gt;cr_groups)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetngroups(cred)=C2=A0 =C2=A0 =C2=A0 =
((cred)-&gt;cr_ngroups)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetsid(cred, i)=C2=A0 =C2=A0 =C2=A0 =
=C2=A0(NULL)<br>
<br>
-struct proc;=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0/* cred.h is included in proc.h */<br>
-struct prcred;<br>
-struct ksid;<br>
-struct ksidlist;<br>
-struct credklpd;<br>
-struct credgrp;<br>
-<br>
-struct auditinfo_addr;=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0/* cred.h is included in audit.h */<br>
-<br>
-extern int ngroups_max;<br>
=C2=A0/*<br>
=C2=A0 * kcred is used when you need all privileges.<br>
=C2=A0 */<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kcred=C2=A0 =C2=A0(thread0.td_ucred)<br=
>
<br>
-extern void cred_init(void);<br>
-extern void crfree(cred_t *);<br>
-extern cred_t *cralloc(void);=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 /* all but=
 ref uninitialized */<br>
-extern cred_t *cralloc_ksid(void);=C2=A0 =C2=A0 =C2=A0/* cralloc() + ksid =
alloc&#39;ed */<br>
-extern cred_t *crget(void);=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 /* in=
itialized */<br>
-extern void crcopy_to(cred_t *, cred_t *);<br>
-extern cred_t *crdup(cred_t *);<br>
-extern void crdup_to(cred_t *, cred_t *);<br>
-extern cred_t *crgetcred(void);<br>
-extern void crset(struct proc *, cred_t *);<br>
-extern void crset_zone_privall(cred_t *);<br>
-extern int supgroupmember(gid_t, const cred_t *);<br>
-extern int hasprocperm(const cred_t *, const cred_t *);<br>
-extern int prochasprocperm(struct proc *, struct proc *, const cred_t *);<=
br>
-extern int crcmp(const cred_t *, const cred_t *);<br>
-extern cred_t *zone_kcred(void);<br>
-<br>
-extern gid_t crgetrgid(const cred_t *);<br>
-extern gid_t crgetsgid(const cred_t *);<br>
-<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetzoneid(cr) ((cr)-&gt;cr_prison-&gt=
;pr_id)<br>
-extern projid_t crgetprojid(const cred_t *);<br>
-<br>
-extern cred_t *crgetmapped(const cred_t *);<br>
-<br>
-<br>
-extern const struct auditinfo_addr *crgetauinfo(const cred_t *);<br>
-extern struct auditinfo_addr *crgetauinfo_modifiable(cred_t *);<br>
-<br>
-extern uint_t crgetref(const cred_t *);<br>
-<br>
-extern const gid_t *crgetggroups(const struct credgrp *);<br>
-<br>
-<br>
-/*<br>
- * Sets real, effective and/or saved uid/gid;<br>
- * -1 argument accepted as &quot;no change&quot;.<br>
- */<br>
-extern int crsetresuid(cred_t *, uid_t, uid_t, uid_t);<br>
-extern int crsetresgid(cred_t *, gid_t, gid_t, gid_t);<br>
-<br>
-/*<br>
- * Sets real, effective and saved uids/gids all to the same<br>
- * values.=C2=A0 Both values must be non-negative and &lt;=3D MAXUID<br>
- */<br>
-extern int crsetugid(cred_t *, uid_t, gid_t);<br>
-<br>
-/*<br>
- * Functions to handle the supplemental group list.<br>
- */<br>
-extern struct credgrp *crgrpcopyin(int, gid_t *);<br>
-extern void crgrprele(struct credgrp *);<br>
-extern void crsetcredgrp(cred_t *, struct credgrp *);<br>
-<br>
-/*<br>
- * Private interface for setting zone association of credential.<br>
- */<br>
-struct zone;<br>
-extern void crsetzone(cred_t *, struct zone *);<br>
-extern struct zone *crgetzone(const cred_t *);<br>
-<br>
-/*<br>
- * Private interface for setting project id in credential.<br>
- */<br>
-extern void crsetprojid(cred_t *, projid_t);<br>
-<br>
-/*<br>
- * Private interface for nfs.<br>
- */<br>
-extern cred_t *crnetadjust(cred_t *);<br>
-<br>
-/*<br>
- * Private interface for procfs.<br>
- */<br>
-extern void cred2prcred(const cred_t *, struct prcred *);<br>
-<br>
-/*<br>
- * Private interfaces for Rampart Trusted Solaris.<br>
- */<br>
-struct ts_label_s;<br>
-extern struct ts_label_s *crgetlabel(const cred_t *);<br>
-extern boolean_t crisremote(const cred_t *);<br>
-<br>
-/*<br>
- * Private interfaces for ephemeral uids.<br>
- */<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 VALID_UID(id, zn)=C2=A0 =C2=A0 =C2=A0 =
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0\<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0((id) &lt;=3D MAXUID || valid_ephemeral_uid((zn=
), (id)))<br>
-<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 VALID_GID(id, zn)=C2=A0 =C2=A0 =C2=A0 =
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0\<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0((id) &lt;=3D MAXUID || valid_ephemeral_gid((zn=
), (id)))<br>
-<br>
-extern boolean_t valid_ephemeral_uid(struct zone *, uid_t);<br>
-extern boolean_t valid_ephemeral_gid(struct zone *, gid_t);<br>
-<br>
-extern int eph_uid_alloc(struct zone *, int, uid_t *, int);<br>
-extern int eph_gid_alloc(struct zone *, int, gid_t *, int);<br>
-<br>
-extern void crsetsid(cred_t *, struct ksid *, int);<br>
-extern void crsetsidlist(cred_t *, struct ksidlist *);<br>
-<br>
-extern struct ksidlist *crgetsidlist(const cred_t *);<br>
-<br>
-extern int crsetpriv(cred_t *, ...);<br>
-<br>
-extern struct credklpd *crgetcrklpd(const cred_t *);<br>
-extern void crsetcrklpd(cred_t *, struct credklpd *);<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 KUID_TO_SUID(x)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0(x)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 KGID_TO_SGID(x)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0(x)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetuid(cr)=C2=A0 =C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 ((cr)-&gt;cr_uid)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetruid(cr)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 =C2=A0((cr)-&gt;cr_ruid)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetgid(cr)=C2=A0 =C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 ((cr)-&gt;cr_gid)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetgroups(cr)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0((cr)-&gt;cr_groups)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetngroups(cr)=C2=A0 =C2=A0 =C2=A0 =
=C2=A0 ((cr)-&gt;cr_ngroups)<br>
+#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 crgetzoneid(cr)=C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0((cr)-&gt;cr_prison-&gt;pr_id)<br>
<br>
=C2=A0#ifdef __cplusplus<br>
=C2=A0}<br>
diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h b/sys/=
contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h<br>
deleted file mode 100644<br>
index dc0cf5988a42..000000000000<br>
--- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/kidmap.h<br>
+++ /dev/null<br>
@@ -1,41 +0,0 @@<br>
-/*<br>
- * Copyright (c) 2007 Pawel Jakub Dawidek &lt;pjd@FreeBSD.org&gt;<br>
- * All rights reserved.<br>
- *<br>
- * Redistribution and use in source and binary forms, with or without<br>
- * modification, are permitted provided that the following conditions<br>
- * are met:<br>
- * 1. Redistributions of source code must retain the above copyright<br>
- *=C2=A0 =C2=A0 notice, this list of conditions and the following disclaim=
er.<br>
- * 2. Redistributions in binary form must reproduce the above copyright<br=
>
- *=C2=A0 =C2=A0 notice, this list of conditions and the following disclaim=
er in the<br>
- *=C2=A0 =C2=A0 documentation and/or other materials provided with the dis=
tribution.<br>
- *<br>
- * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS&#39;&=
#39; AND<br>
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE<b=
r>
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURP=
OSE<br>
- * ARE DISCLAIMED.=C2=A0 IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE =
LIABLE<br>
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENT=
IAL<br>
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS=
<br>
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)<b=
r>
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STR=
ICT<br>
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY W=
AY<br>
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF<=
br>
- * SUCH DAMAGE.<br>
- *<br>
- * $FreeBSD$<br>
- */<br>
-<br>
-#ifndef _OPENSOLARIS_SYS_KIDMAP_H_<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 _OPENSOLARIS_SYS_KIDMAP_H_<br>
-<br>
-#include &lt;sys/idmap.h&gt;<br>
-<br>
-typedef int32_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 idmap_stat;<br>
-typedef void=C2=A0 =C2=A0idmap_get_handle_t;<br>
-<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kidmap_get_create()=C2=A0 =C2=A0 =C2=A0=
 =C2=A0 =C2=A0 =C2=A0 =C2=A0(NULL)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kidmap_get_destroy(hdl)=C2=A0 =C2=A0 =
=C2=A0 =C2=A0 =C2=A0do { } while (0)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kidmap_get_mappings(hdl)=C2=A0 =C2=A0 =
=C2=A0 =C2=A0 (NULL)<br>
-<br>
-#endif /* _OPENSOLARIS_SYS_KIDMAP_H_ */<br>
diff --git a/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h b/sys/con=
trib/openzfs/include/os/freebsd/spl/sys/sid.h<br>
index d3fab8b24744..f249d05d55a0 100644<br>
--- a/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h<br>
+++ b/sys/contrib/openzfs/include/os/freebsd/spl/sys/sid.h<br>
@@ -29,7 +29,6 @@<br>
=C2=A0#ifndef _OPENSOLARIS_SYS_SID_H_<br>
=C2=A0#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 _OPENSOLARIS_SYS_SID_H_<br>
=C2=A0#include &lt;sys/idmap.h&gt;<br>
-#include &lt;sys/kidmap.h&gt;<br>
<br>
=C2=A0typedef struct ksiddomain {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char=C2=A0 =C2=A0 *kd_name;=C2=A0 =C2=A0 =C2=A0=
 =C2=A0/* Domain part of SID */<br>
@@ -59,28 +58,4 @@ ksiddomain_rele(ksiddomain_t *kd)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 kmem_free(kd, sizeof (*kd));<br>
=C2=A0}<br>
<br>
-static __inline uint_t<br>
-ksid_getid(ksid_t *ks)<br>
-{<br>
-<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0panic(&quot;%s has been unexpectedly called&quo=
t;, __func__);<br>
-}<br>
-<br>
-static __inline const char *<br>
-ksid_getdomain(ksid_t *ks)<br>
-{<br>
-<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0panic(&quot;%s has been unexpectedly called&quo=
t;, __func__);<br>
-}<br>
-<br>
-static __inline uint_t<br>
-ksid_getrid(ksid_t *ks)<br>
-{<br>
-<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0panic(&quot;%s has been unexpectedly called&quo=
t;, __func__);<br>
-}<br>
-<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kidmap_getsidbyuid(zone, uid, sid_prefi=
x, rid)=C2=A0 (1)<br>
-#define=C2=A0 =C2=A0 =C2=A0 =C2=A0 kidmap_getsidbygid(zone, gid, sid_prefi=
x, rid)=C2=A0 (1)<br>
-<br>
=C2=A0#endif /* _OPENSOLARIS_SYS_SID_H_ */<br>
diff --git a/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h b=
/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h<br>
index 6d4c7a09fe82..0f6a222ba667 100644<br>
--- a/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h<br>
+++ b/sys/contrib/openzfs/include/os/linux/kernel/linux/simd_x86.h<br>
@@ -420,9 +420,9 @@ kfpu_end(void)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (static_cpu_has(X86_FEATURE_XSAVE)) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 kfpu_do_xrstor(&quo=
t;xrstor&quot;, &amp;state-&gt;xsave, ~0);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 } else if (static_cpu_has(X86_FEATURE_FXSR)) {<=
br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0kfpu_save_fxsr(&amp=
;state-&gt;fxsave);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0kfpu_restore_fxsr(&=
amp;state-&gt;fxsave);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 } else {<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0kfpu_save_fsave(&am=
p;state-&gt;fsave);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0kfpu_restore_fsave(=
&amp;state-&gt;fsave);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
=C2=A0out:<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 local_irq_enable();<br>
diff --git a/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h b/sys/cont=
rib/openzfs/include/os/linux/spl/sys/cred.h<br>
index 9cc85deb5c8a..b7d3f38d70bb 100644<br>
--- a/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h<br>
+++ b/sys/contrib/openzfs/include/os/linux/spl/sys/cred.h<br>
@@ -49,12 +49,7 @@ extern void crhold(cred_t *cr);<br>
=C2=A0extern void crfree(cred_t *cr);<br>
=C2=A0extern uid_t crgetuid(const cred_t *cr);<br>
=C2=A0extern uid_t crgetruid(const cred_t *cr);<br>
-extern uid_t crgetsuid(const cred_t *cr);<br>
-extern uid_t crgetfsuid(const cred_t *cr);<br>
=C2=A0extern gid_t crgetgid(const cred_t *cr);<br>
-extern gid_t crgetrgid(const cred_t *cr);<br>
-extern gid_t crgetsgid(const cred_t *cr);<br>
-extern gid_t crgetfsgid(const cred_t *cr);<br>
=C2=A0extern int crgetngroups(const cred_t *cr);<br>
=C2=A0extern gid_t *crgetgroups(const cred_t *cr);<br>
=C2=A0extern int groupmember(gid_t gid, const cred_t *cr);<br>
diff --git a/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c b/sys/contrib/o=
penzfs/lib/libzfs/libzfs_crypto.c<br>
index 644dd26859f1..f77becd6a5c1 100644<br>
--- a/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c<br>
+++ b/sys/contrib/openzfs/lib/libzfs/libzfs_crypto.c<br>
@@ -606,7 +606,6 @@ get_key_material_https(libzfs_handle_t *hdl, const char=
 *uri,<br>
=C2=A0kfdok:<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if ((key =3D fdopen(kfd, &quot;r+&quot;)) =3D=
=3D NULL) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 ret =3D errno;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0free(path);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (void) close(kfd);<=
br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 zfs_error_aux(hdl, =
dgettext(TEXT_DOMAIN,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 &quot=
;Couldn&#39;t reopen temporary file: %s&quot;), strerror(ret));<br>
diff --git a/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os=
.c b/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c<br>
index 13f8bd031612..45a6f6f5935b 100644<br>
--- a/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c<br>
+++ b/sys/contrib/openzfs/lib/libzutil/os/linux/zutil_device_path_os.c<br>
@@ -527,7 +527,7 @@ zfs_dev_is_dm(const char *dev_name)<br>
=C2=A0boolean_t<br>
=C2=A0zfs_dev_is_whole_disk(const char *dev_name)<br>
=C2=A0{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0struct dk_gpt *label;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0struct dk_gpt *label =3D NULL;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 int fd;<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if ((fd =3D open(dev_name, O_RDONLY | O_DIRECT =
| O_CLOEXEC)) &lt; 0)<br>
@@ -613,22 +613,24 @@ zfs_get_underlying_path(const char *dev_name)<br>
=C2=A0/*<br>
=C2=A0 * A disk is considered a multipath whole disk when:<br>
=C2=A0 *=C2=A0 =C2=A0 =C2=A0DEVNAME key value has &quot;dm-&quot;<br>
- *=C2=A0 =C2=A0 =C2=A0DM_NAME key value has &quot;mpath&quot; prefix<br>
- *=C2=A0 =C2=A0 =C2=A0DM_UUID key exists<br>
+ *=C2=A0 =C2=A0 =C2=A0DM_UUID key exists and starts with &#39;mpath-&#39;<=
br>
=C2=A0 *=C2=A0 =C2=A0 =C2=A0ID_PART_TABLE_TYPE key does not exist or is not=
 gpt<br>
+ *=C2=A0 =C2=A0 =C2=A0ID_FS_LABEL key does not exist (disk isn&#39;t label=
ed)<br>
=C2=A0 */<br>
=C2=A0static boolean_t<br>
-udev_mpath_whole_disk(struct udev_device *dev)<br>
+is_mpath_udev_sane(struct udev_device *dev)<br>
=C2=A0{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0const char *devname, *type, *uuid;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0const char *devname, *type, *uuid, *label;<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 devname =3D udev_device_get_property_value(dev,=
 &quot;DEVNAME&quot;);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 type =3D udev_device_get_property_value(dev, &q=
uot;ID_PART_TABLE_TYPE&quot;);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uuid =3D udev_device_get_property_value(dev, &q=
uot;DM_UUID&quot;);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0label =3D udev_device_get_property_value(dev, &=
quot;ID_FS_LABEL&quot;);<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if ((devname !=3D NULL &amp;&amp; strncmp(devna=
me, &quot;/dev/dm-&quot;, 8) =3D=3D 0) &amp;&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 ((type =3D=3D NULL) || (strcmp(ty=
pe, &quot;gpt&quot;) !=3D 0)) &amp;&amp;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0(uuid !=3D NULL)) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0((uuid !=3D NULL) &amp;&amp; (str=
ncmp(uuid, &quot;mpath-&quot;, 6) =3D=3D 0)) &amp;&amp;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0(label =3D=3D NULL)) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (B_TRUE);<br=
>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
<br>
@@ -636,7 +638,11 @@ udev_mpath_whole_disk(struct udev_device *dev)<br>
=C2=A0}<br>
<br>
=C2=A0/*<br>
- * Check if a disk is effectively a multipath whole disk<br>
+ * Check if a disk is a multipath &quot;blank&quot; disk:<br>
+ *<br>
+ * 1. The disk has udev values that suggest it&#39;s a multipath disk<br>
+ * 2. The disk is not currently labeled with a filesystem of any type<br>
+ * 3. There are no partitions on the disk<br>
=C2=A0 */<br>
=C2=A0boolean_t<br>
=C2=A0is_mpath_whole_disk(const char *path)<br>
@@ -645,7 +651,6 @@ is_mpath_whole_disk(const char *path)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 struct udev_device *dev =3D NULL;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char nodepath[MAXPATHLEN];<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 char *sysname;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0boolean_t wholedisk =3D B_FALSE;<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (realpath(path, nodepath) =3D=3D NULL)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (B_FALSE);<b=
r>
@@ -660,10 +665,11 @@ is_mpath_whole_disk(const char *path)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (B_FALSE);<b=
r>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0wholedisk =3D udev_mpath_whole_disk(dev);<br>
-<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0/* Sanity check some udev values */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0boolean_t is_sane =3D is_mpath_udev_sane(dev);<=
br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 udev_device_unref(dev);<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (wholedisk);<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0return (is_sane);<br>
=C2=A0}<br>
<br>
=C2=A0#else /* HAVE_LIBUDEV */<br>
diff --git a/sys/contrib/openzfs/module/Makefile.bsd b/sys/contrib/openzfs/=
module/Makefile.bsd<br>
index 8aa4ed22275e..dc6cc2b74243 100644<br>
--- a/sys/contrib/openzfs/module/Makefile.bsd<br>
+++ b/sys/contrib/openzfs/module/Makefile.bsd<br>
@@ -32,7 +32,7 @@ CFLAGS+=3D -include ${INCDIR}/os/freebsd/spl/sys/ccompile=
.h<br>
<br>
=C2=A0CFLAGS+=3D -D__KERNEL__ -DFREEBSD_NAMECACHE -DBUILDING_ZFS=C2=A0 -D__=
BSD_VISIBLE=3D1 \<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0-DHAVE_UIO_ZEROCOPY -DWITHOUT_NETDUMP -D_=
_KERNEL -D_SYS_CONDVAR_H_ \<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 -D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DSMP -DHAVE_KS=
ID -DCOMPAT_FREEBSD11<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 -D_SYS_VMEM_H_ -DKDTRACE_HOOKS -DSMP -DCOMPAT_=
FREEBSD11<br>
<br>
=C2=A0.if ${MACHINE_ARCH} =3D=3D &quot;amd64&quot;<br>
=C2=A0CFLAGS+=3D -DHAVE_AVX2 -DHAVE_AVX -D__x86_64 -DHAVE_SSE2 -DHAVE_AVX51=
2F -DHAVE_SSSE3<br>
diff --git a/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c b/sys=
/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c<br>
index d5d50080fafd..16188c71b53d 100644<br>
--- a/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c<br>
+++ b/sys/contrib/openzfs/module/os/freebsd/spl/spl_sysevent.c<br>
@@ -250,7 +250,17 @@ sysevent_worker(void *arg __unused)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 nvlist_free(event);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 }<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0zfs_zevent_destroy(ze);<br>
+<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0/*<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * We avoid zfs_zevent_destroy() here because w=
e&#39;re otherwise racing<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * against fm_fini() destroying the zevent_lock=
.=C2=A0 zfs_zevent_destroy()<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * will currently only clear `ze-&gt;ze_zevent`=
 from an event list then<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * free `ze`, so just inline the free() here --=
 events have already<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 * been drained.<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 */<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0VERIFY3P(ze-&gt;ze_zevent, =3D=3D, NULL);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0kmem_free(ze, sizeof (zfs_zevent_t));<br>
+<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 kthread_exit();<br>
=C2=A0}<br>
<br>
diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c b/sys/cont=
rib/openzfs/module/os/freebsd/zfs/zfs_acl.c<br>
index ae758bcefe21..fe0f69132321 100644<br>
--- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c<br>
+++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_acl.c<br>
@@ -1653,8 +1653,10 @@ zfs_acl_ids_create(znode_t *dzp, int flag, vattr_t *=
vap, cred_t *cr,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 ZFS_G=
ROUP, &amp;acl_ids-&gt;z_fuidp);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 gid =3D vap-&gt;va_=
gid;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 } else {<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0acl_ids-&gt;z_fuid =
=3D zfs_fuid_create_cred(zfsvfs, ZFS_OWNER,<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0cr, &=
amp;acl_ids-&gt;z_fuidp);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0uid_t id =3D crgetu=
id(cr);<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0if (IS_EPHEMERAL(id=
))<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0id =3D UID_NOBODY;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0acl_ids-&gt;z_fuid =
=3D (uint64_t)id;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 acl_ids-&gt;z_fgid =
=3D 0;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 if (vap-&gt;va_mask=
 &amp; AT_GID)=C2=A0 {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=
=A0 =C2=A0 acl_ids-&gt;z_fgid =3D zfs_fuid_create(zfsvfs,<br>
diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c b/sys=
/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c<br>
index 7bcf80bf5a94..b2cc3d063f9c 100644<br>
--- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c<br>
+++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_vnops_os.c<br>
@@ -1060,8 +1060,7 @@ zfs_create(znode_t *dzp, const char *name, vattr_t *v=
ap, int excl, int mode,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 objset_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 *os;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 dmu_tx_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 *tx;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 int=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =
=C2=A0error;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0ksid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 *ksid;=
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0uid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0u=
id;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0uid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0u=
id =3D crgetuid(cr);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 gid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0g=
id =3D crgetgid(cr);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 projid =3D =
ZFS_DEFAULT_PROJID;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 zfs_acl_ids_t=C2=A0 =C2=A0acl_ids;<br>
@@ -1075,13 +1074,6 @@ zfs_create(znode_t *dzp, const char *name, vattr_t *=
vap, int excl, int mode,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* If we have an ephemeral id, ACL, or XVA=
TTR then<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* make sure file system is at proper vers=
ion<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
-<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0ksid =3D crgetsid(cr, KSID_OWNER);<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (ksid)<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0uid =3D ksid_getid(=
ksid);<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0else<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0uid =3D crgetuid(cr=
);<br>
-<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (zfsvfs-&gt;z_use_fuids =3D=3D B_FALSE &amp;=
&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 (vsecp || (vap-&gt;va_mask &amp; =
AT_XVATTR) ||<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 IS_EPHEMERAL(uid) || IS_EPHEMERAL=
(gid)))<br>
@@ -1415,8 +1407,7 @@ zfs_mkdir(znode_t *dzp, const char *dirname, vattr_t =
*vap, znode_t **zpp,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 txtype;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 dmu_tx_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 *tx;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 int=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =
=C2=A0error;<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0ksid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 *ksid;=
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0uid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0u=
id;<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0uid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0u=
id =3D crgetuid(cr);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 gid_t=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0g=
id =3D crgetgid(cr);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 zfs_acl_ids_t=C2=A0 =C2=A0acl_ids;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 boolean_t=C2=A0 =C2=A0 =C2=A0 =C2=A0fuid_dirtie=
d;<br>
@@ -1427,12 +1418,6 @@ zfs_mkdir(znode_t *dzp, const char *dirname, vattr_t=
 *vap, znode_t **zpp,<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* If we have an ephemeral id, ACL, or XVA=
TTR then<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0* make sure file system is at proper vers=
ion<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0*/<br>
-<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0ksid =3D crgetsid(cr, KSID_OWNER);<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (ksid)<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0uid =3D ksid_getid(=
ksid);<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0else<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0uid =3D crgetuid(cr=
);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (zfsvfs-&gt;z_use_fuids =3D=3D B_FALSE &amp;=
&amp;<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 ((vap-&gt;va_mask &amp; AT_XVATTR=
) ||<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 IS_EPHEMERAL(uid) || IS_EPHEMERAL=
(gid)))<br>
diff --git a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c b/sys/co=
ntrib/openzfs/module/os/freebsd/zfs/zfs_znode.c<br>
index d14df9d88a35..8a2773ac7971 100644<br>
--- a/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c<br>
+++ b/sys/contrib/openzfs/module/os/freebsd/zfs/zfs_znode.c<br>
@@ -839,7 +839,9 @@ zfs_xvattr_set(znode_t *zp, xvattr_t *xvap, dmu_tx_t *t=
x)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 xoap =3D xva_getxoptattr(xvap);<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 ASSERT3P(xoap, !=3D, NULL);<br>
<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0ASSERT_VOP_IN_SEQC(ZTOV(zp));<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (zp-&gt;z_zfsvfs-&gt;z_replay =3D=3D B_FALSE=
) {<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0ASSERT_VOP_IN_SEQC(=
ZTOV(zp));<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0}<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (XVA_ISSET_REQ(xvap, XAT_CREATETIME)) {<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 uint64_t times[2];<=
br>
diff --git a/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c b/sys/contr=
ib/openzfs/module/os/linux/spl/spl-cred.c<br>
index 8fe1cc30ba99..f81b9540a639 100644<br>
--- a/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c<br>
+++ b/sys/contrib/openzfs/module/os/linux/spl/spl-cred.c<br>
@@ -128,7 +128,7 @@ groupmember(gid_t gid, const cred_t *cr)<br>
=C2=A0uid_t<br>
=C2=A0crgetuid(const cred_t *cr)<br>
=C2=A0{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KUID_TO_SUID(cr-&gt;euid));<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KUID_TO_SUID(cr-&gt;fsuid));<br>
=C2=A0}<br>
<br>
=C2=A0/* Return the real user id */<br>
@@ -138,44 +138,9 @@ crgetruid(const cred_t *cr)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 return (KUID_TO_SUID(cr-&gt;uid));<br>
=C2=A0}<br>
<br>
-/* Return the saved user id */<br>
-uid_t<br>
-crgetsuid(const cred_t *cr)<br>
-{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KUID_TO_SUID(cr-&gt;suid));<br>
-}<br>
-<br>
-/* Return the filesystem user id */<br>
-uid_t<br>
-crgetfsuid(const cred_t *cr)<br>
-{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KUID_TO_SUID(cr-&gt;fsuid));<br>
-}<br>
-<br>
=C2=A0/* Return the effective group id */<br>
=C2=A0gid_t<br>
=C2=A0crgetgid(const cred_t *cr)<br>
-{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KGID_TO_SGID(cr-&gt;egid));<br>
-}<br>
-<br>
-/* Return the real group id */<br>
-gid_t<br>
-crgetrgid(const cred_t *cr)<br>
-{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KGID_TO_SGID(cr-&gt;gid));<br>
-}<br>
-<br>
-/* Return the saved group id */<br>
-gid_t<br>
-crgetsgid(const cred_t *cr)<br>
-{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0return (KGID_TO_SGID(cr-&gt;sgid));<br>
-}<br>
-<br>
-/* Return the filesystem group id */<br>
-gid_t<br>
-crgetfsgid(const cred_t *cr)<br>
=C2=A0{<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 return (KGID_TO_SGID(cr-&gt;fsgid));<br>
=C2=A0}<br>
@@ -184,12 +149,7 @@ EXPORT_SYMBOL(crhold);<br>
=C2=A0EXPORT_SYMBOL(crfree);<br>
=C2=A0EXPORT_SYMBOL(crgetuid);<br>
=C2=A0EXPORT_SYMBOL(crgetruid);<br>
-EXPORT_SYMBOL(crgetsuid);<br>
-EXPORT_SYMBOL(crgetfsuid);<br>
=C2=A0EXPORT_SYMBOL(crgetgid);<br>
-EXPORT_SYMBOL(crgetrgid);<br>
-EXPORT_SYMBOL(crgetsgid);<br>
-EXPORT_SYMBOL(crgetfsgid);<br>
=C2=A0EXPORT_SYMBOL(crgetngroups);<br>
=C2=A0EXPORT_SYMBOL(crgetgroups);<br>
=C2=A0EXPORT_SYMBOL(groupmember);<br>
diff --git a/sys/contrib/openzfs/module/os/linux/zfs/policy.c b/sys/contrib=
/openzfs/module/os/linux/zfs/policy.c<br>
index bbccb2e572d9..5a52092bb90a 100644<br>
--- a/sys/contrib/openzfs/module/os/linux/zfs/policy.c<br>
+++ b/sys/contrib/openzfs/module/os/linux/zfs/policy.c<br>
@@ -121,7 +121,7 @@ secpolicy_vnode_access2(const cred_t *cr, struct inode =
*ip, uid_t owner,<br>
=C2=A0int<br>
=C2=A0secpolicy_vnode_any_access(const cred_t *cr, struct inode *ip, uid_t =
owner)<br>
=C2=A0{<br>
-=C2=A0 =C2=A0 =C2=A0 =C2=A0if (crgetfsuid(cr) =3D=3D owner)<br>
+=C2=A0 =C2=A0 =C2=A0 =C2=A0if (crgetuid(cr) =3D=3D owner)<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0 return (0);<br>
<br>
=C2=A0 =C2=A0 =C2=A0 =C2=A0 if (zpl_inode_owner_or_capable(kcred-&gt;user_n=
s, ip))<br>
@@ -147,7 +147,7 @@ secpolicy_vnode_any_access(const cred_t *cr, struct ino=
de *ip, uid_t owner)<br>
=C2=A0int<br>
=C2=A0secpolicy_vnode_chown(const cred_t *cr, uid_t owner)<br>
*** 141 LINES SKIPPED ***<br>
</blockquote></div>

--0000000000009d978a05db5d4121--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAF3%2Bn_e%2BM=3K6EMcN6XJvpC3f8cuSFbM25dqY=xthpzdDy%2B-yw>