Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 30 Nov 2007 03:35:18 -0500 (EST)
From:      jeff@rexdb.com
To:        "Tai-hwa Liang" <avatar@mmlab.cse.yzu.edu.tw>
Cc:        Remko Lodder <remko@freebsd.org>, FreeBSD Current <freebsd-current@freebsd.org>, kib@freebsd.org
Subject:   Re: [Fwd: Re: kern/118258 sysctl causing panics on 7.0-xxx]
Message-ID:  <28249.76.3.162.23.1196411718.squirrel@mail.rexdb.com>
In-Reply-To: <071130112653E.701@www.mmlab.cse.yzu.edu.tw>
References:  <474D81DB.7020004@FreeBSD.org> <071130112653E.701@www.mmlab.cse.yzu.edu.tw>

next in thread | previous in thread | raw e-mail | index | archive | help
> On Wed, 28 Nov 2007, Remko Lodder wrote:
>> Hello,
>>
>> So as per Jeff's information, can someone from the -current
>> list either contact jeff or try to resolve the problems
>> mentioned? :)
>
>    This is a longstanding bug which also exists in RELENG_6.  It turns out
> that 'sysctl kern.ttys' after a terminal device is removed could trigger
> this panic reliably.  For example, do 'sysctl kern.ttys' multiple times
> after detaching an USB serial-to-rs232 cable or a PCMCIA modem card.
>

Suddenly,  it all becomes quite clear.  I use umodem and ucom for my
cellphone (motorola razr v3) mostly to charge it, but occasionally to
provide my laptop with mobile connectivity.  So I add/remove a USB tty
almost every night.

