public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* sleeping function called from invalid context at kernel/mutex.c
@ 2008-09-30 17:00 Sitsofe Wheeler
       [not found] ` <20081001071004.GA9366@elte.hu>
  0 siblings, 1 reply; 4+ messages in thread
From: Sitsofe Wheeler @ 2008-09-30 17:00 UTC (permalink / raw)
  To: linux-kernel; +Cc: Ingo Molnar, Andrew Morton

This turned up in a linux-tip from yesterday after resuming from a 
suspend on an EeePC 900:

[ 1176.720189] ACPI: Preparing to enter system sleep state S3
[ 1176.745011] Intel machine check architecture supported.
[ 1176.745011] Intel machine check reporting enabled on CPU#0.
[ 1176.745011] Back to C!
[ 1176.745011] BUG: sleeping function called from invalid context at 
kernel/mutex.c:207
[ 1176.745011] in_atomic(): 0, irqs_disabled(): 1, pid: 4513, name: 
pm-suspend
[ 1176.745011] 3 locks held by pm-suspend/4513:
[ 1176.745011]  #0:  (&buffer->mutex){--..}, at: [<c01b89c0>] 
sysfs_write_file+0x30/0x100
[ 1176.745011]  #1:  (pm_mutex){--..}, at: [<c014ef5a>] 
enter_state+0x4a/0x140
[ 1176.745011]  #2:  (dpm_list_mtx){--..}, at: [<c029c254>] 
device_pm_lock+0x14/0x20
[ 1176.745011] irq event stamp: 28504
[ 1176.745011] hardirqs last  enabled at (28503): [<c014a92b>] 
trace_hardirqs_on+0xb/0x10
[ 1176.745011] hardirqs last disabled at (28504): [<c014593b>] 
trace_hardirqs_off+0xb/0x10
[ 1176.745011] softirqs last  enabled at (27690): [<c012bd53>] 
__do_softirq+0xa3/0xc0
[ 1176.745011] softirqs last disabled at (27685): [<c012bdc5>] 
do_softirq+0x55/0x60
[ 1176.745011] Pid: 4513, comm: pm-suspend Not tainted 
2.6.27-rc7-tipskw-00976-g30d1868-dirty #25
[ 1176.745011]  [<c012bdc5>] ? do_softirq+0x55/0x60
[ 1176.745011]  [<c011fe74>] __might_sleep+0xe4/0x110
[ 1176.745011]  [<c03cfd44>] mutex_lock_nested+0x24/0x50
[ 1176.745011]  [<c0116772>] microcode_update_cpu+0x22/0xf0
[ 1176.745011]  [<c014593b>] ? trace_hardirqs_off+0xb/0x10
[ 1176.745011]  [<c03d178c>] ? _spin_unlock_irqrestore+0x3c/0x60
[ 1176.745011]  [<c0116855>] mc_sysdev_resume+0x15/0x20
[ 1176.745011]  [<c029754b>] __sysdev_resume+0x3b/0x50
[ 1176.745011]  [<c0297997>] sysdev_resume+0x57/0x90
[ 1176.745011]  [<c029cf00>] device_power_up+0x10/0x20
[ 1176.745011]  [<c014ee8f>] suspend_devices_and_enter+0x11f/0x140
[ 1176.745011]  [<c014efbb>] enter_state+0xab/0x140
[ 1176.745011]  [<c014f0f4>] state_store+0xa4/0xe0
[ 1176.745011]  [<c014f050>] ? state_store+0x0/0xe0
[ 1176.745011]  [<c0205934>] kobj_attr_store+0x24/0x30
[ 1176.745011]  [<c01b8a37>] sysfs_write_file+0xa7/0x100
[ 1176.745011]  [<c017b4da>] vfs_write+0x9a/0x120
[ 1176.745011]  [<c01b8990>] ? sysfs_write_file+0x0/0x100
[ 1176.745011]  [<c017b622>] sys_write+0x42/0x70
[ 1176.745011]  [<c010334d>] sysenter_do_call+0x12/0x35
[ 1176.745011]  =======================
[ 1176.745011] Force enabled HPET at resume
[ 1176.748667] ACPI: Waking up from system sleep state S3
[ 1176.801657] ACPI: EC: non-query interrupt received, switching to 
interrupt mode

-- 
Sitsofe | http://sucs.org/~sits/


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: sleeping function called from invalid context at kernel/mutex.c
       [not found]         ` <b647ffbd0810020656l48eba7bdt8cd8e4cd47a8a95b@mail.gmail.com>
@ 2008-10-02 13:59           ` Dmitry Adamushko
  2008-10-02 14:01             ` Dmitry Adamushko
  0 siblings, 1 reply; 4+ messages in thread
From: Dmitry Adamushko @ 2008-10-02 13:59 UTC (permalink / raw)
  To: Ingo Molnar
  Cc: Peter Oruba, Sitsofe Wheeler, Rafael J. Wysocki, Andrew Morton,
	linux-kernel

