Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 8 Jul 2004 22:31:52 -0400 (EDT)
From:      Robert Watson <rwatson@FreeBSD.org>
To:        current@FreeBSD.org
Subject:   panic: Assertion td->td_turnstile != NULL failed at ../../../kern/subr_turnstile.c:478
Message-ID:  <Pine.NEB.3.96L.1040708222518.60816A-100000@fledge.watson.org>

next in thread | raw e-mail | index | archive | help

Was doing some stress testing on a box with some if_xl locking tweaks from
Bruce Simpson, and ran into this.  Configuration is a GENERIC kernel
running on a dual-Xeon 2.4GHz (each one with two logical processors, so 
4 HTT processors).  The workload was as follows:

- Apache 1.3 running on the box, 20 recursive wget clients from an
  adjacent machine.

- Simultaneous "supersmack" select key mysql test running with 11 threads
  and 10,000 transactions, running with libkse.

I attempted to log in on the serial console and got this panic:

login: root
Password:panic: Assertion td->td_turnstile != NULL failed at
../../../kern/subr_turnstile.c:478
cpuid = 1; 
Stack backtrace:
backtrace(100,c2ba4840,c088f4a0,c2ba4840,c24ade80) at backtrace+0x12
panic(c07ccf34,c07d2fd8,c07d2dc0,1de,c089a9c0) at panic+0x11e
turnstile_wait(c24ade80,c088f4a0,c22d6b00,c088f4a0,2,c07cf595,20d) at
turnstile_wait+0x23a
_mtx_lock_sleep(c088f4a0,0,c07d873a,208) at _mtx_lock_sleep+0x103
_mtx_lock_flags(c088f4a0,0,c07d873a,208) at _mtx_lock_flags+0x80
vn_read(c291c330,e6ff8c88,c2a54400,1,c2ba4840) at vn_read+0x22
dofileread(c2ba4840,c291c330,20,ac3e528,3b) at dofileread+0xb0
pread(c2ba4840,e6ff8d14,6,a3,202) at pread+0x6d
syscall(ac0002f,ac1002f,bf82002f,3b,0) at syscall+0x217
Xint0x80_syscall() at Xint0x80_syscall+0x1f
--- syscall (198), eip = 0x28472477, esp = 0xbf82a360, ebp = 0xbf82a38c ---
Debugger("panic")
Stopped at      Debugger+0x46:  xchgl   %ebx,in_Debugger.0
db> show pcpu
cpuid        = 1
curthread    = 0xc2ba4840: pid 601 "mysqld"
curpcb       = 0xe6ff8da0
fpcurthread  = none
idlethread   = 0xc225f840: pid 13 "idle: cpu1"
APIC ID      = 1
currentldt   = 0x30
spin locks held:

---

(kgdb) bt
#0  Debugger (msg=0xc07d01bb "panic") at
../../../i386/i386/db_interface.c:319
#1  0xc05eeaa9 in panic (fmt=0xc07ccf34 "Assertion %s failed at %s:%d")
    at ../../../kern/kern_shutdown.c:543
#2  0xc060bfd6 in turnstile_wait (ts=0xc24ade80, lock=0xc088f4a0, 
    owner=0xc22d6b00) at ../../../kern/subr_turnstile.c:518
#3  0xc05e715b in _mtx_lock_sleep (m=0xc088f4a0, opts=0, 
    file=0xc07d873a "../../../kern/vfs_vnops.c", line=520)
    at ../../../kern/kern_mutex.c:541
#4  0xc05e6db4 in _mtx_lock_flags (m=0xc088f4a0, opts=0, 
    file=0xc07d873a "../../../kern/vfs_vnops.c", line=520)
    at ../../../kern/kern_mutex.c:252
#5  0xc064516a in vn_read (fp=0xc291c330, uio=0xe6ff8c88, 
    active_cred=0xc2a54400, flags=1, td=0xc2ba4840)
    at ../../../kern/vfs_vnops.c:520
#6  0xc060ea70 in dofileread (td=0xc2ba4840, fp=0xc291c330, fd=32, 
    buf=0xac3e528, nbyte=59, offset=-4539276580668571630, flags=1)
    at ../../../sys/file.h:234
#7  0xc060e9a5 in pread (td=0xc2ba4840, uap=0xe6ff8d14)
    at ../../../kern/sys_generic.c:144
#8  0xc0769513 in syscall (frame=
      {tf_fs = 180355119, tf_es = 180420655, tf_ds = -1081999313, tf_edi =
59, tf_esi = 0, tf_ebp = -1081957492, tf_isp = -419459724, tf_ebx =
676218668, tf_edx = 180380160, tf_ecx = 179573384, tf_eax = 198, tf_trapno
= 0, tf_err = 2, tf_eip = 675751031, tf_cs = 31, tf_eflags = 514, tf_esp =
-1081957536, tf_ss = 47})
    at ../../../i386/i386/trap.c:1004
(kgdb) up
#1  0xc05eeaa9 in panic (fmt=0xc07ccf34 "Assertion %s failed at %s:%d")
    at ../../../kern/kern_shutdown.c:543
543                     Debugger ("panic");
(kgdb) up
#2  0xc060bfd6 in turnstile_wait (ts=0xc24ade80, lock=0xc088f4a0, 
    owner=0xc22d6b00) at ../../../kern/subr_turnstile.c:518
518                     MPASS(owner == ts->ts_owner);
(kgdb) inspect *ts
$1 = {ts_blocked = {tqh_first = 0xc2ba49a0, tqh_last = 0xc2ba4440}, 
  ts_pending = {tqh_first = 0x0, tqh_last = 0xc24ade88}, ts_hash = {
    le_next = 0x0, le_prev = 0xc089a9c0}, ts_link = {le_next = 0x0, 
    le_prev = 0xc22d6b74}, ts_free = {lh_first = 0xc2a7d9c0}, 
  ts_lockobj = 0xc088f4a0, ts_owner = 0xc22d6b00}
(kgdb) 
(kgdb) up
#3  0xc05e715b in _mtx_lock_sleep (m=0xc088f4a0, opts=0, 
    file=0xc07d873a "../../../kern/vfs_vnops.c", line=520)
    at ../../../kern/kern_mutex.c:541
541                     turnstile_wait(ts, &m->mtx_object, mtx_owner(m));
(kgdb) inspect *m
$2 = {mtx_object = {lo_class = 0xc082af3c, lo_name = 0xc07e0295 "Giant", 
    lo_type = 0xc07e0295 "Giant", lo_flags = 720896, lo_list = {
      tqe_next = 0xc088f460, tqe_prev = 0xc0899770}, lo_witness =
0xc089cac8}, 
  mtx_lock = 3257756418, mtx_recurse = 0}

Robert N M Watson             FreeBSD Core Team, TrustedBSD Projects
robert@fledge.watson.org      Principal Research Scientist, McAfee Research



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.NEB.3.96L.1040708222518.60816A-100000>