Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 18 Dec 2003 23:53:16 -0800 (PST)
From:      Don Lewis <truckman@FreeBSD.org>
To:        mezz7@cox.net, "Justin T. Gibbs" <gibbs@FreeBSD.org>
Cc:        freebsd-current@FreeBSD.org
Subject:   Re: The reboot doesn't work anymore in today -CURRENT..
Message-ID:  <200312190753.hBJ7rGeF076868@gw.catspoiler.org>
In-Reply-To: <200312190548.hBJ5mSeF076722@gw.catspoiler.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On 18 Dec, Don Lewis wrote:
> On 18 Dec, Jeremy Messenger wrote:
>> On Fri, 19 Dec 2003 00:20:48 -0500, Joe Marcus Clarke 
>> <marcus@marcuscom.com> wrote:
>> 
>>> On Fri, 2003-12-19 at 00:16, Jeremy Messenger wrote:
>>>> Yesterday and today, I CVSup'ed and the reboot doesn't work anymore,
>>>> something isn't work correct. The last week -CURRENT works fine, I can
>>>> reboot. I tried to use GENERIC kernel and I still get the same result, 
>>>> so
>>>> I am not sure what I should do next. Attaching the dmesg.txt here..
>>>>
>>>> shutdown's -r and -p don't work, I had to press the power button to turn
>>>> off and on by manual. It does shutdown clean like 'shutdown -h', 
>>>> thought.
> 
> I just saw the same thing here when I rebooted a two day old kernel.

Here's my stack trace and the output of the ddb ps command:

db> tr
siointr1(c6933800,0,c089c7f4,6a0,e0414c88) at siointr1+0x11c
siointr(c6933800,c0809e0a,c29a1cec,e0414c7c,4) at siointr+0x35
intr_execute_handlers(c29a1c8c,e0414ca0,e0414ce8,c07fdcc3,34) at intr_execute_handlers+0xc8
lapic_handle_intr(34) at lapic_handle_intr+0x3a
Xapic_isr1() at Xapic_isr1+0x33
--- interrupt, eip = 0xc080f960, esp = 0xe0414ce4, ebp = 0xe0414ce8 ---
mp_grab_cpu_hlt(e0414d10,c063c6bc,c0940940,2,c087fd4e) at mp_grab_cpu_hlt+0x30
cpu_idle(c0940940,2,c087fd4e,53,c063c680) at cpu_idle+0x8
idle_proc(0,e0414d48,c087fbff,311,0) at idle_proc+0x3c
fork_exit(c063c680,0,e0414d48) at fork_exit+0xb4
fork_trampoline() at fork_trampoline+0x8
--- trap 0x1, eip = 0, esp = 0xe0414d7c, ebp = 0 ---

