usr/src/uts/common/fs/zfs/sys/dsl_dataset.h
author Lin Ling <Lin.Ling@Sun.COM>
Mon, 03 May 2010 14:54:08 -0700
changeset 12296 7cf402a7f374
parent 11209 462283cb4096
child 12450 c77e20e4e046
permissions -rw-r--r--
6675946 'zpool status' should show the progress of resilvering for individual disk. 6683750 scrub -s have to wait until resilver completed? 6841252 Resilvering not restartable - causing an excess reboot delay 6855073 spa scrub stats (eg %done) are reset on reboot 6891824 7410 NAS head "continually resilvering" following HDD replacement 6899970 scrub/resilver percent complete reporting in zpool status can be overly optimistic 6940889 add interval (count) args to zpool list 6944623 dbuf_read_done() locking performance improvement 6946760 mutex problem in bplist_enqueue() 6391915 RFE: provide interval arg to zpool status to monitor resilvering 6946512 want zfs_send() to pass back debug info 6943992 'zpool scrub' should not restart the existing scrub silently 6878281 zpool should store the time of last scrub/resilver and other zpool status info in pool properties. 6935158 Assertion failed: used <= spa_get_dspace(dd->dd_pool->dp_spa) 6944388 dsl_dataset_snapshot_reserve_space() causes dp_write_limit=max
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     1
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     2
 * CDDL HEADER START
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     3
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     4
 * The contents of this file are subject to the terms of the
1544
938876158511 PSARC 2006/077 zpool clear
eschrock
parents: 789
diff changeset
     5
 * Common Development and Distribution License (the "License").
938876158511 PSARC 2006/077 zpool clear
eschrock
parents: 789
diff changeset
     6
 * You may not use this file except in compliance with the License.
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     7
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     8
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     9
 * or http://www.opensolaris.org/os/licensing.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    10
 * See the License for the specific language governing permissions
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    11
 * and limitations under the License.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    12
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    13
 * When distributing Covered Code, include this CDDL HEADER in each
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    14
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    15
 * If applicable, add the following below this CDDL HEADER, with the
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    16
 * fields enclosed by brackets "[]" replaced with your own identifying
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    17
 * information: Portions Copyright [yyyy] [name of copyright owner]
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    18
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    19
 * CDDL HEADER END
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    20
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    21
/*
12296
7cf402a7f374 6675946 'zpool status' should show the progress of resilvering for individual disk.
Lin Ling <Lin.Ling@Sun.COM>
parents: 11209
diff changeset
    22
 * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    23
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    24
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    25
#ifndef	_SYS_DSL_DATASET_H
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    26
#define	_SYS_DSL_DATASET_H
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    27
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    28
#include <sys/dmu.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    29
#include <sys/spa.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    30
#include <sys/txg.h>
3547
e396e0a440b1 6512391 DMU should leverage ZIO dependencies to achieve greater parallelism
maybee
parents: 3517
diff changeset
    31
#include <sys/zio.h>
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    32
#include <sys/bplist.h>
2199
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
    33
#include <sys/dsl_synctask.h>
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    34
#include <sys/zfs_context.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    35
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    36
#ifdef	__cplusplus
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    37
extern "C" {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    38
#endif
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    39
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    40
struct dsl_dataset;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    41
struct dsl_dir;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    42
struct dsl_pool;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    43
2082
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    44
#define	DS_FLAG_INCONSISTENT	(1ULL<<0)
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
    45
#define	DS_IS_INCONSISTENT(ds)	\
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
    46
	((ds)->ds_phys->ds_flags & DS_FLAG_INCONSISTENT)
2082
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    47
/*
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    48
 * NB: nopromote can not yet be set, but we want support for it in this
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    49
 * on-disk version, so that we don't need to upgrade for it later.  It
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    50
 * will be needed when we implement 'zfs split' (where the split off
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    51
 * clone should not be promoted).
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    52
 */
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    53
#define	DS_FLAG_NOPROMOTE	(1ULL<<1)
76b439ec3ac1 PSARC 2006/223 ZFS Hot Spares
eschrock
parents: 1731
diff changeset
    54
