mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-13 19:50:25 +03:00
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:
parent
5e8ff25644
commit
0391690583
@ -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
68
include/sys/dmu_recv.h
Normal 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 */
|
@ -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 */
|
||||||
|
@ -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" {
|
||||||
|
@ -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 \
|
||||||
|
@ -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
|
||||||
|
@ -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
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
@ -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>
|
||||||
|
@ -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>
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user