Refactor dmu_recv into its own file

This change moves the bottom half of dmu_send.c (where the receive
logic is kept) into a new file, dmu_recv.c, and does similarly
for receive-related changes in header files.

Reviewed by: Matthew Ahrens <mahrens@delphix.com>
Reviewed by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Paul Dagnelie <pcd@delphix.com>
Closes #7982
This commit is contained in:
Paul Dagnelie 2018-10-09 14:05:13 -07:00 committed by Brian Behlendorf
parent 5e8ff25644
commit 0391690583
12 changed files with 2969 additions and 2863 deletions

View File

@ -20,6 +20,7 @@ COMMON_H = \
$(top_srcdir)/include/sys/dmu.h \ $(top_srcdir)/include/sys/dmu.h \
$(top_srcdir)/include/sys/dmu_impl.h \ $(top_srcdir)/include/sys/dmu_impl.h \
$(top_srcdir)/include/sys/dmu_objset.h \ $(top_srcdir)/include/sys/dmu_objset.h \
$(top_srcdir)/include/sys/dmu_recv.h \
$(top_srcdir)/include/sys/dmu_send.h \ $(top_srcdir)/include/sys/dmu_send.h \
$(top_srcdir)/include/sys/dmu_traverse.h \ $(top_srcdir)/include/sys/dmu_traverse.h \
$(top_srcdir)/include/sys/dmu_tx.h \ $(top_srcdir)/include/sys/dmu_tx.h \

68
include/sys/dmu_recv.h Normal file
View File

@ -0,0 +1,68 @@
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2018 by Delphix. All rights reserved.
* Copyright 2011 Nexenta Systems, Inc. All rights reserved.
* Copyright (c) 2013, Joyent, Inc. All rights reserved.
*/
#ifndef _DMU_RECV_H
#define _DMU_RECV_H
#include <sys/inttypes.h>
#include <sys/dsl_bookmark.h>
#include <sys/dsl_dataset.h>
#include <sys/spa.h>
extern const char *recv_clone_name;
typedef struct dmu_recv_cookie {
struct dsl_dataset *drc_ds;
struct dmu_replay_record *drc_drr_begin;
struct drr_begin *drc_drrb;
const char *drc_tofs;
const char *drc_tosnap;
boolean_t drc_newfs;
boolean_t drc_byteswap;
boolean_t drc_force;
boolean_t drc_resumable;
boolean_t drc_raw;
boolean_t drc_clone;
struct avl_tree *drc_guid_to_ds_map;
nvlist_t *drc_keynvl;
zio_cksum_t drc_cksum;
uint64_t drc_newsnapobj;
void *drc_owner;
cred_t *drc_cred;
} dmu_recv_cookie_t;
int dmu_recv_begin(char *tofs, char *tosnap,
struct dmu_replay_record *drr_begin, boolean_t force, boolean_t resumable,
nvlist_t *localprops, nvlist_t *hidden_args, char *origin,
dmu_recv_cookie_t *drc);
int dmu_recv_stream(dmu_recv_cookie_t *drc, struct vnode *vp, offset_t *voffp,
int cleanup_fd, uint64_t *action_handlep);
int dmu_recv_end(dmu_recv_cookie_t *drc, void *owner);
boolean_t dmu_objset_is_receiving(objset_t *os);
#endif /* _DMU_RECV_H */

View File

@ -39,8 +39,6 @@ struct drr_begin;
struct avl_tree; struct avl_tree;
struct dmu_replay_record; struct dmu_replay_record;
extern const char *recv_clone_name;
int dmu_send(const char *tosnap, const char *fromsnap, boolean_t embedok, int dmu_send(const char *tosnap, const char *fromsnap, boolean_t embedok,
boolean_t large_block_ok, boolean_t compressok, boolean_t rawok, int outfd, boolean_t large_block_ok, boolean_t compressok, boolean_t rawok, int outfd,
uint64_t resumeobj, uint64_t resumeoff, struct vnode *vp, offset_t *off); uint64_t resumeobj, uint64_t resumeoff, struct vnode *vp, offset_t *off);
@ -52,33 +50,4 @@ int dmu_send_obj(const char *pool, uint64_t tosnap, uint64_t fromsnap,
boolean_t embedok, boolean_t large_block_ok, boolean_t compressok, boolean_t embedok, boolean_t large_block_ok, boolean_t compressok,
boolean_t rawok, int outfd, struct vnode *vp, offset_t *off); boolean_t rawok, int outfd, struct vnode *vp, offset_t *off);
typedef struct dmu_recv_cookie {
struct dsl_dataset *drc_ds;
struct dmu_replay_record *drc_drr_begin;
struct drr_begin *drc_drrb;
const char *drc_tofs;
const char *drc_tosnap;
boolean_t drc_newfs;
boolean_t drc_byteswap;
boolean_t drc_force;
boolean_t drc_resumable;
boolean_t drc_raw;
boolean_t drc_clone;
struct avl_tree *drc_guid_to_ds_map;
nvlist_t *drc_keynvl;
zio_cksum_t drc_cksum;
uint64_t drc_newsnapobj;
void *drc_owner;
cred_t *drc_cred;
} dmu_recv_cookie_t;
int dmu_recv_begin(char *tofs, char *tosnap,
struct dmu_replay_record *drr_begin, boolean_t force, boolean_t resumable,
nvlist_t *localprops, nvlist_t *hidden_args, char *origin,
dmu_recv_cookie_t *drc);
int dmu_recv_stream(dmu_recv_cookie_t *drc, struct vnode *vp, offset_t *voffp,
int cleanup_fd, uint64_t *action_handlep);
int dmu_recv_end(dmu_recv_cookie_t *drc, void *owner);
boolean_t dmu_objset_is_receiving(objset_t *os);
#endif /* _DMU_SEND_H */ #endif /* _DMU_SEND_H */

