[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <Pine.LNX.4.44L0.0711191521170.3129-100000@iolanthe.rowland.org>
Date: Mon, 19 Nov 2007 15:27:14 -0500 (EST)
From: Alan Stern <stern@...land.harvard.edu>
To: Rudolf Marek <r.marek@...embler.cz>
cc: Jiri Slaby <jirislaby@...il.com>,
"Rafael J. Wysocki" <rjw@...k.pl>,
Andrew Morton <akpm@...ux-foundation.org>,
Greg KH <greg@...ah.com>,
Kernel development list <linux-kernel@...r.kernel.org>,
Linux-pm mailing list <linux-pm@...ts.linux-foundation.org>,
<lm-sensors@...sensors.org>
Subject: Re: broken suspend [Was: 2.6.24-rc2-mm1]
On Mon, 19 Nov 2007, Rudolf Marek wrote:
> Hello all,
> >>> gives coretemp_cpu_callback -> coretemp_device_remove ->
> >>> platform_device_unregister, so coretemp seems to be what I have and you don't.
> >
> > Yes.
> >
> > For the coretemp developers: coretemp_cpu_callback() needs to be more
> > careful about what it does. During a system sleep transition (suspend,
> > hibernate, resume) it isn't possible to register or unregister a
> > device. Attempts to register will fail and attempts to unregister will
> > block until the system sleep is over -- and for this callback that
> > means hanging.
>
> Well I wrote the driver. Thanks for the clarification. If I recall correctly I
> looked how this part should be done from others drivers. Now while checking
> what happened to the file, seems Rafael added something related.
>
> http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=8bb7844286fb8c9fce6f65d8288aeb09d03a5e0d
That does look like it was meant for exactly this sort of situation.
> > It's not clear what the best way is to fix this. Perhaps the CPU
> > notification should be sent along with a special flag indicating that
> > the CPU transition is part of a system sleep (although this seems
> > racy). Perhaps the driver should notice when a system sleep begins,
> > and defer all CPU-change handling until after the sleep is over.
>
> maybe it does exist? CPU_DOWN_PREPARE ?
>
> http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=blob;f=Documentation/cpu-hotplug.txt;hb=HEAD
>
> Unfortunately I'm not very familiar with this, calling the
> coretemp_device_remove from CPU_DOWN_PREPARE would help? Looking at microcode
> driver, seems it just hide sysfs interface from user.
I'm not sure exactly what you want to do here. But it seems like a
waste to unregister the coretemp devices at the start of a system sleep
and then register them back at the end.
Could you simply leave the devices registered throughout the entire
sleep? Of course, at the end you would have to check that all the CPUs
really did come back up, and unregister the devices for the CPUs that
are still offline.
Alan Stern
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists