Changeset 78571 in vbox for trunk/src/VBox/Devices/PC
- Timestamp:
- May 17, 2019 2:24:30 PM (6 years ago)
- Location:
- trunk/src/VBox/Devices/PC
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Devices/PC/BIOS/ata.c
r78423 r78571 638 638 fdpt = ebda_seg :> &EbdaData->fdpt1; 639 639 640 #if 0640 #if 1 641 641 /* Place the FDPT outside of conventional memory. Needed for 642 642 * 286 XENIX 2.1.3/2.2.1 because it completely wipes out -
trunk/src/VBox/Devices/PC/BIOS/disk.c
r76553 r78571 162 162 dpt->heads = bios_dsk->devices[device].pchs.heads; 163 163 dpt->spt = bios_dsk->devices[device].pchs.spt; 164 #if 1 164 165 lba = bios_dsk->devices[device].sectors; 166 #else 167 // Makes PC DOS 7.1 FDISK32 happy 168 lba = (uint32_t)dpt->cylinders * dpt->heads * dpt->spt; 169 #endif 165 170 dpt->sector_count1 = lba; 166 171 dpt->sector_count2 = lba >> 32; … … 395 400 break; 396 401 402 #ifdef VBOX_WITH_SCSIz 403 case 0x06: /* identify SCSI devices */ 404 if (VBOX_IS_SCSI_DEVICE(device)|| 1) { 405 BX_INFO("%s: AX=%04x BX=%04x CX=%04x DX=%04x ES=%04x\n", __func__, AX, BX, CX, DX, ES); 406 BX_INFO("%s: function %02xh detected SCSI drive\n", __func__, GET_AH()); 407 SET_BH(0); 408 SET_BL(0); 409 SET_AL(0x80); 410 goto int13_success; 411 } 412 BX_INFO("%s no SCSI drives, returns fail\n", __func__); 413 goto int13_fail; 414 break; 415 #endif 397 416 case 0x08: /* read disk drive parameters */ 398 417 399 418 /* Get the logical geometry from internal table. */ 419 #if 0 420 /* Windows 3.1 FastDisk (wdctrl) insists on this */ 421 nlc = bios_dsk->devices[device].lchs.cylinders - 1; 422 #else 400 423 nlc = bios_dsk->devices[device].lchs.cylinders; 424 #endif 401 425 nlh = bios_dsk->devices[device].lchs.heads; 402 426 nlspt = bios_dsk->devices[device].lchs.spt; -
trunk/src/VBox/Devices/PC/BIOS/makefile
r71426 r78571 47 47 48 48 vbxbios.rom : vbxbios.bin 49 !if $(CPU) > 286 49 50 biossums $< $@ 51 !else 52 cp $< $@ 53 !endif 50 54 51 55 vbxbios.bin : $(OBJS) $(__MAKEFILES__) -
trunk/src/VBox/Devices/PC/DevACPI.cpp
r76553 r78571 2114 2114 { 2115 2115 ACPIState *pThis = (ACPIState *)pvUser; 2116 DEVACPI_LOCK_R3(pThis);2117 2116 2118 2117 LogFunc(("Port=%#x u32=%#x cb=%u\n", Port, u32, cb)); … … 2122 2121 return PDMDevHlpDBGFStop(pDevIns, RT_SRC_POS, "cb=%d Port=%u u32=%#x\n", cb, Port, u32); 2123 2122 2123 DEVACPI_LOCK_R3(pThis); 2124 2124 switch (off) 2125 2125 { … … 2203 2203 RT_NOREF1(pDevIns); 2204 2204 ACPIState *pThis = (ACPIState *)pvUser; 2205 DEVACPI_LOCK_R3(pThis);2206 2205 2207 2206 int rc = VINF_SUCCESS; … … 2212 2211 return VERR_IOM_IOPORT_UNUSED; 2213 2212 2213 DEVACPI_LOCK_R3(pThis); 2214 2214 switch (off) 2215 2215 { -
trunk/src/VBox/Devices/PC/DevDMA.cpp
r76553 r78571 99 99 #define DMA_SAVESTATE_OLD 1 /* The original saved state. */ 100 100 #define DMA_SAVESTATE_CURRENT 2 /* The new and improved saved state. */ 101 #define DMA_FIXES 101 102 102 103 /* State information for a single DMA channel. */ … … 266 267 else 267 268 ch->u16BaseAddr = RT_MAKE_U16(ch->u16BaseAddr, u32); 268 269 ch->u16CurCount = 0;270 ch->u16CurAddr = ch->u16BaseAddr;271 269 } 272 270 else … … 278 276 ch->u16BaseAddr = RT_MAKE_U16(u32, RT_HIBYTE(ch->u16BaseAddr)); 279 277 } 278 /* 279 * Update the current count/address. 280 * 281 * NB: The current count actually counts from zero up, while the base count 282 * uses the the 8257 semantics and counts down. The guest never sees the 283 * current count directly. 284 */ 285 if (is_count) 286 ch->u16CurCount = 0; 287 else 288 ch->u16CurAddr = ch->u16BaseAddr; 289 280 290 Log2(("dmaWriteAddr: port %#06x, chidx %d, data %#02x\n", 281 291 port, chidx, u32)); … … 312 322 val = ch->u16BaseCount - ch->u16CurCount; 313 323 else 324 #ifdef DMA_FIXES 325 val = ch->u16CurAddr; 326 #else 314 327 val = ch->u16CurAddr + ch->u16CurCount * dir; 328 #endif 315 329 316 330 bptr = dmaReadBytePtr(dc); … … 601 615 DMAChannel *ch = &dc->ChState[chidx]; 602 616 uint32_t start_cnt, end_cnt; 617 int uDelta; 603 618 int opmode; 604 619 … … 616 631 end_cnt = ch->pfnXferHandler(pThis->pDevIns, ch->pvUser, (ctlidx * 4) + chidx, 617 632 start_cnt, (ch->u16BaseCount + 1) << dc->is16bit); 633 uDelta = (end_cnt - start_cnt) >> dc->is16bit; 618 634 ch->u16CurCount = end_cnt >> dc->is16bit; 635 #ifdef DMA_FIXES // Necessary, but currently upsets SB16. 636 int dir = IS_MODE_DEC(ch->u8Mode) ? -1 : 1; 637 ch->u16CurAddr += uDelta * dir; 638 #endif 619 639 /* Set the TC (Terminal Count) bit if transfer was completed. */ 620 640 if (ch->u16CurCount == ch->u16BaseCount + 1) … … 624 644 case DMODE_SINGLE: 625 645 case DMODE_BLOCK: 626 dc->u8Status |= RT_BIT(chidx); 627 Log3(("TC set for DMA channel %d\n", (ctlidx * 4) + chidx)); 646 dc->u8Status |= RT_BIT(chidx); /* Set the TC status bit. */ 647 Log3(("TC set for DMA channel %d, auto-init %s\n", (ctlidx * 4) + chidx, IS_MODE_AI(ch->u8Mode) ? "on" : "off")); 648 if (IS_MODE_AI(ch->u8Mode)) 649 { 650 /* Auto-init DMA, resets the current address/count. */ 651 #ifdef DMA_FIXES // Necessary, but currently upsets SB16. 652 ch->u16CurAddr = ch->u16BaseAddr; 653 ch->u16CurCount = 0; 654 #endif 655 } 656 else 657 dc->u8Mask |= RT_BIT(chidx); /* No auto-init, mask channel. */ 628 658 break; 629 659 default: … … 655 685 { 656 686 mask = 1 << chidx; 687 /* Run channel if not masked and its DREQ is active. */ 657 688 if (!(dc->u8Mask & mask) && (dc->u8Status & (mask << 4))) 658 689 dmaRunChannel(pThis, ctlidx, chidx);
Note:
See TracChangeset
for help on using the changeset viewer.