Author: smh
Date: Thu Sep 18 14:50:50 2014
New Revision: 271776
URL: http://svnweb.freebsd.org/changeset/base/271776

Log:
  MFC r271429:
  Persist vdev_resilver_txg changes to avoid panic caused by validation
  vs a vdev_resilver_txg value from a previous resilver.
  
  Approved by:  re (glebius)
  Sponsored by: Multiplay

Modified:
  stable/10/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev.c
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev.c
==============================================================================
--- stable/10/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev.c     Thu Sep 
18 14:50:21 2014        (r271775)
+++ stable/10/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/vdev.c     Thu Sep 
18 14:50:50 2014        (r271776)
@@ -1951,12 +1951,15 @@ vdev_dtl_reassess(vdev_t *vd, uint64_t t
 
                /*
                 * If the vdev was resilvering and no longer has any
-                * DTLs then reset its resilvering flag.
+                * DTLs then reset its resilvering flag and dirty
+                * the top level so that we persist the change.
                 */
                if (vd->vdev_resilver_txg != 0 &&
                    range_tree_space(vd->vdev_dtl[DTL_MISSING]) == 0 &&
-                   range_tree_space(vd->vdev_dtl[DTL_OUTAGE]) == 0)
+                   range_tree_space(vd->vdev_dtl[DTL_OUTAGE]) == 0) {
                        vd->vdev_resilver_txg = 0;
+                       vdev_config_dirty(vd->vdev_top);
+               }
 
                mutex_exit(&vd->vdev_dtl_lock);
 
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to