source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Src/Handlers/Int13h/AH1Eh_XTCF.asm

Last change on this file was 592, checked in by krille_n_, 6 years ago

Changes:

  • The problem with NASM in the previous revision (r591) has been fixed.
  • The colors used by the boot menu and hotkey bar can now be customized by selecting one of a number of pre-defined color themes. Suggestions for additional themes are more than welcome!
  • Large builds are now 10 KB. Small builds are still 8 KB with the exception of the Tiny build which is now 4 KB. In other words, builds are now as small as possible to make it easier to combine them with other BIOSes.
  • Added code to the library to improve drive error handling. XTIDECFG can now handle "Drive Not Ready" errors.
  • Fixed a couple of potential bugs in AtaID.asm (AtaID_GetMaxPioModeToAXandMinCycleTimeToCX); 1) ATA1.bPioMode was treated as a WORD variable. 2) ATA2.bPIOSupp was assumed to be non-zero which would result in PIO mode 3 being returned if the assumption was wrong.
  • Made the same changes in the equivalent function used by BIOSDRVS (DisplayPioModeInformationUsingAtaInfoFromDSBX in AtaInfo.asm).
  • Fixed a bug from r587 in PDC20x30.asm in PDC20x30_GetMaxPioModeToALandMinPioCycleTimeToBX.
  • Fixed a bug from r523 in XTIDECFG where Auto Configure would only set the IRQ on one IDE interface on AT-builds.
  • XTIDECFG will now restore the default settings for the "Serial port virtual device" when reselecting it in the list of device types. This makes it behave consistently for all device types.
  • The eAAM macro is now used regardless if USE_UNDOC_INTEL is defined or not because it is apparently supported on all processors including the NEC V20/V30 CPUs.
  • Renamed the EXCLUDE_FROM_XTIDE_UNIVERSAL_BIOS define to EXCLUDE_FROM_XUB.
  • Added a define to exclude unused library code from BIOSDRVS (EXCLUDE_FROM_BIOSDRVS). This makes it a lot smaller than in previous revisions.
  • All unnecessary CLD-instructions are now under a new define 'CLD_NEEDED' which is only enabled for the BIOS. It is disabled for XTIDECFG and BIOSDRVS but can be enabled if needed by adding this define to the respective makefile. This change was made because these unnecessary instructions are wasteful and should never be needed. In fact, they only serve to hide bugs (in other peoples code) which I strongly believe should be avoided. I recommend people making their own BIOSes from source to not use this define as it's extremely unlikely to be needed.
  • Updated the copyright info in SerDrive and changed an URL to point to the new site.
  • Updated the copyright info and version number in BIOSDRVS.
  • Updated the copyright info in XTIDECFG.
  • Optimizations in general.