My only question is:  up until recently the panic was a double panic and
hang,  with no vmcore available.  then all of a sudden it was a single
panic where savecore was actually useful.  I wonder what changed (or even
if it's the same panic)

If this is a known and longstanding bug, I'll just use a wall charger for
my cellphone, and leave everyone alone.  Thanks for the input!

Jeff

>    Alternatively, following script would demo the panic if you don't have
> a physically removable terminal device:
>
> #!/bin/sh
> #
> # Warning! Running this script as root will panic your CURRENT box...
> #
> while true; do
>  	kldload dcons
>  	kldunload dcons
>  	ls /dev
>  	sysctl kern.ttys
>  	sleep 1
> done
>
>    This seems to be a race between devfs and destroy_dev(), Cc'ing kib@
> since he probably has more clues in this area.
>
>> -------- Original Message --------
>> Subject: Re: kern/118258 sysctl causing panics on 7.0-xxx
>> Date: Wed, 28 Nov 2007 14:50:02 GMT
>> From: Jeff Palmer <jeff@rexdb.com>
>> Reply-To: Jeff Palmer <jeff@rexdb.com>
>> To: freebsd-bugs@FreeBSD.org
>>
>> The following reply was made to PR kern/118258; it has been noted by
>> GNATS.
>>
>> From: Jeff Palmer <jeff@rexdb.com>
>> To: bug-followup@freebsd.org
>> Cc:
>> Subject: Re: kern/118258 sysctl causing panics on 7.0-xxx
>> Date: Wed, 28 Nov 2007 09:28:47 -0500
>>
>> Caught another vmcore,=20
>> this time simply from 'sysctl -a'
>> This one showed debugging data from the if_wpi driver on the terminal
>> immediately before the panic.
>>
>> Since the wpi driver is in -CURRENT (and not in 7.3-BETA3) I'm uncertain
>> if this should actually be filed as a PR,  or just brought up on the
>> current@ list.
>> I'm not certain it's directly related to the wpi driver,  so until
>> informed otherwise,  I'll just keep submitting followups to this PR as I
>> can.
>>
>> Thanks,
>>
>> Jeff Palmer
>>
>>
>> Laptop# kgdb /usr/obj/usr/src/sys/GENERIC/kernel.debug
>> /var/crash/vmcore.=
>> 1
>> [GDB will not be able to debug user-mode threads:
>> /usr/lib/libthread_db.so: Undefined symbol "
>> ps_pglobal_lookup"]
>> GNU gdb 6.1.1 [FreeBSD]
>> Copyright 2004 Free Software Foundation, Inc.
>> GDB is free software, covered by the GNU General Public License, and you
>> =
>> are
>> welcome to change it and/or distribute copies of it under certain
>> conditions.
>> Type "show copying" to see the conditions.
>> There is absolutely no warranty for GDB.  Type "show warranty" for
>> detail=
>> s.
>> This GDB was configured as "i386-marcel-freebsd".
>>
>> Unread portion of the kernel message buffer:
>>
>>
>> Fatal trap 12: page fault while in kernel mode
>> cpuid =3D 1; apic id =3D 01
>> fault virtual address   =3D 0x18264
>> fault code              =3D supervisor read, page not present
>> instruction pointer     =3D 0x20:0xc06e6a11
>> stack pointer           =3D 0x28:0xe76e9aa4
>> frame pointer           =3D 0x28:0xe76e9aa4
>> code segment            =3D base 0x0, limit 0xfffff, type 0x1b
>>                         =3D DPL 0, pres 1, def32 1, gran 1
>> processor eflags        =3D interrupt enabled, resume, IOPL =3D 0
>> current process         =3D 53221 (sysctl)
>> trap number             =3D 12
>> panic: page fault
>> cpuid =3D 1
>> Uptime: 1d5h15m17s
>> Physical memory: 1001 MB
>> Dumping 210 MB: 195 179 163 147 131 115 99 83 67 51 35 19 3
>>
>> #0  doadump () at pcpu.h:195
>> 195     pcpu.h: No such file or directory.
>>         in pcpu.h
>> (kgdb) bt
>> #0  doadump () at pcpu.h:195
>> #1  0xc0750c17 in boot (howto=3D260) at
>> /usr/src/sys/kern/kern_shutdown.c=
>> :409
>> #2  0xc0750ed9 in panic (fmt=3DVariable "fmt" is not available.
>> ) at /usr/src/sys/kern/kern_shutdown.c:563
>> #3  0xc0a1542c in trap_fatal (frame=3D0xe76e9a64, eva=3D98916)
>>     at /usr/src/sys/i386/i386/trap.c:872
>> #4  0xc0a156b0 in trap_pfault (frame=3D0xe76e9a64, usermode=3D0,
>> eva=3D98=
>> 916)
>>     at /usr/src/sys/i386/i386/trap.c:785
>> #5  0xc0a16025 in trap (frame=3D0xe76e9a64) at
>> /usr/src/sys/i386/i386/trap.c:463
>> #6  0xc09fc04b in calltrap () at /usr/src/sys/i386/i386/exception.s:139
>> #7  0xc06e6a11 in dev2udev (x=3D0xc50f4b00) at
>> /usr/src/sys/fs/devfs/devfs_vnops.c:1322
>> #8  0xc0790e22 in sysctl_kern_ttys (oidp=3D0xc0b4b7e0, arg1=3D0x0,
>> arg2=3D=
>> 0,
>> req=3D0xe76e9ba4)
>>     at /usr/src/sys/kern/tty.c:3078
>> #9  0xc075a457 in sysctl_root (oidp=3DVariable "oidp" is not available.
>> ) at /usr/src/sys/kern/kern_sysctl.c:1306
>> #10 0xc075a5a4 in userland_sysctl (td=3D0xc5049210, name=3D0xe76e9c14,
>> namelen=3D2, old=3D0x0,
>>     oldlenp=3D0xbfbfe334, inkernel=3D0, new=3D0x0, newlen=3D0,
>> retval=3D0xe76e9c10, flags=3D0)
>>     at /usr/src/sys/kern/kern_sysctl.c:1401
>> #11 0xc075b33e in __sysctl (td=3D0xc5049210, uap=3D0xe76e9cfc)
>>     at /usr/src/sys/kern/kern_sysctl.c:1336
>> #12 0xc0a15a05 in syscall (frame=3D0xe76e9d38) at
>> /usr/src/sys/i386/i386/trap.c:1008
>> #13 0xc09fc0b0 in Xint0x80_syscall () at
>> /usr/src/sys/i386/i386/exception.s:196
>> #14 0x00000033 in ?? ()
>> Previous frame inner to this frame (corrupt stack?)
>> (kgdb) list
>> 196             call    syscall
>> 197             add     $4, %esp
>> 198             MEXITCOUNT
>> 199             jmp     doreti
>> 200
>> 201     ENTRY(fork_trampoline)
>> 202             pushl   %esp                    /* trapframe pointer */
>> 203             pushl   %ebx                    /* arg1 */
>> 204             pushl   %esi                    /* function */
>> 205             call    fork_exit
>> (kgdb)
> --
> Cheers,
>
> Tai-hwa Liang
> _______________________________________________
> freebsd-current@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-current
> To unsubscribe, send any mail to "freebsd-current-unsubscribe@freebsd.org"
>
> !DSPAM:8,474f8d94174311715688600!
>
>
>





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