Legacy Patch kvm-qemu-preXX-dictzip3.patch
This commit is contained in:
committed by
Andreas Färber
parent
6b8c388560
commit
36f1cdefb3
13
block/tar.c
13
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);
|
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;
|
int retval = 0;
|
||||||
|
|
||||||
@@ -99,10 +100,17 @@ static int is_target_file(BlockDriverState *bs, char *filename)
|
|||||||
if (str_ends(filename, ".vmdk"))
|
if (str_ends(filename, ".vmdk"))
|
||||||
retval = 1;
|
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");
|
dprintf("does filename %s match? %s\n", filename, retval ? "yes" : "no");
|
||||||
|
|
||||||
/* make sure we're not using this name again */
|
/* make sure we're not using this name again */
|
||||||
filename[0] = '\0';
|
filename[0] = '\0';
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -229,12 +237,13 @@ static int tar_open(BlockDriverState *bs, QDict *options, int flags, Error **err
|
|||||||
bdrv_pread(s->hd, header_offs - s->file_len, s->longfile,
|
bdrv_pread(s->hd, header_offs - s->file_len, s->longfile,
|
||||||
sizeof(s->longfile));
|
sizeof(s->longfile));
|
||||||
s->longfile[sizeof(s->longfile)-1] = '\0';
|
s->longfile[sizeof(s->longfile)-1] = '\0';
|
||||||
|
real_file = header;
|
||||||
} else if (s->longfile[0]) {
|
} else if (s->longfile[0]) {
|
||||||
real_file = s->longfile;
|
real_file = s->longfile;
|
||||||
} else {
|
} else {
|
||||||
real_file = header;
|
real_file = header;
|
||||||
}
|
}
|
||||||
} while(!is_target_file(bs, real_file));
|
} while(!is_target_file(bs, real_file, header));
|
||||||
|
|
||||||
/* We found an image! */
|
/* We found an image! */
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user