aboutsummaryrefslogtreecommitdiff
path: root/hw/ide.c
diff options
context:
space:
mode:
authorbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>2008-02-03 03:37:46 +0000
committerbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>2008-02-03 03:37:46 +0000
commitc717d8bf13d4c24372c4885eefa821ec76378d2b (patch)
tree31eab27985fe9f8e48fc03e58921043671d29bfd /hw/ide.c
parent7241f532c3adbebfc8689b878aec3f244043d147 (diff)
Simplify guess_disk_lchs - should fix Windows stack corruption spotted by TeLeMan (patch by Tristan Gingold).
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3953 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'hw/ide.c')
-rw-r--r--hw/ide.c9
1 files changed, 1 insertions, 8 deletions
diff --git a/hw/ide.c b/hw/ide.c
index 0e883b3b91..25f5b9f8e8 100644
--- a/hw/ide.c
+++ b/hw/ide.c
@@ -2474,22 +2474,17 @@ struct partition {
static int guess_disk_lchs(IDEState *s,
int *pcylinders, int *pheads, int *psectors)
{
- uint8_t *buf;
+ uint8_t *buf = s->io_buffer;
int ret, i, heads, sectors, cylinders;
struct partition *p;
uint32_t nr_sects;
- buf = qemu_memalign(512, 512);
- if (buf == NULL)
- return -1;
ret = bdrv_read(s->bs, 0, buf, 1);
if (ret < 0) {
- qemu_free(buf);
return -1;
}
/* test msdos magic */
if (buf[510] != 0x55 || buf[511] != 0xaa) {
- qemu_free(buf);
return -1;
}
for(i = 0; i < 4; i++) {
@@ -2512,11 +2507,9 @@ static int guess_disk_lchs(IDEState *s,
printf("guessed geometry: LCHS=%d %d %d\n",
cylinders, heads, sectors);
#endif
- qemu_free(buf);
return 0;
}
}
- qemu_free(buf);
return -1;
}