5378
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    55
/*
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    56
 * DS_FLAG_UNIQUE_ACCURATE is set if ds_unique_bytes has been correctly
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    57
 * calculated for head datasets (starting with SPA_VERSION_UNIQUE_ACCURATE,
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    58
 * refquota/refreservations).
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    59
 */
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    60
#define	DS_FLAG_UNIQUE_ACCURATE	(1ULL<<2)
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
    61
6492
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    62
/*
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    63
 * DS_FLAG_DEFER_DESTROY is set after 'zfs destroy -d' has been called
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    64
 * on a dataset. This allows the dataset to be destroyed using 'zfs release'.
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    65
 */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    66
#define	DS_FLAG_DEFER_DESTROY	(1ULL<<3)
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    67
#define	DS_IS_DEFER_DESTROY(ds)	\
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    68
	((ds)->ds_phys->ds_flags & DS_FLAG_DEFER_DESTROY)
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    69
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
    70
/*
6492
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    71
 * DS_FLAG_CI_DATASET is set if the dataset contains a file system whose
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    72
 * name lookups should be performed case-insensitively.
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    73
 */
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    74
#define	DS_FLAG_CI_DATASET	(1ULL<<16)
903545192033 6654808 FIGNORECASE lookups in a zfs xattr dir don't provide 'realname' data
timh
parents: 5831
diff changeset
    75
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    76
typedef struct dsl_dataset_phys {
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    77
	uint64_t ds_dir_obj;		/* DMU_OT_DSL_DIR */
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    78
	uint64_t ds_prev_snap_obj;	/* DMU_OT_DSL_DATASET */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    79
	uint64_t ds_prev_snap_txg;
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    80
	uint64_t ds_next_snap_obj;	/* DMU_OT_DSL_DATASET */
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    81
	uint64_t ds_snapnames_zapobj;	/* DMU_OT_DSL_DS_SNAP_MAP 0 for snaps */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    82
	uint64_t ds_num_children;	/* clone/snap children; ==0 for head */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    83
	uint64_t ds_creation_time;	/* seconds since 1970 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    84
	uint64_t ds_creation_txg;
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    85
	uint64_t ds_deadlist_obj;	/* DMU_OT_BPLIST */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    86
	uint64_t ds_used_bytes;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    87
	uint64_t ds_compressed_bytes;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    88
	uint64_t ds_uncompressed_bytes;
3517
79d66aa80b8b 6363303 numerous source files misspell "relevant"
mp204432
parents: 2885
diff changeset
    89
	uint64_t ds_unique_bytes;	/* only relevant to snapshots */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    90
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    91
	 * The ds_fsid_guid is a 56-bit ID that can change to avoid
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    92
	 * collisions.  The ds_guid is a 64-bit ID that will never
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    93
	 * change, so there is a small probability that it will collide.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    94
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    95
	uint64_t ds_fsid_guid;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    96
	uint64_t ds_guid;
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
    97
	uint64_t ds_flags;		/* DS_FLAG_* */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    98
	blkptr_t ds_bp;
7265
cc18862247da PSARC/2008/483 ZFS clone -o
ahrens
parents: 7046
diff changeset
    99
	uint64_t ds_next_clones_obj;	/* DMU_OT_DSL_CLONES */
cc18862247da PSARC/2008/483 ZFS clone -o
ahrens
parents: 7046
diff changeset
   100
	uint64_t ds_props_obj;		/* DMU_OT_DSL_PROPS for snaps */
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   101
	uint64_t ds_userrefs_obj;	/* DMU_OT_USERREFS */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   102
	uint64_t ds_pad[5]; /* pad out to 320 bytes for good measure */
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   103
} dsl_dataset_phys_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   104
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   105
typedef struct dsl_dataset {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   106
	/* Immutable: */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   107
	struct dsl_dir *ds_dir;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   108
	dsl_dataset_phys_t *ds_phys;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   109
	dmu_buf_t *ds_dbuf;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   110
	uint64_t ds_object;
4787
602d3f97842c 6393351 unique_* could be improved
ahrens
parents: 4007
diff changeset
   111
	uint64_t ds_fsid_guid;
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   112
7390
6d408f0a5fbd PSARC/2008/518 ZFS space accounting enhancements
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 7265
diff changeset
   113
	/* only used in syncing context, only valid for non-snapshots: */
6d408f0a5fbd PSARC/2008/518 ZFS space accounting enhancements
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 7265
diff changeset
   114
	struct dsl_dataset *ds_prev;
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   115
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   116
	/* has internal locking: */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   117
	bplist_t ds_deadlist;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   118
10204
83c3a84aecef 6760420 zfs unmount -f causes recv to fail
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 9653
diff changeset
   119
	/* to protect against multiple concurrent incremental recv */
83c3a84aecef 6760420 zfs unmount -f causes recv to fail
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 9653
diff changeset
   120
	kmutex_t ds_recvlock;
83c3a84aecef 6760420 zfs unmount -f causes recv to fail
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 9653
diff changeset
   121
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   122
	/* protected by lock on pool's dp_dirty_datasets list */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   123
	txg_node_t ds_dirty_link;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   124
	list_node_t ds_synced_link;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   125
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   126
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   127
	 * ds_phys->ds_<accounting> is also protected by ds_lock.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   128
	 * Protected by ds_lock:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   129
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   130
	kmutex_t ds_lock;
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   131
	objset_t *ds_objset;
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   132
	uint64_t ds_userrefs;
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   133
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   134
	/*
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   135
	 * ds_owner is protected by the ds_rwlock and the ds_lock
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   136
	 */
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   137
	krwlock_t ds_rwlock;
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   138
	kcondvar_t ds_exclusive_cv;
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   139
	void *ds_owner;
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   140
2199
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
   141
	/* no locking; only for making guesses */
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
   142
	uint64_t ds_trysnap_txg;
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
   143
4787
602d3f97842c 6393351 unique_* could be improved
ahrens
parents: 4007
diff changeset
   144
	/* for objset_open() */
602d3f97842c 6393351 unique_* could be improved
ahrens
parents: 4007
diff changeset
   145
	kmutex_t ds_opening_lock;
602d3f97842c 6393351 unique_* could be improved
ahrens
parents: 4007
diff changeset
   146
5378
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   147
	uint64_t ds_reserved;	/* cached refreservation */
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   148
	uint64_t ds_quota;	/* cached refquota */
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   149
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   150
	/* Protected by ds_lock; keep at end of struct for better locality */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   151
	char ds_snapname[MAXNAMELEN];
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   152
} dsl_dataset_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   153
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   154
struct dsl_ds_destroyarg {
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   155
	dsl_dataset_t *ds;		/* ds to destroy */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   156
	dsl_dataset_t *rm_origin;	/* also remove our origin? */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   157
	boolean_t is_origin_rm;		/* set if removing origin snap */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   158
	boolean_t defer;		/* destroy -d requested? */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   159
	boolean_t releasing;		/* destroying due to release? */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   160
	boolean_t need_prep;		/* do we need to retry due to EBUSY? */
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   161
};
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   162
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   163
#define	dsl_dataset_is_snapshot(ds)	\
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   164
	((ds)->ds_phys->ds_num_children != 0)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   165
