Re: sleeping function called from cpufreq

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 7 Nov 2005, Pierre Ossman wrote:

> As of lately I've been getting tonnes of these:
> 
> [  610.185635] Debug: sleeping function called from invalid context at
> include/linux/rwsem.h:43
> [  610.185647] in_atomic():1, irqs_disabled():0
> [  610.185653]  [<c01041be>] dump_stack+0x1e/0x20
> [  610.185667]  [<c0119b62>] __might_sleep+0xa2/0xc0
> [  610.185678]  [<c029de86>] cpufreq_notify_transition+0x46/0x220
> [  610.185690]  [<e09d08fc>] centrino_target+0xfc/0x130 [speedstep_centrino]
> [  610.185708]  [<c029f17f>] __cpufreq_driver_target+0x5f/0x70
> [  610.185718]  [<c02a029d>] cpufreq_set+0x7d/0xa0
> [  610.185728]  [<c02a0339>] store_speed+0x49/0x50
> [  610.185737]  [<c029e6c6>] store+0x46/0x60
> [  610.185745]  [<c01a5f27>] flush_write_buffer+0x37/0x40
> [  610.185754]  [<c01a5f98>] sysfs_write_file+0x68/0x90
> [  610.185763]  [<c01639b8>] vfs_write+0xa8/0x190
> [  610.185773]  [<c0163b57>] sys_write+0x47/0x70
> [  610.185781]  [<c01032bb>] sysenter_past_esp+0x54/0x75
> 
> Ideas on solving it?

There is a fix for it in 2.6.14-mm1 but i think it also requires the 
following patch in order to link. I'm not actually advocating the hotplug 
in progress flag and would prefer using a previously posted 
preempt_disable/enable method.

--- linux-mm/include/linux/cpu.h.old	2005-11-06 22:08:39.000000000 -0500
+++ linux-mm/include/linux/cpu.h	2005-11-06 22:41:17.000000000 -0500
@@ -33,7 +33,6 @@
 
 extern int register_cpu(struct cpu *, int, struct node *);
 extern struct sys_device *get_cpu_sysdev(int cpu);
-extern int current_in_cpu_hotplug(void);
 #ifdef CONFIG_HOTPLUG_CPU
 extern void unregister_cpu(struct cpu *, struct node *);
 #endif
@@ -43,6 +42,7 @@
 /* Need to know about CPUs going up/down? */
 extern int register_cpu_notifier(struct notifier_block *nb);
 extern void unregister_cpu_notifier(struct notifier_block *nb);
+extern int current_in_cpu_hotplug(void);
 
 int cpu_up(unsigned int cpu);
 
@@ -55,6 +55,10 @@
 static inline void unregister_cpu_notifier(struct notifier_block *nb)
 {
 }
+static inline int current_in_cpu_hotplug(void)
+{
+	return 0;
+}
 
 #endif /* CONFIG_SMP */
 extern struct sysdev_class cpu_sysdev_class;
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux