From: Jim Ramsay <jim.ramsay@gmail.com>
To: linux-kernel@vger.kernel.org
Subject: Bug in 8520.c - port.type not set for serial console
Date: Mon, 30 May 2005 16:38:29 -0600 [thread overview]
Message-ID: <4789af9e05053015385667923@mail.gmail.com> (raw)
I am attempting to get the 8520.c driver's serial console working with
a 16550A UART implementation, and have run into what I consider to be
a bug: In short, the proper 'port.type' for this serial port is not
set until the module init (serial8250_init) is called, so the FCR is
set incorrectly during serial8250_console_init for any port type which
is different than UNKNOWN.
The exact problem is that the FCR is being set to '0x0' for a port
type of 'UNKNOWN', when for my specific 16550A, it should be set to
'0xC1' - and this makes my screen fill with empty characters instead
of the printk output I need. It appears that after some time (once
the kernel actually calls serial8250_init) the problem clears up, but
I still lose a large section of the output before this point.
The proper flags are sitting there in the uart_config array for the
proper type, and this type is properly deduced by the 'autoconfig'
routine that eventually gets called by serial8250_init. The problem
is that the autoconfig is isn't called by serial8250_console_init
which of course happens much earlier than serial8250_init.
I have a workaround that works for me, telling the
serial8250_set_termios() routine to only set the FCR if the type is
not UNKNOWN, changing
if (up->port.type != PORT_16750 ) {
to
if (up->port.type != PORT_16750 && up->port.type != PORT_UNKNOWN) {
This will leave the FCR at whatever it was at boot time, which for me
is correct.
Would this be a "good enough" fix in general, or would there be a
better way of doing this?
I suppose the other way would be to duplicate some of what
serial8250_init does (like call 'autoconfig') in
serial8250_console_init, but I haven't tried this yet... maybe it
depends on too much kernel magic to be called as early as
'console_init'?
Any suggestions on the best way to fix this would be great, I'd be
happy to develop this more, test a bit, and submit a patch.
--
Jim Ramsay
"Me fail English? That's unpossible!"
next reply other threads:[~2005-05-30 22:38 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-05-30 22:38 Jim Ramsay [this message]
2005-05-31 22:25 ` Bug in 8520.c - port.type not set for serial console Bjorn Helgaas
2005-06-06 15:03 ` Jim Ramsay
2005-06-06 15:55 ` Bjorn Helgaas
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4789af9e05053015385667923@mail.gmail.com \
--to=jim.ramsay@gmail.com \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox