*
* 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;
*
* 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;
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));
char *root = NULL;
struct libmnt_fs *src_fs;
const char *src, *tgt;
+ char *xsrc;
int flags = 0, rc = 0;
assert(tb);
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);
rc = 1; /* success */
}
+ if (xsrc && !tb->cache)
+ free(xsrc);
+
free(root);
return rc;
}