diff options
Diffstat (limited to 'usr/src/lib')
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs.h | 4 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_config.c | 35 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_dataset.c | 11 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/mapfile-vers | 8 | 
4 files changed, 45 insertions, 13 deletions
| diff --git a/usr/src/lib/libzfs/common/libzfs.h b/usr/src/lib/libzfs/common/libzfs.h index b369b18671..81e4cca5f1 100644 --- a/usr/src/lib/libzfs/common/libzfs.h +++ b/usr/src/lib/libzfs/common/libzfs.h @@ -24,8 +24,8 @@   * Copyright (c) 2011, 2015 by Delphix. All rights reserved.   * Copyright (c) 2012, Joyent, Inc. All rights reserved.   * Copyright (c) 2013 Steven Hartland. All rights reserved. - * Copyright 2013 Nexenta Systems, Inc.  All rights reserved.   * Copyright (c) 2014 Integros [integros.com] + * Copyright 2016 Nexenta Systems, Inc.   */  #ifndef	_LIBZFS_H @@ -220,6 +220,7 @@ extern void zpool_free_handles(libzfs_handle_t *);   */  typedef int (*zpool_iter_f)(zpool_handle_t *, void *);  extern int zpool_iter(libzfs_handle_t *, zpool_iter_f, void *); +extern boolean_t zpool_skip_pool(const char *);  /*   * Functions to create and destroy pools @@ -409,6 +410,7 @@ extern void zfs_close(zfs_handle_t *);  extern zfs_type_t zfs_get_type(const zfs_handle_t *);  extern const char *zfs_get_name(const zfs_handle_t *);  extern zpool_handle_t *zfs_get_pool_handle(const zfs_handle_t *); +extern const char *zfs_get_pool_name(const zfs_handle_t *);  /*   * Property management functions.  Some functions are shared with the kernel, diff --git a/usr/src/lib/libzfs/common/libzfs_config.c b/usr/src/lib/libzfs/common/libzfs_config.c index c3dafd6a77..fe380a24a2 100644 --- a/usr/src/lib/libzfs/common/libzfs_config.c +++ b/usr/src/lib/libzfs/common/libzfs_config.c @@ -27,6 +27,7 @@  /*   * Copyright (c) 2012 by Delphix. All rights reserved.   * Copyright (c) 2015 by Syneto S.R.L. All rights reserved. + * Copyright 2016 Nexenta Systems, Inc.   */  /* @@ -339,33 +340,47 @@ zpool_refresh_stats(zpool_handle_t *zhp, boolean_t *missing)  }  /* - * If the __ZFS_POOL_RESTRICT environment variable is set we only iterate over - * pools it lists. + * The following environment variables are undocumented + * and should be used for testing purposes only:   * - * This is an undocumented feature for use during testing only. + * __ZFS_POOL_EXCLUDE - don't iterate over the pools it lists + * __ZFS_POOL_RESTRICT - iterate only over the pools it lists   *   * This function returns B_TRUE if the pool should be skipped   * during iteration.   */ -static boolean_t -check_restricted(const char *poolname) +boolean_t +zpool_skip_pool(const char *poolname)  {  	static boolean_t initialized = B_FALSE; -	static char *restricted = NULL; +	static const char *exclude = NULL; +	static const char *restricted = NULL;  	const char *cur, *end; -	int len, namelen; +	int len; +	int namelen = strlen(poolname);  	if (!initialized) {  		initialized = B_TRUE; +		exclude = getenv("__ZFS_POOL_EXCLUDE");  		restricted = getenv("__ZFS_POOL_RESTRICT");  	} +	if (exclude != NULL) { +		cur = exclude; +		do { +			end = strchr(cur, ' '); +			len = (NULL == end) ? strlen(cur) : (end - cur); +			if (len == namelen && 0 == strncmp(cur, poolname, len)) +				return (B_TRUE); +			cur += (len + 1); +		} while (NULL != end); +	} +  	if (NULL == restricted)  		return (B_FALSE);  	cur = restricted; -	namelen = strlen(poolname);  	do {  		end = strchr(cur, ' ');  		len = (NULL == end) ? strlen(cur) : (end - cur); @@ -403,7 +418,7 @@ zpool_iter(libzfs_handle_t *hdl, zpool_iter_f func, void *data)  	for (cn = uu_avl_first(hdl->libzfs_ns_avl); cn != NULL;  	    cn = uu_avl_next(hdl->libzfs_ns_avl, cn)) { -		if (check_restricted(cn->cn_name)) +		if (zpool_skip_pool(cn->cn_name))  			continue;  		if (zpool_open_silent(hdl, cn->cn_name, &zhp) != 0) { @@ -441,7 +456,7 @@ zfs_iter_root(libzfs_handle_t *hdl, zfs_iter_f func, void *data)  	for (cn = uu_avl_first(hdl->libzfs_ns_avl); cn != NULL;  	    cn = uu_avl_next(hdl->libzfs_ns_avl, cn)) { -		if (check_restricted(cn->cn_name)) +		if (zpool_skip_pool(cn->cn_name))  			continue;  		if ((zhp = make_dataset_handle(hdl, cn->cn_name)) == NULL) diff --git a/usr/src/lib/libzfs/common/libzfs_dataset.c b/usr/src/lib/libzfs/common/libzfs_dataset.c index 034edebb24..2d443e7c71 100644 --- a/usr/src/lib/libzfs/common/libzfs_dataset.c +++ b/usr/src/lib/libzfs/common/libzfs_dataset.c @@ -26,8 +26,8 @@   * Copyright (c) 2012 DEY Storage Systems, Inc.  All rights reserved.   * Copyright (c) 2013 Martin Matuska. All rights reserved.   * Copyright (c) 2013 Steven Hartland. All rights reserved. - * Copyright 2013 Nexenta Systems, Inc.  All rights reserved.   * Copyright (c) 2014 Integros [integros.com] + * Copyright 2016 Nexenta Systems, Inc.   */  #include <ctype.h> @@ -2911,6 +2911,15 @@ zfs_get_name(const zfs_handle_t *zhp)  }  /* + * Returns the name of the parent pool for the given zfs handle. + */ +const char * +zfs_get_pool_name(const zfs_handle_t *zhp) +{ +	return (zhp->zpool_hdl->zpool_name); +} + +/*   * Returns the type of the given zfs handle.   */  zfs_type_t diff --git a/usr/src/lib/libzfs/common/mapfile-vers b/usr/src/lib/libzfs/common/mapfile-vers index f348bf03ab..7c6bcb0fab 100644 --- a/usr/src/lib/libzfs/common/mapfile-vers +++ b/usr/src/lib/libzfs/common/mapfile-vers @@ -18,10 +18,14 @@  #  # CDDL HEADER END  # + +#  # Copyright (c) 2006, 2010, Oracle and/or its affiliates. All rights reserved. -# Copyright 2011 Nexenta Systems, Inc. All rights reserved.  # Copyright (c) 2011, 2014 by Delphix. All rights reserved.  # Copyright (c) 2012, Joyent, Inc. All rights reserved. +# Copyright 2016 Nexenta Systems, Inc. +# +  #  # MAPFILE HEADER START  # @@ -80,6 +84,7 @@ SYMBOL_VERSION SUNWprivate_1.1 {  	zfs_get_hole_count;  	zfs_get_name;  	zfs_get_pool_handle; +	zfs_get_pool_name;  	zfs_get_user_props;  	zfs_get_type;  	zfs_handle_dup; @@ -233,6 +238,7 @@ SYMBOL_VERSION SUNWprivate_1.1 {  	zpool_scan;  	zpool_search_import;  	zpool_set_prop; +	zpool_skip_pool;  	zpool_state_to_name;  	zpool_unmount_datasets;  	zpool_upgrade; | 
