Fix recovery import (-F) with encrypted pool
When performing zil_claim() at pool import time, it is important that encrypted datasets set os_next_write_raw before writing to the zil_header_t. This prevents the code from attempting to re-authenticate the objset_phys_t when it writes it out, which is unnecessary because the zil_header_t is not protected by either objset MAC and impossible since the keys aren't loaded yet. Unfortunately, one of the code paths did not set this flag, which causes failed ASSERTs during 'zpool import -F'. This patch corrects this issue. Reviewed-by: Jorgen Lundman <lundman@lundman.net> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed by: Matthew Ahrens <mahrens@delphix.com> Signed-off-by: Tom Caputi <tcaputi@datto.com> Closes #6864 Closes #6916
This commit is contained in:
parent
ae76f45cda
commit
d53bd7f524
@ -819,6 +819,8 @@ zil_claim(dsl_pool_t *dp, dsl_dataset_t *ds, void *txarg)
|
||||
if (zilog->zl_parse_lr_count || zilog->zl_parse_blk_count > 1)
|
||||
zh->zh_flags |= ZIL_REPLAY_NEEDED;
|
||||
zh->zh_flags |= ZIL_CLAIM_LR_SEQ_VALID;
|
||||
if (os->os_encrypted)
|
||||
os->os_next_write_raw = B_TRUE;
|
||||
dsl_dataset_dirty(dmu_objset_ds(os), tx);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user