[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] Xen full virtualization does not handle unaligned IO with page crossing.
# HG changeset patch # User kaf24@xxxxxxxxxxxxxxxxxxxx # Node ID 3acc0ae6a00186a12ccf18ee277d053274a8ad61 # Parent 5f77050a58f68bcae6b8983e57e0825ebd27ed0b Xen full virtualization does not handle unaligned IO with page crossing. Disable 32-bit PIO as a workaround. Signed-off-by: Asit Mallick <asit.k.mallick@xxxxxxxxx> Signed-off-by: Arun Sharma <arun.sharma@xxxxxxxxx> diff -r 5f77050a58f6 -r 3acc0ae6a001 tools/firmware/rombios/rombios.c --- a/tools/firmware/rombios/rombios.c Mon Jul 25 21:00:30 2005 +++ b/tools/firmware/rombios/rombios.c Mon Jul 25 21:01:42 2005 @@ -28,6 +28,11 @@ #define VMXASSIST #undef VMXTEST + +// Xen full virtualization does not handle unaligned IO with page crossing. +// Disable 32-bit PIO as a workaround. +#define NO_PIO32 + // ROM BIOS compatability entry points: // =================================== @@ -2248,6 +2253,9 @@ Bit16u cylinders, heads, spt, blksize; Bit8u translation, removable, mode; + // default mode to PIO16 + mode = ATA_MODE_PIO16; + //Temporary values to do the transfer write_byte(ebda_seg,&EbdaData->ata.devices[device].device,ATA_DEVICE_HD); write_byte(ebda_seg,&EbdaData->ata.devices[device].mode, ATA_MODE_PIO16); @@ -2256,7 +2264,10 @@ BX_PANIC("ata-detect: Failed to detect ATA device\n"); removable = (read_byte(get_SS(),buffer+0) & 0x80) ? 1 : 0; +#ifndef NO_PIO32 mode = read_byte(get_SS(),buffer+96) ? ATA_MODE_PIO32 : ATA_MODE_PIO16; +#endif + blksize = read_word(get_SS(),buffer+10); cylinders = read_word(get_SS(),buffer+(1*2)); // word 1 @@ -2346,6 +2357,9 @@ Bit8u type, removable, mode; Bit16u blksize; + // default mode to PIO16 + mode = ATA_MODE_PIO16; + //Temporary values to do the transfer write_byte(ebda_seg,&EbdaData->ata.devices[device].device,ATA_DEVICE_CDROM); write_byte(ebda_seg,&EbdaData->ata.devices[device].mode, ATA_MODE_PIO16); @@ -2355,7 +2369,9 @@ type = read_byte(get_SS(),buffer+1) & 0x1f; removable = (read_byte(get_SS(),buffer+0) & 0x80) ? 1 : 0; +#ifndef NO_PIO32 mode = read_byte(get_SS(),buffer+96) ? ATA_MODE_PIO32 : ATA_MODE_PIO16; +#endif blksize = 2048; write_byte(ebda_seg,&EbdaData->ata.devices[device].device, type); _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |