libzfs/mnttab: shorten names, reorg a bit

We can't change the public interface, but internally we don't need so
much redundant naming.

Sponsored-by: TrueNAS
Reviewed-by: Ameer Hamza <ahamza@ixsystems.com>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Rob Norris <rob.norris@truenas.com>
Closes #18296
This commit is contained in:
Rob Norris 2026-02-19 11:42:57 +11:00 committed by Brian Behlendorf
parent f43cb1fef6
commit c0ea89db9f
2 changed files with 46 additions and 53 deletions

View File

@ -58,20 +58,14 @@ struct libzfs_handle {
char libzfs_action[1024]; char libzfs_action[1024];
char libzfs_desc[1024]; char libzfs_desc[1024];
int libzfs_printerr; int libzfs_printerr;
/*
* We need a lock to handle the case where parallel mount
* threads are populating the mnttab cache simultaneously. The
* lock only protects the integrity of the avl tree, and does
* not protect the contents of the mnttab entries themselves.
*/
kmutex_t libzfs_mnttab_cache_lock;
avl_tree_t libzfs_mnttab_cache;
int libzfs_pool_iter; int libzfs_pool_iter;
boolean_t libzfs_prop_debug; boolean_t libzfs_prop_debug;
regex_t libzfs_urire; regex_t libzfs_urire;
uint64_t libzfs_max_nvlist; uint64_t libzfs_max_nvlist;
void *libfetch; void *libfetch;
char *libfetch_load_error; char *libfetch_load_error;
kmutex_t zh_mnttab_lock;
avl_tree_t zh_mnttab;
}; };
struct zfs_handle { struct zfs_handle {

View File

@ -70,7 +70,7 @@ mnttab_node_free(libzfs_handle_t *hdl, mnttab_node_t *mtn)
} }
static int static int
libzfs_mnttab_cache_compare(const void *arg1, const void *arg2) mnttab_compare(const void *arg1, const void *arg2)
{ {
const mnttab_node_t *mtn1 = (const mnttab_node_t *)arg1; const mnttab_node_t *mtn1 = (const mnttab_node_t *)arg1;
const mnttab_node_t *mtn2 = (const mnttab_node_t *)arg2; const mnttab_node_t *mtn2 = (const mnttab_node_t *)arg2;
@ -84,19 +84,40 @@ libzfs_mnttab_cache_compare(const void *arg1, const void *arg2)
void void
libzfs_mnttab_init(libzfs_handle_t *hdl) libzfs_mnttab_init(libzfs_handle_t *hdl)
{ {
mutex_init(&hdl->libzfs_mnttab_cache_lock, NULL, MUTEX_DEFAULT, NULL); mutex_init(&hdl->zh_mnttab_lock, NULL, MUTEX_DEFAULT, NULL);
assert(avl_numnodes(&hdl->libzfs_mnttab_cache) == 0); assert(avl_numnodes(&hdl->zh_mnttab) == 0);
avl_create(&hdl->libzfs_mnttab_cache, libzfs_mnttab_cache_compare, avl_create(&hdl->zh_mnttab, mnttab_compare,
sizeof (mnttab_node_t), offsetof(mnttab_node_t, mtn_node)); sizeof (mnttab_node_t), offsetof(mnttab_node_t, mtn_node));
} }
void
libzfs_mnttab_fini(libzfs_handle_t *hdl)
{
void *cookie = NULL;
mnttab_node_t *mtn;
while ((mtn = avl_destroy_nodes(&hdl->zh_mnttab, &cookie))
!= NULL)
mnttab_node_free(hdl, mtn);
avl_destroy(&hdl->zh_mnttab);
(void) mutex_destroy(&hdl->zh_mnttab_lock);
}
void
libzfs_mnttab_cache(libzfs_handle_t *hdl, boolean_t enable)
{
/* This is a no-op to preserve ABI backward compatibility. */
(void) hdl, (void) enable;
}
static int static int
libzfs_mnttab_update(libzfs_handle_t *hdl) mnttab_update(libzfs_handle_t *hdl)
{ {
FILE *mnttab; FILE *mnttab;
struct mnttab entry; struct mnttab entry;
ASSERT(MUTEX_HELD(&hdl->libzfs_mnttab_cache_lock)); ASSERT(MUTEX_HELD(&hdl->zh_mnttab_lock));
if ((mnttab = fopen(MNTTAB, "re")) == NULL) if ((mnttab = fopen(MNTTAB, "re")) == NULL)
return (ENOENT); return (ENOENT);
@ -112,39 +133,18 @@ libzfs_mnttab_update(libzfs_handle_t *hdl)
entry.mnt_mountp, entry.mnt_mntopts); entry.mnt_mountp, entry.mnt_mntopts);
/* Exclude duplicate mounts */ /* Exclude duplicate mounts */
if (avl_find(&hdl->libzfs_mnttab_cache, mtn, &where) != NULL) { if (avl_find(&hdl->zh_mnttab, mtn, &where) != NULL) {
mnttab_node_free(hdl, mtn); mnttab_node_free(hdl, mtn);
continue; continue;
} }
avl_add(&hdl->libzfs_mnttab_cache, mtn); avl_add(&hdl->zh_mnttab, mtn);
} }
(void) fclose(mnttab); (void) fclose(mnttab);
return (0); return (0);
} }
void
libzfs_mnttab_fini(libzfs_handle_t *hdl)
{
void *cookie = NULL;
mnttab_node_t *mtn;
while ((mtn = avl_destroy_nodes(&hdl->libzfs_mnttab_cache, &cookie))
!= NULL)
mnttab_node_free(hdl, mtn);
avl_destroy(&hdl->libzfs_mnttab_cache);
(void) mutex_destroy(&hdl->libzfs_mnttab_cache_lock);
}
void
libzfs_mnttab_cache(libzfs_handle_t *hdl, boolean_t enable)
{
/* This is a no-op to preserve ABI backward compatibility. */
(void) hdl, (void) enable;
}
int int
libzfs_mnttab_find(libzfs_handle_t *hdl, const char *fsname, libzfs_mnttab_find(libzfs_handle_t *hdl, const char *fsname,
struct mnttab *entry) struct mnttab *entry)
@ -153,23 +153,23 @@ libzfs_mnttab_find(libzfs_handle_t *hdl, const char *fsname,
mnttab_node_t *mtn; mnttab_node_t *mtn;
int ret = ENOENT; int ret = ENOENT;
mutex_enter(&hdl->libzfs_mnttab_cache_lock); mutex_enter(&hdl->zh_mnttab_lock);
if (avl_numnodes(&hdl->libzfs_mnttab_cache) == 0) { if (avl_numnodes(&hdl->zh_mnttab) == 0) {
int error; int error;
if ((error = libzfs_mnttab_update(hdl)) != 0) { if ((error = mnttab_update(hdl)) != 0) {
mutex_exit(&hdl->libzfs_mnttab_cache_lock); mutex_exit(&hdl->zh_mnttab_lock);
return (error); return (error);
} }
} }
find.mtn_mt.mnt_special = (char *)fsname; find.mtn_mt.mnt_special = (char *)fsname;
mtn = avl_find(&hdl->libzfs_mnttab_cache, &find, NULL); mtn = avl_find(&hdl->zh_mnttab, &find, NULL);
if (mtn) { if (mtn) {
*entry = mtn->mtn_mt; *entry = mtn->mtn_mt;
ret = 0; ret = 0;
} }
mutex_exit(&hdl->libzfs_mnttab_cache_lock); mutex_exit(&hdl->zh_mnttab_lock);
return (ret); return (ret);
} }
@ -179,20 +179,20 @@ libzfs_mnttab_add(libzfs_handle_t *hdl, const char *special,
{ {
mnttab_node_t *mtn; mnttab_node_t *mtn;
mutex_enter(&hdl->libzfs_mnttab_cache_lock); mutex_enter(&hdl->zh_mnttab_lock);
mtn = mnttab_node_alloc(hdl, special, mountp, mntopts); mtn = mnttab_node_alloc(hdl, special, mountp, mntopts);
/* /*
* Another thread may have already added this entry * Another thread may have already added this entry
* via libzfs_mnttab_update. If so we should skip it. * via mnttab_update. If so we should skip it.
*/ */
if (avl_find(&hdl->libzfs_mnttab_cache, mtn, NULL) != NULL) if (avl_find(&hdl->zh_mnttab, mtn, NULL) != NULL)
mnttab_node_free(hdl, mtn); mnttab_node_free(hdl, mtn);
else else
avl_add(&hdl->libzfs_mnttab_cache, mtn); avl_add(&hdl->zh_mnttab, mtn);
mutex_exit(&hdl->libzfs_mnttab_cache_lock); mutex_exit(&hdl->zh_mnttab_lock);
} }
void void
@ -201,12 +201,11 @@ libzfs_mnttab_remove(libzfs_handle_t *hdl, const char *fsname)
mnttab_node_t find; mnttab_node_t find;
mnttab_node_t *ret; mnttab_node_t *ret;
mutex_enter(&hdl->libzfs_mnttab_cache_lock); mutex_enter(&hdl->zh_mnttab_lock);
find.mtn_mt.mnt_special = (char *)fsname; find.mtn_mt.mnt_special = (char *)fsname;
if ((ret = avl_find(&hdl->libzfs_mnttab_cache, (void *)&find, NULL)) if ((ret = avl_find(&hdl->zh_mnttab, (void *)&find, NULL)) != NULL) {
!= NULL) { avl_remove(&hdl->zh_mnttab, ret);
avl_remove(&hdl->libzfs_mnttab_cache, ret);
mnttab_node_free(hdl, ret); mnttab_node_free(hdl, ret);
} }
mutex_exit(&hdl->libzfs_mnttab_cache_lock); mutex_exit(&hdl->zh_mnttab_lock);
} }