* lockdep input layer warnings.
@ 2006-07-06 17:34 Dave Jones
2006-07-06 18:37 ` Dmitry Torokhov
0 siblings, 1 reply; 8+ messages in thread
From: Dave Jones @ 2006-07-06 17:34 UTC (permalink / raw)
To: arjan; +Cc: mingo, Linux Kernel
One of our Fedora-devel users picked up on this this morning
in an 18rc1 based kernel.
Dave
Synaptics Touchpad, model: 1, fw: 5.9, id: 0x2c6ab1, caps: 0x884793/0x0
serio: Synaptics pass-through port at isa0060/serio1/input0
input: SynPS/2 Synaptics TouchPad as /class/input/input1
PM: Adding info for serio:serio2
=============================================
[ INFO: possible recursive locking detected ]
---------------------------------------------
kseriod/111 is trying to acquire lock:
(&ps2dev->cmd_mutex/1){--..}, at: [<c05937fd>] ps2_command+0x6a/0x2bd
but task is already holding lock:
(&ps2dev->cmd_mutex/1){--..}, at: [<c05937fd>] ps2_command+0x6a/0x2bd
other info that might help us debug this:
4 locks held by kseriod/111:
#0: (serio_mutex){--..}, at: [<c060d6bb>] mutex_lock+0x21/0x24
#1: (&serio->drv_mutex){--..}, at: [<c060d6bb>] mutex_lock+0x21/0x24
#2: (psmouse_mutex){--..}, at: [<c060d6bb>] mutex_lock+0x21/0x24
#3: (&ps2dev->cmd_mutex/1){--..}, at: [<c05937fd>] ps2_command+0x6a/0x2bd
stack backtrace:
[<c0405167>] show_trace_log_lvl+0x54/0xfd
[<c040571e>] show_trace+0xd/0x10
[<c040583d>] dump_stack+0x19/0x1b
[<c043bdb2>] __lock_acquire+0x76a/0x98d
[<c043c546>] lock_acquire+0x4b/0x6d
[<c060d793>] mutex_lock_nested+0xd5/0x251
[<c05937fd>] ps2_command+0x6a/0x2bd
[<c0598f41>] psmouse_sliced_command+0x1c/0x5a
[<c059c45a>] synaptics_pt_write+0x1e/0x44
[<c05936fb>] ps2_sendbyte+0x3e/0xd6
[<c0593879>] ps2_command+0xe6/0x2bd
[<c0598b3e>] psmouse_probe+0x1d/0x68
[<c0599ad0>] psmouse_connect+0xe8/0x20f
[<c05910d9>] serio_connect_driver+0x1e/0x2e
[<c05910ff>] serio_driver_probe+0x16/0x18
[<c0550076>] driver_probe_device+0x45/0x92
[<c05500cb>] __device_attach+0x8/0xa
[<c054fa0c>] bus_for_each_drv+0x3a/0x65
[<c0550126>] device_attach+0x59/0x6e
[<c054f74a>] bus_attach_device+0x16/0x2b
[<c054eb03>] device_add+0x1f4/0x307
[<c0591b9d>] serio_thread+0xfd/0x27c
[<c04365dc>] kthread+0xc3/0xef
[<c0402005>] kernel_thread_helper+0x5/0xb
--
http://www.codemonkey.org.uk
^ permalink raw reply [flat|nested] 8+ messages in thread* Re: lockdep input layer warnings. 2006-07-06 17:34 lockdep input layer warnings Dave Jones @ 2006-07-06 18:37 ` Dmitry Torokhov 2006-07-06 19:02 ` Arjan van de Ven 0 siblings, 1 reply; 8+ messages in thread From: Dmitry Torokhov @ 2006-07-06 18:37 UTC (permalink / raw) To: Dave Jones, arjan, mingo, Linux Kernel On 7/6/06, Dave Jones <davej@redhat.com> wrote: > One of our Fedora-devel users picked up on this this morning > in an 18rc1 based kernel. > > Dave > > > Synaptics Touchpad, model: 1, fw: 5.9, id: 0x2c6ab1, caps: 0x884793/0x0 > serio: Synaptics pass-through port at isa0060/serio1/input0 > input: SynPS/2 Synaptics TouchPad as /class/input/input1 > PM: Adding info for serio:serio2 > > ============================================= > [ INFO: possible recursive locking detected ] > --------------------------------------------- False alarm, there was a lockdep annotating patch for it in -mm. -- Dmitry ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-06 18:37 ` Dmitry Torokhov @ 2006-07-06 19:02 ` Arjan van de Ven 2006-07-06 20:29 ` Dmitry Torokhov 0 siblings, 1 reply; 8+ messages in thread From: Arjan van de Ven @ 2006-07-06 19:02 UTC (permalink / raw) To: Dmitry Torokhov; +Cc: Dave Jones, mingo, Linux Kernel On Thu, 2006-07-06 at 14:37 -0400, Dmitry Torokhov wrote: > On 7/6/06, Dave Jones <davej@redhat.com> wrote: > > One of our Fedora-devel users picked up on this this morning > > in an 18rc1 based kernel. > > > > Dave > > > > > > Synaptics Touchpad, model: 1, fw: 5.9, id: 0x2c6ab1, caps: 0x884793/0x0 > > serio: Synaptics pass-through port at isa0060/serio1/input0 > > input: SynPS/2 Synaptics TouchPad as /class/input/input1 > > PM: Adding info for serio:serio2 > > > > ============================================= > > [ INFO: possible recursive locking detected ] > > --------------------------------------------- > > False alarm, there was a lockdep annotating patch for it in -mm. not so sure; that patch is supposed to be in -rc1 already; investigating ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-06 19:02 ` Arjan van de Ven @ 2006-07-06 20:29 ` Dmitry Torokhov 2006-07-10 15:12 ` Arjan van de Ven 0 siblings, 1 reply; 8+ messages in thread From: Dmitry Torokhov @ 2006-07-06 20:29 UTC (permalink / raw) To: Arjan van de Ven; +Cc: Dave Jones, mingo, Linux Kernel On 7/6/06, Arjan van de Ven <arjan@infradead.org> wrote: > On Thu, 2006-07-06 at 14:37 -0400, Dmitry Torokhov wrote: > > On 7/6/06, Dave Jones <davej@redhat.com> wrote: > > > One of our Fedora-devel users picked up on this this morning > > > in an 18rc1 based kernel. > > > > > > Dave > > > > > > > > > Synaptics Touchpad, model: 1, fw: 5.9, id: 0x2c6ab1, caps: 0x884793/0x0 > > > serio: Synaptics pass-through port at isa0060/serio1/input0 > > > input: SynPS/2 Synaptics TouchPad as /class/input/input1 > > > PM: Adding info for serio:serio2 > > > > > > ============================================= > > > [ INFO: possible recursive locking detected ] > > > --------------------------------------------- > > > > False alarm, there was a lockdep annotating patch for it in -mm. > not so sure; that patch is supposed to be in -rc1 already; investigating > Well, you are right, the patch is in -rc1 and I see mutex_lock_nested in the backtrace but for some reason it is still not happy. Again, this is with pass-through Synaptics port and we first taking mutex of the child device and then (going through pass-through port) trying to take mutex of the parent. -- Dmitry ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-06 20:29 ` Dmitry Torokhov @ 2006-07-10 15:12 ` Arjan van de Ven 2006-07-10 15:49 ` Dmitry Torokhov 0 siblings, 1 reply; 8+ messages in thread From: Arjan van de Ven @ 2006-07-10 15:12 UTC (permalink / raw) To: Dmitry Torokhov; +Cc: Dave Jones, mingo, Linux Kernel On Thu, 2006-07-06 at 16:29 -0400, Dmitry Torokhov wrote: > On 7/6/06, Arjan van de Ven <arjan@infradead.org> wrote: > > On Thu, 2006-07-06 at 14:37 -0400, Dmitry Torokhov wrote: > > > On 7/6/06, Dave Jones <davej@redhat.com> wrote: > > > > One of our Fedora-devel users picked up on this this morning > > > > in an 18rc1 based kernel. > > > > > > > > Dave > > > > > > > > > > > > Synaptics Touchpad, model: 1, fw: 5.9, id: 0x2c6ab1, caps: 0x884793/0x0 > > > > serio: Synaptics pass-through port at isa0060/serio1/input0 > > > > input: SynPS/2 Synaptics TouchPad as /class/input/input1 > > > > PM: Adding info for serio:serio2 > > > > > > > > ============================================= > > > > [ INFO: possible recursive locking detected ] > > > > --------------------------------------------- > > > > > > False alarm, there was a lockdep annotating patch for it in -mm. > > not so sure; that patch is supposed to be in -rc1 already; investigating > > > > Well, you are right, the patch is in -rc1 and I see mutex_lock_nested > in the backtrace but for some reason it is still not happy. Again, > this is with pass-through Synaptics port and we first taking mutex of > the child device and then (going through pass-through port) trying to > take mutex of the parent. Ok it seems more drastic measures are needed; and a split of the cmd_mutex class on a per driver basis. The easiest way to do that is to inline the lock initialization (patch below) but to be honest I think the patch is a bit ugly; I considered inlining the entire function instead, any opinions on that? Index: linux-2.6.18-rc1/drivers/input/serio/libps2.c =================================================================== --- linux-2.6.18-rc1.orig/drivers/input/serio/libps2.c +++ linux-2.6.18-rc1/drivers/input/serio/libps2.c @@ -27,7 +27,7 @@ MODULE_AUTHOR("Dmitry Torokhov <dtor@mai MODULE_DESCRIPTION("PS/2 driver library"); MODULE_LICENSE("GPL"); -EXPORT_SYMBOL(ps2_init); +EXPORT_SYMBOL(__ps2_init); EXPORT_SYMBOL(ps2_sendbyte); EXPORT_SYMBOL(ps2_drain); EXPORT_SYMBOL(ps2_command); @@ -177,7 +177,7 @@ int ps2_command(struct ps2dev *ps2dev, u return -1; } - mutex_lock_nested(&ps2dev->cmd_mutex, SINGLE_DEPTH_NESTING); + mutex_lock(&ps2dev->cmd_mutex); serio_pause_rx(ps2dev->serio); ps2dev->flags = command == PS2_CMD_GETID ? PS2_FLAG_WAITID : 0; @@ -279,7 +279,7 @@ int ps2_schedule_command(struct ps2dev * * ps2_init() initializes ps2dev structure */ -void ps2_init(struct ps2dev *ps2dev, struct serio *serio) +void __ps2_init(struct ps2dev *ps2dev, struct serio *serio) { mutex_init(&ps2dev->cmd_mutex); init_waitqueue_head(&ps2dev->wait); Index: linux-2.6.18-rc1/include/linux/libps2.h =================================================================== --- linux-2.6.18-rc1.orig/include/linux/libps2.h +++ linux-2.6.18-rc1/include/linux/libps2.h @@ -39,7 +39,12 @@ struct ps2dev { unsigned char nak; }; -void ps2_init(struct ps2dev *ps2dev, struct serio *serio); +void __ps2_init(struct ps2dev *ps2dev, struct serio *serio); +static inline void ps2_init(struct ps2dev *ps2dev, struct serio *serio) +{ + __ps2_init(ps2dev, serio); + mutex_init(&ps2dev->cmd_mutex); +} int ps2_sendbyte(struct ps2dev *ps2dev, unsigned char byte, int timeout); void ps2_drain(struct ps2dev *ps2dev, int maxbytes, int timeout); int ps2_command(struct ps2dev *ps2dev, unsigned char *param, int command); ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-10 15:12 ` Arjan van de Ven @ 2006-07-10 15:49 ` Dmitry Torokhov 2006-07-10 15:53 ` Arjan van de Ven 0 siblings, 1 reply; 8+ messages in thread From: Dmitry Torokhov @ 2006-07-10 15:49 UTC (permalink / raw) To: Arjan van de Ven; +Cc: Dave Jones, mingo, Linux Kernel On 7/10/06, Arjan van de Ven <arjan@infradead.org> wrote: > On Thu, 2006-07-06 at 16:29 -0400, Dmitry Torokhov wrote: > > > > Well, you are right, the patch is in -rc1 and I see mutex_lock_nested > > in the backtrace but for some reason it is still not happy. Again, > > this is with pass-through Synaptics port and we first taking mutex of > > the child device and then (going through pass-through port) trying to > > take mutex of the parent. > > Ok it seems more drastic measures are needed; and a split of the > cmd_mutex class on a per driver basis. The easiest way to do that is to > inline the lock initialization (patch below) but to be honest I think > the patch is a bit ugly; I considered inlining the entire function > instead, any opinions on that? > It is ugly. Maybe we could have something like mutex_init_nolockdep() to annotate that lockdep is confused and make it ignore such locks? Of course there is a chance that lockdep is correct but I do not think so. -- Dmitry ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-10 15:49 ` Dmitry Torokhov @ 2006-07-10 15:53 ` Arjan van de Ven 2006-07-10 15:59 ` Dmitry Torokhov 0 siblings, 1 reply; 8+ messages in thread From: Arjan van de Ven @ 2006-07-10 15:53 UTC (permalink / raw) To: Dmitry Torokhov; +Cc: Dave Jones, mingo, Linux Kernel On Mon, 2006-07-10 at 11:49 -0400, Dmitry Torokhov wrote: > On 7/10/06, Arjan van de Ven <arjan@infradead.org> wrote: > > On Thu, 2006-07-06 at 16:29 -0400, Dmitry Torokhov wrote: > > > > > > Well, you are right, the patch is in -rc1 and I see mutex_lock_nested > > > in the backtrace but for some reason it is still not happy. Again, > > > this is with pass-through Synaptics port and we first taking mutex of > > > the child device and then (going through pass-through port) trying to > > > take mutex of the parent. > > > > Ok it seems more drastic measures are needed; and a split of the > > cmd_mutex class on a per driver basis. The easiest way to do that is to > > inline the lock initialization (patch below) but to be honest I think > > the patch is a bit ugly; I considered inlining the entire function > > instead, any opinions on that? > > > > It is ugly. Maybe we could have something like mutex_init_nolockdep() > to annotate that lockdep is confused and make it ignore such locks? nope but there is a function to make it unique, we could put that in the wrapper instead of mutex_init if that makes it less ugly.. ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: lockdep input layer warnings. 2006-07-10 15:53 ` Arjan van de Ven @ 2006-07-10 15:59 ` Dmitry Torokhov 0 siblings, 0 replies; 8+ messages in thread From: Dmitry Torokhov @ 2006-07-10 15:59 UTC (permalink / raw) To: Arjan van de Ven; +Cc: Dave Jones, mingo, Linux Kernel On 7/10/06, Arjan van de Ven <arjan@infradead.org> wrote: > On Mon, 2006-07-10 at 11:49 -0400, Dmitry Torokhov wrote: > > On 7/10/06, Arjan van de Ven <arjan@infradead.org> wrote: > > > On Thu, 2006-07-06 at 16:29 -0400, Dmitry Torokhov wrote: > > > > > > > > Well, you are right, the patch is in -rc1 and I see mutex_lock_nested > > > > in the backtrace but for some reason it is still not happy. Again, > > > > this is with pass-through Synaptics port and we first taking mutex of > > > > the child device and then (going through pass-through port) trying to > > > > take mutex of the parent. > > > > > > Ok it seems more drastic measures are needed; and a split of the > > > cmd_mutex class on a per driver basis. The easiest way to do that is to > > > inline the lock initialization (patch below) but to be honest I think > > > the patch is a bit ugly; I considered inlining the entire function > > > instead, any opinions on that? > > > > > > > It is ugly. Maybe we could have something like mutex_init_nolockdep() > > to annotate that lockdep is confused and make it ignore such locks? > > nope but there is a function to make it unique, we could put that in the > wrapper instead of mutex_init if that makes it less ugly.. > What function is that? BTW, I dont think that inlining will work because it is truly recursive scanario. The only driver in question in the backtrace provided is psmouse; there is only one call to ps2_init there. -- Dmitry ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2006-07-10 15:59 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2006-07-06 17:34 lockdep input layer warnings Dave Jones 2006-07-06 18:37 ` Dmitry Torokhov 2006-07-06 19:02 ` Arjan van de Ven 2006-07-06 20:29 ` Dmitry Torokhov 2006-07-10 15:12 ` Arjan van de Ven 2006-07-10 15:49 ` Dmitry Torokhov 2006-07-10 15:53 ` Arjan van de Ven 2006-07-10 15:59 ` Dmitry Torokhov
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox