* [PATCH] Bluetooth node manager causes up to ~3.25s delay in freezing tasks.
@ 2008-12-09 7:55 Nigel Cunningham
2008-12-09 11:24 ` Marcel Holtmann
0 siblings, 1 reply; 3+ messages in thread
From: Nigel Cunningham @ 2008-12-09 7:55 UTC (permalink / raw)
To: linux-bluetooth, marcel, linux-pm, LKML
Hi all.
The bluetooth nodemanager function "nodemgr_host_thread" contains a loop
that calls try_to_freeze near the top of the loop, but then delays for
up to 3.25 seconds (plus time to do work) before getting back to the top
of the loop. When starting a cycle post-boot, this doesn't seem to bite,
but it is causing a noticeable delay at boot time, when freezing
processes prior to starting to read the image.
The following patch adds invocation of try_to_freeze to the subloops
that are used in the body of this function. With these additions, the
time to freeze when starting to resume at boot time is virtually zero.
I'm no expert on bluetooth, and so don't know that we shouldn't check
the return value and jump back to the top of the loop or such like after
being frozen, but I submit it for your consideration.
Signed-off-by: Nigel Cunningham <nigel@tuxonice.net>
nodemgr.c | 2 ++
1 file changed, 2 insertions(+)
diff -ruNp 710-nodemanager-freezing.patch-old/drivers/ieee1394/nodemgr.c 710-nodemanager-freezing.patch-new/drivers/ieee1394/nodemgr.c
--- 710-nodemanager-freezing.patch-old/drivers/ieee1394/nodemgr.c 2008-12-06 08:42:08.000000000 +1100
+++ 710-nodemanager-freezing.patch-new/drivers/ieee1394/nodemgr.c 2008-12-09 18:49:26.000000000 +1100
@@ -1685,6 +1685,7 @@ static int nodemgr_host_thread(void *dat
g = get_hpsb_generation(host);
for (i = 0; i < 4 ; i++) {
msleep_interruptible(63);
+ try_to_freeze();
if (kthread_should_stop())
goto exit;
@@ -1725,6 +1726,7 @@ static int nodemgr_host_thread(void *dat
/* Sleep 3 seconds */
for (i = 3000/200; i; i--) {
msleep_interruptible(200);
+ try_to_freeze();
if (kthread_should_stop())
goto exit;
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] Bluetooth node manager causes up to ~3.25s delay in freezing tasks.
2008-12-09 7:55 [PATCH] Bluetooth node manager causes up to ~3.25s delay in freezing tasks Nigel Cunningham
@ 2008-12-09 11:24 ` Marcel Holtmann
2008-12-09 11:37 ` Nigel Cunningham
0 siblings, 1 reply; 3+ messages in thread
From: Marcel Holtmann @ 2008-12-09 11:24 UTC (permalink / raw)
To: Nigel Cunningham; +Cc: linux-bluetooth, linux-pm, LKML
Hi Nigel,
> The bluetooth nodemanager function "nodemgr_host_thread" contains a loop
> that calls try_to_freeze near the top of the loop, but then delays for
> up to 3.25 seconds (plus time to do work) before getting back to the top
> of the loop. When starting a cycle post-boot, this doesn't seem to bite,
> but it is causing a noticeable delay at boot time, when freezing
> processes prior to starting to read the image.
I don't wanna disappoint you, but IEEE1394 is actually Firewire and not
Bluetooth :)
Regards
Marcel
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] Bluetooth node manager causes up to ~3.25s delay in freezing tasks.
2008-12-09 11:24 ` Marcel Holtmann
@ 2008-12-09 11:37 ` Nigel Cunningham
0 siblings, 0 replies; 3+ messages in thread
From: Nigel Cunningham @ 2008-12-09 11:37 UTC (permalink / raw)
To: Marcel Holtmann; +Cc: linux-bluetooth, linux-pm, LKML
Hi.
On Tue, 2008-12-09 at 12:24 +0100, Marcel Holtmann wrote:
> Hi Nigel,
>
> > The bluetooth nodemanager function "nodemgr_host_thread" contains a loop
> > that calls try_to_freeze near the top of the loop, but then delays for
> > up to 3.25 seconds (plus time to do work) before getting back to the top
> > of the loop. When starting a cycle post-boot, this doesn't seem to bite,
> > but it is causing a noticeable delay at boot time, when freezing
> > processes prior to starting to read the image.
>
> I don't wanna disappoint you, but IEEE1394 is actually Firewire and not
> Bluetooth :)
Aww. Sorry. All these newfangled technologies confuse an old-timer like
me. Oh, wait. I'm not even 40 yet.
I'll try the right list this time, I hope!
Nigel
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2008-12-09 11:37 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-12-09 7:55 [PATCH] Bluetooth node manager causes up to ~3.25s delay in freezing tasks Nigel Cunningham
2008-12-09 11:24 ` Marcel Holtmann
2008-12-09 11:37 ` Nigel Cunningham
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox