Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 22 Dec 2014 22:07:23 +0000 (UTC)
From:      Ian Lepore <ian@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r276087 - in head/sys/boot: common forth
Message-ID:  <201412222207.sBMM7NGd091055@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: ian
Date: Mon Dec 22 22:07:22 2014
New Revision: 276087
URL: https://svnweb.freebsd.org/changeset/base/276087

Log:
  Add a new loader(8) variable, twiddle_divisor, allowing control over the
  output frequency of the "twiddle" IO progress indicator.  The default
  value is 1.  For larger values N, the next stage of the animation is only
  output on every Nth call to the output routine.  A sufficiently large N
  effectively disables the animation completely.

Modified:
  head/sys/boot/common/console.c
  head/sys/boot/common/loader.8
  head/sys/boot/forth/loader.conf

Modified: head/sys/boot/common/console.c
==============================================================================
--- head/sys/boot/common/console.c	Mon Dec 22 21:52:37 2014	(r276086)
+++ head/sys/boot/common/console.c	Mon Dec 22 22:07:22 2014	(r276087)
@@ -39,6 +39,7 @@ static int	cons_set(struct env_var *ev, 
 static int	cons_find(const char *name);
 static int	cons_check(const char *string);
 static void	cons_change(const char *string);
+static int	twiddle_set(struct env_var *ev, int flags, const void *value);
 
 /*
  * Detect possible console(s) to use.  If preferred console(s) have been
@@ -52,6 +53,9 @@ cons_probe(void) 
     int			active;
     char		*prefconsole;
     
+    /* We want a callback to install the new value when this var changes. */
+    env_setenv("twiddle_divisor", EV_VOLATILE, "1", twiddle_set, env_nounset);
+
     /* Do all console probes */
     for (cons = 0; consoles[cons] != NULL; cons++) {
 	consoles[cons]->c_flags = 0;
@@ -232,3 +236,28 @@ cons_change(const char *string)
 
     free(dup);
 }
+
+/*
+ * Change the twiddle divisor.
+ *
+ * The user can set the twiddle_divisor variable to directly control how fast
+ * the progress twiddle spins, useful for folks with slow serial consoles.  The
+ * code to monitor changes to the variable and propagate them to the twiddle
+ * routines has to live somewhere.  Twiddling is console-related so it's here.
+ */
+static int
+twiddle_set(struct env_var *ev, int flags, const void *value)
+{
+    u_long tdiv;
+    char * eptr;
+
+    tdiv = strtoul(value, &eptr, 0);
+    if (*(const char *)value == 0 || *eptr != 0) {
+	printf("invalid twiddle_divisor '%s'\n", (const char *)value);
+	return (CMD_ERROR);
+    }
+    twiddle_divisor((u_int)tdiv);
+    env_setenv(ev->ev_name, flags | EV_NOHOOK, value, NULL, NULL);
+
+    return(CMD_OK);
+}

Modified: head/sys/boot/common/loader.8
==============================================================================
--- head/sys/boot/common/loader.8	Mon Dec 22 21:52:37 2014	(r276086)
+++ head/sys/boot/common/loader.8	Mon Dec 22 22:07:22 2014	(r276087)
@@ -24,7 +24,7 @@
 .\"
 .\" $FreeBSD$
 .\"
-.Dd October 1, 2013
+.Dd December 22, 2014
 .Dt LOADER 8
 .Os
 .Sh NAME
@@ -670,6 +670,12 @@ Overrides the compile-time set value of
 .Dv TCBHASHSIZE
 or the preset default of 512.
 Must be a power of 2.
+.It Va twiddle_divisor
+Throttles the output of the `twiddle' I/O progress indicator displayed
+while loading the kernel and modules.
+This is useful on slow serial consoles where the time spent waiting for
+these characters to be written can add up to many seconds.
+The default is 1 (full speed); a value of 2 spins half as fast, and so on.
 .It Va vm.kmem_size
 Sets the size of kernel memory (bytes).
 This overrides the value determined when the kernel was compiled.

Modified: head/sys/boot/forth/loader.conf
==============================================================================
--- head/sys/boot/forth/loader.conf	Mon Dec 22 21:52:37 2014	(r276086)
+++ head/sys/boot/forth/loader.conf	Mon Dec 22 22:07:22 2014	(r276087)
@@ -75,6 +75,7 @@ module_path="/boot/modules"	# Set the mo
 				# the block size is set to 512.  If the value
 				# is out of range ( < 8 || > 9008 ) an error is
 				# returned.
+#twiddle_divisor="1"		# >1 means slow down the progress indicator.
 
 
 ##############################################################



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201412222207.sBMM7NGd091055>