mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-28 02:44:30 +03:00
Fix for #6703
This patch resolves an issue where spa_keystore_change_key_sync_impl() incorrectly recursed into clone DSL Directories while recursively rewrapping encryption keys. Clones share keys with their origins, so this logic was incorrect. Signed-off-by: Tom Caputi <tcaputi@datto.com>
This commit is contained in:
parent
440a3eb939
commit
b135b9f11a
@ -1321,10 +1321,12 @@ spa_keystore_change_key_sync_impl(uint64_t rddobj, uint64_t ddobj,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* stop recursing if this dsl dir didn't inherit from the root */
|
/*
|
||||||
|
* Stop recursing if this dsl dir didn't inherit from the root
|
||||||
|
* or if this dd is a clone.
|
||||||
|
*/
|
||||||
VERIFY0(dsl_dir_get_encryption_root_ddobj(dd, &curr_rddobj));
|
VERIFY0(dsl_dir_get_encryption_root_ddobj(dd, &curr_rddobj));
|
||||||
|
if (curr_rddobj != rddobj || dsl_dir_is_clone(dd)) {
|
||||||
if (curr_rddobj != rddobj) {
|
|
||||||
dsl_dir_rele(dd, FTAG);
|
dsl_dir_rele(dd, FTAG);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1350,7 +1352,7 @@ spa_keystore_change_key_sync_impl(uint64_t rddobj, uint64_t ddobj,
|
|||||||
zc = kmem_alloc(sizeof (zap_cursor_t), KM_SLEEP);
|
zc = kmem_alloc(sizeof (zap_cursor_t), KM_SLEEP);
|
||||||
za = kmem_alloc(sizeof (zap_attribute_t), KM_SLEEP);
|
za = kmem_alloc(sizeof (zap_attribute_t), KM_SLEEP);
|
||||||
|
|
||||||
/* Recurse into all child and clone dsl dirs. */
|
/* Recurse into all child dsl dirs. */
|
||||||
for (zap_cursor_init(zc, dp->dp_meta_objset,
|
for (zap_cursor_init(zc, dp->dp_meta_objset,
|
||||||
dsl_dir_phys(dd)->dd_child_dir_zapobj);
|
dsl_dir_phys(dd)->dd_child_dir_zapobj);
|
||||||
zap_cursor_retrieve(zc, za) == 0;
|
zap_cursor_retrieve(zc, za) == 0;
|
||||||
@ -1360,20 +1362,6 @@ spa_keystore_change_key_sync_impl(uint64_t rddobj, uint64_t ddobj,
|
|||||||
}
|
}
|
||||||
zap_cursor_fini(zc);
|
zap_cursor_fini(zc);
|
||||||
|
|
||||||
for (zap_cursor_init(zc, dp->dp_meta_objset,
|
|
||||||
dsl_dir_phys(dd)->dd_clones);
|
|
||||||
zap_cursor_retrieve(zc, za) == 0;
|
|
||||||
zap_cursor_advance(zc)) {
|
|
||||||
dsl_dataset_t *clone;
|
|
||||||
|
|
||||||
VERIFY0(dsl_dataset_hold_obj(dp,
|
|
||||||
za->za_first_integer, FTAG, &clone));
|
|
||||||
spa_keystore_change_key_sync_impl(rddobj,
|
|
||||||
clone->ds_dir->dd_object, new_rddobj, wkey, tx);
|
|
||||||
dsl_dataset_rele(clone, FTAG);
|
|
||||||
}
|
|
||||||
zap_cursor_fini(zc);
|
|
||||||
|
|
||||||
kmem_free(za, sizeof (zap_attribute_t));
|
kmem_free(za, sizeof (zap_attribute_t));
|
||||||
kmem_free(zc, sizeof (zap_cursor_t));
|
kmem_free(zc, sizeof (zap_cursor_t));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user