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

Last change on this file since 593 was 593, checked in by aitotat, 6 years ago

Flashing now works again.
Hack to get Windows 95 to work properly (MODULE_WIN95_CMOS_HACK included for 386 builds by default).
Edited makefile to produce large 386 build.
Fixed recovery time for QDI Vision VLB-IDE controllers.
No more warnings with Nasm 2.13.xx and later.
File dialog now properly restores default drive when file selection is cancelled.

File size: 4.8 KB
Line 
1; Project name  :   XTIDE Universal BIOS
2; Description   :   Functions for accessing DPT data.
3
4;
5; XTIDE Universal BIOS and Associated Tools
6; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2013 by XTIDE Universal BIOS Team.
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.
12;
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
16; GNU General Public License for more details.
17; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
18;
19
20; Section containing code
21SECTION .text
22
23;--------------------------------------------------------------------
24; AccessDPT_GetDriveSelectByteToAL
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
33AccessDPT_GetDriveSelectByteToAL:
34    mov     al, [di+DPT.bFlagsLow]
35    and     al, FLGL_DPT_SLAVE | FLGL_DPT_LBA
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:
51%ifdef MODULE_IRQ
52
53%ifndef USE_UNDOC_INTEL
54    xor     al, al
55%endif
56
57    test    BYTE [di+DPT.bFlagsLow], FLGL_DPT_ENABLE_IRQ    ; Clears CF
58
59%ifdef USE_UNDOC_INTEL
60    salc    ; Clears AL using CF while preserving flags
61%endif
62
63    jnz     SHORT .EnableDeviceIrq
64    mov     al, FLG_DEVCONTROL_nIEN ; Disable IRQ
65.EnableDeviceIrq:
66%else   ; ifndef MODULE_IRQ
67    mov     al, FLG_DEVCONTROL_nIEN ; Disable IRQ
68%endif ; MODULE_IRQ
69    ret
70
71
72;--------------------------------------------------------------------
73; AccessDPT_GetLCHStoAXBLBH
74;   Parameters:
75;       DS:DI:  Ptr to Disk Parameter Table
76;   Returns:
77;       AX:     Number of L-CHS cylinders
78;       BL:     Number of L-CHS heads
79;       BH:     Number of L-CHS sectors per track
80;   Corrupts registers:
81;       Nothing
82;--------------------------------------------------------------------
83AccessDPT_GetLCHStoAXBLBH:
84    mov     ax, [di+DPT.wLchsCylinders]
85    mov     bx, [di+DPT.wLchsHeadsAndSectors]
86    ret
87
88
89%ifdef MODULE_8BIT_IDE_ADVANCED
90;--------------------------------------------------------------------
91; AccessDPT_IsThisDeviceXTCF
92;   Parameters:
93;       DS:DI:  Ptr to Disk Parameter Table
94;   Returns:
95;       AH:     Device Type
96;       CF:     Cleared if XTCF
97;               Set if some other device
98;   Corrupts registers:
99;       Nothing
100;--------------------------------------------------------------------
101AccessDPT_IsThisDeviceXTCF:
102    mov     ah, [di+DPT_ATA.bDevice]
103    cmp     ah, FIRST_XTCF_DEVICE
104    jb      SHORT .DeviceIsNotXTCF
105    cmp     ah, LAST_XTCF_DEVICE+1
106    cmc
107.DeviceIsNotXTCF:
108    ret
109%endif ; MODULE_8BIT_IDE_ADVANCED
110
111
112%ifdef MODULE_EBIOS
113;--------------------------------------------------------------------
114; AccessDPT_GetLbaSectorCountToBXDXAX
115;   Parameters:
116;       DS:DI:  Ptr to Disk Parameter Table
117;   Returns:
118;       BX:DX:AX:   48-bit sector count
119;   Corrupts registers:
120;       Nothing
121;--------------------------------------------------------------------
122AccessDPT_GetLbaSectorCountToBXDXAX:
123    mov     ax, [di+DPT.twLbaSectors]
124    mov     dx, [di+DPT.twLbaSectors+2]
125    mov     bx, [di+DPT.twLbaSectors+4]
126    ret
127%endif ; MODULE_EBIOS
128
129
130;--------------------------------------------------------------------
131; Returns pointer to DRVPARAMS for master or slave drive.
132;
133; AccessDPT_GetPointerToDRVPARAMStoCSBX
134;   Parameters:
135;       DS:DI:  Ptr to Disk Parameter Table
136;   Returns:
137;       CS:BX:  Ptr to DRVPARAMS
138;   Corrupts registers:
139;       Nothing
140;--------------------------------------------------------------------
141AccessDPT_GetPointerToDRVPARAMStoCSBX:
142    call    AccessDPT_GetIdevarsToCSBX
143    add     bx, BYTE IDEVARS.drvParamsMaster    ; CS:BX points to Master Drive DRVPARAMS
144    test    BYTE [di+DPT.bFlagsLow], FLGL_DPT_SLAVE
145    jz      SHORT .ReturnPointerToDRVPARAMS
146    add     bx, BYTE DRVPARAMS_size             ; CS:BX points to Slave Drive DRVPARAMS
147.ReturnPointerToDRVPARAMS:
148    ret
149
150
151;--------------------------------------------------------------------
152; Needed many times during initialization so it is better to
153; make it as a function to save bytes.
154;
155; AccessDPT_GetIdevarsToCSBX
156;   Parameters:
157;       DS:DI:  Ptr to Disk Parameter Table
158;   Returns:
159;       CS:BX:  Ptr to IDEVARS for the drive
160;   Corrupts registers:
161;       Nothing
162;--------------------------------------------------------------------
163AccessDPT_GetIdevarsToCSBX:
164    eMOVZX  bx, [di+DPT.bIdevarsOffset]
165    ret
166
Note: See TracBrowser for help on using the repository browser.