summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard W.M. Jones <rjones@redhat.com>2011-03-22 11:20:38 +0000
committerRichard W.M. Jones <rjones@redhat.com>2011-03-22 11:26:34 +0000
commitd06fee159c14d4fe7654a02bae8849c4f82565f8 (patch)
treec20cbac89e67d1e6839e3f1162fa4aca941f4fe7
parent5776c145d411e5ae00072ecf422055f3d0bd29e2 (diff)
downloadlibguestfs-d06fee159c14d4fe7654a02bae8849c4f82565f8.tar.gz
libguestfs-d06fee159c14d4fe7654a02bae8849c4f82565f8.tar.xz
libguestfs-d06fee159c14d4fe7654a02bae8849c4f82565f8.zip
inspect: Don't fail for Windows guests with multiple disks (RHBZ#674130).
Notes
Notes: Labels: bugfix, RHBZ#674130 Depends: 5776c145d411e5ae00072ecf422055f3d0bd29e2
-rw-r--r--src/guestfs-internal.h2
-rw-r--r--src/inspect.c15
2 files changed, 15 insertions, 2 deletions
diff --git a/src/guestfs-internal.h b/src/guestfs-internal.h
index ccc5bb5f..d0dcf235 100644
--- a/src/guestfs-internal.h
+++ b/src/guestfs-internal.h
@@ -173,6 +173,8 @@ enum inspect_fs_content {
FS_CONTENT_UNKNOWN = 0,
FS_CONTENT_LINUX_ROOT,
FS_CONTENT_WINDOWS_ROOT,
+ FS_CONTENT_WINDOWS_VOLUME_WITH_APPS,
+ FS_CONTENT_WINDOWS_VOLUME,
FS_CONTENT_LINUX_BOOT,
FS_CONTENT_LINUX_USR,
FS_CONTENT_LINUX_USR_LOCAL,
diff --git a/src/inspect.c b/src/inspect.c
index 20e88068..1129a53d 100644
--- a/src/inspect.c
+++ b/src/inspect.c
@@ -366,9 +366,13 @@ check_filesystem (guestfs_h *g, const char *device,
guestfs_is_dir (g, "/run") > 0 &&
guestfs_is_dir (g, "/spool") > 0)
fs->content = FS_CONTENT_LINUX_VAR;
- /* Windows root? */
+ /* Windows root?
+ * Note that if a Windows guest has multiple disks and applications
+ * are installed on those other disks, then those other disks will
+ * contain "/Program Files" and "/System Volume Information". Those
+ * would *not* be Windows root disks. (RHBZ#674130)
+ */
else if (is_file_nocase (g, "/AUTOEXEC.BAT") > 0 ||
- is_dir_nocase (g, "/Program Files") > 0 ||
is_dir_nocase (g, "/WINDOWS") > 0 ||
is_dir_nocase (g, "/WIN32") > 0 ||
is_dir_nocase (g, "/WINNT") > 0 ||
@@ -380,6 +384,13 @@ check_filesystem (guestfs_h *g, const char *device,
if (check_windows_root (g, fs) == -1)
return -1;
}
+ /* Windows volume with installed applications (but not root)? */
+ else if (is_dir_nocase (g, "/System Volume Information") > 0 &&
+ is_dir_nocase (g, "/Program Files") > 0)
+ fs->content = FS_CONTENT_WINDOWS_VOLUME_WITH_APPS;
+ /* Windows volume (but not root)? */
+ else if (is_dir_nocase (g, "/System Volume Information") > 0)
+ fs->content = FS_CONTENT_WINDOWS_VOLUME;
/* Install CD/disk? Skip these checks if it's not a whole device
* (eg. CD) or the first partition (eg. bootable USB key).
*/