* [patch 2/8] isdn/capi: replace interruptible_sleep_on() with wait_event_interruptible()
@ 2005-03-06 22:38 domen
2005-03-07 3:47 ` Andrew Morton
0 siblings, 1 reply; 3+ messages in thread
From: domen @ 2005-03-06 22:38 UTC (permalink / raw)
To: akpm; +Cc: linux-kernel, isdn4linux, domen, nacc
Use wait_event_interruptible() instead of the deprecated
interruptible_sleep_on(). Patch is straight-forward as current sleep is
conditionally looped. Patch is compile-tested.
Signed-off-by: Nishanth Aravamudan <nacc@us.ibm.com>
Signed-off-by: Domen Puncer <domen@coderock.org>
---
kj-domen/drivers/isdn/capi/capi.c | 9 ++-------
1 files changed, 2 insertions(+), 7 deletions(-)
diff -puN drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi drivers/isdn/capi/capi.c
--- kj/drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi 2005-03-05 16:11:36.000000000 +0100
+++ kj-domen/drivers/isdn/capi/capi.c 2005-03-05 16:11:36.000000000 +0100
@@ -675,13 +675,8 @@ capi_read(struct file *file, char __user
if (file->f_flags & O_NONBLOCK)
return -EAGAIN;
- for (;;) {
- interruptible_sleep_on(&cdev->recvwait);
- if ((skb = skb_dequeue(&cdev->recvqueue)) != 0)
- break;
- if (signal_pending(current))
- break;
- }
+ wait_event_interruptible(cdev->recvwait,
+ ((skb = skb_dequeue(&cdev->recvqueue)) == 0));
if (skb == 0)
return -ERESTARTNOHAND;
}
_
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 2/8] isdn/capi: replace interruptible_sleep_on() with wait_event_interruptible()
2005-03-06 22:38 [patch 2/8] isdn/capi: replace interruptible_sleep_on() with wait_event_interruptible() domen
@ 2005-03-07 3:47 ` Andrew Morton
2005-03-07 8:35 ` Domen Puncer
0 siblings, 1 reply; 3+ messages in thread
From: Andrew Morton @ 2005-03-07 3:47 UTC (permalink / raw)
To: domen; +Cc: linux-kernel, isdn4linux, domen, nacc
domen@coderock.org wrote:
>
>
>
> Use wait_event_interruptible() instead of the deprecated
> interruptible_sleep_on(). Patch is straight-forward as current sleep is
> conditionally looped. Patch is compile-tested.
>
> Signed-off-by: Nishanth Aravamudan <nacc@us.ibm.com>
> Signed-off-by: Domen Puncer <domen@coderock.org>
> ---
>
>
> kj-domen/drivers/isdn/capi/capi.c | 9 ++-------
> 1 files changed, 2 insertions(+), 7 deletions(-)
>
> diff -puN drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi drivers/isdn/capi/capi.c
> --- kj/drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi 2005-03-05 16:11:36.000000000 +0100
> +++ kj-domen/drivers/isdn/capi/capi.c 2005-03-05 16:11:36.000000000 +0100
> @@ -675,13 +675,8 @@ capi_read(struct file *file, char __user
> if (file->f_flags & O_NONBLOCK)
> return -EAGAIN;
>
> - for (;;) {
> - interruptible_sleep_on(&cdev->recvwait);
> - if ((skb = skb_dequeue(&cdev->recvqueue)) != 0)
> - break;
> - if (signal_pending(current))
> - break;
> - }
> + wait_event_interruptible(cdev->recvwait,
> + ((skb = skb_dequeue(&cdev->recvqueue)) == 0));
> if (skb == 0)
> return -ERESTARTNOHAND;
> }
hmm, OK. Putting an expression with side-effect such as this into a macro
which evaluates the expression multiple times is a bit of a worry, but it
appears that everything will work OK.
That being said, I'd prefer that this come in via the ISDN team, after
having been tested please.
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 2/8] isdn/capi: replace interruptible_sleep_on() with wait_event_interruptible()
2005-03-07 3:47 ` Andrew Morton
@ 2005-03-07 8:35 ` Domen Puncer
0 siblings, 0 replies; 3+ messages in thread
From: Domen Puncer @ 2005-03-07 8:35 UTC (permalink / raw)
To: Andrew Morton; +Cc: linux-kernel, isdn4linux, nacc
On 06/03/05 19:47 -0800, Andrew Morton wrote:
> domen@coderock.org wrote:
> >
> >
> >
> > Use wait_event_interruptible() instead of the deprecated
> > interruptible_sleep_on(). Patch is straight-forward as current sleep is
> > conditionally looped. Patch is compile-tested.
> >
> > Signed-off-by: Nishanth Aravamudan <nacc@us.ibm.com>
> > Signed-off-by: Domen Puncer <domen@coderock.org>
> > ---
> >
> >
> > kj-domen/drivers/isdn/capi/capi.c | 9 ++-------
> > 1 files changed, 2 insertions(+), 7 deletions(-)
> >
> > diff -puN drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi drivers/isdn/capi/capi.c
> > --- kj/drivers/isdn/capi/capi.c~int_sleep_on-drivers_isdn_capi_capi 2005-03-05 16:11:36.000000000 +0100
> > +++ kj-domen/drivers/isdn/capi/capi.c 2005-03-05 16:11:36.000000000 +0100
> > @@ -675,13 +675,8 @@ capi_read(struct file *file, char __user
> > if (file->f_flags & O_NONBLOCK)
> > return -EAGAIN;
> >
> > - for (;;) {
> > - interruptible_sleep_on(&cdev->recvwait);
> > - if ((skb = skb_dequeue(&cdev->recvqueue)) != 0)
> > - break;
> > - if (signal_pending(current))
> > - break;
> > - }
> > + wait_event_interruptible(cdev->recvwait,
> > + ((skb = skb_dequeue(&cdev->recvqueue)) == 0));
> > if (skb == 0)
> > return -ERESTARTNOHAND;
> > }
>
> hmm, OK. Putting an expression with side-effect such as this into a macro
> which evaluates the expression multiple times is a bit of a worry, but it
> appears that everything will work OK.
>
> That being said, I'd prefer that this come in via the ISDN team, after
> having been tested please.
I believe last update from ISDN team was 13 months ago. :-(
And I concur, testing would be great.
Domen
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2005-03-07 8:39 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-03-06 22:38 [patch 2/8] isdn/capi: replace interruptible_sleep_on() with wait_event_interruptible() domen
2005-03-07 3:47 ` Andrew Morton
2005-03-07 8:35 ` Domen Puncer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox