Date: Wed, 17 Dec 2008 01:14:48 +0100 From: "Paul B. Mahol" <onemda@gmail.com> To: "Artem Belevich" <fbsdlist@src.cx> Cc: freebsd-current@freebsd.org, trasz@freebsd.org Subject: Re: panic: _mtx_lock_sleep: recursed on non-recursive mutex sbp @ /usr/src-8-mq/src/sys/cam/cam_periph.h:182 Message-ID: <3a142e750812161614u274ef75fibe291e1d1e8b1a56@mail.gmail.com> In-Reply-To: <ed91d4a80812161556y1edd118fv6d644f1a6ea05b3a@mail.gmail.com> References: <ed91d4a80812161556y1edd118fv6d644f1a6ea05b3a@mail.gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On 12/17/08, Artem Belevich <fbsdlist@src.cx> wrote: > Freshly CVSupped -current/amd64 crashes on boot due to a locking issue > in sys/cam. > > The crash may be related to this commit: > > http://svn.freebsd.org/viewvc/base?view=revision&revision=186186 > Author: trasz > Date: Tue Dec 16 17:01:52 2008 UTC (6 hours, 37 minutes ago) > Log Message: Fix locking in periph drivers - don't try to unlock periph > that was already deallocated. > > Reviewed by: scottl > Approved by: rwatson (mentor) > Sponsored by: FreeBSD Foundation > > --Artem > > panic: _mtx_lock_sleep: recursed on non-recursive mutex sbp @ > /usr/src-8-mq/src/sys/cam/cam_periph.h:182 > > cpuid = 0 > KDB: enter: panic > [thread pid 12 tid 100026 ] > Stopped at kdb_enter+0x3d: movq $0,0x487294(%rip) > db> trace > Tracing pid 12 tid 100026 td 0xffffff0004543720 > kdb_enter() at kdb_enter+0x3d > panic() at panic+0x176 > _mtx_lock_flags() at _mtx_lock_flags > _mtx_lock_flags() at _mtx_lock_flags+0xc3 > xpt_remove_periph() at xpt_remove_periph+0x25 > camperiphfree() at camperiphfree+0xbf > cam_periph_release() at cam_periph_release+0x43 > probedone() at probedone+0x459 > camisr_runqueue() at camisr_runqueue+0x1b4 > camisr() at camisr+0xc0 > intr_event_execute_handlers() at intr_event_execute_handlers+0x68 > ithread_loop() at ithread_loop+0xae > fork_exit() at fork_exit+0x12a > fork_trampoline() at fork_trampoline+0xe > --- trap 0, rip = 0, rsp = 0xfffffff8000a2d40, rbp = 0 --- > db> show locks > exclusive sleep mutex sbp (sbp) r = 0 (0xffffff00045a1ec8) locked @ > /usr/src-8-mq/src/sys/cam/cam_xpt.c:7137 +1 In my case, it panics with kldloading cam+atapicd+atapicam: db:0:kdb.enter.panic> run lockinfo db:1:lockinfo> show locks db:1:locks> show alllocks Process 627 (powerd) thread 0xc4131000 (100065) Process 316 (devd) thread 0xc4001d80 (100053) Process 2 (g_event) thread 0xc3cfd000 (100008) Process 11 (intr) thread 0xc3fb16c0 (100076) db:1:alllocks> show lockedvnods Locked vnodes db:0:kdb.enter.panic> show pcpu cpuid = 0 curthread = 0xc3fb16c0: pid 11 "swi2: cambio" curpcb = 0xc3b32d90 fpcurthread = none idlethread = 0xc3cfdb40: pid 10 "idle: cpu0" APIC ID = 0 currentldt = 0x50 spin locks held: db:0:kdb.enter.panic> bt Tracing pid 11 tid 100076 td 0xc3fb16c0 kdb_enter(c0620503,c0620503,c061ef92,c3b32798,0,...) at kdb_enter+0x3a panic(c061ef92,c4406b3f,c436213d,b6,c3f92664,...) at panic+0x131 _mtx_lock_sleep(c3f92664,c3fb16c0,0,c436213d,b6,...) at _mtx_lock_sleep+0x4a _mtx_lock_flags(c3f92664,0,c436213d,b6,c430b168,...) at _mtx_lock_flags+0xeb xpt_remove_periph(c3fe9280,c436238d,0,c3b32888,c0604aca,...) at xpt_remove_periph+0x31 camperiphfree(c3fe3020,c3b32bd8,c4347e55,c3fe9280,c3fe3020,...) at camperiphfree+0xa2 cam_periph_release(c3fe9280,c3fe3020,c3fdec00,c3f4740c,c4348bc7,...) at cam_periph_release+0x34 probedone(c3fe9280,c3fdec00,c4361fb8,c0625d7d,c3fc8b94,...) at probedone+0x4e0 camisr_runqueue(c3f92664,0,c4361fb8,1be1,0,...) at camisr_runqueue+0x16a camisr(0,c3b32cc8,c04b0b0d,c06906c0,c3fc8b38,...) at camisr+0xcd intr_event_execute_handlers(c3cfba90,c3fc8b00,c061c876,4dd,c3fc8b70,...) at intr_event_execute_handlers+0x10f ithread_loop(c3f3d5f0,c3b32d38,c061c5cc,32d,c3cfba90,...) at ithread_loop+0x98 fork_exit(c04a0cbf,c3f3d5f0,c3b32d38) at fork_exit+0xb8 fork_trampoline() at fork_trampoline+0x8 --- trap 0, eip = 0, esp = 0xc3b32d70, ebp = 0 --- acd0: DVDR <TSSTcorpCD/DVDW TS-L632D/HH17> at ata1-master PIO4 acd0: FAILURE - INQUIRY ILLEGAL REQUEST asc=0x24 ascq=0x00 panic: _mtx_lock_sleep: recursed on non-recursive mutex ATAPICAM lock @ @/cam/cam_periph.h:182 cpuid = 0 KDB: enter: panic exclusive sleep mutex ATAPICAM lock (ATAPICAM lock) r = 0 (0xc3f92664) locked @ /usr/src/sys/modules/ata/atapicam/../../../dev/ata/atapi-cam.c:642 exclusive sx cpufreq lock (cpufreq lock) r = 0 (0xc3e69c00) locked @ /usr/src/sys/kern/kern_cpu.c:252 exclusive sx sysctl lock (sysctl lock) r = 0 (0xc068c7e4) locked @ /usr/src/sys/kern/kern_sysctl.c:1417 exclusive sleep mutex Giant (Giant) r = 0 (0xc068c1b0) locked @ /usr/src/sys/kern/kern_sysctl.c:1355 shared sx filedesc structure (filedesc structure) r = 0 (0xc3faf32c) locked @ /usr/src/sys/kern/sys_generic.c:958 exclusive sx GEOM topology (GEOM topology) r = 0 (0xc068a3c8) locked @ /usr/src/sys/geom/geom_event.c:185 exclusive sleep mutex ATAPICAM lock (ATAPICAM lock) r = 0 (0xc3f92664) locked @ /usr/src/sys/modules/ata/atapicam/../../../dev/ata/atapi-cam.c:642 -- Paul
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3a142e750812161614u274ef75fibe291e1d1e8b1a56>