From nobody@FreeBSD.ORG Wed May 19 05:39:06 1999
Return-Path: <nobody@FreeBSD.ORG>
Received: by hub.freebsd.org (Postfix, from userid 32767)
	id 1E72814EA6; Wed, 19 May 1999 05:39:06 -0700 (PDT)
Message-Id: <19990519123906.1E72814EA6@hub.freebsd.org>
Date: Wed, 19 May 1999 05:39:06 -0700 (PDT)
From: lha@stacken.kth.se
Sender: nobody@FreeBSD.ORG
To: freebsd-gnats-submit@freebsd.org
Subject: kernel panic in module_release
X-Send-Pr-Version: www-1.0

>Number:         11779
>Category:       kern
>Synopsis:       kernel panic in module_release
>Confidential:   no
>Severity:       critical
>Priority:       high
>Responsible:    freebsd-bugs
>State:          closed
>Quarter:        
>Keywords:       
>Date-Required:  
>Class:          sw-bug
>Submitter-Id:   current-users
>Arrival-Date:   Wed May 19 05:40:00 PDT 1999
>Closed-Date:    Fri May 21 19:31:48 PDT 1999
>Last-Modified:  Fri May 21 19:32:30 PDT 1999
>Originator:     Love
>Release:        current
>Organization:
Stacken
>Environment:
FreeBSD mulet.e.kth.se 4.0-CURRENT FreeBSD 4.0-CURRENT #2: Wed May 19 14:26:24 CEST 1999     root@mulet.e.kth.se:/usr/src/sys/compile/MULET  i386

>Description:
page fault in module_release when doing a kld_unload

The pagefault is in the last TAILQ_REMOVE in module_release (kern/kern_module.c:1.17)

stacktrace:
  module_release
  linker_file_unload
  kld_unload
  syscall

>How-To-Repeat:
load and unload a kld
>Fix:
The following patch seams to fix the bug, and this code was
remove in patch kern/kern_module.c: 1.16 to 1.17 by peter

--- kern_module.c.old   Wed May 19 14:08:25 1999
+++ kern_module.c       Wed May 19 14:16:08 1999
@@ -136,6 +136,7 @@
        container = linker_current_file;
     if (container)
        TAILQ_INSERT_TAIL(&container->modules, newmod, flink);
+    newmod->file = container;
 
     return 0;
 }


>Release-Note:
>Audit-Trail:
State-Changed-From-To: open->closed 
State-Changed-By: peter 
State-Changed-When: Fri May 21 19:31:48 PDT 1999 
State-Changed-Why:  
Suggested fix applied in rev 1.18 of kern_module.c, thanks! (blush!) 
>Unformatted:
