From owner-freebsd-hackers Wed Apr 3 21:33: 3 2002 Delivered-To: freebsd-hackers@freebsd.org Received: from falcon.prod.itd.earthlink.net (falcon.mail.pas.earthlink.net [207.217.120.74]) by hub.freebsd.org (Postfix) with ESMTP id 385C937B400 for ; Wed, 3 Apr 2002 21:32:57 -0800 (PST) Received: from pool0127.cvx40-bradley.dialup.earthlink.net ([216.244.42.127] helo=mindspring.com) by falcon.prod.itd.earthlink.net with esmtp (Exim 3.33 #1) id 16szrh-0003ET-00; Wed, 03 Apr 2002 21:32:53 -0800 Message-ID: <3CABE569.D0560F0C@mindspring.com> Date: Wed, 03 Apr 2002 21:32:25 -0800 From: Terry Lambert X-Mailer: Mozilla 4.7 [en]C-CCK-MCD {Sony} (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: David Greenman Cc: Will Froning , hackers@freebsd.org Subject: Re: Fatal trap 12: page fault while in kernel mode References: <20020403181854.I42720-100000@angui.sh> <20020403200327.B7095@nexus.root.com> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG David Greenman wrote: > >#16 0xc0152220 in tsleep () > >#17 0xc016abfe in m_clalloc_wait () > >#18 0xc01c8b14 in nfs_realign () > >#19 0xc01c9653 in nfsrv_rcv () > >#20 0xc01701d0 in sowakeup () > >#21 0xc01abd7c in udp_input () > >#22 0xc01a1bfb in ip_input () > >#23 0xc01a1c5b in ipintr () > > This is basically telling you that there is a bug in the NFS code that is > incorrectly trying to do a "wait" type of allocation in an interrupt context, > which is not valid. You can't sleep when there is no process context. Amusing. Then the fix is probably to take the proc pointer of the proc whose socket is being used to do the call, which is the third argument to nfssvc_addsock(), and put it into the structure pointed to by "struct nfssvc_sock *" as the argument to the upcall. Then, in the upcall code in nfsrv_rcv(), pass the proc pointer down as the process context. I think, actually, that multiple sleeps by the same process are also disallowed (;^)), so probably... You will need to modify nfs_realign() to take a waitflag, as propagated from nfsrv_rcv()... and then pass it through on the MCLGET and the MGET, to make sure that if the alloc fails, that it's OK. This does point out a problem in MCLGET() (the macro that wraps m_clalloc_wait()) wanting a process context. Probably, the best thing would be to pass a proc p in, and if it's NULL, just imply no wait semantics. What an ugly mess... -- Terry To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message