Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 15 Nov 2009 11:47:28 -0500
From:      Jim Wilcoxson <prirun@gmail.com>
To:        freebsd-hackers@freebsd.org
Subject:   acl_from_text leaking memory
Message-ID:  <c5830b750911150847r3698b21ey819d4de3312ef78d@mail.gmail.com>
In-Reply-To: <c5830b750911150804i694b00aai891819242816e89c@mail.gmail.com>
References:  <c5830b750911150804i694b00aai891819242816e89c@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
I've been working on a new backup program, HashBackup, and believe I
have found a memory leak with ACLs in PCBSD/FreeBSD 7.1 and OSX
(Leopard).

acl_from_text is a function that takes a text string as input, and
returns a pointer to a malloc'd acl.  This acl is then freed with
acl_free.  I noticed that acl_from_text appears to leak memory.  This
is not used during the backup of a filesystem, but is needed to do a
restore.

After looking at the acl_from_text source in /usr/src/lib/libc/posix1e
(from PCBSD7.1), I believe the problem is that the duplicate text
string, mybuf_p, is not freed on normal return of this function.  Here
is the end of this function:

        }

#if 0
        /* XXX Should we only return ACLs valid according to acl_valid? */
        /* Verify validity of the ACL we read in. */
        if (acl_valid(acl) == -1) {
                errno = EINVAL;
                goto error_label;
        }
#endif

        return(acl);

error_label:
        acl_free(acl);
        free(mybuf_p);
        return(NULL);
}

I think there should be a free(mybuf_p) before return(acl).

Here is a PCBSD/FreeBSD test program that causes the memory leak:

#include <stdio.h>
#include <sys/types.h>
#include <sys/acl.h>

main() {
   acl_t acl;
   char* acltext;

   acltext = "user::rw-\n group::r--\n mask::r--\n other::r--\n";
   while (1) {
      acl = acl_from_text(acltext);
      if (acl == NULL)
        printf("acl_from_text failed\n");
      if (acl_free(acl) != 0)
        printf("acl_free failed\n");
  }
}

I've subscribed to the lists for a few days in case there are
questions or I can help test something.

Thanks,
Jim
--
HashBackup beta: http://sites.google.com/site/hashbackup



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?c5830b750911150847r3698b21ey819d4de3312ef78d>