From owner-freebsd-hackers Tue Feb 9 10:42:40 1999 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id KAA20666 for freebsd-hackers-outgoing; Tue, 9 Feb 1999 10:42:40 -0800 (PST) (envelope-from owner-freebsd-hackers@FreeBSD.ORG) Received: from alpo.whistle.com (alpo.whistle.com [207.76.204.38]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id KAA20660 for ; Tue, 9 Feb 1999 10:42:39 -0800 (PST) (envelope-from julian@whistle.com) Received: (from daemon@localhost) by alpo.whistle.com (8.8.5/8.8.5) id KAA02814; Tue, 9 Feb 1999 10:38:02 -0800 (PST) Received: from current1.whistle.com(207.76.205.22) via SMTP by alpo.whistle.com, id smtpdqN2805; Tue Feb 9 18:37:54 1999 Date: Tue, 9 Feb 1999 10:37:46 -0800 (PST) From: Julian Elischer To: Larry Lile cc: hackers@FreeBSD.ORG Subject: Re: Why did this panic? In-Reply-To: Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Content-Transfer-Encoding: 8bit X-MIME-Autoconverted: from QUOTED-PRINTABLE to 8bit by hub.freebsd.org id KAA20661 Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG ah yes that's what I want.. mclfree is garbage.... exactly liek we saw on our mystery crash This indicates that an mbuf cluster was used after it was freed, or it was allocated to two differnt users. that's exactly what we saw. What version EXACTLY (date etc) of FreeBSD? tell me.. what protocols are compiled in? and what netowrking drivers and what machines are on your nets (specifically, do you have MACS and the netatalk code compiled in? On Tue, 9 Feb 1999, Larry Lile wrote: > > Is this what you were looking for? > > (kgdb) print *m0 > $4 = {m_hdr = {mh_next = 0x0, mh_nextpkt = 0x0, mh_data = 0xf0756a20 "(rc=", > mh_len = 40, mh_type = 1, mh_flags = 2}, M_dat = {MH = {MH_pkthdr = { > rcvif = 0x0, len = 1492, header = 0x4000000}, MH_dat = {MH_ext = { > ext_buf = 0x3d637228
, > ext_free = 0, ext_size = 2048, ext_ref = 0}, > MH_databuf = "(rc=\000\000\000\000\000\b\000\000\000\000\000\000E\b\005Ô1º@\000@\006ï_\n\000\000\001\n\000\000\002\000\024\004\r\t\211ô¾\013ø¶\002P\020D\020Z²\000\000sap f4 ui/C len=\020@\020\000Z±Åì\000\000\203/íªª\003\000\000\000\b\000le"}}, > M_databuf = "\000\000\000\000Ô\005\000\000\000\000\000\004(rc=\000\000\000\000\000\b\000\000\000\000\000\000E\b\005Ô1º@\000@\006ï_\n\000\000\001\n\000\000\002\000\024\004\r\t\211ô¾\013ø¶\002P\020D\020Z²\000\000sap f4 ui/C len=\020@\020\000Z±Åì\000\000\203/íªª\003\000\000\000\b\000le"}} > > (kgdb) print m0.M_dat.MH.MH_dat.MH_ext > $6 = {ext_buf = 0x3d637228
, ext_free = 0, > ext_size = 2048, ext_ref = 0} > > (kgdb) print ((union mcluster *)(m0.M_dat.MH.MH_dat.MH_ext.ext_buf))->mcl_next > Cannot access memory at address 0x3d637228. > > or more to the point: > > (kgdb) print mclfree > $8 = (union mcluster *) 0x3d637228 *blam* Somethings not freeing mbuf clusters correctly. > (kgdb) print *mclfree > Cannot access memory at address 0x3d637228. > (kgdb) > > Or am I misenterpreting MCLGET/MCLALLOC? > > I must have missed the messages about this, was it fixed? > > Larry Lile > lile@stdio.com > > On Tue, 9 Feb 1999, Julian Elischer wrote: > > > I think We saw this last week.. > > it crashed on MCLGET.. > > what is the pointer to the next free mbuf cluster? > > (not the next mbuf) (check the MCLGET macro to see what I mean) > > > > > > On Tue, 9 Feb 1999, Larry Lile wrote: > > > > > > > > I am working on improving the mtu sizes (above 1500) for the Olicom > > > token ring driver but I just ran across this panic that I really > > > don't understand. Any ideas? > > > > > > Larry Lile > > > lile@stdio.com > > > > > > > > > Fatal trap 12: page fault while in kernel mode > > > fault virtual address = 0xf07eddc2 > > > fault code = supervisor write, page not present > > > instruction pointer = 0x8:0xf02096ff > > > stack pointer = 0x10:0xf6829cdc > > > frame pointer = 0x10:0xf6829d14 > > > code segment = base 0x0, limit 0xfffff, type 0x1b > > > = DPL 0, pres 1, def32 1, gran 1 > > > processor eflags = interrupt enabled, resume, IOPL = 0 > > > current process = 352 (ftpd) > > > interrupt mask = net > > > trap number = 12 > > > panic: page fault > > > > > > syncing disks... 7 7 done > > > > > > dumping to dev 20419, offset 761856 > > > dump 128 127 126 125 124 123 122 121 120 119 118 117 116 115 114 113 112 111 110 109 108 107 106 105 104 103 102 101 100 99 98 97 96 95 94 93 92 91 90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 > > > --- > > > #0 boot (howto=256) at ../../kern/kern_shutdown.c:285 > > > 285 dumppcb.pcb_cr3 = rcr3(); > > > (kgdb) bt > > > #0 boot (howto=256) at ../../kern/kern_shutdown.c:285 > > > #1 0xf013f55d in panic (fmt=0xf023f25b "page fault") > > > at ../../kern/kern_shutdown.c:446 > > > #2 0xf02024da in trap_fatal (frame=0xf6829ca0, eva=4034846146) > > > at ../../i386/i386/trap.c:942 > > > #3 0xf0202193 in trap_pfault (frame=0xf6829ca0, usermode=0, eva=4034846146) > > > at ../../i386/i386/trap.c:835 > > > #4 0xf0201daa in trap (frame={tf_es = 16, tf_ds = 16, tf_edi = -260740608, > > > tf_esi = -260740576, tf_ebp = -159212268, tf_isp = -159212344, > > > tf_ebx = -1073314688, tf_edx = 630210, tf_ecx = -265747636, > > > tf_eax = -260751360, tf_trapno = 12, tf_err = 2, tf_eip = -266299649, > > > tf_cs = 8, tf_eflags = 66066, tf_esp = -250238026, tf_ss = -250238028}) > > > at ../../i386/i386/trap.c:437 > > > #5 0xf02096ff in DriverReceiveFrameCompleted (DriverHandle=0x1, > > > ByteCount=1514, FragmentCount=1, FragmentHandle=0x9, ReceiveStatus=0) > > > at ../../i386/isa/if_oltr.c:1236 > > > #6 0xf0210acc in ReturnCompletedBuffers () > > > #7 0x631000 in ?? () > > > #8 0xecc5b15a in ?? () > > > Cannot access memory at address 0x104018. > > > (kgdb) up 5 > > > #5 0xf02096ff in DriverReceiveFrameCompleted (DriverHandle=0x1, > > > ByteCount=1514, FragmentCount=1, FragmentHandle=0x9, ReceiveStatus=0) > > > at ../../i386/isa/if_oltr.c:1236 > > > 1236 MCLGET(m0, M_DONTWAIT); > > > (kgdb) print m0 > > > $1 = (struct mbuf *) 0xf0756a00 > > > (kgdb) list > > > 1231 if (m0 == NULL) { > > > 1232 ifp->if_ierrors++; > > > 1233 goto out; > > > 1234 } > > > 1235 if (ByteCount + 2 > MHLEN) { > > > 1236 MCLGET(m0, M_DONTWAIT); > > > 1237 mbuf_size = MCLBYTES; > > > 1238 if ((m0->m_flags & M_EXT) == 0) { > > > 1239 m_freem(m0); > > > 1240 ifp->if_ierrors++; > > > (kgdb) print mbstat > > > $3 = {m_mbufs = 128, m_clusters = 100, m_spare = 0, m_clfree = 27, > > > m_drops = 0, m_wait = 0, m_drain = 0, m_mtypes = {65453, 79, 4, > > > 0 }, m_mcfail = 0, m_mpfail = 0, m_msize = 128, > > > m_mclbytes = 2048, m_minclsize = 204, m_mlen = 108, m_mhlen = 96} > > > (kgdb) print *m0 > > > $4 = {m_hdr = {mh_next = 0x0, mh_nextpkt = 0x0, mh_data = 0xf0756a20 "(rc=", > > > mh_len = 40, mh_type = 1, mh_flags = 2}, M_dat = {MH = {MH_pkthdr = { > > > rcvif = 0x0, len = 1492, header = 0x4000000}, MH_dat = {MH_ext = { > > > ext_buf = 0x3d637228
, > > > ext_free = 0, ext_size = 2048, ext_ref = 0}, > > > MH_databuf = "(rc=\000\000\000\000\000\b\000\000\000\000\000\000E\b\005Ô1º@\000@\006ï_\n\000\000\001\n\000\000\002\000\024\004\r\t\211ô¾\013ø¶\002P\020D\020Z²\000\000sap f4 ui/C len=\020@\020\000Z±Åì\000\000\203/íªª\003\000\000\000\b\000le"}}, > > > M_databuf = "\000\000\000\000Ô\005\000\000\000\000\000\004(rc=\000\000\000\000\000\b\000\000\000\000\000\000E\b\005Ô1º@\000@\006ï_\n\000\000\001\n\000\000\002\000\024\004\r\t\211ô¾\013ø¶\002P\020D\020Z²\000\000sap f4 ui/C len=\020@\020\000Z±Åì\000\000\203/íªª\003\000\000\000\b\000le"}} > > > (kgdb) > > > > > > > > > To Unsubscribe: send mail to majordomo@FreeBSD.org > > > with "unsubscribe freebsd-hackers" in the body of the message > > > > > > > > > To Unsubscribe: send mail to majordomo@FreeBSD.org > > with "unsubscribe freebsd-hackers" in the body of the message > > > > To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message