5378
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   166
#define	DS_UNIQUE_IS_ACCURATE(ds)	\
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   167
	(((ds)->ds_phys->ds_flags & DS_FLAG_UNIQUE_ACCURATE) != 0)
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   168
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   169
int dsl_dataset_hold(const char *name, void *tag, dsl_dataset_t **dsp);
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   170
int dsl_dataset_hold_obj(struct dsl_pool *dp, uint64_t dsobj,
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   171
    void *tag, dsl_dataset_t **);
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   172
int dsl_dataset_own(const char *name, boolean_t inconsistentok,
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   173
    void *tag, dsl_dataset_t **dsp);
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   174
int dsl_dataset_own_obj(struct dsl_pool *dp, uint64_t dsobj,
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   175
    boolean_t inconsistentok, void *tag, dsl_dataset_t **dsp);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   176
void dsl_dataset_name(dsl_dataset_t *ds, char *name);
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   177
void dsl_dataset_rele(dsl_dataset_t *ds, void *tag);
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   178
void dsl_dataset_disown(dsl_dataset_t *ds, void *tag);
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
   179
void dsl_dataset_drop_ref(dsl_dataset_t *ds, void *tag);
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   180
boolean_t dsl_dataset_tryown(dsl_dataset_t *ds, boolean_t inconsistentok,
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   181
    void *tag);
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   182
void dsl_dataset_make_exclusive(dsl_dataset_t *ds, void *tag);
6689
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   183
uint64_t dsl_dataset_create_sync(dsl_dir_t *pds, const char *lastname,
47572a2f5e73 6610506 Eliminate or improve retry logic from callers of dmu_objset_open()
maybee
parents: 6492
diff changeset
   184
    dsl_dataset_t *origin, uint64_t flags, cred_t *, dmu_tx_t *);
