source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Src/VariablesAndDPTs/AccessDPT.asm @ 545

Last change on this file since 545 was 545, checked in by aitotat@…, 11 years ago

Changes to XTIDE Universal BIOS:

  • Integrated XT-CFv3 support by James Pearce.
  • XT-CFv2 memory mapped I/O and DMA modes are no longer supported (but PIO mode is).
File size: 5.7 KB
RevLine 
[99]1; Project name  :   XTIDE Universal BIOS
[3]2; Description   :   Functions for accessing DPT data.
3
[376]4;
[491]5; XTIDE Universal BIOS and Associated Tools
[526]6; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2013 by XTIDE Universal BIOS Team.
[376]7;
8; This program is free software; you can redistribute it and/or modify
9; it under the terms of the GNU General Public License as published by
10; the Free Software Foundation; either version 2 of the License, or
11; (at your option) any later version.
[491]12;
[376]13; This program is distributed in the hope that it will be useful,
14; but WITHOUT ANY WARRANTY; without even the implied warranty of
15; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
[491]16; GNU General Public License for more details.
[376]17; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
[491]18;
[376]19
[3]20; Section containing code
21SECTION .text
22
23;--------------------------------------------------------------------
[542]24; AccessDPT_GetDriveSelectByteToAL
[150]25;   Parameters:
26;       DS:DI:  Ptr to Disk Parameter Table
27;   Returns:
28;       AL:     Drive Select Byte
29;   Corrupts registers:
30;       Nothing
31;--------------------------------------------------------------------
32ALIGN JUMP_ALIGN
[542]33AccessDPT_GetDriveSelectByteToAL:
[421]34    mov     al, [di+DPT.bFlagsLow]
[542]35    and     al, FLGL_DPT_SLAVE | FLGL_DPT_LBA
[150]36    or      al, MASK_DRVNHEAD_SET   ; Bits set to 1 for old drives
37    ret
38
39
40;--------------------------------------------------------------------
41; AccessDPT_GetDeviceControlByteToAL
42;   Parameters:
43;       DS:DI:  Ptr to Disk Parameter Table
44;   Returns:
45;       AL:     Device Control Byte
46;   Corrupts registers:
47;       Nothing
48;--------------------------------------------------------------------
49ALIGN JUMP_ALIGN
50AccessDPT_GetDeviceControlByteToAL:
[411]51%ifdef MODULE_IRQ
[491]52
53%ifndef USE_UNDOC_INTEL
[150]54    xor     al, al
[491]55%endif
56
57    test    BYTE [di+DPT.bFlagsLow], FLGL_DPT_ENABLE_IRQ    ; Clears CF
58
59%ifdef USE_UNDOC_INTEL
60    eSALC   ; Clears AL using CF while preserving flags
61%endif
62
[150]63    jnz     SHORT .EnableDeviceIrq
64    or      al, FLG_DEVCONTROL_nIEN ; Disable IRQ
65.EnableDeviceIrq:
[411]66%else
67    mov     al, FLG_DEVCONTROL_nIEN ; Disable IRQ
[491]68%endif ; MODULE_IRQ
[150]69    ret
70
[227]71
[150]72;--------------------------------------------------------------------
[227]73; AccessDPT_GetLCHStoAXBLBH
[3]74;   Parameters:
75;       DS:DI:  Ptr to Disk Parameter Table
76;   Returns:
[227]77;       AX:     Number of L-CHS cylinders
78;       BL:     Number of L-CHS heads
79;       BH:     Number of L-CHS sectors per track
[3]80;   Corrupts registers:
[421]81;       Nothing
[3]82;--------------------------------------------------------------------
[227]83AccessDPT_GetLCHStoAXBLBH:
[421]84    mov     ax, [di+DPT.wLchsCylinders]
85    mov     bx, [di+DPT.wLchsHeadsAndSectors]
[227]86    ret
[173]87
[227]88
[493]89%ifdef MODULE_8BIT_IDE_ADVANCED
[473]90;--------------------------------------------------------------------
91; AccessDPT_IsThisDeviceXTCF
92;   Parameters:
93;       DS:DI:  Ptr to Disk Parameter Table
94;   Returns:
95;       AH:     Device Type
96;       ZF:     Set if XTCF
97;               Cleared if some other device
98;   Corrupts registers:
99;       Nothing
100;--------------------------------------------------------------------
101AccessDPT_IsThisDeviceXTCF:
102    mov     ah, [di+DPT_ATA.bDevice]
103    cmp     ah, DEVICE_8BIT_XTCF_PIO8
104    je      SHORT .DeviceIsXTCF
[545]105    cmp     ah, DEVICE_8BIT_XTCF_PIO8_WITH_BIU_OFFLOAD
106    je      SHORT .DeviceIsXTCF
[473]107    cmp     ah, DEVICE_8BIT_XTCF_DMA
108.DeviceIsXTCF:
109    ret
[493]110%endif ; MODULE_8BIT_IDE_ADVANCED
[473]111
112
[421]113%ifdef MODULE_EBIOS
[227]114;--------------------------------------------------------------------
[230]115; AccessDPT_GetLbaSectorCountToBXDXAX
116;   Parameters:
117;       DS:DI:  Ptr to Disk Parameter Table
118;   Returns:
119;       BX:DX:AX:   48-bit sector count
120;   Corrupts registers:
121;       Nothing
122;--------------------------------------------------------------------
123AccessDPT_GetLbaSectorCountToBXDXAX:
124    mov     ax, [di+DPT.twLbaSectors]
125    mov     dx, [di+DPT.twLbaSectors+2]
126    mov     bx, [di+DPT.twLbaSectors+4]
127    ret
[421]128%endif ; MODULE_EBIOS
[230]129
130
131;--------------------------------------------------------------------
[3]132; Returns pointer to DRVPARAMS for master or slave drive.
133;
134; AccessDPT_GetPointerToDRVPARAMStoCSBX
135;   Parameters:
136;       DS:DI:  Ptr to Disk Parameter Table
137;   Returns:
138;       CS:BX:  Ptr to DRVPARAMS
139;   Corrupts registers:
140;       Nothing
141;--------------------------------------------------------------------
142AccessDPT_GetPointerToDRVPARAMStoCSBX:
[473]143    call    AccessDPT_GetIdevarsToCSBX
[150]144    add     bx, BYTE IDEVARS.drvParamsMaster    ; CS:BX points to Master Drive DRVPARAMS
[158]145    test    BYTE [di+DPT.bFlagsLow], FLGL_DPT_SLAVE
[150]146    jz      SHORT .ReturnPointerToDRVPARAMS
147    add     bx, BYTE DRVPARAMS_size             ; CS:BX points to Slave Drive DRVPARAMS
148.ReturnPointerToDRVPARAMS:
[3]149    ret
[200]150
[421]151
[200]152;--------------------------------------------------------------------
[473]153; Needed many times during initialization so it is better to
154; make it as a function to save bytes.
155;
156; AccessDPT_GetIdevarsToCSBX
157;   Parameters:
158;       DS:DI:  Ptr to Disk Parameter Table
159;   Returns:
160;       CS:BX:  Ptr to IDEVARS for the drive
161;   Corrupts registers:
162;       Nothing
163;--------------------------------------------------------------------
164AccessDPT_GetIdevarsToCSBX:
165    eMOVZX  bx, BYTE [di+DPT.bIdevarsOffset]
166    ret
167
168
169;--------------------------------------------------------------------
[422]170; ACCESSDPT__GET_UNSHIFTED_TRANSLATE_MODE_TO_AXZF
[200]171;   Parameters:
172;       DS:DI:  Ptr to Disk Parameter Table
173;   Returns:
[422]174;       AX:     Translate Mode (TRANSLATEMODE_NORMAL, TRANSLATEMODE_LARGE or TRANSLATEMODE_ASSISTED_LBA)
[200]175;               unshifted (still shifted where it is in bFlagsLow)
176;       ZF:     Set based on value in AL
177;   Corrupts registers:
[421]178;       Nothing
[200]179;--------------------------------------------------------------------
[230]180;
181; Converted to a macro since only called in two places, and the call/ret overhead
[200]182; is not worth it for these two instructions (4 bytes total)
183;
[422]184%macro ACCESSDPT__GET_UNSHIFTED_TRANSLATE_MODE_TO_AXZF 0
[200]185    mov     al, [di+DPT.bFlagsLow]
[422]186    and     ax, BYTE MASKL_DPT_TRANSLATEMODE
[200]187%endmacro
Note: See TracBrowser for help on using the repository browser.