zfs_prop.c revision 1.1.1.3 1 1.1 haad /*
2 1.1 haad * CDDL HEADER START
3 1.1 haad *
4 1.1 haad * The contents of this file are subject to the terms of the
5 1.1 haad * Common Development and Distribution License (the "License").
6 1.1 haad * You may not use this file except in compliance with the License.
7 1.1 haad *
8 1.1 haad * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 1.1 haad * or http://www.opensolaris.org/os/licensing.
10 1.1 haad * See the License for the specific language governing permissions
11 1.1 haad * and limitations under the License.
12 1.1 haad *
13 1.1 haad * When distributing Covered Code, include this CDDL HEADER in each
14 1.1 haad * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 1.1 haad * If applicable, add the following below this CDDL HEADER, with the
16 1.1 haad * fields enclosed by brackets "[]" replaced with your own identifying
17 1.1 haad * information: Portions Copyright [yyyy] [name of copyright owner]
18 1.1 haad *
19 1.1 haad * CDDL HEADER END
20 1.1 haad */
21 1.1 haad /*
22 1.1.1.3 chs * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
23 1.1.1.3 chs * Copyright (c) 2011, 2014 by Delphix. All rights reserved.
24 1.1.1.3 chs * Copyright (c) 2013 by Saso Kiselkov. All rights reserved.
25 1.1.1.3 chs * Copyright (c) 2013, Joyent, Inc. All rights reserved.
26 1.1.1.3 chs * Copyright (c) 2014 Integros [integros.com]
27 1.1 haad */
28 1.1 haad
29 1.1.1.3 chs /* Portions Copyright 2010 Robert Milkowski */
30 1.1.1.3 chs
31 1.1 haad #include <sys/zio.h>
32 1.1 haad #include <sys/spa.h>
33 1.1 haad #include <sys/u8_textprep.h>
34 1.1 haad #include <sys/zfs_acl.h>
35 1.1 haad #include <sys/zfs_ioctl.h>
36 1.1 haad #include <sys/zfs_znode.h>
37 1.1 haad
38 1.1 haad #include "zfs_prop.h"
39 1.1 haad #include "zfs_deleg.h"
40 1.1 haad
41 1.1 haad #if defined(_KERNEL)
42 1.1 haad #include <sys/systm.h>
43 1.1 haad #else
44 1.1 haad #include <stdlib.h>
45 1.1 haad #include <string.h>
46 1.1 haad #include <ctype.h>
47 1.1 haad #endif
48 1.1 haad
49 1.1 haad static zprop_desc_t zfs_prop_table[ZFS_NUM_PROPS];
50 1.1 haad
51 1.1.1.2 haad /* Note this is indexed by zfs_userquota_prop_t, keep the order the same */
52 1.1.1.2 haad const char *zfs_userquota_prop_prefixes[] = {
53 1.1.1.2 haad "userused@",
54 1.1.1.2 haad "userquota@",
55 1.1.1.2 haad "groupused@",
56 1.1.1.2 haad "groupquota@"
57 1.1.1.2 haad };
58 1.1.1.2 haad
59 1.1 haad zprop_desc_t *
60 1.1 haad zfs_prop_get_table(void)
61 1.1 haad {
62 1.1 haad return (zfs_prop_table);
63 1.1 haad }
64 1.1 haad
65 1.1 haad void
66 1.1 haad zfs_prop_init(void)
67 1.1 haad {
68 1.1 haad static zprop_index_t checksum_table[] = {
69 1.1 haad { "on", ZIO_CHECKSUM_ON },
70 1.1 haad { "off", ZIO_CHECKSUM_OFF },
71 1.1 haad { "fletcher2", ZIO_CHECKSUM_FLETCHER_2 },
72 1.1 haad { "fletcher4", ZIO_CHECKSUM_FLETCHER_4 },
73 1.1 haad { "sha256", ZIO_CHECKSUM_SHA256 },
74 1.1.1.3 chs { "noparity", ZIO_CHECKSUM_NOPARITY },
75 1.1.1.3 chs { "sha512", ZIO_CHECKSUM_SHA512 },
76 1.1.1.3 chs { "skein", ZIO_CHECKSUM_SKEIN },
77 1.1.1.3 chs #ifdef illumos
78 1.1.1.3 chs { "edonr", ZIO_CHECKSUM_EDONR },
79 1.1.1.3 chs #endif
80 1.1 haad { NULL }
81 1.1 haad };
82 1.1 haad
83 1.1.1.2 haad static zprop_index_t dedup_table[] = {
84 1.1.1.2 haad { "on", ZIO_CHECKSUM_ON },
85 1.1.1.2 haad { "off", ZIO_CHECKSUM_OFF },
86 1.1.1.2 haad { "verify", ZIO_CHECKSUM_ON | ZIO_CHECKSUM_VERIFY },
87 1.1.1.2 haad { "sha256", ZIO_CHECKSUM_SHA256 },
88 1.1.1.2 haad { "sha256,verify",
89 1.1.1.2 haad ZIO_CHECKSUM_SHA256 | ZIO_CHECKSUM_VERIFY },
90 1.1.1.3 chs { "sha512", ZIO_CHECKSUM_SHA512 },
91 1.1.1.3 chs { "sha512,verify",
92 1.1.1.3 chs ZIO_CHECKSUM_SHA512 | ZIO_CHECKSUM_VERIFY },
93 1.1.1.3 chs { "skein", ZIO_CHECKSUM_SKEIN },
94 1.1.1.3 chs { "skein,verify",
95 1.1.1.3 chs ZIO_CHECKSUM_SKEIN | ZIO_CHECKSUM_VERIFY },
96 1.1.1.3 chs #ifdef illumos
97 1.1.1.3 chs { "edonr,verify",
98 1.1.1.3 chs ZIO_CHECKSUM_EDONR | ZIO_CHECKSUM_VERIFY },
99 1.1.1.3 chs #endif
100 1.1.1.2 haad { NULL }
101 1.1.1.2 haad };
102 1.1.1.2 haad
103 1.1 haad static zprop_index_t compress_table[] = {
104 1.1 haad { "on", ZIO_COMPRESS_ON },
105 1.1 haad { "off", ZIO_COMPRESS_OFF },
106 1.1 haad { "lzjb", ZIO_COMPRESS_LZJB },
107 1.1 haad { "gzip", ZIO_COMPRESS_GZIP_6 }, /* gzip default */
108 1.1 haad { "gzip-1", ZIO_COMPRESS_GZIP_1 },
109 1.1 haad { "gzip-2", ZIO_COMPRESS_GZIP_2 },
110 1.1 haad { "gzip-3", ZIO_COMPRESS_GZIP_3 },
111 1.1 haad { "gzip-4", ZIO_COMPRESS_GZIP_4 },
112 1.1 haad { "gzip-5", ZIO_COMPRESS_GZIP_5 },
113 1.1 haad { "gzip-6", ZIO_COMPRESS_GZIP_6 },
114 1.1 haad { "gzip-7", ZIO_COMPRESS_GZIP_7 },
115 1.1 haad { "gzip-8", ZIO_COMPRESS_GZIP_8 },
116 1.1 haad { "gzip-9", ZIO_COMPRESS_GZIP_9 },
117 1.1.1.2 haad { "zle", ZIO_COMPRESS_ZLE },
118 1.1.1.3 chs { "lz4", ZIO_COMPRESS_LZ4 },
119 1.1 haad { NULL }
120 1.1 haad };
121 1.1 haad
122 1.1 haad static zprop_index_t snapdir_table[] = {
123 1.1 haad { "hidden", ZFS_SNAPDIR_HIDDEN },
124 1.1 haad { "visible", ZFS_SNAPDIR_VISIBLE },
125 1.1 haad { NULL }
126 1.1 haad };
127 1.1 haad
128 1.1 haad static zprop_index_t acl_mode_table[] = {
129 1.1 haad { "discard", ZFS_ACL_DISCARD },
130 1.1 haad { "groupmask", ZFS_ACL_GROUPMASK },
131 1.1 haad { "passthrough", ZFS_ACL_PASSTHROUGH },
132 1.1.1.3 chs { "restricted", ZFS_ACL_RESTRICTED },
133 1.1 haad { NULL }
134 1.1 haad };
135 1.1 haad
136 1.1 haad static zprop_index_t acl_inherit_table[] = {
137 1.1 haad { "discard", ZFS_ACL_DISCARD },
138 1.1 haad { "noallow", ZFS_ACL_NOALLOW },
139 1.1 haad { "restricted", ZFS_ACL_RESTRICTED },
140 1.1 haad { "passthrough", ZFS_ACL_PASSTHROUGH },
141 1.1 haad { "secure", ZFS_ACL_RESTRICTED }, /* bkwrd compatability */
142 1.1 haad { "passthrough-x", ZFS_ACL_PASSTHROUGH_X },
143 1.1 haad { NULL }
144 1.1 haad };
145 1.1 haad
146 1.1 haad static zprop_index_t case_table[] = {
147 1.1 haad { "sensitive", ZFS_CASE_SENSITIVE },
148 1.1 haad { "insensitive", ZFS_CASE_INSENSITIVE },
149 1.1 haad { "mixed", ZFS_CASE_MIXED },
150 1.1 haad { NULL }
151 1.1 haad };
152 1.1 haad
153 1.1 haad static zprop_index_t copies_table[] = {
154 1.1 haad { "1", 1 },
155 1.1 haad { "2", 2 },
156 1.1 haad { "3", 3 },
157 1.1 haad { NULL }
158 1.1 haad };
159 1.1 haad
160 1.1 haad /*
161 1.1 haad * Use the unique flags we have to send to u8_strcmp() and/or
162 1.1 haad * u8_textprep() to represent the various normalization property
163 1.1 haad * values.
164 1.1 haad */
165 1.1 haad static zprop_index_t normalize_table[] = {
166 1.1 haad { "none", 0 },
167 1.1 haad { "formD", U8_TEXTPREP_NFD },
168 1.1 haad { "formKC", U8_TEXTPREP_NFKC },
169 1.1 haad { "formC", U8_TEXTPREP_NFC },
170 1.1 haad { "formKD", U8_TEXTPREP_NFKD },
171 1.1 haad { NULL }
172 1.1 haad };
173 1.1 haad
174 1.1 haad static zprop_index_t version_table[] = {
175 1.1 haad { "1", 1 },
176 1.1 haad { "2", 2 },
177 1.1 haad { "3", 3 },
178 1.1.1.2 haad { "4", 4 },
179 1.1.1.3 chs { "5", 5 },
180 1.1 haad { "current", ZPL_VERSION },
181 1.1 haad { NULL }
182 1.1 haad };
183 1.1 haad
184 1.1 haad static zprop_index_t boolean_table[] = {
185 1.1 haad { "off", 0 },
186 1.1 haad { "on", 1 },
187 1.1 haad { NULL }
188 1.1 haad };
189 1.1 haad
190 1.1.1.2 haad static zprop_index_t logbias_table[] = {
191 1.1.1.2 haad { "latency", ZFS_LOGBIAS_LATENCY },
192 1.1.1.2 haad { "throughput", ZFS_LOGBIAS_THROUGHPUT },
193 1.1.1.2 haad { NULL }
194 1.1.1.2 haad };
195 1.1.1.2 haad
196 1.1 haad static zprop_index_t canmount_table[] = {
197 1.1 haad { "off", ZFS_CANMOUNT_OFF },
198 1.1 haad { "on", ZFS_CANMOUNT_ON },
199 1.1 haad { "noauto", ZFS_CANMOUNT_NOAUTO },
200 1.1 haad { NULL }
201 1.1 haad };
202 1.1 haad
203 1.1 haad static zprop_index_t cache_table[] = {
204 1.1 haad { "none", ZFS_CACHE_NONE },
205 1.1 haad { "metadata", ZFS_CACHE_METADATA },
206 1.1 haad { "all", ZFS_CACHE_ALL },
207 1.1 haad { NULL }
208 1.1 haad };
209 1.1 haad
210 1.1.1.3 chs static zprop_index_t sync_table[] = {
211 1.1.1.3 chs { "standard", ZFS_SYNC_STANDARD },
212 1.1.1.3 chs { "always", ZFS_SYNC_ALWAYS },
213 1.1.1.3 chs { "disabled", ZFS_SYNC_DISABLED },
214 1.1.1.3 chs { NULL }
215 1.1.1.3 chs };
216 1.1.1.3 chs
217 1.1.1.3 chs static zprop_index_t volmode_table[] = {
218 1.1.1.3 chs { "default", ZFS_VOLMODE_DEFAULT },
219 1.1.1.3 chs { "geom", ZFS_VOLMODE_GEOM },
220 1.1.1.3 chs { "dev", ZFS_VOLMODE_DEV },
221 1.1.1.3 chs { "none", ZFS_VOLMODE_NONE },
222 1.1.1.3 chs { NULL }
223 1.1.1.3 chs };
224 1.1.1.3 chs
225 1.1.1.3 chs static zprop_index_t redundant_metadata_table[] = {
226 1.1.1.3 chs { "all", ZFS_REDUNDANT_METADATA_ALL },
227 1.1.1.3 chs { "most", ZFS_REDUNDANT_METADATA_MOST },
228 1.1.1.3 chs { NULL }
229 1.1.1.3 chs };
230 1.1.1.3 chs
231 1.1 haad /* inherit index properties */
232 1.1.1.3 chs zprop_register_index(ZFS_PROP_REDUNDANT_METADATA, "redundant_metadata",
233 1.1.1.3 chs ZFS_REDUNDANT_METADATA_ALL,
234 1.1.1.3 chs PROP_INHERIT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
235 1.1.1.3 chs "all | most", "REDUND_MD",
236 1.1.1.3 chs redundant_metadata_table);
237 1.1.1.3 chs zprop_register_index(ZFS_PROP_SYNC, "sync", ZFS_SYNC_STANDARD,
238 1.1 haad PROP_INHERIT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
239 1.1.1.3 chs "standard | always | disabled", "SYNC",
240 1.1.1.3 chs sync_table);
241 1.1.1.3 chs zprop_register_index(ZFS_PROP_CHECKSUM, "checksum",
242 1.1.1.3 chs ZIO_CHECKSUM_DEFAULT, PROP_INHERIT, ZFS_TYPE_FILESYSTEM |
243 1.1.1.3 chs ZFS_TYPE_VOLUME,
244 1.1.1.3 chs "on | off | fletcher2 | fletcher4 | sha256 | sha512 | "
245 1.1.1.3 chs "skein | edonr", "CHECKSUM", checksum_table);
246 1.1.1.3 chs zprop_register_index(ZFS_PROP_DEDUP, "dedup", ZIO_CHECKSUM_OFF,
247 1.1.1.2 haad PROP_INHERIT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
248 1.1.1.3 chs "on | off | verify | sha256[,verify], sha512[,verify], "
249 1.1.1.3 chs "skein[,verify], edonr,verify", "DEDUP", dedup_table);
250 1.1.1.3 chs zprop_register_index(ZFS_PROP_COMPRESSION, "compression",
251 1.1 haad ZIO_COMPRESS_DEFAULT, PROP_INHERIT,
252 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
253 1.1.1.3 chs "on | off | lzjb | gzip | gzip-[1-9] | zle | lz4",
254 1.1.1.3 chs "COMPRESS", compress_table);
255 1.1.1.3 chs zprop_register_index(ZFS_PROP_SNAPDIR, "snapdir", ZFS_SNAPDIR_HIDDEN,
256 1.1 haad PROP_INHERIT, ZFS_TYPE_FILESYSTEM,
257 1.1 haad "hidden | visible", "SNAPDIR", snapdir_table);
258 1.1.1.3 chs zprop_register_index(ZFS_PROP_ACLMODE, "aclmode", ZFS_ACL_DISCARD,
259 1.1 haad PROP_INHERIT, ZFS_TYPE_FILESYSTEM,
260 1.1.1.3 chs "discard | groupmask | passthrough | restricted", "ACLMODE",
261 1.1.1.3 chs acl_mode_table);
262 1.1.1.3 chs zprop_register_index(ZFS_PROP_ACLINHERIT, "aclinherit",
263 1.1.1.3 chs ZFS_ACL_RESTRICTED, PROP_INHERIT, ZFS_TYPE_FILESYSTEM,
264 1.1 haad "discard | noallow | restricted | passthrough | passthrough-x",
265 1.1 haad "ACLINHERIT", acl_inherit_table);
266 1.1.1.3 chs zprop_register_index(ZFS_PROP_COPIES, "copies", 1, PROP_INHERIT,
267 1.1.1.3 chs ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
268 1.1 haad "1 | 2 | 3", "COPIES", copies_table);
269 1.1.1.3 chs zprop_register_index(ZFS_PROP_PRIMARYCACHE, "primarycache",
270 1.1 haad ZFS_CACHE_ALL, PROP_INHERIT,
271 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT | ZFS_TYPE_VOLUME,
272 1.1 haad "all | none | metadata", "PRIMARYCACHE", cache_table);
273 1.1.1.3 chs zprop_register_index(ZFS_PROP_SECONDARYCACHE, "secondarycache",
274 1.1 haad ZFS_CACHE_ALL, PROP_INHERIT,
275 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT | ZFS_TYPE_VOLUME,
276 1.1 haad "all | none | metadata", "SECONDARYCACHE", cache_table);
277 1.1.1.3 chs zprop_register_index(ZFS_PROP_LOGBIAS, "logbias", ZFS_LOGBIAS_LATENCY,
278 1.1.1.2 haad PROP_INHERIT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
279 1.1.1.2 haad "latency | throughput", "LOGBIAS", logbias_table);
280 1.1.1.3 chs zprop_register_index(ZFS_PROP_VOLMODE, "volmode",
281 1.1.1.3 chs ZFS_VOLMODE_DEFAULT, PROP_INHERIT,
282 1.1.1.3 chs ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT | ZFS_TYPE_VOLUME,
283 1.1.1.3 chs "default | geom | dev | none", "VOLMODE", volmode_table);
284 1.1 haad
285 1.1 haad /* inherit index (boolean) properties */
286 1.1.1.3 chs zprop_register_index(ZFS_PROP_ATIME, "atime", 1, PROP_INHERIT,
287 1.1 haad ZFS_TYPE_FILESYSTEM, "on | off", "ATIME", boolean_table);
288 1.1.1.3 chs zprop_register_index(ZFS_PROP_DEVICES, "devices", 1, PROP_INHERIT,
289 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT, "on | off", "DEVICES",
290 1.1 haad boolean_table);
291 1.1.1.3 chs zprop_register_index(ZFS_PROP_EXEC, "exec", 1, PROP_INHERIT,
292 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT, "on | off", "EXEC",
293 1.1 haad boolean_table);
294 1.1.1.3 chs zprop_register_index(ZFS_PROP_SETUID, "setuid", 1, PROP_INHERIT,
295 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT, "on | off", "SETUID",
296 1.1 haad boolean_table);
297 1.1.1.3 chs zprop_register_index(ZFS_PROP_READONLY, "readonly", 0, PROP_INHERIT,
298 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "on | off", "RDONLY",
299 1.1 haad boolean_table);
300 1.1.1.3 chs zprop_register_index(ZFS_PROP_ZONED, "jailed", 0, PROP_INHERIT,
301 1.1.1.3 chs ZFS_TYPE_FILESYSTEM, "on | off", "JAILED", boolean_table);
302 1.1.1.3 chs zprop_register_index(ZFS_PROP_XATTR, "xattr", 1, PROP_INHERIT,
303 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT, "on | off", "XATTR",
304 1.1 haad boolean_table);
305 1.1.1.3 chs zprop_register_index(ZFS_PROP_VSCAN, "vscan", 0, PROP_INHERIT,
306 1.1 haad ZFS_TYPE_FILESYSTEM, "on | off", "VSCAN",
307 1.1 haad boolean_table);
308 1.1.1.3 chs zprop_register_index(ZFS_PROP_NBMAND, "nbmand", 0, PROP_INHERIT,
309 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT, "on | off", "NBMAND",
310 1.1 haad boolean_table);
311 1.1 haad
312 1.1 haad /* default index properties */
313 1.1.1.3 chs zprop_register_index(ZFS_PROP_VERSION, "version", 0, PROP_DEFAULT,
314 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT,
315 1.1.1.3 chs "1 | 2 | 3 | 4 | 5 | current", "VERSION", version_table);
316 1.1.1.3 chs zprop_register_index(ZFS_PROP_CANMOUNT, "canmount", ZFS_CANMOUNT_ON,
317 1.1 haad PROP_DEFAULT, ZFS_TYPE_FILESYSTEM, "on | off | noauto",
318 1.1 haad "CANMOUNT", canmount_table);
319 1.1 haad
320 1.1 haad /* readonly index (boolean) properties */
321 1.1.1.3 chs zprop_register_index(ZFS_PROP_MOUNTED, "mounted", 0, PROP_READONLY,
322 1.1 haad ZFS_TYPE_FILESYSTEM, "yes | no", "MOUNTED", boolean_table);
323 1.1.1.3 chs zprop_register_index(ZFS_PROP_DEFER_DESTROY, "defer_destroy", 0,
324 1.1.1.2 haad PROP_READONLY, ZFS_TYPE_SNAPSHOT, "yes | no", "DEFER_DESTROY",
325 1.1.1.2 haad boolean_table);
326 1.1 haad
327 1.1 haad /* set once index properties */
328 1.1.1.3 chs zprop_register_index(ZFS_PROP_NORMALIZE, "normalization", 0,
329 1.1 haad PROP_ONETIME, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT,
330 1.1 haad "none | formC | formD | formKC | formKD", "NORMALIZATION",
331 1.1 haad normalize_table);
332 1.1.1.3 chs zprop_register_index(ZFS_PROP_CASE, "casesensitivity",
333 1.1.1.3 chs ZFS_CASE_SENSITIVE, PROP_ONETIME, ZFS_TYPE_FILESYSTEM |
334 1.1.1.3 chs ZFS_TYPE_SNAPSHOT,
335 1.1 haad "sensitive | insensitive | mixed", "CASE", case_table);
336 1.1 haad
337 1.1 haad /* set once index (boolean) properties */
338 1.1.1.3 chs zprop_register_index(ZFS_PROP_UTF8ONLY, "utf8only", 0, PROP_ONETIME,
339 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_SNAPSHOT,
340 1.1 haad "on | off", "UTF8ONLY", boolean_table);
341 1.1 haad
342 1.1 haad /* string properties */
343 1.1.1.3 chs zprop_register_string(ZFS_PROP_ORIGIN, "origin", NULL, PROP_READONLY,
344 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<snapshot>", "ORIGIN");
345 1.1.1.3 chs zprop_register_string(ZFS_PROP_CLONES, "clones", NULL, PROP_READONLY,
346 1.1.1.3 chs ZFS_TYPE_SNAPSHOT, "<dataset>[,...]", "CLONES");
347 1.1.1.3 chs zprop_register_string(ZFS_PROP_MOUNTPOINT, "mountpoint", "/",
348 1.1.1.3 chs PROP_INHERIT, ZFS_TYPE_FILESYSTEM, "<path> | legacy | none",
349 1.1.1.3 chs "MOUNTPOINT");
350 1.1.1.3 chs zprop_register_string(ZFS_PROP_SHARENFS, "sharenfs", "off",
351 1.1.1.3 chs PROP_INHERIT, ZFS_TYPE_FILESYSTEM, "on | off | share(1M) options",
352 1.1.1.3 chs "SHARENFS");
353 1.1.1.3 chs zprop_register_string(ZFS_PROP_TYPE, "type", NULL, PROP_READONLY,
354 1.1.1.3 chs ZFS_TYPE_DATASET | ZFS_TYPE_BOOKMARK,
355 1.1.1.3 chs "filesystem | volume | snapshot | bookmark", "TYPE");
356 1.1.1.3 chs zprop_register_string(ZFS_PROP_SHARESMB, "sharesmb", "off",
357 1.1.1.3 chs PROP_INHERIT, ZFS_TYPE_FILESYSTEM,
358 1.1.1.3 chs "on | off | sharemgr(1M) options", "SHARESMB");
359 1.1.1.3 chs zprop_register_string(ZFS_PROP_MLSLABEL, "mlslabel",
360 1.1.1.3 chs ZFS_MLSLABEL_DEFAULT, PROP_INHERIT, ZFS_TYPE_DATASET,
361 1.1.1.3 chs "<sensitivity label>", "MLSLABEL");
362 1.1.1.3 chs zprop_register_string(ZFS_PROP_RECEIVE_RESUME_TOKEN,
363 1.1.1.3 chs "receive_resume_token",
364 1.1.1.3 chs NULL, PROP_READONLY, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
365 1.1.1.3 chs "<string token>", "RESUMETOK");
366 1.1 haad
367 1.1 haad /* readonly number properties */
368 1.1.1.3 chs zprop_register_number(ZFS_PROP_USED, "used", 0, PROP_READONLY,
369 1.1 haad ZFS_TYPE_DATASET, "<size>", "USED");
370 1.1.1.3 chs zprop_register_number(ZFS_PROP_AVAILABLE, "available", 0, PROP_READONLY,
371 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<size>", "AVAIL");
372 1.1.1.3 chs zprop_register_number(ZFS_PROP_REFERENCED, "referenced", 0,
373 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET, "<size>", "REFER");
374 1.1.1.3 chs zprop_register_number(ZFS_PROP_COMPRESSRATIO, "compressratio", 0,
375 1.1 haad PROP_READONLY, ZFS_TYPE_DATASET,
376 1.1 haad "<1.00x or higher if compressed>", "RATIO");
377 1.1.1.3 chs zprop_register_number(ZFS_PROP_REFRATIO, "refcompressratio", 0,
378 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET,
379 1.1.1.3 chs "<1.00x or higher if compressed>", "REFRATIO");
380 1.1.1.3 chs zprop_register_number(ZFS_PROP_VOLBLOCKSIZE, "volblocksize",
381 1.1.1.2 haad ZVOL_DEFAULT_BLOCKSIZE, PROP_ONETIME,
382 1.1 haad ZFS_TYPE_VOLUME, "512 to 128k, power of 2", "VOLBLOCK");
383 1.1.1.3 chs zprop_register_number(ZFS_PROP_USEDSNAP, "usedbysnapshots", 0,
384 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<size>",
385 1.1.1.3 chs "USEDSNAP");
386 1.1.1.3 chs zprop_register_number(ZFS_PROP_USEDDS, "usedbydataset", 0,
387 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<size>",
388 1.1.1.3 chs "USEDDS");
389 1.1.1.3 chs zprop_register_number(ZFS_PROP_USEDCHILD, "usedbychildren", 0,
390 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<size>",
391 1.1.1.3 chs "USEDCHILD");
392 1.1.1.3 chs zprop_register_number(ZFS_PROP_USEDREFRESERV, "usedbyrefreservation", 0,
393 1.1 haad PROP_READONLY,
394 1.1 haad ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "<size>", "USEDREFRESERV");
395 1.1.1.3 chs zprop_register_number(ZFS_PROP_USERREFS, "userrefs", 0, PROP_READONLY,
396 1.1.1.2 haad ZFS_TYPE_SNAPSHOT, "<count>", "USERREFS");
397 1.1.1.3 chs zprop_register_number(ZFS_PROP_WRITTEN, "written", 0, PROP_READONLY,
398 1.1.1.3 chs ZFS_TYPE_DATASET, "<size>", "WRITTEN");
399 1.1.1.3 chs zprop_register_number(ZFS_PROP_LOGICALUSED, "logicalused", 0,
400 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET, "<size>", "LUSED");
401 1.1.1.3 chs zprop_register_number(ZFS_PROP_LOGICALREFERENCED, "logicalreferenced",
402 1.1.1.3 chs 0, PROP_READONLY, ZFS_TYPE_DATASET, "<size>", "LREFER");
403 1.1 haad
404 1.1 haad /* default number properties */
405 1.1.1.3 chs zprop_register_number(ZFS_PROP_QUOTA, "quota", 0, PROP_DEFAULT,
406 1.1 haad ZFS_TYPE_FILESYSTEM, "<size> | none", "QUOTA");
407 1.1.1.3 chs zprop_register_number(ZFS_PROP_RESERVATION, "reservation", 0,
408 1.1.1.3 chs PROP_DEFAULT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
409 1.1.1.3 chs "<size> | none", "RESERV");
410 1.1.1.3 chs zprop_register_number(ZFS_PROP_VOLSIZE, "volsize", 0, PROP_DEFAULT,
411 1.1 haad ZFS_TYPE_VOLUME, "<size>", "VOLSIZE");
412 1.1.1.3 chs zprop_register_number(ZFS_PROP_REFQUOTA, "refquota", 0, PROP_DEFAULT,
413 1.1 haad ZFS_TYPE_FILESYSTEM, "<size> | none", "REFQUOTA");
414 1.1.1.3 chs zprop_register_number(ZFS_PROP_REFRESERVATION, "refreservation", 0,
415 1.1 haad PROP_DEFAULT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
416 1.1 haad "<size> | none", "REFRESERV");
417 1.1.1.3 chs zprop_register_number(ZFS_PROP_FILESYSTEM_LIMIT, "filesystem_limit",
418 1.1.1.3 chs UINT64_MAX, PROP_DEFAULT, ZFS_TYPE_FILESYSTEM,
419 1.1.1.3 chs "<count> | none", "FSLIMIT");
420 1.1.1.3 chs zprop_register_number(ZFS_PROP_SNAPSHOT_LIMIT, "snapshot_limit",
421 1.1.1.3 chs UINT64_MAX, PROP_DEFAULT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
422 1.1.1.3 chs "<count> | none", "SSLIMIT");
423 1.1.1.3 chs zprop_register_number(ZFS_PROP_FILESYSTEM_COUNT, "filesystem_count",
424 1.1.1.3 chs UINT64_MAX, PROP_DEFAULT, ZFS_TYPE_FILESYSTEM,
425 1.1.1.3 chs "<count>", "FSCOUNT");
426 1.1.1.3 chs zprop_register_number(ZFS_PROP_SNAPSHOT_COUNT, "snapshot_count",
427 1.1.1.3 chs UINT64_MAX, PROP_DEFAULT, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME,
428 1.1.1.3 chs "<count>", "SSCOUNT");
429 1.1 haad
430 1.1 haad /* inherit number properties */
431 1.1.1.3 chs zprop_register_number(ZFS_PROP_RECORDSIZE, "recordsize",
432 1.1.1.3 chs SPA_OLD_MAXBLOCKSIZE, PROP_INHERIT,
433 1.1.1.3 chs ZFS_TYPE_FILESYSTEM, "512 to 1M, power of 2", "RECSIZE");
434 1.1 haad
435 1.1 haad /* hidden properties */
436 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_CREATETXG, "createtxg", PROP_TYPE_NUMBER,
437 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET | ZFS_TYPE_BOOKMARK, "CREATETXG");
438 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_NUMCLONES, "numclones", PROP_TYPE_NUMBER,
439 1.1.1.2 haad PROP_READONLY, ZFS_TYPE_SNAPSHOT, "NUMCLONES");
440 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_NAME, "name", PROP_TYPE_STRING,
441 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET | ZFS_TYPE_BOOKMARK, "NAME");
442 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_ISCSIOPTIONS, "iscsioptions",
443 1.1.1.3 chs PROP_TYPE_STRING, PROP_INHERIT, ZFS_TYPE_VOLUME, "ISCSIOPTIONS");
444 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_STMF_SHAREINFO, "stmf_sbd_lu",
445 1.1.1.2 haad PROP_TYPE_STRING, PROP_INHERIT, ZFS_TYPE_VOLUME,
446 1.1.1.2 haad "STMF_SBD_LU");
447 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_GUID, "guid", PROP_TYPE_NUMBER,
448 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_DATASET | ZFS_TYPE_BOOKMARK, "GUID");
449 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_USERACCOUNTING, "useraccounting",
450 1.1.1.2 haad PROP_TYPE_NUMBER, PROP_READONLY, ZFS_TYPE_DATASET,
451 1.1.1.2 haad "USERACCOUNTING");
452 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_UNIQUE, "unique", PROP_TYPE_NUMBER,
453 1.1.1.2 haad PROP_READONLY, ZFS_TYPE_DATASET, "UNIQUE");
454 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_OBJSETID, "objsetid", PROP_TYPE_NUMBER,
455 1.1.1.2 haad PROP_READONLY, ZFS_TYPE_DATASET, "OBJSETID");
456 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_INCONSISTENT, "inconsistent",
457 1.1.1.3 chs PROP_TYPE_NUMBER, PROP_READONLY, ZFS_TYPE_DATASET, "INCONSISTENT");
458 1.1.1.3 chs zprop_register_hidden(ZFS_PROP_PREV_SNAP, "prevsnap", PROP_TYPE_STRING,
459 1.1.1.3 chs PROP_READONLY, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME, "PREVSNAP");
460 1.1 haad
461 1.1 haad /* oddball properties */
462 1.1.1.3 chs zprop_register_impl(ZFS_PROP_CREATION, "creation", PROP_TYPE_NUMBER, 0,
463 1.1.1.3 chs NULL, PROP_READONLY, ZFS_TYPE_DATASET | ZFS_TYPE_BOOKMARK,
464 1.1 haad "<date>", "CREATION", B_FALSE, B_TRUE, NULL);
465 1.1 haad }
466 1.1 haad
467 1.1 haad boolean_t
468 1.1 haad zfs_prop_delegatable(zfs_prop_t prop)
469 1.1 haad {
470 1.1 haad zprop_desc_t *pd = &zfs_prop_table[prop];
471 1.1.1.2 haad
472 1.1.1.2 haad /* The mlslabel property is never delegatable. */
473 1.1.1.2 haad if (prop == ZFS_PROP_MLSLABEL)
474 1.1.1.2 haad return (B_FALSE);
475 1.1.1.2 haad
476 1.1 haad return (pd->pd_attr != PROP_READONLY);
477 1.1 haad }
478 1.1 haad
479 1.1 haad /*
480 1.1 haad * Given a zfs dataset property name, returns the corresponding property ID.
481 1.1 haad */
482 1.1 haad zfs_prop_t
483 1.1 haad zfs_name_to_prop(const char *propname)
484 1.1 haad {
485 1.1 haad return (zprop_name_to_prop(propname, ZFS_TYPE_DATASET));
486 1.1 haad }
487 1.1 haad
488 1.1 haad /*
489 1.1 haad * For user property names, we allow all lowercase alphanumeric characters, plus
490 1.1 haad * a few useful punctuation characters.
491 1.1 haad */
492 1.1 haad static int
493 1.1 haad valid_char(char c)
494 1.1 haad {
495 1.1 haad return ((c >= 'a' && c <= 'z') ||
496 1.1 haad (c >= '0' && c <= '9') ||
497 1.1 haad c == '-' || c == '_' || c == '.' || c == ':');
498 1.1 haad }
499 1.1 haad
500 1.1 haad /*
501 1.1 haad * Returns true if this is a valid user-defined property (one with a ':').
502 1.1 haad */
503 1.1 haad boolean_t
504 1.1 haad zfs_prop_user(const char *name)
505 1.1 haad {
506 1.1 haad int i;
507 1.1 haad char c;
508 1.1 haad boolean_t foundsep = B_FALSE;
509 1.1 haad
510 1.1 haad for (i = 0; i < strlen(name); i++) {
511 1.1 haad c = name[i];
512 1.1 haad if (!valid_char(c))
513 1.1 haad return (B_FALSE);
514 1.1 haad if (c == ':')
515 1.1 haad foundsep = B_TRUE;
516 1.1 haad }
517 1.1 haad
518 1.1 haad if (!foundsep)
519 1.1 haad return (B_FALSE);
520 1.1 haad
521 1.1 haad return (B_TRUE);
522 1.1 haad }
523 1.1 haad
524 1.1 haad /*
525 1.1.1.2 haad * Returns true if this is a valid userspace-type property (one with a '@').
526 1.1.1.2 haad * Note that after the @, any character is valid (eg, another @, for SID
527 1.1.1.2 haad * user@domain).
528 1.1.1.2 haad */
529 1.1.1.2 haad boolean_t
530 1.1.1.2 haad zfs_prop_userquota(const char *name)
531 1.1.1.2 haad {
532 1.1.1.2 haad zfs_userquota_prop_t prop;
533 1.1.1.2 haad
534 1.1.1.2 haad for (prop = 0; prop < ZFS_NUM_USERQUOTA_PROPS; prop++) {
535 1.1.1.2 haad if (strncmp(name, zfs_userquota_prop_prefixes[prop],
536 1.1.1.2 haad strlen(zfs_userquota_prop_prefixes[prop])) == 0) {
537 1.1.1.2 haad return (B_TRUE);
538 1.1.1.2 haad }
539 1.1.1.2 haad }
540 1.1.1.2 haad
541 1.1.1.2 haad return (B_FALSE);
542 1.1.1.2 haad }
543 1.1.1.2 haad
544 1.1.1.2 haad /*
545 1.1.1.3 chs * Returns true if this is a valid written@ property.
546 1.1.1.3 chs * Note that after the @, any character is valid (eg, another @, for
547 1.1.1.3 chs * written@pool/fs@origin).
548 1.1.1.3 chs */
549 1.1.1.3 chs boolean_t
550 1.1.1.3 chs zfs_prop_written(const char *name)
551 1.1.1.3 chs {
552 1.1.1.3 chs static const char *prefix = "written@";
553 1.1.1.3 chs return (strncmp(name, prefix, strlen(prefix)) == 0);
554 1.1.1.3 chs }
555 1.1.1.3 chs
556 1.1.1.3 chs /*
557 1.1 haad * Tables of index types, plus functions to convert between the user view
558 1.1 haad * (strings) and internal representation (uint64_t).
559 1.1 haad */
560 1.1 haad int
561 1.1 haad zfs_prop_string_to_index(zfs_prop_t prop, const char *string, uint64_t *index)
562 1.1 haad {
563 1.1 haad return (zprop_string_to_index(prop, string, index, ZFS_TYPE_DATASET));
564 1.1 haad }
565 1.1 haad
566 1.1 haad int
567 1.1 haad zfs_prop_index_to_string(zfs_prop_t prop, uint64_t index, const char **string)
568 1.1 haad {
569 1.1 haad return (zprop_index_to_string(prop, index, string, ZFS_TYPE_DATASET));
570 1.1 haad }
571 1.1 haad
572 1.1.1.2 haad uint64_t
573 1.1.1.2 haad zfs_prop_random_value(zfs_prop_t prop, uint64_t seed)
574 1.1.1.2 haad {
575 1.1.1.2 haad return (zprop_random_value(prop, seed, ZFS_TYPE_DATASET));
576 1.1.1.2 haad }
577 1.1.1.2 haad
578 1.1 haad /*
579 1.1 haad * Returns TRUE if the property applies to any of the given dataset types.
580 1.1 haad */
581 1.1 haad boolean_t
582 1.1 haad zfs_prop_valid_for_type(int prop, zfs_type_t types)
583 1.1 haad {
584 1.1 haad return (zprop_valid_for_type(prop, types));
585 1.1 haad }
586 1.1 haad
587 1.1 haad zprop_type_t
588 1.1 haad zfs_prop_get_type(zfs_prop_t prop)
589 1.1 haad {
590 1.1 haad return (zfs_prop_table[prop].pd_proptype);
591 1.1 haad }
592 1.1 haad
593 1.1 haad /*
594 1.1 haad * Returns TRUE if the property is readonly.
595 1.1 haad */
596 1.1 haad boolean_t
597 1.1 haad zfs_prop_readonly(zfs_prop_t prop)
598 1.1 haad {
599 1.1 haad return (zfs_prop_table[prop].pd_attr == PROP_READONLY ||
600 1.1 haad zfs_prop_table[prop].pd_attr == PROP_ONETIME);
601 1.1 haad }
602 1.1 haad
603 1.1 haad /*
604 1.1 haad * Returns TRUE if the property is only allowed to be set once.
605 1.1 haad */
606 1.1 haad boolean_t
607 1.1 haad zfs_prop_setonce(zfs_prop_t prop)
608 1.1 haad {
609 1.1 haad return (zfs_prop_table[prop].pd_attr == PROP_ONETIME);
610 1.1 haad }
611 1.1 haad
612 1.1 haad const char *
613 1.1 haad zfs_prop_default_string(zfs_prop_t prop)
614 1.1 haad {
615 1.1 haad return (zfs_prop_table[prop].pd_strdefault);
616 1.1 haad }
617 1.1 haad
618 1.1 haad uint64_t
619 1.1 haad zfs_prop_default_numeric(zfs_prop_t prop)
620 1.1 haad {
621 1.1 haad return (zfs_prop_table[prop].pd_numdefault);
622 1.1 haad }
623 1.1 haad
624 1.1 haad /*
625 1.1 haad * Given a dataset property ID, returns the corresponding name.
626 1.1 haad * Assuming the zfs dataset property ID is valid.
627 1.1 haad */
628 1.1 haad const char *
629 1.1 haad zfs_prop_to_name(zfs_prop_t prop)
630 1.1 haad {
631 1.1 haad return (zfs_prop_table[prop].pd_name);
632 1.1 haad }
633 1.1 haad
634 1.1 haad /*
635 1.1 haad * Returns TRUE if the property is inheritable.
636 1.1 haad */
637 1.1 haad boolean_t
638 1.1 haad zfs_prop_inheritable(zfs_prop_t prop)
639 1.1 haad {
640 1.1 haad return (zfs_prop_table[prop].pd_attr == PROP_INHERIT ||
641 1.1 haad zfs_prop_table[prop].pd_attr == PROP_ONETIME);
642 1.1 haad }
643 1.1 haad
644 1.1 haad #ifndef _KERNEL
645 1.1 haad
646 1.1 haad /*
647 1.1 haad * Returns a string describing the set of acceptable values for the given
648 1.1 haad * zfs property, or NULL if it cannot be set.
649 1.1 haad */
650 1.1 haad const char *
651 1.1 haad zfs_prop_values(zfs_prop_t prop)
652 1.1 haad {
653 1.1 haad return (zfs_prop_table[prop].pd_values);
654 1.1 haad }
655 1.1 haad
656 1.1 haad /*
657 1.1 haad * Returns TRUE if this property is a string type. Note that index types
658 1.1 haad * (compression, checksum) are treated as strings in userland, even though they
659 1.1 haad * are stored numerically on disk.
660 1.1 haad */
661 1.1 haad int
662 1.1 haad zfs_prop_is_string(zfs_prop_t prop)
663 1.1 haad {
664 1.1 haad return (zfs_prop_table[prop].pd_proptype == PROP_TYPE_STRING ||
665 1.1 haad zfs_prop_table[prop].pd_proptype == PROP_TYPE_INDEX);
666 1.1 haad }
667 1.1 haad
668 1.1 haad /*
669 1.1 haad * Returns the column header for the given property. Used only in
670 1.1 haad * 'zfs list -o', but centralized here with the other property information.
671 1.1 haad */
672 1.1 haad const char *
673 1.1 haad zfs_prop_column_name(zfs_prop_t prop)
674 1.1 haad {
675 1.1 haad return (zfs_prop_table[prop].pd_colname);
676 1.1 haad }
677 1.1 haad
678 1.1 haad /*
679 1.1 haad * Returns whether the given property should be displayed right-justified for
680 1.1 haad * 'zfs list'.
681 1.1 haad */
682 1.1 haad boolean_t
683 1.1 haad zfs_prop_align_right(zfs_prop_t prop)
684 1.1 haad {
685 1.1 haad return (zfs_prop_table[prop].pd_rightalign);
686 1.1 haad }
687 1.1 haad
688 1.1 haad #endif
689