You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							116 lines
						
					
					
						
							3.7 KiB
						
					
					
				
			
		
		
	
	
							116 lines
						
					
					
						
							3.7 KiB
						
					
					
				| # --- SDE-COPYRIGHT-NOTE-BEGIN --- | |
| # This copyright note is auto-generated by ./scripts/Create-CopyPatch. | |
| # | |
| # Filename: package/.../autofs/2-fg.patch | |
| # Copyright (C) 2006 The T2 SDE Project | |
| # | |
| # More information can be found in the files COPYING and README. | |
| # | |
| # This patch file is dual-licensed. It is available under the license the | |
| # patched project is licensed under, as long as it is an OpenSource license | |
| # as defined at http://www.opensource.org/ (e.g. BSD, X11) or under the terms | |
| # of the GNU General Public License as published by the Free Software | |
| # Foundation; either version 2 of the License, or (at your option) any later | |
| # version. | |
| # --- SDE-COPYRIGHT-NOTE-END --- | |
|  | |
| add -f --foreground option which prevents automount from daemonizing | |
| adapted from: http://lkml.org/lkml/2004/10/7/217 by Denis Vlasenko | |
| 		 | |
| diff -urpN autofs-4.1.4/daemon/automount.c autofs-4.1.4-fg/daemon/automount.c | |
| --- autofs-4.1.4/daemon/automount.c	2005-03-06 06:43:55.000000000 -0300 | |
| +++ autofs-4.1.4-fg/daemon/automount.c	2006-02-12 10:21:38.000000000 -0300 | |
| @@ -60,6 +60,7 @@ static int submount = 0; | |
|   | |
|  int do_verbose = 0;		/* Verbose feedback option */ | |
|  int do_debug = 0;		/* Enable full debug output */ | |
| +int daemonize = 1;		/* Shall we daemonize? */ | |
|   | |
|  sigset_t ready_sigs;		/* signals only accepted in ST_READY */ | |
|  sigset_t lock_sigs;		/* signals blocked for locking */ | |
| @@ -1282,7 +1283,7 @@ static void become_daemon(void) | |
|  	chdir("/"); | |
|   | |
|  	/* Detach from foreground process */ | |
| -	if (!submount) { | |
| +	if (!submount && daemonize) { | |
|  		pid = fork(); | |
|  		if (pid > 0) | |
|  			exit(0); | |
| @@ -1311,9 +1311,15 @@ | |
|  	 * ouselves from the controling tty. This ensures we don't get unexpected | |
|  	 * signals. This call also sets us as the process group leader. | |
|  	 */ | |
| -	if (!submount && (setsid() == -1)) { | |
| -		crit("setsid: %m"); | |
| -		exit(1); | |
| +	if (!submount) { | |
| +		if (daemonize && (setsid() == -1)) { | |
| +			crit("setsid: %m"); | |
| +			exit(1); | |
| +		} | |
| +		if (!daemonize && (setpgrp() == -1)) { | |
| +			crit("setpgrp: %m"); | |
| +			exit(1); | |
| +		} | |
|  	} | |
|  	my_pgrp = getpgrp(); | |
|   | |
| @@ -1327,7 +1328,7 @@ static void become_daemon(void) | |
|  		crit("redirecting file descriptors failed: %m"); | |
|  		exit(1); | |
|  	} | |
| -	close(nullfd); | |
| +	if (nullfd > 2) close(nullfd); | |
|   | |
|  	/* Write pid file if requested */ | |
|  	if (pid_file) { | |
| @@ -1379,7 +1380,19 @@ static unsigned long getnumopt(char *str | |
|   | |
|  static void usage(void) | |
|  { | |
| -	fprintf(stderr, "Usage: %s [options] path map_type [args...]\n", program); | |
| +	fprintf(stderr, | |
| +		"Usage: %s [options] path map_type [args...]\n" | |
| +		"	-h --help	this text\n" | |
| +		"	-p --pid-file f	write process id to file f\n" | |
| +		"	-t --timeout n	auto-unmount in n seconds (0-disable)\n" | |
| +		"	-f --foreground	do not daemonize\n" | |
| +		"	-v --verbose	be verbose\n" | |
| +		"	-d --debug	be even more verbose\n" | |
| +		"	-V --version	print version and exit\n" | |
| +		/* "	-g --ghost	\n" */ | |
| +		/* "	--submount	\n" */ | |
| +		, program | |
| +	); | |
|  } | |
|   | |
|  static void setup_signals(__sighandler_t event_handler, __sighandler_t cld_handler) | |
| @@ -1666,6 +1679,7 @@ int main(int argc, char *argv[]) | |
|  		{"help", 0, 0, 'h'}, | |
|  		{"pid-file", 1, 0, 'p'}, | |
|  		{"timeout", 1, 0, 't'}, | |
| +		{"foreground", 0, 0, 'f'}, | |
|  		{"verbose", 0, 0, 'v'}, | |
|  		{"debug", 0, 0, 'd'}, | |
|  		{"version", 0, 0, 'V'}, | |
| @@ -1683,7 +1697,7 @@ int main(int argc, char *argv[]) | |
|  	ap.dir_created = 0; /* We haven't created the main directory yet */ | |
|   | |
|  	opterr = 0; | |
| -	while ((opt = getopt_long(argc, argv, "+hp:t:vdVg", long_options, NULL)) != EOF) { | |
| +	while ((opt = getopt_long(argc, argv, "+hp:t:fvdVg", long_options, NULL)) != EOF) { | |
|  		switch (opt) { | |
|  		case 'h': | |
|  			usage(); | |
| @@ -1697,6 +1711,10 @@ int main(int argc, char *argv[]) | |
|  			ap.exp_timeout = getnumopt(optarg, opt); | |
|  			break; | |
|   | |
| +		case 'f': | |
| +			daemonize = 0; | |
| +			break; | |
| + | |
|  		case 'v': | |
|  			do_verbose = 1; | |
|  			break;
 | |
| 
 |