Date: Tue, 18 Dec 2007 08:21:45 +1300 From: Andrew Thompson <thompsa@FreeBSD.org> To: Robert Watson <rwatson@FreeBSD.org> Cc: freebsd-current@freebsd.org, Thierry Herbelot <thierry@herbelot.com> Subject: Re: -current kernel panic Message-ID: <20071217192145.GA85906@heff.fud.org.nz> In-Reply-To: <20071217191047.D57519@fledge.watson.org> References: <200712171935.10911.thierry@herbelot.com> <20071217191047.D57519@fledge.watson.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, Dec 17, 2007 at 07:13:54PM +0000, Robert Watson wrote: > > On Mon, 17 Dec 2007, Thierry Herbelot wrote: > >> db> where >> Tracing pid 11 tid 100003 td 0xc2763880 >> kdb_enter(c0aff8da,0,c0afaad4,dd238a2c,0,...) at kdb_enter+0x32 >> panic(c0afaad4,c0b018c6,c0b01376,742,c0c1a680,...) at panic+0x124 >> sched_switch(c2763880,0,1,17b,86a5c2a4,...) at sched_switch+0xe6 >> mi_switch(1,0,c0b03bf0,2e2,c2736e60,...) at mi_switch+0x217 >> turnstile_wait(c2736e60,c36dbaa0,0,184,c1474708,...) at >> turnstile_wait+0x4cb >> _mtx_lock_sleep(c1474708,c2763880,0,c0b213d7,726,...) at >> _mtx_lock_sleep+0x18e >> _mtx_lock_flags(c1474708,0,c0b213d7,726,c0b04452,...) at >> _mtx_lock_flags+0xef >> uma_zalloc_arg(c1472960,0,2,2,dd238b9e,...) at uma_zalloc_arg+0xd3 >> malloc(2,c0bb1a40,2,131,208bb0,...) at malloc+0xd2 >> getenv(c0b2dfe8,c0c20a80,c2763880,3,dd238cc8,...) at getenv+0xa6 >> cpu_idle_default(dd238cf8,c077d839,c0c20a80,0,c0b01376,...) at >> cpu_idle_default+0x13 >> cpu_idle(c0c20a80,0,c0b01376,322,c0c1a680,...) at cpu_idle+0x28 >> sched_idletd(0,dd238d38,c0afc024,30c,c2761804,...) at sched_idletd+0x249 >> fork_exit(c077d5f0,0,dd238d38) at fork_exit+0xb8 >> fork_trampoline() at fork_trampoline+0x8 >> --- trap 0, eip = 0, esp = 0xdd238d70, ebp = 0 --- > > Well, that's something of an ugly thread. The idle thread should not be > calling the kernel getenv() as it involves locks, and worse yet, the > potential for memory allocation. The idle thread is not allowed to yield > in such a way as it becomes unrunnable, or we will find ourselves in a > situation where there is no idle thread for a CPU, and always having an > idle thread is an invariant. I am a bit unclear on how that could happen, I > don't se an obvious call to getenv() in the cpu idle default code on i386 > or amd64. See sys/i386/i386/machdep.c r1.663, Rui put the macbook test in the wrong function. It should be fixed now. Andrew
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20071217192145.GA85906>