From: Peter Hurley <peter@hurleysoftware.com>
To: Masahiro Yamada <yamada.masahiro@socionext.com>,
linux-serial@vger.kernel.org
Cc: Vineet Gupta <Vineet.Gupta1@synopsys.com>,
Kevin Cernekee <cernekee@gmail.com>, Jiri Slaby <jslaby@suse.com>,
Rob Herring <robh@kernel.org>,
linux-kernel@vger.kernel.org,
Eddie Huang <eddie.huang@mediatek.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Subject: Re: [PATCH] serial: 8250_early: do not save and restore IER in write callback
Date: Fri, 23 Oct 2015 08:45:53 -0400 [thread overview]
Message-ID: <562A2C01.4070006@hurleysoftware.com> (raw)
In-Reply-To: <1445502100-10860-1-git-send-email-yamada.masahiro@socionext.com>
On 10/22/2015 04:21 AM, Masahiro Yamada wrote:
> The IER has already been masked in early_serial8250_setup(), there is
> no reason to save and restore it every time early_serial8250_write()
> is called.
>
> Let wait_for_xmitr() melt into serial_putc().
Both of these changes are ok with me, but please split this into
2 patches so reverting either one in case of regression is trivial.
Regards,
Peter Hurley
> Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
> ---
>
> drivers/tty/serial/8250/8250_early.c | 20 ++------------------
> 1 file changed, 2 insertions(+), 18 deletions(-)
>
> diff --git a/drivers/tty/serial/8250/8250_early.c b/drivers/tty/serial/8250/8250_early.c
> index 7aff3d8..19aca19 100644
> --- a/drivers/tty/serial/8250/8250_early.c
> +++ b/drivers/tty/serial/8250/8250_early.c
> @@ -76,21 +76,17 @@ static void __init serial8250_early_out(struct uart_port *port, int offset, int
>
> #define BOTH_EMPTY (UART_LSR_TEMT | UART_LSR_THRE)
>
> -static void __init wait_for_xmitr(struct uart_port *port)
> +static void __init serial_putc(struct uart_port *port, int c)
> {
> unsigned int status;
>
> for (;;) {
> status = serial8250_early_in(port, UART_LSR);
> if ((status & BOTH_EMPTY) == BOTH_EMPTY)
> - return;
> + break;
> cpu_relax();
> }
> -}
>
> -static void __init serial_putc(struct uart_port *port, int c)
> -{
> - wait_for_xmitr(port);
> serial8250_early_out(port, UART_TX, c);
> }
>
> @@ -99,20 +95,8 @@ static void __init early_serial8250_write(struct console *console,
> {
> struct earlycon_device *device = console->data;
> struct uart_port *port = &device->port;
> - unsigned int ier;
> -
> - /* Save the IER and disable interrupts preserving the UUE bit */
> - ier = serial8250_early_in(port, UART_IER);
> - if (ier)
> - serial8250_early_out(port, UART_IER, ier & UART_IER_UUE);
>
> uart_console_write(port, s, count, serial_putc);
> -
> - /* Wait for transmitter to become empty and restore the IER */
> - wait_for_xmitr(port);
> -
> - if (ier)
> - serial8250_early_out(port, UART_IER, ier);
> }
>
> static void __init init_port(struct earlycon_device *device)
>
next prev parent reply other threads:[~2015-10-23 12:45 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-10-22 8:21 [PATCH] serial: 8250_early: do not save and restore IER in write callback Masahiro Yamada
2015-10-23 12:45 ` Peter Hurley [this message]
2015-10-24 4:02 ` Masahiro Yamada
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=562A2C01.4070006@hurleysoftware.com \
--to=peter@hurleysoftware.com \
--cc=Vineet.Gupta1@synopsys.com \
--cc=cernekee@gmail.com \
--cc=eddie.huang@mediatek.com \
--cc=gregkh@linuxfoundation.org \
--cc=jslaby@suse.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-serial@vger.kernel.org \
--cc=robh@kernel.org \
--cc=yamada.masahiro@socionext.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.