Blame SOURCES/autofs-5.1.2-fix-included-master-map-not-found-return.patch

23b4c9
autofs-5.1.2 - fix included master map not found return
23b4c9
23b4c9
From: Ian Kent <raven@themaw.net>
23b4c9
23b4c9
When retrying the master map read at startup a not found return is needed
23b4c9
when there is no map rather than an unknown or unavailable for the retry
23b4c9
logic to work.
23b4c9
23b4c9
Signed-off-by: Ian Kent <raven@themaw.net>
23b4c9
---
23b4c9
 CHANGELOG             |    1 +
23b4c9
 daemon/lookup.c       |    6 ++++--
23b4c9
 modules/lookup_file.c |   18 ++++++++++++------
23b4c9
 3 files changed, 17 insertions(+), 8 deletions(-)
23b4c9
23b4c9
--- autofs-5.0.7.orig/CHANGELOG
23b4c9
+++ autofs-5.0.7/CHANGELOG
23b4c9
@@ -208,6 +208,7 @@
23b4c9
 - add config option to supress not found log message.
23b4c9
 - wait for master map available at start.
23b4c9
 - add master read wait option.
23b4c9
+- fix included master map not found return.
23b4c9
 
23b4c9
 25/07/2012 autofs-5.0.7
23b4c9
 =======================
23b4c9
--- autofs-5.0.7.orig/daemon/lookup.c
23b4c9
+++ autofs-5.0.7/daemon/lookup.c
23b4c9
@@ -241,7 +241,7 @@ int lookup_nss_read_master(struct master
23b4c9
 	}
23b4c9
 
23b4c9
 	/* First one gets it */
23b4c9
-	result = NSS_STATUS_UNKNOWN;
23b4c9
+	result = NSS_STATUS_SUCCESS;
23b4c9
 	head = &nsslist;
23b4c9
 	list_for_each(p, head) {
23b4c9
 		struct nss_source *this;
23b4c9
@@ -282,8 +282,10 @@ int lookup_nss_read_master(struct master
23b4c9
 			}
23b4c9
 		}
23b4c9
 
23b4c9
-		if (result == NSS_STATUS_UNKNOWN) {
23b4c9
+		if (result == NSS_STATUS_UNKNOWN ||
23b4c9
+		    result == NSS_STATUS_NOTFOUND) {
23b4c9
 			debug(logopt, "no map - continuing to next source");
23b4c9
+			result = NSS_STATUS_SUCCESS;
23b4c9
 			continue;
23b4c9
 		}
23b4c9
 
23b4c9
--- autofs-5.0.7.orig/modules/lookup_file.c
23b4c9
+++ autofs-5.0.7/modules/lookup_file.c
23b4c9
@@ -463,6 +463,8 @@ int lookup_read_master(struct master *ma
23b4c9
 
23b4c9
 	f = open_fopen_r(ctxt->mapname);
23b4c9
 	if (!f) {
23b4c9
+		if (errno == ENOENT)
23b4c9
+			return NSS_STATUS_NOTFOUND;
23b4c9
 		error(logopt,
23b4c9
 		      MODPREFIX "could not open master map file %s",
23b4c9
 		      ctxt->mapname);
23b4c9
@@ -506,12 +508,14 @@ int lookup_read_master(struct master *ma
23b4c9
 				     MODPREFIX
23b4c9
 				     "failed to read included master map %s",
23b4c9
 				     master->name);
23b4c9
-				/*
23b4c9
-				 * If we're starting up wee need the whole
23b4c9
-				 * master map initially, so tell the upper
23b4c9
-				 * layer to retry.
23b4c9
-				 */
23b4c9
-				master->read_fail = 1;
23b4c9
+				if (status != NSS_STATUS_NOTFOUND) {
23b4c9
+					/*
23b4c9
+					 * If we're starting up wee need the whole
23b4c9
+					 * master map initially, so tell the upper
23b4c9
+					 * layer to retry.
23b4c9
+					 */
23b4c9
+					master->read_fail = 1;
23b4c9
+				}
23b4c9
 			}
23b4c9
 			master->depth--;
23b4c9
 			master->recurse = 0;
23b4c9
@@ -712,6 +716,8 @@ int lookup_read_map(struct autofs_point
23b4c9
 
23b4c9
 	f = open_fopen_r(ctxt->mapname);
23b4c9
 	if (!f) {
23b4c9
+		if (errno == ENOENT)
23b4c9
+			return NSS_STATUS_NOTFOUND;
23b4c9
 		error(ap->logopt,
23b4c9
 		      MODPREFIX "could not open map file %s", ctxt->mapname);
23b4c9
 		return NSS_STATUS_UNAVAIL;