7046
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
   185
uint64_t dsl_dataset_create_sync_dd(dsl_dir_t *dd, dsl_dataset_t *origin,
361307ae060d 6343667 scrub/resilver has to start over when a snapshot is taken
ahrens
parents: 6992
diff changeset
   186
    uint64_t flags, dmu_tx_t *tx);
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   187
int dsl_dataset_destroy(dsl_dataset_t *ds, void *tag, boolean_t defer);
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   188
int dsl_snapshots_destroy(char *fsname, char *snapname, boolean_t defer);
5367
c40abbe796be PSARC/2007/574 zfs send -R
ahrens
parents: 5326
diff changeset
   189
dsl_checkfunc_t dsl_dataset_destroy_check;
c40abbe796be PSARC/2007/574 zfs send -R
ahrens
parents: 5326
diff changeset
   190
dsl_syncfunc_t dsl_dataset_destroy_sync;
2199
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
   191
dsl_checkfunc_t dsl_dataset_snapshot_check;
712a788c2dfd PSARC 2006/388 snapshot -r
ahrens
parents: 2082
diff changeset
   192
dsl_syncfunc_t dsl_dataset_snapshot_sync;
4007
c6f5c6753018 PSARC 2007/142 zfs rename -r
mmusante
parents: 3912
diff changeset
   193
int dsl_dataset_rename(char *name, const char *newname, boolean_t recursive);
10588
dc03f981ea18 6438937 if 'zfs destroy' fails, it can leave a zvol device link missing
Eric Taylor <Eric.Taylor@Sun.COM>
parents: 10373
diff changeset
   194
int dsl_dataset_promote(const char *name, char *conflsnap);
5367
c40abbe796be PSARC/2007/574 zfs send -R
ahrens
parents: 5326
diff changeset
   195
int dsl_dataset_clone_swap(dsl_dataset_t *clone, dsl_dataset_t *origin_head,
c40abbe796be PSARC/2007/574 zfs send -R
ahrens
parents: 5326
diff changeset
   196
    boolean_t force);
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   197
int dsl_dataset_user_hold(char *dsname, char *snapname, char *htag,
10342
108f0058f837 6833815 scheduled snapshots deleted per snapshot policy can lead to replication failures
Chris Kirby <chris.kirby@sun.com>
parents: 10298
diff changeset
   198
    boolean_t recursive, boolean_t temphold);
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   199
int dsl_dataset_user_release(char *dsname, char *snapname, char *htag,
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   200
    boolean_t recursive);
