Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 2 Sep 2003 18:33:36 +1000 (EST)
From:      Bruce Evans <bde@zeta.org.au>
To:        Scott Long <scottl@freebsd.org>
Cc:        current@freebsd.org
Subject:   Re: Question related to FreeBSD Serial Console...
Message-ID:  <20030902175538.A617@gamplex.bde.org>
In-Reply-To: <3F53E315.6070401@freebsd.org>
References:  <1062445674.59251.1.camel@acheron.livid.de> <3F53CF00.6020304@freebsd.org><3F53D645.2040501@freebsd.org> <3F53E315.6070401@freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
About the original question: multiple consoles in the kernel are
unsupported in FreeBSD-4 but are standard in -current.  Unfortunately,
their implementation is slightly incomplete even in -current.  In
-current, you get them by booting with -D after booting using the
kern.console sysctl.  The number of consoles is limited only by the
number of devices that support consoles.  Low level console i/o (mainly
boot messages and other kernel messags printed by kernel printfs) is
then sent to and received from all the consoles, but for some reason
high-level console output (all i/o from/to /dev/console) is only sent
to the first console in the list.  This should be easy to fix for
writes and ioctls though not so easy for reads.  I think booting with
-Dh makes the serial console first and booting with -D makes the video
console first (if both are configured).  The order can be changed using
the sysctl.

On Mon, 1 Sep 2003, Scott Long wrote:

> John Birrell wrote:
> > On Mon, Sep 01, 2003 at 05:29:09PM -0600, Scott Long wrote:
> >
> >>At one time I was working on patches to the loader to make the console
> >>speed configurable.  At the time, at least, I didn't see any evidence
> >>that the settings were stored in the boot0 block, but maybe I was wrong.

There are already too many places to set it.

> > AFAIK, the boot0 block uses bios int 0x16 to get a key-press and bios int
> > 0x10 to display a character, so in a situation where you *want* a serial
> > console, the F1 etc stuff can't be used unless the bios supports console
> > re-direction. And you have to live with whatever baud rate the bios sets.

I think boot0 is already full (unless you unportabalize it by expanding it
beyond one sector).  It doesn't have its own serial i/o routines mainly
because there is no space for them.

> > Once you get to boot2, then the serial console can work if set in /boot.config.
> >
> > It would be nice to have a boot.config setting for the baud rate. I have a
> > board here that allows bios re-direction to either the first or second serial
> > port at a fixed baud rate of 38400. I have to build boot2 with
> > BOOT_COMCONSOLE_SPEED=38400, and then the kernel with CONSPEED=38400 to
> > get all the ducks in a row.

The latter shouldn't be necessary.  The kernel (i386 sio only) uses the
same speed that boot2 used if the kernel was booted with -h.  It should
also use the same speed if the kernel was booted with -D.

> > But it would be even nicer if both boot2 and the kernel would just work with
> > whatever baud rate the bios set.
>
> This is exactly the problem that I was working on.

Unfortunately most BIOSes don't provide a way to set the speed.  I'm not
sure that it even has a default.  I always use 115200 bps, but at least he
old BIOS interface is limited to 9600 bps.  I may work on this a bit soon
to make 921600 bps work.

Bruce



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