Tom Caputi 369aa501d1 Fix handling of maxblkid for raw sends
Currently, the receive code can create an unreadable dataset from
a correct raw send stream. This is because it is currently
impossible to set maxblkid to a lower value without freeing the
associated object. This means truncating files on the send side
to a non-0 size could result in corruption. This patch solves this
issue by adding a new 'force' flag to dnode_new_blkid() which will
allow the raw receive code to force the DMU to accept the provided
maxblkid even if it is a lower value than the existing one.

For testing purposes the send_encrypted_files.ksh test has been
extended to include a variety of truncated files and multiple
snapshots. It also now leverages the xattrtest command to help
ensure raw receives correctly handle xattrs.

Reviewed-by: Paul Dagnelie <pcd@delphix.com>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed-by: Matt Ahrens <mahrens@delphix.com>
Signed-off-by: Tom Caputi <tcaputi@datto.com>
Closes #8168 
Closes #8487
2019-03-13 10:52:01 -07:00
..
2016-03-16 13:46:16 -07:00
2016-03-16 13:46:16 -07:00
2017-05-22 12:34:32 -04:00
2017-05-22 12:34:32 -04:00
2018-04-12 10:50:39 -07:00
2017-05-22 12:34:32 -04:00
2018-03-28 10:19:22 -07:00
2016-03-16 13:46:16 -07:00
2016-03-16 13:46:16 -07:00
2016-10-08 14:57:56 -07:00
2016-03-16 13:46:16 -07:00
2017-05-22 12:34:32 -04:00