diff options
author | Alexander Graf <agraf@suse.de> | 2012-12-12 19:11:30 +0100 |
---|---|---|
committer | Junfeng Dong <junfeng.dong@intel.com> | 2013-11-19 18:57:38 +0800 |
commit | 358da53a4ccfdab10856928a2fc63c0b825134f2 (patch) | |
tree | d9f43aac82cd9187cd98fc130c105237e28d4545 | |
parent | b3ac76e1e06186321251741807dd4413c3ccfedc (diff) | |
download | qemu-358da53a4ccfdab10856928a2fc63c0b825134f2.tar.gz qemu-358da53a4ccfdab10856928a2fc63c0b825134f2.tar.bz2 qemu-358da53a4ccfdab10856928a2fc63c0b825134f2.zip |
Legacy Patch kvm-qemu-preXX-dictzip3.patch
-rw-r--r-- | block/tar.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/block/tar.c b/block/tar.c index 87bf55261..bf24c98ff 100644 --- a/block/tar.c +++ b/block/tar.c @@ -83,7 +83,8 @@ static int str_ends(char *str, const char *end) return !strncmp(str + str_len - end_len, end, end_len); } -static int is_target_file(BlockDriverState *bs, char *filename) +static int is_target_file(BlockDriverState *bs, char *filename, + char *header) { int retval = 0; @@ -99,10 +100,17 @@ static int is_target_file(BlockDriverState *bs, char *filename) if (str_ends(filename, ".vmdk")) retval = 1; + if (retval && + (header[OFFS_TYPE] != '0') && + (header[OFFS_TYPE] != 'S')) { + retval = 0; + } + dprintf("does filename %s match? %s\n", filename, retval ? "yes" : "no"); /* make sure we're not using this name again */ filename[0] = '\0'; + return retval; } @@ -229,12 +237,13 @@ static int tar_open(BlockDriverState *bs, QDict *options, int flags) bdrv_pread(s->hd, header_offs - s->file_len, s->longfile, sizeof(s->longfile)); s->longfile[sizeof(s->longfile)-1] = '\0'; + real_file = header; } else if (s->longfile[0]) { real_file = s->longfile; } else { real_file = header; } - } while(!is_target_file(bs, real_file)); + } while(!is_target_file(bs, real_file, header)); /* We found an image! */ |