]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - include/os/freebsd/zfs/sys/zfs_znode_impl.h
Vendor import of openzfs master @ 184df27eef0abdc7ab2105b21257f753834b936b
[FreeBSD/FreeBSD.git] / include / os / freebsd / zfs / sys / zfs_znode_impl.h
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
23  * Copyright (c) 2012, 2015 by Delphix. All rights reserved.
24  * Copyright (c) 2014 Integros [integros.com]
25  * Copyright 2016 Nexenta Systems, Inc. All rights reserved.
26  */
27
28 #ifndef _FREEBSD_ZFS_SYS_ZNODE_IMPL_H
29 #define _FREEBSD_ZFS_SYS_ZNODE_IMPL_H
30
31 #include <sys/list.h>
32 #include <sys/dmu.h>
33 #include <sys/sa.h>
34 #include <sys/zfs_vfsops.h>
35 #include <sys/rrwlock.h>
36 #include <sys/zfs_sa.h>
37 #include <sys/zfs_stat.h>
38 #include <sys/zfs_rlock.h>
39 #include <sys/zfs_acl.h>
40 #include <sys/zil.h>
41 #include <sys/zfs_project.h>
42
43 #ifdef  __cplusplus
44 extern "C" {
45 #endif
46
47 /*
48  * Directory entry locks control access to directory entries.
49  * They are used to protect creates, deletes, and renames.
50  * Each directory znode has a mutex and a list of locked names.
51  */
52 #define ZNODE_OS_FIELDS                 \
53         struct zfsvfs   *z_zfsvfs;      \
54         vnode_t         *z_vnode;       \
55         uint64_t                z_uid;          \
56         uint64_t                z_gid;          \
57         uint64_t                z_gen;          \
58         uint64_t                z_atime[2];     \
59         uint64_t                z_links;
60
61 #define ZFS_LINK_MAX    UINT64_MAX
62
63 /*
64  * ZFS minor numbers can refer to either a control device instance or
65  * a zvol. Depending on the value of zss_type, zss_data points to either
66  * a zvol_state_t or a zfs_onexit_t.
67  */
68 enum zfs_soft_state_type {
69         ZSST_ZVOL,
70         ZSST_CTLDEV
71 };
72
73 typedef struct zfs_soft_state {
74         enum zfs_soft_state_type zss_type;
75         void *zss_data;
76 } zfs_soft_state_t;
77
78 extern minor_t zfsdev_minor_alloc(void);
79
80 /*
81  * Range locking rules
82  * --------------------
83  * 1. When truncating a file (zfs_create, zfs_setattr, zfs_space) the whole
84  *    file range needs to be locked as RL_WRITER. Only then can the pages be
85  *    freed etc and zp_size reset. zp_size must be set within range lock.
86  * 2. For writes and punching holes (zfs_write & zfs_space) just the range
87  *    being written or freed needs to be locked as RL_WRITER.
88  *    Multiple writes at the end of the file must coordinate zp_size updates
89  *    to ensure data isn't lost. A compare and swap loop is currently used
90  *    to ensure the file size is at least the offset last written.
91  * 3. For reads (zfs_read, zfs_get_data & zfs_putapage) just the range being
92  *    read needs to be locked as RL_READER. A check against zp_size can then
93  *    be made for reading beyond end of file.
94  */
95
96 /*
97  * Convert between znode pointers and vnode pointers
98  */
99 #define ZTOV(ZP)        ((ZP)->z_vnode)
100 #define ZTOI(ZP)        ((ZP)->z_vnode)
101 #define VTOZ(VP)        ((struct znode *)(VP)->v_data)
102 #define VTOZ_SMR(VP)    ((znode_t *)vn_load_v_data_smr(VP))
103 #define ITOZ(VP)        ((struct znode *)(VP)->v_data)
104 #define zhold(zp)       vhold(ZTOV((zp)))
105 #define zrele(zp)       vrele(ZTOV((zp)))
106
107 #define ZTOZSB(zp) ((zp)->z_zfsvfs)
108 #define ITOZSB(vp) (VTOZ(vp)->z_zfsvfs)
109 #define ZTOTYPE(zp)     (ZTOV(zp)->v_type)
110 #define ZTOGID(zp) ((zp)->z_gid)
111 #define ZTOUID(zp) ((zp)->z_uid)
112 #define ZTONLNK(zp) ((zp)->z_links)
113 #define Z_ISBLK(type) ((type) == VBLK)
114 #define Z_ISCHR(type) ((type) == VCHR)
115 #define Z_ISLNK(type) ((type) == VLNK)
116
117
118 /* Called on entry to each ZFS vnode and vfs operation  */
119 #define ZFS_ENTER(zfsvfs) \
120         { \
121                 rrm_enter_read(&(zfsvfs)->z_teardown_lock, FTAG); \
122                 if ((zfsvfs)->z_unmounted) { \
123                         ZFS_EXIT(zfsvfs); \
124                         return (EIO); \
125                 } \
126         }
127
128 /* Must be called before exiting the vop */
129 #define ZFS_EXIT(zfsvfs) rrm_exit(&(zfsvfs)->z_teardown_lock, FTAG)
130
131 /* Verifies the znode is valid */
132 #define ZFS_VERIFY_ZP(zp) \
133         if ((zp)->z_sa_hdl == NULL) { \
134                 ZFS_EXIT((zp)->z_zfsvfs); \
135                 return (EIO); \
136         } \
137
138 /*
139  * Macros for dealing with dmu_buf_hold
140  */
141 #define ZFS_OBJ_HASH(obj_num)   ((obj_num) & (ZFS_OBJ_MTX_SZ - 1))
142 #define ZFS_OBJ_MUTEX(zfsvfs, obj_num)  \
143         (&(zfsvfs)->z_hold_mtx[ZFS_OBJ_HASH(obj_num)])
144 #define ZFS_OBJ_HOLD_ENTER(zfsvfs, obj_num) \
145         mutex_enter(ZFS_OBJ_MUTEX((zfsvfs), (obj_num)))
146 #define ZFS_OBJ_HOLD_TRYENTER(zfsvfs, obj_num) \
147         mutex_tryenter(ZFS_OBJ_MUTEX((zfsvfs), (obj_num)))
148 #define ZFS_OBJ_HOLD_EXIT(zfsvfs, obj_num) \
149         mutex_exit(ZFS_OBJ_MUTEX((zfsvfs), (obj_num)))
150
151 /* Encode ZFS stored time values from a struct timespec */
152 #define ZFS_TIME_ENCODE(tp, stmp)               \
153 {                                               \
154         (stmp)[0] = (uint64_t)(tp)->tv_sec;     \
155         (stmp)[1] = (uint64_t)(tp)->tv_nsec;    \
156 }
157
158 /* Decode ZFS stored time values to a struct timespec */
159 #define ZFS_TIME_DECODE(tp, stmp)               \
160 {                                               \
161         (tp)->tv_sec = (time_t)(stmp)[0];               \
162         (tp)->tv_nsec = (long)(stmp)[1];                \
163 }
164 #define ZFS_ACCESSTIME_STAMP(zfsvfs, zp) \
165         if ((zfsvfs)->z_atime && !((zfsvfs)->z_vfs->vfs_flag & VFS_RDONLY)) \
166                 zfs_tstamp_update_setup_ext(zp, ACCESSED, NULL, NULL, B_FALSE);
167
168 extern void     zfs_tstamp_update_setup_ext(struct znode *,
169     uint_t, uint64_t [2], uint64_t [2], boolean_t have_tx);
170 extern void zfs_znode_free(struct znode *);
171
172 extern zil_get_data_t zfs_get_data;
173 extern zil_replay_func_t *zfs_replay_vector[TX_MAX_TYPE];
174 extern int zfsfstype;
175
176 extern int zfs_znode_parent_and_name(struct znode *zp, struct znode **dzpp,
177     char *buf);
178
179 #ifdef  __cplusplus
180 }
181 #endif
182
183 #endif  /* _FREEBSD_SYS_FS_ZFS_ZNODE_H */