All of lore.kernel.org
 help / color / mirror / Atom feed
From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: linuxppc-dev list <linuxppc-dev@ozlabs.org>,
	Jiri Slaby <jslaby@suse.cz>,
	Linux Kernel list <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] tty/hvc/hvc_console: Fix wakeup of HVC thread on hvc_kick()
Date: Wed, 28 May 2014 10:01:30 +1000	[thread overview]
Message-ID: <1401235290.8262.9.camel@pasglop> (raw)
In-Reply-To: <1400838066.29150.69.camel@pasglop>

On Fri, 2014-05-23 at 19:41 +1000, Benjamin Herrenschmidt wrote:
> Some backends call hvc_kick() to wakeup the HVC thread from its
> slumber upon incoming characters. This however doesn't work
> properly because it uses msleep_interruptible() which is mostly
> immune to wake_up_process(). It will basically go back to sleep
> until the timeout is expired (only signals can really wake it).
>
> Replace it with a simple shedule_timeout_interruptible() instead,
> which may wakeup earlier every now and then but we really don't
> care in this case.

Nobody commented ? :-)

Greg, do you want to take this in the tty tree or can I stick it in
powerpc ?

Cheers,
Ben 

> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> ---
>  drivers/tty/hvc/hvc_console.c |    9 ++++++++-
>  1 file changed, 8 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/tty/hvc/hvc_console.c b/drivers/tty/hvc/hvc_console.c
> index 94f9e3a..1094265 100644
> --- a/drivers/tty/hvc/hvc_console.c
> +++ b/drivers/tty/hvc/hvc_console.c
> @@ -760,10 +760,17 @@ static int khvcd(void *unused)
>  			if (poll_mask == 0)
>  				schedule();
>  			else {
> +				unsigned long j_timeout;
> +
>  				if (timeout < MAX_TIMEOUT)
>  					timeout += (timeout >> 6) + 1;
>  
> -				msleep_interruptible(timeout);
> +				/*
> +				 * We don't use msleep_interruptible otherwise
> +				 * "kick" will fail to wake us up
> +				 */
> +				j_timeout = msecs_to_jiffies(timeout) + 1;
> +				schedule_timeout_interruptible(j_timeout);
>  			}
>  		}
>  		__set_current_state(TASK_RUNNING);
> 

WARNING: multiple messages have this Message-ID (diff)
From: Benjamin Herrenschmidt <benh@kernel.crashing.org>
To: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: Jiri Slaby <jslaby@suse.cz>,
	Linux Kernel list <linux-kernel@vger.kernel.org>,
	linuxppc-dev list <linuxppc-dev@ozlabs.org>
Subject: Re: [PATCH] tty/hvc/hvc_console: Fix wakeup of HVC thread on hvc_kick()
Date: Wed, 28 May 2014 10:01:30 +1000	[thread overview]
Message-ID: <1401235290.8262.9.camel@pasglop> (raw)
In-Reply-To: <1400838066.29150.69.camel@pasglop>

On Fri, 2014-05-23 at 19:41 +1000, Benjamin Herrenschmidt wrote:
> Some backends call hvc_kick() to wakeup the HVC thread from its
> slumber upon incoming characters. This however doesn't work
> properly because it uses msleep_interruptible() which is mostly
> immune to wake_up_process(). It will basically go back to sleep
> until the timeout is expired (only signals can really wake it).
>
> Replace it with a simple shedule_timeout_interruptible() instead,
> which may wakeup earlier every now and then but we really don't
> care in this case.

Nobody commented ? :-)

Greg, do you want to take this in the tty tree or can I stick it in
powerpc ?

Cheers,
Ben 

> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> ---
>  drivers/tty/hvc/hvc_console.c |    9 ++++++++-
>  1 file changed, 8 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/tty/hvc/hvc_console.c b/drivers/tty/hvc/hvc_console.c
> index 94f9e3a..1094265 100644
> --- a/drivers/tty/hvc/hvc_console.c
> +++ b/drivers/tty/hvc/hvc_console.c
> @@ -760,10 +760,17 @@ static int khvcd(void *unused)
>  			if (poll_mask == 0)
>  				schedule();
>  			else {
> +				unsigned long j_timeout;
> +
>  				if (timeout < MAX_TIMEOUT)
>  					timeout += (timeout >> 6) + 1;
>  
> -				msleep_interruptible(timeout);
> +				/*
> +				 * We don't use msleep_interruptible otherwise
> +				 * "kick" will fail to wake us up
> +				 */
> +				j_timeout = msecs_to_jiffies(timeout) + 1;
> +				schedule_timeout_interruptible(j_timeout);
>  			}
>  		}
>  		__set_current_state(TASK_RUNNING);
> 



  reply	other threads:[~2014-05-28  0:01 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-05-23  9:41 [PATCH] tty/hvc/hvc_console: Fix wakeup of HVC thread on hvc_kick() Benjamin Herrenschmidt
2014-05-23  9:41 ` Benjamin Herrenschmidt
2014-05-28  0:01 ` Benjamin Herrenschmidt [this message]
2014-05-28  0:01   ` Benjamin Herrenschmidt
2014-05-28 20:32   ` Greg Kroah-Hartman
2014-05-28 20:32     ` Greg Kroah-Hartman

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=1401235290.8262.9.camel@pasglop \
    --to=benh@kernel.crashing.org \
    --cc=gregkh@linuxfoundation.org \
    --cc=jslaby@suse.cz \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linuxppc-dev@ozlabs.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 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.