summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKarel Zak2012-01-02 14:16:15 +0100
committerKarel Zak2012-01-02 14:16:15 +0100
commit16b8db49fee91417aad09aaa98edd3acd9e70754 (patch)
treebd94b3b002967ce63d8e375a8ad5a39542e08b11
parentlibmount: always trust the source of a pseudofs (diff)
downloadkernel-qcow2-util-linux-16b8db49fee91417aad09aaa98edd3acd9e70754.tar.gz
kernel-qcow2-util-linux-16b8db49fee91417aad09aaa98edd3acd9e70754.tar.xz
kernel-qcow2-util-linux-16b8db49fee91417aad09aaa98edd3acd9e70754.zip
libmount; fix possible mem-leak
Signed-off-by: Karel Zak <kzak@redhat.com>
-rw-r--r--libmount/src/fs.c6
-rw-r--r--libmount/src/tab.c23
2 files changed, 20 insertions, 9 deletions
diff --git a/libmount/src/fs.c b/libmount/src/fs.c
index 26560d161..90f484bec 100644
--- a/libmount/src/fs.c
+++ b/libmount/src/fs.c
@@ -1081,7 +1081,8 @@ int mnt_fs_get_attribute(struct libmnt_fs *fs, const char *name,
*
* Returns: 1 if @fs target is equal to @target else 0.
*/
-int mnt_fs_match_target(struct libmnt_fs *fs, const char *target, struct libmnt_cache *cache)
+int mnt_fs_match_target(struct libmnt_fs *fs, const char *target,
+ struct libmnt_cache *cache)
{
int rc = 0;
@@ -1127,7 +1128,8 @@ int mnt_fs_match_target(struct libmnt_fs *fs, const char *target, struct libmnt_
*
* Returns: 1 if @fs source is equal to @source else 0.
*/
-int mnt_fs_match_source(struct libmnt_fs *fs, const char *source, struct libmnt_cache *cache)
+int mnt_fs_match_source(struct libmnt_fs *fs, const char *source,
+ struct libmnt_cache *cache)
{
char *cn;
const char *src, *t, *v;
diff --git a/libmount/src/tab.c b/libmount/src/tab.c
index 8b708112d..15e20f8f6 100644
--- a/libmount/src/tab.c
+++ b/libmount/src/tab.c
@@ -731,19 +731,23 @@ struct libmnt_fs *mnt_table_get_fs_root(struct libmnt_table *tb,
if (tb && (mountflags & MS_BIND)) {
const char *src, *src_root;
+ char *xsrc = NULL;
DBG(TAB, mnt_debug("fs-root for bind"));
- src = mnt_resolve_spec(mnt_fs_get_source(fs), tb->cache);
- if (!src)
- goto err;
+ src = xsrc = mnt_resolve_spec(mnt_fs_get_source(fs), tb->cache);
+ if (src)
+ mnt = mnt_get_mountpoint(src);
+ if (mnt)
+ root = mnt_get_fs_root(src, mnt);
- mnt = mnt_get_mountpoint(src);
+ if (xsrc && !tb->cache) {
+ free(xsrc);
+ src = NULL;
+ }
if (!mnt)
goto err;
- root = mnt_get_fs_root(src, mnt);
-
src_fs = mnt_table_find_target(tb, mnt, MNT_ITER_BACKWARD);
if (!src_fs) {
DBG(TAB, mnt_debug("not found '%s' in mountinfo -- using default", mnt));
@@ -827,6 +831,7 @@ int mnt_table_is_fs_mounted(struct libmnt_table *tb, struct libmnt_fs *fstab_fs)
char *root = NULL;
struct libmnt_fs *src_fs;
const char *src, *tgt;
+ char *xsrc;
int flags = 0, rc = 0;
assert(tb);
@@ -844,7 +849,8 @@ int mnt_table_is_fs_mounted(struct libmnt_table *tb, struct libmnt_fs *fstab_fs)
else if (fstab_fs->flags & MNT_FS_PSEUDO)
src = mnt_fs_get_source(fstab_fs);
else
- src = mnt_resolve_spec(mnt_fs_get_source(fstab_fs), tb->cache);
+ src = xsrc = mnt_resolve_spec(mnt_fs_get_source(fstab_fs),
+ tb->cache);
tgt = mnt_fs_get_target(fstab_fs);
@@ -873,6 +879,9 @@ int mnt_table_is_fs_mounted(struct libmnt_table *tb, struct libmnt_fs *fstab_fs)
rc = 1; /* success */
}
+ if (xsrc && !tb->cache)
+ free(xsrc);
+
free(root);
return rc;
}