xref: /illumos-gate/usr/src/lib/libzfs/common/libzfs_dataset.c (revision 5cce9d40d191f7d11762f0803b81ddffaabafd3e)
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, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 #pragma ident	"%Z%%M%	%I%	%E% SMI"
28 
29 #include <assert.h>
30 #include <ctype.h>
31 #include <errno.h>
32 #include <libdevinfo.h>
33 #include <libintl.h>
34 #include <math.h>
35 #include <stdio.h>
36 #include <stdlib.h>
37 #include <strings.h>
38 #include <unistd.h>
39 #include <zone.h>
40 #include <sys/mntent.h>
41 #include <sys/mnttab.h>
42 #include <sys/mount.h>
43 
44 #include <sys/spa.h>
45 #include <sys/zio.h>
46 #include <libzfs.h>
47 
48 #include "zfs_namecheck.h"
49 #include "zfs_prop.h"
50 #include "libzfs_impl.h"
51 
52 /*
53  * Given a single type (not a mask of types), return the type in a human
54  * readable form.
55  */
56 const char *
57 zfs_type_to_name(zfs_type_t type)
58 {
59 	switch (type) {
60 	case ZFS_TYPE_FILESYSTEM:
61 		return (dgettext(TEXT_DOMAIN, "filesystem"));
62 	case ZFS_TYPE_SNAPSHOT:
63 		return (dgettext(TEXT_DOMAIN, "snapshot"));
64 	case ZFS_TYPE_VOLUME:
65 		return (dgettext(TEXT_DOMAIN, "volume"));
66 	}
67 
68 	zfs_baderror(type);
69 	return (NULL);
70 }
71 
72 /*
73  * Given a path and mask of ZFS types, return a string describing this dataset.
74  * This is used when we fail to open a dataset and we cannot get an exact type.
75  * We guess what the type would have been based on the path and the mask of
76  * acceptable types.
77  */
78 static const char *
79 path_to_str(const char *path, int types)
80 {
81 	/*
82 	 * When given a single type, always report the exact type.
83 	 */
84 	if (types == ZFS_TYPE_SNAPSHOT)
85 		return (dgettext(TEXT_DOMAIN, "snapshot"));
86 	if (types == ZFS_TYPE_FILESYSTEM)
87 		return (dgettext(TEXT_DOMAIN, "filesystem"));
88 	if (types == ZFS_TYPE_VOLUME)
89 		return (dgettext(TEXT_DOMAIN, "volume"));
90 
91 	/*
92 	 * The user is requesting more than one type of dataset.  If this is the
93 	 * case, consult the path itself.  If we're looking for a snapshot, and
94 	 * a '@' is found, then report it as "snapshot".  Otherwise, remove the
95 	 * snapshot attribute and try again.
96 	 */
97 	if (types & ZFS_TYPE_SNAPSHOT) {
98 		if (strchr(path, '@') != NULL)
99 			return (dgettext(TEXT_DOMAIN, "snapshot"));
100 		return (path_to_str(path, types & ~ZFS_TYPE_SNAPSHOT));
101 	}
102 
103 
104 	/*
105 	 * The user has requested either filesystems or volumes.
106 	 * We have no way of knowing a priori what type this would be, so always
107 	 * report it as "filesystem" or "volume", our two primitive types.
108 	 */
109 	if (types & ZFS_TYPE_FILESYSTEM)
110 		return (dgettext(TEXT_DOMAIN, "filesystem"));
111 
112 	assert(types & ZFS_TYPE_VOLUME);
113 	return (dgettext(TEXT_DOMAIN, "volume"));
114 }
115 
116 /*
117  * Validate a ZFS path.  This is used even before trying to open the dataset, to
118  * provide a more meaningful error message.  We place a more useful message in
119  * 'buf' detailing exactly why the name was not valid.
120  */
121 static int
122 zfs_validate_name(const char *path, int type, char *buf, size_t buflen)
123 {
124 	namecheck_err_t why;
125 	char what;
126 
127 	if (dataset_namecheck(path, &why, &what) != 0) {
128 		if (buf != NULL) {
129 			switch (why) {
130 			case NAME_ERR_TOOLONG:
131 				(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
132 				    "name is too long"), buflen);
133 				break;
134 
135 			case NAME_ERR_LEADING_SLASH:
136 				(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
137 				    "leading slash"), buflen);
138 				break;
139 
140 			case NAME_ERR_EMPTY_COMPONENT:
141 				(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
142 				    "empty component"), buflen);
143 				break;
144 
145 			case NAME_ERR_TRAILING_SLASH:
146 				(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
147 				    "trailing slash"), buflen);
148 				break;
149 
150 			case NAME_ERR_INVALCHAR:
151 				(void) snprintf(buf, buflen,
152 				    dgettext(TEXT_DOMAIN, "invalid character "
153 				    "'%c'"), what);
154 				break;
155 
156 			case NAME_ERR_MULTIPLE_AT:
157 				(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
158 				    "multiple '@' delimiters"), buflen);
159 				break;
160 			}
161 		}
162 
163 		return (0);
164 	}
165 
166 	if (!(type & ZFS_TYPE_SNAPSHOT) && strchr(path, '@') != NULL) {
167 		if (buf != NULL)
168 			(void) strlcpy(buf,
169 			    dgettext(TEXT_DOMAIN,
170 			    "snapshot delimiter '@'"), buflen);
171 		return (0);
172 	}
173 
174 	return (1);
175 }
176 
177 int
178 zfs_name_valid(const char *name, zfs_type_t type)
179 {
180 	return (zfs_validate_name(name, type, NULL, NULL));
181 }
182 
183 /*
184  * Utility function to gather stats (objset and zpl) for the given object.
185  */
186 static int
187 get_stats(zfs_handle_t *zhp)
188 {
189 	zfs_cmd_t zc = { 0 };
190 
191 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
192 
193 	zc.zc_config_src = (uint64_t)(uintptr_t)zfs_malloc(1024);
194 	zc.zc_config_src_size = 1024;
195 
196 	while (ioctl(zfs_fd, ZFS_IOC_OBJSET_STATS, &zc) != 0) {
197 		if (errno == ENOMEM) {
198 			zc.zc_config_src = (uint64_t)(uintptr_t)
199 			    zfs_malloc(zc.zc_config_src_size);
200 		} else {
201 			free((void *)(uintptr_t)zc.zc_config_src);
202 			return (-1);
203 		}
204 	}
205 
206 	bcopy(&zc.zc_objset_stats, &zhp->zfs_dmustats,
207 	    sizeof (zc.zc_objset_stats));
208 
209 	verify(nvlist_unpack((void *)(uintptr_t)zc.zc_config_src,
210 	    zc.zc_config_src_size, &zhp->zfs_props, 0) == 0);
211 
212 	zhp->zfs_volsize = zc.zc_volsize;
213 	zhp->zfs_volblocksize = zc.zc_volblocksize;
214 
215 	return (0);
216 }
217 
218 /*
219  * Refresh the properties currently stored in the handle.
220  */
221 void
222 zfs_refresh_properties(zfs_handle_t *zhp)
223 {
224 	(void) get_stats(zhp);
225 }
226 
227 /*
228  * Makes a handle from the given dataset name.  Used by zfs_open() and
229  * zfs_iter_* to create child handles on the fly.
230  */
231 zfs_handle_t *
232 make_dataset_handle(const char *path)
233 {
234 	zfs_handle_t *zhp = zfs_malloc(sizeof (zfs_handle_t));
235 
236 	(void) strlcpy(zhp->zfs_name, path, sizeof (zhp->zfs_name));
237 
238 	if (get_stats(zhp) != 0) {
239 		free(zhp);
240 		return (NULL);
241 	}
242 
243 	/*
244 	 * We've managed to open the dataset and gather statistics.  Determine
245 	 * the high-level type.
246 	 */
247 	if (zhp->zfs_dmustats.dds_is_snapshot)
248 		zhp->zfs_type = ZFS_TYPE_SNAPSHOT;
249 	else if (zhp->zfs_dmustats.dds_type == DMU_OST_ZVOL)
250 		zhp->zfs_type = ZFS_TYPE_VOLUME;
251 	else if (zhp->zfs_dmustats.dds_type == DMU_OST_ZFS)
252 		zhp->zfs_type = ZFS_TYPE_FILESYSTEM;
253 	else
254 		/* we should never see any other dataset types */
255 		zfs_baderror(zhp->zfs_dmustats.dds_type);
256 
257 	return (zhp);
258 }
259 
260 /*
261  * Opens the given snapshot, filesystem, or volume.   The 'types'
262  * argument is a mask of acceptable types.  The function will print an
263  * appropriate error message and return NULL if it can't be opened.
264  */
265 zfs_handle_t *
266 zfs_open(const char *path, int types)
267 {
268 	zfs_handle_t *zhp;
269 
270 	/*
271 	 * Validate the name before we even try to open it.  We don't care about
272 	 * the verbose invalid messages here; just report a generic error.
273 	 */
274 	if (!zfs_validate_name(path, types, NULL, 0)) {
275 		zfs_error(dgettext(TEXT_DOMAIN,
276 		    "cannot open '%s': invalid %s name"), path,
277 		    path_to_str(path, types));
278 		return (NULL);
279 	}
280 
281 	/*
282 	 * Try to get stats for the dataset, which will tell us if it exists.
283 	 */
284 	errno = 0;
285 	if ((zhp = make_dataset_handle(path)) == NULL) {
286 		switch (errno) {
287 		case ENOENT:
288 			/*
289 			 * The dataset doesn't exist.
290 			 */
291 			zfs_error(dgettext(TEXT_DOMAIN,
292 			    "cannot open '%s': no such %s"), path,
293 			    path_to_str(path, types));
294 			break;
295 
296 		case EBUSY:
297 			/*
298 			 * We were able to open the dataset but couldn't
299 			 * get the stats.
300 			 */
301 			zfs_error(dgettext(TEXT_DOMAIN,
302 			    "cannot open '%s': %s is busy"), path,
303 			    path_to_str(path, types));
304 			break;
305 
306 		default:
307 			zfs_baderror(errno);
308 
309 		}
310 		return (NULL);
311 	}
312 
313 	if (!(types & zhp->zfs_type)) {
314 		zfs_error(dgettext(TEXT_DOMAIN, "cannot open '%s': operation "
315 		    "not supported for %ss"), path,
316 		    zfs_type_to_name(zhp->zfs_type));
317 		free(zhp);
318 		return (NULL);
319 	}
320 
321 	return (zhp);
322 }
323 
324 /*
325  * Release a ZFS handle.  Nothing to do but free the associated memory.
326  */
327 void
328 zfs_close(zfs_handle_t *zhp)
329 {
330 	if (zhp->zfs_mntopts)
331 		free(zhp->zfs_mntopts);
332 	free(zhp);
333 }
334 
335 struct {
336 	const char *name;
337 	uint64_t value;
338 } checksum_table[] = {
339 	{ "on",		ZIO_CHECKSUM_ON },
340 	{ "off",	ZIO_CHECKSUM_OFF },
341 	{ "fletcher2",	ZIO_CHECKSUM_FLETCHER_2 },
342 	{ "fletcher4",	ZIO_CHECKSUM_FLETCHER_4 },
343 	{ "sha256",	ZIO_CHECKSUM_SHA256 },
344 	{ NULL }
345 };
346 
347 struct {
348 	const char *name;
349 	uint64_t value;
350 } compress_table[] = {
351 	{ "on",		ZIO_COMPRESS_ON },
352 	{ "off",	ZIO_COMPRESS_OFF },
353 	{ "lzjb",	ZIO_COMPRESS_LZJB },
354 	{ NULL }
355 };
356 
357 struct {
358 	const char *name;
359 	uint64_t value;
360 } snapdir_table[] = {
361 	{ "hidden",	ZFS_SNAPDIR_HIDDEN },
362 	{ "visible",	ZFS_SNAPDIR_VISIBLE },
363 	{ NULL }
364 };
365 
366 struct {
367 	const char *name;
368 	uint64_t value;
369 } acl_mode_table[] = {
370 	{ "discard",	DISCARD },
371 	{ "groupmask",	GROUPMASK },
372 	{ "passthrough", PASSTHROUGH },
373 	{ NULL }
374 };
375 
376 struct {
377 	const char *name;
378 	uint64_t value;
379 } acl_inherit_table[] = {
380 	{ "discard",	DISCARD },
381 	{ "noallow",	NOALLOW },
382 	{ "secure",	SECURE },
383 	{ "passthrough", PASSTHROUGH },
384 	{ NULL }
385 };
386 
387 
388 /*
389  * Given a numeric suffix, convert the value into a number of bits that the
390  * resulting value must be shifted.
391  */
392 static int
393 str2shift(const char *buf, char *reason, size_t len)
394 {
395 	const char *ends = "BKMGTPEZ";
396 	int i;
397 
398 	if (buf[0] == '\0')
399 		return (0);
400 	for (i = 0; i < strlen(ends); i++) {
401 		if (toupper(buf[0]) == ends[i])
402 			break;
403 	}
404 	if (i == strlen(ends)) {
405 		(void) snprintf(reason, len, dgettext(TEXT_DOMAIN, "invalid "
406 		    "numeric suffix '%s'"), buf);
407 		return (-1);
408 	}
409 
410 	/*
411 	 * We want to allow trailing 'b' characters for 'GB' or 'Mb'.  But don't
412 	 * allow 'BB' - that's just weird.
413 	 */
414 	if (buf[1] == '\0' || (toupper(buf[1]) == 'B' && buf[2] == '\0' &&
415 	    toupper(buf[0]) != 'B')) {
416 		return (10*i);
417 	}
418 
419 	(void) snprintf(reason, len, dgettext(TEXT_DOMAIN, "invalid numeric "
420 	    "suffix '%s'"), buf);
421 	return (-1);
422 }
423 
424 /*
425  * Convert a string of the form '100G' into a real number.  Used when setting
426  * properties or creating a volume.  'buf' is used to place an extended error
427  * message for the caller to use.
428  */
429 static int
430 nicestrtonum(const char *value, uint64_t *num, char *buf, size_t buflen)
431 {
432 	char *end;
433 	int shift;
434 
435 	*num = 0;
436 
437 	/* Check to see if this looks like a number.  */
438 	if ((value[0] < '0' || value[0] > '9') && value[0] != '.') {
439 		(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
440 		    "must be a numeric value"), buflen);
441 		return (-1);
442 	}
443 
444 	/* Rely on stroll() to process the numeric portion.  */
445 	errno = 0;
446 	*num = strtoll(value, &end, 10);
447 
448 	/*
449 	 * Check for ERANGE, which indicates that the value is too large to fit
450 	 * in a 64-bit value.
451 	 */
452 	if (errno == ERANGE) {
453 		(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
454 		    "value is too large"), buflen);
455 		return (-1);
456 	}
457 
458 	/*
459 	 * If we have a decimal value, then do the computation with floating
460 	 * point arithmetic.  Otherwise, use standard arithmetic.
461 	 */
462 	if (*end == '.') {
463 		double fval = strtod(value, &end);
464 
465 		if ((shift = str2shift(end, buf, buflen)) == -1)
466 			return (-1);
467 
468 		fval *= pow(2, shift);
469 
470 		if (fval > UINT64_MAX) {
471 			(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
472 			    "value is too large"), buflen);
473 			return (-1);
474 		}
475 
476 		*num = (uint64_t)fval;
477 	} else {
478 		if ((shift = str2shift(end, buf, buflen)) == -1)
479 			return (-1);
480 
481 		/* Check for overflow */
482 		if (shift >= 64 || (*num << shift) >> shift != *num) {
483 			(void) strlcpy(buf, dgettext(TEXT_DOMAIN,
484 			    "value is too large"), buflen);
485 			return (-1);
486 		}
487 
488 		*num <<= shift;
489 	}
490 
491 	return (0);
492 }
493 
494 int
495 zfs_nicestrtonum(const char *str, uint64_t *val)
496 {
497 	char buf[1];
498 
499 	return (nicestrtonum(str, val, buf, sizeof (buf)));
500 }
501 
502 /*
503  * Given a property type and value, verify that the value is appropriate.  Used
504  * by zfs_prop_set() and some libzfs consumers.
505  */
506 int
507 zfs_prop_validate(zfs_prop_t prop, const char *value, uint64_t *intval)
508 {
509 	const char *propname = zfs_prop_to_name(prop);
510 	uint64_t number;
511 	char reason[64];
512 	int i;
513 
514 	/*
515 	 * Check to see if this a read-only property.
516 	 */
517 	if (zfs_prop_readonly(prop)) {
518 		zfs_error(dgettext(TEXT_DOMAIN,
519 		    "cannot set %s property: read-only property"), propname);
520 		return (-1);
521 	}
522 
523 	/* See if the property value is too long */
524 	if (strlen(value) >= ZFS_MAXPROPLEN) {
525 		zfs_error(dgettext(TEXT_DOMAIN,
526 		    "bad %s value '%s': value is too long"), propname,
527 		    value);
528 		return (-1);
529 	}
530 
531 	/* Perform basic checking based on property type */
532 	switch (zfs_prop_get_type(prop)) {
533 	case prop_type_boolean:
534 		if (strcmp(value, "on") == 0) {
535 			number = 1;
536 		} else if (strcmp(value, "off") == 0) {
537 			number = 0;
538 		} else {
539 			zfs_error(dgettext(TEXT_DOMAIN,
540 			    "bad %s value '%s': must be 'on' or 'off'"),
541 			    propname, value);
542 			return (-1);
543 		}
544 		break;
545 
546 	case prop_type_number:
547 		/* treat 'none' as 0 */
548 		if (strcmp(value, "none") == 0) {
549 			number = 0;
550 			break;
551 		}
552 
553 		if (nicestrtonum(value, &number, reason,
554 		    sizeof (reason)) != 0) {
555 			zfs_error(dgettext(TEXT_DOMAIN,
556 			    "bad %s value '%s': %s"), propname, value,
557 			    reason);
558 			return (-1);
559 		}
560 
561 		/* don't allow 0 for quota, use 'none' instead */
562 		if (prop == ZFS_PROP_QUOTA && number == 0 &&
563 		    strcmp(value, "none") != 0) {
564 			zfs_error(dgettext(TEXT_DOMAIN,
565 			    "bad %s value '%s': use '%s=none' to disable"),
566 			    propname, value, propname);
567 			return (-1);
568 		}
569 
570 		/* must be power of two within SPA_{MIN,MAX}BLOCKSIZE */
571 		if (prop == ZFS_PROP_RECORDSIZE ||
572 		    prop == ZFS_PROP_VOLBLOCKSIZE) {
573 			if (number < SPA_MINBLOCKSIZE ||
574 			    number > SPA_MAXBLOCKSIZE || !ISP2(number)) {
575 				zfs_error(dgettext(TEXT_DOMAIN,
576 				    "bad %s value '%s': "
577 				    "must be power of 2 from %u to %uk"),
578 				    propname, value,
579 				    (uint_t)SPA_MINBLOCKSIZE,
580 				    (uint_t)SPA_MAXBLOCKSIZE >> 10);
581 				return (-1);
582 			}
583 		}
584 
585 		break;
586 
587 	case prop_type_string:
588 	case prop_type_index:
589 		/*
590 		 * The two writable string values, 'mountpoint' and
591 		 * 'checksum' need special consideration.  The 'index' types are
592 		 * specified as strings by the user, but passed to the kernel as
593 		 * integers.
594 		 */
595 		switch (prop) {
596 		case ZFS_PROP_MOUNTPOINT:
597 			if (strcmp(value, ZFS_MOUNTPOINT_NONE) == 0 ||
598 			    strcmp(value, ZFS_MOUNTPOINT_LEGACY) == 0)
599 				break;
600 
601 			if (value[0] != '/') {
602 				zfs_error(dgettext(TEXT_DOMAIN,
603 				    "bad %s value '%s': must be an absolute "
604 				    "path, 'none', or 'legacy'"),
605 				    propname, value);
606 				return (-1);
607 			}
608 			break;
609 
610 		case ZFS_PROP_CHECKSUM:
611 			for (i = 0; checksum_table[i].name != NULL; i++) {
612 				if (strcmp(value, checksum_table[i].name)
613 				    == 0) {
614 					number = checksum_table[i].value;
615 					break;
616 				}
617 			}
618 
619 			if (checksum_table[i].name == NULL) {
620 				zfs_error(dgettext(TEXT_DOMAIN,
621 				    "bad %s value '%s': must be 'on', 'off', "
622 				    "'fletcher2', 'fletcher4', or 'sha256'"),
623 				    propname, value);
624 				return (-1);
625 			}
626 			break;
627 
628 		case ZFS_PROP_COMPRESSION:
629 			for (i = 0; compress_table[i].name != NULL; i++) {
630 				if (strcmp(value, compress_table[i].name)
631 				    == 0) {
632 					number = compress_table[i].value;
633 					break;
634 				}
635 			}
636 
637 			if (compress_table[i].name == NULL) {
638 				zfs_error(dgettext(TEXT_DOMAIN,
639 				    "bad %s value '%s': must be 'on', 'off', "
640 				    "or 'lzjb'"),
641 				    propname, value);
642 				return (-1);
643 			}
644 			break;
645 
646 		case ZFS_PROP_SNAPDIR:
647 			for (i = 0; snapdir_table[i].name != NULL; i++) {
648 				if (strcmp(value, snapdir_table[i].name) == 0) {
649 					number = snapdir_table[i].value;
650 					break;
651 				}
652 			}
653 
654 			if (snapdir_table[i].name == NULL) {
655 				zfs_error(dgettext(TEXT_DOMAIN,
656 				    "bad %s value '%s': must be 'hidden' "
657 				    "or 'visible'"),
658 				    propname, value);
659 				return (-1);
660 			}
661 			break;
662 
663 		case ZFS_PROP_ACLMODE:
664 			for (i = 0; acl_mode_table[i].name != NULL; i++) {
665 				if (strcmp(value, acl_mode_table[i].name)
666 				    == 0) {
667 					number = acl_mode_table[i].value;
668 					break;
669 				}
670 			}
671 
672 			if (acl_mode_table[i].name == NULL) {
673 				zfs_error(dgettext(TEXT_DOMAIN,
674 				    "bad %s value '%s': must be 'discard', "
675 				    "'groupmask' or 'passthrough'"),
676 				    propname, value);
677 				return (-1);
678 			}
679 			break;
680 
681 		case ZFS_PROP_ACLINHERIT:
682 			for (i = 0; acl_inherit_table[i].name != NULL; i++) {
683 				if (strcmp(value, acl_inherit_table[i].name)
684 				    == 0) {
685 					number = acl_inherit_table[i].value;
686 					break;
687 				}
688 			}
689 
690 			if (acl_inherit_table[i].name == NULL) {
691 				zfs_error(dgettext(TEXT_DOMAIN,
692 				    "bad %s value '%s': must be 'discard', "
693 				    "'noallow', 'secure' or 'passthrough'"),
694 				    propname, value);
695 				return (-1);
696 			}
697 			break;
698 
699 		case ZFS_PROP_SHARENFS:
700 			/*
701 			 * Nothing to do for 'sharenfs', this gets passed on to
702 			 * share(1M) verbatim.
703 			 */
704 			break;
705 		}
706 	}
707 
708 	if (intval != NULL)
709 		*intval = number;
710 
711 	return (0);
712 }
713 
714 /*
715  * Given a property name and value, set the property for the given dataset.
716  */
717 int
718 zfs_prop_set(zfs_handle_t *zhp, zfs_prop_t prop, const char *propval)
719 {
720 	const char *propname = zfs_prop_to_name(prop);
721 	uint64_t number;
722 	zfs_cmd_t zc = { 0 };
723 	int ret;
724 	prop_changelist_t *cl;
725 
726 	if (zfs_prop_validate(prop, propval, &number) != 0)
727 		return (-1);
728 
729 	/*
730 	 * Check to see if the value applies to this type
731 	 */
732 	if (!zfs_prop_valid_for_type(prop, zhp->zfs_type)) {
733 		zfs_error(dgettext(TEXT_DOMAIN,
734 		    "cannot set %s for '%s': property does not apply to %ss"),
735 		    propname, zhp->zfs_name, zfs_type_to_name(zhp->zfs_type));
736 		return (-1);
737 	}
738 
739 	/*
740 	 * For the mountpoint and sharenfs properties, check if it can be set
741 	 * in a global/non-global zone based on the zoned property value:
742 	 *
743 	 *		global zone	    non-global zone
744 	 * -----------------------------------------------------
745 	 * zoned=on	mountpoint (no)	    mountpoint (yes)
746 	 *		sharenfs (no)	    sharenfs (no)
747 	 *
748 	 * zoned=off	mountpoint (yes)	N/A
749 	 *		sharenfs (yes)
750 	 */
751 	if (prop == ZFS_PROP_MOUNTPOINT || prop == ZFS_PROP_SHARENFS) {
752 		if (zfs_prop_get_int(zhp, ZFS_PROP_ZONED)) {
753 			if (getzoneid() == GLOBAL_ZONEID) {
754 				zfs_error(dgettext(TEXT_DOMAIN,
755 				    "cannot set %s for '%s': "
756 				    "dataset is used in a non-global zone"),
757 				    propname, zhp->zfs_name);
758 				return (-1);
759 			} else if (prop == ZFS_PROP_SHARENFS) {
760 				zfs_error(dgettext(TEXT_DOMAIN,
761 				    "cannot set %s for '%s': filesystems "
762 				    "cannot be shared in a non-global zone"),
763 				    propname, zhp->zfs_name);
764 				return (-1);
765 			}
766 		} else if (getzoneid() != GLOBAL_ZONEID) {
767 			/*
768 			 * If zoned property is 'off', this must be in
769 			 * a globle zone. If not, something is wrong.
770 			 */
771 			zfs_error(dgettext(TEXT_DOMAIN,
772 			    "cannot set %s for '%s': dataset is "
773 			    "used in a non-global zone, but 'zoned' "
774 			    "property is not set"),
775 			    propname, zhp->zfs_name);
776 			return (-1);
777 		}
778 	}
779 
780 	if ((cl = changelist_gather(zhp, prop, 0)) == NULL)
781 		return (-1);
782 
783 	if (prop == ZFS_PROP_MOUNTPOINT && changelist_haszonedchild(cl)) {
784 		zfs_error(dgettext(TEXT_DOMAIN, "cannot set %s for '%s', "
785 			"child dataset with inherited mountpoint is used "
786 			"in a non-global zone"),
787 			propname, zhp->zfs_name);
788 		ret = -1;
789 		goto error;
790 	}
791 
792 	if ((ret = changelist_prefix(cl)) != 0)
793 		goto error;
794 
795 	/*
796 	 * Execute the corresponding ioctl() to set this property.
797 	 */
798 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
799 
800 	switch (prop) {
801 	case ZFS_PROP_QUOTA:
802 		zc.zc_cookie = number;
803 		ret = ioctl(zfs_fd, ZFS_IOC_SET_QUOTA, &zc);
804 		break;
805 	case ZFS_PROP_RESERVATION:
806 		zc.zc_cookie = number;
807 		ret = ioctl(zfs_fd, ZFS_IOC_SET_RESERVATION, &zc);
808 		break;
809 	case ZFS_PROP_MOUNTPOINT:
810 	case ZFS_PROP_SHARENFS:
811 		/*
812 		 * These properties are passed down as real strings.
813 		 */
814 		(void) strlcpy(zc.zc_prop_name, propname,
815 		    sizeof (zc.zc_prop_name));
816 		(void) strlcpy(zc.zc_prop_value, propval,
817 		    sizeof (zc.zc_prop_value));
818 		zc.zc_intsz = 1;
819 		zc.zc_numints = strlen(propval) + 1;
820 		ret = ioctl(zfs_fd, ZFS_IOC_SET_PROP, &zc);
821 		break;
822 	case ZFS_PROP_VOLSIZE:
823 		zc.zc_volsize = number;
824 		ret = ioctl(zfs_fd, ZFS_IOC_SET_VOLSIZE, &zc);
825 		break;
826 	case ZFS_PROP_VOLBLOCKSIZE:
827 		zc.zc_volblocksize = number;
828 		ret = ioctl(zfs_fd, ZFS_IOC_SET_VOLBLOCKSIZE, &zc);
829 		break;
830 	default:
831 		(void) strlcpy(zc.zc_prop_name, propname,
832 		    sizeof (zc.zc_prop_name));
833 		/* LINTED - alignment */
834 		*(uint64_t *)zc.zc_prop_value = number;
835 		zc.zc_intsz = 8;
836 		zc.zc_numints = 1;
837 		ret = ioctl(zfs_fd, ZFS_IOC_SET_PROP, &zc);
838 		break;
839 	}
840 
841 	if (ret != 0) {
842 		switch (errno) {
843 
844 		case EPERM:
845 			zfs_error(dgettext(TEXT_DOMAIN,
846 			    "cannot set %s for '%s': permission "
847 			    "denied"), propname, zhp->zfs_name);
848 			break;
849 
850 		case ENOENT:
851 			zfs_error(dgettext(TEXT_DOMAIN,
852 			    "cannot open '%s': no such %s"), zhp->zfs_name,
853 			    zfs_type_to_name(zhp->zfs_type));
854 			break;
855 
856 		case ENOSPC:
857 			/*
858 			 * For quotas and reservations, ENOSPC indicates
859 			 * something different; setting a quota or reservation
860 			 * doesn't use any disk space.
861 			 */
862 			switch (prop) {
863 			case ZFS_PROP_QUOTA:
864 				zfs_error(dgettext(TEXT_DOMAIN, "cannot set %s "
865 				    "for '%s': size is less than current "
866 				    "used or reserved space"), propname,
867 				    zhp->zfs_name);
868 				break;
869 
870 			case ZFS_PROP_RESERVATION:
871 				zfs_error(dgettext(TEXT_DOMAIN, "cannot set %s "
872 				    "for '%s': size is greater than available "
873 				    "space"), propname, zhp->zfs_name);
874 				break;
875 
876 			default:
877 				zfs_error(dgettext(TEXT_DOMAIN,
878 				    "cannot set %s for '%s': out of space"),
879 				    propname, zhp->zfs_name);
880 				break;
881 			}
882 			break;
883 
884 		case EBUSY:
885 			if (prop == ZFS_PROP_VOLBLOCKSIZE) {
886 				zfs_error(dgettext(TEXT_DOMAIN,
887 				    "cannot set %s for '%s': "
888 				    "volume already contains data"),
889 				    propname, zhp->zfs_name);
890 			} else {
891 				zfs_baderror(errno);
892 			}
893 			break;
894 
895 		case EROFS:
896 			zfs_error(dgettext(TEXT_DOMAIN, "cannot set %s for "
897 			    "'%s': read only %s"), propname, zhp->zfs_name,
898 			    zfs_type_to_name(zhp->zfs_type));
899 			break;
900 
901 		case EOVERFLOW:
902 			/*
903 			 * This platform can't address a volume this big.
904 			 */
905 #ifdef _ILP32
906 			if (prop == ZFS_PROP_VOLSIZE) {
907 				zfs_error(dgettext(TEXT_DOMAIN,
908 				    "cannot set %s for '%s': "
909 				    "max volume size is 1TB on 32-bit systems"),
910 				    propname, zhp->zfs_name);
911 				break;
912 			}
913 #endif
914 			zfs_baderror(errno);
915 		default:
916 			zfs_baderror(errno);
917 		}
918 	} else {
919 		/*
920 		 * Refresh the statistics so the new property value
921 		 * is reflected.
922 		 */
923 		if ((ret = changelist_postfix(cl)) != 0)
924 			goto error;
925 
926 		(void) get_stats(zhp);
927 	}
928 
929 error:
930 	changelist_free(cl);
931 	return (ret);
932 }
933 
934 /*
935  * Given a property, inherit the value from the parent dataset.
936  */
937 int
938 zfs_prop_inherit(zfs_handle_t *zhp, zfs_prop_t prop)
939 {
940 	const char *propname = zfs_prop_to_name(prop);
941 	zfs_cmd_t zc = { 0 };
942 	int ret;
943 	prop_changelist_t *cl;
944 
945 	/*
946 	 * Verify that this property is inheritable.
947 	 */
948 	if (zfs_prop_readonly(prop)) {
949 		zfs_error(dgettext(TEXT_DOMAIN,
950 		    "cannot inherit %s for '%s': property is read-only"),
951 		    propname, zhp->zfs_name);
952 		return (-1);
953 	}
954 
955 	if (!zfs_prop_inheritable(prop)) {
956 		zfs_error(dgettext(TEXT_DOMAIN,
957 		    "cannot inherit %s for '%s': property is not inheritable"),
958 		    propname, zhp->zfs_name);
959 		return (-1);
960 	}
961 
962 	/*
963 	 * Check to see if the value applies to this type
964 	 */
965 	if (!zfs_prop_valid_for_type(prop, zhp->zfs_type)) {
966 		zfs_error(dgettext(TEXT_DOMAIN,
967 		    "cannot inherit %s for '%s': property does "
968 		    "not apply to %ss"), propname, zhp->zfs_name,
969 		    zfs_type_to_name(zhp->zfs_type));
970 		return (-1);
971 	}
972 
973 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
974 	(void) strlcpy(zc.zc_prop_name, propname, sizeof (zc.zc_prop_name));
975 
976 	if (prop == ZFS_PROP_MOUNTPOINT && getzoneid() == GLOBAL_ZONEID &&
977 	    zfs_prop_get_int(zhp, ZFS_PROP_ZONED)) {
978 		zfs_error(dgettext(TEXT_DOMAIN, "cannot inherit %s for '%s', "
979 		    "dataset is used in a non-global zone"), propname,
980 		    zhp->zfs_name);
981 		return (-1);
982 	}
983 
984 	/*
985 	 * Determine datasets which will be affected by this change, if any.
986 	 */
987 	if ((cl = changelist_gather(zhp, prop, 0)) == NULL)
988 		return (-1);
989 
990 	if (prop == ZFS_PROP_MOUNTPOINT && changelist_haszonedchild(cl)) {
991 		zfs_error(dgettext(TEXT_DOMAIN, "cannot inherit %s for '%s', "
992 			"child dataset with inherited mountpoint is "
993 			"used in a non-global zone"),
994 			propname, zhp->zfs_name);
995 		ret = -1;
996 		goto error;
997 	}
998 
999 	if ((ret = changelist_prefix(cl)) != 0)
1000 		goto error;
1001 
1002 	zc.zc_numints = 0;
1003 
1004 	if ((ret = ioctl(zfs_fd, ZFS_IOC_SET_PROP, &zc)) != 0) {
1005 		switch (errno) {
1006 		case EPERM:
1007 			zfs_error(dgettext(TEXT_DOMAIN,
1008 			    "cannot inherit %s for '%s': permission "
1009 			    "denied"), propname, zhp->zfs_name);
1010 			break;
1011 		case ENOENT:
1012 			zfs_error(dgettext(TEXT_DOMAIN,
1013 			    "cannot open '%s': no such %s"), zhp->zfs_name,
1014 			    zfs_type_to_name(zhp->zfs_type));
1015 			break;
1016 		case ENOSPC:
1017 			zfs_error(dgettext(TEXT_DOMAIN,
1018 			    "cannot inherit %s for '%s': "
1019 			    "out of space"), propname, zhp->zfs_name);
1020 			break;
1021 		default:
1022 			zfs_baderror(errno);
1023 		}
1024 
1025 	} else {
1026 
1027 		if ((ret = changelist_postfix(cl)) != 0)
1028 			goto error;
1029 
1030 		/*
1031 		 * Refresh the statistics so the new property is reflected.
1032 		 */
1033 		(void) get_stats(zhp);
1034 	}
1035 
1036 
1037 error:
1038 	changelist_free(cl);
1039 	return (ret);
1040 }
1041 
1042 static void
1043 nicebool(int value, char *buf, size_t buflen)
1044 {
1045 	if (value)
1046 		(void) strlcpy(buf, "on", buflen);
1047 	else
1048 		(void) strlcpy(buf, "off", buflen);
1049 }
1050 
1051 /*
1052  * True DSL properties are stored in an nvlist.  The following two functions
1053  * extract them appropriately.
1054  */
1055 static uint64_t
1056 getprop_uint64(zfs_handle_t *zhp, zfs_prop_t prop, char **source)
1057 {
1058 	nvlist_t *nv;
1059 	uint64_t value;
1060 
1061 	if (nvlist_lookup_nvlist(zhp->zfs_props,
1062 	    zfs_prop_to_name(prop), &nv) == 0) {
1063 		verify(nvlist_lookup_uint64(nv, ZFS_PROP_VALUE, &value) == 0);
1064 		verify(nvlist_lookup_string(nv, ZFS_PROP_SOURCE, source) == 0);
1065 	} else {
1066 		value = zfs_prop_default_numeric(prop);
1067 		*source = "";
1068 	}
1069 
1070 	return (value);
1071 }
1072 
1073 static char *
1074 getprop_string(zfs_handle_t *zhp, zfs_prop_t prop, char **source)
1075 {
1076 	nvlist_t *nv;
1077 	char *value;
1078 
1079 	if (nvlist_lookup_nvlist(zhp->zfs_props,
1080 	    zfs_prop_to_name(prop), &nv) == 0) {
1081 		verify(nvlist_lookup_string(nv, ZFS_PROP_VALUE, &value) == 0);
1082 		verify(nvlist_lookup_string(nv, ZFS_PROP_SOURCE, source) == 0);
1083 	} else {
1084 		if ((value = (char *)zfs_prop_default_string(prop)) == NULL)
1085 			value = "";
1086 		*source = "";
1087 	}
1088 
1089 	return (value);
1090 }
1091 
1092 /*
1093  * Internal function for getting a numeric property.  Both zfs_prop_get() and
1094  * zfs_prop_get_int() are built using this interface.
1095  *
1096  * Certain properties can be overridden using 'mount -o'.  In this case, scan
1097  * the contents of the /etc/mnttab entry, searching for the appropriate options.
1098  * If they differ from the on-disk values, report the current values and mark
1099  * the source "temporary".
1100  */
1101 static uint64_t
1102 get_numeric_property(zfs_handle_t *zhp, zfs_prop_t prop, zfs_source_t *src,
1103     char **source)
1104 {
1105 	uint64_t val;
1106 	struct mnttab mnt;
1107 
1108 	*source = NULL;
1109 
1110 	if (zhp->zfs_mntopts == NULL)
1111 		mnt.mnt_mntopts = "";
1112 	else
1113 		mnt.mnt_mntopts = zhp->zfs_mntopts;
1114 
1115 	switch (prop) {
1116 	case ZFS_PROP_ATIME:
1117 		val = getprop_uint64(zhp, prop, source);
1118 
1119 		if (hasmntopt(&mnt, MNTOPT_ATIME) && !val) {
1120 			val = TRUE;
1121 			if (src)
1122 				*src = ZFS_SRC_TEMPORARY;
1123 		} else if (hasmntopt(&mnt, MNTOPT_NOATIME) && val) {
1124 			val = FALSE;
1125 			if (src)
1126 				*src = ZFS_SRC_TEMPORARY;
1127 		}
1128 		return (val);
1129 
1130 	case ZFS_PROP_AVAILABLE:
1131 		return (zhp->zfs_dmustats.dds_available);
1132 
1133 	case ZFS_PROP_DEVICES:
1134 		val = getprop_uint64(zhp, prop, source);
1135 
1136 		if (hasmntopt(&mnt, MNTOPT_DEVICES) && !val) {
1137 			val = TRUE;
1138 			if (src)
1139 				*src = ZFS_SRC_TEMPORARY;
1140 		} else if (hasmntopt(&mnt, MNTOPT_NODEVICES) && val) {
1141 			val = FALSE;
1142 			if (src)
1143 				*src = ZFS_SRC_TEMPORARY;
1144 		}
1145 		return (val);
1146 
1147 	case ZFS_PROP_EXEC:
1148 		val = getprop_uint64(zhp, prop, source);
1149 
1150 		if (hasmntopt(&mnt, MNTOPT_EXEC) && !val) {
1151 			val = TRUE;
1152 			if (src)
1153 				*src = ZFS_SRC_TEMPORARY;
1154 		} else if (hasmntopt(&mnt, MNTOPT_NOEXEC) && val) {
1155 			val = FALSE;
1156 			if (src)
1157 				*src = ZFS_SRC_TEMPORARY;
1158 		}
1159 		return (val);
1160 
1161 	case ZFS_PROP_RECORDSIZE:
1162 	case ZFS_PROP_COMPRESSION:
1163 	case ZFS_PROP_ZONED:
1164 		val = getprop_uint64(zhp, prop, source);
1165 		return (val);
1166 
1167 	case ZFS_PROP_READONLY:
1168 		val = getprop_uint64(zhp, prop, source);
1169 
1170 		if (hasmntopt(&mnt, MNTOPT_RO) && !val) {
1171 			val = TRUE;
1172 			if (src)
1173 				*src = ZFS_SRC_TEMPORARY;
1174 		} else if (hasmntopt(&mnt, MNTOPT_RW) && val) {
1175 			val = FALSE;
1176 			if (src)
1177 				*src = ZFS_SRC_TEMPORARY;
1178 		}
1179 		return (val);
1180 
1181 	case ZFS_PROP_QUOTA:
1182 		if (zhp->zfs_dmustats.dds_quota == 0)
1183 			*source = "";	/* default */
1184 		else
1185 			*source = zhp->zfs_name;
1186 		return (zhp->zfs_dmustats.dds_quota);
1187 
1188 	case ZFS_PROP_RESERVATION:
1189 		if (zhp->zfs_dmustats.dds_reserved == 0)
1190 			*source = "";	/* default */
1191 		else
1192 			*source = zhp->zfs_name;
1193 		return (zhp->zfs_dmustats.dds_reserved);
1194 
1195 	case ZFS_PROP_COMPRESSRATIO:
1196 		/*
1197 		 * Using physical space and logical space, calculate the
1198 		 * compression ratio.  We return the number as a multiple of
1199 		 * 100, so '2.5x' would be returned as 250.
1200 		 */
1201 		if (zhp->zfs_dmustats.dds_compressed_bytes == 0)
1202 			return (100ULL);
1203 		else
1204 			return (zhp->zfs_dmustats.dds_uncompressed_bytes * 100 /
1205 			    zhp->zfs_dmustats.dds_compressed_bytes);
1206 
1207 	case ZFS_PROP_REFERENCED:
1208 		/*
1209 		 * 'referenced' refers to the amount of physical space
1210 		 * referenced (possibly shared) by this object.
1211 		 */
1212 		return (zhp->zfs_dmustats.dds_space_refd);
1213 
1214 	case ZFS_PROP_SETUID:
1215 		val = getprop_uint64(zhp, prop, source);
1216 
1217 		if (hasmntopt(&mnt, MNTOPT_SETUID) && !val) {
1218 			val = TRUE;
1219 			if (src)
1220 				*src = ZFS_SRC_TEMPORARY;
1221 		} else if (hasmntopt(&mnt, MNTOPT_NOSETUID) && val) {
1222 			val = FALSE;
1223 			if (src)
1224 				*src = ZFS_SRC_TEMPORARY;
1225 		}
1226 		return (val);
1227 
1228 	case ZFS_PROP_VOLSIZE:
1229 		return (zhp->zfs_volsize);
1230 
1231 	case ZFS_PROP_VOLBLOCKSIZE:
1232 		return (zhp->zfs_volblocksize);
1233 
1234 	case ZFS_PROP_USED:
1235 		return (zhp->zfs_dmustats.dds_space_used);
1236 
1237 	case ZFS_PROP_CREATETXG:
1238 		return (zhp->zfs_dmustats.dds_creation_txg);
1239 
1240 	case ZFS_PROP_MOUNTED:
1241 		/*
1242 		 * Unlike other properties, we defer calculation of 'MOUNTED'
1243 		 * until actually requested.  This is because the getmntany()
1244 		 * call can be extremely expensive on systems with a large
1245 		 * number of filesystems, and the property isn't needed in
1246 		 * normal use cases.
1247 		 */
1248 		if (zhp->zfs_mntopts == NULL) {
1249 			struct mnttab search = { 0 }, entry;
1250 
1251 			search.mnt_special = (char *)zhp->zfs_name;
1252 			rewind(mnttab_file);
1253 
1254 			if (getmntany(mnttab_file, &entry, &search) == 0)
1255 				zhp->zfs_mntopts =
1256 				    zfs_strdup(entry.mnt_mntopts);
1257 		}
1258 		return (zhp->zfs_mntopts != NULL);
1259 
1260 	default:
1261 		zfs_baderror(EINVAL);
1262 	}
1263 
1264 	return (0);
1265 }
1266 
1267 /*
1268  * Calculate the source type, given the raw source string.
1269  */
1270 static void
1271 get_source(zfs_handle_t *zhp, zfs_source_t *srctype, char *source,
1272     char *statbuf, size_t statlen)
1273 {
1274 	if (statbuf == NULL || *srctype == ZFS_SRC_TEMPORARY)
1275 		return;
1276 
1277 	if (source == NULL) {
1278 		*srctype = ZFS_SRC_NONE;
1279 	} else if (source[0] == '\0') {
1280 		*srctype = ZFS_SRC_DEFAULT;
1281 	} else {
1282 		if (strcmp(source, zhp->zfs_name) == 0) {
1283 			*srctype = ZFS_SRC_LOCAL;
1284 		} else {
1285 			(void) strlcpy(statbuf, source, statlen);
1286 			*srctype = ZFS_SRC_INHERITED;
1287 		}
1288 	}
1289 
1290 }
1291 
1292 /*
1293  * Retrieve a property from the given object.  If 'literal' is specified, then
1294  * numbers are left as exact values.  Otherwise, numbers are converted to a
1295  * human-readable form.
1296  *
1297  * Returns 0 on success, or -1 on error.
1298  */
1299 int
1300 zfs_prop_get(zfs_handle_t *zhp, zfs_prop_t prop, char *propbuf, size_t proplen,
1301     zfs_source_t *src, char *statbuf, size_t statlen, int literal)
1302 {
1303 	char *source = NULL;
1304 	uint64_t val;
1305 	char *str;
1306 	int i;
1307 	const char *root;
1308 
1309 	/*
1310 	 * Check to see if this property applies to our object
1311 	 */
1312 	if (!zfs_prop_valid_for_type(prop, zhp->zfs_type))
1313 		return (-1);
1314 
1315 	if (src)
1316 		*src = ZFS_SRC_NONE;
1317 
1318 	switch (prop) {
1319 	case ZFS_PROP_ATIME:
1320 	case ZFS_PROP_READONLY:
1321 	case ZFS_PROP_SETUID:
1322 	case ZFS_PROP_ZONED:
1323 	case ZFS_PROP_DEVICES:
1324 	case ZFS_PROP_EXEC:
1325 		/*
1326 		 * Basic boolean values are built on top of
1327 		 * get_numeric_property().
1328 		 */
1329 		nicebool(get_numeric_property(zhp, prop, src, &source),
1330 		    propbuf, proplen);
1331 
1332 		break;
1333 
1334 	case ZFS_PROP_AVAILABLE:
1335 	case ZFS_PROP_RECORDSIZE:
1336 	case ZFS_PROP_CREATETXG:
1337 	case ZFS_PROP_REFERENCED:
1338 	case ZFS_PROP_USED:
1339 	case ZFS_PROP_VOLSIZE:
1340 	case ZFS_PROP_VOLBLOCKSIZE:
1341 		/*
1342 		 * Basic numeric values are built on top of
1343 		 * get_numeric_property().
1344 		 */
1345 		val = get_numeric_property(zhp, prop, src, &source);
1346 		if (literal)
1347 			(void) snprintf(propbuf, proplen, "%llu", val);
1348 		else
1349 			zfs_nicenum(val, propbuf, proplen);
1350 		break;
1351 
1352 	case ZFS_PROP_COMPRESSION:
1353 		val = getprop_uint64(zhp, prop, &source);
1354 		for (i = 0; compress_table[i].name != NULL; i++) {
1355 			if (compress_table[i].value == val)
1356 				break;
1357 		}
1358 		assert(compress_table[i].name != NULL);
1359 		(void) strlcpy(propbuf, compress_table[i].name, proplen);
1360 		break;
1361 
1362 	case ZFS_PROP_CHECKSUM:
1363 		val = getprop_uint64(zhp, prop, &source);
1364 		for (i = 0; checksum_table[i].name != NULL; i++) {
1365 			if (checksum_table[i].value == val)
1366 				break;
1367 		}
1368 		assert(checksum_table[i].name != NULL);
1369 		(void) strlcpy(propbuf, checksum_table[i].name, proplen);
1370 		break;
1371 
1372 	case ZFS_PROP_SNAPDIR:
1373 		val = getprop_uint64(zhp, prop, &source);
1374 		for (i = 0; snapdir_table[i].name != NULL; i++) {
1375 			if (snapdir_table[i].value == val)
1376 				break;
1377 		}
1378 		assert(snapdir_table[i].name != NULL);
1379 		(void) strlcpy(propbuf, snapdir_table[i].name, proplen);
1380 		break;
1381 
1382 	case ZFS_PROP_ACLMODE:
1383 		val = getprop_uint64(zhp, prop, &source);
1384 		for (i = 0; acl_mode_table[i].name != NULL; i++) {
1385 			if (acl_mode_table[i].value == val)
1386 				break;
1387 		}
1388 		assert(acl_mode_table[i].name != NULL);
1389 		(void) strlcpy(propbuf, acl_mode_table[i].name, proplen);
1390 		break;
1391 
1392 	case ZFS_PROP_ACLINHERIT:
1393 		val = getprop_uint64(zhp, prop, &source);
1394 		for (i = 0; acl_inherit_table[i].name != NULL; i++) {
1395 			if (acl_inherit_table[i].value == val)
1396 				break;
1397 		}
1398 		assert(acl_inherit_table[i].name != NULL);
1399 		(void) strlcpy(propbuf, acl_inherit_table[i].name, proplen);
1400 		break;
1401 
1402 	case ZFS_PROP_CREATION:
1403 		/*
1404 		 * 'creation' is a time_t stored in the statistics.  We convert
1405 		 * this into a string unless 'literal' is specified.
1406 		 */
1407 		{
1408 			time_t time = (time_t)
1409 			    zhp->zfs_dmustats.dds_creation_time;
1410 			struct tm t;
1411 
1412 			if (literal ||
1413 			    localtime_r(&time, &t) == NULL ||
1414 			    strftime(propbuf, proplen, "%a %b %e %k:%M %Y",
1415 			    &t) == 0)
1416 				(void) snprintf(propbuf, proplen, "%llu",
1417 				    zhp->zfs_dmustats.dds_creation_time);
1418 		}
1419 		break;
1420 
1421 	case ZFS_PROP_MOUNTPOINT:
1422 		/*
1423 		 * Getting the precise mountpoint can be tricky.
1424 		 *
1425 		 *  - for 'none' or 'legacy', return those values.
1426 		 *  - for default mountpoints, construct it as /zfs/<dataset>
1427 		 *  - for inherited mountpoints, we want to take everything
1428 		 *    after our ancestor and append it to the inherited value.
1429 		 *
1430 		 * If the pool has an alternate root, we want to prepend that
1431 		 * root to any values we return.
1432 		 */
1433 		root = zhp->zfs_dmustats.dds_altroot;
1434 		str = getprop_string(zhp, prop, &source);
1435 
1436 		if (str[0] == '\0') {
1437 			(void) snprintf(propbuf, proplen, "%s/zfs/%s",
1438 			    root, zhp->zfs_name);
1439 		} else if (str[0] == '/') {
1440 			const char *relpath = zhp->zfs_name + strlen(source);
1441 
1442 			if (relpath[0] == '/')
1443 				relpath++;
1444 			if (str[1] == '\0')
1445 				str++;
1446 
1447 			if (relpath[0] == '\0')
1448 				(void) snprintf(propbuf, proplen, "%s%s",
1449 				    root, str);
1450 			else
1451 				(void) snprintf(propbuf, proplen, "%s%s%s%s",
1452 				    root, str, relpath[0] == '@' ? "" : "/",
1453 				    relpath);
1454 		} else {
1455 			/* 'legacy' or 'none' */
1456 			(void) strlcpy(propbuf, str, proplen);
1457 		}
1458 
1459 		break;
1460 
1461 	case ZFS_PROP_SHARENFS:
1462 		(void) strlcpy(propbuf, getprop_string(zhp, prop, &source),
1463 		    proplen);
1464 		break;
1465 
1466 	case ZFS_PROP_ORIGIN:
1467 		(void) strlcpy(propbuf, getprop_string(zhp, prop, &source),
1468 		    proplen);
1469 		/*
1470 		 * If there is no parent at all, return failure to indicate that
1471 		 * it doesn't apply to this dataset.
1472 		 */
1473 		if (propbuf[0] == '\0')
1474 			return (-1);
1475 		break;
1476 
1477 	case ZFS_PROP_QUOTA:
1478 	case ZFS_PROP_RESERVATION:
1479 		val = get_numeric_property(zhp, prop, src, &source);
1480 
1481 		/*
1482 		 * If quota or reservation is 0, we translate this into 'none'
1483 		 * (unless literal is set), and indicate that it's the default
1484 		 * value.  Otherwise, we print the number nicely and indicate
1485 		 * that its set locally.
1486 		 */
1487 		if (val == 0) {
1488 			if (literal)
1489 				(void) strlcpy(propbuf, "0", proplen);
1490 			else
1491 				(void) strlcpy(propbuf, "none", proplen);
1492 		} else {
1493 			if (literal)
1494 				(void) snprintf(propbuf, proplen, "%llu", val);
1495 			else
1496 				zfs_nicenum(val, propbuf, proplen);
1497 		}
1498 		break;
1499 
1500 	case ZFS_PROP_COMPRESSRATIO:
1501 		val = get_numeric_property(zhp, prop, src, &source);
1502 		(void) snprintf(propbuf, proplen, "%lld.%02lldx", val / 100,
1503 		    val % 100);
1504 		break;
1505 
1506 	case ZFS_PROP_TYPE:
1507 		switch (zhp->zfs_type) {
1508 		case ZFS_TYPE_FILESYSTEM:
1509 			str = "filesystem";
1510 			break;
1511 		case ZFS_TYPE_VOLUME:
1512 			str = "volume";
1513 			break;
1514 		case ZFS_TYPE_SNAPSHOT:
1515 			str = "snapshot";
1516 			break;
1517 		default:
1518 			zfs_baderror(zhp->zfs_type);
1519 		}
1520 		(void) snprintf(propbuf, proplen, "%s", str);
1521 		break;
1522 
1523 	case ZFS_PROP_MOUNTED:
1524 		/*
1525 		 * The 'mounted' property is a pseudo-property that described
1526 		 * whether the filesystem is currently mounted.  Even though
1527 		 * it's a boolean value, the typical values of "on" and "off"
1528 		 * don't make sense, so we translate to "yes" and "no".
1529 		 */
1530 		if (get_numeric_property(zhp, ZFS_PROP_MOUNTED, src, &source))
1531 			(void) strlcpy(propbuf, "yes", proplen);
1532 		else
1533 			(void) strlcpy(propbuf, "no", proplen);
1534 		break;
1535 
1536 	case ZFS_PROP_NAME:
1537 		/*
1538 		 * The 'name' property is a pseudo-property derived from the
1539 		 * dataset name.  It is presented as a real property to simplify
1540 		 * consumers.
1541 		 */
1542 		(void) strlcpy(propbuf, zhp->zfs_name, proplen);
1543 		break;
1544 
1545 	default:
1546 		zfs_baderror(EINVAL);
1547 	}
1548 
1549 	get_source(zhp, src, source, statbuf, statlen);
1550 
1551 	return (0);
1552 }
1553 
1554 /*
1555  * Utility function to get the given numeric property.  Does no validation that
1556  * the given property is the appropriate type; should only be used with
1557  * hard-coded property types.
1558  */
1559 uint64_t
1560 zfs_prop_get_int(zfs_handle_t *zhp, zfs_prop_t prop)
1561 {
1562 	char *source;
1563 	zfs_source_t sourcetype = ZFS_SRC_NONE;
1564 
1565 	return (get_numeric_property(zhp, prop, &sourcetype, &source));
1566 }
1567 
1568 /*
1569  * Similar to zfs_prop_get(), but returns the value as an integer.
1570  */
1571 int
1572 zfs_prop_get_numeric(zfs_handle_t *zhp, zfs_prop_t prop, uint64_t *value,
1573     zfs_source_t *src, char *statbuf, size_t statlen)
1574 {
1575 	char *source;
1576 
1577 	/*
1578 	 * Check to see if this property applies to our object
1579 	 */
1580 	if (!zfs_prop_valid_for_type(prop, zhp->zfs_type))
1581 		return (-1);
1582 
1583 	if (src)
1584 		*src = ZFS_SRC_NONE;
1585 
1586 	*value = get_numeric_property(zhp, prop, src, &source);
1587 
1588 	get_source(zhp, src, source, statbuf, statlen);
1589 
1590 	return (0);
1591 }
1592 
1593 /*
1594  * Returns the name of the given zfs handle.
1595  */
1596 const char *
1597 zfs_get_name(const zfs_handle_t *zhp)
1598 {
1599 	return (zhp->zfs_name);
1600 }
1601 
1602 /*
1603  * Returns the type of the given zfs handle.
1604  */
1605 zfs_type_t
1606 zfs_get_type(const zfs_handle_t *zhp)
1607 {
1608 	return (zhp->zfs_type);
1609 }
1610 
1611 /*
1612  * Iterate over all child filesystems
1613  */
1614 int
1615 zfs_iter_filesystems(zfs_handle_t *zhp, zfs_iter_f func, void *data)
1616 {
1617 	zfs_cmd_t zc = { 0 };
1618 	zfs_handle_t *nzhp;
1619 	int ret;
1620 
1621 	for ((void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
1622 	    ioctl(zfs_fd, ZFS_IOC_DATASET_LIST_NEXT, &zc) == 0;
1623 	    (void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name))) {
1624 		/*
1625 		 * Ignore private dataset names.
1626 		 */
1627 		if (dataset_name_hidden(zc.zc_name))
1628 			continue;
1629 
1630 		/*
1631 		 * Silently ignore errors, as the only plausible explanation is
1632 		 * that the pool has since been removed.
1633 		 */
1634 		if ((nzhp = make_dataset_handle(zc.zc_name)) == NULL)
1635 			continue;
1636 
1637 		if ((ret = func(nzhp, data)) != 0)
1638 			return (ret);
1639 	}
1640 
1641 	/*
1642 	 * An errno value of ESRCH indicates normal completion.  If ENOENT is
1643 	 * returned, then the underlying dataset has been removed since we
1644 	 * obtained the handle.
1645 	 */
1646 	if (errno != ESRCH && errno != ENOENT)
1647 		zfs_baderror(errno);
1648 
1649 	return (0);
1650 }
1651 
1652 /*
1653  * Iterate over all snapshots
1654  */
1655 int
1656 zfs_iter_snapshots(zfs_handle_t *zhp, zfs_iter_f func, void *data)
1657 {
1658 	zfs_cmd_t zc = { 0 };
1659 	zfs_handle_t *nzhp;
1660 	int ret;
1661 
1662 	for ((void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
1663 	    ioctl(zfs_fd, ZFS_IOC_SNAPSHOT_LIST_NEXT, &zc) == 0;
1664 	    (void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name))) {
1665 
1666 		if ((nzhp = make_dataset_handle(zc.zc_name)) == NULL)
1667 			continue;
1668 
1669 		if ((ret = func(nzhp, data)) != 0)
1670 			return (ret);
1671 	}
1672 
1673 	/*
1674 	 * An errno value of ESRCH indicates normal completion.  If ENOENT is
1675 	 * returned, then the underlying dataset has been removed since we
1676 	 * obtained the handle.  Silently ignore this case, and return success.
1677 	 */
1678 	if (errno != ESRCH && errno != ENOENT)
1679 		zfs_baderror(errno);
1680 
1681 	return (0);
1682 }
1683 
1684 /*
1685  * Iterate over all children, snapshots and filesystems
1686  */
1687 int
1688 zfs_iter_children(zfs_handle_t *zhp, zfs_iter_f func, void *data)
1689 {
1690 	int ret;
1691 
1692 	if ((ret = zfs_iter_filesystems(zhp, func, data)) != 0)
1693 		return (ret);
1694 
1695 	return (zfs_iter_snapshots(zhp, func, data));
1696 }
1697 
1698 /*
1699  * Given a complete name, return just the portion that refers to the parent.
1700  * Can return NULL if this is a pool.
1701  */
1702 static int
1703 parent_name(const char *path, char *buf, size_t buflen)
1704 {
1705 	char *loc;
1706 
1707 	if ((loc = strrchr(path, '/')) == NULL)
1708 		return (-1);
1709 
1710 	(void) strncpy(buf, path, MIN(buflen, loc - path));
1711 	buf[loc - path] = '\0';
1712 
1713 	return (0);
1714 }
1715 
1716 /*
1717  * Checks to make sure that the given path has a parent, and that it exists.
1718  */
1719 static int
1720 check_parents(const char *path, zfs_type_t type)
1721 {
1722 	zfs_cmd_t zc = { 0 };
1723 	char parent[ZFS_MAXNAMELEN];
1724 	char *slash;
1725 	zfs_handle_t *zhp;
1726 
1727 	/* get parent, and check to see if this is just a pool */
1728 	if (parent_name(path, parent, sizeof (parent)) != 0) {
1729 		zfs_error(dgettext(TEXT_DOMAIN,
1730 		    "cannot create '%s': missing dataset name"),
1731 		    path, zfs_type_to_name(type));
1732 		zfs_error(dgettext(TEXT_DOMAIN,
1733 		    "use 'zpool create' to create a storage pool"));
1734 		return (-1);
1735 	}
1736 
1737 	/* check to see if the pool exists */
1738 	if ((slash = strchr(parent, '/')) == NULL)
1739 		slash = parent + strlen(parent);
1740 	(void) strncpy(zc.zc_name, parent, slash - parent);
1741 	zc.zc_name[slash - parent] = '\0';
1742 	if (ioctl(zfs_fd, ZFS_IOC_OBJSET_STATS, &zc) != 0 &&
1743 	    errno == ENOENT) {
1744 		zfs_error(dgettext(TEXT_DOMAIN,
1745 		    "cannot create '%s': no such pool '%s'"), path, zc.zc_name);
1746 		return (-1);
1747 	}
1748 
1749 	/* check to see if the parent dataset exists */
1750 	if ((zhp = make_dataset_handle(parent)) == NULL) {
1751 		switch (errno) {
1752 		case ENOENT:
1753 			zfs_error(dgettext(TEXT_DOMAIN,
1754 			    "cannot create '%s': parent does not exist"), path);
1755 			return (-1);
1756 
1757 		default:
1758 			zfs_baderror(errno);
1759 		}
1760 	}
1761 
1762 	/* we are in a non-global zone, but parent is in the global zone */
1763 	if (getzoneid() != GLOBAL_ZONEID &&
1764 	    zfs_prop_get_int(zhp, ZFS_PROP_ZONED)) {
1765 		zfs_error(dgettext(TEXT_DOMAIN,
1766 		    "cannot create '%s': permission denied"), path);
1767 		zfs_close(zhp);
1768 		return (-1);
1769 	}
1770 
1771 	/* make sure parent is a filesystem */
1772 	if (zfs_get_type(zhp) != ZFS_TYPE_FILESYSTEM) {
1773 		zfs_error(dgettext(TEXT_DOMAIN,
1774 		    "cannot create '%s': parent is not a filesystem"),
1775 		    path);
1776 		zfs_close(zhp);
1777 		return (-1);
1778 	}
1779 
1780 	zfs_close(zhp);
1781 	return (0);
1782 }
1783 
1784 /*
1785  * Create a new filesystem or volume.  'sizestr' and 'blocksizestr' are used
1786  * only for volumes, and indicate the size and blocksize of the volume.
1787  */
1788 int
1789 zfs_create(const char *path, zfs_type_t type,
1790 	const char *sizestr, const char *blocksizestr)
1791 {
1792 	char reason[64];
1793 	zfs_cmd_t zc = { 0 };
1794 	int ret;
1795 	uint64_t size = 0;
1796 	uint64_t blocksize = zfs_prop_default_numeric(ZFS_PROP_VOLBLOCKSIZE);
1797 
1798 	/* convert sizestr into integer size */
1799 	if (sizestr != NULL && nicestrtonum(sizestr, &size,
1800 	    reason, sizeof (reason)) != 0) {
1801 		zfs_error(dgettext(TEXT_DOMAIN,
1802 		    "bad volume size '%s': %s"), sizestr, reason);
1803 		return (-1);
1804 	}
1805 
1806 	/* convert blocksizestr into integer blocksize */
1807 	if (blocksizestr != NULL && nicestrtonum(blocksizestr, &blocksize,
1808 	    reason, sizeof (reason)) != 0) {
1809 		zfs_error(dgettext(TEXT_DOMAIN,
1810 		    "bad volume blocksize '%s': %s"), blocksizestr, reason);
1811 		return (-1);
1812 	}
1813 
1814 	/* validate the path, taking care to note the extended error message */
1815 	if (!zfs_validate_name(path, type, reason, sizeof (reason))) {
1816 		zfs_error(dgettext(TEXT_DOMAIN,
1817 		    "cannot create '%s': %s in %s name"), path, reason,
1818 		    zfs_type_to_name(type));
1819 		if (strstr(reason, "snapshot") != NULL)
1820 			zfs_error(dgettext(TEXT_DOMAIN,
1821 			    "use 'zfs snapshot' to create a snapshot"));
1822 		return (-1);
1823 	}
1824 
1825 	/* validate parents exist */
1826 	if (check_parents(path, type) != 0)
1827 		return (-1);
1828 
1829 	/*
1830 	 * The failure modes when creating a dataset of a different type over
1831 	 * one that already exists is a little strange.  In particular, if you
1832 	 * try to create a dataset on top of an existing dataset, the ioctl()
1833 	 * will return ENOENT, not EEXIST.  To prevent this from happening, we
1834 	 * first try to see if the dataset exists.
1835 	 */
1836 	(void) strlcpy(zc.zc_name, path, sizeof (zc.zc_name));
1837 	if (ioctl(zfs_fd, ZFS_IOC_OBJSET_STATS, &zc) == 0) {
1838 		zfs_error(dgettext(TEXT_DOMAIN,
1839 		    "cannot create '%s': dataset exists"), path);
1840 		return (-1);
1841 	}
1842 
1843 	if (type == ZFS_TYPE_VOLUME)
1844 		zc.zc_objset_type = DMU_OST_ZVOL;
1845 	else
1846 		zc.zc_objset_type = DMU_OST_ZFS;
1847 
1848 	if (type == ZFS_TYPE_VOLUME) {
1849 		/*
1850 		 * If we are creating a volume, the size and block size must
1851 		 * satisfy a few restraints.  First, the blocksize must be a
1852 		 * valid block size between SPA_{MIN,MAX}BLOCKSIZE.  Second, the
1853 		 * volsize must be a multiple of the block size, and cannot be
1854 		 * zero.
1855 		 */
1856 		if (size == 0) {
1857 			zfs_error(dgettext(TEXT_DOMAIN,
1858 			    "bad volume size '%s': cannot be zero"), sizestr);
1859 			return (-1);
1860 		}
1861 
1862 		if (blocksize < SPA_MINBLOCKSIZE ||
1863 		    blocksize > SPA_MAXBLOCKSIZE || !ISP2(blocksize)) {
1864 			zfs_error(dgettext(TEXT_DOMAIN,
1865 			    "bad volume block size '%s': "
1866 			    "must be power of 2 from %u to %uk"),
1867 			    blocksizestr,
1868 			    (uint_t)SPA_MINBLOCKSIZE,
1869 			    (uint_t)SPA_MAXBLOCKSIZE >> 10);
1870 			return (-1);
1871 		}
1872 
1873 		if (size % blocksize != 0) {
1874 			char buf[64];
1875 			zfs_nicenum(blocksize, buf, sizeof (buf));
1876 			zfs_error(dgettext(TEXT_DOMAIN,
1877 			    "bad volume size '%s': "
1878 			    "must be multiple of volume block size (%s)"),
1879 			    sizestr, buf);
1880 			return (-1);
1881 		}
1882 
1883 		zc.zc_volsize = size;
1884 		zc.zc_volblocksize = blocksize;
1885 	}
1886 
1887 	/* create the dataset */
1888 	ret = ioctl(zfs_fd, ZFS_IOC_CREATE, &zc);
1889 
1890 	if (ret == 0 && type == ZFS_TYPE_VOLUME)
1891 		ret = zvol_create_link(path);
1892 
1893 	/* check for failure */
1894 	if (ret != 0) {
1895 		char parent[ZFS_MAXNAMELEN];
1896 		(void) parent_name(path, parent, sizeof (parent));
1897 
1898 		switch (errno) {
1899 		case ENOENT:
1900 			/*
1901 			 * The parent dataset has been deleted since our
1902 			 * previous check.
1903 			 */
1904 			zfs_error(dgettext(TEXT_DOMAIN,
1905 			    "cannot create '%s': no such parent '%s'"),
1906 			    path, parent);
1907 			break;
1908 
1909 		case EPERM:
1910 			/*
1911 			 * The user doesn't have permission to create a new
1912 			 * dataset here.
1913 			 */
1914 			zfs_error(dgettext(TEXT_DOMAIN,
1915 			    "cannot create '%s': permission denied"), path);
1916 			break;
1917 
1918 		case EDQUOT:
1919 		case ENOSPC:
1920 			/*
1921 			 * The parent dataset does not have enough free space
1922 			 * to create a new dataset.
1923 			 */
1924 			zfs_error(dgettext(TEXT_DOMAIN,
1925 			    "cannot create '%s': not enough space in '%s'"),
1926 			    path, parent);
1927 			break;
1928 
1929 		case EEXIST:
1930 			/*
1931 			 * The target dataset already exists.  We should have
1932 			 * caught this above, but there may be some unexplained
1933 			 * race condition.
1934 			 */
1935 			zfs_error(dgettext(TEXT_DOMAIN,
1936 			    "cannot create '%s': dataset exists"), path);
1937 			break;
1938 
1939 		case EINVAL:
1940 			/*
1941 			 * The target dataset does not support children.
1942 			 */
1943 			zfs_error(dgettext(TEXT_DOMAIN,
1944 			    "cannot create '%s': children unsupported in '%s'"),
1945 			    path, parent);
1946 			break;
1947 
1948 		case EDOM:
1949 			zfs_error(dgettext(TEXT_DOMAIN, "bad %s value '%s': "
1950 			    "must be power of 2 from %u to %uk"),
1951 			    zfs_prop_to_name(ZFS_PROP_VOLBLOCKSIZE),
1952 			    blocksizestr ? blocksizestr : "<unknown>",
1953 			    (uint_t)SPA_MINBLOCKSIZE,
1954 			    (uint_t)SPA_MAXBLOCKSIZE >> 10);
1955 			break;
1956 #ifdef _ILP32
1957 		case EOVERFLOW:
1958 			/*
1959 			 * This platform can't address a volume this big.
1960 			 */
1961 			if (type == ZFS_TYPE_VOLUME) {
1962 				zfs_error(dgettext(TEXT_DOMAIN,
1963 				    "cannot create '%s': "
1964 				    "max volume size is 1TB on 32-bit systems"),
1965 				    path);
1966 				break;
1967 			}
1968 #endif
1969 
1970 		default:
1971 			zfs_baderror(errno);
1972 		}
1973 
1974 		return (-1);
1975 	}
1976 
1977 	return (0);
1978 }
1979 
1980 /*
1981  * Destroys the given dataset.  The caller must make sure that the filesystem
1982  * isn't mounted, and that there are no active dependents.
1983  */
1984 int
1985 zfs_destroy(zfs_handle_t *zhp)
1986 {
1987 	zfs_cmd_t zc = { 0 };
1988 	int ret;
1989 
1990 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
1991 
1992 	/*
1993 	 * We use the check for 'zfs_volblocksize' instead of ZFS_TYPE_VOLUME
1994 	 * so that we do the right thing for snapshots of volumes.
1995 	 */
1996 	if (zhp->zfs_volblocksize != 0) {
1997 		if (zvol_remove_link(zhp->zfs_name) != 0)
1998 			return (-1);
1999 
2000 		zc.zc_objset_type = DMU_OST_ZVOL;
2001 	} else {
2002 		zc.zc_objset_type = DMU_OST_ZFS;
2003 	}
2004 
2005 	ret = ioctl(zfs_fd, ZFS_IOC_DESTROY, &zc);
2006 
2007 	if (ret != 0) {
2008 		switch (errno) {
2009 
2010 		case EPERM:
2011 			/*
2012 			 * We don't have permission to destroy this dataset.
2013 			 */
2014 			zfs_error(dgettext(TEXT_DOMAIN,
2015 			    "cannot destroy '%s': permission denied"),
2016 			    zhp->zfs_name);
2017 			break;
2018 
2019 		case ENOENT:
2020 			/*
2021 			 * We've hit a race condition where the dataset has been
2022 			 * destroyed since we opened it.
2023 			 */
2024 			zfs_error(dgettext(TEXT_DOMAIN,
2025 			    "cannot destroy '%s': no such %s"),
2026 			    zhp->zfs_name, zfs_type_to_name(zhp->zfs_type));
2027 			break;
2028 
2029 		case EBUSY:
2030 			/*
2031 			 * Even if we destroy all children, there is a chance we
2032 			 * can hit this case if:
2033 			 *
2034 			 * 	- A child dataset has since been created
2035 			 * 	- A filesystem is mounted
2036 			 *
2037 			 * This error message is awful, but hopefully we've
2038 			 * already caught the common cases (and aborted more
2039 			 * appropriately) before calling this function.  There's
2040 			 * nothing else we can do at this point.
2041 			 */
2042 			zfs_error(dgettext(TEXT_DOMAIN,
2043 			    "cannot destroy '%s': %s is busy"),
2044 			    zhp->zfs_name, zfs_type_to_name(zhp->zfs_type));
2045 			break;
2046 
2047 		default:
2048 			zfs_baderror(errno);
2049 		}
2050 
2051 		return (-1);
2052 	}
2053 
2054 	remove_mountpoint(zhp);
2055 
2056 	return (0);
2057 }
2058 
2059 /*
2060  * Clones the given dataset.  The target must be of the same type as the source.
2061  */
2062 int
2063 zfs_clone(zfs_handle_t *zhp, const char *target)
2064 {
2065 	char reason[64];
2066 	zfs_cmd_t zc = { 0 };
2067 	char parent[ZFS_MAXNAMELEN];
2068 	int ret;
2069 
2070 	assert(zhp->zfs_type == ZFS_TYPE_SNAPSHOT);
2071 
2072 	/* validate the target name */
2073 	if (!zfs_validate_name(target, ZFS_TYPE_FILESYSTEM, reason,
2074 	    sizeof (reason))) {
2075 		zfs_error(dgettext(TEXT_DOMAIN,
2076 		    "cannot create '%s': %s in filesystem name"), target,
2077 		    reason, zfs_type_to_name(ZFS_TYPE_FILESYSTEM));
2078 		return (-1);
2079 	}
2080 
2081 	/* validate parents exist */
2082 	if (check_parents(target, zhp->zfs_type) != 0)
2083 		return (-1);
2084 
2085 	(void) parent_name(target, parent, sizeof (parent));
2086 
2087 	/* do the clone */
2088 	if (zhp->zfs_volblocksize != 0)
2089 		zc.zc_objset_type = DMU_OST_ZVOL;
2090 	else
2091 		zc.zc_objset_type = DMU_OST_ZFS;
2092 
2093 	(void) strlcpy(zc.zc_name, target, sizeof (zc.zc_name));
2094 	(void) strlcpy(zc.zc_filename, zhp->zfs_name, sizeof (zc.zc_filename));
2095 	ret = ioctl(zfs_fd, ZFS_IOC_CREATE, &zc);
2096 
2097 	if (ret != 0) {
2098 		switch (errno) {
2099 		case EPERM:
2100 			/*
2101 			 * The user doesn't have permission to create the clone.
2102 			 */
2103 			zfs_error(dgettext(TEXT_DOMAIN,
2104 			    "cannot create '%s': permission denied"),
2105 			    target);
2106 			break;
2107 
2108 		case ENOENT:
2109 			/*
2110 			 * The parent doesn't exist.  We should have caught this
2111 			 * above, but there may a race condition that has since
2112 			 * destroyed the parent.
2113 			 *
2114 			 * At this point, we don't know whether it's the source
2115 			 * that doesn't exist anymore, or whether the target
2116 			 * dataset doesn't exist.
2117 			 */
2118 			zfs_error(dgettext(TEXT_DOMAIN,
2119 			    "cannot create '%s': no such parent '%s'"),
2120 			    target, parent);
2121 			break;
2122 
2123 		case EDQUOT:
2124 		case ENOSPC:
2125 			/*
2126 			 * There is not enough space in the target dataset
2127 			 */
2128 			zfs_error(dgettext(TEXT_DOMAIN,
2129 			    "cannot create '%s': not enough space in '%s'"),
2130 			    target, parent);
2131 			break;
2132 
2133 		case EEXIST:
2134 			/*
2135 			 * The target already exists.
2136 			 */
2137 			zfs_error(dgettext(TEXT_DOMAIN,
2138 			    "cannot create '%s': dataset exists"), target);
2139 			break;
2140 
2141 		case EXDEV:
2142 			/*
2143 			 * The source and target pools differ.
2144 			 */
2145 			zfs_error(dgettext(TEXT_DOMAIN, "cannot create '%s': "
2146 			    "source and target pools differ"), target);
2147 			break;
2148 
2149 		default:
2150 			zfs_baderror(errno);
2151 		}
2152 	} else if (zhp->zfs_volblocksize != 0) {
2153 		ret = zvol_create_link(target);
2154 	}
2155 
2156 	return (ret);
2157 }
2158 
2159 /*
2160  * Takes a snapshot of the given dataset
2161  */
2162 int
2163 zfs_snapshot(const char *path)
2164 {
2165 	char reason[64];
2166 	const char *delim;
2167 	char *parent;
2168 	zfs_handle_t *zhp;
2169 	zfs_cmd_t zc = { 0 };
2170 	int ret;
2171 
2172 	/* validate the snapshot name */
2173 	if (!zfs_validate_name(path, ZFS_TYPE_SNAPSHOT, reason,
2174 	    sizeof (reason))) {
2175 		zfs_error(dgettext(TEXT_DOMAIN,
2176 		    "cannot snapshot '%s': %s in snapshot name"), path,
2177 		    reason);
2178 		return (-1);
2179 	}
2180 
2181 	/* make sure we have a snapshot */
2182 	if ((delim = strchr(path, '@')) == NULL) {
2183 		zfs_error(dgettext(TEXT_DOMAIN,
2184 		    "cannot snapshot '%s': missing '@' delim in snapshot "
2185 		    "name"), path);
2186 		zfs_error(dgettext(TEXT_DOMAIN,
2187 		    "use 'zfs create' to create a filesystem"));
2188 		return (-1);
2189 	}
2190 
2191 	/* make sure the parent exists and is of the appropriate type */
2192 	parent = zfs_malloc(delim - path + 1);
2193 	(void) strncpy(parent, path, delim - path);
2194 	parent[delim - path] = '\0';
2195 
2196 	if ((zhp = zfs_open(parent, ZFS_TYPE_FILESYSTEM |
2197 	    ZFS_TYPE_VOLUME)) == NULL) {
2198 		free(parent);
2199 		return (-1);
2200 	}
2201 
2202 	(void) strlcpy(zc.zc_name, path, sizeof (zc.zc_name));
2203 
2204 	if (zhp->zfs_type == ZFS_TYPE_VOLUME)
2205 		zc.zc_objset_type = DMU_OST_ZVOL;
2206 	else
2207 		zc.zc_objset_type = DMU_OST_ZFS;
2208 
2209 	ret = ioctl(zfs_fd, ZFS_IOC_CREATE, &zc);
2210 
2211 	if (ret == 0 && zhp->zfs_type == ZFS_TYPE_VOLUME) {
2212 		ret = zvol_create_link(path);
2213 		if (ret != 0)
2214 			(void) ioctl(zfs_fd, ZFS_IOC_DESTROY, &zc);
2215 	}
2216 
2217 	if (ret != 0) {
2218 		switch (errno) {
2219 		case EPERM:
2220 			/*
2221 			 * User doesn't have permission to create a snapshot
2222 			 */
2223 			zfs_error(dgettext(TEXT_DOMAIN, "cannot create '%s': "
2224 			    "permission denied"), path);
2225 			break;
2226 
2227 		case EDQUOT:
2228 		case ENOSPC:
2229 			/*
2230 			 * Out of space in parent.
2231 			 */
2232 			zfs_error(dgettext(TEXT_DOMAIN, "cannot create '%s': "
2233 			    "not enough space in '%s'"), path, parent);
2234 			break;
2235 
2236 		case EEXIST:
2237 			/*
2238 			 * Snapshot already exists.
2239 			 */
2240 			zfs_error(dgettext(TEXT_DOMAIN, "cannot create '%s': "
2241 			    "snapshot exists"), path);
2242 			break;
2243 
2244 		case ENOENT:
2245 			/*
2246 			 * Shouldn't happen because we verified the parent
2247 			 * above.  But there may be a race condition where it
2248 			 * has since been removed.
2249 			 */
2250 			zfs_error(dgettext(TEXT_DOMAIN, "cannot open '%s': "
2251 			    "no such %s"), parent,
2252 			    zfs_type_to_name(zhp->zfs_type));
2253 			break;
2254 
2255 		default:
2256 			zfs_baderror(errno);
2257 		}
2258 	}
2259 
2260 	free(parent);
2261 	zfs_close(zhp);
2262 
2263 	return (ret);
2264 }
2265 
2266 /*
2267  * Dumps a backup of tosnap, incremental from fromsnap if it isn't NULL.
2268  */
2269 int
2270 zfs_backup(zfs_handle_t *zhp_to, zfs_handle_t *zhp_from)
2271 {
2272 	zfs_cmd_t zc = { 0 };
2273 	int ret;
2274 
2275 	/* do the ioctl() */
2276 	(void) strlcpy(zc.zc_name, zhp_to->zfs_name, sizeof (zc.zc_name));
2277 	if (zhp_from) {
2278 		(void) strlcpy(zc.zc_prop_value, zhp_from->zfs_name,
2279 		    sizeof (zc.zc_name));
2280 	} else {
2281 		zc.zc_prop_value[0] = '\0';
2282 	}
2283 	zc.zc_cookie = STDOUT_FILENO;
2284 
2285 	ret = ioctl(zfs_fd, ZFS_IOC_SENDBACKUP, &zc);
2286 	if (ret != 0) {
2287 		switch (errno) {
2288 		case EPERM:
2289 			/*
2290 			 * User doesn't have permission to do a backup
2291 			 */
2292 			zfs_error(dgettext(TEXT_DOMAIN, "cannot backup '%s': "
2293 			    "permission denied"), zhp_to->zfs_name);
2294 			break;
2295 
2296 		case EXDEV:
2297 			zfs_error(dgettext(TEXT_DOMAIN,
2298 			    "cannot do incremental backup from %s:\n"
2299 			    "it is not an earlier snapshot from the "
2300 			    "same fs as %s"),
2301 			    zhp_from->zfs_name, zhp_to->zfs_name);
2302 			break;
2303 
2304 		case ENOENT:
2305 			/*
2306 			 * Shouldn't happen because we verified the parent
2307 			 * above.  But there may be a race condition where it
2308 			 * has since been removed.
2309 			 */
2310 			zfs_error(dgettext(TEXT_DOMAIN, "cannot open: "
2311 			    "no such snapshot"));
2312 			break;
2313 
2314 		case EDQUOT:
2315 		case EFBIG:
2316 		case EIO:
2317 		case ENOLINK:
2318 		case ENOSPC:
2319 		case ENOSTR:
2320 		case ENXIO:
2321 		case EPIPE:
2322 		case ERANGE:
2323 		case EFAULT:
2324 		case EROFS:
2325 			zfs_error(dgettext(TEXT_DOMAIN,
2326 			    "cannot write backup stream: %s"),
2327 			    strerror(errno));
2328 			break;
2329 
2330 		case EINTR:
2331 			zfs_error(dgettext(TEXT_DOMAIN,
2332 			    "backup failed: signal recieved"));
2333 			break;
2334 
2335 		default:
2336 			zfs_baderror(errno);
2337 		}
2338 	}
2339 
2340 	return (ret);
2341 }
2342 
2343 /*
2344  * Restores a backup of tosnap from stdin.
2345  */
2346 int
2347 zfs_restore(const char *tosnap, int isprefix, int verbose, int dryrun)
2348 {
2349 	zfs_cmd_t zc = { 0 };
2350 	time_t begin_time;
2351 	int ioctl_err, err, bytes, size;
2352 	char *cp;
2353 	dmu_replay_record_t drr;
2354 	struct drr_begin *drrb = &zc.zc_begin_record;
2355 
2356 	begin_time = time(NULL);
2357 
2358 	/* trim off snapname, if any */
2359 	(void) strcpy(zc.zc_name, tosnap);
2360 	cp = strchr(zc.zc_name, '@');
2361 	if (cp)
2362 		*cp = '\0';
2363 
2364 	/* read in the BEGIN record */
2365 	cp = (char *)&drr;
2366 	bytes = 0;
2367 	do {
2368 		size = read(STDIN_FILENO, cp, sizeof (drr) - bytes);
2369 		cp += size;
2370 		bytes += size;
2371 	} while (size > 0);
2372 
2373 	if (size < 0 || bytes != sizeof (drr)) {
2374 		zfs_error(dgettext(TEXT_DOMAIN,
2375 		    "cannot restore: invalid backup stream "
2376 		    "(couldn't read first record)"));
2377 		return (-1);
2378 	}
2379 
2380 	zc.zc_begin_record = drr.drr_u.drr_begin;
2381 
2382 	if (drrb->drr_magic != DMU_BACKUP_MAGIC &&
2383 	    drrb->drr_magic != BSWAP_64(DMU_BACKUP_MAGIC)) {
2384 		zfs_error(dgettext(TEXT_DOMAIN,
2385 		    "cannot restore: invalid backup stream "
2386 		    "(invalid magic number)"));
2387 		return (-1);
2388 	}
2389 
2390 	if (drrb->drr_version != DMU_BACKUP_VERSION &&
2391 	    drrb->drr_version != BSWAP_64(DMU_BACKUP_VERSION)) {
2392 		if (drrb->drr_magic == BSWAP_64(DMU_BACKUP_MAGIC))
2393 			drrb->drr_version = BSWAP_64(drrb->drr_version);
2394 		zfs_error(dgettext(TEXT_DOMAIN,
2395 		    "cannot restore: only backup version 0x%llx is supported, "
2396 		    "stream is version %llx."),
2397 		    DMU_BACKUP_VERSION, drrb->drr_version);
2398 		return (-1);
2399 	}
2400 
2401 	/*
2402 	 * Determine name of destination snapshot.
2403 	 */
2404 	(void) strcpy(drrb->drr_toname, tosnap);
2405 	if (isprefix) {
2406 		if (strchr(tosnap, '@') != NULL) {
2407 			zfs_error(dgettext(TEXT_DOMAIN,
2408 			    "cannot restore: "
2409 			    "argument to -d must be a filesystem"));
2410 			return (-1);
2411 		}
2412 
2413 		cp = strchr(drr.drr_u.drr_begin.drr_toname, '/');
2414 		if (cp == NULL)
2415 			cp = drr.drr_u.drr_begin.drr_toname;
2416 		else
2417 			cp++;
2418 
2419 		(void) strcat(drrb->drr_toname, "/");
2420 		(void) strcat(drrb->drr_toname, cp);
2421 	} else if (strchr(tosnap, '@') == NULL) {
2422 		/*
2423 		 * they specified just a filesystem; tack on the
2424 		 * snapname from the backup.
2425 		 */
2426 		cp = strchr(drr.drr_u.drr_begin.drr_toname, '@');
2427 		if (cp == NULL || strlen(tosnap) + strlen(cp) >= MAXNAMELEN) {
2428 			zfs_error(dgettext(TEXT_DOMAIN,
2429 			    "cannot restore: invalid backup stream "
2430 			    "(invalid snapshot name)"));
2431 			return (-1);
2432 		}
2433 		(void) strcat(drrb->drr_toname, cp);
2434 	}
2435 
2436 	if (drrb->drr_fromguid) {
2437 		zfs_handle_t *h;
2438 		/* incremental backup stream */
2439 
2440 		/* do the ioctl to the containing fs */
2441 		(void) strcpy(zc.zc_name, drrb->drr_toname);
2442 		cp = strchr(zc.zc_name, '@');
2443 		*cp = '\0';
2444 
2445 		/* make sure destination fs exists */
2446 		h = zfs_open(zc.zc_name, ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME);
2447 		if (h == NULL) {
2448 			zfs_error(dgettext(TEXT_DOMAIN,
2449 			    "cannot restore incrememtal backup: destination\n"
2450 			    "filesystem %s does not exist"),
2451 			    zc.zc_name);
2452 			return (-1);
2453 		}
2454 		if (!dryrun) {
2455 			/* unmount destination fs or remove device link. */
2456 			if (h->zfs_type == ZFS_TYPE_FILESYSTEM) {
2457 				(void) zfs_unmount(h, NULL, 0);
2458 			} else {
2459 				(void) zvol_remove_link(h->zfs_name);
2460 			}
2461 		}
2462 		zfs_close(h);
2463 	} else {
2464 		/* full backup stream */
2465 
2466 		(void) strcpy(zc.zc_name, drrb->drr_toname);
2467 
2468 		/* make sure they aren't trying to restore into the root */
2469 		if (strchr(zc.zc_name, '/') == NULL) {
2470 			cp = strchr(zc.zc_name, '@');
2471 			if (cp)
2472 				*cp = '\0';
2473 			zfs_error(dgettext(TEXT_DOMAIN,
2474 			    "cannot restore: destination fs %s already exists"),
2475 			    zc.zc_name);
2476 			return (-1);
2477 		}
2478 
2479 		if (isprefix) {
2480 			zfs_handle_t *h;
2481 
2482 			/* make sure prefix exists */
2483 			h = zfs_open(tosnap, ZFS_TYPE_FILESYSTEM |
2484 			    ZFS_TYPE_VOLUME);
2485 			if (h == NULL) {
2486 				zfs_error(dgettext(TEXT_DOMAIN,
2487 				    "cannot restore: "
2488 				    "filesystem %s does not exist"),
2489 				    tosnap);
2490 				return (-1);
2491 			}
2492 
2493 			/* create any necessary ancestors up to prefix */
2494 			zc.zc_objset_type = DMU_OST_ZFS;
2495 			/*
2496 			 * zc.zc_name is now the full name of the snap
2497 			 * we're restoring into
2498 			 */
2499 			cp = zc.zc_name + strlen(tosnap) + 1;
2500 			while (cp = strchr(cp, '/')) {
2501 				*cp = '\0';
2502 				err = ioctl(zfs_fd, ZFS_IOC_CREATE, &zc);
2503 				if (err && errno != ENOENT && errno != EEXIST) {
2504 					zfs_error(dgettext(TEXT_DOMAIN,
2505 					    "cannot restore: "
2506 					    "couldn't create ancestor %s"),
2507 					    zc.zc_name);
2508 					return (-1);
2509 				}
2510 				*cp = '/';
2511 				cp++;
2512 			}
2513 		}
2514 
2515 		/* Make sure destination fs does not exist */
2516 		cp = strchr(zc.zc_name, '@');
2517 		*cp = '\0';
2518 		if (ioctl(zfs_fd, ZFS_IOC_OBJSET_STATS, &zc) == 0) {
2519 			zfs_error(dgettext(TEXT_DOMAIN,
2520 			    "cannot restore full backup: "
2521 			    "destination filesystem %s already exists"),
2522 			    zc.zc_name);
2523 			return (-1);
2524 		}
2525 
2526 		/* Do the recvbackup ioctl to the fs's parent. */
2527 		cp = strrchr(zc.zc_name, '/');
2528 		*cp = '\0';
2529 	}
2530 
2531 	(void) strcpy(zc.zc_prop_value, tosnap);
2532 	zc.zc_cookie = STDIN_FILENO;
2533 	zc.zc_intsz = isprefix;
2534 	if (verbose) {
2535 		(void) printf("%s %s backup of %s into %s\n",
2536 		    dryrun ? "would restore" : "restoring",
2537 		    drrb->drr_fromguid ? "incremental" : "full",
2538 		    drr.drr_u.drr_begin.drr_toname,
2539 		    zc.zc_begin_record.drr_toname);
2540 		(void) fflush(stdout);
2541 	}
2542 	if (dryrun)
2543 		return (0);
2544 	err = ioctl_err = ioctl(zfs_fd, ZFS_IOC_RECVBACKUP, &zc);
2545 	if (ioctl_err != 0) {
2546 		switch (errno) {
2547 		case ENODEV:
2548 			zfs_error(dgettext(TEXT_DOMAIN,
2549 			    "cannot restore: "
2550 			    "most recent snapshot does not "
2551 			    "match incremental backup source"));
2552 			break;
2553 		case ETXTBSY:
2554 			zfs_error(dgettext(TEXT_DOMAIN,
2555 			    "cannot restore: "
2556 			    "destination has been modified since "
2557 			    "most recent snapshot --\n"
2558 			    "use 'zfs rollback' to discard changes"));
2559 			break;
2560 		case EEXIST:
2561 			if (drrb->drr_fromguid == 0) {
2562 				/* it's the containing fs that exists */
2563 				cp = strchr(drrb->drr_toname, '@');
2564 				*cp = '\0';
2565 			}
2566 			zfs_error(dgettext(TEXT_DOMAIN,
2567 			    "cannot restore to %s: destination already exists"),
2568 			    drrb->drr_toname);
2569 			break;
2570 		case ENOENT:
2571 			zfs_error(dgettext(TEXT_DOMAIN,
2572 			    "cannot restore: destination does not exist"));
2573 			break;
2574 		case EBUSY:
2575 			zfs_error(dgettext(TEXT_DOMAIN,
2576 			    "cannot restore: destination is in use"));
2577 			break;
2578 		case ENOSPC:
2579 			zfs_error(dgettext(TEXT_DOMAIN,
2580 			    "cannot restore: out of space"));
2581 			break;
2582 		case EDQUOT:
2583 			zfs_error(dgettext(TEXT_DOMAIN,
2584 			    "cannot restore: quota exceeded"));
2585 			break;
2586 		case EINTR:
2587 			zfs_error(dgettext(TEXT_DOMAIN,
2588 			    "restore failed: signal recieved"));
2589 			break;
2590 		case EINVAL:
2591 			zfs_error(dgettext(TEXT_DOMAIN,
2592 			    "cannot restore: invalid backup stream"));
2593 			break;
2594 		case EPERM:
2595 			zfs_error(dgettext(TEXT_DOMAIN,
2596 			    "cannot restore: permission denied"));
2597 			break;
2598 		default:
2599 			zfs_baderror(errno);
2600 		}
2601 	}
2602 
2603 	/*
2604 	 * Mount or recreate the /dev links for the target filesystem
2605 	 * (if created, or if we tore them down to do an incremental
2606 	 * restore), and the /dev links for the new snapshot (if
2607 	 * created).
2608 	 */
2609 	cp = strchr(drrb->drr_toname, '@');
2610 	if (cp && (ioctl_err == 0 || drrb->drr_fromguid)) {
2611 		zfs_handle_t *h;
2612 
2613 		*cp = '\0';
2614 		h = zfs_open(drrb->drr_toname,
2615 		    ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME);
2616 		*cp = '@';
2617 		if (h) {
2618 			if (h->zfs_type == ZFS_TYPE_FILESYSTEM) {
2619 				err = zfs_mount(h, NULL, 0);
2620 			} else {
2621 				err = zvol_create_link(h->zfs_name);
2622 				if (err == 0 && ioctl_err == 0) {
2623 					err =
2624 					    zvol_create_link(drrb->drr_toname);
2625 				}
2626 			}
2627 			zfs_close(h);
2628 		}
2629 	}
2630 
2631 	if (err || ioctl_err)
2632 		return (-1);
2633 
2634 	if (verbose) {
2635 		char buf1[64];
2636 		char buf2[64];
2637 		uint64_t bytes = zc.zc_cookie;
2638 		time_t delta = time(NULL) - begin_time;
2639 		if (delta == 0)
2640 			delta = 1;
2641 		zfs_nicenum(bytes, buf1, sizeof (buf1));
2642 		zfs_nicenum(bytes/delta, buf2, sizeof (buf1));
2643 
2644 		(void) printf("restored %sb backup in %lu seconds (%sb/sec)\n",
2645 		    buf1, delta, buf2);
2646 	}
2647 	return (0);
2648 }
2649 
2650 /*
2651  * Destroy any more recent snapshots.  We invoke this callback on any dependents
2652  * of the snapshot first.  If the 'cb_dependent' member is non-zero, then this
2653  * is a dependent and we should just destroy it without checking the transaction
2654  * group.
2655  */
2656 typedef struct rollback_data {
2657 	const char	*cb_target;		/* the snapshot */
2658 	uint64_t	cb_create;		/* creation time reference */
2659 	prop_changelist_t *cb_clp;		/* changelist pointer */
2660 	int		cb_error;
2661 	int		cb_dependent;
2662 } rollback_data_t;
2663 
2664 static int
2665 rollback_destroy(zfs_handle_t *zhp, void *data)
2666 {
2667 	rollback_data_t *cbp = data;
2668 
2669 	if (!cbp->cb_dependent) {
2670 		if (strcmp(zhp->zfs_name, cbp->cb_target) != 0 &&
2671 		    zfs_get_type(zhp) == ZFS_TYPE_SNAPSHOT &&
2672 		    zfs_prop_get_int(zhp, ZFS_PROP_CREATETXG) >
2673 		    cbp->cb_create) {
2674 
2675 			cbp->cb_dependent = TRUE;
2676 			(void) zfs_iter_dependents(zhp, rollback_destroy, cbp);
2677 			cbp->cb_dependent = FALSE;
2678 
2679 			if (zfs_destroy(zhp) != 0)
2680 				cbp->cb_error = 1;
2681 			else
2682 				changelist_remove(zhp, cbp->cb_clp);
2683 		}
2684 	} else {
2685 		if (zfs_destroy(zhp) != 0)
2686 			cbp->cb_error = 1;
2687 		else
2688 			changelist_remove(zhp, cbp->cb_clp);
2689 	}
2690 
2691 	zfs_close(zhp);
2692 	return (0);
2693 }
2694 
2695 /*
2696  * Rollback the dataset to its latest snapshot.
2697  */
2698 static int
2699 do_rollback(zfs_handle_t *zhp)
2700 {
2701 	int ret;
2702 	zfs_cmd_t zc = { 0 };
2703 
2704 	assert(zhp->zfs_type == ZFS_TYPE_FILESYSTEM ||
2705 	    zhp->zfs_type == ZFS_TYPE_VOLUME);
2706 
2707 	if (zhp->zfs_type == ZFS_TYPE_VOLUME &&
2708 	    zvol_remove_link(zhp->zfs_name) != 0)
2709 		return (-1);
2710 
2711 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
2712 
2713 	if (zhp->zfs_volblocksize != 0)
2714 		zc.zc_objset_type = DMU_OST_ZVOL;
2715 	else
2716 		zc.zc_objset_type = DMU_OST_ZFS;
2717 
2718 	/*
2719 	 * We rely on the consumer to verify that there are no newer snapshots
2720 	 * for the given dataset.  Given these constraints, we can simply pass
2721 	 * the name on to the ioctl() call.  There is still an unlikely race
2722 	 * condition where the user has taken a snapshot since we verified that
2723 	 * this was the most recent.
2724 	 */
2725 	if ((ret = ioctl(zfs_fd, ZFS_IOC_ROLLBACK, &zc)) != 0) {
2726 		switch (errno) {
2727 		case EPERM:
2728 			/*
2729 			 * The user doesn't have permission to rollback the
2730 			 * given dataset.
2731 			 */
2732 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rollback '%s': "
2733 			    "permission denied"), zhp->zfs_name);
2734 			break;
2735 
2736 		case EDQUOT:
2737 		case ENOSPC:
2738 			/*
2739 			 * The parent dataset doesn't have enough space to
2740 			 * rollback to the last snapshot.
2741 			 */
2742 			{
2743 				char parent[ZFS_MAXNAMELEN];
2744 				(void) parent_name(zhp->zfs_name, parent,
2745 				    sizeof (parent));
2746 				zfs_error(dgettext(TEXT_DOMAIN, "cannot "
2747 				    "rollback '%s': out of space"), parent);
2748 			}
2749 			break;
2750 
2751 		case ENOENT:
2752 			/*
2753 			 * The dataset doesn't exist.  This shouldn't happen
2754 			 * except in race conditions.
2755 			 */
2756 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rollback '%s': "
2757 			    "no such %s"), zhp->zfs_name,
2758 			    zfs_type_to_name(zhp->zfs_type));
2759 			break;
2760 
2761 		case EBUSY:
2762 			/*
2763 			 * The filesystem is busy.  This should have been caught
2764 			 * by the caller before getting here, but there may be
2765 			 * an unexpected problem.
2766 			 */
2767 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rollback '%s': "
2768 			    "%s is busy"), zhp->zfs_name,
2769 			    zfs_type_to_name(zhp->zfs_type));
2770 			break;
2771 
2772 		default:
2773 			zfs_baderror(errno);
2774 		}
2775 	} else if (zhp->zfs_type == ZFS_TYPE_VOLUME) {
2776 		ret = zvol_create_link(zhp->zfs_name);
2777 	}
2778 
2779 	return (ret);
2780 }
2781 
2782 /*
2783  * Given a dataset, rollback to a specific snapshot, discarding any
2784  * data changes since then and making it the active dataset.
2785  *
2786  * Any snapshots more recent than the target are destroyed, along with
2787  * their dependents.
2788  */
2789 int
2790 zfs_rollback(zfs_handle_t *zhp, zfs_handle_t *snap, int flag)
2791 {
2792 	int ret;
2793 	rollback_data_t cb = { 0 };
2794 	prop_changelist_t *clp;
2795 
2796 	/*
2797 	 * Unmount all dependendents of the dataset and the dataset itself.
2798 	 * The list we need to gather is the same as for doing rename
2799 	 */
2800 	clp = changelist_gather(zhp, ZFS_PROP_NAME, flag ? MS_FORCE: 0);
2801 	if (clp == NULL)
2802 		return (-1);
2803 
2804 	if ((ret = changelist_prefix(clp)) != 0)
2805 		goto out;
2806 
2807 	/*
2808 	 * Destroy all recent snapshots and its dependends.
2809 	 */
2810 	cb.cb_target = snap->zfs_name;
2811 	cb.cb_create = zfs_prop_get_int(snap, ZFS_PROP_CREATETXG);
2812 	cb.cb_clp = clp;
2813 	(void) zfs_iter_children(zhp, rollback_destroy, &cb);
2814 
2815 	if ((ret = cb.cb_error) != 0) {
2816 		(void) changelist_postfix(clp);
2817 		goto out;
2818 	}
2819 
2820 	/*
2821 	 * Now that we have verified that the snapshot is the latest,
2822 	 * rollback to the given snapshot.
2823 	 */
2824 	ret = do_rollback(zhp);
2825 
2826 	if (ret != 0) {
2827 		(void) changelist_postfix(clp);
2828 		goto out;
2829 	}
2830 
2831 	/*
2832 	 * We only want to re-mount the filesystem if it was mounted in the
2833 	 * first place.
2834 	 */
2835 	ret = changelist_postfix(clp);
2836 
2837 out:
2838 	changelist_free(clp);
2839 	return (ret);
2840 }
2841 
2842 /*
2843  * Iterate over all dependents for a given dataset.  This includes both
2844  * hierarchical dependents (children) and data dependents (snapshots and
2845  * clones).  The bulk of the processing occurs in get_dependents() in
2846  * libzfs_graph.c.
2847  */
2848 int
2849 zfs_iter_dependents(zfs_handle_t *zhp, zfs_iter_f func, void *data)
2850 {
2851 	char **dependents;
2852 	size_t count;
2853 	int i;
2854 	zfs_handle_t *child;
2855 	int ret = 0;
2856 
2857 	dependents = get_dependents(zhp->zfs_name, &count);
2858 	for (i = 0; i < count; i++) {
2859 		if ((child = make_dataset_handle(dependents[i])) == NULL)
2860 			continue;
2861 
2862 		if ((ret = func(child, data)) != 0)
2863 			break;
2864 	}
2865 
2866 	for (i = 0; i < count; i++)
2867 		free(dependents[i]);
2868 	free(dependents);
2869 
2870 	return (ret);
2871 }
2872 
2873 /*
2874  * Renames the given dataset.
2875  */
2876 int
2877 zfs_rename(zfs_handle_t *zhp, const char *target)
2878 {
2879 	int ret;
2880 	zfs_cmd_t zc = { 0 };
2881 	char reason[64];
2882 	char *delim;
2883 	prop_changelist_t *cl;
2884 	char parent[ZFS_MAXNAMELEN];
2885 
2886 	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));
2887 	(void) strlcpy(zc.zc_prop_value, target, sizeof (zc.zc_prop_value));
2888 
2889 	/* if we have the same exact name, just return success */
2890 	if (strcmp(zhp->zfs_name, target) == 0)
2891 		return (0);
2892 
2893 	/*
2894 	 * Make sure the target name is valid
2895 	 */
2896 	if (!zfs_validate_name(target, zhp->zfs_type, reason,
2897 	    sizeof (reason))) {
2898 		zfs_error(dgettext(TEXT_DOMAIN,
2899 		    "cannot create '%s': %s in %s name"), target, reason,
2900 		    zfs_type_to_name(zhp->zfs_type));
2901 		return (-1);
2902 	}
2903 
2904 	if (zhp->zfs_type == ZFS_TYPE_SNAPSHOT) {
2905 		if ((delim = strchr(target, '@')) == NULL) {
2906 			zfs_error(dgettext(TEXT_DOMAIN,
2907 			    "cannot rename to '%s': not a snapshot"), target);
2908 			return (-1);
2909 		}
2910 
2911 		/*
2912 		 * Make sure we're renaming within the same dataset.
2913 		 */
2914 		if (strncmp(zhp->zfs_name, target, delim - target) != 0 ||
2915 		    zhp->zfs_name[delim - target] != '@') {
2916 			zfs_error(dgettext(TEXT_DOMAIN,
2917 			    "cannot rename to '%s': snapshots must be part "
2918 			    "of same dataset"), target);
2919 			return (-1);
2920 		}
2921 
2922 		(void) strncpy(parent, target, delim - target);
2923 		parent[delim - target] = '\0';
2924 	} else {
2925 		/* validate parents */
2926 		if (check_parents(target, zhp->zfs_type) != 0)
2927 			return (-1);
2928 
2929 		(void) parent_name(target, parent, sizeof (parent));
2930 
2931 		/* make sure we're in the same pool */
2932 		verify((delim = strchr(target, '/')) != NULL);
2933 		if (strncmp(zhp->zfs_name, target, delim - target) != 0 ||
2934 		    zhp->zfs_name[delim - target] != '/') {
2935 			zfs_error(dgettext(TEXT_DOMAIN,
2936 			    "cannot rename to '%s': "
2937 			    "datasets must be within same pool"), target);
2938 			return (-1);
2939 		}
2940 	}
2941 
2942 	if (getzoneid() == GLOBAL_ZONEID &&
2943 	    zfs_prop_get_int(zhp, ZFS_PROP_ZONED)) {
2944 		zfs_error(dgettext(TEXT_DOMAIN, "cannot rename %s, "
2945 		    "dataset is used in a non-global zone"), zhp->zfs_name);
2946 		return (-1);
2947 	}
2948 
2949 	if ((cl = changelist_gather(zhp, ZFS_PROP_NAME, 0)) == NULL)
2950 		return (1);
2951 
2952 	if (changelist_haszonedchild(cl)) {
2953 		zfs_error(dgettext(TEXT_DOMAIN,
2954 		    "cannot rename '%s': child dataset with inherited "
2955 		    "mountpoint is used in a non-global zone"), zhp->zfs_name);
2956 		ret = -1;
2957 		goto error;
2958 	}
2959 
2960 	if ((ret = changelist_prefix(cl)) != 0)
2961 		goto error;
2962 
2963 	if (zhp->zfs_volblocksize != 0)
2964 		zc.zc_objset_type = DMU_OST_ZVOL;
2965 	else
2966 		zc.zc_objset_type = DMU_OST_ZFS;
2967 
2968 	if ((ret = ioctl(zfs_fd, ZFS_IOC_RENAME, &zc)) != 0) {
2969 		switch (errno) {
2970 		case EPERM:
2971 			/*
2972 			 * The user doesn't have permission to rename the
2973 			 * given dataset.
2974 			 */
2975 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rename '%s': "
2976 			    "permission denied"), zhp->zfs_name);
2977 			break;
2978 
2979 		case EDQUOT:
2980 		case ENOSPC:
2981 			/*
2982 			 * Not enough space in the parent dataset.
2983 			 */
2984 			zfs_error(dgettext(TEXT_DOMAIN, "cannot "
2985 			    "rename '%s': not enough space in '%s'"),
2986 			    zhp->zfs_name, parent);
2987 			break;
2988 
2989 		case ENOENT:
2990 			/*
2991 			 * The destination doesn't exist.
2992 			 */
2993 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rename '%s' "
2994 			    "to '%s': destination doesn't exist"),
2995 			    zhp->zfs_name, target);
2996 			break;
2997 
2998 		case EEXIST:
2999 			/*
3000 			 * The destination already exists.
3001 			 */
3002 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rename '%s' "
3003 			    "to '%s': destination already exists"),
3004 			    zhp->zfs_name, target);
3005 			break;
3006 
3007 		case EBUSY:
3008 			/*
3009 			 * The filesystem is busy.  This should have been caught
3010 			 * by the caller before getting here, but there may be
3011 			 * an unexpected problem.
3012 			 */
3013 			zfs_error(dgettext(TEXT_DOMAIN, "cannot rename '%s': "
3014 			    "%s is busy"), zhp->zfs_name,
3015 			    zfs_type_to_name(zhp->zfs_type));
3016 			break;
3017 
3018 		default:
3019 			zfs_baderror(errno);
3020 		}
3021 
3022 		/*
3023 		 * On failure, we still want to remount any filesystems that
3024 		 * were previously mounted, so we don't alter the system state.
3025 		 */
3026 		(void) changelist_postfix(cl);
3027 	} else {
3028 		changelist_rename(cl, zfs_get_name(zhp), target);
3029 
3030 		ret = changelist_postfix(cl);
3031 	}
3032 
3033 error:
3034 	changelist_free(cl);
3035 	return (ret);
3036 }
3037 
3038 /*
3039  * Given a zvol dataset, issue the ioctl to create the appropriate minor node,
3040  * poke devfsadm to create the /dev link, and then wait for the link to appear.
3041  */
3042 int
3043 zvol_create_link(const char *dataset)
3044 {
3045 	zfs_cmd_t zc = { 0 };
3046 	di_devlink_handle_t hdl;
3047 
3048 	(void) strlcpy(zc.zc_name, dataset, sizeof (zc.zc_name));
3049 
3050 	/*
3051 	 * Issue the appropriate ioctl.
3052 	 */
3053 	if (ioctl(zfs_fd, ZFS_IOC_CREATE_MINOR, &zc) != 0) {
3054 		switch (errno) {
3055 		case EPERM:
3056 			zfs_error(dgettext(TEXT_DOMAIN, "cannot create "
3057 			    "device links for '%s': permission denied"),
3058 			    dataset);
3059 			break;
3060 
3061 		case EEXIST:
3062 			/*
3063 			 * Silently ignore the case where the link already
3064 			 * exists.  This allows 'zfs volinit' to be run multiple
3065 			 * times without errors.
3066 			 */
3067 			return (0);
3068 
3069 		default:
3070 			zfs_baderror(errno);
3071 		}
3072 
3073 		return (-1);
3074 	}
3075 
3076 	/*
3077 	 * Call devfsadm and wait for the links to magically appear.
3078 	 */
3079 	if ((hdl = di_devlink_init(ZFS_DRIVER, DI_MAKE_LINK)) == NULL) {
3080 		zfs_error(dgettext(TEXT_DOMAIN,
3081 		    "cannot create device links for '%s'"), dataset);
3082 		(void) ioctl(zfs_fd, ZFS_IOC_REMOVE_MINOR, &zc);
3083 		return (-1);
3084 	} else {
3085 		(void) di_devlink_fini(&hdl);
3086 	}
3087 
3088 	return (0);
3089 }
3090 
3091 /*
3092  * Remove a minor node for the given zvol and the associated /dev links.
3093  */
3094 int
3095 zvol_remove_link(const char *dataset)
3096 {
3097 	zfs_cmd_t zc = { 0 };
3098 
3099 	(void) strlcpy(zc.zc_name, dataset, sizeof (zc.zc_name));
3100 
3101 	if (ioctl(zfs_fd, ZFS_IOC_REMOVE_MINOR, &zc) != 0) {
3102 		switch (errno) {
3103 		case EPERM:
3104 			zfs_error(dgettext(TEXT_DOMAIN, "cannot remove "
3105 			    "device links for '%s': permission denied"),
3106 			    dataset);
3107 			break;
3108 
3109 		case EBUSY:
3110 			zfs_error(dgettext(TEXT_DOMAIN, "cannot remove "
3111 			    "device links for '%s': volume is in use"),
3112 			    dataset);
3113 			break;
3114 
3115 		case ENXIO:
3116 			/*
3117 			 * Silently ignore the case where the link no longer
3118 			 * exists, so that 'zfs volfini' can be run multiple
3119 			 * times without errors.
3120 			 */
3121 			return (0);
3122 
3123 		default:
3124 			zfs_baderror(errno);
3125 		}
3126 
3127 		return (-1);
3128 	}
3129 
3130 	return (0);
3131 }
3132