All of lore.kernel.org
 help / color / mirror / Atom feed
From: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
To: Yicong Yang <yangyicong@huawei.com>
Cc: gregkh@linuxfoundation.org, jirislaby@kernel.org,
	tony@atomide.com, linux-kernel@vger.kernel.org,
	linux-serial@vger.kernel.org, john.ogness@linutronix.de,
	tglx@linutronix.de, yangyicong@hisilicon.com,
	linuxarm@huawei.com, prime.zeng@hisilicon.com,
	jonathan.cameron@huawei.com, fanghao11@huawei.com
Subject: Re: [PATCH v4] serial: port: Don't suspend if the port is still busy
Date: Fri, 23 Feb 2024 17:44:31 +0200	[thread overview]
Message-ID: <Zdi9X8qzQhNE3rGl@smile.fi.intel.com> (raw)
In-Reply-To: <20240223083903.42129-1-yangyicong@huawei.com>

On Fri, Feb 23, 2024 at 04:39:03PM +0800, Yicong Yang wrote:
> From: Yicong Yang <yangyicong@hisilicon.com>
> 
> We accidently met the issue that the bash prompt is not shown after the
> previous command done and until the next input if there's only one CPU
> (In our issue other CPUs are isolated by isolcpus=). Further analysis
> shows it's because the port entering runtime suspend even if there's
> still pending chars in the buffer and the pending chars will only be
> processed in next device resuming. We are using amba-pl011 and the
> problematic flow is like below:
> 
> Bash                                         kworker
> tty_write()
>   file_tty_write()
>     n_tty_write()
>       uart_write()
>         __uart_start()
>           pm_runtime_get() // wakeup waker
>             queue_work()
>                                              pm_runtime_work()
>                                                rpm_resume()
>                                                 status = RPM_RESUMING
>                                                 serial_port_runtime_resume()
>                                                   port->ops->start_tx()
>                                                     pl011_tx_chars()
>                                                       uart_write_wakeup()
>         […]
>         __uart_start()
>           pm_runtime_get() < 0 // because runtime status = RPM_RESUMING
>                                // later data are not commit to the port driver
>                                                 status = RPM_ACTIVE
>                                                 rpm_idle() -> rpm_suspend()
> 
> This patch tries to fix this by checking the port busy before entering
> runtime suspending. A runtime_suspend callback is added for the port
> driver. When entering runtime suspend the callback is invoked, if there's
> still pending chars in the buffer then flush the buffer.

...

> Cc: Tony Lindgren <tony@atomide.com>

No need to Cc to people whose tags you already have. The Git tools will add
them to the Cc list.

> Cc: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> Cc: Jiri Slaby <jirislaby@kernel.org>

In general, Cc is better to be either supplied with --cc or be located after
the cutter '---' line, so they won't pollute the commit message.

...

Code wise LGTM, thanks.
Minor remarks below, with them addressed,
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>

> +static int serial_port_runtime_suspend(struct device *dev)
> +{
> +	struct serial_port_device *port_dev = to_serial_base_port_device(dev);

> +	struct uart_port *port;

You can assign here

	struct uart_port *port = port_dev->port;

and save 2 LoCs.

> +	unsigned long flags;
> +	bool busy;
> +
> +	port = port_dev->port;

> +

If you want to have assignment separated, this blank line may be dropped.

> +	if (port->flags & UPF_DEAD)
> +		return 0;
> +
> +	uart_port_lock_irqsave(port, &flags);
> +	busy = __serial_port_busy(port);
> +	if (busy)
> +		port->ops->start_tx(port);
> +	uart_port_unlock_irqrestore(port, flags);
> +
> +	if (busy)
> +		pm_runtime_mark_last_busy(dev);
> +
> +	return busy ? -EBUSY : 0;
> +}

-- 
With Best Regards,
Andy Shevchenko



      reply	other threads:[~2024-02-23 15:44 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-02-23  8:39 [PATCH v4] serial: port: Don't suspend if the port is still busy Yicong Yang
2024-02-23 15:44 ` Andy Shevchenko [this message]

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=Zdi9X8qzQhNE3rGl@smile.fi.intel.com \
    --to=andriy.shevchenko@linux.intel.com \
    --cc=fanghao11@huawei.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=jirislaby@kernel.org \
    --cc=john.ogness@linutronix.de \
    --cc=jonathan.cameron@huawei.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-serial@vger.kernel.org \
    --cc=linuxarm@huawei.com \
    --cc=prime.zeng@hisilicon.com \
    --cc=tglx@linutronix.de \
    --cc=tony@atomide.com \
    --cc=yangyicong@hisilicon.com \
    --cc=yangyicong@huawei.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.