From 3708ab2594ddc5f06b4b7aad45d15712e9c90c35 Mon Sep 17 00:00:00 2001 From: phk Date: Fri, 2 May 2003 12:52:51 +0000 Subject: Use g_wither_geom() and plug memory leaks. --- sys/geom/geom_aes.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'sys/geom/geom_aes.c') diff --git a/sys/geom/geom_aes.c b/sys/geom/geom_aes.c index 95055dd..0745624 100644 --- a/sys/geom/geom_aes.c +++ b/sys/geom/geom_aes.c @@ -251,11 +251,9 @@ g_aes_orphan(struct g_consumer *cp) gp = cp->geom; sc = gp->softc; - gp->flags |= G_GEOM_WITHER; - error = cp->provider->error; - LIST_FOREACH(pp, &gp->provider, provider) - g_orphan_provider(pp, error); + g_wither_geom(gp, cp->provider->error); bzero(sc, sizeof(struct g_aes_softc)); /* destroy evidence */ + g_free(sc); return; } @@ -323,9 +321,11 @@ g_aes_taste(struct g_class *mp, struct g_provider *pp, int flags __unused) strlen(aes_magic_test))) { sc->keying = KEY_TEST; } else { + g_free(buf); g_free(sc); break; } + g_free(buf); gp->softc = sc; gp->access = g_aes_access; sc->sectorsize = sectorsize; -- cgit v1.1