diff options
author | Richard Jones <rjones@centos5x32.home.annexia.org> | 2009-07-03 00:22:14 +0100 |
---|---|---|
committer | Richard Jones <rjones@centos5x32.home.annexia.org> | 2009-07-03 00:22:14 +0100 |
commit | 6fb57e430c8daa06d8d938ac02a104c8aadbbda5 (patch) | |
tree | 38586363a6a7d68e5559347d1cc7671593c81aed /daemon/mount.c | |
parent | b7e094fa14b306fe776b9b2695cf82fa32d4923f (diff) | |
parent | ee4c49fad5a3e36c6e909ab90bcb7d719c9395b3 (diff) | |
download | libguestfs-6fb57e430c8daa06d8d938ac02a104c8aadbbda5.tar.gz libguestfs-6fb57e430c8daa06d8d938ac02a104c8aadbbda5.tar.xz libguestfs-6fb57e430c8daa06d8d938ac02a104c8aadbbda5.zip |
Merge branch 'master' of git+ssh://192.168.122.1/home/rjones/d/libguestfs
Diffstat (limited to 'daemon/mount.c')
-rw-r--r-- | daemon/mount.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/daemon/mount.c b/daemon/mount.c index 4955fcf3..b0cb496e 100644 --- a/daemon/mount.c +++ b/daemon/mount.c @@ -71,6 +71,7 @@ do_mount_vfs (char *options, char *vfstype, else r = command (NULL, &error, "mount", "-o", options, device, mp, NULL); + free (mp); if (r == -1) { reply_with_error ("mount: %s on %s: %s", device, mountpoint, error); free (error); @@ -277,3 +278,47 @@ do_umount_all (void) return 0; } + +/* Mount using the loopback device. You can't use the generic + * do_mount call for this because the first parameter isn't a + * device. + */ +int +do_mount_loop (char *file, char *mountpoint) +{ + int len, r; + char *buf, *mp; + char *error; + + NEED_ROOT (-1); + ABS_PATH (file, -1); + + /* We have to prefix /sysroot on both the filename and the mountpoint. */ + len = strlen (mountpoint) + 9; + mp = malloc (len); + if (!mp) { + reply_with_perror ("malloc"); + return -1; + } + snprintf (mp, len, "/sysroot%s", mountpoint); + + len = strlen (file) + 9; + buf = malloc (len); + if (!file) { + reply_with_perror ("malloc"); + free (mp); + return -1; + } + snprintf (buf, len, "/sysroot%s", file); + + r = command (NULL, &error, "mount", "-o", "loop", buf, mp, NULL); + free (mp); + free (buf); + if (r == -1) { + reply_with_error ("mount: %s on %s: %s", file, mountpoint, error); + free (error); + return -1; + } + + return 0; +} |