mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-22 10:37:35 +03:00
Revert "Fix "snapdev" property inheritance behaviour"
This reverts commit 959f56b993.
An issue was uncovered by the new zvol_misc_snapdev test case
which needs to be investigated and resolved.
Reviewed-by: loli10K <ezomori.nozomu@gmail.com>
Reviewed-by: George Melikov <mail@gmelikov.ru>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #6174
Issue #6131
This commit is contained in:
+49
-48
@@ -2761,12 +2761,54 @@ zfs_ioc_inherit_prop(zfs_cmd_t *zc)
|
||||
zprop_source_t source = (received
|
||||
? ZPROP_SRC_NONE /* revert to received value, if any */
|
||||
: ZPROP_SRC_INHERITED); /* explicitly inherit */
|
||||
nvlist_t *dummy;
|
||||
nvpair_t *pair;
|
||||
zprop_type_t type;
|
||||
int err;
|
||||
|
||||
if (!received) {
|
||||
if (received) {
|
||||
nvlist_t *dummy;
|
||||
nvpair_t *pair;
|
||||
zprop_type_t type;
|
||||
int err;
|
||||
|
||||
/*
|
||||
* zfs_prop_set_special() expects properties in the form of an
|
||||
* nvpair with type info.
|
||||
*/
|
||||
if (prop == ZPROP_INVAL) {
|
||||
if (!zfs_prop_user(propname))
|
||||
return (SET_ERROR(EINVAL));
|
||||
|
||||
type = PROP_TYPE_STRING;
|
||||
} else if (prop == ZFS_PROP_VOLSIZE ||
|
||||
prop == ZFS_PROP_VERSION) {
|
||||
return (SET_ERROR(EINVAL));
|
||||
} else {
|
||||
type = zfs_prop_get_type(prop);
|
||||
}
|
||||
|
||||
VERIFY(nvlist_alloc(&dummy, NV_UNIQUE_NAME, KM_SLEEP) == 0);
|
||||
|
||||
switch (type) {
|
||||
case PROP_TYPE_STRING:
|
||||
VERIFY(0 == nvlist_add_string(dummy, propname, ""));
|
||||
break;
|
||||
case PROP_TYPE_NUMBER:
|
||||
case PROP_TYPE_INDEX:
|
||||
VERIFY(0 == nvlist_add_uint64(dummy, propname, 0));
|
||||
break;
|
||||
default:
|
||||
nvlist_free(dummy);
|
||||
return (SET_ERROR(EINVAL));
|
||||
}
|
||||
|
||||
pair = nvlist_next_nvpair(dummy, NULL);
|
||||
if (pair == NULL) {
|
||||
nvlist_free(dummy);
|
||||
return (SET_ERROR(EINVAL));
|
||||
}
|
||||
err = zfs_prop_set_special(zc->zc_name, source, pair);
|
||||
nvlist_free(dummy);
|
||||
if (err != -1)
|
||||
return (err); /* special property already handled */
|
||||
} else {
|
||||
/*
|
||||
* Only check this in the non-received case. We want to allow
|
||||
* 'inherit -S' to revert non-inheritable properties like quota
|
||||
@@ -2777,49 +2819,8 @@ zfs_ioc_inherit_prop(zfs_cmd_t *zc)
|
||||
return (SET_ERROR(EINVAL));
|
||||
}
|
||||
|
||||
if (prop == ZPROP_INVAL) {
|
||||
if (!zfs_prop_user(propname))
|
||||
return (SET_ERROR(EINVAL));
|
||||
|
||||
type = PROP_TYPE_STRING;
|
||||
} else if (prop == ZFS_PROP_VOLSIZE || prop == ZFS_PROP_VERSION) {
|
||||
return (SET_ERROR(EINVAL));
|
||||
} else {
|
||||
type = zfs_prop_get_type(prop);
|
||||
}
|
||||
|
||||
/*
|
||||
* zfs_prop_set_special() expects properties in the form of an
|
||||
* nvpair with type info.
|
||||
*/
|
||||
dummy = fnvlist_alloc();
|
||||
|
||||
switch (type) {
|
||||
case PROP_TYPE_STRING:
|
||||
VERIFY(0 == nvlist_add_string(dummy, propname, ""));
|
||||
break;
|
||||
case PROP_TYPE_NUMBER:
|
||||
case PROP_TYPE_INDEX:
|
||||
VERIFY(0 == nvlist_add_uint64(dummy, propname, 0));
|
||||
break;
|
||||
default:
|
||||
err = SET_ERROR(EINVAL);
|
||||
goto errout;
|
||||
}
|
||||
|
||||
pair = nvlist_next_nvpair(dummy, NULL);
|
||||
if (pair == NULL) {
|
||||
err = SET_ERROR(EINVAL);
|
||||
} else {
|
||||
err = zfs_prop_set_special(zc->zc_name, source, pair);
|
||||
if (err == -1) /* property is not "special", needs handling */
|
||||
err = dsl_prop_inherit(zc->zc_name, zc->zc_value,
|
||||
source);
|
||||
}
|
||||
|
||||
errout:
|
||||
nvlist_free(dummy);
|
||||
return (err);
|
||||
/* property name has been validated by zfs_secpolicy_inherit_prop() */
|
||||
return (dsl_prop_inherit(zc->zc_name, zc->zc_value, source));
|
||||
}
|
||||
|
||||
static int
|
||||
|
||||
+8
-19
@@ -2216,18 +2216,20 @@ zvol_set_snapdev_check(void *arg, dmu_tx_t *tx)
|
||||
return (error);
|
||||
}
|
||||
|
||||
/* ARGSUSED */
|
||||
static int
|
||||
zvol_set_snapdev_sync_cb(dsl_pool_t *dp, dsl_dataset_t *ds, void *arg)
|
||||
{
|
||||
zvol_set_snapdev_arg_t *zsda = arg;
|
||||
char dsname[MAXNAMELEN];
|
||||
zvol_task_t *task;
|
||||
uint64_t snapdev;
|
||||
|
||||
dsl_dataset_name(ds, dsname);
|
||||
if (dsl_prop_get_int_ds(ds, "snapdev", &snapdev) != 0)
|
||||
return (0);
|
||||
task = zvol_task_alloc(ZVOL_ASYNC_SET_SNAPDEV, dsname, NULL, snapdev);
|
||||
dsl_prop_set_sync_impl(ds, zfs_prop_to_name(ZFS_PROP_SNAPDEV),
|
||||
zsda->zsda_source, sizeof (zsda->zsda_value), 1,
|
||||
&zsda->zsda_value, zsda->zsda_tx);
|
||||
|
||||
task = zvol_task_alloc(ZVOL_ASYNC_SET_SNAPDEV, dsname,
|
||||
NULL, zsda->zsda_value);
|
||||
if (task == NULL)
|
||||
return (0);
|
||||
|
||||
@@ -2237,11 +2239,7 @@ zvol_set_snapdev_sync_cb(dsl_pool_t *dp, dsl_dataset_t *ds, void *arg)
|
||||
}
|
||||
|
||||
/*
|
||||
* Traverse all child datasets and apply snapdev appropriately.
|
||||
* We call dsl_prop_set_sync_impl() here to set the value only on the toplevel
|
||||
* dataset and read the effective "snapdev" on every child in the callback
|
||||
* function: this is because the value is not guaranteed to be the same in the
|
||||
* whole dataset hierarchy.
|
||||
* Traverse all child snapshot datasets and apply snapdev appropriately.
|
||||
*/
|
||||
static void
|
||||
zvol_set_snapdev_sync(void *arg, dmu_tx_t *tx)
|
||||
@@ -2249,19 +2247,10 @@ zvol_set_snapdev_sync(void *arg, dmu_tx_t *tx)
|
||||
zvol_set_snapdev_arg_t *zsda = arg;
|
||||
dsl_pool_t *dp = dmu_tx_pool(tx);
|
||||
dsl_dir_t *dd;
|
||||
dsl_dataset_t *ds;
|
||||
int error;
|
||||
|
||||
VERIFY0(dsl_dir_hold(dp, zsda->zsda_name, FTAG, &dd, NULL));
|
||||
zsda->zsda_tx = tx;
|
||||
|
||||
error = dsl_dataset_hold(dp, zsda->zsda_name, FTAG, &ds);
|
||||
if (error == 0) {
|
||||
dsl_prop_set_sync_impl(ds, zfs_prop_to_name(ZFS_PROP_SNAPDEV),
|
||||
zsda->zsda_source, sizeof (zsda->zsda_value), 1,
|
||||
&zsda->zsda_value, zsda->zsda_tx);
|
||||
dsl_dataset_rele(ds, FTAG);
|
||||
}
|
||||
dmu_objset_find_dp(dp, dd->dd_object, zvol_set_snapdev_sync_cb,
|
||||
zsda, DS_FIND_CHILDREN);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user