[ cc'd: lkml ]

On 02/10/2008, Dmitry Adamushko <dmitry.adamushko@gmail.com> wrote:
> On 02/10/2008, Ingo Molnar <mingo@elte.hu> wrote:
>  >
>  >  * Peter Oruba <peter.oruba@amd.com> wrote:
>  >
>  >  > microcode_update_cpu() is still there, being called from
>  >  > microcode_init_cpu() and mc_sysdev_resume().
>  >
>  >
>  > ah, microcode_update_cpu, not update_microcode_cpu. So yes, the problem
>  >  is still there with the latest code.
>

Right, I've been looking at the wrong tree. Please find the fix
enclosed. Compiles ok, shouldn't break anything else.

 >
 >         Ingo
 >



-- 
Best regards,
Dmitry Adamushko

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: sleeping function called from invalid context at kernel/mutex.c
  2008-10-02 13:59           ` Dmitry Adamushko
@ 2008-10-02 14:01             ` Dmitry Adamushko
  2008-10-02 15:52               ` Ingo Molnar
  0 siblings, 1 reply; 4+ messages in thread
From: Dmitry Adamushko @ 2008-10-02 14:01 UTC (permalink / raw)
  To: Ingo Molnar
  Cc: Peter Oruba, Sitsofe Wheeler, Rafael J. Wysocki, Andrew Morton,
	linux-kernel

[-- Attachment #1: Type: text/plain, Size: 782 bytes --]

err... I appologize for spamming. I've forgot to attach the fix.

>
>
>  On 02/10/2008, Dmitry Adamushko <dmitry.adamushko@gmail.com> wrote:
>  > On 02/10/2008, Ingo Molnar <mingo@elte.hu> wrote:
>  >  >
>  >  >  * Peter Oruba <peter.oruba@amd.com> wrote:
>  >  >
>  >  >  > microcode_update_cpu() is still there, being called from
>  >  >  > microcode_init_cpu() and mc_sysdev_resume().
>  >  >
>  >  >
>  >  > ah, microcode_update_cpu, not update_microcode_cpu. So yes, the problem
>  >  >  is still there with the latest code.
>  >
>
>  Right, I've been looking at the wrong tree. Please find the fix
>  enclosed. Compiles ok, shouldn't break anything else.
>
>   >
>   >         Ingo
>   >
>
>
>
>  --
>  Best regards,
>  Dmitry Adamushko
>


-- 
Best regards,
Dmitry Adamushko

[-- Attachment #2: ucode-fix.patch --]
[-- Type: application/octet-stream, Size: 1520 bytes --]


Subject: x86-microcode: update locking scheme

Fix the following "sleeping function called from invalid context" warning:

...
__might_sleep
mutex_lock_nested
microcode_update_cpu
mc_sysdev_resume
__sysdev_resume
sysdev_resume
device_power_up
...

Signed-off-by: Dmitry Adamushko <dmitry.adamushko@gmail.com>

diff --git a/arch/x86/kernel/microcode_core.c b/arch/x86/kernel/microcode_core.c
index 8db2eb5..936d8d5 100644
--- a/arch/x86/kernel/microcode_core.c
+++ b/arch/x86/kernel/microcode_core.c
@@ -324,10 +324,6 @@ void microcode_update_cpu(int cpu)
 	struct ucode_cpu_info *uci = ucode_cpu_info + cpu;
 	int err = 0;
 
-	/* We should bind the task to the CPU */
-	BUG_ON(raw_smp_processor_id() != cpu);
-
-	mutex_lock(&microcode_mutex);
 	/*
 	 * Check if the system resume is in progress (uci->valid != NULL),
 	 * otherwise just request a firmware:
@@ -340,11 +336,8 @@ void microcode_update_cpu(int cpu)
 			err = microcode_ops->request_microcode_fw(cpu,
 					&microcode_pdev->dev);
 	}
-
 	if (!err)
 		microcode_ops->apply_microcode(cpu);
-
-	mutex_unlock(&microcode_mutex);
 }
 
 static void microcode_init_cpu(int cpu)
@@ -352,7 +345,13 @@ static void microcode_init_cpu(int cpu)
 	cpumask_t old = current->cpus_allowed;
 
 	set_cpus_allowed_ptr(current, &cpumask_of_cpu(cpu));
+	/* We should bind the task to the CPU */
+	BUG_ON(raw_smp_processor_id() != cpu);
+
+	mutex_lock(&microcode_mutex);
 	microcode_update_cpu(cpu);
+	mutex_unlock(&microcode_mutex);
+
 	set_cpus_allowed_ptr(current, &old);
 }
 

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: sleeping function called from invalid context at kernel/mutex.c
  2008-10-02 14:01             ` Dmitry Adamushko
@ 2008-10-02 15:52               ` Ingo Molnar
  0 siblings, 0 replies; 4+ messages in thread
From: Ingo Molnar @ 2008-10-02 15:52 UTC (permalink / raw)
  To: Dmitry Adamushko
  Cc: Peter Oruba, Sitsofe Wheeler, Rafael J. Wysocki, Andrew Morton,
	linux-kernel


* Dmitry Adamushko <dmitry.adamushko@gmail.com> wrote:

> >  Right, I've been looking at the wrong tree. Please find the fix 
> >  enclosed. Compiles ok, shouldn't break anything else.

applied to tip/x86/microcode, thanks Dmitry!

	Ingo

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-10-02 15:53 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-30 17:00 sleeping function called from invalid context at kernel/mutex.c Sitsofe Wheeler
     [not found] ` <20081001071004.GA9366@elte.hu>
     [not found]   ` <b647ffbd0810020029v1fd59d85u8d8048aebe3e4d55@mail.gmail.com>
     [not found]     ` <48E4882E.5000100@amd.com>
     [not found]       ` <20081002085529.GB3550@elte.hu>
     [not found]         ` <b647ffbd0810020656l48eba7bdt8cd8e4cd47a8a95b@mail.gmail.com>
2008-10-02 13:59           ` Dmitry Adamushko
2008-10-02 14:01             ` Dmitry Adamushko
2008-10-02 15:52               ` Ingo Molnar

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox