Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759449AbZAHQN0 (ORCPT ); Thu, 8 Jan 2009 11:13:26 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1759564AbZAHQMx (ORCPT ); Thu, 8 Jan 2009 11:12:53 -0500 Received: from viefep11-int.chello.at ([62.179.121.31]:20355 "EHLO viefep11-int.chello.at" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753769AbZAHQMw (ORCPT ); Thu, 8 Jan 2009 11:12:52 -0500 X-SourceIP: 213.46.9.244 Subject: Re: [bug] sound: INFO: possible recursive locking detected From: Peter Zijlstra To: Takashi Iwai Cc: Ingo Molnar , linux-kernel@vger.kernel.org, Wu Fengguang In-Reply-To: References: <20090108152037.GA25652@elte.hu> Content-Type: text/plain Date: Thu, 08 Jan 2009 17:12:54 +0100 Message-Id: <1231431174.11687.483.camel@twins> Mime-Version: 1.0 X-Mailer: Evolution 2.24.2 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4085 Lines: 73 On Thu, 2009-01-08 at 17:10 +0100, Takashi Iwai wrote: > At Thu, 08 Jan 2009 16:39:31 +0100, > I wrote: > > > > At Thu, 8 Jan 2009 16:20:37 +0100, > > Ingo Molnar wrote: > > > > > > FYI, -tip testing found this new lockdep workqueue locking assert > > > triggered by the Intel HDA sound driver: > (snip) > > > [ 30.718689] ============================================= > > > [ 30.718689] [ INFO: possible recursive locking detected ] > > > [ 30.718689] 2.6.28-tip #2 > > > [ 30.718689] --------------------------------------------- > > > [ 30.718689] events/0/7 is trying to acquire lock: > > > [ 30.718689] (events){--..}, at: [] flush_workqueue+0x0/0x90 > > > [ 30.718689] > > > [ 30.718689] but task is already holding lock: > > > [ 30.718689] (events){--..}, at: [] run_workqueue+0x14a/0x240 > > > [ 30.718689] > > > [ 30.718689] other info that might help us debug this: > > > [ 30.718689] 2 locks held by events/0/7: > > > [ 30.718689] #0: (events){--..}, at: [] run_workqueue+0x14a/0x240 > > > [ 30.718689] #1: (&wfc.work){--..}, at: [] run_workqueue+0x14a/0x240 > > > [ 30.718689] > > > [ 30.718689] stack backtrace: > > > [ 30.718689] Pid: 7, comm: events/0 Not tainted 2.6.28-tip #2 > > > [ 30.718689] Call Trace: > > > [ 30.718689] [] validate_chain+0xc56/0x1340 > > > [ 30.718689] [] __lock_acquire+0x376/0x610 > > > [ 30.718689] [] lock_acquire+0x99/0xd0 > > > [ 30.718689] [] ? flush_workqueue+0x0/0x90 > > > [ 30.718689] [] flush_workqueue+0x41/0x90 > > > [ 30.718689] [] ? flush_workqueue+0x0/0x90 > > > [ 30.718689] [] flush_scheduled_work+0x15/0x20 > > > [ 30.718689] [] azx_clear_irq_pending+0x54/0x60 > > > [ 30.718689] [] azx_free+0x10c/0x160 > > > [ 30.718689] [] ? snd_device_free+0x8d/0x100 > > > [ 30.718689] [] azx_dev_free+0x12/0x20 > > > [ 30.718689] [] snd_device_free+0x81/0x100 > > > [ 30.718689] [] snd_device_free_all+0x69/0xa0 > > > [ 30.718689] [] snd_card_do_free+0x50/0xd0 > > > [ 30.718689] [] snd_card_free+0xa2/0xc0 > > > [ 30.718689] [] ? __delay+0xf/0x20 > > > [ 30.718689] [] azx_probe+0x38a/0x9f0 > > > [ 30.718689] [] ? azx_send_cmd+0x0/0x130 > > > [ 30.718689] [] ? azx_get_response+0x0/0x210 > > > [ 30.718689] [] ? azx_attach_pcm_stream+0x0/0x1b0 > > > [ 30.718689] [] ? do_work_for_cpu+0x0/0x30 > > > [ 30.718689] [] local_pci_probe+0x17/0x20 > > > [ 30.718689] [] do_work_for_cpu+0x18/0x30 > > > [ 30.718689] [] ? do_work_for_cpu+0x0/0x30 > > > [ 30.718689] [] run_workqueue+0x19b/0x240 > > > [ 30.718689] [] ? run_workqueue+0x14a/0x240 > > > [ 30.718689] [] worker_thread+0xaf/0x110 > > > [ 30.718689] [] ? autoremove_wake_function+0x0/0x40 > > > [ 30.718689] [] ? worker_thread+0x0/0x110 > > > [ 30.718689] [] kthread+0x53/0x80 > > > [ 30.718689] [] child_rip+0xa/0x20 > > > [ 30.718689] [] ? restore_args+0x0/0x30 > > > [ 30.718689] [] ? kthread+0x0/0x80 > > > [ 30.718689] [] ? child_rip+0x0/0x20 > > The backtrace implies that the probe callback is called in a > workqueue. Is it right? Yes, it appears a worklet tries to flush the queue he's on. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/