Allow inherited properties in zfs_check_settable()

This change modifies how 'checksum' and 'dedup' properties are verified
in zfs_check_settable() handling the case where they are explicitly
inherited in the dataset hierarchy when receiving a recursive send
stream.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed-by: Tom Caputi <tcaputi@datto.com>
Signed-off-by: loli10K <ezomori.nozomu@gmail.com>
Closes #7755
Closes #7576
Closes #7757
This commit is contained in:
LOLi 2018-08-03 23:56:25 +02:00 committed by Tony Hutter
parent fe8de1c8a6
commit caafa436eb
2 changed files with 17 additions and 15 deletions

View File

@ -3967,7 +3967,6 @@ zfs_check_settable(const char *dsname, nvpair_t *pair, cred_t *cr)
{ {
spa_feature_t feature; spa_feature_t feature;
spa_t *spa; spa_t *spa;
uint64_t intval;
int err; int err;
/* dedup feature version checks */ /* dedup feature version checks */
@ -3975,22 +3974,23 @@ zfs_check_settable(const char *dsname, nvpair_t *pair, cred_t *cr)
zfs_earlier_version(dsname, SPA_VERSION_DEDUP)) zfs_earlier_version(dsname, SPA_VERSION_DEDUP))
return (SET_ERROR(ENOTSUP)); return (SET_ERROR(ENOTSUP));
if (nvpair_value_uint64(pair, &intval) != 0) if (nvpair_type(pair) == DATA_TYPE_UINT64 &&
return (SET_ERROR(EINVAL)); nvpair_value_uint64(pair, &intval) == 0) {
/* check prop value is enabled in features */
feature = zio_checksum_to_feature(
intval & ZIO_CHECKSUM_MASK);
if (feature == SPA_FEATURE_NONE)
break;
/* check prop value is enabled in features */ if ((err = spa_open(dsname, &spa, FTAG)) != 0)
feature = zio_checksum_to_feature(intval & ZIO_CHECKSUM_MASK); return (err);
if (feature == SPA_FEATURE_NONE)
break;
if ((err = spa_open(dsname, &spa, FTAG)) != 0) if (!spa_feature_is_enabled(spa, feature)) {
return (err); spa_close(spa, FTAG);
return (SET_ERROR(ENOTSUP));
if (!spa_feature_is_enabled(spa, feature)) { }
spa_close(spa, FTAG); spa_close(spa, FTAG);
return (SET_ERROR(ENOTSUP));
} }
spa_close(spa, FTAG);
break; break;
} }

View File

@ -221,15 +221,17 @@ log_must eval "zfs set '$userprop:snap'='$userval' $origsub@snap3"
log_must eval "zfs send -R -I $orig@snap1 $orig@snap3 > $streamfile_incr" log_must eval "zfs send -R -I $orig@snap1 $orig@snap3 > $streamfile_incr"
# Sets various combination of override and exclude options # Sets various combination of override and exclude options
log_must eval "zfs recv -F -o atime=off -o '$userprop:dest2'='$userval' "\ log_must eval "zfs recv -F -o atime=off -o '$userprop:dest2'='$userval' "\
"-o quota=123456789 -x compression -x '$userprop:orig' " \ "-o quota=123456789 -o checksum=sha512 -x compression "\
"-x '$userprop:snap3' $dest < $streamfile_incr" "-x '$userprop:orig' -x '$userprop:snap3' $dest < $streamfile_incr"
# Verify we can correctly override and exclude properties # Verify we can correctly override and exclude properties
log_must eval "check_prop_source $dest copies 2 received" log_must eval "check_prop_source $dest copies 2 received"
log_must eval "check_prop_source $dest atime off local" log_must eval "check_prop_source $dest atime off local"
log_must eval "check_prop_source $dest '$userprop:dest2' '$userval' local" log_must eval "check_prop_source $dest '$userprop:dest2' '$userval' local"
log_must eval "check_prop_source $dest quota 123456789 local" log_must eval "check_prop_source $dest quota 123456789 local"
log_must eval "check_prop_source $dest checksum sha512 local"
log_must eval "check_prop_inherit $destsub copies $dest" log_must eval "check_prop_inherit $destsub copies $dest"
log_must eval "check_prop_inherit $destsub atime $dest" log_must eval "check_prop_inherit $destsub atime $dest"
log_must eval "check_prop_inherit $destsub checksum $dest"
log_must eval "check_prop_inherit $destsub '$userprop:dest2' $dest" log_must eval "check_prop_inherit $destsub '$userprop:dest2' $dest"
log_must eval "check_prop_source $destsub quota 0 default" log_must eval "check_prop_source $destsub quota 0 default"
log_must eval "check_prop_source $destsub compression off default" log_must eval "check_prop_source $destsub compression off default"