diff options
| author | Keith M Wesolowski <wesolows@foobazco.org> | 2013-08-27 00:59:04 +0000 | 
|---|---|---|
| committer | Keith M Wesolowski <wesolows@foobazco.org> | 2013-08-27 00:59:04 +0000 | 
| commit | 7bf5a6f485b8d8bb5c024482e916542997c5d6b6 (patch) | |
| tree | f0a0bf8503f8174fd9b500feff8547cab885132d /usr/src/lib | |
| parent | d907c5084d3f67c85c5551ee093457940f8aec17 (diff) | |
| download | illumos-joyent-7bf5a6f485b8d8bb5c024482e916542997c5d6b6.tar.gz | |
back out merge: incompatible ZFS throttling mechanisms
Diffstat (limited to 'usr/src/lib')
| -rw-r--r-- | usr/src/lib/libbe/common/be_activate.c | 79 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_create.c | 79 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_list.c | 85 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_mount.c | 60 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_snapshot.c | 64 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_utils.c | 72 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/be_zones.c | 121 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/libbe.h | 7 | ||||
| -rw-r--r-- | usr/src/lib/libbe/common/libbe_priv.h | 4 | ||||
| -rw-r--r-- | usr/src/lib/libzpool/common/llib-lzpool | 4 | ||||
| -rw-r--r-- | usr/src/lib/libzpool/common/sys/zfs_context.h | 2 | 
11 files changed, 105 insertions, 472 deletions
| diff --git a/usr/src/lib/libbe/common/be_activate.c b/usr/src/lib/libbe/common/be_activate.c index 5b4555d924..c83e442fa9 100644 --- a/usr/src/lib/libbe/common/be_activate.c +++ b/usr/src/lib/libbe/common/be_activate.c @@ -23,10 +23,6 @@   * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.   */ -/* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. - */ -  #include <assert.h>  #include <libintl.h>  #include <libnvpair.h> @@ -135,7 +131,6 @@ _be_activate(char *be_name)  	be_transaction_data_t cb = { 0 };  	zfs_handle_t	*zhp = NULL;  	char		root_ds[MAXPATHLEN]; -	char		active_ds[MAXPATHLEN];  	char		*cur_vers = NULL, *new_vers = NULL;  	be_node_list_t	*be_nodes = NULL;  	uuid_t		uu = {0}; @@ -229,13 +224,10 @@ _be_activate(char *be_name)  		goto done;  	} -	if (getzoneid() == GLOBAL_ZONEID) { -		if ((ret = set_bootfs(be_nodes->be_rpool, -		    root_ds)) != BE_SUCCESS) { -			be_print_err(gettext("be_activate: failed to set " -			    "bootfs pool property for %s\n"), root_ds); -			goto done; -		} +	if ((ret = set_bootfs(be_nodes->be_rpool, root_ds)) != BE_SUCCESS) { +		be_print_err(gettext("be_activate: failed to set " +		    "bootfs pool property for %s\n"), root_ds); +		goto done;  	}  	if ((zhp = zfs_open(g_zfs, root_ds, ZFS_TYPE_FILESYSTEM)) != NULL) { @@ -254,7 +246,7 @@ _be_activate(char *be_name)  			goto done;  		}  	} else { -		be_print_err(gettext("be_activate: failed to open " +		be_print_err(gettext("be_activate:: failed to open "  		    "dataset (%s): %s\n"), root_ds,  		    libzfs_error_description(g_zfs));  		ret = zfs_err_to_be_err(g_zfs); @@ -270,67 +262,6 @@ _be_activate(char *be_name)  		    cb.obe_name);  	} -	if (getzoneid() != GLOBAL_ZONEID) { -		if (!be_zone_compare_uuids(root_ds)) { -			be_print_err(gettext("be_activate: activating zone " -			    "root dataset from non-active global BE is not " -			    "supported\n")); -			ret = BE_ERR_NOTSUP; -			goto done; -		} -		if ((zhp = zfs_open(g_zfs, root_ds, -		    ZFS_TYPE_FILESYSTEM)) == NULL) { -			be_print_err(gettext("be_activate: failed to open " -			    "dataset (%s): %s\n"), root_ds, -			    libzfs_error_description(g_zfs)); -			ret = zfs_err_to_be_err(g_zfs); -			goto done; -		} -		/* Find current active zone root dataset */ -		if ((ret = be_find_active_zone_root(zhp, cb.obe_zpool, -		    active_ds, sizeof (active_ds))) != BE_SUCCESS) { -			be_print_err(gettext("be_activate: failed to find " -			    "active zone root dataset\n")); -			ZFS_CLOSE(zhp); -			goto done; -		} -		/* Do nothing if requested BE is already active */ -		if (strcmp(root_ds, active_ds) == 0) { -			ret = BE_SUCCESS; -			ZFS_CLOSE(zhp); -			goto done; -		} - -		/* Set active property for BE */ -		if (zfs_prop_set(zhp, BE_ZONE_ACTIVE_PROPERTY, "on") != 0) { -			be_print_err(gettext("be_activate: failed to set " -			    "active property (%s): %s\n"), root_ds, -			    libzfs_error_description(g_zfs)); -			ret = zfs_err_to_be_err(g_zfs); -			ZFS_CLOSE(zhp); -			goto done; -		} -		ZFS_CLOSE(zhp); - -		/* Unset active property for old active root dataset */ -		if ((zhp = zfs_open(g_zfs, active_ds, -		    ZFS_TYPE_FILESYSTEM)) == NULL) { -			be_print_err(gettext("be_activate: failed to open " -			    "dataset (%s): %s\n"), active_ds, -			    libzfs_error_description(g_zfs)); -			ret = zfs_err_to_be_err(g_zfs); -			goto done; -		} -		if (zfs_prop_set(zhp, BE_ZONE_ACTIVE_PROPERTY, "off") != 0) { -			be_print_err(gettext("be_activate: failed to unset " -			    "active property (%s): %s\n"), active_ds, -			    libzfs_error_description(g_zfs)); -			ret = zfs_err_to_be_err(g_zfs); -			ZFS_CLOSE(zhp); -			goto done; -		} -		ZFS_CLOSE(zhp); -	}  done:  	be_free_list(be_nodes);  	return (ret); diff --git a/usr/src/lib/libbe/common/be_create.c b/usr/src/lib/libbe/common/be_create.c index 8bbd7e3fd2..48bf4ec6bf 100644 --- a/usr/src/lib/libbe/common/be_create.c +++ b/usr/src/lib/libbe/common/be_create.c @@ -24,7 +24,7 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2011 Nexenta Systems, Inc. All rights reserved.   */  /* @@ -450,17 +450,6 @@ be_destroy(nvlist_t *be_attrs)  	    sizeof (obe_root_ds));  	bt.obe_root_ds = obe_root_ds; -	if (getzoneid() != GLOBAL_ZONEID) { -		if (!be_zone_compare_uuids(bt.obe_root_ds)) { -			if (be_is_active_on_boot(bt.obe_name)) { -				be_print_err(gettext("be_destroy: destroying " -				    "active zone root dataset from non-active " -				    "global BE is not supported\n")); -				return (BE_ERR_NOTSUP); -			} -		} -	} -  	/*  	 * Detect if the BE to destroy has the 'active on boot' property set.  	 * If so, set the 'active on boot' property on the the 'active' BE. @@ -493,12 +482,9 @@ be_destroy(nvlist_t *be_attrs)  	}  	/* Get the UUID of the global BE */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if (be_get_uuid(zfs_get_name(zhp), -		    &dd.gz_be_uuid) != BE_SUCCESS) { -			be_print_err(gettext("be_destroy: BE has no " -			"UUID (%s)\n"), zfs_get_name(zhp)); -		} +	if (be_get_uuid(zfs_get_name(zhp), &dd.gz_be_uuid) != BE_SUCCESS) { +		be_print_err(gettext("be_destroy: BE has no UUID (%s)\n"), +		    zfs_get_name(zhp));  	}  	/* @@ -609,7 +595,6 @@ be_copy(nvlist_t *be_attrs)  	zpool_handle_t	*zphp = NULL;  	nvlist_t	*zfs_props = NULL;  	uuid_t		uu = { 0 }; -	uuid_t		parent_uu = { 0 };  	char		obe_root_ds[MAXPATHLEN];  	char		nbe_root_ds[MAXPATHLEN];  	char		ss[MAXPATHLEN]; @@ -768,30 +753,17 @@ be_copy(nvlist_t *be_attrs)  		}  		/* Verify it doesn't already exist */ -		if (getzoneid() == GLOBAL_ZONEID) { -			if ((zret = zpool_iter(g_zfs, be_exists_callback, -			    bt.nbe_name)) > 0) { -				be_print_err(gettext("be_copy: BE (%s) already " -				    "exists\n"), bt.nbe_name); -				ret = BE_ERR_BE_EXISTS; -				goto done; -			} else if (zret < 0) { -				be_print_err(gettext("be_copy: zpool_iter " -				    "failed: %s\n"), -				    libzfs_error_description(g_zfs)); -				ret = zfs_err_to_be_err(g_zfs); -				goto done; -			} -		} else { -			be_make_root_ds(bt.nbe_zpool, bt.nbe_name, nbe_root_ds, -			    sizeof (nbe_root_ds)); -			if (zfs_dataset_exists(g_zfs, nbe_root_ds, -			    ZFS_TYPE_FILESYSTEM)) { -				be_print_err(gettext("be_copy: BE (%s) already " -				    "exists\n"), bt.nbe_name); -				ret = BE_ERR_BE_EXISTS; -				goto done; -			} +		if ((zret = zpool_iter(g_zfs, be_exists_callback, bt.nbe_name)) +		    > 0) { +			be_print_err(gettext("be_copy: BE (%s) already " +			    "exists\n"), bt.nbe_name); +			ret = BE_ERR_BE_EXISTS; +			goto done; +		} else if (zret < 0) { +			be_print_err(gettext("be_copy: zpool_iter failed: " +			    "%s\n"), libzfs_error_description(g_zfs)); +			ret = zfs_err_to_be_err(g_zfs); +			goto done;  		}  	} else {  		/* @@ -1044,24 +1016,9 @@ be_copy(nvlist_t *be_attrs)  	}  	/* Set UUID for new BE */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if (be_set_uuid(bt.nbe_root_ds) != BE_SUCCESS) { -			be_print_err(gettext("be_copy: failed to " -			    "set uuid for new BE\n")); -		} -	} else { -		if ((ret = be_zone_get_parent_uuid(bt.obe_root_ds, -		    &parent_uu)) != BE_SUCCESS) { -			be_print_err(gettext("be_copy: failed to get " -			    "parentbe uuid from orig BE\n")); -			ret = BE_ERR_ZONE_NO_PARENTBE; -			goto done; -		} else if ((ret = be_zone_set_parent_uuid(bt.nbe_root_ds, -		    parent_uu)) != BE_SUCCESS) { -			be_print_err(gettext("be_copy: failed to set " -			    "parentbe uuid for newly created BE\n")); -			goto done; -		} +	if (be_set_uuid(bt.nbe_root_ds) != BE_SUCCESS) { +		be_print_err(gettext("be_copy: failed to " +		    "set uuid for new BE\n"));  	}  	/* diff --git a/usr/src/lib/libbe/common/be_list.c b/usr/src/lib/libbe/common/be_list.c index 535e35a2ca..e669f24cc8 100644 --- a/usr/src/lib/libbe/common/be_list.c +++ b/usr/src/lib/libbe/common/be_list.c @@ -24,7 +24,7 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2011 Nexenta Systems, Inc. All rights reserved.   * Copyright 2011 Joyent, Inc. All rights reserved.   */ @@ -189,7 +189,7 @@ _be_list(char *be_name, be_node_list_t **be_nodes)  	if (be_defaults.be_deflt_rpool_container && rpool != NULL) {  		if ((zphp = zpool_open(g_zfs, rpool)) == NULL) { -			be_print_err(gettext("be_list: failed to " +			be_print_err(gettext("be_get_node_data: failed to "  			    "open rpool (%s): %s\n"), rpool,  			    libzfs_error_description(g_zfs));  			free(cb.be_name); @@ -825,9 +825,7 @@ be_get_node_data(  	char prop_buf[MAXPATHLEN];  	nvlist_t *userprops = NULL;  	nvlist_t *propval = NULL; -	nvlist_t *zone_propval = NULL;  	char *prop_str = NULL; -	char *zone_prop_str = NULL;  	char *grub_default_bootfs = NULL;  	zpool_handle_t *zphp = NULL;  	int err = 0; @@ -868,38 +866,27 @@ be_get_node_data(  	be_node->be_space_used = zfs_prop_get_int(zhp, ZFS_PROP_USED); -	if (getzoneid() == GLOBAL_ZONEID) { -		if ((zphp = zpool_open(g_zfs, rpool)) == NULL) { -			be_print_err(gettext("be_get_node_data: failed to open " -			    "pool (%s): %s\n"), rpool, -			    libzfs_error_description(g_zfs)); -			return (zfs_err_to_be_err(g_zfs)); -		} +	if ((zphp = zpool_open(g_zfs, rpool)) == NULL) { +		be_print_err(gettext("be_get_node_data: failed to open pool " +		    "(%s): %s\n"), rpool, libzfs_error_description(g_zfs)); +		return (zfs_err_to_be_err(g_zfs)); +	} -		(void) zpool_get_prop(zphp, ZPOOL_PROP_BOOTFS, prop_buf, -		    ZFS_MAXPROPLEN, NULL, B_FALSE); -		if (be_has_grub() && (be_default_grub_bootfs(rpool, -		    &grub_default_bootfs) == BE_SUCCESS) && -		    grub_default_bootfs != NULL) -			if (strcmp(grub_default_bootfs, be_ds) == 0) -				be_node->be_active_on_boot = B_TRUE; -			else -				be_node->be_active_on_boot = B_FALSE; -		else if (prop_buf != NULL && strcmp(prop_buf, be_ds) == 0) +	(void) zpool_get_prop(zphp, ZPOOL_PROP_BOOTFS, prop_buf, ZFS_MAXPROPLEN, +	    NULL, B_FALSE); +	if (be_has_grub() && +	    (be_default_grub_bootfs(rpool, &grub_default_bootfs) +	    == BE_SUCCESS) && grub_default_bootfs != NULL) +		if (strcmp(grub_default_bootfs, be_ds) == 0)  			be_node->be_active_on_boot = B_TRUE;  		else  			be_node->be_active_on_boot = B_FALSE; - -		be_node->be_global_active = B_TRUE; - -		free(grub_default_bootfs); -		zpool_close(zphp); -	} else { -		if (be_zone_compare_uuids(be_node->be_root_ds)) -			be_node->be_global_active = B_TRUE; -		else -			be_node->be_global_active = B_FALSE; -	} +	else if (prop_buf != NULL && strcmp(prop_buf, be_ds) == 0) +		be_node->be_active_on_boot = B_TRUE; +	else +		be_node->be_active_on_boot = B_FALSE; +	free(grub_default_bootfs); +	zpool_close(zphp);  	/*  	 * If the dataset is mounted use the mount point @@ -924,22 +911,6 @@ be_get_node_data(  	if ((userprops = zfs_get_user_props(zhp)) == NULL) {  		be_node->be_policy_type = strdup(be_default_policy());  	} else { -		if (getzoneid() != GLOBAL_ZONEID) { -			if (nvlist_lookup_nvlist(userprops, -			    BE_ZONE_ACTIVE_PROPERTY, &zone_propval) != 0 || -			    zone_propval == NULL) { -				be_node->be_active_on_boot = B_FALSE; -			} else { -				verify(nvlist_lookup_string(zone_propval, -				    ZPROP_VALUE, &zone_prop_str) == 0); -				if (strcmp(zone_prop_str, "on") == 0) { -					be_node->be_active_on_boot = B_TRUE; -				} else { -					be_node->be_active_on_boot = B_FALSE; -				} -			} -		} -  		if (nvlist_lookup_nvlist(userprops, BE_POLICY_PROPERTY,  		    &propval) != 0 || propval == NULL) {  			be_node->be_policy_type = @@ -954,19 +925,11 @@ be_get_node_data(  			else  				be_node->be_policy_type = strdup(prop_str);  		} -		if (getzoneid() != GLOBAL_ZONEID) { -			if (nvlist_lookup_nvlist(userprops, -			    BE_ZONE_PARENTBE_PROPERTY, &propval) != 0 && -			    nvlist_lookup_string(propval, ZPROP_VALUE, -			    &prop_str) == 0) { -				be_node->be_uuid_str = strdup(prop_str); -			} -		} else { -			if (nvlist_lookup_nvlist(userprops, BE_UUID_PROPERTY, -			    &propval) == 0 && nvlist_lookup_string(propval, -			    ZPROP_VALUE, &prop_str) == 0) { -				be_node->be_uuid_str = strdup(prop_str); -			} + +		if (nvlist_lookup_nvlist(userprops, BE_UUID_PROPERTY, &propval) +		    == 0 && nvlist_lookup_string(propval, ZPROP_VALUE, +		    &prop_str) == 0) { +			be_node->be_uuid_str = strdup(prop_str);  		}  	} diff --git a/usr/src/lib/libbe/common/be_mount.c b/usr/src/lib/libbe/common/be_mount.c index bda2b20b12..6c631da67d 100644 --- a/usr/src/lib/libbe/common/be_mount.c +++ b/usr/src/lib/libbe/common/be_mount.c @@ -23,7 +23,7 @@   * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2012 Nexenta Systems, Inc. All rights reserved.   */  /* @@ -31,7 +31,6 @@   */  #include <assert.h>  #include <errno.h> -#include <libgen.h>  #include <libintl.h>  #include <libnvpair.h>  #include <libzfs.h> @@ -327,29 +326,14 @@ _be_mount(char *be_name, char **altroot, int flags)  		tmp_altroot = *altroot;  	} -	md.altroot = tmp_altroot; -	md.shared_fs = flags & BE_MOUNT_FLAG_SHARED_FS; -	md.shared_rw = flags & BE_MOUNT_FLAG_SHARED_RW; -  	/* Mount the BE's root file system */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if ((ret = be_mount_root(zhp, tmp_altroot)) != BE_SUCCESS) { -			be_print_err(gettext("be_mount: failed to " -			    "mount BE root file system\n")); -			if (gen_tmp_altroot) -				free(tmp_altroot); -			ZFS_CLOSE(zhp); -			return (ret); -		} -	} else { -		/* Legacy mount the zone root dataset */ -		if ((ret = be_mount_zone_root(zhp, &md)) != BE_SUCCESS) { -			be_print_err(gettext("be_mount: failed to " -			    "mount BE zone root file system\n")); -			free(md.altroot); -			ZFS_CLOSE(zhp); -			return (ret); -		} +	if ((ret = be_mount_root(zhp, tmp_altroot)) != BE_SUCCESS) { +		be_print_err(gettext("be_mount: failed to " +		    "mount BE root file system\n")); +		if (gen_tmp_altroot) +			free(tmp_altroot); +		ZFS_CLOSE(zhp); +		return (ret);  	}  	/* Iterate through BE's children filesystems */ @@ -363,6 +347,10 @@ _be_mount(char *be_name, char **altroot, int flags)  		return (err);  	} +	md.altroot = tmp_altroot; +	md.shared_fs = flags & BE_MOUNT_FLAG_SHARED_FS; +	md.shared_rw = flags & BE_MOUNT_FLAG_SHARED_RW; +  	/*  	 * Mount shared file systems if mount flag says so.  	 */ @@ -540,16 +528,9 @@ _be_unmount(char *be_name, int flags)  	}  	/* Unmount this BE's root filesystem */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if ((ret = be_unmount_root(zhp, &ud)) != BE_SUCCESS) { -			ZFS_CLOSE(zhp); -			return (ret); -		} -	} else { -		if ((ret = be_unmount_zone_root(zhp, &ud)) != BE_SUCCESS) { -			ZFS_CLOSE(zhp); -			return (ret); -		} +	if ((ret = be_unmount_root(zhp, &ud)) != BE_SUCCESS) { +		ZFS_CLOSE(zhp); +		return (ret);  	}  	ZFS_CLOSE(zhp); @@ -572,7 +553,6 @@ _be_unmount(char *be_name, int flags)  int  be_mount_zone_root(zfs_handle_t *zhp, be_mount_data_t *md)  { -	struct stat buf;  	char	mountpoint[MAXPATHLEN];  	int	err = 0; @@ -596,16 +576,6 @@ be_mount_zone_root(zfs_handle_t *zhp, be_mount_data_t *md)  		return (BE_ERR_ZONE_ROOT_NOT_LEGACY);  	} -	/* Create the mountpoint if it doesn't exist */ -	if (lstat(md->altroot, &buf) != 0) { -		if (mkdirp(md->altroot, 0755) != 0) { -			err = errno; -			be_print_err(gettext("be_mount_zone_root: failed " -			    "to create mountpoint %s\n"), md->altroot); -			return (errno_to_be_err(err)); -		} -	} -  	/*  	 * Legacy mount the zone root dataset.  	 * diff --git a/usr/src/lib/libbe/common/be_snapshot.c b/usr/src/lib/libbe/common/be_snapshot.c index d63528d05e..2cb011ea5a 100644 --- a/usr/src/lib/libbe/common/be_snapshot.c +++ b/usr/src/lib/libbe/common/be_snapshot.c @@ -24,7 +24,7 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2011 Nexenta Systems, Inc. All rights reserved.   */  /* @@ -323,15 +323,6 @@ be_rollback(nvlist_t *be_attrs)  	    sizeof (obe_root_ds));  	bt.obe_root_ds = obe_root_ds; -	if (getzoneid() != GLOBAL_ZONEID) { -		if (!be_zone_compare_uuids(bt.obe_root_ds)) { -			be_print_err(gettext("be_rollback: rolling back zone " -			    "root dataset from non-active global BE is not " -			    "supported\n")); -			return (BE_ERR_NOTSUP); -		} -	} -  	/* Get handle to BE's root dataset */  	if ((zhp = zfs_open(g_zfs, bt.obe_root_ds, ZFS_TYPE_DATASET)) == NULL) {  		be_print_err(gettext("be_rollback: " @@ -438,16 +429,6 @@ _be_create_snapshot(char *be_name, char **snap_name, char *policy)  	    sizeof (root_ds));  	bt.obe_root_ds = root_ds; -	if (getzoneid() != GLOBAL_ZONEID) { -		if (!be_zone_compare_uuids(bt.obe_root_ds)) { -			be_print_err(gettext("be_create_snapshot: creating " -			    "snapshot for the zone root dataset from " -			    "non-active global BE is not " -			    "supported\n")); -			return (BE_ERR_NOTSUP); -		} -	} -  	/* If BE policy not specified, use the default policy */  	if (bt.policy == NULL) {  		bt.policy = be_default_policy(); @@ -501,30 +482,27 @@ _be_create_snapshot(char *be_name, char **snap_name, char *policy)  	 * cleanup policy there.  Otherwise don't set one - this snapshot  	 * will always inherit the cleanup policy from its parent.  	 */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if (pool_version >= SPA_VERSION_SNAP_PROPS) { -			if (nvlist_alloc(&ss_props, NV_UNIQUE_NAME, 0) != 0) { -				be_print_err(gettext("be_create_snapshot: " -				    "internal error: out of memory\n")); -				return (BE_ERR_NOMEM); -			} -			if (nvlist_add_string(ss_props, BE_POLICY_PROPERTY, -			    bt.policy) != 0) { -				be_print_err(gettext("be_create_snapshot: " -				    "internal error: out of memory\n")); -				nvlist_free(ss_props); -				return (BE_ERR_NOMEM); -			} -		} else if (policy != NULL) { -			/* -			 * If an explicit cleanup policy was requested -			 * by the caller and we don't support it, error out. -			 */ -			be_print_err(gettext("be_create_snapshot: cannot set " -			    "cleanup policy: ZFS pool version is %d\n"), -			    pool_version); -			return (BE_ERR_NOTSUP); +	if (pool_version >= SPA_VERSION_SNAP_PROPS) { +		if (nvlist_alloc(&ss_props, NV_UNIQUE_NAME, 0) != 0) { +			be_print_err(gettext("be_create_snapshot: internal " +			    "error: out of memory\n")); +			return (BE_ERR_NOMEM);  		} +		if (nvlist_add_string(ss_props, BE_POLICY_PROPERTY, bt.policy) +		    != 0) { +			be_print_err(gettext("be_create_snapshot: internal " +			    "error: out of memory\n")); +			nvlist_free(ss_props); +			return (BE_ERR_NOMEM); +		} +	} else if (policy != NULL) { +		/* +		 * If an explicit cleanup policy was requested +		 * by the caller and we don't support it, error out. +		 */ +		be_print_err(gettext("be_create_snapshot: cannot set " +		    "cleanup policy: ZFS pool version is %d\n"), pool_version); +		return (BE_ERR_NOTSUP);  	}  	/* Create the snapshots recursively */ diff --git a/usr/src/lib/libbe/common/be_utils.c b/usr/src/lib/libbe/common/be_utils.c index a24e1e0941..888a8e2c71 100644 --- a/usr/src/lib/libbe/common/be_utils.c +++ b/usr/src/lib/libbe/common/be_utils.c @@ -24,7 +24,7 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2011 Nexenta Systems, Inc. All rights reserved.   */ @@ -53,7 +53,6 @@  #include <deflt.h>  #include <wait.h>  #include <libdevinfo.h> -#include <libgen.h>  #include <libbe.h>  #include <libbe_priv.h> @@ -231,30 +230,13 @@ be_make_root_ds(const char *zpool, const char *be_name, char *be_root_ds,  {  	struct be_defaults be_defaults;  	be_get_defaults(&be_defaults); -	char	*root_ds = NULL; -	if (getzoneid() == GLOBAL_ZONEID) { -		if (be_defaults.be_deflt_rpool_container) { -			(void) snprintf(be_root_ds, be_root_ds_size, -			    "%s/%s", zpool, be_name); -		} else { -			(void) snprintf(be_root_ds, be_root_ds_size, -			    "%s/%s/%s", zpool, BE_CONTAINER_DS_NAME, be_name); -		} -	} else { -		/* -		 * In non-global zone we can use path from mounted root dataset -		 * to generate BE's root dataset string. -		 */ -		if ((root_ds = be_get_ds_from_dir("/")) != NULL) { -			(void) snprintf(be_root_ds, be_root_ds_size, "%s/%s", -			    dirname(root_ds), be_name); -		} else { -			be_print_err(gettext("be_make_root_ds: zone root " -			    "dataset is not mounted\n")); -			return; -		} -	} +	if (be_defaults.be_deflt_rpool_container) +		(void) snprintf(be_root_ds, be_root_ds_size, "%s/%s", zpool, +		    be_name); +	else +		(void) snprintf(be_root_ds, be_root_ds_size, "%s/%s/%s", zpool, +		    BE_CONTAINER_DS_NAME, be_name);  }  /* @@ -276,26 +258,12 @@ be_make_container_ds(const char *zpool,  char *container_ds,  {  	struct be_defaults be_defaults;  	be_get_defaults(&be_defaults); -	char	*root_ds = NULL; -	if (getzoneid() == GLOBAL_ZONEID) { -		if (be_defaults.be_deflt_rpool_container) { -			(void) snprintf(container_ds, container_ds_size, -			    "%s", zpool); -		} else { -			(void) snprintf(container_ds, container_ds_size, -			    "%s/%s", zpool, BE_CONTAINER_DS_NAME); -		} -	} else { -		if ((root_ds = be_get_ds_from_dir("/")) != NULL) { -			(void) strlcpy(container_ds, dirname(root_ds), -			    container_ds_size); -		} else { -			be_print_err(gettext("be_make_container_ds: zone root " -			    "dataset is not mounted\n")); -			return; -		} -	} +	if (be_defaults.be_deflt_rpool_container) +		(void) snprintf(container_ds, container_ds_size, "%s", zpool); +	else +		(void) snprintf(container_ds, container_ds_size, "%s/%s", zpool, +		    BE_CONTAINER_DS_NAME);  }  /* @@ -2468,25 +2436,11 @@ be_zpool_find_current_be_callback(zpool_handle_t *zlp, void *data)  	zfs_handle_t		*zhp = NULL;  	const char		*zpool =  zpool_get_name(zlp);  	char			be_container_ds[MAXPATHLEN]; -	char			*zpath = NULL;  	/*  	 * Generate string for BE container dataset  	 */ -	if (getzoneid() != GLOBAL_ZONEID) { -		if ((zpath = be_get_ds_from_dir("/")) != NULL) { -			(void) strlcpy(be_container_ds, dirname(zpath), -			    sizeof (be_container_ds)); -		} else { -			be_print_err(gettext( -			    "be_zpool_find_current_be_callback: " -			    "zone root dataset is not mounted\n")); -			return (0); -		} -	} else { -		be_make_container_ds(zpool, be_container_ds, -		    sizeof (be_container_ds)); -	} +	be_make_container_ds(zpool, be_container_ds, sizeof (be_container_ds));  	/*  	 * Check if a BE container dataset exists in this pool. diff --git a/usr/src/lib/libbe/common/be_zones.c b/usr/src/lib/libbe/common/be_zones.c index 8b2af7efee..886b0dacad 100644 --- a/usr/src/lib/libbe/common/be_zones.c +++ b/usr/src/lib/libbe/common/be_zones.c @@ -24,10 +24,6 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. - */ - -/*   * System includes   */  #include <assert.h> @@ -117,25 +113,14 @@ be_find_active_zone_root(zfs_handle_t *be_zhp, char *zonepath_ds,  	int				ret = BE_SUCCESS;  	/* Get the uuid of the parent global BE */ -	if (getzoneid() == GLOBAL_ZONEID) { -		if ((ret = be_get_uuid(zfs_get_name(be_zhp), -		    &azr_data.parent_uuid)) != BE_SUCCESS) { -			be_print_err(gettext("be_find_active_zone_root: failed " -			    "to get uuid for BE root dataset %s\n"), -			    zfs_get_name(be_zhp)); -			return (ret); -		} -	} else { -		if ((ret = be_zone_get_parent_uuid(zfs_get_name(be_zhp), -		    &azr_data.parent_uuid)) != BE_SUCCESS) { -			be_print_err(gettext("be_find_active_zone_root: failed " -			    "to get parentbe uuid for zone root dataset %s\n"), -			    zfs_get_name(be_zhp)); -			return (ret); -		} +	if ((ret = be_get_uuid(zfs_get_name(be_zhp), &azr_data.parent_uuid)) +	    != BE_SUCCESS) { +		be_print_err(gettext("be_find_active_zone_root: failed to " +		    "get uuid for BE root dataset %s\n"), zfs_get_name(be_zhp)); +		return (ret);  	} -	/* Generate string for the root container dataset  for this zone. */ +	/* Generate string for the root container dataset for this zone. */  	be_make_container_ds(zonepath_ds, zone_container_ds,  	    sizeof (zone_container_ds)); @@ -391,100 +376,6 @@ done:  	return (ret);  } -/* - * Function:	be_zone_set_parent_uuid - * Description:	This function sets parentbe uuid into - *		a zfs user property for a root zone dataset. - * Parameters: - *		root_ds - Root zone dataset of the BE to set a uuid on. - * Return: - *		be_errno_t - Failure - *		BE_SUCCESS - Success - * Scope: - *		Semi-private (library wide uses only) - */ -int -be_zone_set_parent_uuid(char *root_ds, uuid_t uu) -{ -	zfs_handle_t	*zhp = NULL; -	char		uu_string[UUID_PRINTABLE_STRING_LENGTH]; -	int		ret = BE_SUCCESS; - -	uuid_unparse(uu, uu_string); - -	/* Get handle to the root zone dataset. */ -	if ((zhp = zfs_open(g_zfs, root_ds, ZFS_TYPE_FILESYSTEM)) == NULL) { -		be_print_err(gettext("be_zone_set_parent_uuid: failed to " -		    "open root zone dataset (%s): %s\n"), root_ds, -		    libzfs_error_description(g_zfs)); -		return (zfs_err_to_be_err(g_zfs)); -	} - -	/* Set parentbe uuid property for the root zone dataset */ -	if (zfs_prop_set(zhp, BE_ZONE_PARENTBE_PROPERTY, uu_string) != 0) { -		be_print_err(gettext("be_zone_set_parent_uuid: failed to " -		    "set parentbe uuid property for root zone dataset: %s\n"), -		    libzfs_error_description(g_zfs)); -		ret = zfs_err_to_be_err(g_zfs); -	} - -	ZFS_CLOSE(zhp); -	return (ret); -} - -/* - * Function:	be_zone_compare_uuids - * Description:	This function compare the parentbe uuid of the - *		current running root zone dataset with the parentbe - *		uuid of the given root zone dataset. - * Parameters: - *		root_ds - Root zone dataset of the BE to compare. - * Return: - *		B_TRUE - root dataset has right parentbe uuid - *		B_FALSE - root dataset has wrong parentbe uuid - * Scope: - *		Semi-private (library wide uses only) - */ -boolean_t -be_zone_compare_uuids(char *root_ds) -{ -	char		*active_ds; -	uuid_t		parent_uuid = {0}; -	uuid_t		cur_parent_uuid = {0}; - -	/* Get parentbe uuid from given zone root dataset */ -	if ((be_zone_get_parent_uuid(root_ds, -	    &parent_uuid)) != BE_SUCCESS) { -		be_print_err(gettext("be_zone_compare_uuids: failed to get " -		    "parentbe uuid from the given BE\n")); -		return (B_FALSE); -	} - -	/* -	 * Find current running zone root dataset and get it's parentbe -	 * uuid property. -	 */ -	if ((active_ds = be_get_ds_from_dir("/")) != NULL) { -		if ((be_zone_get_parent_uuid(active_ds, -		    &cur_parent_uuid)) != BE_SUCCESS) { -			be_print_err(gettext("be_zone_compare_uuids: failed " -			"to get parentbe uuid from the current running zone " -			"root dataset\n")); -			return (B_FALSE); -		} -	} else { -		be_print_err(gettext("be_zone_compare_uuids: zone root dataset " -		    "is not mounted\n")); -		return (B_FALSE); -	} - -	if (uuid_compare(parent_uuid, cur_parent_uuid) != 0) { -		return (B_FALSE); -	} - -	return (B_TRUE); -} -  /* ******************************************************************** */  /*			Private Functions				*/  /* ******************************************************************** */ diff --git a/usr/src/lib/libbe/common/libbe.h b/usr/src/lib/libbe/common/libbe.h index 93c90d4f22..27baecab89 100644 --- a/usr/src/lib/libbe/common/libbe.h +++ b/usr/src/lib/libbe/common/libbe.h @@ -23,10 +23,6 @@   * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.   */ -/* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. - */ -  #ifndef _LIBBE_H  #define	_LIBBE_H @@ -62,7 +58,6 @@ extern "C" {  #define	BE_ATTR_ACTIVE		"active"  #define	BE_ATTR_ACTIVE_ON_BOOT	"active_boot" -#define	BE_ATTR_GLOBAL_ACTIVE	"global_active"  #define	BE_ATTR_SPACE		"space_used"  #define	BE_ATTR_DATASET		"dataset"  #define	BE_ATTR_STATUS		"status" @@ -171,8 +166,6 @@ typedef struct be_node_list {  	boolean_t be_mounted;		/* is BE currently mounted */  	boolean_t be_active_on_boot;	/* is this BE active on boot */  	boolean_t be_active;		/* is this BE active currently */ -	boolean_t be_global_active;	/* is zone's BE associated with */ -					/* an active global BE */  	uint64_t be_space_used;  	char *be_node_name;  	char *be_rpool; diff --git a/usr/src/lib/libbe/common/libbe_priv.h b/usr/src/lib/libbe/common/libbe_priv.h index 1453e5ee3e..7e79c798e9 100644 --- a/usr/src/lib/libbe/common/libbe_priv.h +++ b/usr/src/lib/libbe/common/libbe_priv.h @@ -24,7 +24,7 @@   */  /* - * Copyright 2013 Nexenta Systems, Inc. All rights reserved. + * Copyright 2011 Nexenta Systems, Inc. All rights reserved.   */  #ifndef	_LIBBE_PRIV_H @@ -205,8 +205,6 @@ int be_find_mounted_zone_root(char *, char *, char *, int);  boolean_t be_zone_supported(char *);  zoneBrandList_t *be_get_supported_brandlist(void);  int be_zone_get_parent_uuid(const char *, uuid_t *); -int be_zone_set_parent_uuid(char *, uuid_t); -boolean_t be_zone_compare_uuids(char *);  /* check architecture functions */  char *be_get_default_isa(void); diff --git a/usr/src/lib/libzpool/common/llib-lzpool b/usr/src/lib/libzpool/common/llib-lzpool index 6c64977c32..7e61b55a91 100644 --- a/usr/src/lib/libzpool/common/llib-lzpool +++ b/usr/src/lib/libzpool/common/llib-lzpool @@ -24,7 +24,7 @@   */  /* - * Copyright (c) 2013 by Delphix. All rights reserved. + * Copyright (c) 2012 by Delphix. All rights reserved.   */  /* LINTLIBRARY */ @@ -64,4 +64,4 @@  extern uint64_t metaslab_gang_bang;  extern uint64_t metaslab_df_alloc_threshold;  extern boolean_t zfeature_checks_disable; -extern uint64_t zfs_deadman_synctime_ms; +extern uint64_t zfs_deadman_synctime; diff --git a/usr/src/lib/libzpool/common/sys/zfs_context.h b/usr/src/lib/libzpool/common/sys/zfs_context.h index 3aa58fb05a..8d55a0140f 100644 --- a/usr/src/lib/libzpool/common/sys/zfs_context.h +++ b/usr/src/lib/libzpool/common/sys/zfs_context.h @@ -165,8 +165,6 @@ extern int aok;   */  #define	curthread	((void *)(uintptr_t)thr_self()) -#define	kpreempt(x)	yield() -  typedef struct kthread kthread_t;  #define	thread_create(stk, stksize, func, arg, len, pp, state, pri)	\ | 