File size: 6.2 KB
Line 
1; Project name  :   XTIDE Universal BIOS
2; Description   :   Int 13h function AH=1Eh, Lo-tech XT-CF features
3;
4; More information at http://www.lo-tech.co.uk/XT-CF
5
6;
7; XTIDE Universal BIOS and Associated Tools
8; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2013 by XTIDE Universal BIOS Team.
9;
10; This program is free software; you can redistribute it and/or modify
11; it under the terms of the GNU General Public License as published by
12; the Free Software Foundation; either version 2 of the License, or
13; (at your option) any later version.
14;
15; This program is distributed in the hope that it will be useful,
16; but WITHOUT ANY WARRANTY; without even the implied warranty of
17; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18; GNU General Public License for more details.
19; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20;
21
22; Section containing code
23SECTION .text
24
25;--------------------------------------------------------------------
26; Int 13h function AH=1Eh, Lo-tech XT-CF features.
27; This function is supported only by XTIDE Universal BIOS.
28;
29; AH1Eh_HandlerForXTCFfeatures
30;   Parameters:
31;       AL, CX: Same as in INTPACK
32;       DL:     Translated Drive number
33;       DS:DI:  Ptr to DPT (in RAMVARS segment)
34;       SS:BP:  Ptr to IDEPACK
35;   Parameters on INTPACK:
36;       AL:     XT-CF subcommand (see XTCF.inc for more info)
37;   Returns with INTPACK:
38;       AH:     Int 13h return status
39;       CF:     0 if successful, 1 if error
40;       DX:     Command return values (see XTCF.inc)
41;--------------------------------------------------------------------
42AH1Eh_HandlerForXTCFfeatures:
43%ifndef USE_186
44    call    ProcessXTCFsubcommandFromAL
45    jmp     Int13h_ReturnFromHandlerAfterStoringErrorCodeFromAH
46%else
47    push    Int13h_ReturnFromHandlerAfterStoringErrorCodeFromAH
48    ; Fall to ProcessXTCFsubcommandFromAL
49%endif
50
51
52;--------------------------------------------------------------------
53; ProcessXTCFsubcommandFromAL
54;   Parameters:
55;       AL:     XT-CF subcommand (see XTCF.inc for more info)
56;       DS:DI:  Ptr to DPT (in RAMVARS segment)
57;       SS:BP:  Ptr to IDEPACK
58;   Returns:
59;       AH:     Int 13h return status
60;       CF:     0 if successful, 1 if error
61;   Corrupts registers:
62;       AL, BX, CX, DX, SI
63;--------------------------------------------------------------------
64ProcessXTCFsubcommandFromAL:
65    ; IS_THIS_DRIVE_XTCF. We check this for all commands.
66    call    AccessDPT_IsThisDeviceXTCF
67    jc      SHORT .XTCFnotFound
68    and     ax, 0FFh                    ; Subcommand now in AX (clears AH and CF)
69    jz      SHORT .XTCFfound            ; Sub-function IS_THIS_DRIVE_XTCF (=0)
70
71    dec     ax                          ; Test subcommand...
72    jz      SHORT .SetXTCFtransferMode  ; ...for value 1 (SET_XTCF_TRANSFER_MODE)
73
74    dec     ax                          ; Test subcommand for value 2 (GET_XTCF_TRANSFER_MODE)
75    jnz     SHORT .AH1Eh_LoadInvalidCommandToAHandSetCF
76
77    ; GET_XTCF_TRANSFER_MODE
78    call    AH1Eh_GetCurrentXTCFmodeToAX
79    mov     dh, al
80    mov     dl, [di+DPT_ATA.bBlockSize]
81    mov     [bp+IDEPACK.intpack+INTPACK.dx], dx ; Return mode value (DH) and block size (DL) via INTPACK
82.XTCFfound:
83    ret     ; With AH and CF cleared
84
85.XTCFnotFound:
86.AH1Eh_LoadInvalidCommandToAHandSetCF:
87    stc     ; Set carry flag since XT-CF not found or invalid subcommand
88    mov     ah, RET_HD_INVALID
89    ret
90
91.SetXTCFtransferMode:
92    mov     al, [bp+IDEPACK.intpack+INTPACK.dh] ; Get specified mode (eg XTCF_DMA_MODE)
93    ; Fall to AH1Eh_ChangeXTCFmodeBasedOnModeInAL
94
95
96;--------------------------------------------------------------------
97; AH1Eh_ChangeXTCFmodeBasedOnModeInAL
98;   Parameters:
99;       AL:     XT-CF Mode (see XTCF.inc)
100;       DS:DI:  Ptr to DPT (in RAMVARS segment)
101;       SS:BP:  Ptr to IDEPACK
102;   Returns:
103;       AH:     Int 13h return status
104;       CF:     0 if successful, 1 if error
105;   Corrupts registers:
106;       AL, BX, CX, DX, SI
107;--------------------------------------------------------------------
108AH1Eh_ChangeXTCFmodeBasedOnModeInAL:
109    ; Note: Control register (as of XT-CFv3) is now a write-only register,
110    ;       whose purpose is *only* to raise DRQ.  The register cannot be read.
111    ;       Selected transfer mode is stored in BIOS variable (DPT_ATA.bDevice).
112
113    ; Note that when selecting 'XTCF_8BIT_PIO_MODE_WITH_BIU_OFFLOAD' mode,
114    ; the ATA device (i.e. CompactFlash card) will operate in 8-bit mode, but
115    ; data will be transferred from its data register using 16-bit CPU instructions
116    ; like REP INSW.  This works because XT-CF adapters are 8-bit cards, and
117    ; the BIU in the machine splits each WORD requested by the CPU into two 8-bit
118    ; ISA cycles at base+0h and base+1h.  The XT-CF cards do not decode A0, hence
119    ; both accesses appear the same to the card and the BIU then re-constructs
120    ; the data for presentation to the CPU.
121    ;
122    ; Also note that some machines, noteably the Olivetti M24 (also known as
123    ; the AT&T PC6300 or Xerox 6060 or Logabax Persona 1600), have hardware errors
124    ; in the BIU logic, resulting in reversed byte ordering.  Therefore,
125    ; XTCF_8BIT_PIO_MODE is the default transfer mode for best system compatibility.
126
127
128    ; Is requested mode valid?
129    cmp     al, 3                       ; Valid modes are 0...3
130    ja      SHORT ProcessXTCFsubcommandFromAL.AH1Eh_LoadInvalidCommandToAHandSetCF
131
132    ; Convert mode to XT-CF device type (see RomVars.inc and XTCF.inc for full details)
133    eSHL_IM al, 1                       ; Shift requested mode
134    add     al, XTCF_DEVICE_OFFSET      ; Add the device offset (already shifted)
135    mov     [di+DPT_ATA.bDevice], al    ; Set the new mode (or device actually)
136
137    cmp     al, DEVICE_8BIT_XTCF_PIO16_WITH_BIU_OFFLOAD
138    je      SHORT AH23h_Disable8bitPioMode
139
140    ; We always need to enable 8-bit mode since 16-bit mode is restored
141    ; when controller is reset (AH=00h or 0Dh)
142
143    cmp     al, DEVICE_8BIT_XTCF_DMA
144    jne     SHORT AH23h_Enable8bitPioMode
145
146    ; DMA transfers have limited block size
147    mov     al, XTCF_DMA_MODE_MAX_BLOCK_SIZE
148    cmp     [di+DPT_ATA.bBlockSize], al
149    jbe     SHORT AH23h_Enable8bitPioMode   ; No need to limit block size
150    call    AH24h_SetBlockSize
151    jmp     SHORT AH23h_Enable8bitPioMode
152
153
154;--------------------------------------------------------------------
155; AH1Eh_GetCurrentXTCFmodeToAX
156;   Parameters:
157;       DS:DI:  Ptr to DPT (in RAMVARS segment)
158;   Returns:
159;       AX:     XT-CF mode (see XTCF.inc)
160;       CF:     Clear
161;   Corrupts registers:
162;       Nothing
163;--------------------------------------------------------------------
164AH1Eh_GetCurrentXTCFmodeToAX:
165    mov     ax, -XTCF_DEVICE_OFFSET & 0FFh
166    add     al, [di+DPT_ATA.bDevice]
167    shr     al, 1
168    ret
169
Note: See TracBrowser for help on using the repository browser.