PERFORCE change 151957 for review
Ed Schouten
ed at FreeBSD.org
Sun Oct 26 15:14:32 UTC 2008
http://perforce.freebsd.org/chv.cgi?CH=151957
Change 151957 by ed at ed_mekker on 2008/10/26 15:13:40
Don't hardcode "ttyv0" in TTY selection.
I've introduced a new function that is called from our low-level
console code. This function is called each time the first entry
in cn_devlist is changed. Each time /dev/console is being
opened, it will iterate the list of TTY's on the system to look
up the TTY by that name.
It is not possible to perform the lookup when cn_devlist
changes, because cn_devlist is already being filled very early
during boot.
Affected files ...
.. //depot/projects/mpsafetty/sys/kern/tty.c#60 edit
.. //depot/projects/mpsafetty/sys/kern/tty_cons.c#6 edit
.. //depot/projects/mpsafetty/sys/sys/tty.h#23 edit
Differences ...
==== //depot/projects/mpsafetty/sys/kern/tty.c#60 (text+ko) ====
@@ -74,7 +74,8 @@
static unsigned int tty_list_count = 0;
/* Character device of /dev/console. */
-static struct cdev *dev_console;
+static struct cdev *dev_console;
+static const char *dev_console_filename;
/*
* Flags that are supported and stored by this implementation.
@@ -1126,10 +1127,6 @@
dev->si_drv2 = &tp->t_termios_lock_out;
}
}
-
- /* XXX: console hardcoding! */
- if (strcmp(tty_devname(tp), "ttyv0") == 0)
- dev_console->si_drv1 = tp;
}
/*
@@ -1756,10 +1753,20 @@
static int
ttyconsdev_open(struct cdev *dev, int oflags, int devtype, struct thread *td)
{
- struct tty *tp = dev->si_drv1;
+ struct tty *tp;
+
+ /* Look up corresponding TTY by device name. */
+ sx_slock(&tty_list_sx);
+ TAILQ_FOREACH(tp, &tty_list, t_list) {
+ if (strcmp(dev_console_filename, tty_devname(tp)) == 0) {
+ dev_console->si_drv1 = tp;
+ break;
+ }
+ }
+ sx_sunlock(&tty_list_sx);
- /* /dev/console without associated TTY. */
- if (tp == NULL)
+ /* Still no TTY associated by that name. */
+ if (dev_console->si_drv1 == NULL)
return (ENXIO);
return (ttydev_open(dev, oflags, devtype, td));
@@ -1802,6 +1809,13 @@
SYSINIT(tty, SI_SUB_DRIVERS, SI_ORDER_FIRST, ttyconsdev_init, NULL);
+void
+ttyconsdev_select(const char *name)
+{
+
+ dev_console_filename = name;
+}
+
#include "opt_ddb.h"
#ifdef DDB
#include <ddb/ddb.h>
==== //depot/projects/mpsafetty/sys/kern/tty_cons.c#6 (text+ko) ====
@@ -186,6 +186,8 @@
printf("WARNING: console at %p has no name\n", cn);
}
STAILQ_INSERT_TAIL(&cn_devlist, cnd, cnd_next);
+ if (STAILQ_FIRST(&cn_devlist) == cnd)
+ ttyconsdev_select(cnd->cnd_cn->cn_name);
/* Add device to the active mask. */
cnavailable(cn, (cn->cn_flags & CN_FLAG_NOAVAIL) == 0);
@@ -236,6 +238,7 @@
return;
STAILQ_REMOVE(&cn_devlist, cnd, cn_device, cnd_next);
STAILQ_INSERT_HEAD(&cn_devlist, cnd, cnd_next);
+ ttyconsdev_select(cnd->cnd_cn->cn_name);
return;
}
}
==== //depot/projects/mpsafetty/sys/sys/tty.h#23 (text+ko) ====
@@ -192,6 +192,9 @@
/* Status line printing. */
void tty_info(struct tty *tp);
+/* /dev/console selection. */
+void ttyconsdev_select(const char *name);
+
/* Pseudo-terminal hooks. */
int pts_alloc_external(int fd, struct thread *td, struct file *fp,
struct cdev *dev, const char *name);
More information about the p4-projects
mailing list