diff options
Diffstat (limited to 'usr/src/cmd/halt/halt.c')
| -rw-r--r-- | usr/src/cmd/halt/halt.c | 19 | 
1 files changed, 16 insertions, 3 deletions
| diff --git a/usr/src/cmd/halt/halt.c b/usr/src/cmd/halt/halt.c index 528823531e..9a4e113936 100644 --- a/usr/src/cmd/halt/halt.c +++ b/usr/src/cmd/halt/halt.c @@ -21,6 +21,7 @@  /*   * Copyright 2010 Sun Microsystems, Inc.  All rights reserved.   * Use is subject to license terms. + * Copyright 2011 Joyent, Inc.  All rights reserved.   */  /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/ @@ -1228,6 +1229,17 @@ do_archives_update(int do_fast_reboot)  	pid_t	pid;  	char	*cmd_argv[MAXARGS]; +#if defined(__i386) +	{ +		/* +		 * bootadm will complain and exit if not a grub root, so +		 * just skip running it. +		 */ +		struct stat sb; +		if (stat("/boot/grub/stage2", &sb) == -1) +			return; +	} +#endif	/* __i386 */  	cmd_argv[i++] = "/sbin/bootadm";  	cmd_argv[i++] = "-ea"; @@ -1294,7 +1306,7 @@ main(int argc, char *argv[])  		optstring = "dlnqfp";  		usage = gettext("usage: %s [ -dlnq(p|f) ] [ boot args ]\n");  #endif -		cmd = A_SHUTDOWN; +		cmd = A_REBOOT;  		fcn = AD_BOOT;  	} else {  		(void) fprintf(stderr, @@ -1503,7 +1515,8 @@ main(int argc, char *argv[])  	 * check_zone_haltedness later on.  	 */  	if (zoneid == GLOBAL_ZONEID && cmd != A_DUMP) { -		need_check_zones = halt_zones(); +		if (!qflag) +			need_check_zones = halt_zones();  	}  #if defined(__i386) @@ -1603,7 +1616,7 @@ main(int argc, char *argv[])  	(void) signal(SIGINT, SIG_IGN); -	if (!qflag && !nosync) { +	if (!nosync) {  		struct utmpx wtmpx;  		bzero(&wtmpx, sizeof (struct utmpx)); | 
