mirror of
https://github.com/microsoft/MS-DOS.git
synced 2025-01-22 16:50:21 +00:00
198 lines
8.8 KiB
NASM
198 lines
8.8 KiB
NASM
; TITLE MSHEAD.ASM -- MS-DOS DEFINITIONS
|
||
PAGE
|
||
; MS-DOS High-performance operating system for the 8086 version 1.28
|
||
; by Microsoft MSDOS development group:
|
||
; Tim Paterson (Ret.)
|
||
; Aaron Reynolds
|
||
; Nancy Panners (Parenting)
|
||
; Mark Zbikowski
|
||
; Chris Peters (BIOS) (ret.)
|
||
|
||
; ****************** Revision History *************************
|
||
; >> EVERY change must noted below!! <<
|
||
;
|
||
; 0.34 12/29/80 General release, updating all past customers
|
||
; 0.42 02/25/81 32-byte directory entries added
|
||
; 0.56 03/23/81 Variable record and sector sizes
|
||
; 0.60 03/27/81 Ctrl-C exit changes, including register save on user stack
|
||
; 0.74 04/15/81 Recognize I/O devices with file names
|
||
; 0.75 04/17/81 Improve and correct buffer handling
|
||
; 0.76 04/23/81 Correct directory size when not 2^N entries
|
||
; 0.80 04/27/81 Add console input without echo, Functions 7 & 8
|
||
; 1.00 04/28/81 Renumber for general release
|
||
; 1.01 05/12/81 Fix bug in `STORE'
|
||
; 1.10 07/21/81 Fatal error trapping, NUL device, hidden files, date & time,
|
||
; RENAME fix, general cleanup
|
||
; 1.11 09/03/81 Don't set CURRENT BLOCK to 0 on open; fix SET FILE SIZE
|
||
; 1.12 10/09/81 Zero high half of CURRENT BLOCK after all (CP/M programs don't)
|
||
; 1.13 10/29/81 Fix classic "no write-through" error in buffer handling
|
||
; 1.20 12/31/81 Add time to FCB; separate FAT from DPT; Kill SMALLDIR; Add
|
||
; FLUSH and MAPDEV calls; allow disk mapping in DSKCHG; Lots
|
||
; of smaller improvements
|
||
; 1.21 01/06/82 HIGHMEM switch to run DOS in high memory
|
||
; 1.22 01/12/82 Add VERIFY system call to enable/disable verify after write
|
||
; 1.23 02/11/82 Add defaulting to parser; use variable escape character Don't
|
||
; zero extent field in IBM version (back to 1.01!)
|
||
; 1.24 03/01/82 Restore fcn. 27 to 1.0 level; add fcn. 28
|
||
; 1.25 03/03/82 Put marker (00) at end of directory to speed searches
|
||
; 1.26 03/03/82 Directory buffers searched as a circular queue, current buffer
|
||
; is searched first when possible to minimize I/O
|
||
; 03/03/82 STORE routine optimized to tack on partial sector tail as
|
||
; full sector write when file is growing
|
||
; 03/09/82 Multiple I/O buffers
|
||
; 03/29/82 Two bugs: Delete all case resets search to start at beginning
|
||
; of directory (infinite loop possible otherwise), DSKRESET
|
||
; must invalidate all buffers (disk and directory).
|
||
; 1.27 03/31/82 Installable device drivers
|
||
; Function call 47 - Get pointer to device table list
|
||
; Function call 48 - Assign CON AUX LIST
|
||
; 04/01/82 Spooler interrupt (INT 28) added.
|
||
; 1.28 04/15/82 DOS retructured to use ASSUMEs and PROC labels around system
|
||
; call entries. Most CS relative references changed to SS
|
||
; relative with an eye toward putting a portion of the DOS in
|
||
; ROM. DOS source also broken into header, data and code pieces
|
||
; 04/15/82 GETDMA and GETVECT calls added as 24 and 32. These calls
|
||
; return the current values.
|
||
; 04/15/82 INDOS flag implemented for interrupt processing along with
|
||
; call to return flag location (call 29)
|
||
; 04/15/82 Volume ID attribute added
|
||
; 04/17/82 Changed ABORT return to user to a long ret from a long jump to
|
||
; avoid a CS relative reference.
|
||
; 04/17/82 Put call to STATCHK in dispatcher to catch ^C more often
|
||
; 04/20/82 Added INT int_upooler into loop ^S wait
|
||
; 04/22/82 Dynamic disk I/O buffer allocation and call to manage them
|
||
; call 49.
|
||
; 04/23/82 Added GETDSKPTDL as call 50, similar to GETFATPT(DL), returns
|
||
; address of DPB
|
||
; 04/29/82 Mod to WRTDEV to look for ^C or ^S at console input when
|
||
; writting to console device via file I/O. Added a console
|
||
; output attribute to devices.
|
||
; 04/30/82 Call to en/dis able ^C check in dispatcher Call 51
|
||
; 04/30/82 Code to allow assignment of func 1-12 to disk files as well
|
||
; as devices.... pipes, redirection now possible
|
||
; 04/30/82 Expanded GETLIST call to 2.0 standard
|
||
; 05/04/82 Change to INT int_fatal_abort callout int HARDERR. DOS SS
|
||
; (data segment) stashed in ES, INT int_fatal_abort routines must
|
||
; preserve ES. This mod so HARDERR can be ROMed.
|
||
; 1.29 06/01/82 Installable block and character devices as per 2.0 spec
|
||
; 06/04/82 Fixed Bug in CLOSE regarding call to CHKFATWRT. It got left
|
||
; out back about 1.27 or so (oops). ARR
|
||
; 1.30 06/07/82 Directory sector buffering added to main DOS buffer queue
|
||
; 1.40 06/15/82 Tree structured directories. XENIX Path Parser MKDIR CHDIR
|
||
; RMDIR Xenix calls
|
||
; 1.41 06/13/82 Made GETBUFFR call PLACEBUF
|
||
; 1.50 06/17/82 FATs cached in buffer pool, get FAT pointer calls disappear
|
||
; Frees up lots of memory.
|
||
; 1.51 06/24/82 BREAKDOWN modified to do EXACT one sector read/write through
|
||
; system buffers
|
||
; 1.52 06/30/82 OPEN, CLOSE, READ, WRITE, DUP, DUP2, LSEEK implemented
|
||
; 1.53 07/01/82 OPEN CLOSE mod for Xenix calls, saves and gets remote dir
|
||
; 1.54 07/11/82 Function calls 1-12 make use of new 2.0 PDB. Init code
|
||
; changed to set file handle environment.
|
||
; 2.00 08/01/82 Number for IBM release
|
||
; 01/19/83 No environ bug in EXEC
|
||
; 01/19/83 MS-DOS OEM INT 21 extensions (SET_OEM_HANDLER)
|
||
; 01/19/83 Performance bug fix in cooked write to NUL
|
||
; 01/27/83 Growcnt fixed for 32-bits
|
||
; 01/27/83 Find-first problem after create
|
||
; 2.01 02/17/83 International DOS
|
||
; 2.11 08/12/83 Dos split into several more modules for assembly on
|
||
; an IBM PC
|
||
;
|
||
; *************************************************************
|
||
|
||
|
||
SUBTTL EQUATES
|
||
PAGE
|
||
; Interrupt Entry Points:
|
||
|
||
; INTBASE: ABORT
|
||
; INTBASE+4: COMMAND
|
||
; INTBASE+8: BASE EXIT ADDRESS
|
||
; INTBASE+C: CONTROL-C ABORT
|
||
; INTBASE+10H: FATAL ERROR ABORT
|
||
; INTBASE+14H: BIOS DISK READ
|
||
; INTBASE+18H: BIOS DISK WRITE
|
||
; INTBASE+1CH: END BUT STAY RESIDENT (NOT SET BY DOS)
|
||
; INTBASE+20H: SPOOLER INTERRUPT
|
||
; INTBASE+40H: Long jump to CALL entry point
|
||
|
||
ENTRYPOINTSEG EQU 0CH
|
||
MAXDIF EQU 0FFFH
|
||
SAVEXIT EQU 10
|
||
|
||
INCLUDE DOSSYM.ASM
|
||
INCLUDE DEVSYM.ASM
|
||
|
||
SUBTTL ^C, terminate/abort/exit and Hard error actions
|
||
PAGE
|
||
;
|
||
; There are three kinds of context resets that can occur during normal DOS
|
||
; functioning: ^C trap, terminate/abort/exit, and Hard-disk error. These must
|
||
; be handles in a clean fashion that allows nested executions along with the
|
||
; ability to trap one's own errors.
|
||
;
|
||
; ^C trap - A process may elect to catch his own ^Cs. This is achieved by
|
||
; using the $GET_INTERRUPT_VECTOR and $SET_INTERRUPT_VECTOR as
|
||
; follows:
|
||
;
|
||
; $GET_INTERRUPT_VECTOR for INT int_ctrl_c
|
||
; Save it in static memory.
|
||
; $SET_INTERRUPT_VECTOR for INT int_ctrl_c
|
||
;
|
||
; The interrupt service routine must preserve all registers and
|
||
; return carry set iff the operation is to be aborted (via abort
|
||
; system call), otherwise, carry is reset and the operation is
|
||
; restarted. ANY DEVIATION FROM THIS WILL LEAD TO UNRELIABLE
|
||
; RESULTS.
|
||
;
|
||
; To restore original ^C processing (done on terminate/abort/exit),
|
||
; restore INT int_ctrl_c from the saved vector.
|
||
;
|
||
; Hard-disk error -- The interrupt service routine for INT int_fatal_abort must
|
||
; also preserve registers and return one of three values in AL: 0 and
|
||
; 1 imply retry and ignore (???) and 2 indicates an abort. The user
|
||
; himself is not to issue the abort, rather, the dos will do it for
|
||
; him by simulating a normal abort/exit system call. ANY DEVIATION
|
||
; FROM THIS WILL LEAD TO UNRELIABLE RESULTS.
|
||
;
|
||
; terminate/abort/exit -- The user may not, under any circumstances trap an
|
||
; abort call. This is reserved for knowledgeable system programs.
|
||
; ANY DEVIATION FROM THIS WILL LEAD TO UNRELIABLE RESULTS.
|
||
|
||
SUBTTL SEGMENT DECLARATIONS
|
||
PAGE
|
||
|
||
; The following are all of the segments used. They are declared in the order
|
||
; that they should be placed in the executable
|
||
|
||
;
|
||
; segment ordering for MSDOS
|
||
;
|
||
|
||
START SEGMENT BYTE PUBLIC 'START'
|
||
START ENDS
|
||
|
||
CONSTANTS SEGMENT BYTE PUBLIC 'CONST'
|
||
CONSTANTS ENDS
|
||
|
||
DATA SEGMENT WORD PUBLIC 'DATA'
|
||
DATA ENDS
|
||
|
||
CODE SEGMENT BYTE PUBLIC 'CODE'
|
||
CODE ENDS
|
||
|
||
LAST SEGMENT BYTE PUBLIC 'LAST'
|
||
LAST ENDS
|
||
|
||
DOSGROUP GROUP CODE,CONSTANTS,DATA,LAST
|
||
|
||
; The following segment is defined such that the data/const classes appear
|
||
; before the code class for ROMification
|
||
|
||
START SEGMENT BYTE PUBLIC 'START'
|
||
ASSUME CS:DOSGROUP,DS:NOTHING,ES:NOTHING,SS:NOTHING
|
||
JMP DOSINIT
|
||
START ENDS
|
||
|
||
|