svn commit: r347605 - stable/11/cddl/contrib/opensolaris/cmd/zfs
Alexander Motin
mav at FreeBSD.org
Wed May 15 01:40:41 UTC 2019
Author: mav
Date: Wed May 15 01:40:40 2019
New Revision: 347605
URL: https://svnweb.freebsd.org/changeset/base/347605
Log:
MFC r347240: Fix dataset name comparison in zfs_compare().
The code never returned match comparing two datasets (not snapshots).
As result, uu_avl_find(), called from zfs_callback(), never succeeded,
allowing to add same dataset into the list multiple times, for example:
# zfs get name pers pers pers at z pers at z
NAME PROPERTY VALUE SOURCE
pers name pers -
pers name pers -
pers at z name pers at z -
With the patch:
# zfs get name pers pers pers at z pers at z
NAME PROPERTY VALUE SOURCE
pers name pers -
pers at z name pers at z -
Modified:
stable/11/cddl/contrib/opensolaris/cmd/zfs/zfs_iter.c
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/cddl/contrib/opensolaris/cmd/zfs/zfs_iter.c
==============================================================================
--- stable/11/cddl/contrib/opensolaris/cmd/zfs/zfs_iter.c Wed May 15 01:38:34 2019 (r347604)
+++ stable/11/cddl/contrib/opensolaris/cmd/zfs/zfs_iter.c Wed May 15 01:40:40 2019 (r347605)
@@ -225,7 +225,7 @@ zfs_compare(const void *larg, const void *rarg, void *
*rat = '\0';
ret = strcmp(lname, rname);
- if (ret == 0) {
+ if (ret == 0 && (lat != NULL || rat != NULL)) {
/*
* If we're comparing a dataset to one of its snapshots, we
* always make the full dataset first.
More information about the svn-src-stable-11
mailing list