mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-24 19:28:53 +03:00
assertion in arc_release() during encrypted receive
In the existing code, when doing a raw (encrypted) zfs receive, we call arc_convert_to_raw() from open context. This creates a race condition between arc_release()/arc_change_state() and writing out the block from syncing context (arc_write_ready/done()). This change makes it so that when we are doing a raw (encrypted) zfs receive, we save the crypt parameters (salt, iv, mac) of dnode blocks in the dbuf_dirty_record_t, and call arc_convert_to_raw() from syncing context when writing out the block of dnodes. Additionally, we can eliminate dr_raw and associated setters, and instead know that dnode blocks are always raw when doing a zfs receive (see the new field os_raw_receive). Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Tom Caputi <tcaputi@datto.com> Signed-off-by: Matthew Ahrens <mahrens@delphix.com> Closes #7424 Closes #7429
This commit is contained in:
committed by
Brian Behlendorf
parent
b40d45bc6c
commit
0c03d21ac9
@@ -1663,11 +1663,12 @@ dmu_objset_sync(objset_t *os, zio_t *pio, dmu_tx_t *tx)
|
||||
dmu_write_policy(os, NULL, 0, 0, &zp);
|
||||
|
||||
/*
|
||||
* If we are either claiming the ZIL or doing a raw receive write out
|
||||
* the os_phys_buf raw. Neither of these actions will effect the MAC
|
||||
* at this point.
|
||||
* If we are either claiming the ZIL or doing a raw receive, write
|
||||
* out the os_phys_buf raw. Neither of these actions will effect the
|
||||
* MAC at this point.
|
||||
*/
|
||||
if (os->os_next_write_raw[tx->tx_txg & TXG_MASK]) {
|
||||
if (os->os_raw_receive ||
|
||||
os->os_next_write_raw[tx->tx_txg & TXG_MASK]) {
|
||||
ASSERT(os->os_encrypted);
|
||||
os->os_next_write_raw[tx->tx_txg & TXG_MASK] = B_FALSE;
|
||||
arc_convert_to_raw(os->os_phys_buf,
|
||||
|
||||
Reference in New Issue
Block a user