Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 7 Feb 2014 15:10:25 +0000 (UTC)
From:      John Baldwin <jhb@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r261600 - head/sys/dev/bvm
Message-ID:  <201402071510.s17FAPD5070327@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: jhb
Date: Fri Feb  7 15:10:24 2014
New Revision: 261600
URL: http://svnweb.freebsd.org/changeset/base/261600

Log:
  - Use a callout instead of the deprecated timeout_handle.
  - Set the console name always so that the bvm console device can be used
    via conscontrol even if it isn't chosen as the default console.

Modified:
  head/sys/dev/bvm/bvm_console.c

Modified: head/sys/dev/bvm/bvm_console.c
==============================================================================
--- head/sys/dev/bvm/bvm_console.c	Fri Feb  7 15:00:08 2014	(r261599)
+++ head/sys/dev/bvm/bvm_console.c	Fri Feb  7 15:10:24 2014	(r261600)
@@ -58,8 +58,7 @@ static struct ttydevsw bvm_ttydevsw = {
 };
 
 static int			polltime;
-static struct callout_handle	bvm_timeouthandle
-    = CALLOUT_HANDLE_INITIALIZER(&bvm_timeouthandle);
+static struct callout		bvm_timer;
 
 #if defined(KDB)
 static int			alt_break_state;
@@ -107,9 +106,9 @@ cn_drvinit(void *unused)
 {
 	struct tty *tp;
 
-	if (bvm_consdev.cn_pri != CN_DEAD &&
-	    bvm_consdev.cn_name[0] != '\0') {
+	if (bvm_consdev.cn_pri != CN_DEAD) {
 		tp = tty_alloc(&bvm_ttydevsw, NULL);
+		callout_init_mtx(&bvm_timer, tty_getlock(tp), 0);
 		tty_makedev(tp, NULL, "bvmcons");
 	}
 }
@@ -120,7 +119,7 @@ bvm_tty_open(struct tty *tp)
 	polltime = hz / BVMCONS_POLL_HZ;
 	if (polltime < 1)
 		polltime = 1;
-	bvm_timeouthandle = timeout(bvm_timeout, tp, polltime);
+	callout_reset(&bvm_timer, polltime, bvm_timeout, tp);
 
 	return (0);
 }
@@ -129,8 +128,9 @@ static void
 bvm_tty_close(struct tty *tp)
 {
 
-	/* XXX Should be replaced with callout_stop(9) */
-	untimeout(bvm_timeout, tp, bvm_timeouthandle);
+	tty_lock(tp);
+	callout_stop(&bvm_timer);
+	tty_unlock(tp);
 }
 
 static void
@@ -158,13 +158,12 @@ bvm_timeout(void *v)
 
 	tp = (struct tty *)v;
 
-	tty_lock(tp);
+	tty_lock_assert(tp, MA_OWNED);
 	while ((c = bvm_cngetc(NULL)) != -1)
 		ttydisc_rint(tp, c, 0);
 	ttydisc_rint_done(tp);
-	tty_unlock(tp);
 
-	bvm_timeouthandle = timeout(bvm_timeout, tp, polltime);
+	callout_reset(&bvm_timer, polltime, bvm_timeout, tp);
 }
 
 static void
@@ -174,6 +173,7 @@ bvm_cnprobe(struct consdev *cp)
 
 	disabled = 0;
 	cp->cn_pri = CN_DEAD;
+	strcpy(cp->cn_name, "bvmcons");
 
 	resource_int_value("bvmconsole", 0, "disabled", &disabled);
 	if (!disabled) {
@@ -195,8 +195,6 @@ bvm_cninit(struct consdev *cp)
 		for (i = 0; i < strlen(bootmsg); i++)
 			bvm_cnputc(cp, bootmsg[i]);
 	}
-
-	strcpy(cp->cn_name, "bvmcons");
 }
 
 static void



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