mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-10-24 08:55:00 +03:00
OpenZFS 8331 - zfs_unshare returns wrong error code for smb unshare failure
Authored by: Andrew Stormont <astormont@racktopsystems.com> Reviewed by: Marcel Telka <marcel@telka.sk> Reviewed by: Toomas Soome <tsoome@me.com> Approved by: Dan McDonald <danmcd@omniti.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: George Melikov <mail@gmelikov.ru> Ported-by: Giuseppe Di Natale <dinatale2@llnl.gov> OpenZFS-issue: https://www.illumos.org/issues/8331 OpenZFS-commit: https://github.com/openzfs/openzfs/commit/4f4378c Closes #6255
This commit is contained in:
parent
29eb494285
commit
7e35ea783e
@ -24,6 +24,7 @@
|
|||||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||||
* Copyright (c) 2014, 2015 by Delphix. All rights reserved.
|
* Copyright (c) 2014, 2015 by Delphix. All rights reserved.
|
||||||
* Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>
|
* Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>
|
||||||
|
* Copyright 2017 RackTop Systems.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -91,7 +92,7 @@ zfs_share_type_t zfs_is_shared_proto(zfs_handle_t *, char **,
|
|||||||
zfs_share_proto_t);
|
zfs_share_proto_t);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The share protocols table must be in the same order as the zfs_share_prot_t
|
* The share protocols table must be in the same order as the zfs_share_proto_t
|
||||||
* enum in libzfs_impl.h
|
* enum in libzfs_impl.h
|
||||||
*/
|
*/
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -936,7 +937,7 @@ unshare_one(libzfs_handle_t *hdl, const char *name, const char *mountpoint,
|
|||||||
/* make sure libshare initialized */
|
/* make sure libshare initialized */
|
||||||
if ((err = zfs_init_libshare(hdl, SA_INIT_SHARE_API)) != SA_OK) {
|
if ((err = zfs_init_libshare(hdl, SA_INIT_SHARE_API)) != SA_OK) {
|
||||||
free(mntpt); /* don't need the copy anymore */
|
free(mntpt); /* don't need the copy anymore */
|
||||||
return (zfs_error_fmt(hdl, EZFS_UNSHARENFSFAILED,
|
return (zfs_error_fmt(hdl, proto_table[proto].p_unshare_err,
|
||||||
dgettext(TEXT_DOMAIN, "cannot unshare '%s': %s"),
|
dgettext(TEXT_DOMAIN, "cannot unshare '%s': %s"),
|
||||||
name, sa_errorstr(err)));
|
name, sa_errorstr(err)));
|
||||||
}
|
}
|
||||||
@ -947,12 +948,13 @@ unshare_one(libzfs_handle_t *hdl, const char *name, const char *mountpoint,
|
|||||||
if (share != NULL) {
|
if (share != NULL) {
|
||||||
err = sa_disable_share(share, proto_table[proto].p_name);
|
err = sa_disable_share(share, proto_table[proto].p_name);
|
||||||
if (err != SA_OK) {
|
if (err != SA_OK) {
|
||||||
return (zfs_error_fmt(hdl, EZFS_UNSHARENFSFAILED,
|
return (zfs_error_fmt(hdl,
|
||||||
|
proto_table[proto].p_unshare_err,
|
||||||
dgettext(TEXT_DOMAIN, "cannot unshare '%s': %s"),
|
dgettext(TEXT_DOMAIN, "cannot unshare '%s': %s"),
|
||||||
name, sa_errorstr(err)));
|
name, sa_errorstr(err)));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return (zfs_error_fmt(hdl, EZFS_UNSHARENFSFAILED,
|
return (zfs_error_fmt(hdl, proto_table[proto].p_unshare_err,
|
||||||
dgettext(TEXT_DOMAIN, "cannot unshare '%s': not found"),
|
dgettext(TEXT_DOMAIN, "cannot unshare '%s': not found"),
|
||||||
name));
|
name));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user