Blame SOURCES/autofs-5.1.6-add-a-hash-index-to-mnt_list.patch

9a499a
autofs-5.1.6 - add a hash index to mnt_list
9a499a
9a499a
From: Ian Kent <raven@themaw.net>
9a499a
9a499a
Add a hash index (and utility functions) to struct mnt_list.
9a499a
9a499a
Signed-off-by: Ian Kent <raven@themaw.net>
9a499a
---
9a499a
 CHANGELOG        |    1 
9a499a
 include/mounts.h |    8 +++
9a499a
 lib/mounts.c     |  135 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
9a499a
 3 files changed, 144 insertions(+)
9a499a
9a499a
--- autofs-5.1.4.orig/CHANGELOG
9a499a
+++ autofs-5.1.4/CHANGELOG
9a499a
@@ -121,6 +121,7 @@ xx/xx/2018 autofs-5.1.5
9a499a
 - change mountpoint to mp in struct ext_mount.
9a499a
 - make external mounts independent of amd_entry.
9a499a
 - make external mounts use simpler hashtable.
9a499a
+- add a hash index to mnt_list.
9a499a
 
9a499a
 19/12/2017 autofs-5.1.4
9a499a
 - fix spec file url.
9a499a
--- autofs-5.1.4.orig/include/mounts.h
9a499a
+++ autofs-5.1.4/include/mounts.h
9a499a
@@ -54,10 +54,16 @@ struct mapent;
9a499a
 struct mnt_list {
9a499a
 	char *mp;
9a499a
 	unsigned int flags;
9a499a
+
9a499a
+	/* Hash of all mounts */
9a499a
+	struct hlist_node hash;
9a499a
+	unsigned int ref;
9a499a
+
9a499a
 	/*
9a499a
 	 * List operations ie. get_mnt_list.
9a499a
 	 */
9a499a
 	struct mnt_list *next;
9a499a
+
9a499a
 	/*
9a499a
 	 * Tree operations ie. tree_make_tree,
9a499a
 	 * tree_get_mnt_list etc.
9a499a
@@ -100,6 +106,8 @@ char *make_mnt_name_string(char *path);
9a499a
 int ext_mount_add(const char *, const char *);
9a499a
 int ext_mount_remove(const char *);
9a499a
 int ext_mount_inuse(const char *);
9a499a
+struct mnt_list *mnts_lookup_mount(const char *mp);
9a499a
+void mnts_put_mount(struct mnt_list *mnt);
9a499a
 struct mnt_list *get_mnt_list(const char *path, int include);
9a499a
 int unlink_mount_tree(struct autofs_point *ap, const char *mp);
9a499a
 void free_mnt_list(struct mnt_list *list);
9a499a
--- autofs-5.1.4.orig/lib/mounts.c
9a499a
+++ autofs-5.1.4/lib/mounts.c
9a499a
@@ -63,6 +63,11 @@ struct ext_mount {
9a499a
 static DEFINE_HASHTABLE(ext_mounts_hash, EXT_MOUNTS_HASH_BITS);
9a499a
 static pthread_mutex_t ext_mount_hash_mutex = PTHREAD_MUTEX_INITIALIZER;
9a499a
 
9a499a
+#define MNTS_HASH_BITS	7
9a499a
+
9a499a
+static DEFINE_HASHTABLE(mnts_hash, MNTS_HASH_BITS);
9a499a
+static pthread_mutex_t mnts_hash_mutex = PTHREAD_MUTEX_INITIALIZER;
9a499a
+
9a499a
 unsigned int linux_version_code(void)
9a499a
 {
9a499a
 	struct utsname my_utsname;
9a499a
@@ -832,6 +837,136 @@ done:
9a499a
 	return ret;
9a499a
 }
9a499a
 
9a499a
+static void mnts_hash_mutex_lock(void)
9a499a
+{
9a499a
+	int status = pthread_mutex_lock(&mnts_hash_mutex);
9a499a
+	if (status)
9a499a
+		fatal(status);
9a499a
+}
9a499a
+
9a499a
+static void mnts_hash_mutex_unlock(void)
9a499a
+{
9a499a
+	int status = pthread_mutex_unlock(&mnts_hash_mutex);
9a499a
+	if (status)
9a499a
+		fatal(status);
9a499a
+}
9a499a
+
9a499a
+static struct mnt_list *mnts_lookup(const char *mp)
9a499a
+{
9a499a
+	uint32_t hval = hash(mp, HASH_SIZE(mnts_hash));
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	if (hlist_empty(&mnts_hash[hval]))
9a499a
+		return NULL;
9a499a
+
9a499a
+	hlist_for_each_entry(this, &mnts_hash[hval], hash) {
9a499a
+		if (!strcmp(this->mp, mp) && this->ref)
9a499a
+			return this;
9a499a
+	}
9a499a
+
9a499a
+	return NULL;
9a499a
+}
9a499a
+
9a499a
+static struct mnt_list *mnts_alloc_mount(const char *mp)
9a499a
+{
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	this = malloc(sizeof(*this));
9a499a
+	if (!this)
9a499a
+		goto done;
9a499a
+	memset(this, 0, sizeof(*this));
9a499a
+
9a499a
+	this->mp = strdup(mp);
9a499a
+	if (!this->mp) {
9a499a
+		free(this);
9a499a
+		this = NULL;
9a499a
+		goto done;
9a499a
+	}
9a499a
+
9a499a
+	this->ref = 1;
9a499a
+	INIT_HLIST_NODE(&this->hash);
9a499a
+done:
9a499a
+	return this;
9a499a
+}
9a499a
+
9a499a
+static void __mnts_get_mount(struct mnt_list *mnt)
9a499a
+{
9a499a
+	mnt->ref++;
9a499a
+}
9a499a
+
9a499a
+static void __mnts_put_mount(struct mnt_list *mnt)
9a499a
+{
9a499a
+	mnt->ref--;
9a499a
+	if (!mnt->ref) {
9a499a
+		hash_del(&mnt->hash);
9a499a
+		free(mnt->mp);
9a499a
+		free(mnt);
9a499a
+	}
9a499a
+}
9a499a
+
9a499a
+static struct mnt_list *mnts_new_mount(const char *mp)
9a499a
+{
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	this = mnts_lookup(mp);
9a499a
+	if (this) {
9a499a
+		__mnts_get_mount(this);
9a499a
+		goto done;
9a499a
+	}
9a499a
+
9a499a
+	this = mnts_alloc_mount(mp);
9a499a
+	if (!this)
9a499a
+		goto done;
9a499a
+
9a499a
+	hash_add_str(mnts_hash, &this->hash, this->mp);
9a499a
+done:
9a499a
+	return this;
9a499a
+}
9a499a
+
9a499a
+static struct mnt_list *mnts_get_mount(const char *mp)
9a499a
+{
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	this = mnts_lookup(mp);
9a499a
+	if (this) {
9a499a
+		__mnts_get_mount(this);
9a499a
+		return this;
9a499a
+	}
9a499a
+
9a499a
+	return mnts_new_mount(mp);
9a499a
+}
9a499a
+
9a499a
+static struct mnt_list *__mnts_lookup_mount(const char *mp)
9a499a
+{
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	this = mnts_lookup(mp);
9a499a
+	if (this)
9a499a
+		__mnts_get_mount(this);
9a499a
+
9a499a
+	return this;
9a499a
+}
9a499a
+
9a499a
+struct mnt_list *mnts_lookup_mount(const char *mp)
9a499a
+{
9a499a
+	struct mnt_list *this;
9a499a
+
9a499a
+	mnts_hash_mutex_lock();
9a499a
+	this = __mnts_lookup_mount(mp);
9a499a
+	mnts_hash_mutex_unlock();
9a499a
+
9a499a
+	return this;
9a499a
+}
9a499a
+
9a499a
+void mnts_put_mount(struct mnt_list *mnt)
9a499a
+{
9a499a
+	if (!mnt)
9a499a
+		return;
9a499a
+	mnts_hash_mutex_lock();
9a499a
+	__mnts_put_mount(mnt);
9a499a
+	mnts_hash_mutex_unlock();
9a499a
+}
9a499a
+
9a499a
 /* From glibc decode_name() */
9a499a
 /* Since the values in a line are separated by spaces, a name cannot
9a499a
  * contain a space.  Therefore some programs encode spaces in names