svn commit: r220529 - stable/8/sys/geom/eli
Mikolaj Golub
trociny at FreeBSD.org
Sun Apr 10 19:31:01 UTC 2011
Author: trociny
Date: Sun Apr 10 19:31:00 2011
New Revision: 220529
URL: http://svn.freebsd.org/changeset/base/220529
Log:
MFC r220299:
In g_eli_read_done() and g_eli_write_done(), for a bio with
bio_children > 1, g_destroy_bio() is never called and the bio
leaks. Fix this by calling g_destroy_bio() earlier, before the check.
Submitted by: Victor Balada Diaz <victor at bsdes.net> (initial version)
Approved by: pjd (mentor)
Modified:
stable/8/sys/geom/eli/g_eli.c
Directory Properties:
stable/8/sys/ (props changed)
stable/8/sys/amd64/include/xen/ (props changed)
stable/8/sys/cddl/contrib/opensolaris/ (props changed)
stable/8/sys/contrib/dev/acpica/ (props changed)
stable/8/sys/contrib/pf/ (props changed)
Modified: stable/8/sys/geom/eli/g_eli.c
==============================================================================
--- stable/8/sys/geom/eli/g_eli.c Sun Apr 10 18:36:24 2011 (r220528)
+++ stable/8/sys/geom/eli/g_eli.c Sun Apr 10 19:31:00 2011 (r220529)
@@ -160,13 +160,13 @@ g_eli_read_done(struct bio *bp)
pbp = bp->bio_parent;
if (pbp->bio_error == 0)
pbp->bio_error = bp->bio_error;
+ g_destroy_bio(bp);
/*
* Do we have all sectors already?
*/
pbp->bio_inbed++;
if (pbp->bio_inbed < pbp->bio_children)
return;
- g_destroy_bio(bp);
sc = pbp->bio_to->geom->softc;
if (pbp->bio_error != 0) {
G_ELI_LOGREQ(0, pbp, "%s() failed", __func__);
@@ -202,6 +202,7 @@ g_eli_write_done(struct bio *bp)
if (bp->bio_error != 0)
pbp->bio_error = bp->bio_error;
}
+ g_destroy_bio(bp);
/*
* Do we have all sectors already?
*/
@@ -215,7 +216,6 @@ g_eli_write_done(struct bio *bp)
pbp->bio_error);
pbp->bio_completed = 0;
}
- g_destroy_bio(bp);
/*
* Write is finished, send it up.
*/
More information about the svn-src-all
mailing list