10342
108f0058f837 6833815 scheduled snapshots deleted per snapshot policy can lead to replication failures
Chris Kirby <chris.kirby@sun.com>
parents: 10298
diff changeset
   201
int dsl_dataset_user_release_tmp(struct dsl_pool *dp, uint64_t dsobj,
108f0058f837 6833815 scheduled snapshots deleted per snapshot policy can lead to replication failures
Chris Kirby <chris.kirby@sun.com>
parents: 10298
diff changeset
   202
    char *htag);
10242
c40d075fbca6 PSARC/2009/297 zfs snapshot holds
Chris Kirby <chris.kirby@sun.com>
parents: 10204
diff changeset
   203
int dsl_dataset_get_holds(const char *dsname, nvlist_t **nvp);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   204
3547
e396e0a440b1 6512391 DMU should leverage ZIO dependencies to achieve greater parallelism
maybee
parents: 3517
diff changeset
   205
blkptr_t *dsl_dataset_get_blkptr(dsl_dataset_t *ds);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   206
void dsl_dataset_set_blkptr(dsl_dataset_t *ds, blkptr_t *bp, dmu_tx_t *tx);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   207
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   208
spa_t *dsl_dataset_get_spa(dsl_dataset_t *ds);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   209
5326
6752aa2bd5bc 6425096 want online 'zfs recv' (read only and read/write)
ek110237
parents: 4787
diff changeset
   210
boolean_t dsl_dataset_modified_since_lastsnap(dsl_dataset_t *ds);
6752aa2bd5bc 6425096 want online 'zfs recv' (read only and read/write)
ek110237
parents: 4787
diff changeset
   211
3547
e396e0a440b1 6512391 DMU should leverage ZIO dependencies to achieve greater parallelism
maybee
parents: 3517
diff changeset
   212
void dsl_dataset_sync(dsl_dataset_t *os, zio_t *zio, dmu_tx_t *tx);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   213
10922
e2081f502306 PSARC 2009/571 ZFS Deduplication Properties
Jeff Bonwick <Jeff.Bonwick@Sun.COM>
parents: 10588
diff changeset
   214
void dsl_dataset_block_born(dsl_dataset_t *ds, const blkptr_t *bp,
3547
e396e0a440b1 6512391 DMU should leverage ZIO dependencies to achieve greater parallelism
maybee
parents: 3517
diff changeset
   215
    dmu_tx_t *tx);
10922
e2081f502306 PSARC 2009/571 ZFS Deduplication Properties
Jeff Bonwick <Jeff.Bonwick@Sun.COM>
parents: 10588
diff changeset
   216
int dsl_dataset_block_kill(dsl_dataset_t *ds, const blkptr_t *bp,
e2081f502306 PSARC 2009/571 ZFS Deduplication Properties
Jeff Bonwick <Jeff.Bonwick@Sun.COM>
parents: 10588
diff changeset
   217
    dmu_tx_t *tx, boolean_t async);
9653
a70048a304d1 6664765 Unable to remove files when using fat-zap and quota exceeded on ZFS filesystem
Sanjeev Bagewadi <Sanjeev.Bagewadi@Sun.COM>
parents: 7525
diff changeset
   218
boolean_t dsl_dataset_block_freeable(dsl_dataset_t *ds, uint64_t blk_birth);
1544
938876158511 PSARC 2006/077 zpool clear
eschrock
parents: 789
diff changeset
   219
uint64_t dsl_dataset_prev_snap_txg(dsl_dataset_t *ds);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   220
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   221
void dsl_dataset_dirty(dsl_dataset_t *ds, dmu_tx_t *tx);
2885
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   222
void dsl_dataset_stats(dsl_dataset_t *os, nvlist_t *nv);
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   223
void dsl_dataset_fast_stat(dsl_dataset_t *ds, dmu_objset_stats_t *stat);
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   224
void dsl_dataset_space(dsl_dataset_t *ds,
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   225
    uint64_t *refdbytesp, uint64_t *availbytesp,
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   226
    uint64_t *usedobjsp, uint64_t *availobjsp);