View File

@ -20,6 +20,7 @@
#define _SYS_DSL_BOOKMARK_H #define _SYS_DSL_BOOKMARK_H
#include <sys/zfs_context.h> #include <sys/zfs_context.h>
#include <sys/dsl_dataset.h>
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {

View File

@ -58,6 +58,7 @@ KERNEL_C = \
dmu_diff.c \ dmu_diff.c \
dmu_object.c \ dmu_object.c \
dmu_objset.c \ dmu_objset.c \
dmu_recv.c \
dmu_send.c \ dmu_send.c \
dmu_traverse.c \ dmu_traverse.c \
dmu_tx.c \ dmu_tx.c \

View File

@ -34,6 +34,7 @@ $(MODULE)-objs += dmu.o
$(MODULE)-objs += dmu_diff.o $(MODULE)-objs += dmu_diff.o
$(MODULE)-objs += dmu_object.o $(MODULE)-objs += dmu_object.o
$(MODULE)-objs += dmu_objset.o $(MODULE)-objs += dmu_objset.o
$(MODULE)-objs += dmu_recv.o
$(MODULE)-objs += dmu_send.o $(MODULE)-objs += dmu_send.o
$(MODULE)-objs += dmu_traverse.o $(MODULE)-objs += dmu_traverse.o
$(MODULE)-objs += dmu_tx.o $(MODULE)-objs += dmu_tx.o

View File

@ -58,7 +58,7 @@
#include <sys/zfeature.h> #include <sys/zfeature.h>
#include <sys/policy.h> #include <sys/policy.h>
#include <sys/spa_impl.h> #include <sys/spa_impl.h>
#include <sys/dmu_send.h> #include <sys/dmu_recv.h>
#include <sys/zfs_project.h> #include <sys/zfs_project.h>
#include "zfs_namecheck.h" #include "zfs_namecheck.h"

2893
module/zfs/dmu_recv.c Normal file

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -31,7 +31,7 @@
#include <sys/dmu.h> #include <sys/dmu.h>
#include <sys/dmu_tx.h> #include <sys/dmu_tx.h>
#include <sys/dmu_objset.h> #include <sys/dmu_objset.h>
#include <sys/dmu_send.h> #include <sys/dmu_recv.h>
#include <sys/dsl_dataset.h> #include <sys/dsl_dataset.h>
#include <sys/spa.h> #include <sys/spa.h>
#include <sys/range_tree.h> #include <sys/range_tree.h>

View File

@ -57,7 +57,7 @@
#include <sys/dsl_userhold.h> #include <sys/dsl_userhold.h>
#include <sys/dsl_bookmark.h> #include <sys/dsl_bookmark.h>
#include <sys/policy.h> #include <sys/policy.h>
#include <sys/dmu_send.h> #include <sys/dmu_recv.h>
#include <sys/zio_compress.h> #include <sys/zio_compress.h>
#include <zfs_fletcher.h> #include <zfs_fletcher.h>
#include <sys/zio_checksum.h> #include <sys/zio_checksum.h>

View File

@ -192,6 +192,7 @@
#include <sys/fm/util.h> #include <sys/fm/util.h>
#include <sys/dsl_crypt.h> #include <sys/dsl_crypt.h>
#include <sys/dmu_recv.h>
#include <sys/dmu_send.h> #include <sys/dmu_send.h>
#include <sys/dsl_destroy.h> #include <sys/dsl_destroy.h>
#include <sys/dsl_bookmark.h> #include <sys/dsl_bookmark.h>