Author: mav
Date: Mon Jun  3 17:19:05 2019
New Revision: 348557
URL: https://svnweb.freebsd.org/changeset/base/348557

Log:
  MFV r348534: 9616 Bogus error when attempting to set property on read-only 
pool
  
  illumos/illumos-gate@f62db44dbcda5dd786bb821f1e6fd3ca2e6d4391
  
  Reviewed by: Paul Dagnelie <p...@delphix.com>
  Reviewed by: Matt Ahrens <m...@delphix.com>
  Approved by: Robert Mustacchi <r...@joyent.com>
  Author: Andrew Stormont <astorm...@racktopsystems.com>

Modified:
  head/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c
Directory Properties:
  head/cddl/contrib/opensolaris/   (props changed)
  head/cddl/contrib/opensolaris/lib/libzfs/   (props changed)

Modified: head/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c
==============================================================================
--- head/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c    Mon Jun 
 3 17:14:54 2019        (r348556)
+++ head/cddl/contrib/opensolaris/lib/libzfs/common/libzfs_dataset.c    Mon Jun 
 3 17:19:05 2019        (r348557)
@@ -30,7 +30,7 @@
  * Copyright (c) 2014 Integros [integros.com]
  * Copyright 2017 Nexenta Systems, Inc.
  * Copyright 2016 Igor Kozhukhov <ikozhuk...@gmail.com>
- * Copyright 2017 RackTop Systems.
+ * Copyright 2017-2018 RackTop Systems.
  */
 
 #include <ctype.h>
@@ -1842,13 +1842,18 @@ zfs_prop_set_list(zfs_handle_t *zhp, nvlist_t *props)
        ret = zfs_ioctl(hdl, ZFS_IOC_SET_PROP, &zc);
 
        if (ret != 0) {
+               if (zc.zc_nvlist_dst_filled == B_FALSE) {
+                       (void) zfs_standard_error(hdl, errno, errbuf);
+                       goto error;
+               }
+
                /* Get the list of unset properties back and report them. */
                nvlist_t *errorprops = NULL;
                if (zcmd_read_dst_nvlist(hdl, &zc, &errorprops) != 0)
                        goto error;
-               for (nvpair_t *elem = nvlist_next_nvpair(nvl, NULL);
+               for (nvpair_t *elem = nvlist_next_nvpair(errorprops, NULL);
                    elem != NULL;
-                   elem = nvlist_next_nvpair(nvl, elem)) {
+                   elem = nvlist_next_nvpair(errorprops, elem)) {
                        zfs_prop_t prop = zfs_name_to_prop(nvpair_name(elem));
                        zfs_setprop_error(hdl, prop, errno, errbuf);
                }
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to