mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-10 02:00:34 +03:00
67a1b03791
Block Cloning allows to manually clone a file (or a subset of its blocks) into another (or the same) file by just creating additional references to the data blocks without copying the data itself. Those references are kept in the Block Reference Tables (BRTs). The whole design of block cloning is documented in module/zfs/brt.c. Reviewed-by: Alexander Motin <mav@FreeBSD.org> Reviewed-by: Christian Schwarz <christian.schwarz@nutanix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Rich Ercolani <rincebrain@gmail.com> Signed-off-by: Pawel Jakub Dawidek <pawel@dawidek.net> Closes #13392
60 lines
2.2 KiB
C
60 lines
2.2 KiB
C
/*
|
|
* 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 https://opensource.org/licenses/CDDL-1.0.
|
|
* 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) 2010, Oracle and/or its affiliates. All rights reserved.
|
|
*/
|
|
|
|
#ifndef _SYS_FS_ZFS_VNOPS_H
|
|
#define _SYS_FS_ZFS_VNOPS_H
|
|
#include <sys/zfs_vnops_os.h>
|
|
|
|
extern int zfs_fsync(znode_t *, int, cred_t *);
|
|
extern int zfs_read(znode_t *, zfs_uio_t *, int, cred_t *);
|
|
extern int zfs_write(znode_t *, zfs_uio_t *, int, cred_t *);
|
|
extern int zfs_holey(znode_t *, ulong_t, loff_t *);
|
|
extern int zfs_access(znode_t *, int, int, cred_t *);
|
|
extern int zfs_clone_range(znode_t *, uint64_t *, znode_t *, uint64_t *,
|
|
uint64_t *, cred_t *);
|
|
extern int zfs_clone_range_replay(znode_t *, uint64_t, uint64_t, uint64_t,
|
|
const blkptr_t *, size_t);
|
|
|
|
extern int zfs_getsecattr(znode_t *, vsecattr_t *, int, cred_t *);
|
|
extern int zfs_setsecattr(znode_t *, vsecattr_t *, int, cred_t *);
|
|
|
|
extern int mappedread(znode_t *, int, zfs_uio_t *);
|
|
extern int mappedread_sf(znode_t *, int, zfs_uio_t *);
|
|
extern void update_pages(znode_t *, int64_t, int, objset_t *);
|
|
|
|
/*
|
|
* Platform code that asynchronously drops zp's inode / vnode_t.
|
|
*
|
|
* Asynchronous dropping ensures that the caller will never drop the
|
|
* last reference on an inode / vnode_t in the current context.
|
|
* Doing so while holding open a tx could result in a deadlock if
|
|
* the platform calls into filesystem again in the implementation
|
|
* of inode / vnode_t dropping (e.g. call from iput_final()).
|
|
*/
|
|
extern void zfs_zrele_async(znode_t *zp);
|
|
|
|
extern zil_get_data_t zfs_get_data;
|
|
|
|
#endif
|