|
|
85ad07 |
autofs-5.1.4 - use flags for startup boolean options
|
|
|
85ad07 |
|
|
|
85ad07 |
From: Ian Kent <raven@themaw.net>
|
|
|
85ad07 |
|
|
|
85ad07 |
The daemon uses a number of boolean flags each stored in unsigned int
|
|
|
85ad07 |
variables. But a single bit flag is sufficient storage for most of
|
|
|
85ad07 |
these flags.
|
|
|
85ad07 |
|
|
|
85ad07 |
So use bit flags for these where possible.
|
|
|
85ad07 |
|
|
|
85ad07 |
Signed-off-by: Ian Kent <raven@themaw.net>
|
|
|
85ad07 |
---
|
|
|
85ad07 |
CHANGELOG | 1 +
|
|
|
85ad07 |
daemon/automount.c | 45 ++++++++++++++++++++++-----------------------
|
|
|
85ad07 |
include/automount.h | 6 ++++++
|
|
|
85ad07 |
lib/master.c | 4 ++--
|
|
|
85ad07 |
4 files changed, 31 insertions(+), 25 deletions(-)
|
|
|
85ad07 |
|
|
|
85ad07 |
--- autofs-5.0.7.orig/CHANGELOG
|
|
|
85ad07 |
+++ autofs-5.0.7/CHANGELOG
|
|
|
85ad07 |
@@ -313,6 +313,7 @@
|
|
|
85ad07 |
- fix incorrect locking in sss lookup.
|
|
|
85ad07 |
- add NULL check in prepare_attempt_prefix().
|
|
|
85ad07 |
- update build info with systemd.
|
|
|
85ad07 |
+- use flags for startup boolean options.
|
|
|
85ad07 |
|
|
|
85ad07 |
25/07/2012 autofs-5.0.7
|
|
|
85ad07 |
=======================
|
|
|
85ad07 |
--- autofs-5.0.7.orig/daemon/automount.c
|
|
|
85ad07 |
+++ autofs-5.0.7/daemon/automount.c
|
|
|
85ad07 |
@@ -1197,7 +1197,7 @@ static int handle_packet(struct autofs_p
|
|
|
85ad07 |
return -1;
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
-static void become_daemon(unsigned foreground, unsigned daemon_check)
|
|
|
85ad07 |
+static void become_daemon(unsigned int flags)
|
|
|
85ad07 |
{
|
|
|
85ad07 |
FILE *pidfp;
|
|
|
85ad07 |
char buf[MAX_ERR_BUF];
|
|
|
85ad07 |
@@ -1212,8 +1212,8 @@ static void become_daemon(unsigned foreg
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
/* Detach from foreground process */
|
|
|
85ad07 |
- if (foreground) {
|
|
|
85ad07 |
- if (daemon_check && !aquire_flag_file()) {
|
|
|
85ad07 |
+ if (flags & DAEMON_FLAGS_FOREGROUND) {
|
|
|
85ad07 |
+ if ((flags & DAEMON_FLAGS_CHECK_DAEMON) && !aquire_flag_file()) {
|
|
|
85ad07 |
fprintf(stderr, "%s: program is already running.\n",
|
|
|
85ad07 |
program);
|
|
|
85ad07 |
exit(1);
|
|
|
85ad07 |
@@ -1240,7 +1240,7 @@ static void become_daemon(unsigned foreg
|
|
|
85ad07 |
}
|
|
|
85ad07 |
close(start_pipefd[0]);
|
|
|
85ad07 |
|
|
|
85ad07 |
- if (daemon_check && !aquire_flag_file()) {
|
|
|
85ad07 |
+ if ((flags & DAEMON_FLAGS_CHECK_DAEMON) && !aquire_flag_file()) {
|
|
|
85ad07 |
fprintf(stderr, "%s: program is already running.\n",
|
|
|
85ad07 |
program);
|
|
|
85ad07 |
/* Return success if already running */
|
|
|
85ad07 |
@@ -2159,8 +2159,8 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
{
|
|
|
85ad07 |
int res, opt, status;
|
|
|
85ad07 |
int logpri = -1;
|
|
|
85ad07 |
- unsigned ghost, logging, daemon_check;
|
|
|
85ad07 |
- unsigned dumpmaps, foreground, have_global_options;
|
|
|
85ad07 |
+ unsigned int flags;
|
|
|
85ad07 |
+ unsigned int logging;
|
|
|
85ad07 |
unsigned master_read;
|
|
|
85ad07 |
int master_wait;
|
|
|
85ad07 |
time_t timeout;
|
|
|
85ad07 |
@@ -2203,17 +2203,15 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
|
|
|
85ad07 |
nfs_mount_uses_string_options = check_nfs_mount_version(&vers, &check);
|
|
|
85ad07 |
|
|
|
85ad07 |
+ flags = defaults_get_browse_mode() ? DAEMON_FLAGS_GHOST : 0;
|
|
|
85ad07 |
+ flags |= DAEMON_FLAGS_CHECK_DAEMON;
|
|
|
85ad07 |
+
|
|
|
85ad07 |
kpkt_len = get_kpkt_len();
|
|
|
85ad07 |
master_wait = defaults_get_master_wait();
|
|
|
85ad07 |
timeout = defaults_get_timeout();
|
|
|
85ad07 |
- ghost = defaults_get_browse_mode();
|
|
|
85ad07 |
logging = defaults_get_logging();
|
|
|
85ad07 |
global_selection_options = 0;
|
|
|
85ad07 |
global_options = NULL;
|
|
|
85ad07 |
- have_global_options = 0;
|
|
|
85ad07 |
- foreground = 0;
|
|
|
85ad07 |
- dumpmaps = 0;
|
|
|
85ad07 |
- daemon_check = 1;
|
|
|
85ad07 |
|
|
|
85ad07 |
remove_empty_args(argv, &argc);
|
|
|
85ad07 |
|
|
|
85ad07 |
@@ -2245,7 +2243,7 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'f':
|
|
|
85ad07 |
- foreground = 1;
|
|
|
85ad07 |
+ flags |= DAEMON_FLAGS_FOREGROUND;
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'V':
|
|
|
85ad07 |
@@ -2261,7 +2259,7 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'm':
|
|
|
85ad07 |
- dumpmaps = 1;
|
|
|
85ad07 |
+ flags |= DAEMON_FLAGS_DUMP_MAPS;
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'M':
|
|
|
85ad07 |
@@ -2269,9 +2267,9 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'O':
|
|
|
85ad07 |
- if (!have_global_options) {
|
|
|
85ad07 |
+ if (!(flags & DAEMON_FLAGS_HAVE_GLOBAL_OPTIONS)) {
|
|
|
85ad07 |
global_options = strdup(optarg);
|
|
|
85ad07 |
- have_global_options = 1;
|
|
|
85ad07 |
+ flags |= DAEMON_FLAGS_HAVE_GLOBAL_OPTIONS;
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
}
|
|
|
85ad07 |
printf("%s: global options already specified.\n",
|
|
|
85ad07 |
@@ -2296,7 +2294,7 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'C':
|
|
|
85ad07 |
- daemon_check = 0;
|
|
|
85ad07 |
+ flags &= ~DAEMON_FLAGS_CHECK_DAEMON;
|
|
|
85ad07 |
break;
|
|
|
85ad07 |
|
|
|
85ad07 |
case 'F':
|
|
|
85ad07 |
@@ -2355,7 +2353,8 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
#endif
|
|
|
85ad07 |
|
|
|
85ad07 |
/* Don't need the kernel module just to look at the configured maps */
|
|
|
85ad07 |
- if (!dumpmaps && (!query_kproto_ver() || get_kver_major() < 5)) {
|
|
|
85ad07 |
+ if (!(flags & DAEMON_FLAGS_DUMP_MAPS) &&
|
|
|
85ad07 |
+ (!query_kproto_ver() || get_kver_major() < 5)) {
|
|
|
85ad07 |
fprintf(stderr,
|
|
|
85ad07 |
"%s: test mount forbidden or "
|
|
|
85ad07 |
"incorrect kernel protocol version, "
|
|
|
85ad07 |
@@ -2386,7 +2385,7 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
/* Get processor information for predefined escapes */
|
|
|
85ad07 |
macro_init();
|
|
|
85ad07 |
|
|
|
85ad07 |
- if (dumpmaps) {
|
|
|
85ad07 |
+ if (flags & DAEMON_FLAGS_DUMP_MAPS) {
|
|
|
85ad07 |
struct master_mapent *entry;
|
|
|
85ad07 |
struct list_head *head, *p;
|
|
|
85ad07 |
struct mapent_cache *nc;
|
|
|
85ad07 |
@@ -2404,9 +2403,9 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
if (master)
|
|
|
85ad07 |
- master_list = master_new(NULL, timeout, ghost);
|
|
|
85ad07 |
+ master_list = master_new(NULL, timeout, flags);
|
|
|
85ad07 |
else
|
|
|
85ad07 |
- master_list = master_new(master, timeout, ghost);
|
|
|
85ad07 |
+ master_list = master_new(master, timeout, flags);
|
|
|
85ad07 |
if (!master_list) {
|
|
|
85ad07 |
printf("%s: can't create master map", program);
|
|
|
85ad07 |
macro_free_global_table();
|
|
|
85ad07 |
@@ -2452,9 +2451,9 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
if (argc == 0)
|
|
|
85ad07 |
- master_list = master_new(NULL, timeout, ghost);
|
|
|
85ad07 |
+ master_list = master_new(NULL, timeout, flags);
|
|
|
85ad07 |
else
|
|
|
85ad07 |
- master_list = master_new(argv[0], timeout, ghost);
|
|
|
85ad07 |
+ master_list = master_new(argv[0], timeout, flags);
|
|
|
85ad07 |
|
|
|
85ad07 |
if (!master_list) {
|
|
|
85ad07 |
printf("%s: can't create master map %s", program, argv[0]);
|
|
|
85ad07 |
@@ -2462,7 +2461,7 @@ int main(int argc, char *argv[])
|
|
|
85ad07 |
exit(1);
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
- become_daemon(foreground, daemon_check);
|
|
|
85ad07 |
+ become_daemon(flags);
|
|
|
85ad07 |
|
|
|
85ad07 |
if (pthread_attr_init(&th_attr)) {
|
|
|
85ad07 |
logerr("%s: failed to init thread attribute struct!",
|
|
|
85ad07 |
--- autofs-5.0.7.orig/include/automount.h
|
|
|
85ad07 |
+++ autofs-5.0.7/include/automount.h
|
|
|
85ad07 |
@@ -73,6 +73,12 @@ int load_autofs4_module(void);
|
|
|
85ad07 |
#define SLOPPY
|
|
|
85ad07 |
#endif
|
|
|
85ad07 |
|
|
|
85ad07 |
+#define DAEMON_FLAGS_FOREGROUND 0x0001
|
|
|
85ad07 |
+#define DAEMON_FLAGS_HAVE_GLOBAL_OPTIONS 0x0004
|
|
|
85ad07 |
+#define DAEMON_FLAGS_GHOST 0x0008
|
|
|
85ad07 |
+#define DAEMON_FLAGS_CHECK_DAEMON 0x0010
|
|
|
85ad07 |
+#define DAEMON_FLAGS_DUMP_MAPS 0x0020
|
|
|
85ad07 |
+
|
|
|
85ad07 |
#define AUTOFS_SUPER_MAGIC 0x00000187L
|
|
|
85ad07 |
#define SMB_SUPER_MAGIC 0x0000517BL
|
|
|
85ad07 |
#define CIFS_MAGIC_NUMBER 0xFF534D42L
|
|
|
85ad07 |
--- autofs-5.0.7.orig/lib/master.c
|
|
|
85ad07 |
+++ autofs-5.0.7/lib/master.c
|
|
|
85ad07 |
@@ -921,7 +921,7 @@ void master_free_mapent(struct master_ma
|
|
|
85ad07 |
return;
|
|
|
85ad07 |
}
|
|
|
85ad07 |
|
|
|
85ad07 |
-struct master *master_new(const char *name, unsigned int timeout, unsigned int ghost)
|
|
|
85ad07 |
+struct master *master_new(const char *name, unsigned int timeout, unsigned int flags)
|
|
|
85ad07 |
{
|
|
|
85ad07 |
struct master *master;
|
|
|
85ad07 |
char *tmp;
|
|
|
85ad07 |
@@ -947,7 +947,7 @@ struct master *master_new(const char *na
|
|
|
85ad07 |
master->depth = 0;
|
|
|
85ad07 |
master->reading = 0;
|
|
|
85ad07 |
master->read_fail = 0;
|
|
|
85ad07 |
- master->default_ghost = ghost;
|
|
|
85ad07 |
+ master->default_ghost = flags & DAEMON_FLAGS_GHOST;
|
|
|
85ad07 |
master->default_timeout = timeout;
|
|
|
85ad07 |
master->default_logging = defaults_get_logging();
|
|
|
85ad07 |
master->logopt = master->default_logging;
|