source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Src/Handlers/Int13h/AH2h_HRead.asm @ 526

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

Changes:

  • Update of the copyright notices to include the year 2013.
File size: 2.3 KB
Line 
1; Project name  :   XTIDE Universal BIOS
2; Description   :   Int 13h function AH=2h, Read Disk Sectors.
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; Int 13h function AH=2h, Read Disk Sectors.
25;
26; AH2h_HandlerForReadDiskSectors
27;   Parameters:
28;       AL, CX, DH, ES: Same as in INTPACK
29;       DL:     Translated Drive number
30;       DS:DI:  Ptr to DPT (in RAMVARS segment)
31;       SS:BP:  Ptr to IDEPACK
32;   Parameters on INTPACK:
33;       AL:     Number of sectors to read (1...128)
34;       CH:     Cylinder number, bits 7...0
35;       CL:     Bits 7...6: Cylinder number bits 9 and 8
36;               Bits 5...0: Starting sector number (1...63)
37;       DH:     Starting head number (0...255)
38;       ES:BX:  Pointer to buffer receiving data
39;   Returns with INTPACK:
40;       AH:     Int 13h/40h floppy return status
41;       AL:     Burst error length if AH returns 11h (we never return error code 11h)
42;               Number of sectors actually read (only valid if CF set for someBIOSes)
43;       CF:     0 if successful, 1 if error
44;--------------------------------------------------------------------
45ALIGN JUMP_ALIGN
46AH2h_HandlerForReadDiskSectors:
47    call    Prepare_BufferToESSIforOldInt13hTransfer
48    call    Prepare_GetOldInt13hCommandIndexToBX
49    mov     ah, [cs:bx+g_rgbReadCommandLookup]
50    mov     bx, TIMEOUT_AND_STATUS_TO_WAIT(TIMEOUT_DRQ, FLG_STATUS_DRQ)
51%ifdef USE_186
52    push    Int13h_ReturnFromHandlerAfterStoringErrorCodeFromAHandTransferredSectorsFromCL
53    jmp     Idepack_TranslateOldInt13hAddressAndIssueCommandFromAH
54%else
55    call    Idepack_TranslateOldInt13hAddressAndIssueCommandFromAH
56    jmp     Int13h_ReturnFromHandlerAfterStoringErrorCodeFromAHandTransferredSectorsFromCL
57%endif
58
Note: See TracBrowser for help on using the repository browser.