import autofs-5.1.4-93.el8
This commit is contained in:
parent
83c0c3690c
commit
9c15789dd7
120
SOURCES/autofs-5.1.7-fix-concat_options-error-handling.patch
Normal file
120
SOURCES/autofs-5.1.7-fix-concat_options-error-handling.patch
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
autofs-5.1.7 - fix concat_options() error handling
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
There's a possibility of a memory leak in the mount options processing
|
||||||
|
when calling concat_options() in parse_mount() of the Sun format map
|
||||||
|
entry parsing.
|
||||||
|
|
||||||
|
There's also a case in do_init() of the Sun map format parsing where
|
||||||
|
a previously freed value is used in a logging statement without being
|
||||||
|
set to MULL.
|
||||||
|
|
||||||
|
So ensure concat_options() always frees it's arguments so that the
|
||||||
|
handling can be consistent in all places.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/parse_sun.c | 24 +++++++++++-------------
|
||||||
|
2 files changed, 12 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -102,6 +102,7 @@
|
||||||
|
- fix hosts map deadlock on restart.
|
||||||
|
- fix deadlock with hosts map reload.
|
||||||
|
- fix memory leak in update_hosts_mounts().
|
||||||
|
+- fix concat_options() error handling.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_sun.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_sun.c
|
||||||
|
@@ -380,7 +380,8 @@ static int do_init(int argc, const char
|
||||||
|
if (!tmp) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
logerr(MODPREFIX "concat_options: %s", estr);
|
||||||
|
- free(gbl_options);
|
||||||
|
+ /* freed in concat_options */
|
||||||
|
+ ctxt->optstr = NULL;
|
||||||
|
} else
|
||||||
|
ctxt->optstr = tmp;
|
||||||
|
} else {
|
||||||
|
@@ -492,12 +493,16 @@ static char *concat_options(char *left,
|
||||||
|
char *ret;
|
||||||
|
|
||||||
|
if (left == NULL || *left == '\0') {
|
||||||
|
+ if (!right || *right == '\0')
|
||||||
|
+ return NULL;
|
||||||
|
ret = strdup(right);
|
||||||
|
free(right);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (right == NULL || *right == '\0') {
|
||||||
|
+ if (left == NULL || *left == '\0')
|
||||||
|
+ return NULL;
|
||||||
|
ret = strdup(left);
|
||||||
|
free(left);
|
||||||
|
return ret;
|
||||||
|
@@ -508,6 +513,8 @@ static char *concat_options(char *left,
|
||||||
|
if (ret == NULL) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
logerr(MODPREFIX "malloc: %s", estr);
|
||||||
|
+ free(left);
|
||||||
|
+ free(right);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -988,14 +995,13 @@ static int parse_mapent(const char *ent,
|
||||||
|
if (newopt && strstr(newopt, myoptions)) {
|
||||||
|
free(myoptions);
|
||||||
|
myoptions = newopt;
|
||||||
|
- } else {
|
||||||
|
+ } else if (newopt) {
|
||||||
|
tmp = concat_options(myoptions, newopt);
|
||||||
|
if (!tmp) {
|
||||||
|
char *estr;
|
||||||
|
estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(logopt, MODPREFIX
|
||||||
|
"concat_options: %s", estr);
|
||||||
|
- free(myoptions);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
myoptions = tmp;
|
||||||
|
@@ -1363,16 +1369,12 @@ dont_expand:
|
||||||
|
if (mnt_options && noptions && strstr(noptions, mnt_options)) {
|
||||||
|
free(mnt_options);
|
||||||
|
mnt_options = noptions;
|
||||||
|
- } else {
|
||||||
|
+ } else if (noptions) {
|
||||||
|
tmp = concat_options(mnt_options, noptions);
|
||||||
|
if (!tmp) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(ap->logopt,
|
||||||
|
MODPREFIX "concat_options: %s", estr);
|
||||||
|
- if (noptions)
|
||||||
|
- free(noptions);
|
||||||
|
- if (mnt_options)
|
||||||
|
- free(mnt_options);
|
||||||
|
free(options);
|
||||||
|
free(pmapent);
|
||||||
|
return 1;
|
||||||
|
@@ -1392,15 +1394,11 @@ dont_expand:
|
||||||
|
if (options && mnt_options && strstr(mnt_options, options)) {
|
||||||
|
free(options);
|
||||||
|
options = mnt_options;
|
||||||
|
- } else {
|
||||||
|
+ } else if (mnt_options) {
|
||||||
|
tmp = concat_options(options, mnt_options);
|
||||||
|
if (!tmp) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(ap->logopt, MODPREFIX "concat_options: %s", estr);
|
||||||
|
- if (options)
|
||||||
|
- free(options);
|
||||||
|
- if (mnt_options)
|
||||||
|
- free(mnt_options);
|
||||||
|
free(pmapent);
|
||||||
|
return 1;
|
||||||
|
}
|
32
SOURCES/autofs-5.1.8-coverity-fix-for-invalid-access.patch
Normal file
32
SOURCES/autofs-5.1.8-coverity-fix-for-invalid-access.patch
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
autofs-5.1.8 - coverity fix for invalid access
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
Fix invalid access in modules/parse_amd.c:do_host_mount().
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/parse_amd.c | 1 -
|
||||||
|
2 files changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -98,6 +98,7 @@
|
||||||
|
- fix invalid tsv access.
|
||||||
|
- fix parse module instance mutex naming.
|
||||||
|
- serialise lookup module open and reinit.
|
||||||
|
+- coverity fix for invalid access.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_amd.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_amd.c
|
||||||
|
@@ -1366,7 +1366,6 @@ static int do_host_mount(struct autofs_p
|
||||||
|
if (!instance) {
|
||||||
|
error(ap->logopt, MODPREFIX
|
||||||
|
"failed to create source instance for hosts map");
|
||||||
|
- close_lookup(lookup);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,101 @@
|
|||||||
|
autofs-5.1.8 - dont immediately call function when waiting
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
When autofs needs to wait for a sss connection the connection function
|
||||||
|
is immediately called a second time without first waiting. Adjust the
|
||||||
|
calling so that there's a wait before the next call.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/lookup_sss.c | 24 ++++++++++++------------
|
||||||
|
2 files changed, 13 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -107,6 +107,7 @@
|
||||||
|
- fix incorrect path for is_mounted() in try_remount().
|
||||||
|
- fail on empty replicated host name.
|
||||||
|
- improve handling of ENOENT in sss setautomntent().
|
||||||
|
+- don't immediately call function when waiting.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/lookup_sss.c
|
||||||
|
+++ autofs-5.1.4/modules/lookup_sss.c
|
||||||
|
@@ -338,10 +338,13 @@ static int setautomntent_wait(unsigned i
|
||||||
|
"can't connect to sssd, retry for %d seconds",
|
||||||
|
retries);
|
||||||
|
|
||||||
|
- while (++retry <= retries) {
|
||||||
|
+ while (++retry < retries) {
|
||||||
|
struct timespec t = { SSS_WAIT_INTERVAL, 0 };
|
||||||
|
struct timespec r;
|
||||||
|
|
||||||
|
+ while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
+ memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
+
|
||||||
|
ret = ctxt->setautomntent(ctxt->mapname, sss_ctxt);
|
||||||
|
if (proto_version(ctxt) == 0) {
|
||||||
|
if (ret != ENOENT)
|
||||||
|
@@ -355,9 +358,6 @@ static int setautomntent_wait(unsigned i
|
||||||
|
free(*sss_ctxt);
|
||||||
|
*sss_ctxt = NULL;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
- memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
|
@@ -475,10 +475,13 @@ static int getautomntent_wait(unsigned i
|
||||||
|
"can't contact sssd to to get map entry, retry for %d seconds",
|
||||||
|
retries);
|
||||||
|
|
||||||
|
- while (++retry <= retries) {
|
||||||
|
+ while (++retry < retries) {
|
||||||
|
struct timespec t = { SSS_WAIT_INTERVAL, 0 };
|
||||||
|
struct timespec r;
|
||||||
|
|
||||||
|
+ while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
+ memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
+
|
||||||
|
ret = ctxt->getautomntent_r(key, value, sss_ctxt);
|
||||||
|
if (proto_version(ctxt) == 0) {
|
||||||
|
if (ret != ENOENT)
|
||||||
|
@@ -487,9 +490,6 @@ static int getautomntent_wait(unsigned i
|
||||||
|
if (ret != EHOSTDOWN)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
- memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
|
@@ -600,10 +600,13 @@ static int getautomntbyname_wait(unsigne
|
||||||
|
"can't contact sssd to to lookup key value, retry for %d seconds",
|
||||||
|
retries);
|
||||||
|
|
||||||
|
- while (++retry <= retries) {
|
||||||
|
+ while (++retry < retries) {
|
||||||
|
struct timespec t = { SSS_WAIT_INTERVAL, 0 };
|
||||||
|
struct timespec r;
|
||||||
|
|
||||||
|
+ while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
+ memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
+
|
||||||
|
ret = ctxt->getautomntbyname_r(key, value, sss_ctxt);
|
||||||
|
if (proto_version(ctxt) == 0) {
|
||||||
|
if (ret != ENOENT)
|
||||||
|
@@ -612,9 +615,6 @@ static int getautomntbyname_wait(unsigne
|
||||||
|
if (ret != EHOSTDOWN)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- while (nanosleep(&t, &r) == -1 && errno == EINTR)
|
||||||
|
- memcpy(&t, &r, sizeof(struct timespec));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ret)
|
@ -0,0 +1,57 @@
|
|||||||
|
autofs-5.1.8 - fail on empty replicated host name
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
If a mount location host (or hosts) has an empty host name it has to be
|
||||||
|
a mistake so fail the automount request.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/parse_sun.c | 18 ++++++++++++++++++
|
||||||
|
2 files changed, 19 insertions(+)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -105,6 +105,7 @@
|
||||||
|
- fix concat_options() error handling.
|
||||||
|
- fix minus only option handling in concat_options().
|
||||||
|
- fix incorrect path for is_mounted() in try_remount().
|
||||||
|
+- fail on empty replicated host name.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_sun.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_sun.c
|
||||||
|
@@ -924,6 +924,12 @@ static int validate_location(unsigned in
|
||||||
|
if (*ptr == ':')
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
+ /* Fail on replicated entry with empty first host name */
|
||||||
|
+ if (*ptr == ',') {
|
||||||
|
+ error(logopt, "missing first host name in location %s", loc);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
/*
|
||||||
|
* If a ':/' is present now it must be a host name, except
|
||||||
|
* for those special file systems like sshfs which use "#"
|
||||||
|
@@ -960,6 +966,18 @@ static int validate_location(unsigned in
|
||||||
|
"found in location %s", *ptr, loc);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ /* Fail on replicated entry with empty host name */
|
||||||
|
+ if (*ptr == ',') {
|
||||||
|
+ char next = *(ptr + 1);
|
||||||
|
+
|
||||||
|
+ if (next == ',' || next == ':') {
|
||||||
|
+ error(logopt,
|
||||||
|
+ "missing host name in location %s", loc);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
ptr++;
|
||||||
|
}
|
||||||
|
|
169
SOURCES/autofs-5.1.8-fix-deadlock-with-hosts-map-reload.patch
Normal file
169
SOURCES/autofs-5.1.8-fix-deadlock-with-hosts-map-reload.patch
Normal file
@ -0,0 +1,169 @@
|
|||||||
|
autofs-5.1.8 - fix deadlock with hosts map reload
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
When reloading maps the hosts map calls lookup method ->parse_mount()
|
||||||
|
for each multi-mount root entry in the map (each host) while holding
|
||||||
|
the cache read lock which leads to a cache lock deadlock.
|
||||||
|
|
||||||
|
Remove the need to hold the cache read lock by creating an independent
|
||||||
|
list of entries for the update so the lock doesn't need to be taken.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1
|
||||||
|
modules/lookup_hosts.c | 100 ++++++++++++++++++++++++++++++++++++++++---------
|
||||||
|
2 files changed, 83 insertions(+), 18 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -100,6 +100,7 @@
|
||||||
|
- serialise lookup module open and reinit.
|
||||||
|
- coverity fix for invalid access.
|
||||||
|
- fix hosts map deadlock on restart.
|
||||||
|
+- fix deadlock with hosts map reload.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/lookup_hosts.c
|
||||||
|
+++ autofs-5.1.4/modules/lookup_hosts.c
|
||||||
|
@@ -201,10 +201,72 @@ static int do_parse_mount(struct autofs_
|
||||||
|
return NSS_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
+struct update_context {
|
||||||
|
+ char *key;
|
||||||
|
+ int key_len;
|
||||||
|
+ char *entry;
|
||||||
|
+ struct update_context *next;
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+static int add_update_entry(struct update_context **entries, struct mapent *me)
|
||||||
|
+{
|
||||||
|
+ struct update_context *upd;
|
||||||
|
+ char *key, *ent;
|
||||||
|
+
|
||||||
|
+ key = strdup(me->key);
|
||||||
|
+ if (!key)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ ent = strdup(me->mapent);
|
||||||
|
+ if (!ent) {
|
||||||
|
+ free(key);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ upd = malloc(sizeof(struct update_context));
|
||||||
|
+ if (!upd) {
|
||||||
|
+ free(ent);
|
||||||
|
+ free(key);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ upd->key = key;
|
||||||
|
+ upd->key_len = me->len;
|
||||||
|
+ upd->entry = ent;
|
||||||
|
+ upd->next = NULL;
|
||||||
|
+ if (*entries)
|
||||||
|
+ (*entries)->next = upd;
|
||||||
|
+ *entries = upd;
|
||||||
|
+
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static void free_update_entries(struct update_context *entries)
|
||||||
|
+{
|
||||||
|
+ struct update_context *this = entries;
|
||||||
|
+
|
||||||
|
+ while (this) {
|
||||||
|
+ struct update_context *next = this->next;
|
||||||
|
+ free(this->key);
|
||||||
|
+ free(this->entry);
|
||||||
|
+ free(this);
|
||||||
|
+ this = next;
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void entries_cleanup(void *arg)
|
||||||
|
+{
|
||||||
|
+ struct update_context *entries = arg;
|
||||||
|
+
|
||||||
|
+ free_update_entries(entries);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void update_hosts_mounts(struct autofs_point *ap,
|
||||||
|
struct map_source *source, time_t age,
|
||||||
|
struct lookup_context *ctxt)
|
||||||
|
{
|
||||||
|
+ struct update_context *head = NULL;
|
||||||
|
+ struct update_context *entries = NULL;
|
||||||
|
struct mapent_cache *mc;
|
||||||
|
struct mapent *me;
|
||||||
|
char *mapent;
|
||||||
|
@@ -212,6 +274,8 @@ static void update_hosts_mounts(struct a
|
||||||
|
|
||||||
|
mc = source->mc;
|
||||||
|
|
||||||
|
+ pthread_cleanup_push(entries_cleanup, head);
|
||||||
|
+
|
||||||
|
pthread_cleanup_push(cache_lock_cleanup, mc);
|
||||||
|
cache_writelock(mc);
|
||||||
|
me = cache_lookup_first(mc);
|
||||||
|
@@ -224,39 +288,39 @@ static void update_hosts_mounts(struct a
|
||||||
|
|
||||||
|
mapent = get_exports(ap, me->key);
|
||||||
|
if (mapent) {
|
||||||
|
- cache_update(mc, source, me->key, mapent, age);
|
||||||
|
+ int ret;
|
||||||
|
+
|
||||||
|
+ ret = cache_update(mc, source, me->key, mapent, age);
|
||||||
|
free(mapent);
|
||||||
|
+ if (!IS_MM_ROOT(me))
|
||||||
|
+ goto next;
|
||||||
|
+ if (ret != CHE_FAIL) {
|
||||||
|
+ if (!add_update_entry(&entries, me))
|
||||||
|
+ warn(ap->logopt, MODPREFIX
|
||||||
|
+ "failed to add update entry for %s", me->key);
|
||||||
|
+ else if (!head)
|
||||||
|
+ head = entries;
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
next:
|
||||||
|
me = cache_lookup_next(mc, me);
|
||||||
|
}
|
||||||
|
pthread_cleanup_pop(1);
|
||||||
|
|
||||||
|
- pthread_cleanup_push(cache_lock_cleanup, mc);
|
||||||
|
- cache_readlock(mc);
|
||||||
|
- me = cache_lookup_first(mc);
|
||||||
|
- while (me) {
|
||||||
|
- /*
|
||||||
|
- * Hosts map entry not yet expanded, already expired
|
||||||
|
- * or not the base of the tree
|
||||||
|
- */
|
||||||
|
- if (!IS_MM(me) || !IS_MM_ROOT(me))
|
||||||
|
- goto cont;
|
||||||
|
-
|
||||||
|
+ while (head) {
|
||||||
|
debug(ap->logopt, MODPREFIX
|
||||||
|
- "attempt to update exports for %s", me->key);
|
||||||
|
+ "attempt to update exports for %s", head->key);
|
||||||
|
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = source;
|
||||||
|
ap->flags |= MOUNT_FLAG_REMOUNT;
|
||||||
|
- ret = ctxt->parse->parse_mount(ap, me->key, strlen(me->key),
|
||||||
|
- me->mapent, ctxt->parse->context);
|
||||||
|
+ ret = ctxt->parse->parse_mount(ap, head->key, strlen(head->key),
|
||||||
|
+ head->entry, ctxt->parse->context);
|
||||||
|
if (ret)
|
||||||
|
warn(ap->logopt, MODPREFIX
|
||||||
|
- "failed to parse mount %s", me->mapent);
|
||||||
|
+ "failed to parse mount %s", head->entry);
|
||||||
|
ap->flags &= ~MOUNT_FLAG_REMOUNT;
|
||||||
|
-cont:
|
||||||
|
- me = cache_lookup_next(mc, me);
|
||||||
|
+ head = head->next;
|
||||||
|
}
|
||||||
|
pthread_cleanup_pop(1);
|
||||||
|
}
|
97
SOURCES/autofs-5.1.8-fix-hosts-map-deadlock-on-restart.patch
Normal file
97
SOURCES/autofs-5.1.8-fix-hosts-map-deadlock-on-restart.patch
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
autofs-5.1.8 - fix hosts map deadlock on restart
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
When starting automount(8) with a hosts map that has mounts that were
|
||||||
|
in use at the last exit a deadlock can occur.
|
||||||
|
|
||||||
|
In this case automount(8) will perform the same steps but not actually
|
||||||
|
perform the mount to re-construct the context of each mount. But, with
|
||||||
|
the hosts map, that leads to calling back into the sun parse module
|
||||||
|
while holding the map module read lock which will again try and take
|
||||||
|
the write lock.
|
||||||
|
|
||||||
|
Fix this by only taking the write lock in the mount code path if the
|
||||||
|
module handle has not already been opened.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
daemon/lookup.c | 22 ++++++++++++----------
|
||||||
|
modules/parse_amd.c | 18 ++++++++++--------
|
||||||
|
3 files changed, 23 insertions(+), 18 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -99,6 +99,7 @@
|
||||||
|
- fix parse module instance mutex naming.
|
||||||
|
- serialise lookup module open and reinit.
|
||||||
|
- coverity fix for invalid access.
|
||||||
|
+- fix hosts map deadlock on restart.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/daemon/lookup.c
|
||||||
|
+++ autofs-5.1.4/daemon/lookup.c
|
||||||
|
@@ -815,19 +815,21 @@ int do_lookup_mount(struct autofs_point
|
||||||
|
struct lookup_mod *lookup;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
- map_module_writelock(map);
|
||||||
|
if (!map->lookup) {
|
||||||
|
- status = open_lookup(map->type, "",
|
||||||
|
- map->format, map->argc, map->argv, &lookup);
|
||||||
|
- if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
- map_module_unlock(map);
|
||||||
|
- debug(ap->logopt,
|
||||||
|
- "lookup module %s open failed", map->type);
|
||||||
|
- return status;
|
||||||
|
+ map_module_writelock(map);
|
||||||
|
+ if (!map->lookup) {
|
||||||
|
+ status = open_lookup(map->type, "",
|
||||||
|
+ map->format, map->argc, map->argv, &lookup);
|
||||||
|
+ if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
+ debug(ap->logopt,
|
||||||
|
+ "lookup module %s open failed", map->type);
|
||||||
|
+ return status;
|
||||||
|
+ }
|
||||||
|
+ map->lookup = lookup;
|
||||||
|
}
|
||||||
|
- map->lookup = lookup;
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
}
|
||||||
|
- map_module_unlock(map);
|
||||||
|
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = map;
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_amd.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_amd.c
|
||||||
|
@@ -1370,17 +1370,19 @@ static int do_host_mount(struct autofs_p
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- map_module_writelock(instance);
|
||||||
|
if (!instance->lookup) {
|
||||||
|
- status = open_lookup("hosts", MODPREFIX, NULL, argc, pargv, &lookup);
|
||||||
|
- if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
- map_module_unlock(instance);
|
||||||
|
- debug(ap->logopt, "open lookup module hosts failed");
|
||||||
|
- goto out;
|
||||||
|
+ map_module_writelock(instance);
|
||||||
|
+ if (!instance->lookup) {
|
||||||
|
+ status = open_lookup("hosts", MODPREFIX, NULL, argc, pargv, &lookup);
|
||||||
|
+ if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
+ map_module_unlock(instance);
|
||||||
|
+ debug(ap->logopt, "open lookup module hosts failed");
|
||||||
|
+ goto out;
|
||||||
|
+ }
|
||||||
|
+ instance->lookup = lookup;
|
||||||
|
}
|
||||||
|
- instance->lookup = lookup;
|
||||||
|
+ map_module_unlock(instance);
|
||||||
|
}
|
||||||
|
- map_module_unlock(instance);
|
||||||
|
|
||||||
|
cache_writelock(source->mc);
|
||||||
|
me = cache_lookup_distinct(source->mc, name);
|
@ -0,0 +1,63 @@
|
|||||||
|
autofs-5.1.8 - fix incorrect path for is_mounted() in try_remount()
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
A regression was introduced when the offset mount handling was rewritten.
|
||||||
|
|
||||||
|
It resulted in an incorrect path sometimes being used in an is_mounted()
|
||||||
|
check.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
lib/mounts.c | 26 +++++++++++++++++++++-----
|
||||||
|
2 files changed, 22 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -104,6 +104,7 @@
|
||||||
|
- fix memory leak in update_hosts_mounts().
|
||||||
|
- fix concat_options() error handling.
|
||||||
|
- fix minus only option handling in concat_options().
|
||||||
|
+- fix incorrect path for is_mounted() in try_remount().
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/lib/mounts.c
|
||||||
|
+++ autofs-5.1.4/lib/mounts.c
|
||||||
|
@@ -2803,14 +2803,30 @@ int try_remount(struct autofs_point *ap,
|
||||||
|
ap->flags &= ~MOUNT_FLAG_DIR_CREATED;
|
||||||
|
else
|
||||||
|
ap->flags |= MOUNT_FLAG_DIR_CREATED;
|
||||||
|
+ goto done;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ me->flags &= ~MOUNT_FLAG_DIR_CREATED;
|
||||||
|
+ /* Direct or offset mount, key is full path */
|
||||||
|
+ if (MM_PARENT(me)->key[0] == '/') {
|
||||||
|
+ if (!is_mounted(MM_PARENT(me)->key, MNTS_REAL))
|
||||||
|
+ me->flags |= MOUNT_FLAG_DIR_CREATED;
|
||||||
|
} else {
|
||||||
|
- me->flags &= ~MOUNT_FLAG_DIR_CREATED;
|
||||||
|
- if (type == t_offset) {
|
||||||
|
- if (!is_mounted(MM_PARENT(me)->key, MNTS_REAL))
|
||||||
|
- me->flags |= MOUNT_FLAG_DIR_CREATED;
|
||||||
|
+ char *p_key = MM_PARENT(me)->key;
|
||||||
|
+ char mp[PATH_MAX + 1];
|
||||||
|
+ int len;
|
||||||
|
+
|
||||||
|
+ len = mount_fullpath(mp, PATH_MAX, ap->path, ap->len, p_key);
|
||||||
|
+ if (len > PATH_MAX) {
|
||||||
|
+ /* This should never happen due to earlier checks */
|
||||||
|
+ error(ap->logopt, "mountpoint path too long");
|
||||||
|
+ return 0;
|
||||||
|
}
|
||||||
|
- }
|
||||||
|
|
||||||
|
+ if (!is_mounted(mp, MNTS_REAL))
|
||||||
|
+ me->flags |= MOUNT_FLAG_DIR_CREATED;
|
||||||
|
+ }
|
||||||
|
+done:
|
||||||
|
/*
|
||||||
|
* Either we opened the mount or we're re-reading the map.
|
||||||
|
* If we opened the mount and ioctlfd is not -1 we have
|
46
SOURCES/autofs-5.1.8-fix-invalid-tsv-access.patch
Normal file
46
SOURCES/autofs-5.1.8-fix-invalid-tsv-access.patch
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
autofs-5.1.8 - fix invalid tsv access
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
When using the --dumpmaps option of automount(8) a SEGV can occur
|
||||||
|
because a thread specific data variable accessed in the code hasn't
|
||||||
|
yet been created.
|
||||||
|
|
||||||
|
The thread specific data doesn't need to be set to list the maps
|
||||||
|
so we can create the key and rely on pthread_getspecific() returning
|
||||||
|
NULL when the value hasn't been set as this case is handled correctly.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
daemon/automount.c | 9 +++++++++
|
||||||
|
2 files changed, 10 insertions(+)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -95,6 +95,7 @@
|
||||||
|
- remove nonstrict parameter from tree_mapent_umount_offsets().
|
||||||
|
- fix handling of incorrect return from umount_ent().
|
||||||
|
- dont use initgroups() at spawn.
|
||||||
|
+- fix invalid tsv access.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/daemon/automount.c
|
||||||
|
+++ autofs-5.1.4/daemon/automount.c
|
||||||
|
@@ -2510,6 +2510,15 @@ int main(int argc, char *argv[])
|
||||||
|
master = argv[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
+ status = pthread_key_create(&key_thread_stdenv_vars,
|
||||||
|
+ key_thread_stdenv_vars_destroy);
|
||||||
|
+ if (status) {
|
||||||
|
+ logerr("%s: failed to create thread data key for std env vars!",
|
||||||
|
+ program);
|
||||||
|
+ macro_free_global_table();
|
||||||
|
+ exit(1);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (master)
|
||||||
|
master_list = master_new(NULL, timeout, flags);
|
||||||
|
else
|
@ -0,0 +1,53 @@
|
|||||||
|
autofs-5.1.8 - fix memory leak in update_hosts_mounts()
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
Coverity has reported a memory leak in update_hosts_mounts() introduced
|
||||||
|
by the map reload deadlock fix.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/lookup_hosts.c | 13 +++++++------
|
||||||
|
2 files changed, 8 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -101,6 +101,7 @@
|
||||||
|
- coverity fix for invalid access.
|
||||||
|
- fix hosts map deadlock on restart.
|
||||||
|
- fix deadlock with hosts map reload.
|
||||||
|
+- fix memory leak in update_hosts_mounts().
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/lookup_hosts.c
|
||||||
|
+++ autofs-5.1.4/modules/lookup_hosts.c
|
||||||
|
@@ -307,20 +307,21 @@ next:
|
||||||
|
}
|
||||||
|
pthread_cleanup_pop(1);
|
||||||
|
|
||||||
|
- while (head) {
|
||||||
|
+ entries = head;
|
||||||
|
+ while (entries) {
|
||||||
|
debug(ap->logopt, MODPREFIX
|
||||||
|
- "attempt to update exports for %s", head->key);
|
||||||
|
+ "attempt to update exports for %s", entries->key);
|
||||||
|
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = source;
|
||||||
|
ap->flags |= MOUNT_FLAG_REMOUNT;
|
||||||
|
- ret = ctxt->parse->parse_mount(ap, head->key, strlen(head->key),
|
||||||
|
- head->entry, ctxt->parse->context);
|
||||||
|
+ ret = ctxt->parse->parse_mount(ap, entries->key, strlen(entries->key),
|
||||||
|
+ entries->entry, ctxt->parse->context);
|
||||||
|
if (ret)
|
||||||
|
warn(ap->logopt, MODPREFIX
|
||||||
|
- "failed to parse mount %s", head->entry);
|
||||||
|
+ "failed to parse mount %s", entries->entry);
|
||||||
|
ap->flags &= ~MOUNT_FLAG_REMOUNT;
|
||||||
|
- head = head->next;
|
||||||
|
+ entries = entries->next;
|
||||||
|
}
|
||||||
|
pthread_cleanup_pop(1);
|
||||||
|
}
|
@ -0,0 +1,88 @@
|
|||||||
|
autofs-5.1.8 - fix minus only option handling in concat_options()
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
While a '-' alone isn't strictly valid it hadn't previously cuased a
|
||||||
|
parse error. So commit 9047e91ffa69 (autofs-5.1.7 - fix concat_options()
|
||||||
|
error handling) introduced a regression by no longer allowing this.
|
||||||
|
|
||||||
|
Fix this regression by only failing if errno is set to a non-zero value
|
||||||
|
on return from concat_options() as well as returning NULL.
|
||||||
|
|
||||||
|
Fixes: 9047e91ffa69 (autofs-5.1.7 - fix concat_options() error handling)
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/parse_sun.c | 25 +++++++++++++++++++------
|
||||||
|
2 files changed, 20 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -103,6 +103,7 @@
|
||||||
|
- fix deadlock with hosts map reload.
|
||||||
|
- fix memory leak in update_hosts_mounts().
|
||||||
|
- fix concat_options() error handling.
|
||||||
|
+- fix minus only option handling in concat_options().
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_sun.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_sun.c
|
||||||
|
@@ -376,10 +376,16 @@ static int do_init(int argc, const char
|
||||||
|
if (gbl_options) {
|
||||||
|
append_options = defaults_get_append_options();
|
||||||
|
if (append_options) {
|
||||||
|
- char *tmp = concat_options(gbl_options, ctxt->optstr);
|
||||||
|
+ char *tmp;
|
||||||
|
+
|
||||||
|
+ errno = 0;
|
||||||
|
+ tmp = concat_options(gbl_options, ctxt->optstr);
|
||||||
|
if (!tmp) {
|
||||||
|
- char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
- logerr(MODPREFIX "concat_options: %s", estr);
|
||||||
|
+ /* Ignore non-error NULL return */
|
||||||
|
+ if (errno) {
|
||||||
|
+ char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
+ logerr(MODPREFIX "concat_options: %s", estr);
|
||||||
|
+ }
|
||||||
|
/* freed in concat_options */
|
||||||
|
ctxt->optstr = NULL;
|
||||||
|
} else
|
||||||
|
@@ -996,9 +1002,12 @@ static int parse_mapent(const char *ent,
|
||||||
|
free(myoptions);
|
||||||
|
myoptions = newopt;
|
||||||
|
} else if (newopt) {
|
||||||
|
+ errno = 0;
|
||||||
|
tmp = concat_options(myoptions, newopt);
|
||||||
|
- if (!tmp) {
|
||||||
|
+ /* Ignore non-error NULL return */
|
||||||
|
+ if (!tmp && errno) {
|
||||||
|
char *estr;
|
||||||
|
+
|
||||||
|
estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(logopt, MODPREFIX
|
||||||
|
"concat_options: %s", estr);
|
||||||
|
@@ -1370,8 +1379,10 @@ dont_expand:
|
||||||
|
free(mnt_options);
|
||||||
|
mnt_options = noptions;
|
||||||
|
} else if (noptions) {
|
||||||
|
+ errno = 0;
|
||||||
|
tmp = concat_options(mnt_options, noptions);
|
||||||
|
- if (!tmp) {
|
||||||
|
+ /* Ignore non-error NULL return */
|
||||||
|
+ if (!tmp && errno) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(ap->logopt,
|
||||||
|
MODPREFIX "concat_options: %s", estr);
|
||||||
|
@@ -1395,8 +1406,10 @@ dont_expand:
|
||||||
|
free(options);
|
||||||
|
options = mnt_options;
|
||||||
|
} else if (mnt_options) {
|
||||||
|
+ errno = 0;
|
||||||
|
tmp = concat_options(options, mnt_options);
|
||||||
|
- if (!tmp) {
|
||||||
|
+ /* Ignore non-error NULL return */
|
||||||
|
+ if (!tmp && errno) {
|
||||||
|
char *estr = strerror_r(errno, buf, MAX_ERR_BUF);
|
||||||
|
error(ap->logopt, MODPREFIX "concat_options: %s", estr);
|
||||||
|
free(pmapent);
|
@ -0,0 +1,183 @@
|
|||||||
|
autofs-5.1.8 - fix parse module instance mutex naming
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
The naming used for parse module instance locks is the same as that
|
||||||
|
used for map lookup instances. Rename these to make it clear they
|
||||||
|
are being used in the parse modules.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/parse_amd.c | 28 ++++++++++++++--------------
|
||||||
|
modules/parse_sun.c | 20 ++++++++++----------
|
||||||
|
3 files changed, 25 insertions(+), 24 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -96,6 +96,7 @@
|
||||||
|
- fix handling of incorrect return from umount_ent().
|
||||||
|
- dont use initgroups() at spawn.
|
||||||
|
- fix invalid tsv access.
|
||||||
|
+- fix parse module instance mutex naming.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_amd.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_amd.c
|
||||||
|
@@ -39,18 +39,18 @@ int parse_version = AUTOFS_PARSE_VERSION
|
||||||
|
|
||||||
|
static struct mount_mod *mount_nfs = NULL;
|
||||||
|
static int init_ctr = 0;
|
||||||
|
-static pthread_mutex_t instance_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
+static pthread_mutex_t parse_instance_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
|
||||||
|
-static void instance_mutex_lock(void)
|
||||||
|
+static void parse_instance_mutex_lock(void)
|
||||||
|
{
|
||||||
|
- int status = pthread_mutex_lock(&instance_mutex);
|
||||||
|
+ int status = pthread_mutex_lock(&parse_instance_mutex);
|
||||||
|
if (status)
|
||||||
|
fatal(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void instance_mutex_unlock(void)
|
||||||
|
+static void parse_instance_mutex_unlock(void)
|
||||||
|
{
|
||||||
|
- int status = pthread_mutex_unlock(&instance_mutex);
|
||||||
|
+ int status = pthread_mutex_unlock(&parse_instance_mutex);
|
||||||
|
if (status)
|
||||||
|
fatal(status);
|
||||||
|
}
|
||||||
|
@@ -112,7 +112,7 @@ int parse_init(int argc, const char *con
|
||||||
|
|
||||||
|
/* We only need this once. NFS mounts are so common that we cache
|
||||||
|
this module. */
|
||||||
|
- instance_mutex_lock();
|
||||||
|
+ parse_instance_mutex_lock();
|
||||||
|
if (mount_nfs)
|
||||||
|
init_ctr++;
|
||||||
|
else {
|
||||||
|
@@ -121,11 +121,11 @@ int parse_init(int argc, const char *con
|
||||||
|
} else {
|
||||||
|
kill_context(ctxt);
|
||||||
|
*context = NULL;
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@@ -1358,11 +1358,11 @@ static int do_host_mount(struct autofs_p
|
||||||
|
argc = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
- instance_mutex_lock();
|
||||||
|
+ parse_instance_mutex_lock();
|
||||||
|
status = open_lookup("hosts", MODPREFIX, NULL, argc, pargv, &lookup);
|
||||||
|
if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
debug(ap->logopt, "open lookup module hosts failed");
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1374,13 +1374,13 @@ static int do_host_mount(struct autofs_p
|
||||||
|
if (!instance) {
|
||||||
|
error(ap->logopt, MODPREFIX
|
||||||
|
"failed to create source instance for hosts map");
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
close_lookup(lookup);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
instance->lookup = lookup;
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
|
||||||
|
cache_writelock(source->mc);
|
||||||
|
me = cache_lookup_distinct(source->mc, name);
|
||||||
|
@@ -2373,12 +2373,12 @@ int parse_done(void *context)
|
||||||
|
int rv = 0;
|
||||||
|
struct parse_context *ctxt = (struct parse_context *) context;
|
||||||
|
|
||||||
|
- instance_mutex_lock();
|
||||||
|
+ parse_instance_mutex_lock();
|
||||||
|
if (--init_ctr == 0) {
|
||||||
|
rv = close_mount(mount_nfs);
|
||||||
|
mount_nfs = NULL;
|
||||||
|
}
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
if (ctxt)
|
||||||
|
kill_context(ctxt);
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_sun.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_sun.c
|
||||||
|
@@ -41,18 +41,18 @@ int parse_version = AUTOFS_PARSE_VERSION
|
||||||
|
|
||||||
|
static struct mount_mod *mount_nfs = NULL;
|
||||||
|
static int init_ctr = 0;
|
||||||
|
-static pthread_mutex_t instance_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
+static pthread_mutex_t parse_instance_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
|
||||||
|
-static void instance_mutex_lock(void)
|
||||||
|
+static void parse_instance_mutex_lock(void)
|
||||||
|
{
|
||||||
|
- int status = pthread_mutex_lock(&instance_mutex);
|
||||||
|
+ int status = pthread_mutex_lock(&parse_instance_mutex);
|
||||||
|
if (status)
|
||||||
|
fatal(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void instance_mutex_unlock(void)
|
||||||
|
+static void parse_instance_mutex_unlock(void)
|
||||||
|
{
|
||||||
|
- int status = pthread_mutex_unlock(&instance_mutex);
|
||||||
|
+ int status = pthread_mutex_unlock(&parse_instance_mutex);
|
||||||
|
if (status)
|
||||||
|
fatal(status);
|
||||||
|
}
|
||||||
|
@@ -423,7 +423,7 @@ int parse_init(int argc, const char *con
|
||||||
|
|
||||||
|
/* We only need this once. NFS mounts are so common that we cache
|
||||||
|
this module. */
|
||||||
|
- instance_mutex_lock();
|
||||||
|
+ parse_instance_mutex_lock();
|
||||||
|
if (mount_nfs)
|
||||||
|
init_ctr++;
|
||||||
|
else {
|
||||||
|
@@ -431,11 +431,11 @@ int parse_init(int argc, const char *con
|
||||||
|
init_ctr++;
|
||||||
|
} else {
|
||||||
|
kill_context(ctxt);
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
|
||||||
|
*context = (void *) ctxt;
|
||||||
|
|
||||||
|
@@ -1719,12 +1719,12 @@ int parse_done(void *context)
|
||||||
|
int rv = 0;
|
||||||
|
struct parse_context *ctxt = (struct parse_context *) context;
|
||||||
|
|
||||||
|
- instance_mutex_lock();
|
||||||
|
+ parse_instance_mutex_lock();
|
||||||
|
if (--init_ctr == 0) {
|
||||||
|
rv = close_mount(mount_nfs);
|
||||||
|
mount_nfs = NULL;
|
||||||
|
}
|
||||||
|
- instance_mutex_unlock();
|
||||||
|
+ parse_instance_mutex_unlock();
|
||||||
|
if (ctxt)
|
||||||
|
kill_context(ctxt);
|
||||||
|
|
@ -0,0 +1,59 @@
|
|||||||
|
autofs-5.1.8 - improve handling of ENOENT in sss setautomntent()
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
In the sss lookup module function setautomntent() a return of ENOENT
|
||||||
|
isn't handled quite right.
|
||||||
|
|
||||||
|
If ENOENT (rather than EHOSTDOWN) is returned from sss setautomntent()
|
||||||
|
we should assume the LDAP info. has been read by sss and the entry in
|
||||||
|
fact doesn't exist.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
modules/lookup_sss.c | 16 +++++++++++++++-
|
||||||
|
2 files changed, 16 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -106,6 +106,7 @@
|
||||||
|
- fix minus only option handling in concat_options().
|
||||||
|
- fix incorrect path for is_mounted() in try_remount().
|
||||||
|
- fail on empty replicated host name.
|
||||||
|
+- improve handling of ENOENT in sss setautomntent().
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/modules/lookup_sss.c
|
||||||
|
+++ autofs-5.1.4/modules/lookup_sss.c
|
||||||
|
@@ -394,7 +394,17 @@ static int setautomntent(unsigned int lo
|
||||||
|
if (ret != ENOENT)
|
||||||
|
goto error;
|
||||||
|
} else {
|
||||||
|
- if (ret != ENOENT && ret != EHOSTDOWN)
|
||||||
|
+ /* If we get an ENOENT here assume it's accurrate
|
||||||
|
+ * and return the error.
|
||||||
|
+ */
|
||||||
|
+ if (ret == ENOENT) {
|
||||||
|
+ error(logopt, MODPREFIX
|
||||||
|
+ "setautomountent: entry for map %s not found",
|
||||||
|
+ ctxt->mapname);
|
||||||
|
+ err = NSS_STATUS_NOTFOUND;
|
||||||
|
+ goto free;
|
||||||
|
+ }
|
||||||
|
+ if (ret != EHOSTDOWN)
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -410,6 +420,10 @@ static int setautomntent(unsigned int lo
|
||||||
|
if (ret == EINVAL)
|
||||||
|
goto free;
|
||||||
|
if (ret == ENOENT) {
|
||||||
|
+ /* Map info. not found after host became available */
|
||||||
|
+ error(logopt, MODPREFIX
|
||||||
|
+ "setautomountent: entry for map %s not found",
|
||||||
|
+ ctxt->mapname);
|
||||||
|
err = NSS_STATUS_NOTFOUND;
|
||||||
|
goto free;
|
||||||
|
}
|
@ -0,0 +1,272 @@
|
|||||||
|
autofs-5.1.8 - serialise lookup module open and reinit
|
||||||
|
|
||||||
|
From: Ian Kent <raven@themaw.net>
|
||||||
|
|
||||||
|
Add a map source lock to serialise map setting and use of module
|
||||||
|
structure fields such as the context.
|
||||||
|
|
||||||
|
Signed-off-by: Ian Kent <raven@themaw.net>
|
||||||
|
---
|
||||||
|
CHANGELOG | 1 +
|
||||||
|
daemon/lookup.c | 35 +++++++++++++++++++++--------------
|
||||||
|
daemon/master.c | 43 +++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
include/master.h | 5 +++++
|
||||||
|
modules/parse_amd.c | 26 +++++++++++++++-----------
|
||||||
|
5 files changed, 85 insertions(+), 25 deletions(-)
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/CHANGELOG
|
||||||
|
+++ autofs-5.1.4/CHANGELOG
|
||||||
|
@@ -97,6 +97,7 @@
|
||||||
|
- dont use initgroups() at spawn.
|
||||||
|
- fix invalid tsv access.
|
||||||
|
- fix parse module instance mutex naming.
|
||||||
|
+- serialise lookup module open and reinit.
|
||||||
|
|
||||||
|
xx/xx/2018 autofs-5.1.5
|
||||||
|
- fix flag file permission.
|
||||||
|
--- autofs-5.1.4.orig/daemon/lookup.c
|
||||||
|
+++ autofs-5.1.4/daemon/lookup.c
|
||||||
|
@@ -318,28 +318,27 @@ static int do_read_map(struct autofs_poi
|
||||||
|
struct lookup_mod *lookup;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
- lookup = NULL;
|
||||||
|
- master_source_writelock(ap->entry);
|
||||||
|
+ pthread_cleanup_push(map_module_lock_cleanup, map);
|
||||||
|
+ map_module_writelock(map);
|
||||||
|
if (!map->lookup) {
|
||||||
|
status = open_lookup(map->type, "", map->format,
|
||||||
|
map->argc, map->argv, &lookup);
|
||||||
|
- if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
- master_source_unlock(ap->entry);
|
||||||
|
+ if (status == NSS_STATUS_SUCCESS)
|
||||||
|
+ map->lookup = lookup;
|
||||||
|
+ else
|
||||||
|
debug(ap->logopt,
|
||||||
|
"lookup module %s open failed", map->type);
|
||||||
|
- return status;
|
||||||
|
- }
|
||||||
|
- map->lookup = lookup;
|
||||||
|
} else {
|
||||||
|
- lookup = map->lookup;
|
||||||
|
- status = lookup->lookup_reinit(map->format,
|
||||||
|
- map->argc, map->argv,
|
||||||
|
- &lookup->context);
|
||||||
|
+ status = map->lookup->lookup_reinit(map->format,
|
||||||
|
+ map->argc, map->argv,
|
||||||
|
+ &map->lookup->context);
|
||||||
|
if (status)
|
||||||
|
warn(ap->logopt,
|
||||||
|
"lookup module %s reinit failed", map->type);
|
||||||
|
}
|
||||||
|
- master_source_unlock(ap->entry);
|
||||||
|
+ pthread_cleanup_pop(1);
|
||||||
|
+ if (status != NSS_STATUS_SUCCESS)
|
||||||
|
+ return status;
|
||||||
|
|
||||||
|
if (!map->stale)
|
||||||
|
return NSS_STATUS_SUCCESS;
|
||||||
|
@@ -347,7 +346,11 @@ static int do_read_map(struct autofs_poi
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = map;
|
||||||
|
|
||||||
|
+ pthread_cleanup_push(map_module_lock_cleanup, map);
|
||||||
|
+ map_module_readlock(map);
|
||||||
|
+ lookup = map->lookup;
|
||||||
|
status = lookup->lookup_read_map(ap, age, lookup->context);
|
||||||
|
+ pthread_cleanup_pop(1);
|
||||||
|
|
||||||
|
if (status != NSS_STATUS_SUCCESS)
|
||||||
|
map->stale = 0;
|
||||||
|
@@ -812,23 +815,27 @@ int do_lookup_mount(struct autofs_point
|
||||||
|
struct lookup_mod *lookup;
|
||||||
|
int status;
|
||||||
|
|
||||||
|
+ map_module_writelock(map);
|
||||||
|
if (!map->lookup) {
|
||||||
|
status = open_lookup(map->type, "",
|
||||||
|
map->format, map->argc, map->argv, &lookup);
|
||||||
|
if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
debug(ap->logopt,
|
||||||
|
"lookup module %s open failed", map->type);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
map->lookup = lookup;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- lookup = map->lookup;
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = map;
|
||||||
|
|
||||||
|
+ map_module_readlock(map);
|
||||||
|
+ lookup = map->lookup;
|
||||||
|
status = lookup->lookup_mount(ap, name, name_len, lookup->context);
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
--- autofs-5.1.4.orig/daemon/master.c
|
||||||
|
+++ autofs-5.1.4/daemon/master.c
|
||||||
|
@@ -65,6 +65,34 @@ void master_mutex_lock_cleanup(void *arg
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
+void map_module_writelock(struct map_source *map)
|
||||||
|
+{
|
||||||
|
+ int status = pthread_rwlock_wrlock(&map->module_lock);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void map_module_readlock(struct map_source *map)
|
||||||
|
+{
|
||||||
|
+ int status = pthread_rwlock_rdlock(&map->module_lock);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void map_module_unlock(struct map_source *map)
|
||||||
|
+{
|
||||||
|
+ int status = pthread_rwlock_unlock(&map->module_lock);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+void map_module_lock_cleanup(void *arg)
|
||||||
|
+{
|
||||||
|
+ struct map_source *map = (struct map_source *) arg;
|
||||||
|
+
|
||||||
|
+ map_module_unlock(map);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
int master_add_autofs_point(struct master_mapent *entry, unsigned logopt,
|
||||||
|
unsigned nobind, unsigned ghost, int submount)
|
||||||
|
{
|
||||||
|
@@ -155,6 +183,7 @@ master_add_map_source(struct master_mape
|
||||||
|
struct map_source *source;
|
||||||
|
char *ntype, *nformat;
|
||||||
|
const char **tmpargv;
|
||||||
|
+ int status;
|
||||||
|
|
||||||
|
source = malloc(sizeof(struct map_source));
|
||||||
|
if (!source)
|
||||||
|
@@ -241,6 +270,10 @@ master_add_map_source(struct master_mape
|
||||||
|
|
||||||
|
master_source_unlock(entry);
|
||||||
|
|
||||||
|
+ status = pthread_rwlock_init(&source->module_lock, NULL);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+
|
||||||
|
return source;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -330,6 +363,8 @@ master_get_map_source(struct master_mape
|
||||||
|
|
||||||
|
static void __master_free_map_source(struct map_source *source, unsigned int free_cache)
|
||||||
|
{
|
||||||
|
+ int status;
|
||||||
|
+
|
||||||
|
/* instance map sources are not ref counted */
|
||||||
|
if (source->ref && --source->ref)
|
||||||
|
return;
|
||||||
|
@@ -365,6 +400,10 @@ static void __master_free_map_source(str
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+ status = pthread_rwlock_destroy(&source->module_lock);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+
|
||||||
|
free(source);
|
||||||
|
|
||||||
|
return;
|
||||||
|
@@ -496,6 +535,10 @@ master_add_source_instance(struct map_so
|
||||||
|
if (status)
|
||||||
|
fatal(status);
|
||||||
|
|
||||||
|
+ status = pthread_rwlock_init(&new->module_lock, NULL);
|
||||||
|
+ if (status)
|
||||||
|
+ fatal(status);
|
||||||
|
+
|
||||||
|
return new;
|
||||||
|
}
|
||||||
|
|
||||||
|
--- autofs-5.1.4.orig/include/master.h
|
||||||
|
+++ autofs-5.1.4/include/master.h
|
||||||
|
@@ -35,6 +35,7 @@ struct map_source {
|
||||||
|
unsigned int stale;
|
||||||
|
unsigned int recurse;
|
||||||
|
unsigned int depth;
|
||||||
|
+ pthread_rwlock_t module_lock;
|
||||||
|
struct lookup_mod *lookup;
|
||||||
|
int argc;
|
||||||
|
const char **argv;
|
||||||
|
@@ -126,5 +127,9 @@ int __master_list_empty(struct master *)
|
||||||
|
int master_list_empty(struct master *);
|
||||||
|
int master_done(struct master *);
|
||||||
|
int master_kill(struct master *);
|
||||||
|
+void map_module_writelock(struct map_source *map);
|
||||||
|
+void map_module_readlock(struct map_source *map);
|
||||||
|
+void map_module_unlock(struct map_source *map);
|
||||||
|
+void map_module_lock_cleanup(void *arg);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
--- autofs-5.1.4.orig/modules/parse_amd.c
|
||||||
|
+++ autofs-5.1.4/modules/parse_amd.c
|
||||||
|
@@ -1358,14 +1358,6 @@ static int do_host_mount(struct autofs_p
|
||||||
|
argc = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
- parse_instance_mutex_lock();
|
||||||
|
- status = open_lookup("hosts", MODPREFIX, NULL, argc, pargv, &lookup);
|
||||||
|
- if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
- debug(ap->logopt, "open lookup module hosts failed");
|
||||||
|
- parse_instance_mutex_unlock();
|
||||||
|
- goto out;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
instance = master_find_source_instance(source,
|
||||||
|
"hosts", "sun", argc, pargv);
|
||||||
|
if (!instance) {
|
||||||
|
@@ -1374,13 +1366,22 @@ static int do_host_mount(struct autofs_p
|
||||||
|
if (!instance) {
|
||||||
|
error(ap->logopt, MODPREFIX
|
||||||
|
"failed to create source instance for hosts map");
|
||||||
|
- parse_instance_mutex_unlock();
|
||||||
|
close_lookup(lookup);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- instance->lookup = lookup;
|
||||||
|
- parse_instance_mutex_unlock();
|
||||||
|
+
|
||||||
|
+ map_module_writelock(instance);
|
||||||
|
+ if (!instance->lookup) {
|
||||||
|
+ status = open_lookup("hosts", MODPREFIX, NULL, argc, pargv, &lookup);
|
||||||
|
+ if (status != NSS_STATUS_SUCCESS) {
|
||||||
|
+ map_module_unlock(instance);
|
||||||
|
+ debug(ap->logopt, "open lookup module hosts failed");
|
||||||
|
+ goto out;
|
||||||
|
+ }
|
||||||
|
+ instance->lookup = lookup;
|
||||||
|
+ }
|
||||||
|
+ map_module_unlock(instance);
|
||||||
|
|
||||||
|
cache_writelock(source->mc);
|
||||||
|
me = cache_lookup_distinct(source->mc, name);
|
||||||
|
@@ -1391,8 +1392,11 @@ static int do_host_mount(struct autofs_p
|
||||||
|
master_source_current_wait(ap->entry);
|
||||||
|
ap->entry->current = source;
|
||||||
|
|
||||||
|
+ map_module_readlock(instance);
|
||||||
|
+ lookup = instance->lookup;
|
||||||
|
ret = lookup->lookup_mount(ap, entry->rhost,
|
||||||
|
strlen(entry->rhost), lookup->context);
|
||||||
|
+ map_module_unlock(instance);
|
||||||
|
|
||||||
|
if (!strcmp(name, entry->rhost))
|
||||||
|
goto out;
|
@ -8,7 +8,7 @@
|
|||||||
Summary: A tool for automatically mounting and unmounting filesystems
|
Summary: A tool for automatically mounting and unmounting filesystems
|
||||||
Name: autofs
|
Name: autofs
|
||||||
Version: 5.1.4
|
Version: 5.1.4
|
||||||
Release: 83%{?dist}
|
Release: 93%{?dist}
|
||||||
Epoch: 1
|
Epoch: 1
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: System Environment/Daemons
|
Group: System Environment/Daemons
|
||||||
@ -267,6 +267,19 @@ Patch239: autofs-5.1.8-remove-nonstrict-parameter-from-tree_mapent_umount_offset
|
|||||||
Patch240: autofs-5.1.8-fix-handling-of-incorrect-return-from-umount_ent.patch
|
Patch240: autofs-5.1.8-fix-handling-of-incorrect-return-from-umount_ent.patch
|
||||||
|
|
||||||
Patch241: autofs-5.1.8-dont-use-initgroups-at-spawn.patch
|
Patch241: autofs-5.1.8-dont-use-initgroups-at-spawn.patch
|
||||||
|
Patch242: autofs-5.1.8-fix-invalid-tsv-access.patch
|
||||||
|
Patch243: autofs-5.1.8-fix-parse-module-instance-mutex-naming.patch
|
||||||
|
Patch244: autofs-5.1.8-serialise-lookup-module-open-and-reinit.patch
|
||||||
|
Patch245: autofs-5.1.8-coverity-fix-for-invalid-access.patch
|
||||||
|
Patch246: autofs-5.1.8-fix-hosts-map-deadlock-on-restart.patch
|
||||||
|
Patch247: autofs-5.1.8-fix-deadlock-with-hosts-map-reload.patch
|
||||||
|
Patch248: autofs-5.1.8-fix-memory-leak-in-update_hosts_mounts.patch
|
||||||
|
Patch249: autofs-5.1.7-fix-concat_options-error-handling.patch
|
||||||
|
Patch250: autofs-5.1.8-fix-minus-only-option-handling-in-concat_options.patch
|
||||||
|
Patch251: autofs-5.1.8-fix-incorrect-path-for-is_mounted-in-try_remount.patch
|
||||||
|
Patch252: autofs-5.1.8-fail-on-empty-replicated-host-name.patch
|
||||||
|
Patch253: autofs-5.1.8-improve-handling-of-ENOENT-in-sss-setautomntent.patch
|
||||||
|
Patch254: autofs-5.1.8-dont-immediately-call-function-when-waiting.patch
|
||||||
|
|
||||||
%if %{with_systemd}
|
%if %{with_systemd}
|
||||||
BuildRequires: systemd-units
|
BuildRequires: systemd-units
|
||||||
@ -575,6 +588,19 @@ echo %{version}-%{release} > .version
|
|||||||
%patch239 -p1
|
%patch239 -p1
|
||||||
%patch240 -p1
|
%patch240 -p1
|
||||||
%patch241 -p1
|
%patch241 -p1
|
||||||
|
%patch242 -p1
|
||||||
|
%patch243 -p1
|
||||||
|
%patch244 -p1
|
||||||
|
%patch245 -p1
|
||||||
|
%patch246 -p1
|
||||||
|
%patch247 -p1
|
||||||
|
%patch248 -p1
|
||||||
|
%patch249 -p1
|
||||||
|
%patch250 -p1
|
||||||
|
%patch251 -p1
|
||||||
|
%patch252 -p1
|
||||||
|
%patch253 -p1
|
||||||
|
%patch254 -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
LDFLAGS=-Wl,-z,now
|
LDFLAGS=-Wl,-z,now
|
||||||
@ -670,6 +696,68 @@ fi
|
|||||||
%dir /etc/auto.master.d
|
%dir /etc/auto.master.d
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Feb 08 2023 Ian Kent <ikent@redhat.com> - 5.1.4-93
|
||||||
|
- bz2165143 - Autofs reports can't connect to sssd, retry for 10 seconds when
|
||||||
|
real problem is empty LDAP object
|
||||||
|
- improve handling of ENOENT in sss setautomntent().
|
||||||
|
- dont immediately call function when waiting.
|
||||||
|
- Resolves: rhbz#2165143
|
||||||
|
|
||||||
|
* Tue Jan 24 2023 Ian Kent <ikent@redhat.com> - 5.1.4-92
|
||||||
|
- bz2161336 - Users can trigger a simple autofs DoS with wildcard automounter maps
|
||||||
|
- fail on empty trailing replicated host name.
|
||||||
|
- Resolves: rhbz#2161336
|
||||||
|
|
||||||
|
* Mon Dec 05 2022 Ian Kent <ikent@redhat.com> - 5.1.4-91
|
||||||
|
- bz2148872 - autofs: errors in autofs-5.1.4-83.el8.x86_64 when restarting
|
||||||
|
autofs with busy directories
|
||||||
|
- fix incorrect path for is_mounted() in try_remount().
|
||||||
|
- Resolves: rhbz#2148872
|
||||||
|
|
||||||
|
* Mon Dec 05 2022 Ian Kent <ikent@redhat.com> - 5.1.4-90
|
||||||
|
- bz2149206 - RHEL9: automount does not handle null option string after
|
||||||
|
"-" anymore
|
||||||
|
- fix changelog entry.
|
||||||
|
- Related: rhbz#2149206
|
||||||
|
|
||||||
|
* Mon Dec 05 2022 Ian Kent <ikent@redhat.com> - 5.1.4-89
|
||||||
|
- bz2149206 - RHEL9: automount does not handle null option string after
|
||||||
|
"-" anymore
|
||||||
|
- fix concat_options() error handling.
|
||||||
|
- fix minus only option handling in concat_options().
|
||||||
|
- Resolves: rhbz#2149206
|
||||||
|
|
||||||
|
* Tue Nov 29 2022 Ian Kent <ikent@redhat.com> - 5.1.4-88
|
||||||
|
- bz2139504 - segfault due to lookup_mod->context address being freed
|
||||||
|
and reused while multiple threads were using it
|
||||||
|
- fix memory leak in update_hosts_mounts().
|
||||||
|
- Related: rhbz#2139504
|
||||||
|
|
||||||
|
* Sun Nov 27 2022 Ian Kent <ikent@redhat.com> - 5.1.4-87
|
||||||
|
- bz2139504 - segfault due to lookup_mod->context address being freed
|
||||||
|
and reused while multiple threads were using it
|
||||||
|
- fix hosts map deadlock on restart.
|
||||||
|
- fix deadlock with hosts map reload.
|
||||||
|
- Related: rhbz#2139504
|
||||||
|
|
||||||
|
* Wed Nov 23 2022 Ian Kent <ikent@redhat.com> - 5.1.4-86
|
||||||
|
- bz2139504 - segfault due to lookup_mod->context address being freed
|
||||||
|
and reused while multiple threads were using it
|
||||||
|
- coverity fix for invalid access.
|
||||||
|
- Related: rhbz#2139504
|
||||||
|
|
||||||
|
* Wed Nov 09 2022 Ian Kent <ikent@redhat.com> - 5.1.4-85
|
||||||
|
- bz2139504 - segfault due to lookup_mod->context address being freed
|
||||||
|
and reused while multiple threads were using it
|
||||||
|
- fix parse module instance mutex naming.
|
||||||
|
- serialise lookup module open and reinit.
|
||||||
|
- Resolves: rhbz#2139504
|
||||||
|
|
||||||
|
* Tue Oct 04 2022 Ian Kent <ikent@redhat.com> - 5.1.4-84
|
||||||
|
- bz2130034 - automount -m crashes with Segmentation fault (core dumped)
|
||||||
|
- fix invalid tsv access.
|
||||||
|
- Resolves: rhbz#2130034
|
||||||
|
|
||||||
* Wed May 18 2022 Ian Kent <ikent@redhat.com> - 5.1.4-83
|
* Wed May 18 2022 Ian Kent <ikent@redhat.com> - 5.1.4-83
|
||||||
- bz2069097 - libnss_sss: threads stuck at sss_nss_lock from initgroups
|
- bz2069097 - libnss_sss: threads stuck at sss_nss_lock from initgroups
|
||||||
- dont use initgroups() at spawn.
|
- dont use initgroups() at spawn.
|
||||||
|
Loading…
Reference in New Issue
Block a user