From owner-freebsd-bugs Sun Dec 30 6: 0:13 2001 Delivered-To: freebsd-bugs@hub.freebsd.org Received: from freefall.freebsd.org (freefall.FreeBSD.org [216.136.204.21]) by hub.freebsd.org (Postfix) with ESMTP id 59EF237B417 for ; Sun, 30 Dec 2001 06:00:01 -0800 (PST) Received: (from gnats@localhost) by freefall.freebsd.org (8.11.6/8.11.6) id fBUE01S89121; Sun, 30 Dec 2001 06:00:01 -0800 (PST) (envelope-from gnats) Received: from freefall.freebsd.org (freefall.FreeBSD.org [216.136.204.21]) by hub.freebsd.org (Postfix) with ESMTP id 81B7437B416 for ; Sun, 30 Dec 2001 05:59:50 -0800 (PST) Received: (from nobody@localhost) by freefall.freebsd.org (8.11.6/8.11.6) id fBUDxoI89069; Sun, 30 Dec 2001 05:59:50 -0800 (PST) (envelope-from nobody) Message-Id: <200112301359.fBUDxoI89069@freefall.freebsd.org> Date: Sun, 30 Dec 2001 05:59:50 -0800 (PST) From: David Xu To: freebsd-gnats-submit@FreeBSD.org X-Send-Pr-Version: www-1.0 Subject: kern/33344: memory leak in device resource config load Sender: owner-freebsd-bugs@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.org >Number: 33344 >Category: kern >Synopsis: memory leak in device resource config load >Confidential: no >Severity: serious >Priority: high >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: sw-bug >Submitter-Id: current-users >Arrival-Date: Sun Dec 30 06:00:01 PST 2001 >Closed-Date: >Last-Modified: >Originator: David Xu >Release: FreeBSD 4.5 prerelease >Organization: viasoft.com.cn >Environment: FreeBSD slim.viasoft.com.cn 4.5-PRERELEASE FreeBSD 4.5-PRERELEASE #2: Sun Dec 30 21:00:32 CST 2001 root@slim.viasoft.com.cn:/p3/src/sys/compile/xu i386 >Description: in file /sys/kern/subr_bus.c, there are memory leak when kernel initializes config_devtab resources. the bug is in resource_new_name(). >How-To-Repeat: >Fix: --- subr_bus.c.orig Sun Dec 30 20:49:12 2001 +++ subr_bus.c Sun Dec 30 20:59:43 2001 @@ -1381,6 +1381,8 @@ new[devtab_count].unit = unit; new[devtab_count].resource_count = 0; new[devtab_count].resources = NULL; + if (devtab && devtab != config_devtab) + free(devtab, M_TEMP); devtab = new; return devtab_count++; } >Release-Note: >Audit-Trail: >Unformatted: To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-bugs" in the body of the message