diff options
author | balrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-02-03 03:37:46 +0000 |
---|---|---|
committer | balrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162> | 2008-02-03 03:37:46 +0000 |
commit | c717d8bf13d4c24372c4885eefa821ec76378d2b (patch) | |
tree | 31eab27985fe9f8e48fc03e58921043671d29bfd /hw | |
parent | 7241f532c3adbebfc8689b878aec3f244043d147 (diff) | |
download | qemu-c717d8bf13d4c24372c4885eefa821ec76378d2b.zip qemu-c717d8bf13d4c24372c4885eefa821ec76378d2b.tar.gz qemu-c717d8bf13d4c24372c4885eefa821ec76378d2b.tar.bz2 |
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')
-rw-r--r-- | hw/ide.c | 9 |
1 files changed, 1 insertions, 8 deletions
@@ -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; } |