VirtualBox

Changeset 39567 in vbox for trunk/src/VBox/Devices/PC


Ignore:
Timestamp:
Dec 9, 2011 1:48:57 PM (13 years ago)
Author:
vboxsync
Message:

Reduced generated code size a bit more.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Devices/PC/BIOS-new/eltorito.c

    r39565 r39567  
    615615void BIOSCALL int13_cdrom(uint16_t EHBX, disk_regs_t r)
    616616{
    617     uint16_t        ebda_seg=read_word(0x0040,0x000E);
    618     uint8_t         device, status, locks;
    619     uint8_t         atacmd[12];
    620     uint32_t        lba;
    621     uint16_t        count, segment, offset, size;
    622     bio_dsk_t __far *bios_dsk;
     617    uint16_t            ebda_seg = read_word(0x0040,0x000E);
     618    uint8_t             device, status, locks;
     619    uint8_t             atacmd[12];
     620    uint32_t            lba;
     621    uint16_t            count, segment, offset, size;
     622    bio_dsk_t __far     *bios_dsk;
     623    int13ext_t __far    *i13x;
     624    dpt_t __far         *dpt;
    623625
    624626    bios_dsk = ebda_seg :> &EbdaData->bdisk;
    625 
    626627   
    627628    BX_DEBUG_INT13_CD("%s: AX=%04x BX=%04x CX=%04x DX=%04x ES=%04x\n", __func__, AX, BX, CX, DX, ES);
     
    694695    case 0x47: // IBM/MS extended seek
    695696
    696         count   = read_word(DS, SI+(uint16_t)&Int13Ext->count);
    697         segment = read_word(DS, SI+(uint16_t)&Int13Ext->segment);
    698         offset  = read_word(DS, SI+(uint16_t)&Int13Ext->offset);
     697        /* Load the I13X struct pointer. */
     698        i13x = MK_FP(DS, SI);
     699
     700        count   = i13x->count;
     701        segment = i13x->segment;
     702        offset  = i13x->offset;
    699703
    700704        // Can't use 64 bits lba
    701         lba = read_dword(DS, SI+(uint16_t)&Int13Ext->lba2);
     705        lba = i13x->lba2;
    702706        if (lba != 0L) {
    703707            BX_PANIC("%s: function %02x. Can't use 64bits lba\n", __func__, GET_AH());
     
    706710
    707711        // Get 32 bits lba
    708         lba = read_dword(DS, SI+(uint16_t)&Int13Ext->lba1);
     712        lba = i13x->lba1;
    709713
    710714        // If verify or seek
     
    731735
    732736        count = (uint16_t)(bios_dsk->drqp.trsfbytes >> 11);
    733         write_word(DS, SI+(uint16_t)&Int13Ext->count, count);
     737        i13x->count = count;
    734738
    735739        if (status != 0) {
     
    808812        break;
    809813
     814    //@todo: Part of this should be merged with analogous code in disk.c
    810815    case 0x48: // IBM/MS get drive parameters
    811         size = read_word(DS,SI+(uint16_t)&Int13Ext->size);
     816        dpt = DS :> (dpt_t *)SI;
     817        size = dpt->size;
    812818
    813819        // Buffer is too small
    814         if(size < 0x1a)
     820        if (size < 0x1a)
    815821            goto int13_fail;
    816822
    817823        // EDD 1.x
    818         if(size >= 0x1a) {
     824        if (size >= 0x1a) {
    819825            uint16_t   blksize;
    820826
    821             blksize   = bios_dsk->devices[device].blksize;
    822 
    823             write_word(DS, SI+(uint16_t)&Int13DPT->size, 0x1a);
    824             write_word(DS, SI+(uint16_t)&Int13DPT->infos, 0x74); // removable, media change, lockable, max values
    825             write_dword(DS, SI+(uint16_t)&Int13DPT->cylinders, 0xffffffff);
    826             write_dword(DS, SI+(uint16_t)&Int13DPT->heads, 0xffffffff);
    827             write_dword(DS, SI+(uint16_t)&Int13DPT->spt, 0xffffffff);
    828             write_dword(DS, SI+(uint16_t)&Int13DPT->sector_count1, 0xffffffff);  // FIXME should be Bit64
    829             write_dword(DS, SI+(uint16_t)&Int13DPT->sector_count2, 0xffffffff);
    830             write_word(DS, SI+(uint16_t)&Int13DPT->blksize, blksize);
     827            blksize = bios_dsk->devices[device].blksize;
     828
     829            dpt->size      = 0x1a;
     830            dpt->infos     = 0x74;  /* Removable, media change, lockable, max values */
     831            dpt->cylinders = 0xffffffff;
     832            dpt->heads     = 0xffffffff;
     833            dpt->spt       = 0xffffffff;
     834            dpt->blksize   = blksize;
     835            dpt->sector_count1 = 0xffffffff;  // FIXME should be Bit64
     836            dpt->sector_count2 = 0xffffffff;
    831837        }
    832838
    833839        // EDD 2.x
    834840        if(size >= 0x1e) {
    835             uint8_t  channel, irq, mode, checksum, i;
    836             uint16_t iobase1, iobase2, options;
    837 
    838             write_word(DS, SI+(uint16_t)&Int13DPT->size, 0x1e);
    839 
    840             write_word(DS, SI+(uint16_t)&Int13DPT->dpte_segment, ebda_seg);
    841             write_word(DS, SI+(uint16_t)&Int13DPT->dpte_offset, (uint16_t)&EbdaData->bdisk.dpte);
     841            uint8_t     channel, irq, mode, checksum, i;
     842            uint16_t    iobase1, iobase2, options;
     843
     844            dpt->size = 0x1e;
     845            dpt->dpte_segment = ebda_seg;
     846            dpt->dpte_offset  = (uint16_t)&EbdaData->bdisk.dpte;
    842847
    843848            // Fill in dpte
     
    854859            options |= (mode==ATA_MODE_PIO32?1:0<<7);
    855860
    856             bios_dsk->dpte.iobase1   = iobase1;
    857             bios_dsk->dpte.iobase2   = iobase2;
    858             bios_dsk->dpte.prefix    = (0xe | (device % 2))<<4;
    859             bios_dsk->dpte.unused    = 0xcb;
    860             bios_dsk->dpte.irq       = irq;
    861             bios_dsk->dpte.blkcount  = 1 ;
    862             bios_dsk->dpte.dma       = 0;
    863             bios_dsk->dpte.pio       = 0;
    864             bios_dsk->dpte.options   = options;
    865             bios_dsk->dpte.reserved  = 0;
    866             bios_dsk->dpte.revision  = 0x11;
     861            bios_dsk->dpte.iobase1  = iobase1;
     862            bios_dsk->dpte.iobase2  = iobase2;
     863            bios_dsk->dpte.prefix   = (0xe | (device % 2))<<4;
     864            bios_dsk->dpte.unused   = 0xcb;
     865            bios_dsk->dpte.irq      = irq;
     866            bios_dsk->dpte.blkcount = 1 ;
     867            bios_dsk->dpte.dma      = 0;
     868            bios_dsk->dpte.pio      = 0;
     869            bios_dsk->dpte.options  = options;
     870            bios_dsk->dpte.reserved = 0;
     871            bios_dsk->dpte.revision = 0x11;
    867872
    868873            checksum = 0;
    869             for (i=0; i<15; i++)
     874            for (i = 0; i < 15; ++i)
    870875                checksum += read_byte(ebda_seg, (uint16_t)&EbdaData->bdisk.dpte + i);
    871876            checksum = -checksum;
     
    875880        // EDD 3.x
    876881        if(size >= 0x42) {
    877             uint8_t  channel, iface, checksum, i;
    878             uint16_t iobase1;
     882            uint8_t     channel, iface, checksum, i;
     883            uint16_t    iobase1;
    879884
    880885            channel = device / 2;
     
    882887            iobase1 = bios_dsk->channels[channel].iobase1;
    883888
    884             write_word(DS, SI+(uint16_t)&Int13DPT->size, 0x42);
    885             write_word(DS, SI+(uint16_t)&Int13DPT->key, 0xbedd);
    886             write_byte(DS, SI+(uint16_t)&Int13DPT->dpi_length, 0x24);
    887             write_byte(DS, SI+(uint16_t)&Int13DPT->reserved1, 0);
    888             write_word(DS, SI+(uint16_t)&Int13DPT->reserved2, 0);
     889            dpt->size       = 0x42;
     890            dpt->key        = 0xbedd;
     891            dpt->dpi_length = 0x24;
     892            dpt->reserved1  = 0;
     893            dpt->reserved2  = 0;
    889894
    890895            if (iface == ATA_IFACE_ISA) {
    891                 write_byte(DS, SI+(uint16_t)&Int13DPT->host_bus[0], 'I');
    892                 write_byte(DS, SI+(uint16_t)&Int13DPT->host_bus[1], 'S');
    893                 write_byte(DS, SI+(uint16_t)&Int13DPT->host_bus[2], 'A');
    894                 write_byte(DS, SI+(uint16_t)&Int13DPT->host_bus[3], 0);
     896                dpt->host_bus[0] = 'I';
     897                dpt->host_bus[1] = 'S';
     898                dpt->host_bus[2] = 'A';
     899                dpt->host_bus[3] = ' ';
    895900            }
    896901            else {
    897902                // FIXME PCI
    898903            }
    899             write_byte(DS, SI+(uint16_t)&Int13DPT->iface_type[0], 'A');
    900             write_byte(DS, SI+(uint16_t)&Int13DPT->iface_type[1], 'T');
    901             write_byte(DS, SI+(uint16_t)&Int13DPT->iface_type[2], 'A');
    902             write_byte(DS, SI+(uint16_t)&Int13DPT->iface_type[3], 0);
    903 
    904             if (iface==ATA_IFACE_ISA) {
    905                 write_word(DS, SI+(uint16_t)&Int13DPT->iface_path[0], iobase1);
    906                 write_word(DS, SI+(uint16_t)&Int13DPT->iface_path[2], 0);
    907                 write_dword(DS, SI+(uint16_t)&Int13DPT->iface_path[4], 0L);
     904            dpt->iface_type[0] = 'A';
     905            dpt->iface_type[1] = 'T';
     906            dpt->iface_type[2] = 'A';
     907            dpt->iface_type[3] = ' ';
     908            dpt->iface_type[4] = ' ';
     909            dpt->iface_type[5] = ' ';
     910            dpt->iface_type[6] = ' ';
     911            dpt->iface_type[7] = ' ';
     912
     913            if (iface == ATA_IFACE_ISA) {
     914                ((uint16_t __far *)dpt->iface_path)[0] = iobase1;
     915                ((uint16_t __far *)dpt->iface_path)[1] = 0;
     916                ((uint32_t __far *)dpt->iface_path)[1] = 0;
    908917            }
    909918            else {
    910919                // FIXME PCI
    911920            }
    912             write_byte(DS, SI+(uint16_t)&Int13DPT->device_path[0], device%2);
    913             write_byte(DS, SI+(uint16_t)&Int13DPT->device_path[1], 0);
    914             write_word(DS, SI+(uint16_t)&Int13DPT->device_path[2], 0);
    915             write_dword(DS, SI+(uint16_t)&Int13DPT->device_path[4], 0L);
     921            ((uint16_t __far *)dpt->device_path)[0] = device & 1;
     922            ((uint16_t __far *)dpt->device_path)[1] = 0;
     923            ((uint32_t __far *)dpt->device_path)[1] = 0;
    916924
    917925            checksum = 0;
    918             for (i=30; i<64; i++)
    919                 checksum+=read_byte(DS, SI + i);
     926            for (i = 30; i < 64; ++i)
     927                checksum += ((uint8_t __far *)dpt)[i];
    920928            checksum = -checksum;
    921             write_byte(DS, SI+(uint16_t)&Int13DPT->checksum, checksum);
     929            dpt->checksum = checksum;
    922930        }
    923931
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette