diff options
| author | Matthew Ahrens <mahrens@delphix.com> | 2016-06-09 10:38:27 -0400 | 
|---|---|---|
| committer | Matthew Ahrens <mahrens@delphix.com> | 2016-06-09 15:55:53 -0400 | 
| commit | 9adfa60d484ce2435f5af77cc99dcd4e692b6660 (patch) | |
| tree | 8317e936fc768f79567bf498076c3fbab777adc6 /usr/src/lib/libzfs | |
| parent | 0c779ad424a92a84d1e07d47cab7f8009189202b (diff) | |
| download | illumos-joyent-9adfa60d484ce2435f5af77cc99dcd4e692b6660.tar.gz | |
6314 buffer overflow in dsl_dataset_name
Reviewed by: George Wilson <george.wilson@delphix.com>
Reviewed by: Prakash Surya <prakash.surya@delphix.com>
Reviewed by: Igor Kozhukhov <ikozhukhov@gmail.com>
Approved by: Dan McDonald <danmcd@omniti.com>
Diffstat (limited to 'usr/src/lib/libzfs')
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs.h | 2 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_changelist.c | 3 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_dataset.c | 30 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_diff.c | 3 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_impl.h | 10 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_iter.c | 6 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_mount.c | 2 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_pool.c | 8 | ||||
| -rw-r--r-- | usr/src/lib/libzfs/common/libzfs_sendrecv.c | 51 | 
9 files changed, 58 insertions, 57 deletions
| diff --git a/usr/src/lib/libzfs/common/libzfs.h b/usr/src/lib/libzfs/common/libzfs.h index 82acd00609..9baff24146 100644 --- a/usr/src/lib/libzfs/common/libzfs.h +++ b/usr/src/lib/libzfs/common/libzfs.h @@ -50,8 +50,6 @@ extern "C" {  /*   * Miscellaneous ZFS constants   */ -#define	ZFS_MAXNAMELEN		MAXNAMELEN -#define	ZPOOL_MAXNAMELEN	MAXNAMELEN  #define	ZFS_MAXPROPLEN		MAXPATHLEN  #define	ZPOOL_MAXPROPLEN	MAXPATHLEN diff --git a/usr/src/lib/libzfs/common/libzfs_changelist.c b/usr/src/lib/libzfs/common/libzfs_changelist.c index 18a95db1a2..04666cce99 100644 --- a/usr/src/lib/libzfs/common/libzfs_changelist.c +++ b/usr/src/lib/libzfs/common/libzfs_changelist.c @@ -24,6 +24,7 @@   * Use is subject to license terms.   *   * Portions Copyright 2007 Ramprakash Jelari + * Copyright (c) 2014, 2015 by Delphix. All rights reserved.   * Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>   */ @@ -289,7 +290,7 @@ void  changelist_rename(prop_changelist_t *clp, const char *src, const char *dst)  {  	prop_changenode_t *cn; -	char newname[ZFS_MAXNAMELEN]; +	char newname[ZFS_MAX_DATASET_NAME_LEN];  	for (cn = uu_list_first(clp->cl_list); cn != NULL;  	    cn = uu_list_next(clp->cl_list, cn)) { diff --git a/usr/src/lib/libzfs/common/libzfs_dataset.c b/usr/src/lib/libzfs/common/libzfs_dataset.c index aa4a0e9115..aa557ae80b 100644 --- a/usr/src/lib/libzfs/common/libzfs_dataset.c +++ b/usr/src/lib/libzfs/common/libzfs_dataset.c @@ -556,7 +556,7 @@ zfs_bookmark_exists(const char *path)  {  	nvlist_t *bmarks;  	nvlist_t *props; -	char fsname[ZFS_MAXNAMELEN]; +	char fsname[ZFS_MAX_DATASET_NAME_LEN];  	char *bmark_name;  	char *pound;  	int err; @@ -2139,7 +2139,7 @@ struct get_clones_arg {  	uint64_t numclones;  	nvlist_t *value;  	const char *origin; -	char buf[ZFS_MAXNAMELEN]; +	char buf[ZFS_MAX_DATASET_NAME_LEN];  };  int @@ -2194,7 +2194,7 @@ zfs_get_clones_nvl(zfs_handle_t *zhp)  		if (gca.numclones != 0) {  			zfs_handle_t *root; -			char pool[ZFS_MAXNAMELEN]; +			char pool[ZFS_MAX_DATASET_NAME_LEN];  			char *cp = pool;  			/* get the pool name */ @@ -2966,7 +2966,7 @@ check_parents(libzfs_handle_t *hdl, const char *path, uint64_t *zoned,      boolean_t accept_ancestor, int *prefixlen)  {  	zfs_cmd_t zc = { 0 }; -	char parent[ZFS_MAXNAMELEN]; +	char parent[ZFS_MAX_DATASET_NAME_LEN];  	char *slash;  	zfs_handle_t *zhp;  	char errbuf[1024]; @@ -3205,7 +3205,7 @@ zfs_create(libzfs_handle_t *hdl, const char *path, zfs_type_t type,  		ost = LZC_DATSET_TYPE_ZFS;  	/* open zpool handle for prop validation */ -	char pool_path[MAXNAMELEN]; +	char pool_path[ZFS_MAX_DATASET_NAME_LEN];  	(void) strlcpy(pool_path, path, sizeof (pool_path));  	/* truncate pool_path at first slash */ @@ -3274,7 +3274,7 @@ zfs_create(libzfs_handle_t *hdl, const char *path, zfs_type_t type,  	/* check for failure */  	if (ret != 0) { -		char parent[ZFS_MAXNAMELEN]; +		char parent[ZFS_MAX_DATASET_NAME_LEN];  		(void) parent_name(path, parent, sizeof (parent));  		switch (errno) { @@ -3364,7 +3364,7 @@ static int  zfs_check_snap_cb(zfs_handle_t *zhp, void *arg)  {  	struct destroydata *dd = arg; -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	int rv = 0;  	(void) snprintf(name, sizeof (name), @@ -3454,7 +3454,7 @@ zfs_destroy_snaps_nvl(libzfs_handle_t *hdl, nvlist_t *snaps, boolean_t defer)  int  zfs_clone(zfs_handle_t *zhp, const char *target, nvlist_t *props)  { -	char parent[ZFS_MAXNAMELEN]; +	char parent[ZFS_MAX_DATASET_NAME_LEN];  	int ret;  	char errbuf[1024];  	libzfs_handle_t *hdl = zhp->zfs_hdl; @@ -3584,7 +3584,7 @@ static int  zfs_snapshot_cb(zfs_handle_t *zhp, void *arg)  {  	snapdata_t *sd = arg; -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	int rv = 0;  	if (zfs_prop_get_int(zhp, ZFS_PROP_INCONSISTENT) == 0) { @@ -3633,7 +3633,7 @@ zfs_snapshot_nvl(libzfs_handle_t *hdl, nvlist_t *snaps, nvlist_t *props)  	 * get pool handle for prop validation. assumes all snaps are in the  	 * same pool, as does lzc_snapshot (below).  	 */ -	char pool[MAXNAMELEN]; +	char pool[ZFS_MAX_DATASET_NAME_LEN];  	elem = nvlist_next_nvpair(snaps, NULL);  	(void) strlcpy(pool, nvpair_name(elem), sizeof (pool));  	pool[strcspn(pool, "/@")] = '\0'; @@ -3687,7 +3687,7 @@ zfs_snapshot(libzfs_handle_t *hdl, const char *path, boolean_t recursive,  {  	int ret;  	snapdata_t sd = { 0 }; -	char fsname[ZFS_MAXNAMELEN]; +	char fsname[ZFS_MAX_DATASET_NAME_LEN];  	char *cp;  	zfs_handle_t *zhp;  	char errbuf[1024]; @@ -3866,7 +3866,7 @@ zfs_rename(zfs_handle_t *zhp, const char *target, boolean_t recursive,  	prop_changelist_t *cl = NULL;  	zfs_handle_t *zhrp = NULL;  	char *parentname = NULL; -	char parent[ZFS_MAXNAMELEN]; +	char parent[ZFS_MAX_DATASET_NAME_LEN];  	libzfs_handle_t *hdl = zhp->zfs_hdl;  	char errbuf[1024]; @@ -4348,7 +4348,7 @@ static int  zfs_hold_one(zfs_handle_t *zhp, void *arg)  {  	struct holdarg *ha = arg; -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	int rv = 0;  	(void) snprintf(name, sizeof (name), @@ -4467,7 +4467,7 @@ static int  zfs_release_one(zfs_handle_t *zhp, void *arg)  {  	struct holdarg *ha = arg; -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	int rv = 0;  	nvlist_t *existing_holds; @@ -4596,7 +4596,7 @@ tryagain:  	zc.zc_nvlist_dst_size = nvsz;  	zc.zc_nvlist_dst = (uintptr_t)nvbuf; -	(void) strlcpy(zc.zc_name, zhp->zfs_name, ZFS_MAXNAMELEN); +	(void) strlcpy(zc.zc_name, zhp->zfs_name, sizeof (zc.zc_name));  	if (ioctl(hdl->libzfs_fd, ZFS_IOC_GET_FSACL, &zc) != 0) {  		(void) snprintf(errbuf, sizeof (errbuf), diff --git a/usr/src/lib/libzfs/common/libzfs_diff.c b/usr/src/lib/libzfs/common/libzfs_diff.c index d58558ffa3..d6cf32714d 100644 --- a/usr/src/lib/libzfs/common/libzfs_diff.c +++ b/usr/src/lib/libzfs/common/libzfs_diff.c @@ -22,6 +22,7 @@  /*   * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.   * Copyright 2015 Nexenta Systems, Inc. All rights reserved. + * Copyright (c) 2015 by Delphix. All rights reserved.   * Copyright 2016 Joyent, Inc.   * Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>   */ @@ -601,7 +602,7 @@ get_snapshot_names(differ_info_t *di, const char *fromsnap,  		 * not the same dataset name, might be okay if  		 * tosnap is a clone of a fromsnap descendant.  		 */ -		char origin[ZFS_MAXNAMELEN]; +		char origin[ZFS_MAX_DATASET_NAME_LEN];  		zprop_source_t src;  		zfs_handle_t *zhp; diff --git a/usr/src/lib/libzfs/common/libzfs_impl.h b/usr/src/lib/libzfs/common/libzfs_impl.h index a3fcaab075..c62685085d 100644 --- a/usr/src/lib/libzfs/common/libzfs_impl.h +++ b/usr/src/lib/libzfs/common/libzfs_impl.h @@ -22,17 +22,17 @@  /*   * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.   * Copyright (c) 2011 Pawel Jakub Dawidek. All rights reserved. - * Copyright (c) 2013 by Delphix. All rights reserved. + * Copyright (c) 2011, 2015 by Delphix. All rights reserved.   */  #ifndef	_LIBZFS_IMPL_H  #define	_LIBZFS_IMPL_H -#include <sys/dmu.h>  #include <sys/fs/zfs.h> -#include <sys/zfs_ioctl.h>  #include <sys/spa.h>  #include <sys/nvpair.h> +#include <sys/dmu.h> +#include <sys/zfs_ioctl.h>  #include <libuutil.h>  #include <libzfs.h> @@ -87,7 +87,7 @@ struct libzfs_handle {  struct zfs_handle {  	libzfs_handle_t *zfs_hdl;  	zpool_handle_t *zpool_hdl; -	char zfs_name[ZFS_MAXNAMELEN]; +	char zfs_name[ZFS_MAX_DATASET_NAME_LEN];  	zfs_type_t zfs_type; /* type including snapshot */  	zfs_type_t zfs_head_type; /* type excluding snapshot */  	dmu_objset_stats_t zfs_dmustats; @@ -108,7 +108,7 @@ struct zfs_handle {  struct zpool_handle {  	libzfs_handle_t *zpool_hdl;  	zpool_handle_t *zpool_next; -	char zpool_name[ZPOOL_MAXNAMELEN]; +	char zpool_name[ZFS_MAX_DATASET_NAME_LEN];  	int zpool_state;  	size_t zpool_config_size;  	nvlist_t *zpool_config; diff --git a/usr/src/lib/libzfs/common/libzfs_iter.c b/usr/src/lib/libzfs/common/libzfs_iter.c index fb6a475d34..91ae6f302b 100644 --- a/usr/src/lib/libzfs/common/libzfs_iter.c +++ b/usr/src/lib/libzfs/common/libzfs_iter.c @@ -197,7 +197,7 @@ zfs_iter_bookmarks(zfs_handle_t *zhp, zfs_iter_f func, void *data)  	for (nvpair_t *pair = nvlist_next_nvpair(bmarks, NULL);  	    pair != NULL; pair = nvlist_next_nvpair(bmarks, pair)) { -		char name[ZFS_MAXNAMELEN]; +		char name[ZFS_MAX_DATASET_NAME_LEN];  		char *bmark_name;  		nvlist_t *bmark_props; @@ -385,7 +385,7 @@ zfs_iter_snapspec(zfs_handle_t *fs_zhp, const char *spec_orig,  			 * exists.  			 */  			if (ssa.ssa_last[0] != '\0') { -				char snapname[ZFS_MAXNAMELEN]; +				char snapname[ZFS_MAX_DATASET_NAME_LEN];  				(void) snprintf(snapname, sizeof (snapname),  				    "%s@%s", zfs_get_name(fs_zhp),  				    ssa.ssa_last); @@ -405,7 +405,7 @@ zfs_iter_snapspec(zfs_handle_t *fs_zhp, const char *spec_orig,  				ret = ENOENT;  			}  		} else { -			char snapname[ZFS_MAXNAMELEN]; +			char snapname[ZFS_MAX_DATASET_NAME_LEN];  			zfs_handle_t *snap_zhp;  			(void) snprintf(snapname, sizeof (snapname), "%s@%s",  			    zfs_get_name(fs_zhp), comma_separated); diff --git a/usr/src/lib/libzfs/common/libzfs_mount.c b/usr/src/lib/libzfs/common/libzfs_mount.c index 26f574bc8b..f74860ba67 100644 --- a/usr/src/lib/libzfs/common/libzfs_mount.c +++ b/usr/src/lib/libzfs/common/libzfs_mount.c @@ -231,7 +231,7 @@ static boolean_t  zfs_is_mountable(zfs_handle_t *zhp, char *buf, size_t buflen,      zprop_source_t *source)  { -	char sourceloc[ZFS_MAXNAMELEN]; +	char sourceloc[MAXNAMELEN];  	zprop_source_t sourcetype;  	if (!zfs_prop_valid_for_type(ZFS_PROP_MOUNTPOINT, zhp->zfs_type)) diff --git a/usr/src/lib/libzfs/common/libzfs_pool.c b/usr/src/lib/libzfs/common/libzfs_pool.c index cfe6db8b4d..69b7314dcf 100644 --- a/usr/src/lib/libzfs/common/libzfs_pool.c +++ b/usr/src/lib/libzfs/common/libzfs_pool.c @@ -406,7 +406,7 @@ bootfs_name_valid(const char *pool, char *bootfs)  boolean_t  zpool_is_bootable(zpool_handle_t *zhp)  { -	char bootfs[ZPOOL_MAXNAMELEN]; +	char bootfs[ZFS_MAX_DATASET_NAME_LEN];  	return (zpool_get_prop(zhp, ZPOOL_PROP_BOOTFS, bootfs,  	    sizeof (bootfs), NULL, B_FALSE) == 0 && strncmp(bootfs, "-", @@ -3760,7 +3760,7 @@ zpool_obj_to_path(zpool_handle_t *zhp, uint64_t dsobj, uint64_t obj,  	zfs_cmd_t zc = { 0 };  	boolean_t mounted = B_FALSE;  	char *mntpnt = NULL; -	char dsname[MAXNAMELEN]; +	char dsname[ZFS_MAX_DATASET_NAME_LEN];  	if (dsobj == 0) {  		/* special case for the MOS */ @@ -4017,7 +4017,7 @@ zvol_check_dump_config(char *arg)  	uint_t toplevels;  	libzfs_handle_t *hdl;  	char errbuf[1024]; -	char poolname[ZPOOL_MAXNAMELEN]; +	char poolname[ZFS_MAX_DATASET_NAME_LEN];  	int pathlen = strlen(ZVOL_FULL_DEV_DIR);  	int ret = 1; @@ -4040,7 +4040,7 @@ zvol_check_dump_config(char *arg)  		    "malformed dataset name"));  		(void) zfs_error(hdl, EZFS_INVALIDNAME, errbuf);  		return (1); -	} else if (p - volname >= ZFS_MAXNAMELEN) { +	} else if (p - volname >= ZFS_MAX_DATASET_NAME_LEN) {  		zfs_error_aux(hdl, dgettext(TEXT_DOMAIN,  		    "dataset name is too long"));  		(void) zfs_error(hdl, EZFS_NAMETOOLONG, errbuf); diff --git a/usr/src/lib/libzfs/common/libzfs_sendrecv.c b/usr/src/lib/libzfs/common/libzfs_sendrecv.c index c03b5a6b6e..70114fa812 100644 --- a/usr/src/lib/libzfs/common/libzfs_sendrecv.c +++ b/usr/src/lib/libzfs/common/libzfs_sendrecv.c @@ -745,7 +745,7 @@ send_iterate_prop(zfs_handle_t *zhp, nvlist_t *nv)  static uint64_t  get_snap_txg(libzfs_handle_t *hdl, const char *fs, const char *snap)  { -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	uint64_t txg = 0;  	if (fs == NULL || fs[0] == '\0' || snap == NULL || snap[0] == '\0') @@ -913,7 +913,7 @@ typedef struct send_dump_data {  	/* these are all just the short snapname (the part after the @) */  	const char *fromsnap;  	const char *tosnap; -	char prevsnap[ZFS_MAXNAMELEN]; +	char prevsnap[ZFS_MAX_DATASET_NAME_LEN];  	uint64_t prevsnap_obj;  	boolean_t seenfrom, seento, replicate, doall, fromorigin;  	boolean_t verbose, dryrun, parsable, progress, embed_data, std_out; @@ -926,7 +926,7 @@ typedef struct send_dump_data {  	snapfilter_cb_t *filter_cb;  	void *filter_cb_arg;  	nvlist_t *debugnv; -	char holdtag[ZFS_MAXNAMELEN]; +	char holdtag[ZFS_MAX_DATASET_NAME_LEN];  	int cleanup_fd;  	uint64_t size;  } send_dump_data_t; @@ -1561,7 +1561,7 @@ zfs_send_resume(libzfs_handle_t *hdl, sendflags_t *flags, int outfd,  	uint64_t resumeobj, resumeoff, toguid, fromguid, bytes;  	zfs_handle_t *zhp;  	int error = 0; -	char name[ZFS_MAXNAMELEN]; +	char name[ZFS_MAX_DATASET_NAME_LEN];  	enum lzc_send_flags lzc_flags = 0;  	(void) snprintf(errbuf, sizeof (errbuf), dgettext(TEXT_DOMAIN, @@ -2151,8 +2151,8 @@ recv_rename(libzfs_handle_t *hdl, const char *name, const char *tryname,  	if (err != 0 && strncmp(name + baselen, "recv-", 5) != 0) {  		seq++; -		(void) snprintf(newname, ZFS_MAXNAMELEN, "%.*srecv-%u-%u", -		    baselen, name, getpid(), seq); +		(void) snprintf(newname, ZFS_MAX_DATASET_NAME_LEN, +		    "%.*srecv-%u-%u", baselen, name, getpid(), seq);  		(void) strlcpy(zc.zc_value, newname, sizeof (zc.zc_value));  		if (flags->verbose) { @@ -2280,7 +2280,7 @@ static int  guid_to_name(libzfs_handle_t *hdl, const char *parent, uint64_t guid,      boolean_t bookmark_ok, char *name)  { -	char pname[ZFS_MAXNAMELEN]; +	char pname[ZFS_MAX_DATASET_NAME_LEN];  	guid_to_name_data_t gtnd;  	gtnd.guid = guid; @@ -2335,7 +2335,7 @@ created_before(libzfs_handle_t *hdl, avl_tree_t *avl,  {  	nvlist_t *nvfs;  	char *fsname, *snapname; -	char buf[ZFS_MAXNAMELEN]; +	char buf[ZFS_MAX_DATASET_NAME_LEN];  	int rv;  	zfs_handle_t *guid1hdl, *guid2hdl;  	uint64_t create1, create2; @@ -2386,7 +2386,7 @@ recv_incremental_replication(libzfs_handle_t *hdl, const char *tofs,  	avl_tree_t *local_avl;  	nvpair_t *fselem, *nextfselem;  	char *fromsnap; -	char newname[ZFS_MAXNAMELEN]; +	char newname[ZFS_MAX_DATASET_NAME_LEN];  	int error;  	boolean_t needagain, progress, recursive;  	char *s1, *s2; @@ -2502,7 +2502,7 @@ again:  			/* check for delete */  			if (found == NULL) { -				char name[ZFS_MAXNAMELEN]; +				char name[ZFS_MAX_DATASET_NAME_LEN];  				if (!flags->force)  					continue; @@ -2540,8 +2540,8 @@ again:  			/* check for different snapname */  			if (strcmp(nvpair_name(snapelem),  			    stream_snapname) != 0) { -				char name[ZFS_MAXNAMELEN]; -				char tryname[ZFS_MAXNAMELEN]; +				char name[ZFS_MAX_DATASET_NAME_LEN]; +				char tryname[ZFS_MAX_DATASET_NAME_LEN];  				(void) snprintf(name, sizeof (name), "%s@%s",  				    fsname, nvpair_name(snapelem)); @@ -2603,7 +2603,7 @@ again:  		    ((flags->isprefix || strcmp(tofs, fsname) != 0) &&  		    (s1 != NULL) && (s2 != NULL) && strcmp(s1, s2) != 0)) {  			nvlist_t *parent; -			char tryname[ZFS_MAXNAMELEN]; +			char tryname[ZFS_MAX_DATASET_NAME_LEN];  			parent = fsavl_find(local_avl,  			    stream_parent_fromsnap_guid, NULL); @@ -2669,8 +2669,8 @@ zfs_receive_package(libzfs_handle_t *hdl, int fd, const char *destname,  	char *fromsnap = NULL;  	char *sendsnap = NULL;  	char *cp; -	char tofs[ZFS_MAXNAMELEN]; -	char sendfs[ZFS_MAXNAMELEN]; +	char tofs[ZFS_MAX_DATASET_NAME_LEN]; +	char sendfs[ZFS_MAX_DATASET_NAME_LEN];  	char errbuf[1024];  	dmu_replay_record_t drre;  	int error; @@ -2754,7 +2754,7 @@ zfs_receive_package(libzfs_handle_t *hdl, int fd, const char *destname,  			nvlist_t *renamed = NULL;  			nvpair_t *pair = NULL; -			(void) strlcpy(tofs, destname, ZFS_MAXNAMELEN); +			(void) strlcpy(tofs, destname, sizeof (tofs));  			if (flags->isprefix) {  				struct drr_begin *drrb = &drr->drr_u.drr_begin;  				int i; @@ -2763,7 +2763,7 @@ zfs_receive_package(libzfs_handle_t *hdl, int fd, const char *destname,  					cp = strrchr(drrb->drr_toname, '/');  					if (cp == NULL) {  						(void) strlcat(tofs, "/", -						    ZFS_MAXNAMELEN); +						    sizeof (tofs));  						i = 0;  					} else {  						i = (cp - drrb->drr_toname); @@ -2773,7 +2773,7 @@ zfs_receive_package(libzfs_handle_t *hdl, int fd, const char *destname,  				}  				/* zfs_receive_one() will create_parents() */  				(void) strlcat(tofs, &drrb->drr_toname[i], -				    ZFS_MAXNAMELEN); +				    sizeof (tofs));  				*strchr(tofs, '@') = '\0';  			} @@ -2815,7 +2815,7 @@ zfs_receive_package(libzfs_handle_t *hdl, int fd, const char *destname,  	 * zfs_receive_one().  	 */  	(void) strlcpy(sendfs, drr->drr_u.drr_begin.drr_toname, -	    ZFS_MAXNAMELEN); +	    sizeof (sendfs));  	if ((cp = strchr(sendfs, '@')) != NULL) {  		*cp = '\0';  		/* @@ -2965,7 +2965,7 @@ static void  recv_ecksum_set_aux(libzfs_handle_t *hdl, const char *target_snap,      boolean_t resumable)  { -	char target_fs[ZFS_MAXNAMELEN]; +	char target_fs[ZFS_MAX_DATASET_NAME_LEN];  	zfs_error_aux(hdl, dgettext(TEXT_DOMAIN,  	    "checksum mismatch or incomplete stream")); @@ -3159,7 +3159,7 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,  		if (flags->verbose)  			(void) printf("found clone origin %s\n", zc.zc_string);  	} else if (originsnap) { -		(void) strncpy(zc.zc_string, originsnap, ZFS_MAXNAMELEN); +		(void) strncpy(zc.zc_string, originsnap, sizeof (zc.zc_string));  		if (flags->verbose)  			(void) printf("using provided clone origin %s\n",  			    zc.zc_string); @@ -3184,7 +3184,7 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,  			*cp = '\0';  		if (cp &&  		    !zfs_dataset_exists(hdl, zc.zc_name, ZFS_TYPE_DATASET)) { -			char suffix[ZFS_MAXNAMELEN]; +			char suffix[ZFS_MAX_DATASET_NAME_LEN];  			(void) strcpy(suffix, strrchr(zc.zc_value, '/'));  			if (guid_to_name(hdl, zc.zc_name, parent_snapguid,  			    B_FALSE, zc.zc_value) == 0) { @@ -3211,7 +3211,7 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,  		if ((flags->isprefix || (*(chopprefix = drrb->drr_toname +  		    strlen(sendfs)) != '\0' && *chopprefix != '@')) &&  		    !zfs_dataset_exists(hdl, zc.zc_name, ZFS_TYPE_DATASET)) { -			char snap[ZFS_MAXNAMELEN]; +			char snap[ZFS_MAX_DATASET_NAME_LEN];  			(void) strcpy(snap, strchr(zc.zc_value, '@'));  			if (guid_to_name(hdl, zc.zc_name, drrb->drr_fromguid,  			    B_FALSE, zc.zc_value) == 0) { @@ -3660,7 +3660,7 @@ zfs_receive_impl(libzfs_handle_t *hdl, const char *tosnap,  	}  	if (DMU_GET_STREAM_HDRTYPE(drrb->drr_versioninfo) == DMU_SUBSTREAM) { -		char nonpackage_sendfs[ZFS_MAXNAMELEN]; +		char nonpackage_sendfs[ZFS_MAX_DATASET_NAME_LEN];  		if (sendfs == NULL) {  			/*  			 * We were not called from zfs_receive_package(). Get @@ -3668,7 +3668,8 @@ zfs_receive_impl(libzfs_handle_t *hdl, const char *tosnap,  			 */  			char *cp;  			(void) strlcpy(nonpackage_sendfs, -			    drr.drr_u.drr_begin.drr_toname, ZFS_MAXNAMELEN); +			    drr.drr_u.drr_begin.drr_toname, +			    sizeof (nonpackage_sendfs));  			if ((cp = strchr(nonpackage_sendfs, '@')) != NULL)  				*cp = '\0';  			sendfs = nonpackage_sendfs; | 