db> ps
  pid   proc     uarea   uid  ppid  pgrp  flag   stat  wmesg    wchan  cmd
   59 c693e388 e1ee7000    0     0     0 0000204 [SLP]- 0xc0970f8c] nfsiod 3
   58 c693e54c e1ee8000    0     0     0 0000204 [SLP]- 0xc0970f88] nfsiod 2
   57 c693e710 e1ee9000    0     0     0 0000204 [SLP]- 0xc0970f84] nfsiod 1
   56 c693e8d4 e1eea000    0     0     0 0000204 [SLP]- 0xc0970f80] nfsiod 0
   55 c693ea98 e1eeb000    0     0     0 0000204 [SLP]ktsusp 0xc693eb98] vnlru
   54 c693ec5c e1eec000    0     0     0 0000204 [SLP]ktsusp 0xc693ed5c] syncer
   53 c693ee20 e1eed000    0     0     0 0000204 [SLP]ktsusp 0xc693ef20] bufdaemon
   52 c699a000 e5f03000    0     0     0 000020c [SLP]pgzero 0xc0977808] pagezero
   51 c699a1c4 e5f04000    0     0     0 0000204 [SLP]psleep 0xc0977860] vmdaemon
   50 c699a388 e5f05000    0     0     0 0000204 [SLP]psleep 0xc097784c] pagedaemon
   49 c699a54c e5f06000    0     0     0 0000204 [IWAIT] swi0: tty:sio
   48 c699a710 e5f07000    0     0     0 0000204 [SLP]idle 0xc694d800] aic_recovery0
    9 c699a8d4 e5f50000    0     0     0 0000204 [SLP]idle 0xc694d800] aic_recovery0
   47 c68a3a98 e1eb5000    0     0     0 0000204 [SLP]usbevt 0xc697d210] usb1
   46 c68a3c5c e1eb6000    0     0     0 0000204 [SLP]usbtsk 0xc093a78c] usbtask
   45 c68a3e20 e1eb7000    0     0     0 0000204 [SLP]usbevt 0xc6940210] usb0
    8 c693a000 e1eb8000    0     0     0 0000204 [SLP]actask 0xc0a9f90c] acpi_task2
    7 c693a1c4 e1eb9000    0     0     0 0000204 [SLP]actask 0xc0a9f90c] acpi_task1
    6 c693a388 e1eba000    0     0     0 0000204 [SLP]actask 0xc0a9f90c] acpi_task0
   44 c693a54c e1ebb000    0     0     0 0000204 [IWAIT] swi3: cambio
   43 c693a710 e1ebc000    0     0     0 0000204 new [IWAIT] swi2: camnet
   42 c693a8d4 e1ebd000    0     0     0 0000204 [IWAIT] swi7: acpitaskq
   41 c693aa98 e1ebe000    0     0     0 0000204 new [IWAIT] swi5:+
    5 c693ac5c e1ee3000    0     0     0 0000204 [SLP]tqthr 0xc0943c28] taskqueue
   40 c693ae20 e1ee4000    0     0     0 0000204 new [IWAIT] swi6:+
   39 c693e000 e1ee5000    0     0     0 0000204 new [IWAIT] swi7: task queue
   38 c689254c e1e85000    0     0     0 0000204 [SLP]- 0xc09383a0] random
    4 c6892710 e1e86000    0     0     0 0000204 [SLP]- 0xc093cde0] g_down
    3 c68928d4 e1e87000    0     0     0 0000204 [SLP]- 0xc093cddc] g_up
    2 c6892a98 e1e88000    0     0     0 0000204 [SLP]- 0xc093cdd4] g_event
   37 c6892c5c e1e89000    0     0     0 0000204 new [IWAIT] swi4: vm
   36 c6892e20 e1e8a000    0     0     0 000020c [IWAIT] swi8: tty:sio clock
   35 c68a3000 e1e8b000    0     0     0 0000204 [IWAIT] swi1: net
   34 c68a31c4 e1eb0000    0     0     0 0000204 new [IWAIT] irq0: clk
   33 c68a3388 e1eb1000    0     0     0 0000204 new [IWAIT] irq23:
   32 c68a354c e1eb2000    0     0     0 0000204 new [IWAIT] irq22:
   31 c68a3710 e1eb3000    0     0     0 0000204 new [IWAIT] irq21:
   30 c68a38d4 e1eb4000    0     0     0 0000204 new [IWAIT] irq20:
   29 c29b01c4 e0454000    0     0     0 0000204 new [IWAIT] irq19:
   28 c29b0388 e0455000    0     0     0 0000204 [IWAIT] irq18: fxp0
   27 c29b054c e0456000    0     0     0 0000204 new [IWAIT] irq17:
   26 c29b0710 e0457000    0     0     0 0000204 [IWAIT] irq16: ahc0
   25 c29b08d4 e047c000    0     0     0 0000204 [IWAIT] irq15: ata1
   24 c29b0a98 e047d000    0     0     0 0000204 new [IWAIT] irq14: ata0
   23 c29b0c5c e047e000    0     0     0 0000204 new [IWAIT] irq13:
   22 c29b0e20 e047f000    0     0     0 0000204 new [IWAIT] irq12: psm0
   21 c6892000 e1e82000    0     0     0 0000204 new [IWAIT] irq11:
   20 c68921c4 e1e83000    0     0     0 0000204 new [IWAIT] irq10: uhci0 uhci1
   19 c6892388 e1e84000    0     0     0 0000204 new [IWAIT] irq9: acpi0
   18 c29a7000 e0402000    0     0     0 0000204 new [IWAIT] irq8: rtc
   17 c29a71c4 e044b000    0     0     0 0000204 new [IWAIT] irq7: ppc0
   16 c29a7388 e044c000    0     0     0 0000204 [IWAIT] irq6: fdc0
   15 c29a754c e044d000    0     0     0 0000204 new [IWAIT] irq5:
   14 c29a7710 e044e000    0     0     0 0000204 new [IWAIT] irq4: sio0
   13 c29a78d4 e044f000    0     0     0 0000204 new [IWAIT] irq3: sio1
   12 c29a7a98 e0450000    0     0     0 0000204 [IWAIT] irq1: atkbd0
   11 c29a7c5c e0451000    0     0     0 000020c [CPU 0] idle: cpu0
    1 c29a7e20 e0452000    0     0     1 0004200 [SLP]thtrm 0xc694f240] init
   10 c29b0000 e0453000    0     0     0 0000204 [CV]ktrace 0xc09403c4] ktrace
    0 c093cf40 c0c1f000    0     0     0 0000200 [SLP]sched 0xc093cf40] swapper


One thing I just noticed is that I'm not seeing the "Shutting down ACPI"
message, which I think usually gets printed after the "Uptime" message.
The ACPI message gets printed by acpi_shutdown_final(), so we're not
getting all the way through the shutdown_final handlers, or maybe we're
not even getting that far.

I see that init is sleeping on thtrm, which happens in
aic_terminate_recovery_thread(), which gets called from ahc_shutdown().
It looks aic_terminate_recovery_thread() returns immediately if
aic->platform_data->recovery_thread is NULL, otherwise it sets the
AIC_SHUTDOWN_RECOVERY, calls wakeup(), and then calls tsleep(). The
wakeup appears to wake the recovery thread, which appears to loop
forever in aic_recovery_thread() until the AIC_SHUTDOWN_RECOVERY flag is
set, at which time it should wake aic_terminate_recovery_thread() and
exit.

Something that looks odd to me is that it appears that
aic_terminate_recovery_thread() can be called twice in at least one
case.  In ahc_free(), ahc_terminate_recovery_thread() is unconditionaly
called, and then depending on the init level, ahc_shutdown() may be
called.  When the recovery thread is killed,
aic->platform_data->recovery_thread does not get cleared, so if the
first call to ahc_terminate_recovery_thread() kills the recovery thread,
the second call to ahc_terminate_recovery_thread() (from ahc_shutdown())
will hang because the recovery thread will not be around to wake it up
the second time.

It looks like either ahc_terminate_recovery_thread() or
aic_recovery_thread() should clear aic->platform_data->recovery_thread
when the thread exits.





Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200312190753.hBJ7rGeF076868>