Date: Sat, 17 May 2003 22:35:57 -0700 From: David Schultz <das@FreeBSD.ORG> To: Giorgos Keramidas <keramida@ceid.upatras.gr> Cc: current@FreeBSD.ORG Subject: Re: Panic with swap-backed md devices Message-ID: <20030518053557.GA223@HAL9000.homeunix.com> In-Reply-To: <20030514232428.GA731@gothmog.gr> References: <20030514232428.GA731@gothmog.gr>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, May 15, 2003, Giorgos Keramidas wrote:
> Trying to create and destroy a swap-backed md device results in panics
> with today's CURRENT. I was trying to make a new -t swap md disk to
> test the problem described in a PR. Using the following small shell
> script I noticed that it always causes a panic when mdconfig -d is run:
>
> mdconfig -a -t swap -s 100m -u 10
> disklabel -r -w md10 auto
> newfs -O 1 -b 8192 -s 1024 md10
> mount /dev/md10 /mnt
> mount
> umount /mnt
> mount
> mdconfig -d -u 10
The following patch should fix the panic, but there's a small
vm_object leak that's still unfixed. I'll look into that.
Index: sys/dev/md/md.c
===================================================================
RCS file: /cvs/src/sys/dev/md/md.c,v
retrieving revision 1.98
diff -u -r1.98 md.c
--- sys/dev/md/md.c 2 May 2003 06:18:58 -0000 1.98
+++ sys/dev/md/md.c 18 May 2003 04:04:23 -0000
@@ -932,7 +932,9 @@
if (sc->cred != NULL)
crfree(sc->cred);
if (sc->object != NULL) {
+ VM_OBJECT_LOCK(sc->object);
vm_pager_deallocate(sc->object);
+ VM_OBJECT_UNLOCK(sc->object);
}
if (sc->indir)
destroy_indir(sc, sc->indir);
@@ -990,7 +992,9 @@
sc->flags = mdio->md_options & MD_FORCE;
if (mdio->md_options & MD_RESERVE) {
if (swap_pager_reserve(sc->object, 0, sc->nsect) < 0) {
+ VM_OBJECT_LOCK(sc->object);
vm_pager_deallocate(sc->object);
+ VM_OBJECT_UNLOCK(sc->object);
sc->object = NULL;
mddestroy(sc, td);
return (EDOM);
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030518053557.GA223>