c0259887ebbc 6460059 zfs destroy <snapshot> leaves behind kruft
ahrens
parents: 2199
diff changeset
   227
uint64_t dsl_dataset_fsid_guid(dsl_dataset_t *ds);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   228
3912
f6891a60bd72 PSARC 2007/083 ZFS bootable datasets
lling
parents: 3547
diff changeset
   229
int dsl_dsobj_to_dsname(char *pname, uint64_t obj, char *buf);
f6891a60bd72 PSARC 2007/083 ZFS bootable datasets
lling
parents: 3547
diff changeset
   230
5378
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   231
int dsl_dataset_check_quota(dsl_dataset_t *ds, boolean_t check_quota,
5831
48655d6b290b 6630761 In sub-filesystem, available space is less than refreservation space
ck153898
parents: 5378
diff changeset
   232
    uint64_t asize, uint64_t inflight, uint64_t *used,
48655d6b290b 6630761 In sub-filesystem, available space is less than refreservation space
ck153898
parents: 5378
diff changeset
   233
    uint64_t *ref_rsrv);
11022
63ab26072e41 PSARC 2009/510 ZFS received properties
Tom Erickson <Tom.Erickson@Sun.COM>
parents: 10922
diff changeset
   234
int dsl_dataset_set_quota(const char *dsname, zprop_source_t source,
63ab26072e41 PSARC 2009/510 ZFS received properties
Tom Erickson <Tom.Erickson@Sun.COM>
parents: 10922
diff changeset
   235
    uint64_t quota);
12296
7cf402a7f374 6675946 'zpool status' should show the progress of resilvering for individual disk.
Lin Ling <Lin.Ling@Sun.COM>
parents: 11209
diff changeset
   236
dsl_syncfunc_t dsl_dataset_set_quota_sync;
11022
63ab26072e41 PSARC 2009/510 ZFS received properties
Tom Erickson <Tom.Erickson@Sun.COM>
parents: 10922
diff changeset
   237
int dsl_dataset_set_reservation(const char *dsname, zprop_source_t source,
63ab26072e41 PSARC 2009/510 ZFS received properties
Tom Erickson <Tom.Erickson@Sun.COM>
parents: 10922
diff changeset
   238
    uint64_t reservation);
5378
111aa1baa84a PSARC 2007/555 zfs fs-only quotas and reservations
ck153898
parents: 5367
diff changeset
   239
11209
462283cb4096 6905188 panic: kernel heap corruption when doing "zfs rename -r"
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 11022
diff changeset
   240
int dsl_destroy_inconsistent(const char *dsname, void *arg);
10298
a0d52501437c 6860996 %temporary clones are not automatically destroyed on error
Matthew Ahrens <Matthew.Ahrens@Sun.COM>
parents: 10272
diff changeset
   241
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   242
#ifdef ZFS_DEBUG
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   243
#define	dprintf_ds(ds, fmt, ...) do { \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   244
	if (zfs_flags & ZFS_DEBUG_DPRINTF) { \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   245
	char *__ds_name = kmem_alloc(MAXNAMELEN, KM_SLEEP); \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   246
	dsl_dataset_name(ds, __ds_name); \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   247
	dprintf("ds=%s " fmt, __ds_name, __VA_ARGS__); \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   248
	kmem_free(__ds_name, MAXNAMELEN); \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   249
	} \
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   250
_NOTE(CONSTCOND) } while (0)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   251
#else
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   252
#define	dprintf_ds(dd, fmt, ...)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   253
#endif
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   254
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   255
#ifdef	__cplusplus
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   256
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   257
#endif
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   258
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   259
#endif /* _SYS_DSL_DATASET_H */