From 7c13517fff71be473e47531ef4330160c042bedc Mon Sep 17 00:00:00 2001 From: Serapheim Dimitropoulos Date: Tue, 17 Jan 2017 17:04:34 -0800 Subject: 7745 print error if lzc_* is called before libzfs_core_init Reviewed by: Pavel Zakharov Reviewed by: Matthew Ahrens Approved by: Dan McDonald --- usr/src/lib/libzfs/common/libzfs_sendrecv.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'usr/src/lib/libzfs/common/libzfs_sendrecv.c') diff --git a/usr/src/lib/libzfs/common/libzfs_sendrecv.c b/usr/src/lib/libzfs/common/libzfs_sendrecv.c index b8db4c9c8e..8d4f2fccd8 100644 --- a/usr/src/lib/libzfs/common/libzfs_sendrecv.c +++ b/usr/src/lib/libzfs/common/libzfs_sendrecv.c @@ -266,6 +266,15 @@ cksummer(void *arg) ofp = fdopen(dda->inputfd, "r"); while (ssread(drr, sizeof (*drr), ofp) != 0) { + /* + * kernel filled in checksum, we are going to write same + * record, but need to regenerate checksum. + */ + if (drr->drr_type != DRR_BEGIN) { + bzero(&drr->drr_u.drr_checksum.drr_checksum, + sizeof (drr->drr_u.drr_checksum.drr_checksum)); + } + switch (drr->drr_type) { case DRR_BEGIN: { -- cgit v1.2.3