source: hacks/xtide/xtidebios-patch.diff

Last change on this file was 74, checked in by bird, 10 years ago

xtide util hacking, included bios patch.

File size: 9.1 KB
  • Src/Device/IDE/IdePioBlock.asm

     
    7676        rep insb
    7777        ret
    7878%else ; 808x
     79 %ifdef USE_BIRD ; insane bird rollout
     80        push    bx
     81.NextSector:
     82        pushf
     83        cli
     84  %if 0 ;; @todo 8086+ only, anyone at all? - does not seem to work...
     85                        ; (nominal ticks / expected instruction fetch ticks / -<instr bytes consumed> +<added>
     86                        ;    8088 - iAPX88 BOOK (Intel Order No. 210200-002)
     87        %rep 256                        ;                  8086 - iAPX 86,88 User Manual (Intel Order No. 210201-001), TASM Quick Ref v4
     88                in              al, dx  ;       8/+4/-1+1   8/+4/-1+2    1 byte  Note! 8086 will only be empty half of the time here, but too
     89                xchg    bx, ax  ;       3/+1/-1+1   3/+1/-1+2    1 byte        tired to calculate that now. Probably this comes out as
     90                in              al, dx  ;       8/+4/-1+1   8/--/-1      1 byte        a 0 or 1 cycle win in reality...
     91                xchg    bx, ax  ;       3/+1/-1+1   3/+1/-1+2    1 byte
     92                mov             ah, bl  ;       2/+6/-2+2   2/+2/-2+2    2 bytes
     93                stosw                   ;      15/+4/-1+1  11/--/-1      1 byte
     94        %endrep                         ; sum  39/+20 =59  35/+12=47     7 bytes
     95                                        ; save -1/     -7   3/    -1    -3 bytes
     96   %else
     97        %rep 512
     98                in              al, dx  ;       8/+4/-1+1     8/+4/-1+2  1 byte
     99                stosb                   ;      11/+4/-1+4    11/--/-1    1 byte
     100    %endrep             ; sum  19/+8  =26    19/+4=23    2 bytes
     101   %endif               ; x2   38/+16 =52    38/+8=46    4 bytes
     102    popf
     103        dec     cx
     104        jnz             .NextSector
     105        pop             bx
     106        ret
     107
     108 %else  ; !USE_BIRD
    79109        UNROLL_SECTORS_IN_CX_TO_OWORDS
    80110ALIGN JUMP_ALIGN
    81111.ReadNextOword:
     
    85115        %endrep
    86116        loop    .ReadNextOword
    87117        ret
     118 %endif ; !USE_BIRD
    88119%endif
    89120
    90121%endif  ; MODULE_8BIT_IDE
     
    112143        ret
    113144
    114145%else ; 808x
     146 %ifdef USE_BIRD ; insane bird rollout.
     147.NextSector:
     148    pushf
     149        cli
     150        %rep 256 ; WORDs
     151                in              ax, dx  ; Read WORD
     152                stosw                   ; Store WORD to [ES:DI]
     153        %endrep
     154        popf
     155        dec     cx
     156        jnz     .NextSector
     157        ret
     158
     159 %else  ; !USE_BIRD
    115160        UNROLL_SECTORS_IN_CX_TO_OWORDS
    116161ALIGN JUMP_ALIGN
    117162.ReadNextOword:
     
    121166        %endrep
    122167        loop    .ReadNextOword
    123168        ret
     169 %endif ; !USE_BIRD
    124170%endif
    125171
    126172
     
    220266        ret
    221267
    222268%else ; 808x
     269 %ifdef USE_BIRD ; crazy bird loop unrolling
     270        push    ds
     271        push    es
     272        pop             ds
     273
     274.NextSector:
     275    pushf
     276        cli
     277 %if 1
     278                                                ;      8088 - iAPX88 BOOK (Intel Order No. 210200-002)
     279        %rep 256                        ;                    8086 - iAPX 86,88 User Manual (Intel Order No. 210201-001), TASM Quick Ref v4
     280                lodsw                   ;      16/+4/-1+1    12/+4|--/-1+2|+0     1 byte   - Note! 8086 doesn't need instr fetch half of the time.
     281                out     dx, al  ;       8/+4/-1+1     8/--   /-1          1 byte
     282                mov             al, ah  ;       2/+10/-2+3    2/+6   /-2+4        2 bytes
     283                out     dx, al  ;       8/--/-1       8/--   /-1          1 byte
     284        %endrep                         ; sum  34/+18=52     30/+10|+6=40|36~=38  5 bytes
     285                                                ; save  6/     4     10/        8|12~=10 -1 byte
     286 %else
     287        %rep 512
     288                lodsb                   ;      12/+4/-1+1    12/+4/-1+2           1 byte
     289                out             dx, al  ;       8/+4/-1+1     8/--/-1             1 byte
     290        %endrep                         ; sum  20/+8  =28    20/+4  =24           2 bytes
     291 %endif                                 ; x2   40/+16 =56    40/+8  =48           4 bytes
     292        popf
     293        dec             cx
     294        jnz             .NextSector
     295
     296        pop             ds
     297        ret
     298
     299 %else  ; !USE_BIRD
    223300        UNROLL_SECTORS_IN_CX_TO_QWORDS
    224301        push    ds
    225302        push    es
     
    233310        loop    .WriteNextQword
    234311        pop             ds
    235312        ret
     313 %endif ; !USE_BIRD
    236314%endif
    237315
    238316%endif ; MODULE_8BIT_IDE
     
    259337        ret
    260338
    261339%else ; 808x
     340 %ifdef USE_BIRD ; crazy bird loop unrolling
     341        push    bx
     342        push    ds
     343        push    es
     344        pop             ds
     345
     346.NextSector:
     347        pushf
     348        cli
     349        %rep 256        ; WORDs
     350                lodsw                   ; Load WORD from [DS:SI]
     351                out             dx, ax  ; Write WORD
     352        %endrep
     353        popf
     354        dec             cx
     355        jnz             .NextSector
     356
     357        pop             ds
     358        pop     bx
     359        ret
     360
     361 %else  ; !USE_BIRD
    262362        UNROLL_SECTORS_IN_CX_TO_QWORDS
    263363        push    ds
    264364        push    es
     
    272372        loop    .WriteNextQword
    273373        pop             ds
    274374        ret
     375 %endif ; !USE_BIRD
    275376%endif
    276377
    277378;--------------------------------------------------------------------
  • Src/Handlers/Int13h/AH9h_HInit.asm

     
    175175.SupportedBlockSizeFound:
    176176
    177177
     178%if 0 ; bird
     179;;;     InitializePioMode - disable IORDY and use default mode.
     180%if 0
     181        mov             dl, PIO_DEFAULT_MODE_DISABLE_IORDY
     182%else
     183        mov             dl, PIO_FLOW_CONTROL_MODE_xxx | 0
     184%endif
     185        mov             si, FEATURE_SET_TRANSFER_MODE
     186        call    AH23h_SetControllerFeatures
     187        STORE_ERROR_FLAG_TO_DPT         FLG_INITERROR_FAILED_TO_SET_PIO_MODE
     188
     189%else ; !bird
    178190%ifdef MODULE_ADVANCED_ATA
    179191;;;     InitializePioMode
    180192        ; Initialize fastest supported PIO mode
     
    190202        mov             si, FEATURE_SET_TRANSFER_MODE
    191203        call    AH23h_SetControllerFeatures
    192204        STORE_ERROR_FLAG_TO_DPT         FLG_INITERROR_FAILED_TO_SET_PIO_MODE
     205
    193206%endif ; MODULE_ADVANCED_ATA
     207%endif ; !bird
    194208
    195209
    196210%ifdef MODULE_POWER_MANAGEMENT
  • Src/Initialization/DetectDrives.asm

     
    241241        call    CreateDPT_FromAtaInformation
    242242        jc              SHORT DetectDrives_DriveNotFound
    243243        call    DriveDetectInfo_CreateForHardDisk
     244%ifdef USE_BIRD
     245        call    DetectPrint_DriveNameFromDrvDetectInfoInESBX
     246        call    TestBufferXfers
     247        ret
     248%else  ; !USE_BIRD
    244249        jmp             SHORT DetectPrint_DriveNameFromDrvDetectInfoInESBX
     250%endif ; !USE_BIRD
     251
     252
     253%ifdef USE_BIRD
     254;--------------------------------------------------------------------
     255; TestBufferXfers
     256;       Parameters:
     257;       Returns:
     258;               Nothing
     259;       Corrupts registers:
     260;--------------------------------------------------------------------
     261TestBufferXfers:
     262        ;; @todo later.  The idea is to write to the sector buffer, then read back
     263        ;; what we just wrote and check that the data is as expected.  This would
     264        ;; help detect problems with the PIO Data Write, and in NO_ATAID_VALIDATION
     265        ;; mode, also with PIO Data Read.  Preventing the user from totally screwing
     266        ;; up his CF card in the former case.
     267        ret
     268%endif
     269
  • makefile

     
    4040# USE_386                     Use instructions supported by 386 and later (defines USE_286)        #
    4141# USE_AT                      Use features supported on AT and later systems (not available on XT) #
    4242# USE_UNDOC_INTEL             Optimizations for Intel CPU:s - do NOT use on NEC V20/V30/Sony CPU:s #
     43# USE_BIRD                    Bird stuff                                                           #
     44# USE_BIRD_8086               Use code sequences favoring 8086+ over 8088.                         #
    4345#                                                                                                  #
    4446# ** AT Builds only (when USE_AT is defined)                                                       #
    4547# *** Use this only when certain known good drives are not being detected (eg WD Caviars)          #
     
    102104#################################################################
    103105# Assembler preprocessor defines.                               #
    104106#################################################################
    105 DEFINES_COMMON = MODULE_STRINGS_COMPRESSED MODULE_HOTKEYS MODULE_8BIT_IDE MODULE_EBIOS MODULE_SERIAL MODULE_SERIAL_FLOPPY MODULE_POWER_MANAGEMENT RESERVE_DIAGNOSTIC_CYLINDER NO_ATAID_VALIDATION
     107#DEFINES_COMMON = MODULE_STRINGS_COMPRESSED MODULE_HOTKEYS MODULE_8BIT_IDE MODULE_EBIOS MODULE_SERIAL MODULE_SERIAL_FLOPPY MODULE_POWER_MANAGEMENT RESERVE_DIAGNOSTIC_CYLINDER NO_ATAID_VALIDATION
     108DEFINES_COMMON  = MODULE_STRINGS_COMPRESSED MODULE_HOTKEYS MODULE_8BIT_IDE MODULE_EBIOS                                    MODULE_POWER_MANAGEMENT RESERVE_DIAGNOSTIC_CYLINDER
    106109DEFINES_COMMON_LARGE = MODULE_BOOT_MENU MODULE_8BIT_IDE_ADVANCED MODULE_COMPATIBLE_TABLES
    107110
    108 DEFINES_XT = $(DEFINES_COMMON) ELIMINATE_CGA_SNOW MODULE_8BIT_IDE_ADVANCED
     111DEFINES_XT = $(DEFINES_COMMON) ELIMINATE_CGA_SNOW MODULE_8BIT_IDE_ADVANCED USE_BIRD USE_BIRD_8086
    109112DEFINES_XTPLUS = $(DEFINES_XT) USE_186
    110 DEFINES_AT = $(DEFINES_COMMON) USE_AT USE_286 MODULE_IRQ MODULE_ADVANCED_ATA MODULE_COMPATIBLE_TABLES
     113DEFINES_AT = $(DEFINES_COMMON) USE_AT USE_286 MODULE_IRQ MODULE_ADVANCED_ATA MODULE_COMPATIBLE_TABLES USE_BIRD USE_BIRD_8086
    111114
    112115DEFINES_XT_LARGE = $(DEFINES_XT) $(DEFINES_COMMON_LARGE)
    113116DEFINES_XTPLUS_LARGE = $(DEFINES_XTPLUS) $(DEFINES_COMMON_LARGE)
     
    126129
    127130# Target size of the ROM, used in main.asm for number of 512B blocks and by checksum Perl script below
    128131BIOS_SIZE = 8192                # For BIOS header (use even multiplier!)
     132BIOS_SIZE = 12288               # For BIOS header (use even multiplier!)
    129133ROMSIZE = $(BIOS_SIZE)  # Size of binary to build when building with make checksum
    130134BIOS_SIZE_LARGE = 12288
    131135ROMSIZE_LARGE = $(BIOS_SIZE_LARGE)
Note: See TracBrowser for help on using the repository browser.