home *** CD-ROM | disk | FTP | other *** search
Text File | 1993-04-03 | 330.7 KB | 9,129 lines |
- Interrupt List, part 4 of 8
- This compilation is Copyright (c) 1989,1990,1991,1992,1993 Ralf Brown
- --------D-215F00-----------------------------
- INT 21 - DOS 3.1+ network - GET REDIRECTION MODE
- AX = 5F00h
- BL = redirection type
- 03h printer
- 04h disk drive
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- BH = redirection state
- 00h off
- 01h on
- Note: calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F01h,INT 2F/AX=111Eh
- --------D-215F01-----------------------------
- INT 21 - DOS 3.1+ network - SET REDIRECTION MODE
- AX = 5F01h
- BL = redirection type
- 03h printer
- 04h disk drive
- BH = redirection state
- 00h off
- 01h on
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- Notes: when redirection is off, the local device (if any) rather than the
- remote device is used
- calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F00h,INT 2F/AX=111Eh
- --------D-215F02-----------------------------
- INT 21 - DOS 3.1+ network, Banyan VINES, PC-NFS - GET REDIRECTION LIST ENTRY
- AX = 5F02h
- BX = redirection list index
- CX = 0000h (LANtastic)
- DS:SI -> 16-byte buffer for ASCIZ device name
- ES:DI -> 128-byte buffer for ASCIZ network name
- Return: CF clear if successful
- BH = device status
- 00h valid
- 01h invalid
- BL = device type
- 03h printer
- 04h disk drive
- CX = user data previously set with AX=5F03h
- DS:SI and ES:DI buffers filled
- DX,BP destroyed
- CF set on error
- AX = error code (01h,12h) (see AH=59h)
- Notes: this function is passed through to INT 2F/AX=111Eh
- error code 12h is returned if BX is greater than the size of the list
- also supported by Banyan VINES, PC-NFS, and LANtastic
- SeeAlso: AX=5F03h,INT 2F/AX=111Eh
- --------D-215F03-----------------------------
- INT 21 - DOS 3.1+ network, Banyan VINES, LANtastic - REDIRECT DEVICE
- AX = 5F03h
- BL = device type
- 03h printer
- 04h disk drive
- CX = user data to save
- 0000h for LANtastic
- DS:SI -> ASCIZ local device name (16 bytes max)
- ES:DI -> ASCIZ network name + ASCIZ password (128 bytes max total)
- Return: CF clear if successful
- CF set on error
- AX = error code (01h,03h,05h,08h,0Fh,12h) (see AH=59h)
- Notes: if device type is disk drive, DS:SI must point at either a null string
- or a string consisting the drive letter followed by a colon; if a
- null string, the network attempts to access the destination without
- redirecting a local drive
- calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F02h,AX=5F04h,INT 2F/AX=111Eh
- --------D-215F04-----------------------------
- INT 21 - DOS 3.1+ network, Banyan VINES, LANtastic - CANCEL REDIRECTION
- AX = 5F04h
- DS:SI -> ASCIZ device name or path
- Return: CF clear if successful
- CF set on error
- AX = error code (01h,03h,05h,08h,0Fh,12h) (see AH=59h)
- Notes: the DS:SI string must be either a local device name, a drive letter
- followed by a colon, or a network directory beginning with two
- backslashes
- calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F03h,INT 2F/AX=111Eh
- --------D-215F05-----------------------------
- INT 21 - DOS 4.x + Microsoft Networks - GET REDIRECTION LIST EXTENDED ENTRY
- AX = 5F05h
- BX = redirection list index
- DS:SI -> buffer for ASCIZ source device name
- ES:DI -> buffer for destination ASCIZ network path
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- BH = device status flag (bit 0 clear if valid)
- BL = device type (03h if printer, 04h if drive)
- CX = stored parameter value (user data)
- BP = NETBIOS local session number
- DS:SI buffer filled
- ES:DI buffer filled
- Notes: the local session number allows sharing the redirector's session number
- if an error is caused on the NETBIOS LSN, the redirector may be unable
- to correctly recover from errors
- calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F06h"Network",INT 2F/AX=111Eh
- --------O-215F05-----------------------------
- INT 21 - STARLITE architecture - MAP LOCAL DRIVE LETTER TO REMOTE FILE SYSTEM
- AX = 5F05h
- DL = drive number (0=A:)
- DS:SI -> ASCIZ name of the object to map the drive to
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=5F06h"STARLITE"
- --------N-215F06-----------------------------
- INT 21 U - Network - GET FULL REDIRECTION LIST
- AX = 5F06h
- ???
- Return: ???
- Notes: similar to AX=5F02h and AX=5F05h, but also returns redirections
- excluded from those calls for various reasons
- calls INT 2F/AX=111Eh with AX on top of the stack
- SeeAlso: AX=5F05h"DOS",INT 2F/AX=111Eh
- --------O-215F06-----------------------------
- INT 21 - STARLITE architecture - UNMAP DRIVE LETTER
- AX = 5F06h
- DL = drive to be unmapped (0=A:)
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=5F05h"STARLITE"
- --------D-215F07-----------------------------
- INT 21 - DOS 5+ - ENABLE DRIVE
- AX = 5F07h
- DL = drive number (0=A:)
- Return: CF clear if successful
- CF set on error
- AX = error code (0Fh) (see AH=59h)
- Note: simply sets the "valid" bit in the drive's CDS
- SeeAlso: AH=52h,AX=5F08h"DOS"
- --------O-215F07-----------------------------
- INT 21 - STARLITE architecture - MAKE NAMED OBJECT AVAILABLE ON NETWORK
- AX = 5F07h
- DS:SI -> ASCIZ name of object to offer to network
- ES:DI -> ASCIZ name under which object will be known on the network
- MUST begin with three slashes
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=5F08h"STARLITE"
- --------D-215F08-----------------------------
- INT 21 - DOS 5+ - DISABLE DRIVE
- AX = 5F08h
- DL = drive number (0=A:)
- Return: CF clear if successful
- CF set on error
- AX = error code (0Fh) (see AH=59h)
- Note: simply clears the "valid" bit in the drive's CDS
- SeeAlso: AH=52h,AX=5F07h"DOS"
- --------O-215F08-----------------------------
- INT 21 - STARLITE architecture - REMOVE GLOBAL NETWORK NAME OF OBJECT
- AX = 5F08h
- DS:SI -> ASCIZ network name (not local name) of object to unshare
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=5F07h"STARLITE"
- --------O-215F09-----------------------------
- INT 21 - STARLITE architecture - BIND TO NETWORK DEVICE
- AX = 5F09h
- DS:DX -> ASCIZ name of the device driver to attach to
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- Note: the STARLITE distributed file system can attach to multiple networks
- simultaneously
- SeeAlso: AX=5F0Ah
- --------O-215F0A-----------------------------
- INT 21 - STARLITE architecture - DETACH FROM NETWORK DEVICE
- AX = 5F0Ah
- DS:DX -> ASCIZ name of device driver to detach from
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=5F09h
- --------N-215F30-----------------------------
- INT 21 U - LAN Manager Enhanced DOS - ???
- AX = 5F30h
- ???
- Return: ???
- --------N-215F32-----------------------------
- INT 21 u - Named Pipes - LOCAL DosQNmPipeInfo
- AX = 5F32h
- BX = handle
- CX = size of _PIPEINFO structure
- DX = level (must be 0001h)
- DS:SI -> _PIPEINFO structure (see below)
- Return: CF clear if successful
- _PIPEINFO structure filled in
- CF set on error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F33h,AX=5F34h
-
- Format of _PIPEINFO structure:
- Offset Size Description
- 00h WORD size of outgoing buffer
- 02h WORD size of incoming buffer
- 04h BYTE maximum number of instances allowed
- 05h BYTE current number of instances
- 06h BYTE length of the name (including terminating NUL)
- 07h N BYTEs name
- --------N-215F33-----------------------------
- INT 21 u - Named Pipes - LOCAL DosQNmPHandState
- AX = 5F33h
- BX = handle
- Return: CF clear if successful
- AH = pipe mode bit mask (see below)
- AL = maximum number of instances
- CF set on error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F32h,AX=5F34h
-
- Bitfields for pipe mode:
- bit 7 set if nonblocking, clear if blocking
- bit 6 set if server end, clear if client end
- bit 2 set if write in message mode, clear if write in byte mode
- bit 0 set if read in message mode, clear if read in byte mode
- --------N-215F34-----------------------------
- INT 21 u - Named Pipes - LOCAL DosSetNmPHandState
- AX = 5F34h
- BX = handle
- CX = pipe mode bit mask
- bit 15: set if nonblocking, clear if blocking
- bit 8: set if read in message mode, clear if read in byte mode
- Return: CF clear if successful
- CF set if error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F32h,AX=5F33h,AX=5F36h
- --------N-215F35-----------------------------
- INT 21 u - Named Pipes - LOCAL DosPeekNmPipe
- AX = 5F35h
- BX = handle
- CX = buffer length
- DS:SI -> buffer
- Return: CF clear if successful
- CX = bytes read
- SI = bytes left in the pipe
- DX = bytes left in the current message
- DI = pipe status
- 0001h disconnected
- 0002h listening
- 0003h connected
- 0004h closing
- CF set if error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F38h,AX=5F39h,AX=5F51h
- --------N-215F36-----------------------------
- INT 21 u - Named Pipes - LOCAL DosTransactNmPipe
- AX = 5F36h
- BX = handle
- CX = in buffer length
- DS:SI -> in buffer
- DX = out buffer length
- ES:DI -> out buffer
- Return: CF clear if successful
- CX = bytes read
- CF set on error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F34h,AX=5F37h
- --------N-215F37-----------------------------
- INT 21 u - Named Pipes - DosCallNmPipe
- AX = 5F37h
- DS:SI -> DosCallNmPipe stack frame (see below)
- Return: CF clear if successful
- CX = bytes read
- CF set on error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F36h,AX=5F38h
-
- Format of DosCallNmPipe stack frame:
- Offset Size Description
- 00h DWORD timeout
- 04h DWORD -> bytes read WORD (not used!!)
- 08h WORD out buffer length
- 0Ah DWORD address of out buffer
- 0Eh WORD in buffer length
- 10h DWORD address of in buffer
- 14h DWORD address of pipe name
- --------N-215F38-----------------------------
- INT 21 u - Named Pipes - LOCAL DosWaitNmPipe
- AX = 5F38h
- DS:DX -> pipe name
- BX:CX = timeout value
- Return: CF clear if successful
- CF set if error
- AX = error code
- Note: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- SeeAlso: AX=5F37h,AX=5F39h
- --------N-215F39-----------------------------
- INT 21 U - Named Pipes - LOCAL DosRawReadNmPipe
- AX = 5F39h
- BX = handle
- CX = buffer length
- DS:DX -> buffer
- Return: CF clear if successful
- CX = bytes read
- CF set if error
- AX = error code
- Notes: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- not documented in the LAN Manager Toolkit
- SeeAlso: AX=5F35h,AX=5F3Ah,INT 2F/AX=1186h
- --------N-215F3A-----------------------------
- INT 21 U - Named Pipes - LOCAL DosRawWriteNmPipe
- AX = 5F3Ah
- BX = handle
- CX = buffer length
- DS:DX -> buffer
- Return: CF clear if successful
- CX = bytes written
- CF set if error
- AX = error code
- Notes: this function was introduced by LAN Manager but is also supported by
- the Novell DOS Named Pipe Extender, Banyan VINES, OS/2 Virtual DOS
- Machines, and others
- not documented in the LAN Manager Toolkit
- SeeAlso: AX=5F39h,AX=5F3Bh,INT 2F/AX=118Fh
- --------N-215F3B-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - NetHandleSetInfo
- AX = 5F3Bh
- BX = handle
- CX = handle_info_1 structure length or sizeof DWORD
- DI = parameter number to set
- 0000h all
- 0001h number of milliseconds
- 0002h number of characters
- DS:DX -> handle_info_1 structure (DI=0000h) (see below)
- or DWORD (DI=0001h or 0002h)
- SI = level of information (0001h)
- Return: CF clear if successful
- CX = total bytes available
- CF set if error
- AX = error code
- SeeAlso: AX=5F3Ch
-
- Format of handle_info_1 structure:
- Offset Size Description
- 00h DWORD number of milliseconds which workstations collects data before
- it sends the data to the named pipe
- 04h DWORD number of characters which workstations collects before it
- sends the data to the named pipe
- --------N-215F3C-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - NetHandleGetInfo
- AX = 5F3Ch
- BX = handle
- CX = length of handle_info_1 structure
- DS:DX -> handle_info_1 structure (see AX=5F3Bh)
- SI = level of information (must be 0001h)
- Return: CF clear if successful
- CX = total bytes available
- CF set if error
- AX = error code
- SeeAlso: AX=5F3Bh
- --------N-215F3D-----------------------------
- INT 21 U - LAN Manager Enhanced DOS - WRITE MAILSLOT???
- AX = 5F3Dh
- ???
- Return: ???
- --------N-215F3E-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetSpecialSMB
- AX = 5F3Eh
- ???
- Return: ???
- Note: This function is not documented anywhere in the LAN Manager 2.x Toolkit
- but was documented in LAN Manager 1.x manuals.
- --------N-215F3F-----------------------------
- INT 21 U - LAN Manager Enhanced DOS - REMOTE API CALL
- AX = 5F3Fh
- CX = api number
- ES:DI -> data descriptor
- ES:SI -> parameter descriptor
- ES:DX -> auxiliary descriptor (if DX <> 0)
- ???
- Return: ???
- --------N-215F40-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetMessageBufferSend
- AX = 5F40h
- DS:DX -> NetMessageBufferSend parameter structure (see below)
- Return: AX = error code
-
- Format of NetMessageBufferSend parameter structure:
- Offset Size Description
- 00h DWORD -> recipient name (name for specific user, name* for domain
- name wide, * for broadcast)
- 04h DWORD -> buffer
- 08h WORD length of buffer
- --------N-215F41-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetServiceEnum
- AX = 5F41h
- BL = level of detail (0000h, 0001h or 0002h)
- CX = buffer length
- ES:DI -> buffer of service_info_0, service_info_1, or service_info_2
- (see below)
- Return: CF clear if successful
- CX = entries read
- DX = total available
- CF set on error
- AX = error code
-
- Format of service_info_0 structure:
- Offset Size Description
- 00h 16 BYTEs name
-
- Format of service_info_1 structure:
- Offset Size Description
- 00h 16 BYTEs name
- 10h WORD status bitmask (see below)
- 12h DWORD status code (see below)
- (also see Microsoft LAN Manager Programmer's Reference)
- 16h WORD process id
-
- Format of service_info_2 structure:
- Offset Size Description
- 00h 16 BYTEs name
- 10h WORD status bitmask (see below)
- 12h DWORD status code (see below)
- 16h WORD process id
- 18h 64 BYTEs text
-
- Bitfields for status bitmask:
- bits 0,1 00 uninstall
- 01 install pending
- 10 uninstall pending
- 11 installed
- bits 2,3 00 active
- 01 Continue pending
- 10 Pause pending
- 11 paused
- bit 4 uninstallable
- bit 5 pausable
- bit 8 disk redirector paused
- bit 9 spooled device redirector paused (printing)
- bit 10 communication device redirector paused
-
- Values for status code:
- high word
- 3051 Bad parameter value
- 3052 A parameter is missing
- 3053 An unknown parameter was specified
- 3054 The resource is insufficient
- 3055 Configuration is faulty
- 3056 An MS-DOS or MS OS/2 error occured
- 3057 An internal error occured
- 3058 An ambiguous parameter name was given
- 3059 A duplicate parameter exists
- 3060 The service was terminated by NetSeviceControl when it did not respond
- 3061 The service program file could not be executed
- 3062 The subservice failed to start
- 3063 There is a conflict in the value or use of these parameters
- 3064 There is a problem with the file
- low word
- 3070 There is insufficient memory
- 3071 There is insufficeient disk space
- 3072 Unable to create thread
- 3073 Unable to create process
- 3074 A security failure occured
- 3075 There is bad or missing default path
- 3076 Network software is not installed
- 3077 Server software is not installed
- 3078 The server could not access the UAS database
- 3079 The action requires user-level security
- 3080 The log directory is invalid
- 3081 The LAN group specificed could not be used
- 3082 The computername is being used as a message alias on another computer
- 3083 The workstation failed to announce the servername
- 3084 The user accounts system is not configured properly
- --------N-215F42-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetServiceControl
- AX = 5F42h
- DH = opcode
- 00h interrogate status
- 01h pause
- 02h continue
- 03h uninstall
- DL = argument
- 01h disk resource
- 02h print resource
- 04h communications resource (not implemented for DOS)
- ES:BX -> NetServiceControl parameter structure (see below)
- Return: CF clear if successful
- CF set on error
- AX = error code
-
- Format of NetServiceControl parameter structure:
- Offset Size Description
- 00h DWORD -> service name
- 04h WORD result buffer size
- 06h DWORD -> result buffer as service_info_2 structure
- --------N-215F43-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL DosPrintJobGetId
- AX = 5F43h
- BX = handle of remote print job
- CX = size of PRIDINFO struture
- ES:DI -> PRIDINFO structure (see below)
- Return: CF clear if successful
- PRIDINFO filled in
- CF set on error
- AX = error code
-
- Format of PRIDINFO structure:
- Offset Size Description
- 00h WORD job id
- 02h 16 BYTEs server name
- 12h 13 BYTEs queue name
- 1Fh 1 BYTE pad
- --------N-215F44-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetWkstaGetInfo
- AX = 5F44h
- BX = information level (00h, 01h, or 0Ah)
- CX = buffer size
- ES:DI = buffer in which to store info
- Return: AX = error code
- DX = amount of buffer used (or required)
- SeeAlso: AX=5F45h,AX=5F49h
- --------N-215F45-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetWkstaSetInfo
- AX = 5F45h
- BX = level (0000h or 0001h)
- CX = buffer size
- DX = parameter to set
- ES:DI -> buffer
- Return: CF clear if successful
- CF set if error
- AX = error code
- SeeAlso: AX=5F44h
- --------N-215F46-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetUseEnum
- AX = 5F46h
- BX = level (0000h or 0001h)
- CX = size of buffer
- ES:DI -> buffer of use_info_0 or use_info_1 structures (see below)
- Return: CF clear if successful
- CX = entries read
- DX = total available entries
- CF set if error
- AX = error code
- SeeAlso: AX=5F47h,AX=5F48h,AX=5F4Ch
-
- Format of use_info_0 structure:
- Offset Size Description
- 00h 9 BYTEs local device name
- 09h BYTE padding
- 0Ah DWORD -> remote device name in UNC form \\server\share
-
- Format of use_info_1 structure:
- Offset Size Description
- 00h 9 BYTEs Local device name
- 09h BYTE padding
- 0Ah DWORD -> remote device name in UNC form \\server\share
- 0Eh DWORD -> password
- 10h WORD ignored
- 12h WORD use type (-1 wildcard, 0 disk, 1 print, 2 com, 3 ipc)
- 14h WORD ignored
- 16h WORD ignored
- --------N-215F47-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetUseAdd
- AX = 5F47h
- BX = level (0001h)
- CX = size of use_info_1 structure
- ES:DI -> use_info_1 structure (see AX=5F46h)
- Return: CF clear on success
- CF set on error
- AX = error code
- SeeAlso: AX=5F46h,AX=5F48h
- --------N-215F48-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetUseDel
- AX = 5F48h
- BX = force level
- 0000h no force
- 0001h force
- 0002h lots of force
- ES:DI -> buffer as either the local device name or UNC remote name
- Return: CF clear on success
- CF set on error
- AX = error code
- SeeAlso: AX=5F46h,AX=5F48h,AX=5F49h
- --------N-215F49-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - NetUseGetInfo
- AX = 5F49h
- DS:DX -> NetUseGetInfo parameter structure
- Return: CF clear on success
- DX = total available
- CF set on error
- AX = error code
- SeeAlso: AX=5F44h,AX=5F47h
-
- Format of NetUseGetInfo parameter structure:
- Offset Size Description
- 00h DWORD pointer to either the local device name or UNC remote name
- 04h WORD level of information (0000h or 0001h)
- 06h DWORD pointer to buffer of use_info_0 or use_info_1 structures
- 0Ah WORD length of buffer
- --------N-215F4A-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetRemoteCopy
- AX = 5F4Ah
- DS:DX -> NetRemoteCopy parameter structure
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Bh
-
- Format of NetRemoteCopy parameter structure:
- Offset Size Description
- 00h DWORD -> source name as UNC
- 04h DWORD -> destination name as UNC
- 08h DWORD -> source password
- 0Ch DWORD -> destination password
- 10h WORD destination open bitmap
- if destination path exists
- 0000h open fails
- 0001h file is appended
- 0002h file is overwritten
- if destination path doesn't exist
- 0000h open fails
- 0010h file is created
- 12h WORD copy control bitmap (see below)
- 14h DWORD -> copy_info buffer
- 18h WORD length of copy_info buffer
-
- Bitfields for copy control:
- bit 0 destination must be a file
- bit 1 destination must be a directory
- bit 2 destination is opened in ascii mode instead of binary
- bit 3 source is opened in ascii mode instead of binary
- bit 4 verify all write operations
- --------N-215F4B-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetRemoteMove
- AX = 5F4Bh
- DS:DX -> NetRemoteMove parameter structure
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Ah
-
- Format of NetRemoteMove parameter structure:
- Offset Size Description
- 00h DWORD -> source name as UNC
- 04h DWORD -> destination name as UNC
- 08h DWORD -> source password
- 0Ch DWORD -> destination password
- 10h WORD destination open bitmap
- if destination path exists
- 0000h open fails
- 0001h file is appended
- 0002h file is overwritten
- if destination path doesn't exist
- 0000h open fails
- 0010h file is created
- 12h WORD move control bitmap
- 0001h destination must be a file
- 0002h destination must be a directory
- 14h DWORD -> move_info buffer
- 18h WORD length of move_info buffer
- --------N-215F4C-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - LOCAL NetServerEnum
- AX = 5F4Ch
- BX = level (0000h or 0001h)
- CX = buffer length
- ES:DI -> buffer in which to store information
- Return: CF clear if successful
- ES:DI -> server_info_X structures (depending on level) (see below)
- BX = entries read
- CX = total entries available
- CF set on error
- AX = error code
- Notes: this function is also supported by the Novell DOS Named Pipe Extender
- this function has been obseleted by NetServerEnum2
- SeeAlso: AX=5F53h
-
- Format of server_info_0 structure:
- Offset Size Description
- 00h 16 BYTEs name
-
- Format of server_info_1 structure:
- Offset Size Description
- 00h 16 BYTEs name
- 10h BYTE major version in lower nibble
- 11h BYTE minor version
- 12h DWORD server type bitmask (see below)
- 16h DWORD -> comment string
-
- Bitfields for server type:
- bit 0 workstation
- bit 1 server
- bit 2 SQL server
- bit 3 primary domain controller
- bit 4 backup domain controller
- bit 5 time server
- bit 6 Apple File Protocol (AFP) server
- bit 7 Novell server
- bit 8 Domain Member (v2.1+)
- bit 9 Print Queue server (v2.1+)
- bit 10 Dialin server (v2.1+)
- bit 11 Unix server (v2.1+)
- --------N-215F4D-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosMakeMailslot
- AX = 5F4Dh
- BX = message size
- CX = mailslot size (must be bigger than message size by at least 1)
- (minimum 1000h, maximum FFF6h)
- (buffer must be 9 bytes bigger than this)
- DS:SI -> name
- ES:DI -> memory buffer
- Return: CF clear if successful
- AX = handle
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Eh,AX=5F4Fh,AX=5F50h,AX=5F51h
- --------N-215F4E-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosDeleteMailslot
- AX = 5F4Eh
- BX = handle
- Return: CF clear if successful
- ES:DI -> memory to be freed (allocated during DosMakeMailslot)
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Dh,AX=5F4Fh
- --------N-215F4F-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosMailslotInfo
- AX = 5F4Fh
- BX = handle
- Return: CF clear if successful
- AX = max message size
- BX = mailslot size
- CX = next message size
- DX = next message priority
- SI = number of messages waiting
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Dh,AX=5F4Eh,AX=5F50h
- --------N-215F50-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosReadMailslot
- AX = 5F50h
- BX = handle
- DX:CX = timeout
- ES:DI -> buffer
- Return: CF clear if successful
- AX = bytes read
- CX = next item's size
- DX = next item's priority
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Dh,AX=5F4Fh,AX=5F51h,AX=5F52h
- --------N-215F51-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosPeekMailslot
- AX = 5F51h
- BX = handle
- ES:DI -> buffer
- Return: CF clear if successful
- AX = bytes read
- CX = next item's size
- DX = next item's priority
- CF set on error
- AX = error code
- SeeAlso: AX=5F35h,AX=5F4Fh,AX=5F50h,AX=5F52h
- --------N-215F52-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - DosWriteMailslot
- AX = 5F52h
- BX = class
- CX = length of buffer
- DX = priority
- ES:DI -> DosWriteMailslot parameter structure (see below)
- DS:SI -> mailslot name
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Fh,AX=5F50h,AX=5F51h
-
- Format of DosWriteMailslot parameter structure:
- Offset Size Description
- 00h DWORD timeout
- 04h DWORD -> buffer
- --------N-215F53-----------------------------
- INT 21 u - LAN Manager Enhanced DOS - NetServerEnum2
- AX = 5F53h
- DS:SI -> NetServerEnum2 parameter structure (see below)
- Return: CF clear if successful
- BX = entries read
- CX = total entries available
- CF set on error
- AX = error code
- SeeAlso: AX=5F4Ch
-
- Format of NetServerEnum2 parameter structure:
- Offset Size Description
- 00h WORD level (0000h or 0001h)
- 02h DWORD -> buffer as array of server_info_??? structures
- 06h WORD length of buffer
- 08h DWORD server type bitmask (see below)
- 0Ch DWORD -> Domain name (may be 0000h:0000h for all local domains)
-
- Bitfields for server type:
- bit 0 workstation
- bit 1 server
- bit 2 SQL server
- bit 3 primary domain controller
- bit 4 backup domain controller
- bit 5 time server
- bit 6 Apple File Protocol (AFP) server
- bit 7 Novell server
- bit 8 Domain Member (v2.1+)
- bit 9 Print Queue server (v2.1+)
- bit 10 Dialin server (v2.1+)
- bit 11 Unix server (v2.1+)
- Note: set all bits (FFFFFFFFh) for All Types
-
- Format of server_info_0 structure:
- Offset Size Description
- 00h 16 BYTEs name
-
- Format of server_info_1 structure:
- Offset Size Description
- 00h 16 BYTEs name
- 10h BYTE major version in lower nibble
- 11h BYTE minor version
- 12h DWORD server type (bits 0-11) (see above)
- 16h DWORD -> comment string
- --------N-215F55----------------------------
- INT 21 U - LAN Manager Enhanced DOS - KILL ALL CONNECTIONS???
- AX = 5F55h
- BX = ???
- Return: CF clear if successful
- CF set on error
- AX = error code
- --------N-215F80-----------------------------
- INT 21 - LANtastic - GET LOGIN ENTRY
- AX = 5F80h
- BX = login entry index (0-based)
- ES:DI -> 16-byte buffer for machine name
- Return: CF clear if successful
- buffer filled with machine name ("\\" prefix removed)
- DL = adapter number (v3+)
- CF set on error
- AX = error code
- Note: the login entry index corresponds to the value BX used in AX=5F83h
- SeeAlso: AX=5F83h
- --------N-215F81-----------------------------
- INT 21 - LANtastic - LOGIN TO SERVER
- AX = 5F81h
- ES:DI -> ASCIZ login path followed immediately by ASCIZ password
- BL = adapter number
- FFh try all valid adapters
- 00h-07h try only specified adapter
- Return: CF clear if successful
- CF set on error
- AX = error code
- Notes: login path is of form "\\machine\username"
- if no password is used, the string at ES:DI must be terminated with
- three NULs for compatibility with LANtastic v3.0.
- SeeAlso: AX=5F82h,AX=5F84h
- --------N-215F82-----------------------------
- INT 21 - LANtastic - LOGOUT FROM SERVER
- AX = 5F82h
- ES:DI -> ASCIZ server name (in form "\\machine")
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F81h,AX=5F88h,AX=5FCBh
- --------N-215F83-----------------------------
- INT 21 - LANtastic - GET USERNAME ENTRY
- AX = 5F83h
- BX = login entry index (0-based)
- ES:DI -> 16-byte buffer for username currently logged into
- Return: CF clear if successful
- DL = adapter number (v3+)
- CF set on error
- AX = error code
- Note: the login entry index corresponds to the value BX used in AX=5F80h
- SeeAlso: AX=5F80h
- --------N-215F84-----------------------------
- INT 21 - LANtastic - GET INACTIVE SERVER ENTRY
- AX = 5F84h
- BX = server index not currently logged into
- ES:DI -> 16-byte buffer for server name which is available for logging
- in to ("\\" prefix omitted)
- Return: CF clear if successful
- DL = adapter number to non-logged in server is on
- CF set on error
- AX = error code
- SeeAlso: AX=5F81h
- --------N-215F85-----------------------------
- INT 21 - LANtastic - CHANGE PASSWORD
- AX = 5F85h
- ES:DI -> buffer containing "\\machine\oldpassword" 00h "newpassword"00h
- Return: CF clear if successful
- CF set on error
- AX = error code
- Notes: must be logged into the named machine
- this function is illegal for group accounts
- --------N-215F86-----------------------------
- INT 21 - LANtastic - DISABLE ACCOUNT
- AX = 5F86h
- ES:DI -> ASCIZ machine name and password in form "\\machine\password"
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: must be logged into the named machine and concurrent logins set to 1
- by NET_MGR. Requires system manager to re-enable account.
- --------N-215F87-----------------------------
- INT 21 - LANtastic v3+ - GET ACCOUNT
- AX = 5F87h
- DS:SI -> 128-byte buffer for account information (see below)
- ES:DI -> ASCIZ machine name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX destroyed
- Note: must be logged into the specified machine
-
- Format of user account structure:
- Offset Size Description
- 00h 16 BYTEs blank-padded username (zero-padded for v4.x)
- 10h 16 BYTEs reserved (00h)
- 20h 32 BYTEs user description
- 40h BYTE privilege bits (see below)
- 41h BYTE maximum concurrent users
- 42h 42 BYTEs bit map for disallowed half hours, beginning on Sunday
- (bit set if half-hour not an allowed time)
- 6Ch WORD internal (0002h)
- 6Eh 2 WORDs last login time
- 72h 2 WORDs account expiration date (MS-DOS-format year/month:day)
- 76h 2 WORDs password expiration date (0 = none)
- 7Ah BYTE number of days to extend password after change (1-31)
- 00h if no extension required
- ---v3.x---
- 7Bh 5 BYTEs reserved
- ---v4.x---
- 7Bh BYTE storage for first letter of user name when deleted (first
- character is changed to 00h when deleting account)
- 7Ch BYTE extended privileges
- 7Dh 3 BYTEs reserved
-
- Bitfields for privilege bits:
- bit 7 bypass access control lists
- bit 6 bypass queue protection
- bit 5 treat as local process
- bit 4 bypass mail protection
- bit 3 allow audit entry creation
- bit 2 system manager
- bit 0 user cannot change password
- --------N-215F88-----------------------------
- INT 21 - LANtastic v4.0+ - LOGOUT FROM ALL SERVERS
- AX = 5F88h
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F82h
- --------N-215F97-----------------------------
- INT 21 - LANtastic - COPY FILE
- AX = 5F97h
- CX:DX = number of bytes to copy (FFFFFFFFh = entire file)
- SI = source file handle
- DI = destination file handle
- Return: CF clear if successful
- DX:AX = number of bytes copied
- CF set on error
- AX = error code
- Note: copy is performed by server
- --------N-215F98-----------------------------
- INT 21 - LANtastic - SEND UNSOLICITED MESSAGE
- AX = 5F98h
- DS:SI -> message buffer (see below)
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: v4.1- return no errors
- SeeAlso: AX=5F99h
-
- Format of message buffer:
- Offset Size Description
- 00h BYTE reserved
- 01h BYTE message type
- 00h general
- 01h server warning
- 02h-7Fh reserved
- 80h-FFh user-defined
- 02h 16 BYTEs ASCIZ destination machine name
- 12h 16 BYTEs ASCIZ server name which user must be logged into
- 22h 16 BYTEs ASCIZ user name
- 32h 16 BYTEs ASCIZ originating machine name (filled in when received)
- 42h 80 BYTEs message text
- --------N-215F99-----------------------------
- INT 21 - LANtastic - GET LAST RECEIVED UNSOLICITED MESSAGE
- AX = 5F99h
- ES:DI -> messsage buffer (see AX=5F98h for format)
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F98h
- --------N-215F9A-----------------------------
- INT 21 - LANtastic - GET MESSAGE PROCESSING FLAGS
- AX = 5F9Ah
- Return: CF clear if successful
- DL = bits describing processing for received unsolicited messages
- bit 0: beep before message is delivered
- bit 1: deliver message to message service
- bit 2: pop up message automatically (v3+)
- CF set on error
- AX = error code
- SeeAlso: AX=5F9Bh,AX=5F9Ch,AX=5F9Dh
- --------N-215F9B-----------------------------
- INT 21 - LANtastic - SET MESSAGE PROCESSING FLAG
- AX = 5F9Bh
- DL = bits describing processing for received unsolicited messages
- (see AX=5F9Ah)
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5F9Ah,AX=5F9Eh
- --------N-215F9C-----------------------------
- INT 21 - LANtastic v3+ - POP UP LAST RECEIVED MESSAGE
- AX = 5F9Ch
- CX = time to leave on screen in clock ticks
- DH = 0-based screen line on which to place message
- Return: CF clear if successful
- CF set on error
- AX = error code (0Bh)
- Notes: the original screen contents are restored when the message is removed
- the message will not appear, and an error will be returned, if the
- screen is in a graphics mode
- SeeAlso: AX=5F9Ah
- --------N-215F9D-----------------------------
- INT 21 - LANtastic v4.1+ - GET REDIRECTOR CONTROL BITS
- AX = 5F9Dh
- Return: DL = redirector control bits
- bit 7: set to notify on print job completion
- SeeAlso: AX=5F9Ah,AX=5F9Eh
- --------N-215F9E-----------------------------
- INT 21 - LANtastic v4.1+ - SET REDIRECTOR CONTROL BITS
- AX = 5F9Eh
- DL = redirector control bits (see AH = 5F9Dh)
- Return: nothing
- SeeAlso: AX=5F9Bh,AX=5F9Dh
- --------N-215FA0-----------------------------
- INT 21 - LANtastic - GET QUEUE ENTRY
- AX = 5FA0h
- BX = queue entry index (0000h is first entry)
- DS:SI -> buffer for queue entry (see below)
- ES:DI -> ASCIZ server name in form "\\name"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX = entry index for next queue entry (BX-1 is current index)
- SeeAlso: AX=5FA1h,AX=5FA2h
-
- Format of queue entry:
- Offset Size Description
- 00h BYTE status of entry
- 00h empty
- 01h being updated
- 02h being held
- 03h waiting for despool
- 04h being despooled
- 05h canceled
- 06h spooled file could not be accessed
- 07h destination could not be accessed
- 08h rush job
- 01h DWORD size of spooled file
- 05h BYTE type of entry
- 00h printer queue file
- 01h message
- 02h local file
- 03h remote file
- 04h to remote modem
- 05h batch processor file
- 06h BYTE output control
- bit 6: don't delete (for mail)
- bit 5: mail file contains voice mail (v3+)
- bit 4: mail message has been read
- bit 3: response has been requested for this mail
- 07h WORD number of copies
- 09h DWORD sequence number of queue entry
- 0Dh 48 BYTEs pathname of spooled file
- 3Dh 16 BYTEs user who spooled file
- 4Dh 16 BYTEs name of machine from which file was spooled
- 5Dh WORD date file was spooled (see AX=5700h)
- 5Fh WORD time file was spooled (see AX=5700h)
- 61h 17 BYTEs ASCIZ destination device or user name
- 72h 48 BYTEs comment field
- --------N-215FA1-----------------------------
- INT 21 - LANtastic - SET QUEUE ENTRY
- AX = 5FA1h
- BX = handle of opened queue entry
- DS:SI -> queue entry (see AX=5FA0h)
- Return: CF clear if successful
- CF set on error
- AX = error code
- Notes: the only queue entry fields which may be changed are output control,
- number of copies, destination device, and comment
- the handle in BX is that from a create or open (INT 21/AH=3Ch,3Dh)
- call on the file "\\server\\@MAIL" or "\\server\@name" (for
- printer queue entries)
- SeeAlso: AX=5FA0h,AX=5FA2h,AX=5FA9h
- --------N-215FA2-----------------------------
- INT 21 - LANtastic - CONTROL QUEUE
- AX = 5FA2h
- BL = control command
- 00h start despooling (privileged)
- 01h halt despooling (privileged)
- 02h halt despooling at end of job (privileged)
- 03h pause despooler at end of job (privileged)
- 04h print single job (privileged)
- 05h restart current job (privileged)
- 06h cancel the current job
- 07h hold queue entry
- 08h release a held queue entry
- 09h make queue entry a rushed job (privileged)
- CX:DX = sequence number to control (commands 06h-09h)
- DX = physical printer number (commands 00h-05h)
- 00h-02h LPT1-LPT3
- 03h,04h COM1,COM2
- other all printers
- ES:DI -> ASCIZ server name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- --------N-215FA3-----------------------------
- INT 21 - LANtastic v3+ - GET PRINTER STATUS
- AX = 5FA3h
- BX = physical printer number (00h-02h = LPT1-LPT3, 03h-04h = COM1-COM2)
- DS:SI -> buffer for printer status (see below)
- ES:DI -> ASCIZ server name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX = next physical printer number
- Note: you must be logged in to the specified server
-
- Format of printer status:
- Offset Size Description
- 00h BYTE printer state
- bit 7: printer paused
- bits 0-6: 0 printer disabled
- 1 will stop at end of job
- 2 print multiple jobs
- 01h WORD queue index of print job being despooled
- FFFFh if not despooling--ignore all following fields
- 03h WORD actual characters per second being output
- 05h DWORD number of characters actually output so far
- 09h DWORD number of bytes read from spooled file so far
- 0Dh WORD copies remaining to print
- --------N-215FA4-----------------------------
- INT 21 - LANtastic v3+ - GET STREAM INFO
- AX = 5FA4h
- BX = 0-based stream index number
- DS:SI -> buffer for stream information (see below)
- ES:DI -> ASCIZ machine name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX = next stream number
- SeeAlso: AX=5FA5h
-
- Format of stream information:
- Offset Size Description
- 00h BYTE queueing of jobs for logical printer (0=disabled,other=enabled)
- 01h 11 BYTEs logical printer resource template (may contain ? wildcards)
- --------N-215FA5-----------------------------
- INT 21 - LANtastic v3+ - SET STREAM INFO
- AX = 5FA5h
- BX = 0-based stream index number
- DS:SI -> buffer containing stream information (see AX=5FA4h)
- ES:DI -> ASCIZ machine name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5FA4h
- --------N-215FA7-----------------------------
- INT 21 - LANtastic - CREATE USER AUDIT ENTRY
- AX = 5FA7h
- DS:DX -> ASCIZ reason code (max 8 bytes)
- DS:SI -> ASCIZ variable reason string (max 128 bytes)
- ES:DI -> ASCIZ machine name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: you must be logged in to the specified server and have the "U"
- privilege to execute this call
- --------N-215FA9-----------------------------
- INT 21 - LANtastic v4.1+ - SET EXTENDED QUEUE ENTRY
- AX = 5FA9h
- BX = handle of opened queue entry
- DS:SI -> queue entry (see AX=5FA0h)
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: functions exactly the same as AX=5FA1h except the spooled filename is
- also set. This call supports direct despooling.
- SeeAlso: AX=5FA1h
- --------N-215FB0-----------------------------
- INT 21 - LANtastic - GET ACTIVE USER INFORMATION
- AX = 5FB0h
- BX = server login entry index
- DS:SI -> buffer for active user entry (see below)
- ES:DI -> ASCIZ machine name in form "\\server"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX = next login index
- SeeAlso: AX=5FB2h
-
- Format of active user entry:
- Offset Size Description
- 00h WORD virtual circuit number
- 02h BYTE login state (see below)
- 03h BYTE last command issued (see below)
- 04h 5 BYTEs number of I/O bytes (40-bit unsigned number)
- 09h 3 BYTEs number of server requests (24-bit unsigned)
- 0Ch 16 BYTEs name of user who is logged in
- 1Ch 16 BYTEs name of remote logged in machine
- 2Ch BYTE extended privileges (v4+???)
- bit 0: user cannot change his password
- 2Dh WORD time left in minutes (0000h = unlimited) (v4+???)
-
- Bitfields for login state:
- bit 0 fully logged in
- bit 1 remote program load login
- bit 2 user has system manager privileges
- bit 3 user can create audit entries
- bit 4 bypass mail protection
- bit 5 treat as local process
- bit 6 bypass queue protection
- bit 7 bypass access control lists
-
- Values for last command:
- 00h login
- 01h process termination
- 02h open file
- 03h close file
- 04h create file
- 05h create new file
- 06h create unique file
- 07h commit data to disk
- 08h read file
- 09h write file
- 0Ah delete file
- 0Bh set file attributes
- 0Ch lock byte range
- 0Dh unlock byte range
- 0Eh create subdirectory
- 0Fh remove subdirectory
- 10h rename file
- 11h find first matching file
- 12h find next matching file
- 13h get disk free space
- 14h get a queue entry
- 15h set a queue entry
- 16h control the queue
- 17h return login information
- 18h return link description
- 19h seek on file
- 1Ah get server's time
- 1Bh create audit entry
- 1Ch open file in multitude of modes
- 1Dh change password
- 1Eh disable account
- 1Fh local server file copy
- ---v3+---
- 20h get username from account file
- 21h translate server's logical path
- 22h make indirect file
- 23h get indirect file contents
- 24h get physical printer status
- 25h get logical print stream info
- 26h set logical print stream info
- 27h get user's account record
- ---v4+---
- 28h request server shutdown
- 29h cancel server shutdown
- 2Ah stuff server's keyboard
- 2Bh write then commit data to disk
- 2Ch set extended queue entry
- 2Dh terminate user from server
- 2Eh enable/disable logins
- 2Fh flush server caches
- 30h change username
- 31h get extended queue entry
- (same as get queue, but can return named fields blanked)
- --------N-215FB1-----------------------------
- INT 21 - LANtastic - GET SHARED DIRECTORY INFORMATION
- AX = 5FB1h
- DS:SI -> 64-byte buffer for link description
- ES:DI -> ASCIZ machine and shared directory name in form
- "\\machine\shared-resource"
- Return: CF clear if successful
- CX = access control list privileges for requesting user (see below)
- CF set on error
- AX = error code
-
- Bitfields for access control list:
- bit 4 (I) allow expansion of indirect files
- bit 5 (A) allow attribute changing
- bit 6 (P) allow physical access to device
- bit 7 (E) allow program execution
- bit 8 (N) allow file renaming
- bit 9 (K) allow directory deletion
- bit 10 (D) allow file deletion
- bit 11 (L) allow file/directory lookups
- bit 12 (M) allow directory creation
- bit 13 (C) allow file creation
- bit 14 (W) allow open for write and writing
- bit 15 (R) allow open for read and reading
- --------N-215FB2-----------------------------
- INT 21 - LANtastic v3+ - GET USERNAME FROM ACCOUNT FILE
- AX = 5FB2h
- BX = username entry index (0 for first)
- DS:SI -> 16-byte buffer for username
- ES:DI -> ASCIZ server name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- BX = next queue entry index
- SeeAlso: AX=5FB0h
- --------N-215FB3-----------------------------
- INT 21 - LANtastic v3+ - TRANSLATE PATH
- AX = 5FB3h
- DS:SI -> 128-byte buffer for ASCIZ result
- ES:DI -> full ASCIZ path, including server name
- DX = types of translation to be performed
- bit 0: expand last component as indirect file
- bit 1: return actual path relative to server's physical disk
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: always expands any indirect files along the path
- SeeALso: AX=5FB4h,INT 21/AH=60h
- --------N-215FB4-----------------------------
- INT 21 - LANtastic v3+ - CREATE INDIRECT FILE
- AX = 5FB4h
- DS:SI -> 128-byte buffer containing ASCIZ contents of indirect file
- ES:DI -> full ASCIZ path of indirect file to create, incl machine name
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: the contents of the indirect file may be any valid server-relative path
- SeeAlso: AX=5FB3h,AX=5FB5h
- --------N-215FB5-----------------------------
- INT 21 - LANtastic v3+ - GET INDIRECT FILE CONTENTS
- AX = 5FB5h
- DS:SI -> 128-byte buffer for ASCIZ indirect file contents
- ES:DI -> full ASCIZ path of indirect file
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5FB4h
- --------N-215FB6-----------------------------
- INT 21 - LANtastic v4.1+ - SET AUTO-LOGIN DEFAULTS
- AX = 5FB6h
- ES:DI -> pointer to ASCIZ default user name, immediately followed by
- ASCIZ password
- BL = adapter number to use for default login attempt
- FFh try all valid adapters
- 00h-05h try adapter 0-5 explicitly
- Return: CF clear if successful
- CF set on error
- AX = error code
- Notes: call with ES:DI -> two nulls to disable auto-login
- SeeAlso: AX=5FB7h
- --------N-215FB7-----------------------------
- INT 21 - LANtastic v4.1+ - GET AUTO-LOGIN DEFAULTS
- AX = 5FB7h
- ES:DI -> pointer to 16-byte buffer to store ASCIZ auto-login user name
- Return: CF clear if successful
- DL = adapter number used for default login attempt
- FFh all valid adapters will be tried
- 00h-05h specified adapter will be tried explicitly
- CF set on error
- AX = error code
- SeeAlso: AX=5F81h,AX=5FB6h
- --------N-215FC0-----------------------------
- INT 21 - LANtastic - GET TIME FROM SERVER
- AX = 5FC0h
- DS:SI -> time block (see below)
- ES:DI -> ASCIZ server name to get time from
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AH=E7h
-
- Format of time block:
- Offset Size Description
- 00h WORD year
- 02h BYTE day
- 03h BYTE month
- 04h BYTE minutes
- 05h BYTE hour
- 06h BYTE hundredths of second
- 07h BYTE second
- --------N-215FC8-----------------------------
- INT 21 - LANtastic v4.0+ - SCHEDULE SERVER SHUTDOWN
- AX = 5FC8h
- ES:DI -> ASCIZ server name in form "\\machine"
- DS:SI -> ASCIZ reason string (80 characters)
- CX = number of minutes until shutdown (0 = immediate)
- DX = option flags (see below)
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AH=5FC9h
-
- Bitfields for option flags:
- bit 0 auto reboot
- bit 1 do not notify users
- bit 2 halt after shutdown
- bit 3 shutdown due to power fail (used by UPS)
- bits 4-7 reserved
- bits 8-14 user definable
- bit 15 reserved
- --------N-215FC9-----------------------------
- INT 21 - LANtastic v4.0+ - CANCEL SERVER SHUTDOWN
- AX = 5FC9h
- ES:DI -> ASCIZ server name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: you must have the "S" privilege to use this call
- SeeAlso: AH=5FC8h
- --------N-215FCA-----------------------------
- INT 21 - LANtastic v4.0+ - STUFF SERVER KEYBOARD BUFFER
- AX = 5FCAh
- ES:DI -> ASCIZ server name in form "\\machine"
- DS:SI -> ASCIZ string to stuff (128 bytes)
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: you must have the "S" privilege to use this call
- maximum number of characters that can be stuffed is determined by the
- server's RUN BUFFER SIZE.
- SeeAlso: INT 16/AH=05h
- --------N-215FCB-----------------------------
- INT 21 - LANtastic v4.1+ - TERMINATE USER
- AX = 5FCBh
- ES:DI -> ASCIZ server name in form "\\machine"
- DS:SI -> blank-padded username. A null char = wildcard.
- DS:DX -> blank-padded machine name. A null char = wildcard.
- CX = minutes until termination (0 = immediate)
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: you must have the "S" privilege to use this call
- you cannot log yourself out using this call
- SeeAlso: AX=5F82h
- --------N-215FCC-----------------------------
- INT 21 - LANtastic v4.1+ - GET/SET SERVER CONTROL BITS
- AX = 5FCCh
- ES:DI -> ASCIZ server name in form "\\machine"
- CX = bit values (value of bits you want to set) (see below)
- DX = bit mask (bits you are interested in, 0 = get only) (see below)
- Return: CF clear if successful
- CX = control bits after call
- bit 0: disable logins
- CF set on error
- AX = error code
- Note: you must have the "S" privilege to SET, anyone can GET.
- --------N-215FCD-----------------------------
- INT 21 - LANtastic v4.1+ - FLUSH SERVER CACHES
- AX = 5FCDh
- ES:DI -> ASCIZ server name in form "\\machine"
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: you must have the "S" privilege to use this call.
- --------N-215FD0-----------------------------
- INT 21 - LANtastic - GET REDIRECTED PRINTER TIMEOUT
- AX = 5FD0h
- Return: CF clear if successful
- CX = redirected printer timeout in clock ticks of 55ms
- 0000h if timeout disabled
- CF set on error
- AX = error code
- SeeAlso: AX=5FD1h
- --------N-215FD1-----------------------------
- INT 21 - LANtastic - SET REDIRECTED PRINTER TIMEOUT
- AX = 5FD1h
- CX = printer timeout in clock ticks of 55ms, 0000h to disable timeouts
- Return: CF clear if successful
- CF set on error
- AX = error code
- SeeAlso: AX=5FD0h
- --------N-215FE0-----------------------------
- INT 21 C - LANtastic - GET DOS SERVICE VECTOR
- AX = 5FE0h
- Return: CF clear if successful
- ES:BX -> current FAR service routine
- CF set on error
- AX = error code
- Note: the service routine is called by the LANtastic redirector whenever DOS
- may safely be called, permitting external TSRs and drivers to hook
- into LANtastic's DOS busy flag checking
- SeeAlso: AX=5FE1h,INT 28,INT 2A/AH=84h
- --------N-215FE1-----------------------------
- INT 21 - LANtastic - SET DOS SERVICE VECTOR
- AX = 5FE1h
- ES:BX -> FAR routine to call when DOS services are available
- Return: CF clear if successful
- CF set on error
- AX = error code
- Note: new handler must chain to previous handler as its first action
- SeeAlso: AX=5FE0h
- --------N-215FE2-----------------------------
- INT 21 - LANtastic - GET MESSAGE SERVICE VECTOR
- AX = 5FE2h
- Return: CF clear if successful
- ES:BX -> current FAR message service routine
- CF set on error
- AX = error code
- SeeAlso: AX=5FE0h,AX=5FE3h
- --------N-215FE3-----------------------------
- INT 21 - LANtastic - SET MESSAGE SERVICE VECTOR
- AX = 5FE3h
- ES:BX -> FAR routine for processing network messages
- Return: CF clear if successful
- CF set on error
- AX = error code
- Notes: handler must chain to previous handler as its first action
- on invocation, ES:BX -> just-received message
- SeeAlso: AX=5FE2h
- --------D-2160-------------------------------
- INT 21 - DOS 3.0+ - "TRUENAME" - CANONICALIZE FILENAME OR PATH
- AH = 60h
- DS:SI -> ASCIZ filename or path
- ES:DI -> 128-byte buffer for canonicalized name
- Return: CF set on error
- AX = error code
- 02h invalid component in directory path or drive letter only
- 03h malformed path or invalid drive letter
- ES:DI buffer unchanged
- CF clear if successful
- AH = 00h
- AL = destroyed (00h or 5Ch or last char of current dir on drive)
- buffer filled with qualified name of form D:\PATH\FILE.EXT or
- \\MACHINE\PATH\FILE.EXT
- Desc: determine the canonical name of the specified filename or path,
- corresponding to the undocumented TRUENAME command in COMMAND.COM
- Notes: the input path need not actually exist
- letters are uppercased, forward slashes converted to backslashes,
- asterisks converted to appropriate number of question marks, and
- file and directory names are truncated to 8.3 if necessary.
- '.' and '..' in the path are resolved
- filespecs on local drives always start with "d:", those on network
- drives always start with "\\"
- if path string is on a JOINed drive, the returned name is the one that
- would be needed if the drive were not JOINed; similarly for a
- SUBSTed, ASSIGNed, or network drive letter. Because of this, it is
- possible to get a qualified name that is not legal under the current
- combination of SUBSTs, ASSIGNs, JOINs, and network redirections
- under DOS 3.3 through 6.00, a device name is translated differently if
- the device name does not have an explicit directory or the directory
- is \DEV (relative directory DEV from the root directory works
- correctly). In these cases, the returned string consists of the
- unchanged device name and extension appended to the string X:/
- (forward slash instead of backward slash as in all other cases) where
- X is the default or explicit drive letter.
- functions which take pathnames require canonical paths if invoked via
- INT 21/AX=5D00h
- supported by OS/2 v1.1 compatibility box
- NetWare 2.1x does not support characters with the high bit set; early
- versions of NetWare 386 support such characters except in this call.
- In addition, NetWare returns error code 3 for the path "X:\"; one
- should use "X:\." instead.
- for DOS 3.3-6.0, the input and output buffers may be the same, as the
- canonicalized name is built in an internal buffer and copied to the
- specified output buffer as the very last step
- for DR DOS 6.0, this function is not automatically called when on a
- network. Device drivers reportedly cannot make this call from their
- INIT function. Using the same pointer for both input and output
- buffers is not supported in the April 1992 and earlier versions of
- DR DOS
- SeeAlso: AX=5FB3h,INT 2F/AX=1123h,INT 2F/AX=1221h
- --------D-2161-------------------------------
- INT 21 - DOS 3+ - UNUSED
- AH = 61h
- Return: AL = 00h
- Note: this function does nothing and returns immediately
- --------O-2161-------------------------------
- INT 21 U - OS/2 v1.x FAPI - OS/2 FILE SYSTEM FUNCTION
- AH = 61h
- details not yet available
- Notes: used by JOIN and SUBST to communicate with the OS/2 file system
- also supported by OS/2 v2.0+ Virtual DOS Machines
- --------D-2162-------------------------------
- INT 21 - DOS 3+ - GET CURRENT PSP ADDRESS
- AH = 62h
- Return: BX = segment of PSP for current process
- Notes: under DOS 3+, this function does not use any of the DOS-internal stacks
- and may thus be called at any time, even during another INT 21h call
- the current PSP is not necessarily the caller's PSP
- identical to the undocumented AH=51h
- SeeAlso: AH=50h,AH=51h
- --------D-216300-----------------------------
- INT 21 - DOS 2.25 only - GET LEAD BYTE TABLE ADDRESS
- AX = 6300h
- Return: CF clear if successful
- DS:SI -> lead byte table (see below)
- CF set on error
- AX = error code (01h) (see AH=59h)
- Notes: does not preserve any registers other than SS:SP
- the US version of MS-DOS 3.30 treats this as an unused function,
- setting AL=00h and returning immediately
- SeeAlso: AX=6301h,AH=07h,AH=08h,AH=0Bh
-
- Format of lead byte table entry:
- Offset Size Description
- 00h 2 BYTEs low/high ends of a range of leading byte of double-byte chars
- 02h 2 BYTEs low/high ends of a range of leading byte of double-byte chars
- ...
- N 2 BYTEs 00h,00h end flag
- --------D-216300-----------------------------
- INT 21 - Far East DOS 3.2+ - GET DOUBLE BYTE CHARACTER SET LEAD-BYTE TABLE
- AX = 6300h
- Return: AL = error code
- 00h successful
- DS:SI -> DBCS table (see below)
- all other registers except CS:IP and SS:SP destroyed
- FFh not supported
- Notes: probably identical to AH=63h/AL=00h for DOS 2.25
- the US version of MS-DOS 3.30 treats this as an unused function,
- setting AL=00h and returning immediately
- the US version of DOS 4.0+ accepts this function, but returns an empty
- list
- SeeAlso: AX=6300h"DOS 2.25"
-
- Format of DBCS table:
- Offset Size Description
- 00h 2 BYTEs low/high ends of a range of leading byte of double-byte chars
- 02h 2 BYTEs low/high ends of a range of leading byte of double-byte chars
- ...
- N 2 BYTEs 00h,00h end flag
- --------D-216301-----------------------------
- INT 21 - DOS 2.25, Far East DOS 3.2+ - SET KOREAN (HANGEUL) INPUT MODE
- AX = 6301h
- DL = new mode
- 00h return only full characters on DOS keyboard input functions
- 01h return partially-formed (interim) characters also
- Return: AL = status
- 00h successful
- FFh invalid mode
- SeeAlso: AH=07h,AH=08h,AH=0Bh,AH=63h,AX=6302h
- --------D-216302-----------------------------
- INT 21 - DOS 2.25, Far East DOS 3.2+ - GET KOREAN (HANGEUL) INPUT MODE
- AX = 6302h
- Return: AL = status
- 00h successful
- DL = current input mode
- 00h return only full characters (clears interim flag)
- 01h return partial characters (sets interim flag)
- FFh not supported
- SeeAlso: AH=07h,AH=08h,AH=0Bh,AH=63h,AX=6301h
- --------D-2164-------------------------------
- INT 21 - DOS 3.2+ internal - SET DEVICE DRIVER LOOKAHEAD FLAG
- AH = 64h
- AL = flag
- 00h (default) call device driver function 5 (non-dest read)
- before INT 21/AH=01h,08h,0Ah
- nonzero don't call driver function 5
- Return: nothing (MS-DOS)
- CF set, AX=error code??? (DR-DOS 5.0, which does not support this call)
- Notes: called by DOS 3.3+ PRINT.COM
- under MS-DOS, this function does not use any of the DOS-internal stacks
- and may thus be called at any time, even during another DOS call
- SeeAlso: AH=01h,AH=08h,AH=0Ah,AX=5D06h
- --------O-2164--DX0000-----------------------
- INT 21 U - OS/2 v2.0+ Virtual DOS Machine - ENABLE AUTOMATIC TITLE SWITCH
- AH = 64h
- DX = 0000h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- Note: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- SeeAlso: AH=64h/BX=0001h,INT 21/AH=4Bh
- --------O-2164--DX0001-----------------------
- INT 21 U - OS/2 v2.0+ Virtual DOS Machine - SET SESSION TITLE
- AH = 64h
- DX = 0001h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- ES:DI -> new ASCIZ title (max 12 char) or "" to restore default title
- Note: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- SeeAlso: AH=64h/BX=0000h,AH=64h/BX=0002h,INT 15/AH=12h/BH=05h
- --------O-2164--DX0002-----------------------
- INT 21 U - OS/2 v2.0+ Virtual DOS Machine - GET SESSION TITLE
- AH = 64h
- DX = 0002h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- ES:DI -> 13-byte buffer for current title
- Return: buffer filled (single 00h if title never changed)
- Note: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- SeeAlso: AH=64h/BX=0000h,AH=64h/BX=0001h,INT 15/AH=12h/BH=05h
- --------O-2164--DX0003-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - GET LASTDRIVE
- AH = 64h
- DX = 0003h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- Return: AL = highest drive supported
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- used by WinOS2
- --------O-2164--DX0004-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - GET SIZE OF PTDA JFT
- AH = 64h
- DX = 0004h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- Return: AX = number of entries in OS/2 JFT for VDM
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- in an OS/2 VDM, the DOS Job File Table in the PSP contains an index
- into the OS/2 JFT in the Per-Task Data Area rather than an SFT index
- because the OS/2 SFT can contain more than 255 entries
- --------O-2164--DX0005-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - GET SECOND SFT FLAGS WORD
- AH = 64h
- DX = 0005h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- DI = DOS file handle
- Return: AX = value of second flags word from OS/2 SFT entry for file
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- the OS/2 SFT has two flags words rather than DOS's one word, and this
- function provides access to the word which is not present in DOS
- --------O-2164--DX0006-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - UNLOAD DOSKRNL SYMBOLS & LOAD PROGR
- AH = 64h
- DX = 0006h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- ES:DI -> ASCIZ filespec
- DS = base address for loading
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- this function is only supported by the kernel debugging version of
- OS2KRNL
- --------O-2164--DX0007-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - GET WinOS2 CALL GATE ADDRESS
- AH = 64h
- DX = 0007h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- Return: AX = call gate address
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- used by WinOS2 to make direct calls to OS2KRNL, bypassing the overhead
- of DOSKRNL
- --------O-2164--DX0008-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - GET LOADING MESSAGE
- AH = 64h
- DX = 0008h (function number)
- CX = 636Ch (magic value, "cl")
- BX = 0000h (indicates special request)
- Return: DS:DX -> '$'-terminated message "Loading. Please wait."
- Notes: if CX is not 636Ch on entry, INT 21/AH=6Ch is invoked, because a bug
- in OS/2 1.x FAPI erroneously called AH=64h instead of AH=6Ch
- this function permits National Language Support for the initial message
- displayed while WinOS2 starts a full-screen session
- --------O-2164--CX636C-----------------------
- INT 21 U - OS/2 v2.1+ Virtual DOS Machine - OS/2 API support
- AH = 64h
- CX = 636Ch ("cl")
- BX = API ordinal
- 0025h DOS32StartSession
- 0082h DosGetCP
- 00A7h DosQFSAttach
- 00BFh DosEditName
- 00CBh DosForceDelete
- 0144h Dos32CreateEventSem
- 0145h Dos32OpenEvenSem
- 0146h Dos32CloseEventSem
- 0147h Dos32ResetEventSem
- 0148h Dos32PostEventSem
- 0152h Dos32OpenMuxWaitSem
- 0153h Dos32WaitMuxWaitSem
- 0154h Dos32CloseMuxWaitSem
- other registers as appropriate for API call
- Return: as appropriate for API call
- --------D-2165-------------------------------
- INT 21 - DOS 3.3+ - GET EXTENDED COUNTRY INFORMATION
- AH = 65h
- AL = info ID
- 01h get general internationalization info
- 02h get pointer to uppercase table
- 04h get pointer to filename uppercase table
- 05h get pointer to filename terminator table
- 06h get pointer to collating sequence table
- 07h (DOS 4+) get pointer to Double-Byte Character Set table
- BX = code page (FFFFh=global code page)
- DX = country ID (FFFFh=current country)
- ES:DI -> country information buffer (see below)
- CX = size of buffer (>= 5)
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if succesful
- CX = size of country information returned
- ES:DI -> country information
- Notes: AL=05h appears to return same info for all countries and codepages; it
- has been documented for DOS 5+, but was undocumented in ealier
- versions
- NLSFUNC must be installed to get info for countries other than the
- default
- subfunctions 02h and 04h are identical under OS/2
- SeeAlso: AH=38h,INT 2F/AX=1401h,INT 2F/AX=1402h,INT 2F/AX=14FEh
-
- Format of country information:
- Offset Size Description
- 00h BYTE info ID
- ---if info ID = 01h---
- 01h WORD size
- 03h WORD country ID
- 05h WORD code page
- 07h 34 BYTEs country-dependent info (see AH=38h)
- ---if info ID = 02h---
- 01h DWORD pointer to uppercase table (see below)
- ---if info ID = 04h---
- 01h DWORD pointer to filename uppercase table (see below)
- ---if info ID = 05h---
- 01h DWORD pointer to filename character table (see below)
- ---if info ID = 06h---
- 01h DWORD pointer to collating table (see below)
- ---if info ID = 07h (DOS 4+)---
- 01h DWORD pointer to DBCS lead byte table (see below)
-
- Format of uppercase table:
- Offset Size Description
- 00h WORD table size
- 02h 128 BYTEs uppercase equivalents (if any) of chars 80h to FFh
-
- Format of collating table:
- Offset Size Description
- 00h WORD table size
- 02h 256 BYTEs values used to sort characters 00h to FFh
-
- Format of filename terminator table:
- Offset Size Description
- 00h WORD table size (not counting this word)
- 02h BYTE ??? (01h for MS-DOS 3.30-6.00)
- 03h BYTE lowest permissible character value for filename
- 04h BYTE highest permissible character value for filename
- 05h BYTE ??? (00h for MS-DOS 3.30-6.00)
- 06h BYTE first excluded character in range \ all characters in this
- 07h BYTE last excluded character in range / range are illegal
- 08h BYTE ??? (02h for MS-DOS 3.30-6.00)
- 09h BYTE number of illegal (terminator) characters
- 0Ah N BYTES characters which terminate a filename: ."/\[]:|<>+=;,
- Note: partially documented for DOS 5+, but undocumented for earlier versions
-
- Format of filename uppercase table:
- Offset Size Description
- 00h WORD table size
- 02h 128 BYTEs uppercase equivalents (if any) of chars 80h to FFh
-
- Format of DBCS lead byte table:
- Offset Size Description
- 00h WORD length
- 02h 2N BYTEs start/end for N lead byte ranges
- WORD 0000h (end of table)
- --------D-2165-------------------------------
- INT 21 - DOS 4+ - COUNTRY-DEPENDENT CHARACTER CAPITALIZATION
- AH = 65h
- AL = function
- 20h capitalize character
- DL = character to capitalize
- Return: DL = capitalized character
- 21h capitalize string
- DS:DX -> string to capitalize
- CX = length of string
- 22h capitalize ASCIZ string
- DS:DX -> ASCIZ string to capitalize
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- Note: these calls have been documented for DOS 5+, but were undocumented in
- DOS 4.x.
- --------D-216523-----------------------------
- INT 21 U - DOS 4+ internal - DETERMINE IF CHARACTER REPRESENTS YES/NO RESPONSE
- AX = 6523h
- DL = character
- DH = second character of double-byte character (if applicable)
- Return: CF set on error
- CF clear if successful
- AX = type
- 00h no
- 01h yes
- 02h neither yes nor no
- --------D-2165-------------------------------
- INT 21 U - DOS 4+ internal - COUNTRY-DEPENDENT FILENAME CAPITALIZATION
- AH = 65h
- AL = function
- A0h capitalize filename character
- DL = character to capitalize
- Return: DL = capitalized character
- A1h capitalize counted filename string
- DS:DX -> filename string to capitalize
- CX = length of string
- A2h capitalize ASCIZ filename
- DS:DX -> ASCIZ filename to capitalize
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- Note: nonfunctional in DOS 4.00 through 6.00 due to a bug (the code sets a
- pointer depending on the high bit of AL, but doesn't clear the
- bit before branching by function number).
- --------D-216601-----------------------------
- INT 21 - DOS 3.3+ - GET GLOBAL CODE PAGE TABLE
- AX = 6601h
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- BX = active code page (see AX=6602h)
- DX = system code page
- SeeAlso: AX=6602h
- --------D-216602-----------------------------
- INT 21 - DOS 3.3+ - SET GLOBAL CODE PAGE TABLE
- AX = 6602h
- BX = active code page (see below)
- DX = system code page (active page at boot time)
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- SeeAlso: AX=6601h,INT 2F/AX=14FFh
-
- Values for code page:
- 437 US
- 850 Multilingual
- 852 Slavic/Latin II (DOS 5+)
- 857 Turkish
- 860 Portugal
- 861 Iceland
- 863 Canada (French)
- 865 Norway/Denmark
- --------D-2167-------------------------------
- INT 21 - DOS 3.3+ - SET HANDLE COUNT
- AH = 67h
- BX = size of new file handle table for process
- Return: CF clear if successful
- CF set on error
- AX = error code (see AH=59h)
- Desc: adjust the size of the per-process open file table, thus raising or
- lowering the limit on the number of files the caller can open
- simultaneously
- Notes: if BX <= 20, no action is taken if the handle limit has not yet been
- increased, and the table is copied back into the PSP if the limit
- is currently > 20 handles
- for file handle tables of > 20 handles, DOS 3.30 never reuses the
- same memory block, even if the limit is being reduced; this can lead
- to memory fragmentation as a new block is allocated and the existing
- one freed
- only the first 20 handles are copied to child processes in DOS 3.3-6.0
- increasing the file handles here will not, in general, increase the
- number of files that can be opened using the runtime library of a
- high-level language such as C
- BUG: the original release of DOS 3.30 allocates a full 64K for the handle
- table on requests for an even number of handles
- SeeAlso: AH=26h,AH=86h
- --------D-2168-------------------------------
- INT 21 - DOS 3.3+ - "FFLUSH" - COMMIT FILE
- AH = 68h
- BX = file handle
- Return: CF clear if successful
- all data still in DOS disk buffers is written to disk immediately,
- and the file's directory entry is updated
- CF set on error
- AX = error code (see AH=59h)
- SeeAlso: AX=5D01h,AH=6Ah,INT 2F/AX=1107h
- --------D-2169-------------------------------
- INT 21 U - DOS 4+ internal - GET/SET DISK SERIAL NUMBER
- AH = 69h
- AL = subfunction
- 00h get serial number
- 01h set serial number
- BL = drive (0=default, 1=A, 2=B, etc)
- DS:DX -> disk info (see below)
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- AX destroyed
- (AL = 00h) buffer filled with appropriate values from extended BPB
- (AL = 01h) extended BPB on disk set to values from buffer
- Notes: does not generate a critical error; all errors are returned in AX
- error 0005h given if no extended BPB on disk
- does not work on network drives (error 0001h)
- buffer after first two bytes is exact copy of bytes 27h thru 3Dh of
- extended BPB on disk
- this function is supported under Novell NetWare versions 2.0A through
- 3.11; the returned serial number is the one a DIR would display,
- the volume label is the NetWare volume label, and the file system
- is set to "FAT16".
- the serial number is computed from the current date and time when the
- disk is created; the first part is the sum of the seconds/hundredths
- and month/day, the second part is the sum of the hours/minutes and
- year
- the volume label which is read or set is the one stored in the extended
- BPB on disks formatted with DOS 4.0+, rather than the special root
- directory entry used by the DIR command in COMMAND.COM (use AH=11h
- to find that volume label)
- SeeAlso: AX=440Dh
-
- Format of disk info:
- Offset Size Description
- 00h WORD info level (zero)
- 02h DWORD disk serial number (binary)
- 06h 11 BYTEs volume label or "NO NAME " if none present
- 11h 8 BYTEs (AL=00h only) filesystem type--string "FAT12 " or "FAT16 "
- --------O-2169-------------------------------
- INT 21 - DR-DOS 5.0 - NULL FUNCTION
- AH = 69h
- Return: AL = 00h
- SeeAlso: AH=18h
- --------v-216969-----------------------------
- INT 21 - VIRUS - "Rape-747" - INSTALLATION CHECK
- AX = 6969h
- Return: AX = 0666h if resident
- SeeAlso: AX=58CCh,AH=76h"VIRUS"
- --------D-216A-------------------------------
- INT 21 U - DOS 4+ - COMMIT FILE
- AH = 6Ah
- BX = file handle
- Return: CF clear if successful
- AH = 68h
- CF set on error
- AX = error code (06h) (see AH=59h)
- Note: identical to AH=68h in DOS 5.0-6.0; not known whether this is the case
- in DOS 4.x
- SeeAlso: AH=68h
- --------D-216B-------------------------------
- INT 21 U - DOS 4.0 internal - ???
- AH = 6Bh
- AL = subfunction
- 00h ???
- DS:SI -> Current Directory Structure???
- CL = drive (1=A:)
- 01h ???
- DS:SI -> ???
- CL = file handle???
- 02h ???
- DS:SI -> Current Directory Structure???
- DI = ???
- CX = drive (1=A:)
- Return: CF set on error
- AX = error code (see INT 21/AH=59h)
- CF clear if successful
- Note: passed through to INT 2F/AX=112Fh with AX on top of stack
- SeeAlso: AH=6Bh"DOS 5",INT 2F/AX=112Fh
- --------D-216B-------------------------------
- INT 21 U - DOS 5+ - NULL FUNCTION
- AH = 6Bh
- Return: AL = 00h
- Note: this function does nothing and returns immediately
- SeeAlso: AH=6Bh"DOS 4"
- --------D-216C00-----------------------------
- INT 21 - DOS 4+ - EXTENDED OPEN/CREATE
- AX = 6C00h
- BL = open mode as in AL for normal open (see INT 21/AH=3Dh)
- bit 7: inheritance
- bits 4-6: sharing mode
- bit 3 reserved
- bits 0-2: access mode
- BH = flags
- bit 6 = auto commit on every write (see also AH=68h)
- bit 5 = return error rather than doing INT 24h
- CX = create attribute
- bits 6-15 reserved
- bit 5: archive
- bit 4: reserved
- bit 3: volume label
- bit 2: system
- bit 1: hidden
- bit 0: readonly
- DL = action if file exists/does not exists
- bits 7-4 action if file does not exist
- 0000 fail
- 0001 create
- bits 3-0 action if file exists
- 0000 fail
- 0001 open
- 0010 replace/open
- DH = 00h (reserved)
- DS:SI -> ASCIZ file name
- Return: CF set on error
- AX = error code (see AH=59h)
- CF clear if successful
- AX = file handle
- CX = status
- 1 file opened
- 2 file created
- 3 file replaced
- Note: the PC LAN Program only supports DL=01h, DL=10h/sharing=compatibility,
- and DL=12h
- SeeAlso: AH=3Ch,AH=3Dh,AX=6C01h
- --------O-216C01-----------------------------
- INT 21 U - OS/2 v2.0 - "DosOpen2"
- AX = 6C01h
- ???
- Return: ???
- Note: this function is similar to AX=6C00h, but supports OS/2's extended
- attributes
- SeeAlso: AX=6C00h,AH=6Fh
- --------O-216D-------------------------------
- INT 21 U - OS/2 v1.x FAPI - "DosMkDir2"
- AH = 6Dh
- ???
- Return: ???
- Note: also supported by OS/2 v2.0+ Virtual DOS Machines
- SeeAlso: AH=39h
- --------O-216E-------------------------------
- INT 21 U - OS/2 v1.x FAPI - "DosENumAttrib"
- AH = 6Eh
- ???
- Return: ???
- Note: also supported by OS/2 v2.0+ Virtual DOS Machines
- --------O-216F-------------------------------
- INT 21 U - OS/2 v1.x FAPI - "DosQMaxEASize" - GET MAXIMUM SIZE OF EXTENDED ATTR
- AH = 6Fh
- ???
- Return: ???
- Note: also supported by OS/2 v2.0+ Virtual DOS Machines
- SeeAlso: AX=6C01h
- ----------217070BX6060-----------------------
- INT 21 - PCW Weather Card interface - GET DATA SEGMENT
- AX = 7070h
- BX = 6060h
- CX = 7070h
- DX = 7070h
- SX = 7070h
- DX = 7070h
- Return: AX = segment of data structure
- Notes: the data structure is at offset 516 from this segment.
- the update byte is at offset 514 from this segment. Updates are
- once per second while this byte is nonzero and it is decremented
- once per second. While this byte is 0 updates are once per minute.
- SeeAlso: AX=7070h/BX=7070h
-
- Format of data structure:
- Offset Type Description
- 00h WORD hour
- 02h WORD minute
- 04h WORD second
- 06h WORD day
- 08h WORD month
- 0Ah WORD year
- 0Ch WORD ???
- 0Eh WORD relative barometric pressure (in 1/100 inches)
- 10h WORD ???
- 12h WORD ???
- 14h WORD temperature 1 (in 1/10 degrees F)
- 16h WORD temperature 1 lowest (in 1/10 degrees F)
- 18h WORD temperature 1 highest (in 1/10 degrees F)
- 1Ah WORD temperature 2 (in 1/10 degrees F)
- 1Ch WORD temperature 2 lowest (in 1/10 degrees F)
- 1Eh WORD temperature 2 highest (in 1/10 degrees F)
- 20h WORD wind speed (in MPH)
- 22h WORD average of 60 wind speed samples (in MPH)
- 24h WORD highest wind speed (in MPH)
- 26h WORD wind chill factor (in 1/10 degrees F)
- 28h WORD lowest wind chill factor (in 1/10 degrees F)
- 2Ah WORD ???
- 2Ch WORD wind direction (in degrees)
- 2Eh WORD accumulated daily rainfall (in 1/10 inches)
- 30h WORD accumulated annual rainfall (in 1/10 inches)
- ----------217070BX7070-----------------------
- INT 21 - PCW Weather Card interface - INSTALLATION CHECK
- AX = 7070h
- BX = 7070h
- CX = 7070h
- DX = 7070h
- SX = 7070h
- DX = 7070h
- Return: AX = 0070h
- BX = 0070h
- CX = 0070h
- DX = 0070h
- SX = 0070h
- DX = 0070h
- SeeAlso: AX=7070h/BX=6060h,AX=8080h
- --------v-2176-------------------------------
- INT 21 - VIRUS - "Klaeren"/"Hate" - INSTALLATION CHECK
- AH = 76h
- Return: AL = 48h if resident
- SeeAlso: AX=6969h,AX=7700h"VIRUS"
- --------U-217761-----------------------------
- INT 21 - WATCH.COM v3.2+ - INSTALLATION CHECK
- AX = 7761h ('wa')
- Return: AX = 6177h
- Note: WATCH.COM is part of the "TSR" package by TurboPower Software
- SeeAlso: INT 16/AX=7761h
- --------v-217700-----------------------------
- INT 21 - VIRUS - "Growing Block" - INSTALLATION CHECK
- AX = 7700h
- Return: AX = 0920h if resident
- SeeAlso: AH=76h,AH=7Fh
- --------v-217F-------------------------------
- INT 21 - VIRUS - "Squeaker" - INSTALLATION CHECK
- AH = 7Fh
- Return: AH = 80h if resident
- SeeAlso: AX=7700h,AH=83h"VIRUS"
- --------D-2180-------------------------------
- INT 21 - European MS-DOS 4.0 - "AEXEC" - EXECUTE PROGRAM IN BACKGROUND
- AH = 80h
- CX = mode
- 0000h place child in zombie mode on exit to preserve exit code
- 0001h discard child process and exit code on termination
- DS:DX -> ASCIZ full program name
- ES:BX -> parameter block (as for AX=4B00h)
- Return: CF clear if successful
- AX = Command Subgroup ID (CSID)
- CF set on error
- AX = error code (see AH=59h)
- Program: European MS-DOS 4.0 was written for Siemens in Germany and then used
- by several other European OEMs; its release falls between mainstream
- versions 3.2 and 3.3
- Desc: asynchronously execute a program, creating a new process for it
- Notes: this function is called by the DETACH command
- there is a system-wide limit of 32 processes
- the CSID is used to identify all processes that have been spawned by
- a given process, whether directly or indirectly
- programs to be run in the background must use the new executable format
- (see AH=4Bh)
- background processes may only perform asynchronous (background) EXECs,
- either this function or AX=4B04h
- background processes may execute INT 11, INT 12, INT 21, INT 2A, and
- INT 2F at any time; they may execute INT 10 and INT 16 only while
- they have opened a popup screen via INT 2F/AX=1401h; no other
- interrupts may be executed from the background
- background processes may not use drive B: or overlay their code
- segments
- see AX=8700h for an installation check
- the "NE" new executable format made its first appearance in European
- MS-DOS 4.0
- SeeAlso: AH=4Bh,AH=87h,INT 2F/AX=1400h"POPUP"
- ----------218080-----------------------------
- INT 21 - PCW Weather Card interface - UNINSTALL PCW.COM AND FREE MEMORY
- AX = 8080h
- Return: ???
- SeeAlso: AX=7070h/BX=7070h
- --------D-2181-------------------------------
- INT 21 - European MS-DOS 4.0 - "FREEZE" - STOP A PROCESS
- AH = 81h
- BX = flag (00h freeze command subtree, 01h only specified process)
- CX = Process ID of head of command subtree
- Return: CF clear if successful
- CF set on error
- AX = error code (no such process)
- Desc: temporarily suspend a process or a process and all of its children
- Note: if BX=0001h, this call will not return until the process is actually
- frozen, which may not be until after it unblocks from an I/O
- operation
- SeeAlso: AH=82h,AH=89h,AX=8E00h,INT 15/AX=101Dh
- --------D-2182-------------------------------
- INT 21 - European MS-DOS 4.0 - "RESUME" - RESTART A PROCESS
- AH = 82h
- BX = flag (00h resume command subtree, 01h only specified process)
- CX = Process ID of head of command subtree
- Return: CF clear if successful
- CF set on error
- AX = error code (no such process)
- Desc: restart a previously-suspended process or a process and all of its
- children
- SeeAlso: AX=81h,INT 15/AX=101Eh
- --------D-2183-------------------------------
- INT 21 - European MS-DOS 4.0 - "PARTITION" - GET/SET FOREGROUND PARTITION SIZE
- AH = 83h
- AL = function
- 00h get size
- 01h set new size
- BX = new size in paragraphs
- Return: CF clear if successful
- BX = current size (function 00h) or old size (function 01h)
- CF set on error
- AX = error code (01h,07h,0Dh)(see AH=59h)
- Desc: specify or determine how much memory may be allocated by the foreground
- process
- Note: if the partition size is set to 0000h, no partition management is done
- and all memory allocation is compatible with DOS 3.2.
- the partition size can be changed regardless of what use is being made
- of the changed memory; subsequent allocations will follow the
- partition rules (foreground processes may allocate only foreground
- memory; background processes allocate background memory first, then
- foreground memory)
- SeeAlso: AH=48h,AH=4Ah
- --------v-2183-------------------------------
- INT 21 - VIRUS - "SVC" - INSTALLATION CHECK
- AH = 83h
- Return: DX = 1990h if resident
- SeeAlso: AH=76h,AH=84h"VIRUS"
- --------v-2184-------------------------------
- INT 21 - VIRUS - "SVC 5.0" or "SVC 6.0" - INSTALLATION CHECK
- AH = 84h
- Return: DX = 1990h if resident
- BH = version number (major in high nybble, minor in low)
- SeeAlso: AH=83h"VIRUS",AH=89h"VIRUS"
- --------D-218400-----------------------------
- INT 21 - European MS-DOS 4.0 - "CREATMEM" - CREATE A SHARED MEMORY AREA
- AX = 8400h
- BX = size in bytes (0000h = 65536)
- CX = flags
- bit 6: zero-initialize segment
- DS:DX -> ASCIZ name (must begin with "\SHAREMEM\")
- Return: CF clear if successful
- AX = segment address of shared memory global object
- CF set on error
- AX = error code (06h,08h) (see AH=59h)
- Desc: create an area of memory which may be accessed by multiple processes
- Notes: shared memory objects are created as special files (thus the
- restriction on the name)
- on successful creation, the reference count is set to 1
- SeeAlso: AX=8401h,AX=8402h,INT 15/AX=DE19h
- --------D-218401-----------------------------
- INT 21 - European MS-DOS 4.0 - "GETMEM" - OBTAIN ACCESS TO SHARED MEMORY AREA
- AX = 8401h
- CX = flags
- bit 7: writable segment (ignored by MS-DOS 4.0)
- DS:DX -> ASCIZ name (must begin with "\SHAREMEM\")
- Return: CF clear if successful
- AX = segment address of shared memory global object
- CX = size in bytes
- CF set on error
- AX = error code (invalid name)
- Desc: get address of a previously-created area of memory which may be
- accessed by multiple processes
- Note: this call increments the reference count for the shared memory area
- SeeAlso: AX=8400h,AX=8402h
- --------D-218402-----------------------------
- INT 21 - European MS-DOS 4.0 - "RELEASEMEM" - FREE SHARED MEMORY AREA
- AX = 8402h
- BX = handle (segment address of shared memory object)
- Return: CF clear if successful
- CF set on error
- AX = error code (no such name)
- Desc: indicate that the specified area of shared memory will no longer be
- used by the caller
- Note: the reference count is decremented and the shared memory area is
- deallocated if the new reference count is zero
- SeeAlso: AX=8400h,AX=8401h,INT 15/AX=DE19h
- --------D-2185-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 85h
- ???
- Return: ???
- --------D-2186-------------------------------
- INT 21 - European MS-DOS 4.0 - "SETFILETABLE" - INSTALL NEW FILE HANDLE TABLE
- AH = 86h
- BX = total number of file handles in new table
- Return: CF clear if successful
- CF set on error
- AX = error code (06h,08h) (see AH=59h)
- Desc: adjust the size of the per-process open file table, thus raising or
- lowering the limit on the number of files the caller can open
- simultaneously
- Notes: any currently-open files are copied to the new table
- if the table is increased beyond the default 20 handles, only the
- first 20 will be inherited by child processes
- error 06h is returned if the requested number of handles exceeds
- system limits or would require closing currently-open files
- SeeAlso: AH=26h,AH=67h
- --------D-2187-------------------------------
- INT 21 - European MS-DOS 4.0 - "GETPID" - GET PROCESS IDENTIFIER
- AH = 87h
- Return: AX = PID
- BX = parent process's PID
- CX = Command Subgroup ID (CSID)
- Program: European MS-DOS 4.0 was written for Siemens in Germany and then used
- by several other European OEMs; its release falls between mainstream
- versions 3.2 and 3.3
- Desc: determine an identifier by which to access the calling process
- Notes: called by MS C v5.1 getpid() function
- this function apparently must return AX=0001h for INT 21/AH=80h to
- succeed
- one possible check for European MS-DOS 4.0 is to issue this call with
- AL=00h and check whether AL is nonzero on return
- SeeAlso: AH=30h,AH=62h,AH=80h
- Index: installation check;European MS-DOS 4.0
- --------D-2188-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 88h
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-2189-------------------------------
- INT 21 - European MS-DOS 4.0 - SLEEP
- AH = 89h
- CX = time in milliseconds or 0000h to give up time slice
- Return: CF clear if successful
- CX = 0000h
- CF set on error
- AX = error code (interrupted system call)
- CX = sleep time remaining
- Desc: suspend the calling process for the specified duration
- Notes: the sleep interval is rounded up to the next higher increment of the
- scheduler clock, and may be extended further if other processes are
- running
- this call may be interrupted by signals (see AH=8Dh)
- reportedly called by Microsoft C 4.0 startup code
- background processes have higher priority than the foreground process,
- and should thus periodically yield the CPU
- SeeAlso: AH=81h,INT 15/AX=1000h,INT 2F/AX=1680h,INT 7A/BX=000Ah
- --------v-2189-------------------------------
- INT 21 - VIRUS - "Vriest" - INSTALLATION CHECK
- AH = 89h
- Return: AX = 0123h if resident
- SeeAlso: AH=84h"VIRUS",AH=90h"VIRUS"
- --------D-218A-------------------------------
- INT 21 - European MS-DOS 4.0 - "CWAIT" - WAIT FOR CHILD TO TERMINATE
- AH = 8Ah
- BL = range (00h command subtree, 01h any child)
- BH = suspend flag
- 00h suspend if children exist but none are dead
- 01h return if no dead children
- CX = Process ID of head of command subtree
- Return: CF clear if successful
- AH = termination type
- 00h normal termination
- 01h aborted by Control-C
- 02h aborted by I/O error
- 03h terminate and stay resident
- 04h aborted by signal
- 05h aborted by program error
- AL = return code from child or aborting signal
- BX = PID of child (0000h if no dead children)
- CF set on error
- AX = error code (no child,interrupted system call)
- Desc: get return code from an asynchronously-executed child program,
- optionally waiting if no return code is available
- SeeAlso: AH=4Bh,AH=4Dh,AH=80h,AH=8Dh
- --------D-218B-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 8Bh
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-218C-------------------------------
- INT 21 - European MS-DOS 4.0 - SET SIGNAL HANDLER
- AH = 8Ch
- AL = signal number (see below)
- BL = action (see below)
- DS:DX -> signal handler
- Return: CF clear if successful
- AL = previous action
- ES:BX -> previous signal handler
- CF set on error
- AX = error code (01h,invalid SigNumber or Action) (see AH=59h)
- Desc: set the routine which will be invoked on a number of exceptional
- conditions
- Note: all signals will be sent to the most recently installed handler
- SeeAlso: AH=8Dh
-
- Values for signal number:
- 01h SIGINTR Control-C or user defined interrupt key
- 08h SIGTERM program termination
- 09h SIGPIPE broken pipe
- 0Dh SIGUSER1 reserved for user definition
- 0Eh SIGUSER2 reserved for user definition
-
- Values for signal action:
- 00h SIG_DFL terminate process on receipt
- 01h SIG_IGN ignore signal
- 02h SIG_GET signal is accepted
- 03h SIG_ERR sender gets error
- 04h SIG_ACK acknowledge received signal and clear it, but don't
- change current setting
-
- Signal handler is called with:
- AL = signal number
- AH = signal argument
- Return: RETF, CF set: terminate process
- RETF, CF clear, ZF set: abort any interrupted system call with an error
- RETF, CF clear, ZF clear: restart any interrupted system call
- IRET: restart any interrupted system call
- Note: the signal handler may also perform a nonlocal GOTO by resetting the
- stack pointer and jumping; before doing so, it should dismiss the
- signal by calling this function with BL=04h
- --------D-218D-------------------------------
- INT 21 - European MS-DOS 4.0 - SEND SIGNAL
- AH = 8Dh
- AL = signal number (see AH=8Ch)
- BH = signal argument
- BL = action
- 00h send to entire command subtree
- 01h send only to specified process
- DX = Process ID
- Return: CF clear if successful
- CF set on error
- AX = error code (01h,06h)(see AH=59h)
- Desc: invoke the exceptional-condition handler for the specified process
- Note: error 06h may be returned if one or more of the affected processes
- have an error handler for the signal
- SeeAlso: AH=8Ch
- --------D-218E00BH00-------------------------
- INT 21 - European MS-DOS 4.0 - "SETPRI" - GET/SET PROCESS PRIORITY
- AX = 8E00h
- BH = 00h
- BL = action
- 00h set priority for command subtree
- 01h set priority for specified process only
- CX = Process ID
- DH = 00h
- DL = change in priority (00h to get priority)
- Return: CF clear if successful
- DL = process priority
- DH destroyed
- CF set on error
- AX = error code (01h,no such process)(see AH=59h)
- Desc: specify or determine the execution priority of the specified process
- or the process and all of its children
- SeeAlso: AH=81h
- --------D-218F-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 8Fh
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-2190-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 90h
- ???
- Return: ???
- SeeAlso: AH=87h
- --------v-2190-------------------------------
- INT 21 - VIRUS - "Carioca" - INSTALLATION CHECK
- AH = 90h
- Return: AH = 01h if resident
- SeeAlso: AH=89h"VIRUS",AX=9753h"VIRUS"
- --------D-2191-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 91h
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-2192-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 92h
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-2193-------------------------------
- INT 21 - European MS-DOS 4.0 - "PIPE" - CREATE A NEW PIPE
- AH = 93h
- CX = size in bytes
- Return: CF clear if successful
- AX = read handle
- BX = write handle
- CF set on error
- AX = error code (08h) (see AH=59h)
- Desc: create a communications channel which may be used for interprocess
- data and command exchanges
- SeeAlso: AH=3Ch,AH=3Fh,AH=40h,AH=84h
- --------D-2194-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 94h
- ???
- Return: ???
- SeeAlso: AH=87h
- --------D-2195-------------------------------
- INT 21 - European MS-DOS 4.0 - HARD ERROR PROCESSING
- AH = 95h
- AL = new state
- 00h enabled
- 01h disabled, automatically fail hard errors
- Return: AX = previous setting
- Desc: specify whether hard (critical) errors should automatically fail the
- system call or invoke an INT 24
- SeeAlso: INT 24
- --------D-2196-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 96h
- ???
- Return: ???
- --------D-2197-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 97h
- ???
- Return: ???
- --------v-219753-----------------------------
- INT 21 - VIRUS - "Nina" - INSTALLATION CHECK
- AX = 9753h
- Return: never (executes original program) if virus resident
- SeeAlso: AH=90h"VIRUS",AX=A1D5h"VIRUS"
- --------D-2198-------------------------------
- INT 21 U - European MS-DOS 4.0 - ???
- AH = 98h
- ???
- Return: ???
- --------D-2199-------------------------------
- INT 21 u - European MS-DOS 4.0 - "PBLOCK" - BLOCK A PROCESS
- AH = 99h
- DS:BX -> memory location to block on
- CX = timeout in milliseconds
- DH = nonzero if interruptible
- Return: CF clear if awakened by event
- AX = 0000h
- CF set if unusual wakeup
- ZF set if timeout, clear if interrupted by signal
- AX = nonzero
- Desc: suspend calling process until another process sends a "restart" signal
- or a timeout occurs
- SeeAlso: AH=9Ah,INT 2F/AX=0802h
- --------D-219A-------------------------------
- INT 21 u - European MS-DOS 4.0 - "PRUN" - UNBLOCK A PROCESS
- AH = 9Ah
- DS:BX -> memory location processes may have blocked on
- Return: AX = number of processes awakened
- ZF set if no processes awakened
- Program: European MS-DOS 4.0 was written for Siemens in Germany and then used
- by several other European OEMs; its release falls between mainstream
- versions 3.2 and 3.3
- Desc: restart all processes waiting for the specified "restart" signal
- SeeAlso: AH=99h,INT 2F/AX=0802h
- --------I-21A0-------------------------------
- INT 21 - Attachmate Extra - GET 3270 DISPLAY STATE
- AH = A0h
- Return: AL = display status
- bit 7 : 0=windowed, 1=enlarged
- bits 6-3: current screen profile number 0-9
- bits 2-0: active window number
- 0=PC, 1-4=host B-E, 5-6=notepad F-G
- BX = host window status (see below)
- Program: Attachmate Extra is a 3270 emulator by Attachmate Corporation
- SeeAlso: AH=A1h
-
- Bitfields for host window status:
- bit 15 reserved
- bit 14 0=host E window installed, 1=not
- bit 13 0=host E terminal on, 1=off
- bit 12 0=host E window displayed, 1=not
- bit 11 reserved
- bit 10 0=host D window installed, 1=not
- bit 9 0=host D terminal on, 1=off
- bit 8 0=host D window displayed, 1=not
- bit 7 reserved
- bit 6 0=host C window installed, 1=not
- bit 5 0=host C terminal on, 1=off
- bit 4 0=host C window displayed, 1=not
- bit 3 reserved
- bit 2 0=host B window installed, 1=not
- bit 1 0=host B terminal on, 1=off
- bit 0 0=host B window displayed, 1=not
- --------I-21A1-------------------------------
- INT 21 - Attachmate Extra - SET 3270 DISPLAY STATE
- AH = A1h
- AL = set status byte
- bit 7 : 0=windowed, 1=enlarged
- bits 6-3: current screen profile number 0-9
- bits 2-0: active window number
- 0=PC, 1-4=host B-E, 5-6=notepad F-G
- SeeAlso: AH=A0h,AH=A2h
- --------v-21A1D5-----------------------------
- INT 21 - VIRUS - "789"/"Filehider" - INSTALLATION CHECK
- AX = A1D5h
- Return: AX = 900Dh if resident
- SeeAlso: AX=9753h,AX=A55Ah
- --------I-21A2-------------------------------
- INT 21 - Attachmate Extra - SET HOST WINDOW STATE
- AH = A2h
- AL = set status byte
- bit 7 : 0=power off, 1=power on
- bit 6 : 0=not installed, 1=installed
- bits 5-3: reserved
- bits 2-0: window number 1-4=host B-E
- SeeAlso: AH=A1h
- --------I-21A3-------------------------------
- INT 21 - Attachmate Extra - SEND KEYSTROKES TO HOST WINDOW
- AH = A3h
- AL = window number (1-4=host B-E)
- CX = 0001h
- DS:BX -> keystroke buffer
- DL = zero if keystroke buffer contains host function code,
- non-zero if keystroke buffer contains ASCII character
- Return: CX = zero if character sent, non-zero if not
- BX incremented if CX=0
-
- Values for host function code:
- 00h=reserved 10h=PF16 20h=Clear 30h=SysRq
- 01h=PF1 11h=PF17 21h=Print 31h=ErInp
- 02h=PF2 12h=PF18 22h=Left 32h=ErEof
- 03h=PF3 13h=PF19 23h=Right 33h=Ident
- 04h=PF4 14h=PF20 24h=Up 34h=Test
- 05h=PF5 15h=PF21 25h=Down 35h=Reset
- 06h=PF6 16h=PF22 26h=Home 36h=DevCncl
- 07h=PF7 17h=PF23 27h=Fast Left 37h=Dup
- 08h=PF8 18h=PF24 28h=Fast Right 38h=FldMark
- 09h=PF9 19h=Alt on 29h=Bksp 39h=Enter
- 0Ah=PF10 1Ah=Alt off 2Ah=Insert 3Ah=CrSel
- 0Bh=PF11 1Bh=Shift on 2Bh=Delete
- 0Ch=PF12 1Ch=Shift off 2Ch=Backtab
- 0Dh=PF13 1Dh=PA1 2Dh=Tab
- 0Eh=PF14 1Eh=PA2 2Eh=Newline
- 0Fh=PF15 1Fh=PA3 2Fh=Attn
- --------I-21A4-------------------------------
- INT 21 - Attachmate Extra - GET HOST WINDOW BUFFER ADDRESS
- AH = A4h
- AL = window number (1-4=host B-E)
- Return: DS:BX -> 3270 display buffer
- SeeAlso: AH=A5h,AH=B8h
- --------I-21A5-------------------------------
- INT 21 - Attachmate Extra - GET HOST WINDOW CURSOR POSITION
- AH = A5h
- AL = window number (1-4=host B-E)
- Return: BX = cursor position (80 * row + column, where 0:0 is upper left)
- Note: if the host window is configured with the Extended Attribute (EAB)
- feature, multiply the cursor position by 2 to obtain the byte offset
- into the display buffer
- SeeAlso: AH=A4h
- --------v-21A55A-----------------------------
- INT 21 - VIRUS - "Eddie-2" - INSTALLATION CHECK
- AX = A55Ah
- Return: AX = 5AA5h if resident
- SeeAlso: AX=A1D5h,AX=AA00h
- --------v-21AA00-----------------------------
- INT 21 - VIRUS - "Blinker" - INSTALLATION CHECK
- AX = AA00h
- Return: AX = 00AAh if resident
- SeeAlso: AX=A55Ah,AX=AA03h
- --------v-21AA03-----------------------------
- INT 21 - VIRUS - "Backtime" - INSTALLATION CHECK
- AX = AA03h
- Return: AX = 03AAh if resident
- SeeAlso: AX=AA00h,AH=ABh
- --------v-21AB-------------------------------
- INT 21 - VIRUS - "600" or "Voronezh"-family - INSTALLATION CHECK
- AH = ABh
- Return: AX = 5555h if resident
- SeeAlso: AX=AA03h,AX=BBBBh"VIRUS"
- --------I-21AF-------------------------------
- INT 21 - Attachmate Extra - GET TRANSLATE TABLE ADDRESS
- AH = AFh
- Return: DS:BX -> translate tables (see below)
-
- Format of translate tables:
- Offset Size Description
- 00h 256 BYTEs ASCII to 3270 buffer code translate table
- 100h 256 BYTEs 3270 buffer code to ASCII translate table
- 200h 256 BYTEs 3270 buffer code to EBCDIC translate table
- 300h 256 BYTEs EBCDIC to 3270 buffer code translate table
- --------N-21B4-------------------------------
- INT 21 U - Novell Netware - "AttachHandle"
- AH = B4h
- DS:SI -> input buffer (see below)
- Return: AX = handle or return code
- Note: this is an interface provided by NetWare to give DOS file access to
- NetWare files on non-DOS systems such as Macintosh, OS/2, and Unix
-
- Format of input buffer:
- Offset Size Description
- 00h BYTE "WorkFileServer"
- 01h BYTE access code
- 02h DWORD "OpenHandle"
- 06h WORD "OpenHandleCount"
- 08h DWORD "OpenFileSize"
- --------N-21B500-----------------------------
- INT 21 U - Novell NetWare - VNETWARE.386 API - GET INSTANCE DATA
- AX = B500h
- Return: ES:BX -> data
- CX = length
- SeeAlso: AX=B501h,AX=B502h
- --------N-21B501-----------------------------
- INT 21 U - Novell NetWare - VNETWARE.386 API - END VIRTUAL MACHINE
- AX = B501h
- SeeAlso: AX=B500h,AX=B502h
- --------N-21B502-----------------------------
- INT 21 U - Novell NetWare - VNETWARE.386 API - START VIRTUAL MACHINE
- AX = B502h
- SeeAlso: AX=B500h,AX=B501h
- --------N-21B5-------------------------------
- INT 21 - Novell NetWare shell 3.01 - TASK MODE CONTROL
- AH = B5h
- AL = subfunction
- 03h get task mode
- Return: AH = 00h
- AL = current task mode byte
- 04h get task mode pointer
- Return: ES:BX -> task mode byte
- Notes: the task mode byte specifies how task cleanup should be performed, but
- is declared to be version-dependent
- allows a program to disable the automatic cleanup for programs managing
- task swapping, etc.
-
- Values for task mode byte in version 3.01:
- 00h-03h reserved
- 04h no task cleanup
- --------N-21B505-----------------------------
- INT 21 U - Novell NetWare - VNETWARE.386 API - SET VIRTUAL MACHINE ID
- AX = B505h
- ???
- Return: ???
- SeeAlso: AX=B502h,AX=B506h
- --------N-21B506-----------------------------
- INT 21 U - Novell NetWare - VNETWARE.386 API - GET VIRTUAL MACH SUPPORT LEVEL
- AX = B506h
- Return: AX = ??? (0002h)
- SeeAlso: AX=B505h
- --------N-21B6-------------------------------
- INT 21 - Novell NetWare - FILE SERVICES - EXTENDED FILE ATTRIBUTES
- AH = B6h
- AL = subfunction
- 00h get extended file attributes
- 01h set extended file attributes
- CL = extended file attributes (see below)
- DS:DX -> ASCIZ pathname (max 255 bytes)
- Return: CF set on error
- AL = error code
- 8Ch caller lacks privileges
- FEh not permitted to search directory
- FFh file not found
- CF clear if successful
- AL = 00h (success)
- CL = current extended file attributes (see below)
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=4300h,AH=E3h/SF=0Fh
-
- Bitfields for extended file attributes:
- bits 2-0 search mode (executables only)
- 000 none (use shell's default search)
- 001 search on all opens without path
- 010 do not search
- 011 search on read-only opens without path
- 100 reserved
- 101 search on all opens
- 110 reserved
- 111 search on all read-only opens
- bit 3 reserved
- bit 4 transactions on file tracked
- bit 5 file's FAT indexed
- bit 6 read audit (to be implemented)
- bit 7 write audit (to be implemented)
- --------N-21B7-------------------------------
- INT 21 U - Novell NetWare - "HoldFileModeSet" (obsolete)
- AH = B7h
- AL = new value for HoldFileFlag
- Return: AL = previous value of HoldFileFlag
- Note: this function provided backward compatibility with a bug in early
- DOS versions and CP/M, but is no longer used or supported
- --------I-21B8-------------------------------
- INT 21 - Attachmate Extra - DISABLE HOST BUFFER UPDATES
- AH = B8h
- AL = window number (1-4=host B-E)
- DL = 01h
- Notes: only valid in CUT mode
- next AID keystroke (eg Enter) enables host buffer updates
- SeeAlso: AH=A4h
- --------N-21B800-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET DEFAULT CAPTURE FLAGS
- AX = B800h
- CX = size of reply buffer (01h-3Fh)
- ES:BX -> reply buffer for capture flags table (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.0+
- SeeAlso: AX=B801h,AX=B802h,AH=DFh/DL=00h,AH=DFh/DL=04h
-
- Format of capture flags table:
- Offset Size Description
- 00h BYTE status (used internally, should be set to 00h)
- 01h BYTE print flags
- bit 2: print capture file if interrupted by loss of connection
- bit 3: no automatic form feed after print job
- bit 6: printing control sequences interpreted by print service
- bit 7: print banner page before capture file
- 02h BYTE tab size (01h-12h, default 08h)
- 03h BYTE printer number on server (00h-04h, default 00h)
- 04h BYTE number of copies to print (00h-FFh, default 01h)
- 05h BYTE form type required in printer (default 00h)
- 06h BYTE reserved
- 07h 13 BYTEs text to be placed on banner page
- 14h BYTE reserved
- 15h BYTE default local printer (00h = LPT1)
- 16h WORD timeout in clock ticks for flushing capture file on inactivity
- (big-endian)
- 0000h = never timeout
- 18h BYTE flush capture file on LPT close if nonzero
- 19h WORD maximum lines per page (big-endian)
- 1Bh WORD maximum characters per line (big-endian)
- 1Dh 13 BYTEs name of form required in printer
- 2Ah BYTE LPT capture flag
- 00h inactive, FFh LPT device is being captured
- 2Bh BYTE file capture flag
- 00h if no file specified, FFh if capturing to file
- 2Ch BYTE timing out (00h if no timeout in effect, FFh if timeout counter
- running)
- 2Dh DWORD address of printer setup string (big-endian)
- 31h DWORD address of printer reset string (big-endian)
- 35h BYTE target connection ID
- 36h BYTE capture in progress if FFh
- 37h BYTE job queued for printing if FFh
- 38h BYTE print job valid if FFh
- 39h DWORD bindery object ID of print queue if previous byte FFh
- 3Dh WORD print job number (1-999) `````(big-endian)
- --------N-21B801-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET DEFAULT CAPTURE FLAGS
- AX = B801h
- CX = size of buffer (01h-3Fh)
- ES:BX -> buffer containing capture flags table (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.0+
- SeeAlso: AX=B800h,AX=B803h,AH=DFh/DL=00h,AH=DFh/DL=04h
- --------N-21B802-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET SPECIFIC CAPTURE FLAGS
- AX = B802h
- CX = size of reply buffer (01h-3Fh)
- DH = LPT port (00h-02h)
- ES:BX -> reply buffer for capture flags table (see AX=B800h)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B800h,AX=B803h,AH=DFh/DL=00h,AH=DFh/DL=04h
- --------N-21B803-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET SPECIFIC CAPTURE FLAGS
- AX = B803h
- CX = size of buffer (01h-3Fh)
- DH = LPT port (00h-02h)
- ES:BX -> buffer containing capture flags table (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B800h,AX=B803h,AH=DFh/DL=00h,AH=DFh/DL=04h
- --------N-21B804-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET DEFAULT LOCAL PRINTER
- AX = B804h
- Return: DH = default LPT port (00h-02h)
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B800h,AX=B805h,AH=DFh/DL=00h
- --------N-21B805-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET DEFAULT LOCAL PRINTER
- AX = B805h
- DH = new default LPT port (00h-02h)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B800h,AX=B804h,AH=DFh/DL=00h
- --------N-21B806-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET CAPTURE PRINT QUEUE
- AX = B806h
- DH = LPT port (00h-02h)
- BX:CX = print queue's object ID
- Return: AL = status
- 00h successful
- FFh job already set
- Desc: specify the print queue on which a print job is to be placed the next
- time a capture is started on the given printer port
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B801h,AX=B807h,AX=E009h
- --------N-21B807-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET CAPTURE PRINT JOB
- AX = B807h
- DH = LPT port (00h-02h)
- BX = job number (see AH=E3h/SF=68h)
- SI:DI:CX = NetWare file handle (see AH=E3h/SF=68h)
- Return: AL = status
- 00h successful
- FFh job already queued
- Desc: specify the capture file and print job to be used for subsequent
- output to the given printer port
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AX=B801h,AX=B806h,AX=E009h,AH=E3h/SF=68h
- --------N-21B808-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET BANNER USER NAME
- AX = B808h
- ES:BX -> 12-byte buffer for user name
- Return: AL = status
- 00h successful
- Desc: get the user name which is printed on the banner page
- Notes: this function is supported by Advanced NetWare 2.1+
- the default name is the login name of the user
- SeeAlso: AX=B809h
- --------N-21B809-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SET BANNER USER NAME
- AX = B809h
- ES:BX -> 12-byte buffer containing user name
- Return: AL = status
- 00h successful
- Desc: specify the user name which is printed on the banner page
- Notes: this function is supported by Advanced NetWare 2.1+
- the default name is the login name of the user
- SeeAlso: AX=B808h
- --------N-21B9-------------------------------
- INT 21 U - Novell NetWare - "SpecialAttachableFunction"
- AH = B9h
- AL = FFh to hook this function
- ES:BX -> function to invoke on AH=B9h when AL<>FFh
- Note: this function is no longer used or supported by current versions of
- NetWare
- --------N-21BA-------------------------------
- INT 21 U - Novell NetWare - "ReturnCommandComPointers"
- AH = BAh
- Return: DX = environment segment
- ES:DI -> COMMAND.COM drive
- Desc: used to edit the COMSPEC and PATH variables in the master environment
- when mapping network drives
- Note: this function was documented in older Novell documents which are no
- longer available
- --------N-21BB-------------------------------
- INT 21 - Novell NetWare - WORKSTATION - SET END OF JOB STATUS
- AH = BBh
- AL = new EOJ flag
- 00h disable EOJs
- 01h enable EOJs
- Return: AL = old EOJ flag
- Desc: specify whether the network shell should automatically generate an
- End of Job call when the root command processor regains control
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=19h,AH=D6h
- --------v-21BBBB-----------------------------
- INT 21 - VIRUS - "Hey You" - INSTALLATION CHECK
- AX = BBBBh
- Return: AX = 6969h
- SeeAlso: AH=ABh"VIRUS",AH=BEh"VIRUS"
- --------N-21BC-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOG PHYSICAL RECORD
- AH = BCh
- AL = flags
- bit 0: lock as well as log record
- bit 1: non-exclusive lock
- BX = file handle
- CX:DX = starting offset in file
- SI:DI = length of region to lock
- BP = timeout in timer ticks (1/18 sec)
- 0000h = don't wait if already locked
- Return: AL = status
- 00h successful
- 96h no dynamic memory for file
- FEh timed out
- FFh failed
- Desc: add the specified physical record to the log table, optionally locking
- it
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=5Ch,AH=BDh,AH=BEh,AH=BFh,AH=C2h,AH=D0h
- --------N-21BD-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE PHYSICAL RECORD
- AH = BDh
- BX = file handle
- CX:DX = starting offset in file
- SI:DI = length of record
- Return: AL = status
- 00h successful
- FFh record not locked
- Desc: unlock the specified physical record but do not remove it from log
- table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=BCh,AH=BEh"NetWare",AH=C0h,AH=C3h,AH=D2h
- --------N-21BE-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR PHYSICAL RECORD
- AH = BEh
- BX = file handle
- CX:DX = starting offset within file
- SI:DI = record length in bytes
- Return: AL = status
- 00h successful
- FFh specified record not locked
- Desc: unlock the physical record and remove it from the log table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=5Ch,AH=BCh,AH=BDh,AH=C1h,AH=C4h,AH=D4h
- --------v-21BE-------------------------------
- INT 21 - VIRUS - "Datalock" - INSTALLATION CHECK
- AH = BEh
- Return: AX = 1234h if resident
- SeeAlso: AX=BBBBh,AX=BE00h
- --------v-21BE00-----------------------------
- INT 21 - VIRUS - "USSR-1049" - INSTALLATION CHECK
- AX = BE00h
- CF set
- Return: CF clear if resident
- SeeAlso: AH=BEh"VIRUS",AH=C0h"VIRUS"
- --------N-21BF-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - LOG/LOCK RECORD (FCB)
- AH = BFh
- AL = flags
- bit 0: lock as well as log record
- bit 1: non-exclusive lock
- DS:DX -> opened FCB (see AH=0Fh)
- BX:CX = offset
- BP = lock timeout in timer ticks (1/18 sec) if AL nonzero
- SI:DI = length
- Return: AL = error code (see AH=BCh)
- Note: this function was added in NetWare 4.6, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=BCh,AH=C0h"NetWare",AH=C2h"NetWare"
- --------N-21C0-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - RELEASE RECORD (FCB)
- AH = C0h
- DS:DX -> non-extended FCB (see AH=0Fh)
- BX:CX = offset
- Return: AL = error code (see AH=BCh)
- Notes: unlocks record but does not remove it from log table
- this function was added in NetWare 4.6, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=BDh,AH=BFh,AH=C1h"NetWare",AH=C3h
- --------v-21C0-------------------------------
- INT 21 - VIRUS - "Slow"/"Zerotime", "Solano" - INSTALLATION CHECK
- AH = C0h
- Return: AX = 0300h if "Slow"/"Zerotime" resident
- AX = 1234h if "Solano" resident
- SeeAlso: AX=BE00h,AH=C1h"VIRUS",AX=C301h"VIRUS"
- --------N-21C1-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - CLEAR RECORD (FCB)
- AH = C1h
- DS:DX -> opened FCB (see AH=0Fh)
- BX:CX = offset
- Return: AL = error code (see AH=BCh)
- Note: unlocks record and removes it from log table
- this function was added in NetWare 4.6, but was removed some time prior
- to Advanced NetWare, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=BEh,AH=C0h"NetWare",AH=C4h
- --------v-21C1-------------------------------
- INT 21 - VIRUS - "Solano" - ???
- AH = C1h
- ???
- Return: ???
- SeeAlso: AH=C0h"VIRUS"
- --------N-21C2-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOCK PHYSICAL RECORD SET
- AH = C2h
- AL = flags
- bit 1: non-exclusive lock
- BP = lock timeout in timer ticks (1/18 sec) 0000h = no wait
- Return: AL = status
- 00h successful
- FEh timed out
- FFh failed
- Desc: attempt to lock all physical records listed in the log table
- Notes: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- status FFh will be retuend if one or more physical records have been
- exclusively locked by another process
- SeeAlso: AH=BFh,AH=C3h,AH=D1h
- --------v-21C2-------------------------------
- INT 21 - VIRUS - "Scott's Valley" - ???
- AH = C2h
- ???
- Return: ???
- SeeAlso: AH=C0h"VIRUS"
- --------N-21C3-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE PHYSICAL RECRD SET
- AH = C3h
- Desc: unlock all currently-locked physical records in the log table, but do
- not remove them from the table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=BDh,AH=C0h,AH=C2h"NetWare",AH=C4h,AH=D3h
- --------v-21C301DXF1F1-----------------------
- INT 21 - VIRUS - "905"/"Backfont" - INSTALLATION CHECK
- AX = C301h
- DX = F1F1h
- Return: DX = 0E0Eh if resident
- SeeAlso: AH=C0h"VIRUS",AX=C500h"VIRUS"
- --------N-21C4-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR PHYSICAL RECORD SET
- AH = C4h
- Desc: unlock all physical records in the log table and remove them from the
- log table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=BEh,AH=C1h,AH=D5h
- --------N-21C500-----------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - OPEN SEMAPHORE
- AX = C500h
- DS:DX -> semaphore name (counted string, max 127 bytes)
- CL = initial value for semaphore
- Return: AL = status
- 00h successful
- BL = number of processes having semaphore open
- CX:DX = semaphore handle
- FEh invalid name length
- FFh invalid semaphore value
- Notes: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- the semaphore's value is incremented by AX=C503h and decremented by
- AX=C502h
- SeeAlso: AX=C501h,AX=C502h,AX=C503h,AX=C504h
- --------v-21C500-----------------------------
- INT 21 - VIRUS - "Sverdlov" - INSTALLATION CHECK
- AX = C500h
- Return: AX = 6731h if resident
- SeeAlso: AX=C301h"VIRUS",AH=C6h"VIRUS"
- --------N-21C501-----------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - EXAMINE SEMAPHORE
- AX = C501h
- CX:DX = semaphore handle
- Return: AL = status
- 00h successful
- CX = semaphore value (-127 to 127)
- DL = count of processes which have the semaphore open
- FFh invalid handle
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AX=C500h"NetWare",AX=C502h,AX=C504h
- --------N-21C502-----------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - WAIT ON SEMAPHORE
- AX = C502h
- CX:DX = semaphore handle
- BP = timeout limit in timer ticks (1/18 sec)
- 0000h return immediately if semaphore already zero or negative
- Return: AL = status
- 00h successful
- FEh timeout
- FFh invalid handle
- Desc: decrement the semaphore's value, optionally waiting until its value
- becomes positive before decrementing
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AX=C500h"NetWare",AX=C501h,AX=C503h
- --------N-21C503-----------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - SIGNAL SEMAPHORE
- AX = C503h
- CX:DX = semaphore handle
- Return: AL = status
- 00h successful
- 01h semaphore value overflowed
- FFh invalid handle
- Desc: increment the semaphore's value and signal the first process (if any)
- in the queue waiting on the semaphore
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AX=C500h"NetWare",AX=C502h
- --------N-21C504-----------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLOSE SEMAPHORE
- AX = C504h
- CX:DX = semaphore handle
- Return: AL = status
- 00h successful
- FFh invalid handle
- Desc: decrement the semaphore's open count, and delete the semaphore if the
- count reaches zero
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AX=C500h"NetWare",AX=C501h
- --------N-21C6-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - GET OR SET LOCK MODE
- AH = C6h
- AL = subfunction
- 00h set old "compatibility" mode (default)
- 01h set new extended locks mode
- 02h get lock mode
- Return: AL = current lock mode
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- the locking mode should be 01h for NetWare 4.61+ and Advanced
- NetWare 1.0+ locking calls, and 00h for all older calls
- SeeAlso: AH=BCh,AH=C4h,AH=D0h
- --------v-21C6-------------------------------
- INT 21 - VIRUS - "Socha" - INSTALLATION CHECK
- AH = C6h
- Return: AL = 55h if resident
- SeeAlso: AX=C500h"VIRUS",AX=C603h
- --------v-21C603-----------------------------
- INT 21 - VIRUS - "Yankee" or "MLTI" - INSTALLATION CHECK
- AX = C603h
- CF set
- Return: CF clear if resident
- SeeAlso: AX=C500h"VIRUS",AX=C700h"VIRUS"
- --------N-21C700-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - BEGIN TRANSACTION
- AX = C700h
- Return: CF clear if successful
- AL = 00h
- CF set on error
- AL = error code
- 96h out of memory
- FEh implicit transaction already active, converted to explicit
- FFh explicit transaction already active
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AX=C701h,AX=C702h,AX=C703h
- --------v-21C700-----------------------------
- INT 21 - VIRUS - "MH-757" - INSTALLATION CHECK
- AX = C700h
- Return: AL = 07h if resident
- SeeAlso: AX=C603h"VIRUS",AH=CBh"VIRUS"
- --------N-21C701-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - END TRANSACTION
- AX = C701h
- Return: AL = status
- 00h successful
- CX:DX = transaction number
- FDh transaction tracking disabled
- FEh transaction ended records locked
- FFh no explicit transaction active
- CF clear except when AL=FFh
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AX=C700h"NetWare",AX=C703h
- --------N-21C702-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - INSTALLATION CHECK
- AX = C702h
- Return: AL = status
- 00h not available
- 01h available
- FDh available but disabled
- Desc: determine whether the default file server supports TTS
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- --------N-21C703-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - ABORT TRANSACTION
- AX = C703h
- Return: CF clear if successful
- AL = 00h
- CF set on error
- AL = error code
- FDh transaction tracking disabled, no backout
- FEh transaction ended records locked
- FFh no explicit transaction active
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AX=C700h"NetWare",AX=C701h,AX=C704h
- --------N-21C704-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - TRANSACTION STATUS
- AX = C704h
- CX:DX = transaction number (see AX=C701h)
- Return: AL = status
- 00h successful
- FFh not yet written to disk
- Desc: verify that a transaction has actually been written to disk
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- transactions are written to disk in the order in which they are ended,
- but it may take as much as five seconds for the data to be written
- SeeAlso: AX=C700h"NetWare",AX=C701h,AX=C703h
- --------N-21C705-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - GET APPLICTN THRESHOLDS
- AX = C705h
- Return: AL = status
- 00h successful
- CL = maximum logical record locks (default 0)
- CH = maximum physical record locks (default 0)
- Desc: get the per-application limits on record locks allowed before an
- implicit transaction is begun
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- if either limit is FFh, implicit transactions are disabled for the
- corresponding lock type
- SeeAlso: AX=C706h,AX=C707h
- --------N-21C706-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - SET APPLICTN THRESHOLDS
- AX = C706h
- CL = maximum logical record locks (default 0)
- CH = maximum physical record locks (default 0)
- Return: AL = status
- 00h successful
- Desc: specify the per-application limits on record locks allowed before an
- implicit transaction is begun
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- if either limit is set to FFh, implicit transactions are disabled for
- the corresponding lock type
- SeeAlso: AX=C705h,AX=C708h
- --------N-21C707-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - GET WORKSTN THRESHOLDS
- AX = C707h
- Return: AL = status
- 00h successful
- CL = maximum logical record locks (default 0)
- CH = maximum physical record locks (default 0)
- Desc: get the per-workstation limits on record locks allowed before an
- implicit transaction is begun
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- if either limit is FFh, implicit transactions are disabled for the
- corresponding lock type
- SeeAlso: AX=C705h,AX=C708h
- --------N-21C708-----------------------------
- INT 21 - Novell NetWare - TRANSACTION TRACKING SYSTEM - SET WORKSTN THRESHOLDS
- AX = C708h
- CL = maximum logical record locks (default 0)
- CH = maximum physical record locks (default 0)
- Return: AL = status
- 00h successful
- Desc: specify the per-workstation limits on record locks allowed before an
- implicit transaction is begun
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- if either limit is set to FFh, implicit transactions are disabled for
- the corresponding lock type
- SeeAlso: AX=C706h,AX=C707h
- --------N-21C8-------------------------------
- INT 21 O - Novell NetWare - BEGIN LOGICAL FILE LOCKING
- AH = C8h
- if function C6h lock mode 00h:
- DL = mode
- 00h no wait
- 01h wait
- if function C6h lock mode 01h:
- BP = timeout in timer ticks (1/18 sec)
- Return: AL = error code
- Desc: used to provide TTS support for applications which are not aware of
- Novell's Transaction Tracking System
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=C9h
- --------N-21C9-------------------------------
- INT 21 O - Novell NetWare - END LOGICAL FILE LOCKING
- AH = C9h
- Return: AL = error code
- Desc: used to provide TTS support for applications which are not aware of
- Novell's Transaction Tracking System
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=C8h
- --------N-21CA-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - LOG/LOCK PERSONAL FILE (FCB)
- AH = CAh
- DS:DX -> FCB (see AH=0Fh)
- if function C6h lock mode 01h:
- AL = log and lock flag
- 00h log file only
- 01h lock as well as log file
- BP = lock timeout in timer ticks (1/18 sec)
- Return: AL = error code
- 00h successful
- 96h no dynamic memory for file
- FEh timeout
- FFh failed
- Desc: provides file locking support for FCBs
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=CBh
- --------v-21CA15-----------------------------
- INT 21 - VIRUS - "Piter" - ???
- AX = CA15h
- ???
- Return: ???
- SeeAlso: AH=CCh"VIRUS"
- --------N-21CB-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOCK FILE SET
- AH = CBh
- if function C6h lock mode 00h:
- DL = mode
- 00h no wait
- 01h wait
- if function C6h lock mode 01h:
- BP = lock timeout in timer ticks (1/18 sec) 0000h = no wait
- Return: AL = status
- 00h successful
- FEh timed out
- FFh failed
- Desc: attempt to lock all files listed in the log table
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- status FFh will be returned if one or more of the files have already
- been exclusively locked by another process
- SeeAlso: AH=CAh,AH=CDh,AH=D1h,AH=EBh
- --------v-21CB-------------------------------
- INT 21 - VIRUS - "Milous" - INSTALLATION CHECK
- AH = CBh
- Return: AL = 07h if resident
- SeeAlso: AX=C700h"VIRUS",AX=CB02h
- --------v-21CB02-----------------------------
- INT 21 - VIRUS - "Witcode" - INSTALLATION CHECK
- AX = CB02h
- Return: AX = 02CBh if resident
- SeeAlso: AH=CBh"VIRUS",AH=CCh"VIRUS"
- --------N-21CC-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - RELEASE FILE (FCB)
- AH = CCh
- DS:DX -> FCB (see AH=0Fh)
- Return: none
- Desc: unlocks file, but does not remove it from the log table or close it
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=CAh,AH=CDh
- --------v-21CC-------------------------------
- INT 21 - VIRUS - "Westwood" - INSTALLATION CHECK
- AH = CCh
- Return: AX = 0700h if resident
- SeeAlso: AX=CB02h,AH=CDh"VIRUS",AX=D000h"VIRUS"
- --------N-21CD-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE FILE SET
- AH = CDh
- Return: none
- Desc: unlock all files listed in the log table, but don't remove them from
- the table
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=CBh,AH=CCh,AH=CFh,AH=D3h
- --------v-21CD-------------------------------
- INT 21 - VIRUS - "Westwood" - ???
- AH = CDh
- ???
- Return: ???
- SeeAlso: AH=CCh"VIRUS"
- --------N-21CE-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - CLEAR FILE (FCB)
- AH = CEh
- DS:DX -> FCB (see AH=0Fh)
- Return: AL = error code
- Desc: unlocks file and removes it from log table, then closes all opened and
- logged occurrences
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AH=CAh,AH=CFh,AH=EDh"NetWare"
- --------N-21CF-------------------------------
- INT 21 - LANstep - ???
- AH = CFh
- ???
- Return: ???
- Program: LANstep is a redesign of the Waterloo Microsystems PORT network
- --------N-21CF-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR FILE SET
- AH = CFh
- Return: AL = 00h
- Desc: unlock and remove all files from log table
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=CAh,AH=CEh,AH=EBh"NetWare"
- --------N-21D0-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOG LOGICAL RECORD
- AH = D0h
- DS:DX -> record string (counted string, max 99 data bytes)
- if function C6h lock mode 01h: (Novell, NTNX only)
- AL = flags
- bit 0: lock as well as log the record
- bit 1: non-exclusive lock
- BP = lock timeout in timer ticks (1/18 sec)
- Return: AL = status
- 00h successful
- 96h no dynamic memory for file
- FEh timed out
- FFh unsuccessful
- Desc: add the specified logical record name to the log table, and optionally
- lock the record
- Notes: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+,
- Banyan VINES, and Alloy NTNX
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=BCh,AH=D1h,AH=D2h,AH=D4h,AH=EBh
- --------v-21D000-----------------------------
- INT 21 - VIRUS - "Fellowship" - INSTALLATION CHECK
- AX = D000h
- Return: BX = 1234h if resident
- SeeAlso: AH=CCh"VIRUS",AH=D5h"VIRUS",AX=D5AAh
- --------N-21D1-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOCK LOGICAL RECORD SET
- AH = D1h
- AL = lock type (00h exclusive, 01h shareable)
- if function C6h lock mode 00h:
- DL = mode
- 00h no wait
- 01h wait
- if function C6h lock mode 01h: (Novell only)
- BP = lock timeout in timer ticks (1/18 sec) 0000h = no wait
- 0000h no wait
- Return: AL = status (see AH=CBh)
- Desc: attempt to lock all logical record names listed in the log table
- Notes: this function is supported by NetWare 4.6+, Advanced Netware 1.0+,
- Banyan VINES, and Alloy NTNX
- status FFh will be returned if one or more logical records have been
- exclusively locked by another process
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=C2h,AH=CBh,AH=D0h,AH=D3h,AH=D5h
- --------N-21D2-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE LOGICAL RECORD
- AH = D2h
- DS:DX -> semaphore identifier (counted string up to 99 chars long)
- Return: AL = status
- 00h successful
- FFh no such record
- Desc: unlock the logical record name but do not remove it from the log table
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+,
- Banyan VINES, and Alloy NTNX
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=BDh,AH=D0h,AH=D3h,AH=D4h
- --------N-21D3-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE LOGICAL RECORD SET
- AH = D3h
- Desc: unlock all currently-locked logical record names in the log table, but
- do not remove them from the table
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+,
- Banyan VINES, and Alloy NTNX
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=C3h,AH=CDh,AH=D1h,AH=D2h,AH=D5h
- --------N-21D4-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR LOGICAL RECORD
- AH = D4h
- DS:DX -> logical record name (counted string up to 99 chars long)
- Return: AL = status
- 00h successful
- FFh no such record name
- Desc: unlock and remove the logical record name from the log table
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+,
- Banyan VINES, and Alloy NTNX
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=BEh,AH=D0h,AH=D2h,AH=D5h
- --------N-21D5-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR LOGICAL RECORD SET
- AH = D5h
- Return: AL = error code (see AH=D4h)
- Desc: unlock and remove all logical record name from the log table
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+,
- Banyan VINES, and Alloy NTNX
- locks on logical record names are advisory and may be ignored by other
- applications
- SeeAlso: AH=D1h,AH=D3h,AH=D4h
- --------v-21D5-------------------------------
- INT 21 - VIRUS - "Carfield" - ???
- AH = D5h
- ???
- Return: ???
- SeeAlso: AX=D5AAh,AH=F3h"Carfield"
- --------v-21D5AA-----------------------------
- INT 21 - VIRUS - "Diamond-A", "Diamond-B" - INSTALLATION CHECK
- AX = D5AAh
- Return: AX = 2A55h if "Diamond-A" resident
- AX = 2A03h if "Diamond-B"-family virus resident
- SeeAlso: AX=D000h,AH=D5h"VIRUS",AX=D5AAh/BP=DEAAh
- --------v-21D5AABPDEAA-----------------------
- INT 21 - VIRUS - "Dir" - INSTALLATION CHECK
- AX = D5AAh
- BP = DEAAh
- Return: SI = 4321h if resident
- SeeAlso: AX=D5AAh,AX=DADAh"VIRUS"
- --------N-21D6-------------------------------
- INT 21 - Novell NetWare - WORKSTATION - END OF JOB
- AH = D6h
- BX = job flag (0000h current job, FFFFh all processes on workstation)
- Return: AL = error code
- Desc: unlocks and clears all locked or logged files and records held by the
- process(es), closes all files, resets error and lock modes, and
- releases all network resources
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=BBh,AH=D7h
- --------N-21D7-------------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - SYSTEM LOGOUT
- AH = D7h
- Return: AL = error code
- Desc: this function closes the caller's open files, logs it out from all
- file servers, detaches the workstation from all non-default file
- servers, and maps a drive to the default server's SYS:LOGIN directory
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=D6h,AH=E3h/SF=14h,AH=F1h
- --------N-21D8-------------------------------
- INT 21 - Novell NetWare, Banyan VINES - ALLOCATE RESOURCE
- AH = D8h
- DL = resource number
- Return: AL = status
- 00h successful
- FFh unsucessful
- Note: this function is no longer used or supported by NetWare, and is not
- documented in Novell documents
- SeeAlso: AH=D9h
- --------N-21D9-------------------------------
- INT 21 - Novell NetWare, Banyan VINES - DEALLOCATE RESOURCE
- AH = D9h
- DL = resource number
- Return: AL = status (see AH=D8h)
- Note: this function is no longer used or supported by NetWare, and is not
- documented in Novell documents
- SeeAlso: AH=D8h
- --------N-21DA-------------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET VOLUME INFO WITH NUMBER
- AH = DAh
- DL = volume number
- ES:DI -> reply buffer (see below)
- Return: AL = 00h
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=36h,AH=E2h/SF=15h,AH=E3h/SF=E9h
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD sectors/block
- 02h WORD total blocks on volume
- 04h WORD unused blocks
- 06h WORD total directory entries
- 08h WORD unused directory entries
- 0Ah 16 BYTEs volume name, null padded
- 1Ah WORD removable flag, 0000h = not removable
- Note: all words are big-endian
- --------v-21DADA-----------------------------
- INT 21 - VIRUS - "Gotcha" - INSTALLATION CHECK
- AX = DADAh
- Return: AH = A5h
- SeeAlso: AX=D5AAh,AH=DAFEh"VIRUS"
- --------v-21DAFE-----------------------------
- INT 21 - VIRUS - "Plovdiv 1.3" - INSTALLATION CHECK
- AX = DAFEh
- Return: AX = 1234h if resident
- SeeAlso: AX=DADAh,AH=DDh"VIRUS",AH=DEh"VIRUS"
- --------N-21DB-------------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET NUMBER OF LOCAL DRIVES
- AH = DBh
- Return: AL = number of local disks as set by LASTDRIVE in CONFIG.SYS
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=0Eh
- --------N-21DC-------------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - GET CONNECTION NUMBER
- AH = DCh
- Return: AL = logical connection number
- 00h if NetWare not loaded or this machine is a non-dedicated server
- CX = station number in ASCII (CL = first digit)
- Notes: this function is supported by NetWare 4.0+, Banyan VINES, and Alloy
- NTNX
- station number only unique for those PCs connected to same semaphore
- service
- --------d-21DC-------------------------------
- INT 21 - PCMag PCMANAGE/DCOMPRES - TURN ON/OFF
- AH = DCh
- DX = state
- 0000h turn on
- 0001h turn off
- SeeAlso: AX=FEDCh
- --------N-21DD-------------------------------
- INT 21 - Novell NetWare - WORKSTATION - SET NetWare ERROR MODE
- AH = DDh
- DL = error mode
- 00h invoke INT 24 on critical I/O errors (default)
- 01h return NetWare extended error code in AL
- 02h return error code in AL, mapped to standard DOS error codes
- Return: AL = previous error mode
- Note: this function is supported by Advanced NetWare 2.0+
- SeeAlso: INT 24
- --------v-21DD-------------------------------
- INT 21 - VIRUS - "Jerusalem"-family - RELOCATE VIRUS???
- AH = DDh
- CX = number of bytes to copy
- DS:SI -> source of copy
- ES:DI -> destination of copy
- Return: does not return normally; return address is caller's CS:0100h with
- AX = ???
- SeeAlso: AH=E0h"VIRUS",AH=EEh"VIRUS"
- --------v-21DE-------------------------------
- INT 21 - VIRUS - "Durban" - INSTALLATION CHECK
- AH = DEh
- Return: AH = DFh if resident
- SeeAlso: AX=DAFEh,AX=DEDEh"VIRUS"
- --------v-21DE-------------------------------
- INT 21 - VIRUS - "April 1st EXE" - ???
- AH = DEh
- ???
- Return: ???
- --------N-21DE-------------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - SET BROADCAST MODE
- AH = DEh
- DL = broadcast mode
- 00h receive server and workstation broadcasts (default)
- 01h receive server broadcasts, discard user messages
- 02h store server broadcasts for retrieval
- 03h store all broadcasts for retrieval
- Return: AL = new broadcast mode
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- --------N-21DE--DL04-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - GET BROADCAST MODE
- AH = DEh
- DL = 04h
- Return: AL = current broadcast mode
- 00h receive server and workstation broadcasts (default)
- 01h receive server broadcasts, discard user message
- 02h store server broadcasts for retrieval
- 03h store all broadcasts for retrieval
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- --------N-21DE-------------------------------
- INT 21 - Novell NetWare - SHELL TIMER INTERRUPT CHECKS
- AH = DEh
- DL = function
- 05h disable shell timer interrupt checks
- 06h enable shell timer interrupt checks
- Return: ???
- Note: this function was added in NetWare 4.0, but is not listed in current
- Novell documentation and is probably no longer supported
- --------v-21DEDE-----------------------------
- INT 21 - VIRUS - "Brothers" - INSTALLATION CHECK
- AX = DEDEh
- Return: AH = 41h if resident
- SeeAlso: AH=DEh"VIRUS",AH=E0h"VIRUS"
- --------N-21DF--DL00-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - START LPT CAPTURE
- AH = DFh
- DL = 00h
- Return: AL = status
- 00h successful
- Desc: this function redirects the default LPT to a capture file on the file
- server
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX; under NTNX, it sends a print break (see INT 17/AH=84h)
- a print job is queued when the first character of output is captured
- SeeAlso: AX=B800h,AX=B804h,AH=DFh/DL=01h,AH=DFh/DL=02h,AH=DFh/DL=03h
- SeeAlso: AH=DFh/DL=04h,AX=F003h
- --------N-21DF--DL01-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - END LPT CAPTURE
- AH = DFh
- DL = 01h
- Return: AL = status
- 00h successful
- Desc: stop redirecting the default LPT, close the capture file, and release
- the job in the print queue for printing
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX; under NTNX, it sends a print break (see INT 17/AH=84h)
- after this call, the default LPT defaults to local printing
- SeeAlso: AH=DFh/DL=00h,AH=DFh/DL=02h,AH=DFh/DL=03h,AH=DFh/DL=05h
- --------N-21DF--DL02-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - CANCEL LPT CAPTURE
- AH = DFh
- DL = 02h
- Return: AL = status
- 00h successful
- Desc: this function ends the capture of the default LPT, removes the job from
- the print queue, and deletes the capture file unless it is a
- permanent capture file
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX; under NTNX, it sends a print break (see INT 17/AH=84h)
- after this call, the default LPT defaults to local printing
- SeeAlso: AH=DFh/DL=00h,AH=DFh/DL=06h
- --------N-21DF--DL03-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - FLUSH LPT CAPTURE
- AH = DFh
- DL = 03h
- Return: AL = status
- 00h successful
- Desc: this function closes the current capture file for the default LPT
- and starts printing it if it is not a permanent capture file
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX; under NTNX, it sends a print break (see INT 17/AH=84h)
- if more data is sent to the LPT port after this call, a new capture
- file will be opeend
- SeeAlso: AH=DFh/DL=00h,AH=DFh/DL=01h,AH=DFh/DL=02h,AH=DFh/DL=07h
- --------N-21DF--DL04-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - START SPECIFIC LPT CAPTURE
- AH = DFh
- DL = 04h
- DH = LPT port (00h-02h)
- Return: AL = status
- 00h successful
- Desc: this function redirects the specified LPT to a capture file on the file
- server
- Notes: this function is supported by Advanced NetWare 2.1+
- a print job is queued when the first character of output is captured
- SeeAlso: AX=B800h,AH=DFh/DL=00h,AH=DFh/DL=05h,AH=DFh/DL=06h,AH=DFh/DL=07h
- SeeAlso: AX=F003h
- --------N-21DF--DL05-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - END SPECIFIC LPT CAPTURE
- AH = DFh
- DL = 05h
- DH = LPT port (00h-02h)
- Return: AL = status
- 00h successful
- Desc: stop redirecting the specified LPT, close the capture file, and release
- the job in the print queue for printing
- Notes: this function is supported by Advanced NetWare 2.1+
- after this call, the specified LPT defaults to local printing
- SeeAlso: AH=DFh/DL=01h,AH=DFh/DL=04h,AH=DFh/DL=06h,AH=DFh/DL=07h
- --------N-21DF--DL06-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - CANCEL SPECIFIC LPT CAPTURE
- AH = DFh
- DL = 06h
- DH = LPT port (00h-02h)
- Return: AL = status
- 00h successful
- Desc: this function ends the capture of the specified LPT, removes the job
- from the print queue, and deletes the capture file unless it is a
- permanent capture file
- Notes: this function is supported by Advanced NetWare 2.1+
- after this call, the specified LPT defaults to local printing
- SeeAlso: AH=DFh/DL=02h,AH=DFh/DL=04h,AH=DFh/DL=05h,AH=DFh/DL=07h
- --------N-21DF--DL07-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - FLUSH SPECIFIC LPT CAPTURE
- AH = DFh
- DL = 07h
- DH = LPT port (00h-02h)
- Return: AL = status
- 00h successful
- Desc: this function closes the current capture file for the specified LPT
- and starts printing it if it is not a permanent capture file
- Notes: this function is supported by Advanced NetWare 2.1+
- if more data is sent to the LPT port after this call, a new capture
- file will be opeend
- SeeAlso: AH=DFh/DL=03h,AH=DFh/DL=04h,AH=DFh/DL=05h,AH=DFh/DL=06h
- --------O-21E0-------------------------------
- INT 21 - Digital Research DOS Plus - CALL BDOS
- AH = E0h
- CL = BDOS function number (see INT E0"CP/M")
- other registers as appropriate for function
- Return: as appropriate for function
- SeeAlso: AX=4459h,INT E0"CP/M"
- --------E-21E0-------------------------------
- INT 21 - OS/286, OS/386 - INITIALIZE REAL PROCEDURE
- AH = E0h
- ???
- Return: ???
- SeeAlso: AH=E1h"OS/286"
- --------T-21E0-------------------------------
- INT 21 - DoubleDOS - MENU CONTROL
- AH = E0h
- AL = subfunction
- 01h exchange tasks
- 73h resume invisible job if suspended
- 74h kill other job
- 75h suspend invisible job
- Note: identical to AH=F0h
- SeeAlso: AH=F0h"DoubleDOS"
- --------v-21E0-------------------------------
- INT 21 - VIRUS - "Jerusalem", "Armagedon" - INSTALLATION CHECK
- AH = E0h
- Return: AX = 0300h if "Jerusalem" resident
- AX = DADAh if "Armagedon" resident
- SeeAlso: AH=DEh"VIRUS",AX=DEDEh"VIRUS",AX=E00Fh
- --------N-21E0-------------------------------
- INT 21 - Novell NetWare, Alloy NTNX - PRINT SPOOLING
- AH = E0h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer
- Return: AL = status
- Note: this function was added in NetWare 4.0, but is no longer listed in
- current Novell documentation and may no longer be supported
- SeeAlso: AH-E3h/SF=68h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data
- 02h BYTE subfunction
- 00h spool data to a capture file
- 01h close and queue capture file
- 02h set spool flags
- 03h spool existing file
- 04h get spool queue entry
- 05h remove entry from spool queue
- 03h ???
- --------N-21E0--SF06-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET PRINTER STATUS
- AH = E0h subfn 06h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FFh no such printer
- Desc: get current state of specified printer attached to the server
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 06h (subfunction "Get Printer Status")
- 03h BYTE printer number (00h-04h)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0004h (size of following results buffer)
- 02h BYTE flag: 00h printer active, FFh printer halted
- 03h BYTE flag: 00h printer online, 01h printer offline
- 04h BYTE current form type
- 05h BYTE target printer number (00h-04h)
- same as number in request buffer unless rerouted by server
- console
- --------N-21E0--SF09-------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - SPECIFY CAPTURE FILE
- AH = E0h subfn 09h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 9Ch invalid path
- Desc: create a permanent capture file for the next print capture to be
- started
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- the caller must have read, write, and create rights for the directory
- containing the capture file
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 102h)
- 02h BYTE 09h (subfunction "Specify Capture File")
- 03h BYTE directory handle or 00h
- 04h BYTE length of filename
- 05h N BYTEs name of capture file
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------v-21E00F-----------------------------
- INT 21 - VIRUS - "8-tunes" - INSTALLATION CHECK
- AX = E00Fh
- Return: AX = 4C31h if resident
- SeeAlso: AH=E0h"VIRUS",AH=E1h"VIRUS"
- --------E-21E1-------------------------------
- INT 21 - OS/286, OS/386 - ISSUE REAL PROCEDURE CALL
- AH = E1h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AH=E0h"OS/286",AH=E2h"OS/286",AH=E3h"OS/286",AX=250Eh,INT 31/AX=0301h
- --------T-21E1-------------------------------
- INT 21 - DoubleDOS - CLEAR KEYBOARD BUFFER FOR CURRENT JOB
- AH = E1h
- SeeAlso: AH=E2h"DoubleDOS",AH=E3h"DoubleDOS",AH=E8h"DoubleDOS"
- SeeAlso: AH=F1h"DoubleDOS"
- --------v-21E1-------------------------------
- INT 21 - VIRUS - "Mendoza", "Fu Manchu" - INSTALLATION CHECK
- AH = E1h
- Return: AX = 0300h if "Mendoza" resident
- AX = 0400h if "Fu Manchu" resident
- SeeAlso: AX=E00Fh,AH=E4h"VIRUS"
- --------N-21E1--SF00-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - SEND BROADCAST MESSAGE
- AH = E1h subfn 00h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FEh I/O error or out of dynamic workspace
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=DEh"NetWare",AH=DEh/DL=04h,AH=E1h/SF=01h,AH=E1h/SF=04h
- SeeAlso: AH=E1h/SF=09h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 9Eh)
- 02h BYTE 00h (subfunction "Send Broadcast Message")
- 03h BYTE number of connections (01h-64h)
- 04h N BYTEs list of connections to receive broadcast message
- BYTE length of message (01h-37h)
- N BYTEs broadcast message (no control characters or characters > 7Eh)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs list of per-connection results
- 00h successful
- FCh message rejected due to lack of buffer space
- FDh invalid connection number
- FFh blocked (see also AH=E1h/SF=02h)
- --------N-21E1--SF01-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - GET BROADCAST MESSAGE
- AH = E1h subfn 01h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FCh full message queue
- FEh out of dynamic workspace
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=DEh/DL=04h,AH=E1h/SF=00h,AH=E1h/SF=05h,AH=E1h/SF=09h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 01h (subfunction "Get Broadcast Message")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 38h)
- 02h BYTE length of message (00h-37h)
- 00h if no broadcast messages pending
- 03h N BYTEs message (no control characters or characters > 7Eh)
- --------N-21E1-------------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - ENABLE/DISABLE BROADCAST MESSAGES
- AH = E1h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer
- Return: AL = error code
- Note: these functions are supported by NetWare 4.0+ but are not listed in
- _NetWare_System_Calls--DOS_; they may be obsolete
- SeeAlso: AH=E1h/SF=00h,AH=E1h/SF=04h,AH=E1h/SF=09h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 9Eh)
- 02h BYTE subfunction
- 02h disable station broadcasts
- 03h enable station broadcasts
- 03h ???
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer
- 02h ???
- --------N-21E1--SF04-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - SEND PERSONAL MESSAGE
- AH = E1h subfn 04h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FEh I/O error or out of dynamic workspace
- Notes: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- message pipes use CPU time on the file server; IPX, SPX, or NetBIOS
- connections should be used for peer-to-peer communications as these
- protocols do not use file server time
- SeeAlso: AH=E1h/SF=00h,AH=E1h/SF=05h,AH=E1h/SF=06h,AH=E1h/SF=08h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max E5h)
- 02h BYTE 04h (subfunction "Send Personal Message")
- 03h BYTE number of connections (01h-64h)
- 04h N BYTEs list of connections to receive broadcast message
- BYTE length of message (01h-7Eh)
- N BYTEs message (no control characters or characters > 7Eh)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs list of per-connection results
- 00h successful
- FCh message rejected because queue is full (contains 6 msgs)
- FDh incomplete pipe
- FFh failed
- --------N-21E1--SF05-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - GET PERSONAL MESSAGE
- AH = E1h subfn 05h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FEh out of dynamic workspace
- Desc: return the oldest message in the default file server's message queue
- for the calling workstation
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=E1h/SF=01h,AH=E1h/SF=04h,AH=E1h/SF=06h,AH=E1h/SF=08h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 05h (subfunction "Get Personal Message")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 80h)
- 02h BYTE connection number of sending station
- 03h BYTE length of message (00h-7Eh)
- 00h if no personal messages pending
- 04h N BYTEs message (no control characters or characters > 7Eh)
- --------N-21E1--SF06-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - OPEN MESSAGE PIPE
- AH = E1h subfn 06h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FEh out of dynamic workspace
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=E1h/SF=04h,AH=E1h/SF=07h,AH=E1h/SF=08h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 66h)
- 02h BYTE 06h (subfunction "Open Message Pipe")
- 03h BYTE number of pipes to open (01h-64h)
- 04h N BYTEs list of connection numbers
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs list of results
- 00h successful
- FEh incomplete (target half not yet created)
- FFh failed
- --------N-21E1--SF07-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - CLOSE MESSAGE PIPE
- AH = E1h subfn 07h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- FCh full message queue
- FEh out of dynamic workspace
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=E1h/SF=05h,AH=E1h/SF=06h,AH=E1h/SF=08h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 66h)
- 02h BYTE 07h (subfunction "Close Message Pipe")
- 03h BYTE number of pipes to close (01h-64h)
- 04h N BYTEs list of connection numbers
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs list of results
- 00h successful
- FDh failed
- FFh no such pipe
- --------N-21E1--SF08-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - CHECK PIPE STATUS
- AH = E1h subfn 08h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=E1h/SF=05h,AH=E1h/SF=06h,AH=E1h/SF=07h
-
- Values for status:
- 00h successful
- FCh full message queue
- FEh out of dynamic workspace
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 66h)
- 02h BYTE 08h (subfunction "Check Pipe Status")
- 03h BYTE number of pipes to monitor (01h-64h)
- 04h N BYTEs list of connection numbers
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs list of pipe statuses
- 00h open
- FEh incomplete
- FFh closed
- --------N-21E1--SF09-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - BROADCAST TO CONSOLE
- AH = E1h subfn 09h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E1h/SF=09h)
- Desc: send a one-line message to the system console on the default file
- server
- Note: this function is supported by NetWare 4.0+ and Advanced NetWare 1.0+
- SeeAlso: AH=DEh/DL=04h,AH=E1h/SF=00h,AH=E1h/SF=01h,AH=E3h/SF=D1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 3Eh)
- 02h BYTE 09h (subfunction "Broadcast to Console")
- 03h BYTE length of message (01h-3Ch)
- 04h N BYTEs message (no control characters or characters > 7Eh)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------E-21E2-------------------------------
- INT 21 - OS/286, OS/386 - SET REAL PROCEDURE SIGNAL HANDLER
- AH = E2h
- ???
- Return: ???
- SeeAlso: AH=E0h"OS/286",AH=E1h"OS/286",AH=E6h"OS/286"
- --------N-21E2-------------------------------
- INT 21 - DoubleDOS - SEND CHARACTER TO KEYBOARD BUFFER OF OTHER JOB
- AH = E2h
- AL = character
- Return: AL = 00h successful
- 01h buffer full (128 characters)
- SeeAlso: AH=E1h"DoubleDOS",AH=E3h"DoubleDOS",AH=E8h"DoubleDOS"
- SeeAlso: AH=F2h"DoubleDOS"
- --------N-21E2--SF00-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SET DIRECTORY HANDLE
- AH = E2h subfn 00h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h,9Bh,9Ch) (see below)
- Desc: set the target handle to reference the directory specified by the
- source handle and the source path; both handles must refer to the
- same file server
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- the target handle is not changed if this function fails
- SeeAlso: AH=E2h/SF=01h,AH=E2h/SF=12h,AH=E2h/SF=13h
-
- Values for status:
- 00h successful
- 84h not permitted to create
- 8Ah not permitted to delete
- 8Bh not permitted to rename
- 8Ch not permitted to modify
- 98h nonexistent volume
- 9Bh invalid directory handle
- 9Ch invalid path
- 9Eh invalid filename
- 9Fh directory currently in use
- A0h directory not empty
- FCh no such bindery object
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 00h (subfunction "Set Directory Handle")
- 03h BYTE directory handle of target
- 04h BYTE directory handle of source
- 05h BYTE length of source directory path (01h-FFh)
- 06h N BYTEs source directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E2--SF01-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET DIRECTORY PATH
- AH = E2h subfn 01h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,9Bh) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=02h,AH=E2h/SF=03h,AH=E2h/SF=1Ah,AH=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 01h (subfunction "Get Directory Path")
- 03h BYTE directory handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following data buffer
- 02h BYTE length of directory path (01h-FFh)
- 03h N BYTEs full directory path including volume
- --------N-21E2--SF02-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SCAN DIRECTORY INFORMATION
- AH = E2h subfn 02h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h,9Bh,9Ch) (see AH=E2h/SF=00h)
- Desc: get information about the first or next subdirectory of the specified
- directory
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=01h,AH=E2h/SF=03h,AH=E2h/SF=19h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 104h)
- 02h BYTE 02h (subfunction "Scan Directory Information")
- 03h BYTE directory handle
- 04h WORD subdirectory number (big-endian)
- 0000h for first call, returned subdir number + 1 on next call
- 06h BYTE length of directory path
- 07h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 001Ch (length of following data buffer)
- 02h 16 BYTEs subdirectory name
- 12h DWORD date and time of creation (big-endian) (see below)
- 16h DWORD object ID of owner (bid-endian)
- 1Ah BYTE maximum directory rights (see AH=E2h/SF=03h)
- 1Bh BYTE unused
- 1Ch WORD subdirectory number (big-endian)
-
- Bitfields for date and time:
- bits 31-25 year-1980
- bits 24-21 month
- bits 20-16 day
- bits 15-11 hour
- bits 10-5 minute
- bits 4-0 second
- --------N-21E2--SF03-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET EFFECTIVE DIRECTORY RIGHTS
- AH = E2h subfn 03h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h,9Bh) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=01h,AH=E2h/SF=02h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 102h)
- 02h BYTE 03h (subfunction "Get Effective Directory Rights")
- 03h BYTE directory handle
- 04h BYTE length of directory path (00h-FFh)
- 05h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0001h (length of following data buffer)
- 02h BYTE effective directory rights (see below)
-
- Bitfields for directory rights:
- bit 0 reading allowed
- bit 1 writing allowed
- bit 2 opens allowed
- bit 3 file creation allowed
- bit 4 deletion allowed
- bit 5 "parental" may create/delete subdirectories and
- grant/revoke trustee rights
- bit 6 directory search allowed
- bit 7 file attributes may be changed
- --------N-21E2--SF04-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - MODIFY MAXIMUM RIGHTS MASK
- AH = E2h subfn 04h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,8Ch,98h,9Ch) (see AH=E2h/SF=00h)
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=03h,AH=E2h/SF=0Ah,AH=E2h/SF=0Dh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 104h)
- 02h BYTE 04h (subfunction "Modify Maximum Rights Mask")
- 03h BYTE directory handle
- 04h BYTE rights to grant (see AH=E2h/SF=03h)
- 05h BYTE rights to revoke (see AH=E2h/SF=03h)
- 06h BYTE length of directory path (00h-FFh)
- 07h N BYTEs directory path
- Note: the rights specified at offset 05h are revoked first, and then the
- rights specified at offset 04h are added to the resulting rights
- mask
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E2--SF05-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET VOLUME NUMBER
- AH = E2h subfn 05h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h) (see AH=E2h/SF=00h)
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=DAh,AH=E2h/SF=02h,AH=E2h/SF=05h,AH=E2h/SF=15h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 12h)
- 02h BYTE 05h (subfunction "Get Volume Number")
- 03h BYTE length of volume name (01h-10h)
- 04h N BYTEs volume name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0001h (length of following results buffer)
- 02h BYTE volume number
- --------N-21E2--SF06-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET VOLUME NAME
- AH = E2h subfn 06h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h) (see AH=E2h/SF=00h)
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=DAh,AH=E2h/SF=02h,AH=E2h/SF=05h,AH=E2h/SF=15h,AH=E2h/SF=1Ah
- SeeAlso: AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 06h (subfunction "Get Volume Name")
- 03h BYTE volume number
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0011h (length of following results buffer)
- 02h BYTE length of volume name
- 03h 16 BYTEs NUL-padded volume name
- --------N-21E2--SF0A-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - CREATE DIRECTORY
- AH = E2h subfn 0Ah
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,84h,98h,FCh) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=39h,AH=E2h/SF=0Bh,AH=E2h/SF=0Fh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 0Ah (subfunction "Create Directory")
- 03h BYTE directory handle
- 04h BYTE maximum directory rights (see AH=E2h/SF=01h)
- 05h BYTE length of directory path (00h-FFh)
- 06h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E2--SF0B-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - DELETE DIRECTORY
- AH = E2h subfn 0Bh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,8Ah,98h,9Bh,9Ch,9Fh,A0h) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=3Ah,AH=E2h/SF=0Ah,AH=E2h/SF=0Fh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 0Bh (subfunction "Delete Directory")
- 03h BYTE directory handle
- 04h BYTE unused
- 05h BYTE length of directory path (00h-FFh)
- 06h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E2--SF0C-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SCAN DIRECTORY FOR TRUSTEES
- AH = E2h subfn 0Ch
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 9Ch no more trustees
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E2h/SF=0Dh,AH=E2h/SF=0Eh,AH=E3h/SF=47h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 0Ch (subfunction "Scan Directory For Trustees")
- 03h BYTE directory handle
- 04h BYTE sequence number
- 00h on first call, increment for each subsequent call
- 05h BYTE length of directory path (00h-FFh)
- 06h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0031h (length of following results buffer)
- 02h 16 BYTEs directory name
- 12h 4 BYTEs date and time of creation
- 16h DWORD object ID of owner (big-endian)
- 1Ah 5 DWORDs object IDs of Trustees 0 through 4 (big-endian)
- 00000000h = end of group
- 2Eh 5 BYTEs directory rights for Trustees 0 through 4 (see AH=E2h/SF=03h)
- --------N-21E2--SF0D-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - ADD TRUSTEE TO DIRECTORY
- AH = E2h subfn 0Dh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,8Ch,FCh) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=0Ch,AH=E2h/SF=0Eh,AH=E3h/SF=47h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 107h)
- 02h BYTE 0Dh (subfunction "Add Trustee To Directory")
- 03h BYTE directory handle
- 04h DWORD object ID of trustee (big-endian)
- 08h BYTE trustee directory rights (see AH=E2h/SF=01h)
- 09h BYTE length of directory path (00h-FFh)
- 0Ah N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E2--SF0E-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - DELETE TRUSTEE FROM DIRECTORY
- AH = E2h subfn 0Eh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h,9Bh,9Ch) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=0Ch,AH=E2h/SF=0Dh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 107h)
- 02h BYTE 0Eh (subfunction "Delete Trustee From Directory")
- 03h BYTE directory handle
- 04h DWORD object ID of trustee (big-endian)
- 08h BYTE unused
- 09h BYTE length of directory path (00h-FFh)
- 0Ah N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E2--SF0F-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - RENAME DIRECTORY
- AH = E2h subfn 0Fh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,8Bh,9Bh,9Ch,9Eh) (see AH=E2h/SF=00h)
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- directories SYS:LOGIN, SYS:MAIL, and SYS:PUBLIC must not be renamed
- SeeAlso: AH=56h,AH=E2h/SF=0Ah,AH=E2h/SF=0Bh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 111h)
- 02h BYTE 0Fh (subfunction "Rename Directory")
- 03h BYTE directory handle
- 04h BYTE length of directory path (00h-FFh)
- 05h N BYTEs directory path
- BYTE length of new directory name (01h-0Eh)
- N BYTEs new directory name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E2--SF10-------------------------
- INT 21 - Novell NetWare - FILE SERVICES - PURGE ERASED FILES
- AH = E2h subfn 10h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Desc: purges files marked for deletion on the file server by the calling
- workstation
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=13h,AH=41h,AH=E2h/SF=11h,AH=E3h/SF=CEh,AX=F244h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 10h (subfunction "Purge Erased Files")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E2--SF11-------------------------
- INT 21 - Novell NetWare - FILE SERVICES - RESTORE ERASED FILE
- AH = E2h subfn 11h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 98h nonexistent volume
- FFh no more erased files
- Desc: restores one file marked for deletion which has not yet been purged
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=13h,AH=41h,AH=E2h/SF=10h,AH=E3h/SF=CEh,AX=F244h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 13h)
- 02h BYTE 11h (subfunction "Restore Erased File")
- 03h BYTE directory handle or 00h
- 04h BYTE length of volume name
- 05h N BYTEs volume name (including colon)
- Note: if both a directory handle and a volume name are specified, the volume
- name overrides the handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 001Eh (size of following results buffer)
- 02h 15 BYTEs ASCIZ name of erased file
- 11h 15 BYTEs ASCIZ name under which file was restored
- --------N-21E2--SF12-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - ALLOC PERMANENT DIRECTORY HANDLE
- AH = E2h subfn 12h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,98h,9Ch) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=00h,AH=E2h/SF=13h,AH=E2h/SF=14h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 12h (subfunction "Alloc Permanent Directory Handle")
- 03h BYTE directory handle
- 04h BYTE drive ('A'-'Z')
- 05h BYTE length of directory path
- 06h N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0002h (size of following results buffer)
- 02h BYTE new directory handle
- 03h BYTE effective directory rights (see AH=E2h/SF=01h)
- --------N-21E2--SF13-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - ALLOC TEMPORARY DIRECTORY HANDLE
- AH = E2h subfn 13h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see AH=E2h/SF=12h)
- Return: AL = status (00h,98h,9Ch) (see AH=E2h/SF=00h)
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- this call is the same as AH=E2h/SF=12h except that the directory handle
- will be automatically deallocated when the calling application
- executes an End of Job call (AH=D6h) or terminates
- SeeAlso: AH=D6h,AH=E2h/SF=00h,AH=E2h/SF=12h,AH=E2h/SF=14h,AH=E2h/SF=16h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 103h)
- 02h BYTE 13h (subfunction "Alloc Temporary Directory Handle")
- 03h BYTE directory handle
- 04h BYTE drive ('A'-'Z')
- 05h BYTE length of directory path
- 06h N BYTEs directory path
- --------N-21E2--SF14-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - DEALLOCATE DIRECTORY HANDLE
- AH = E2h subfn 14h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,9Bh) (see AH=E2h/SF=00h)
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=12h,AH=E2h/SF=13h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 14h (subfunction "Deallocate Directory Handle")
- 03h BYTE directory handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no returned data)
- --------N-21E2--SF15-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET VOLUME INFO WITH HANDLE
- AH = E2h subfn 15h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=DAh,AH=E2h/SF=02h,AH=E2h/SF=06h,AH=E2h/SF=19h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 15h (subfunction "Get Volume Info With Handle")
- 03h BYTE directory handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 001Ch (length of following results buffer)
- 02h WORD sectors per block (big-endian)
- 04h WORD total blocks on volume (big-endian)
- 06h WORD blocks available on volume (big-endian)
- 08h WORD total directory slots (big-endian)
- 0Ah WORD directory slots available (big-endian)
- 0Ch 16 BYTEs NUL-padded volume name
- 1Ch WORD flag: volume removable if nonzero (big-endian)
- --------N-21E2--SF16-------------------------
- INT 21 u - Novell NetWare - DIRECTORY SERVICES - ALLOC SPECIAL TEMP DIR HANDLE
- AH = E2h subfn 16h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer
- Return: AL = status
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX,
- but is not described in _NetWare_System_Calls--DOS_
- SeeAlso: AH=E2h/SF=13h,AH=E2h/SF=14h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data
- 02h BYTE 16h (subfunction "Allocate Special Temporary Directory Handle")
- ???
- --------N-21E2--SF17-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SAVE DIRECTORY HANDLE
- AH = E2h subfn 17h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- else network error code
- Note: this function is supported by Advanced NetWare 2.0+ and Alloy NTNX
- SeeAlso: AH=E2h/SF=12h,AH=E2h/SF=17h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 18h (subfunction "Restore Directory Handle")
- 03h BYTE directory handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0010h (length of following results buffer)
- 02h 16 BYTEs save buffer
- --------N-21E2--SF18-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - RESTORE DIRECTORY HANDLE
- AH = E2h subfn 18h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- else network error code
- Desc: restore a previously saved directory handle to reproduce an executing
- environment, possibly on a different execution site
- Note: this function is supported by Advanced NetWare 2.0+ and Alloy NTNX
- SeeAlso: AH=E2h/SF=12h,AH=E2h/SF=17h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0011h (length of following data)
- 02h BYTE 18h (subfunction "Restore Directory Handle")
- 03h 16 BYTEs save buffer
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0002h (length of following results buffer)
- 02h BYTE new directory handle
- 03h BYTE effective rights (see AH=E2h/SF=03h)
- --------N-21E2--SF19-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SET DIRECTORY INFORMATION
- AH = E2h subfn 19h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,9Bh,9Ch) (see AH=E2h/SF=00h)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E2h/SF=02h,AH=E2h/SF=0Fh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 10Bh)
- 02h BYTE 19h (subfunction "Set Directory Information")
- 03h BYTE directory handle
- 04h DWORD date and time of creation (big-endian)
- 08h DWORD object ID of owner (big-endian)
- 0Ch BYTE maximum directory rightes (see AH=E2h/SF=03h)
- 0Dh BYTE length of directory path
- 0Eh N BYTEs directory path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E2--SF1A-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET PATH FROM DIRECTORY ENTRY
- AH = E2h subfn 1Ah
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=01h,AH=E2h/SF=06h,AH=E3h/SF=D7h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0004h (length of following data)
- 02h BYTE 1Ah (subfunction "Get Path From Directory Entry")
- 03h BYTE volume number (00h-1Fh)
- 04h WORD directory entry number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 200h)
- 02h 256 BYTEs path
- --------E-21E3-------------------------------
- INT 21 - OS/286, OS/386 - ISSUE REAL INTERRUPT
- AH = E3h
- AL = interrupt number
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AH=E1h"OS/286",INT 31/AX=0300h
- --------T-21E3-------------------------------
- INT 21 - DoubleDOS - ADD CHARACTER TO KEYBOARD BUFFER OF CURRENT JOB
- AH = E3h
- AL = character
- Return: AL = 00h successful
- 01h buffer full (128 characters)
- SeeAlso: AH=E1h"DoubleDOS",AH=E2h"DoubleDOS",AH=E8h"DoubleDOS"
- SeeAlso: AH=F3h"DoubleDOS"
- --------N-21E3-------------------------------
- INT 21 - Novell NetWare - CONNECTION CONTROL
- AH = E3h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- else error code
- Note: supported by NetWare 4.0+, Advanced NetWare 1.0+, and Alloy NTNX
- SeeAlso: AH=E3h/SF=0Ah,AH=E3h/SF=32h,AH=E3h/SF=64h,AH=E3h/SF=C8h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data
- 02h BYTE subfunction number
- 00h login
- 01h change password
- 02h map user to station set
- 03h map object to number
- 04h map number to object
- 05h get station's logged information
- 06h get station's root mask (obsolete)
- 07h map group name to number
- 08h map number to group name
- 09h get memberset M of group G
- var depends on subfunction
- Notes: the above subfunctions are not described in _NetWare_System_Calls--DOS_
- see separate entries below for other subfunctions
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following buffer space for results
- var depends on subfunction
-
- Format of object property:
- Offset Size Description
- 00h 1-16 BYTEs property name
- N BYTE flags
- bit 0: property is dynamic
- bit 1: property is a set rather than an item
- N+1 BYTE security levels (see below)
- ???
-
- Names of well-known properties:
- ACCOUNT_BALANCE
- ACCOUNT_SERVERS
- GROUP_MEMBERS
- GROUPS_I'M_IN
- IDENTIFICATION user's name
- LOGIN_CONTROL
- NET_ADDRESS
- OPERATORS
- PASSWORD
- SECURITY_EQUALS
-
- Values for security levels:
- 00h "anyone" everyone may access
- 01h "logged" only logged-in clients may access
- 02h "object" only clients logged-in with object's name, type, and password
- 03h "supervisor" only clients logged-in with supervisor privileges
- 04h "NetWare" only NetWare may access
- Note: the above values are stored in a nybble; the high half-byte is write
- access and the low half-byte is read access
-
- Values for object type:
- 0000h unknown
- 0001h user
- 0002h user group
- 0003h print queue
- 0004h file server
- 0005h job server
- 0006h gateway
- 0007h print server
- 0008h archive queue
- 0009h archive server
- 000Ah job queue
- 000Bh administration
- 0026h remote bridge server
- 0047h advertising print server
- 0048h-8000h reserved
- FFFFh wild (used only for finding objects)
- --------N-21E3--SF0A-------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - ENTER LOGIN AREA
- AH = E3h subfn 0Ah
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: change the login directory for the calling workstation
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=D7h,AH=E3h/SF=14h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 102h)
- 02h BYTE 0Ah (subfunction "Enter Login Area")
- 03h BYTE number of local drives
- 04h BYTE length of subdirectory name (00h-FFh)
- 05h N BYTEs name of subdirectory under SYS:LOGIN where to find the login
- utility
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF0C-------------------------
- INT 21 U - Novell Netware - VERIFY NETWORK SERIAL NUMBER
- AH = E3h subfn 0Ch
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: if the network serial number to be verified is correct, the reply
- buffer will contain the corresponding application number
- SeeAlso: AH=E3h/SF=12h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 0Ch (subfunction "Verify Network Serial Number")
- 03h DWORD network serial number to verify (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0002h (size of following results buffer)
- 02h WORD application number (big-endian)
- --------N-21E3--SF0D-------------------------
- INT 21 - Novell NetWare - MESSAGE SERVICES - LOG NETWORK MESSAGE
- AH = E3h subfn 0Dh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: append a line to the default file server's NET$LOG.MSG file
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E1h/SF=09h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 52h)
- 02h BYTE 0Dh (subfunction "Log Network Message")
- 03h BYTE length of message (01h-50h)
- 04h N BYTEs message (no control characters or characters > 7Eh)
- --------N-21E3--SF0E-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET DISK UTILIZATION
- AH = E3h subfn 0Eh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 98h nonexistent volume
- F2h not permitted to read object
- Notes: this function is supported by Advanced NetWare 2.1+
- the caller must have bindery object read privileges
- SeeAlso: AH=E3h/SF=11h,AH=E3h/SF=D6h,AH=E3h/SF=D9h,AH=E3h/SF=E6h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 0Eh (subfunction "Get Disk Utilization")
- 03h BYTE volume number (00h-1Fh)
- 04h DWORD object ID (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 000Bh (size of following results buffer)
- 02h BYTE volume number (00h-1Fh)
- 03h DWORD object ID (big-endian)
- 07h WORD directories used by object (big-endian)
- 09h WORD files created by object (big-endian)
- 0Bh WORD disk blocks used by object-created files (big-endian)
- --------N-21E3--SF0F-------------------------
- INT 21 - Novell NetWare - FILE SERVICES - SCAN FILE INFORMATION
- AH = E3h subfn 0Fh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 89h not permitted to search directory
- FFh no more matching files
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=B6h,AH=E3h/SF=10h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 105h)
- 02h BYTE 0Fh (subfunction "Scan File Information")
- 03h WORD sequence number (big-endian)
- FFFFh on first call
- 05h BYTE directory handle or 00h
- 06h BYTE search attributes (see AX=4301h)
- 07h BYTE length of filespec
- 08h N BYTEs ASCIZ uppercase filespec
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 005Eh (size of following results buffer)
- 02h WORD next sequence number (place in request buffer for next call)
- 04h 14 BYTEs ASCIZ filename
- 12h BYTE file attributes (see AX=4301h for format)
- 13h BYTE extended file attributes (see AH=B6h for format)
- 14h DWORD file size in bytes (big-endian)
- 18h WORD file's creation date (big-endian) (see AX=5700h for format)
- 1Ah WORD date of last access (big-endian) (see AX=5700h for format)
- 1Ch DWORD date and time of last update (big-endian) (see AH=E2h/SF=02h)
- 20h DWORD object ID of owner (big-endian)
- 24h DWORD date and time last archived (big-endian) (see AH=E2h/SF=02h)
- 28h 55 BYTEs reserved
- Note: the official documentation erroneously lists the field at offset 04h as
- 15 bytes and thus shifts the remaining fields by one byte
- --------N-21E3--SF10-------------------------
- INT 21 - Novell NetWare - FILE SERVICES - SET FILE INFORMATION
- AH = E3h subfn 10h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the caller must have modify privileges on the directory containing the
- file
- SeeAlso: AH=B6h,AH=E3h/SF=0Fh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 151h)
- 02h BYTE 10h (subfunction "Set File Information")
- 03h BYTE file attributes (see AX=4301h for format)
- 04h BYTE extended file attributes (see AH=B6h for format)
- 05h 4 BYTEs reserved
- 09h WORD file's creation date (big-endian) (see AX=5700h for format)
- 0Bh WORD date of last access (big-endian) (see AX=5700h for format)
- 0Dh DWORD date and time of last update (big-endian) (see AH=E2h/SF=02h)
- 11h DWORD object ID of owner (big-endian)
- 15h DWORD date and time last archived (big-endian) (see AH=E2h/SF=02h)
- 19h 56 BYTEs reserved
- 51h BYTE directory handle or 00h
- 52h BYTE search attributes (see AX=4301h for format)
- 53h BYTE length of filename
- 54h N BYTEs filename
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF11-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER INFORMATION
- AH = E3h subfn 11h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: determine the version of software installed on the file server and
- how it is configured
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=0Eh,AE3h/SF=12h,AH=E3h/SF=CDh,AH=E3h/SF=D3h,AH=E3h/SF=E7h
- SeeAlso: AH=E7h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 11h (subfunction "Get File Server Information")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0080h (size of following results buffer)
- 02h 48 BYTEs server's name
- 32h BYTE NetWare version
- 33h BYTE NetWare subversion (0-99)
- 34h WORD number of connections supported (big-endian)
- 36h WORD number of connections in use (big-endian)
- 38h WORD maximum connected volumes (big-endian)
- ---Advanced NetWare 2.1+ ---
- 3Ah BYTE operating system revision number
- 3Bh BYTE fault tolerance (SFT) level
- 3Ch BYTE TTS level
- 3Dh WORD maximum simultaneously-used connections (big-endian)
- 3Fh BYTE accounting version
- 40h BYTE VAP version
- 41h BYTE queueing version
- 42h BYTE print server version
- 43h BYTE virtual console version
- 44h BYTE security restrictions level
- 45h BYTE internetwork bridge version
- 46h 60 BYTEs reserved
- --------N-21E3--SF12--------------------
- INT 21 - Novell NetWare - GET SERIAL NUMBER
- AH = E3h subfn 12h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: return the serial number and application number for the software
- installed on the file server
- Note: this function is supported by Advanced Netware 2.1+
- SeeAlso: AH=E3h/SF=0Ch,AH=E3h/SF=11h
-
- Format of request buffer:
- offset size description
- 00h WORD 0001h (length of following data)
- 02h BYTE 12h (subfunction "Get Serial Number")
-
- Format of reply buffer:
- offset size description
- 00h WORD (call) 0006h (size of following results buffer)
- 02h 4 BYTEs Netware software serial number (big-endian)
- 06h 2 BYTEs Netware software application number (big-endian)
- --------N-21E3--SF13-------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - GET INTERNET ADDRESS
- AH = E3h subfn 13h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=DCh"NetWare",AH=E3h/SF=16h,AH=EEh"NetWare"
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 13h (subfunction "Get Internet Address")
- 03h BYTE logical connection number (01h-64h)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 000Ch (length of following results buffer)
- 02h 4 BYTEs network number
- 06h 6 BYTEs physical node address
- 0Ch 2 BYTEs socket number
- --------N-21E3--SF14-------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - LOGIN TO FILE SERVER
- AH = E3h subfn 14h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: this function retrieves a list indicating the connection numbers under
- which a bindery object is logged into the default file server
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=D7h"NetWare",AH=F1h"NetWare"
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max B3h)
- 02h BYTE 14h (subfunction "Login To File Server")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
- BYTE length of password
- N BYTEs password
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF15-------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - GET OBJECT CONNECTION NUMBERS
- AH = E3h subfn 15h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Desc: this function retrieves a list indicating the connection numbers under
- which a bindery object is logged into the default file server
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=DCh"NetWare",AH=E3h/SF=16h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 33h)
- 02h BYTE 15h (subfunction "Get Object Connection Numbers")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following results buffer (max 65h)
- 02h BYTE number of connections
- 03h N BYTEs connection list
- --------N-21E3--SF16-------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - GET CONNECTION INFORMATION
- AH = E3h subfn 16h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=D7h,AH=DCh"NetWare",AH=E3h/SF=14h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE 16h (subfunction "Get Connection Information")
- 03h BYTE logical connection number (01h-64h)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 003Eh (length of following results buffer)
- 02h DWORD object ID for object logged in on the connection (big-endian)
- 00000000h if no object logged in
- 06h WORD type of object (big-endian)
- 08h 48 BYTEs name of object
- 38h 7 BYTEs login time (see below)
- Note: much of the Novell documentation incorrectly states the reply buffer
- length as 3Dh (62) instead of 3Eh (63)
-
- Format of login time:
- Offset Size Description
- 00h BYTE year (80-99 = 1980-1999, 00-79 = 2000-2079)
- 01h BYTE month (1-12)
- 02h BYTE day (1-31)
- 03h BYTE hour (0-23)
- 04h BYTE minute (0-59)
- 05h BYTE second (0-59)
- 06h BYTE day of week (0 = Sunday)
- --------N-21E3--SF32-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CREATE BINDERY OBJECT
- AH = E3h subfn 32h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=33h,AH=E3h/SF=34h,AH=E3h/SF=38h,AH=E3h/SF=39h
-
- Values for status:
- 00h successful
- 96h server out of memory
- EEh object already exists
- EFh invalid name
- F0h wildcard not allowed
- F1h invalid bindery security level
- F3h not permitted to rename object
- F4h not permitted to delete objects
- F5h not permitted to create objects
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 35h)
- 02h BYTE 32h (subfunction "Create Bindery Object")
- 03h BYTE object flag
- 00h static
- 01h dynamic
- 04h BYTE object security levels
- 05h WORD type of object (big-endian)
- 07h BYTE length of object's name
- 08h N BYTEs object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD 0000h (no data returned)
- --------N-21E3--SF33-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - DELETE BINDERY OBJECT
- AH = E3h subfn 33h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=32h)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=34h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 33h)
- 02h BYTE 33h (subfunction "Delete Bindery Object")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF34-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - RENAME BINDERY OBJECT
- AH = E3h subfn 34h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=32h)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=33h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 63h)
- 02h BYTE 34h (subfunction "Rename Bindery Object")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
- BYTE length of new name (01h-2Fh)
- N BYTEs new name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF35-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - GET BINDERY OBJECT ID
- AH = E3h subfn 35h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 96h server out of memory
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
- Notes: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the requesting workstation must be logged into the file server with
- read access to the bindery object
- SeeAlso: AH=E3h/SF=36h,AH=E3h/SF=44h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 33h)
- 02h BYTE 35h (subfunction "Get Bindery Object ID")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name
- 06h N BYTEs object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0036h (length of following buffer space)
- 02h DWORD object ID (big-endian)
- 06h WORD type of object (big-endian)
- 08h 48 BYTEs object name
- --------N-21E3--SF36-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - GET BINDERY OBJECT NAME
- AH = E3h subfn 36h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Notes: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the requesting workstation must be logged into the file server with
- read access to the bindery object
- SeeAlso: AH=E3h/SF=35h,AH=E3h/SF=44h
-
- Values for status:
- 00h successful
- 96h server out of memory
- EFh invalid name
- F0h wildcard not allowed
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 36h (subfunction "Get Bindery Object Name")
- 03h DWORD object ID (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0036h (length of following buffer space)
- 02h DWORD object ID (big-endian)
- 06h WORD type of object (big-endian)
- 08h 48 BYTEs object name
- --------N-21E3--SF37-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - SCAN BINDERY OBJECT
- AH = E3h subfn 37h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=36h)
- Notes: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the requesting workstation must be logged into the file server with
- read access to the bindery object
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=33h,AH=E3h/SF=38h,AH=E3h/SF=3Ch
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 37h)
- 02h BYTE 37h (subfunction "Scan Bindery Object")
- 03h DWORD last object ID (big-endian)
- 07h WORD type of object (big-endian)
- 09h BYTE length of object's name
- 0Ah N BYTEs object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0039h (length of following buffer space)
- 02h DWORD object ID (big-endian)
- FFFFFFFFh for first call
- 06h WORD type of object (big-endian)
- 08h BYTE length of object's name (01h-2Fh)
- 09h N BYTEs object name
- BYTE object flag (00h static, 01h dynamic)
- BYTE object's security levels
- BYTE object properties flag (00h no, FFh yes)
- --------N-21E3--SF38-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CHANGE BINDERY OBJECT SECURITY
- AH = E3h subfn 38h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 96h server out of memory
- F0h wildcard not allowed
- F1h invalid bindery security level
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=3Bh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 34h)
- 02h BYTE 38h (subfunction "Change Bindery Object Security")
- 03h BYTE new security levels
- 04h WORD type of object (big-endian)
- 06h BYTE length of object's name (01h-2Fh)
- 07h N BYTEs object name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF39-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CREATE PROPERTY
- AH = E3h subfn 39h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=3Bh
-
- Values for status:
- 00h successful
- 96h server out of memory
- EDh property already exists
- EFh invalid name
- F0h wildcard not allowed
- F1h invalid bindery security level
- F6h not permitted to delete properties
- F7h not permitted to create properties
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 45h)
- 02h BYTE 39h (subfunction "Create Property")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
- BYTE property flags
- BYTE property security levels
- BYTE length of property's name (01h-0Fh)
- N BYTEs property's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF3A-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - DELETE PROPERTY
- AH = E3h subfn 3Ah
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=39h)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=32h,AH=E3h/SF=39h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 43h)
- 02h BYTE 3Ah (subfunction "Delete Property")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object's name
- BYTE length of property's name (01h-0Fh)
- N BYTEs property's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF3B-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CHANGE PROPERTY SECURITY
- AH = E3h subfn 3Bh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 96h server out of memory
- F0h wildcard not allowed
- F1h invalid bindery security level
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=38h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 44h)
- 02h BYTE 3Bh (subfunction "Change Property Security")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- BYTE new property security levels
- BYTE length of property's name
- N BYTEs property name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF3C-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - SCAN PROPERTY
- AH = E3h subfn 3Ch
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 96h server out of memory
- F0h wildcard not allowed
- F1h invalid bindery security level
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=37h,AH=E3h/SF=3Bh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 47h)
- 02h BYTE 3Ch (subfunction "Scan Property")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- DWORD sequence number (big-endian)
- FFFFFFFFh for first call
- BYTE length of property's name (01h-0Fh)
- N BYTEs property's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0018h (length of following results buffer)
- 02h 16 BYTEs property name
- 12h BYTE property flags
- 13h BYTE property security levels
- 14h DWORD sequence number (big-endian)
- 18h BYTE property value flag (00h no, FFh yes)
- 19h BYTE more properties (00h no, FFh yes)
- --------N-21E3--SF3D-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - READ PROPERTY VALUE
- AH = E3h subfn 3Dh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Desc: retrieve one 128-byte segment of the specified property's value
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=39h,AH=E3h/SF=3Ch,AH=E3h/SF=3Eh
-
- Values for status:
- 00h successful
- 96h server out of memory
- E8h not item property
- ECh no such segment
- F0h wildcard not allowed
- F1h invalid bindery security level
- F8h not permitted to write property
- F9h not permitted to read property
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 44h)
- 02h BYTE 3Dh (subfunction "Read Property Value")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- BYTE segment number (01h on first call, increment until done)
- BYTE length of property's name (01h-0Fh)
- N BYTEs property name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0082h (length of following results buffer)
- 02h 128 BYTEs property's value
- 82h BYTE more segments (00h no, FFh yes)
- 83h BYTE property's flags
- --------N-21E3--SF3E-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - WRITE PROPERTY VALUE
- AH = E3h subfn 3Eh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=3Dh)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=39h,AH=E3h/SF=3Ch,AH=E3h/SF=3Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max C5h)
- 02h BYTE 3Eh (subfunction "Write Property Value")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- BYTE segment number (01h on first call, increment until done)
- BYTE erase remaining segments (00h no, FFh yes)
- BYTE length of property's name (01h-0Fh)
- N BYTEs property name
- 128 BYTEs property value segment
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF3F-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - VERIFY BINDERY OBJECT PASSWORD
- AH = E3h subfn 3Fh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=40h
-
- Values for status:
- 00h successful
- 96h server out of memory
- F0h wildcard not allowed
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure: no such object, bad password, no password for object,
- or invalid old password
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 133h)
- 02h BYTE 3Fh (subfunction "Verify Bindery Object Password")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- BYTE length of password (00h-7Fh)
- N BYTEs password
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF40-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CHANGE BINDERY OBJECT PASSWORD
- AH = E3h subfn 40h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=3Fh)
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=3Fh,AH=E3h/SF=41h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 133h)
- 02h BYTE 40h (subfunction "Change Bindery Object Password")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name (01h-2Fh)
- 06h N BYTEs object name
- BYTE length of old password (00h-7Fh)
- N BYTEs old password
- BYTE length of new password (00h-7Fh)
- N BYTEs new password
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF41-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - ADD BINDERY OBJECT TO SET
- AH = E3h subfn 41h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see below)
- Desc: add the specified object to a set property
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=40h,AH=E3h/SF=42h,AH=E3h/SF=43h
-
- Values for status:
- 00h successful
- 96h server out of memory
- E9h member already exists
- EAh member does not exist
- EBh not a group property
- F0h wildcard not allowed
- F8h can't write property
- F9h not permitted to read property
- FBh no such property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 75h)
- 02h BYTE 41h (subfunction "Add Bindery Object to Set")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name
- 06h N BYTEs object name
- BYTE length of property name (01h-0Fh)
- N BYTEs property name
- WORD type of member object (big-endian)
- BYTE length of member object's name
- N BYTEs member object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF42-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - DELETE BINDERY OBJECT FROM SET
- AH = E3h subfn 42h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=41h)
- Desc: delete the specified object from a set property
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=40h,AH=E3h/SF=42h,AH=E3h/SF=43h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 75h)
- 02h BYTE 42h (subfunction "Delete Bindery Object from Set")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name
- 06h N BYTEs object name
- BYTE length of property name (01h-0Fh)
- N BYTEs property name
- WORD type of member object (big-endian)
- BYTE length of member object's name
- N BYTEs member object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF43-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - IS BINDERY OBJECT IN SET
- AH = E3h subfn 43h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see AH=E3h/SF=41h)
- Desc: determine whether the specified object is a member of the given set
- property
- Notes: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the caller must have read access to the property
- SeeAlso: AH=E3h/SF=41h,AH=E3h/SF=42h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 75h)
- 02h BYTE 43h (subfunction "Is Bindery Object In Set")
- 03h WORD type of object (big-endian)
- 05h BYTE length of object's name
- 06h N BYTEs object's name
- BYTE length of property's name
- N BYTEs property's name
- WORD type of member object (big-endian)
- BYTE length of member object's name
- N BYTEs member object's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF44-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - CLOSE BINDERY
- AH = E3h subfn 44h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E3h/SF=45h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 44h (subfunction "Close Bindery")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF45-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - OPEN BINDERY
- AH = E3h subfn 45h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Notes: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- the bindery may only be opened by the supervisor or an object with
- equivalent privileges
- SeeAlso: AH=E3h/SF=44h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 45h (subfunction "Open Bindery")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no data returned)
- --------N-21E3--SF46-------------------------
- INT 21 - Novell NetWare - BINDERY SERVICES - GET BINDERY ACCESS LEVEL
- AH = E3h subfn 46h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 46h (subfunction "Get Bindery Access Level")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD 0005h (length of following buffer)
- 02h BYTE security levels
- 03h DWORD object ID (big-endian)
- --------N-21E3--SF47-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - SCAN BINDERY OBJ TRUSTEE PATHS
- AH = E3h subfn 47h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- 96h server out of memory
- F0h wildcard not allowed
- F1h invalid bindery security level
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
- Desc: iterate through the directories to which an object is a trustee
- Note: this function is supported by Advanced NetWare 1.0+ and Alloy NTNX
- SeeAlso: AH=E2h/SF=0Ch,AH=E2h/SF=0Dh,AH=E2h/SF=0Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0008h (length of following data)
- 02h BYTE 47h (subfunction "Scan Bindery Object Trustee Paths")
- 03h BYTE volume number (00h-1Fh)
- 04h WORD last sequence number (big-endian)
- 00h on first call
- 06h DWORD object ID (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following results buffer (max 107h)
- 02h WORD next sequence number (big-endian)
- 04h DWORD object ID (big-endian)
- 08h BYTE trustee directory rights (see AH=E2h/SF=03h)
- 09h BYTE length fo trustee path
- 0Ah N BYTEs trustee path
- --------N-21E3--SF64-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CREATE QUEUE
- AH = E3h subfn 64h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,99h,9Bh,9Ch,EDh-F1h,F5h,F7h,FCh,FEh,FFh)
- (see below)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation with supervisor privileges
- SeeAlso: AH=E3h/SF=65h,AH=E3h/SF=66h,AH=E3h/SF=68h,AH=E3h/SF=6Bh
-
- Values for status:
- 00h successful
- 96h server out of memory
- 99h directory full
- 9Bh invalid directory handle
- 9Ch invalid path
- D0h queue error
- D1h no such queue
- D2h no server for queue
- D3h no queue rights
- D4h queue full
- D5h no queue job
- D6h no job rights
- D7h queue servicing error
- D9h station is not a server
- DAh queue halted
- DBh too many queue servers
- EDh property already exists
- EEh object already exists
- EFh invalid name
- F0h wildcard not allowed
- F1h invalid bindery security level
- F5h not permitted to create object
- F7h not permitted to create property
- FCh no such object
- FEh server bindery locked
- FFh bindery failure
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max ABh)
- 02h BYTE 64h (subfunction "Create Queue")
- 03h WORD queue type (big-endian)
- 05h BYTE length of queue's name (01h-2Fh)
- 06h N BYTEs queue's name
- BYTE directory handle or 00h
- BYTE length of path name (01h-76h)
- N BYTEs path name of directory in which to create queue subdirectory
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0004h (size of following results buffer)
- 02h DWORD object ID of queue (big-endian)
- --------N-21E3--SF65-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - DESTROY QUEUE
- AH = E3h subfn 65h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,FFh) (see also AH=E3h/SF=64h)
- FFh hardware failure
- Desc: abort all active jobs, detach all job servers, remove all job entries,
- delete all job files, remove the queue object and its properties
- from the bindery, and delete the queue's subdirectory
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must have SUPERVISOR privileges
- SeeAlso: AH=E3h/SF=64h,AH=E3h/SF=66h,AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=70h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 65h (subfunction "Destroy Queue")
- 03h DWORD object ID of queue (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF66-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - READ QUEUE CURRENT STATUS
- AH = E3h subfn 66h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D1h-D3h,F1h,FCh,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the queue's Q_USERS or Q_OPERATORS properties
- SeeAlso: AH=E3h/SF=64h,AH=E3h/SF=67h,AH=E3h/SF=6Fh,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 66h (subfunction "Read Queue Current Status")
- 03h DWORD object ID of queue (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0085h (size of following results)
- 02h DWORD object ID of queue (big-endian)
- 06h BYTE status of queue
- bit 0: operator disabled addition of new jobs
- bit 1: operator refuses additional job servers attaching
- bit 2: operator disabled job servicing
- 07h BYTE number of jobs in queue (00h-FAh)
- 08h BYTE number of servers attached to queue (00h-19h)
- 09h 25 DWORDs list of object IDs of attached servers
- 6Dh 25 BYTEs list of attached servers' stations
- 86h BYTE (call) maximum number of servers to return
- --------N-21E3--SF67-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - SET QUEUE CURRENT STATUS
- AH = E3h subfn 67h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,D3h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must have operator privileges
- SeeAlso: AH=E3h/SF=64h,AH=E3h/SF=66h,AH=E3h/SF=6Fh,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0006h (length of following data)
- 02h BYTE 67h (subfunction "Set Queue Current Status")
- 03h DWORD object ID of queue (big-endian)
- 07h BYTE queue status
- bit 0: operator disabled addition of new jobs
- bit 1: operator refuses additional job servers attaching
- bit 2: operator disabled job servicing
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF68-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CREATE QUEUE JOB AND FILE
- AH = E3h subfn 68h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,99h,9Ch,D0h-D4h,DAh,EDh,EFh-F1h,F7h,FCh,FEh,FFh)
- (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the queue's Q_USER property
- SeeAlso: AH=E0h"SPOOLING",AH=E3h/SF=69h,AH=E3h/SF=6Ah,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0107h (length of following data)
- 02h BYTE 68h (subfunction "Close File and Start Queue Job")
- 03h DWORD object ID of queue (big-endian)
- 07h BYTE client station
- 08h BYTE client task number
- 09h DWORD object ID of client (big-endian)
- 0Dh DWORD object ID of target server (big-endian)
- FFFFFFFh if any server acceptable
- 11h 6 BYTEs target execution time (year,month,day,hour,minute,second)
- FFFFFFFFFFFFh to execute as soon as possible
- 17h 6 BYTEs job entry time (year,month,day,hour,minute,second)
- 1Dh WORD job number (big-endian)
- 1Fh WORD job type (big-endian)
- 21h BYTE job position
- 22h BYTE job control flags
- 23h 14 BYTEs ASCIZ job file name
- 31h 6 BYTEs job file handle
- 37h BYTE server station
- 38h BYTE server task number
- 39h DWORD object ID of server (big-endian)
- 3Dh 50 BYTEs ASCIZ job description string
- 6Fh 152 BYTEs client record area
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0036h (size of following results buffer)
- 02h BYTE client station
- 03h BYTE client task number
- 04h DWORD object ID of client (big-endian)
- 08h DWORD object ID of target server (big-endian)
- 0Ch 6 BYTEs target execution time (year,month,day,hour,minute,second)
- 12h 6 BYTEs job entry time (year,month,day,hour,minute,second)
- 18h WORD job number (big-endian)
- 1Ah WORD job type (big-endian)
- 1Ch BYTE job position
- 1Dh BYTE job control flags
- 1Eh 14 BYTEs ASCIZ job file name
- 2Ch 6 BYTEs job file handle
- 32h BYTE server station
- 33h BYTE server task number
- 34h DWORD object ID of server or 00000000h (big-endian)
- --------N-21E3--SF69-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CLOSE FILE AND START QUEUE JOB
- AH = E3h subfn 69h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D3h,D5h,D6h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on the workstation which created the job
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 69h (subfunction "Close File and Start Queue Job")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF6A-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - REMOVE JOB FROM QUEUE
- AH = E3h subfn 6Ah
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D5h,D6h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must have created the job or be an operator
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 6Ah (subfunction "Remove Job From Queue")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF6B-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - GET QUEUE JOB LIST
- AH = E3h subfn 6Bh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h-D3h,FCh,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the Q_USERS or Q_OPERATORS properties
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 6Bh (subfunction "Get Queue Job List")
- 03h DWORD object ID of queue (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 1F6h)
- 02h WORD job count (big-endian)
- 04h N WORDs list of job numbers by position in queue (big-endian)
- WORD maximum job numbers
- --------N-21E3--SF6C-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - READ QUEUE JOB ENTRY
- AH = E3h subfn 6Ch
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h-D3h,D5h,FCh,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the Q_USERS, Q_OPERATORS, or Q_SERVERS properties
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 6Ch (subfunction "Read Queue Job Entry")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0100h (size of following results)
- 02h BYTE client station number
- 03h BYTE client task number
- 04h DWORD object ID of client
- 08h DWORD object ID of target server (big-endian)
- FFFFFFFFh if any server acceptable
- 0Ch 6 BYTEs target execution time (year,month,day,hour,minute,second)
- FFFFFFFFFFFFh if serviced as soon as possible
- 12h 6 BYTEs job entry time (year,month,day,hour,minute,second)
- 18h WORD job number (big-endian)
- 1Ah WORD job type (big-endian)
- 1Ch BYTE job position
- 1Dh BYTE job control flags
- bit 3: job will be serviced automatically if connection broken
- bit 4: job remains in queue after server aborts job
- bit 5: client has not filled associated job file
- bit 6: User Hold--job advances, but cannot be serviced until
- this bit is cleared by user or operator
- bit 7: Operator Hold--job advances, but cannot be serviced
- until this bit is cleared by an operator
- 1Eh 14 BYTEs ASCIZ job filename
- 2Ch 6 BYTEs job file handle
- 32h BYTE server station
- 33h BYTE server task number
- 34h DWORD object ID of server
- 38h 50 BYTEs ASCIZ job description string
- 6Ah 152 BYTEs client record area
- --------N-21E3--SF6D-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CHANGE QUEUE JOB ENTRY
- AH = E3h subfn 6Dh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D5h,D7h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be an operator or the user who created the job
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Ch,AH=E3h/SF=6Eh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0105h (length of following data)
- 02h BYTE 6Dh (subfunction "Change Queue Job Entry")
- 03h DWORD object ID of queue (big-endian)
- 07h BYTE client station number
- 08h BYTE client task number
- 09h DWORD object ID of client
- 0Dh DWORD object ID of target server (big-endian)
- 11h 6 BYTEs target execution time (year,month,day,hour,minute,second)
- 17h 6 BYTEs job entry time (year,month,day,hour,minute,second)
- 1Dh WORD job number (big-endian)
- 1Fh WORD job type (big-endian)
- 21h BYTE job position
- 22h BYTE job control flags
- bit 3: job will be serviced automatically if connection broken
- bit 4: job remains in queue after server aborts job
- bit 5: client has not filled associated job file
- bit 6: User Hold--job advances, but cannot be serviced until
- this bit is cleared by user or operator
- bit 7: Operator Hold--job advances, but cannot be serviced
- until this bit is cleared by an operator
- 23h 14 BYTEs ASCIZ job filename
- 31h 6 BYTEs job file handle
- 37h BYTE server station
- 38h BYTE server task number
- 39h DWORD object ID of server
- 3Dh 50 BYTEs ASCIZ job description string
- 6Fh 152 BYTEs client record area
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF6E-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CHANGE QUEUE JOB POSITION
- AH = E3h subfn 6Eh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D5h,D6h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be an operator
- if the specified position is greater than the number of jobs in the
- queue, the job is placed at the end of the queue
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ah,AH=E3h/SF=6Ch,AH=E3h/SF=6Dh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0008h (length of following data)
- 02h BYTE 6Eh (subfunction "Change Queue Job Position")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
- 09h BYTE new position in queue (01h-FAh)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF6F-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - ATTACH QUEUE SERVER TO QUEUE
- AH = E3h subfn 6Fh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,D3h,DAh,DBh,FEh,FFh)
- (see also AH=E3h/SF=64h)
- FFh bindery failure, or no such property, or no such member
- Desc: attach the calling job server to the specified queue
- Notes: this function is supported by Advanced NetWare 2.1+
- a queue may have up to 25 job servers attached
- the calling workstation must be security-equivalent to a member of the
- queue's Q_SERVERS property
- SeeAlso: AH=E3h/SF=70h,AH=E3h/SF=71h,AH=E3h/SF=72h,AH=E3h/SF=73h,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 6Fh (subfunction "Attach Queue Server To Queue")
- 03h DWORD object ID of queue (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF70-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - DETACH QUEUE SERVER FROM QUEUE
- AH = E3h subfn 70h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,D2h,FEh,FFh) (see AH=E3h/SF=64h)
- Desc: remove the calling job server from the specified queue's list of
- servers
- Notes: this function is supported by Advanced NetWare 2.1+
- the caller must have previously attached itself to the queue
- SeeAlso: AH=E3h/SF=6Fh,AH=E3h/SF=72h,AH=E3h/SF=73h,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE 70h (subfunction "Detach Queue Server From Queue")
- 03h DWORD object ID of queue (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF71-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - SERVICE QUEUE JOB AND OPEN FILE
- AH = E3h subfn 71h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see AH=E3h/SF=68h)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,D3h,D5h,D9h,DAh,FEh,FFh)
- (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- the caller must be on a workstation which is security-equivalent to a
- member of the queue's Q_USERS, Q_OPERATORS, or Q_SERVERS properties
- SeeAlso: AH=E3h/SF=6Fh,AH=E3h/SF=72h,AH=E3h/SF=73h,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 71h (subfunction "Service Queue Job and Open File")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD target job type (big-endian)
- FFFFh any
- --------N-21E3--SF72-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - FINISH SERVICING QUEUE JOB AND FILE
- AH = E3h subfn 72h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D6h) (see AH=E3h/SF=64h)
- Desc: inform the Queue Management System (QMS) that the queue server has
- completed a job
- Notes: this function is supported by Advanced NetWare 2.1+
- the caller must be a job server which has previously obtained a job
- for servicing
- SeeAlso: AH=E3h/SF=6Fh,AH=E3h/SF=71h,AH=E3h/SF=73h,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 000Bh (length of following data)
- 02h BYTE 72h (subfunction "Finish Servicing Queue Job and File")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
- 09h DWORD charge (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF73-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - ABORT SERVICING QUEUE JOB AND FILE
- AH = E3h subfn 73h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D6h,D9h) (see AH=E3h/SF=64h)
- Desc: inform the Queue Management System (QMS) that the queue server is
- unable to service a previously-accepted job
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=6Fh,AH=E3h/SF=71h,AH=E3h/SF=72h,AH=E3h/SF=76h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 73h (subfunction "Abort Servicing Queue Job and File")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF74-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - CHANGE TO CLIENT RIGHTS
- AH = E3h subfn 74h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,D0h,D1h,D5h,D9h) (see AH=E3h/SF=64h)
- Desc: temporarily assume the login identity of the client submitting the
- job being serviced
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be a job server which has obtained a job for servicing
- SeeAlso: AH=E3h/SF=75h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 74h (subfunction "Change To Client Rights")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF75-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - RESTORE QUEUE SERVER RIGHTS
- AH = E3h subfn 75h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,D3h,D5h,D9h,DAh,FEh,FFh)
- (see AH=E3h/SF=64h)
- Desc: restore server's own identity after assuming the login identity of the
- client submitting the job being serviced
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be a job server which has previously changed its identity
- SeeAlso: AH=E3h/SF=74h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE 75h (subfunction "Change To Client Rights")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF76-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - READ QUEUE SERVER CURRENT STATUS
- AH = E3h subfn 76h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D1h-D3h,F1h,FCh,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the Q_USERS or Q_OPERATORS properties
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ch,AH=E3h/SF=6Fh,AH=E3h/SF=77h,AH=E3h/SF=78h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 000Ah (length of following data)
- 02h BYTE 76h (subfunction "Read Queue Server Current Status")
- 03h DWORD object ID of queue (big-endian)
- 07h DWORD object ID of server (big-endian)
- 0Bh BYTE server station
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0040h (size of following results)
- 02h 64 BYTEs server status record (format depends on server)
- first four bytes should contain estimated "price" for an
- average job
- --------N-21E3--SF77-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - SET QUEUE SERVER CURRENT STATUS
- AH = E3h subfn 77h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,96h,9Ch,D0h,D1h,FEh,FFh) (see AH=E3h/SF=64h)
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be a job server which has attached itself to the queue
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ch,AH=E3h/SF=6Fh,AH=E3h/SF=76h,AH=E3h/SF=78h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0045h (length of following data)
- 02h BYTE 77h (subfunction "Set Queue Server Current Status")
- 03h DWORD object ID of queue (big-endian)
- 02h 64 BYTEs server status record (format depends on server)
- first four bytes should contain estimated "price" for an
- average job
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SF78-------------------------
- INT 21 - Novell NetWare - QUEUE SERVICES - GET QUEUE JOB'S FILE SIZE
- AH = E3h subfn 78h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (see also AH=E3h/SF=64h)
- 00h successful
- Notes: this function is supported by Advanced NetWare 2.1+
- caller must be on a workstation which is security-equivalent to a
- member of the queue's Q_USERS, Q_OPERATORS, or Q_SERVERS properties
- SeeAlso: AH=E3h/SF=68h,AH=E3h/SF=6Ch,AH=E3h/SF=71h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE 78h (subfunction "Get Queue Job's File Size")
- 03h DWORD object ID of queue (big-endian)
- 07h WORD job number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 000Ah (size of following results)
- 02h DWORD object ID of queue (big-endian)
- 06h WORD job number (big-endian)
- 08h DWORD size of job file in bytes (big-endian)
- --------N-21E3--SF96-------------------------
- INT 21 - Novell NetWare - ACCOUNTING SERVICES - GET ACCOUNT STATUS
- AH = E3h subfn 96h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,C0h,C1h) (see below)
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=97h,AH=E3h/SF=98h,AH=E3h/SF=99h
-
- Values for status:
- 00h successful
- C0h no account privileges
- C1h no account balance
- C2h credit limit exceeded
- C3h too many holds on account
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 33h)
- 02h BYTE 96h (subfunction "Get Account Status")
- 03h WORD type of bindery object (big-endian)
- 05h BYTE length of object name (01h to 2Fh)
- 06h N BYTEs object name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following buffer space
- 02h DWORD account balance (big-endian)
- 06h DWORD credit limit (big-endian)
- signed number indicating lowest allowable account balance
- 0Ah 120 BYTEs reserved
- 82h DWORD object ID, server 1 (big-endian)
- 86h DWORD hold amount, server 1 (big-endian)
- ...
- F8h DWORD object ID, server 16 (big-endian)
- FCh DWORD hold amount, server 16 (big-endian)
- Note: the reply buffer lists the servers which have placed holds on a portion
- of the account balance, and the amount reserved by each
- --------N-21E3--SF97-------------------------
- INT 21 - Novell NetWare - ACCOUNTING SERVICES - SUBMIT ACCOUNT CHARGE
- AH = E3h subfn 97h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,C0h-C2h) (see AH=E3h/SF=96h)
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=96h,AH=E3h/SF=98h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 13Fh)
- 02h BYTE 97h (subfunction "Submit Account Charge")
- 03h WORD service type (big-endian)
- 05h DWORD amount to be charged to account (big-endian)
- 09h DWORD amount of prior hold to be cancelled (big-endian)
- 0Dh WORD type of bindery object (big-endian)
- 0Fh WORD type of comment (big-endian)
- 8000h-FFFFh reserved for experimental use
- 11h BYTE length of object's name
- 12h N BYTEs object name
- BYTE length of comment
- N BYTEs comment
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD 0000h (no data returned)
- --------N-21E3--SF98-------------------------
- INT 21 - Novell NetWare - ACCOUNTING SERVICES - SUBMIT ACCOUNT HOLD
- AH = E3h subfn 98h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status (00h,C0h-C3h) (see AH=E3h/SF=96h)
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=96h,AH=E3h/SF=97h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 37h)
- 02h BYTE 98h (subfunction "Submit Account Hold")
- 03h DWORD amount of account balance to reserve (big-endian)
- 07h WORD type of bindery object
- 09h BYTE length of object's name
- 0Ah N BYTEs object name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD 0000h (no data returned)
- --------N-21E3--SF99-------------------------
- INT 21 - Novell NetWare - ACCOUNTING SERVICES - SUBMIT ACCOUNT NOTE
- AH = E3h subfn 99h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C0h no account privileges
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=96h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 137h)
- 02h BYTE 99h (subfunction "Submit Account Note")
- 03h WORD type of service (big-endian)
- 05h WORD type of bindery object (big-endian)
- 07h WORD type of comment (big-endian)
- 8000h-FFFFh reserved for experimental use
- 09h BYTE length of object's name
- 0Ah N BYTEs object name
- BYTE length of comment
- N BYTEs comment
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD 0000h (no data returned)
- --------N-21E3--SFC8-------------------------
- INT 21 - Novell NetWare - FILE SERVER - CHECK CONSOLE PRIVILEGES
- AH = E3h subfn C8h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Desc: determine whether the caller is a console operator
- Notes: this function is supported by Advanced NetWare 2.1+
- NetWare determines console privileges by checking the file server's
- OPERATOR property for the caller's object ID
- SeeAlso: AH=E3h/SF=C9h,AH=E3h/SF=D1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE C8h (subfunction "Check Console Privileges")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFC9-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER DESCRIPTION STRINGS
- AH = E3h subfn C9h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must be attached to the file server
- SeeAlso: AH=E3h/SF=11h,AH=E3h/SF=CDh,AH=E3h/SF=E8h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE C9h (subfunction "Get File Server Description Strings")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0200h (size of following results buffer)
- 02h var ASCIZ name of company distributing this copy of NetWare
- var ASCIZ version and revision
- 9 BYTEs ASCIZ revision date (mm/dd/yy)
- var ASCIZ copyright notice
- --------N-21E3--SFCA-------------------------
- INT 21 - Novell NetWare - FILE SERVER - SET FILE SERVER DATE AND TIME
- AH = E3h subfn CAh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=2Bh,AH=2Dh,AH=E3h/SF=C8h,AH=E7h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0007h (length of following data)
- 02h BYTE CAh (subfunction "Set File Server Date And Time")
- 03h BYTE year (00-79 = 2000-2079, 80-99 = 1980-1999)
- 04h BYTE month (1-12)
- 05h BYTE day (1-31)
- 06h BYTE hour (0-23)
- 07h BYTE minute
- 08h BYTR second
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFCB-------------------------
- INT 21 - Novell NetWare - FILE SERVER - DISABLE FILE SERVER LOGIN
- AH = E3h subfn CBh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CCh,AH=E3h/SF=D3h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE CBh (subfunction "Disable File Server Login")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFCC-------------------------
- INT 21 - Novell NetWare - FILE SERVER - ENABLE FILE SERVER LOGIN
- AH = E3h subfn CCh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CBh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE CCh (subfunction "Enable File Server Login")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFCD-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER LOGIN STATUS
- AH = E3h subfn CDh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CBh,AH=E3h/SF=CCh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE CDh (subfunction "Get File Server Login Status")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0001h (size of following results buffer)
- 02h BYTE login state (00h disabled, 01h enabled)
- --------N-21E3--SFCE-------------------------
- INT 21 - Novell NetWare - FILE SERVICES - PURGE ALL ERASED FILES
- AH = E3h subfn CEh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Desc: all files marked for deletion on the file server are purged, regardless
- of which workstation actually erased them
- Notes: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- the calling workstation must have console operator privileges
- SeeAlso: AH=13h,AH=E2h/SF=10h,AH=E3h/SF=C8h,AX=F244h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE CEh (subfunction "Purge All Erased Files")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFCF-------------------------
- INT 21 - Novell NetWare - FILE SERVER - DISABLE TRANSACTION TRACKING
- AH = E3h subfn CFh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=D0h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE CFh (subfunction "Disable Transaction Tracking")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFD0-------------------------
- INT 21 - Novell NetWare - FILE SERVER - ENABLE TRANSACTION TRACKING
- AH = E3h subfn D0h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Desc: restart transaction tracking after being stopped either explicitly by
- AH=E3h/SF=CFh or automatically due to a full transaction volume
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CFh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE D0h (subfunction "Enable Transaction Tracking")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFD1-------------------------
- INT 21 - Novell NetWare - FILE SERVER - SEND CONSOLE BROADCAST
- AH = E3h subfn D1h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- the broadcast message will not be received by workstations which have
- disabled broadcasts with AH=E1h/SF=02h
- SeeAlso: AH=E1h/SF=02h,AH=E1h/SF=09h,AH=E3h/SF=C8h,AH=E3h/SF=D3h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max A2h)
- 02h BYTE D1h (subfunction "Send Console Broadcast")
- 03h BYTE number of connections to receive message
- 00h = all, else specific list below
- 04h N BYTEs connection list
- BYTE length of message (max 3Ch)
- N BYTEs message
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFD2-------------------------
- INT 21 - Novell NetWare - FILE SERVER - CLEAR CONNECTION NUMBER
- AH = E3h subfn D2h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Desc: close the open files and release all file locks for a connection,
- abort transactions if a TTS file server, and detach from the file
- server
- Notes: this function is supported by Advanced NetWare 2.1+
- the caller must have SUPERVISOR privileges
- SeeAlso: AH=E3h/SF=C9h,AH=E3h/SF=D1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE D2h (subfunction "Clear Connection Number")
- 03h BYTE connection number
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFD3-------------------------
- INT 21 - Novell NetWare - FILE SERVER - DOWN FILE SERVER
- AH = E3h subfn D3h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- FFh files open
- Desc: take down the file server
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have SUPERVISOR privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CBh,AH=E3h/SF=CFh,AH=E3h/SF=D1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE D3h (subfunction "Down File Server")
- 03h BYTE flag: force down even if files open if nonzero
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0000h (no results returned)
- --------N-21E3--SFD4-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SYSTEM STATISTICS
- AH = E3h subfn D4h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=0Eh,AH=E3h/SF=C8h,AH=E3h/SF=D9h,AH=E3h/SF=E7h,AH=E3h/SF=E8h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE D4h (subfunction "Get File System Statistics")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0028h (size of following results buffer)
- 02h DWORD clock ticks since system started
- 06h WORD maximum open files set by configuration
- 08h WORD maximum files open concurrently
- 0Ah WORD current number of open files
- 0Ch DWORD total files opened
- 10h DWORD total file read requests
- 14h DWORD total file write requests
- 18h WORD current changed FATs
- 1Ah WORD total changed FATs
- 1Ch WORD number of FAT write errors
- 1Eh WORD number of fatal FAT write errors
- 20h WORD number of FAT scan errors
- 22h WORD maximum concurrently-indexed files
- 24h WORD current number of indexed files
- 26h WORD number of attached indexed files
- 28h WORD number of indexed files available
- Note: all fields except the first are big-endian
- --------N-21E3--SFD5-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET TRANSACTION TRACKING STATISTICS
- AH = E3h subfn D5h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=CFh,AH=E3h/SF=D0h,AH=E3h/SF=E8h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE D5h (subfunction "TTS Get Statistics")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) length of following results buffer (max 1BCh)
- 02h DWORD clock ticks since system started (big-endian)
- 06h BYTE transaction tracking supported if nonzero
- (all following fields are invalid if zero)
- 07h BYTE transaction tracking enabled
- 08h WORD transaction volume number (big-endian)
- 0Ah WORD maximum simultaneous transactions configured (big-endian)
- 0Ch WORD maximum simultaneous transactions since startup (big-endian)
- 0Eh WORD current transactions in progress (big-endian)
- 10h DWORD total transactions performed (big-endian)
- 14h DWORD total write transactions (big-endian)
- 18h DWORD total transactions backed out (big-endian)
- 1Ch WORD number of unfilled backout requests (big-endian)
- 1Eh WORD disk blocks used for transaction tracking (big-endian)
- 20h DWORD blocks allocated for tracked-file FATs (big-endian)
- 24h DWORD number of file size changes during a transaction (big-endian)
- 28h DWORD number of file truncations during a transaction (big-endian)
- 2Ch BYTE number of records following
- 2Dh Active Transaction Records [array]
- Offset Size Description
- 00h BYTE logical connection number
- 01h BYTE task number
- --------N-21E3--SFD6-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET DISK CACHE STATISTICS
- AH = E3h subfn D6h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=D5h,AH=E3h/SF=D8h,AH=E3h/SF=D9h,AH=E3h/SF=E6h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE D6h (subfunction "Get Disk Cache Statistics")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 004Eh (length of following results buffer)
- 02h DWORD clock ticks since system started (big-endian)
- 06h WORD number of cache buffers (big-endian)
- 08h WORD size of cache buffer in bytes (big-endian)
- 0Ah WORD number of dirty cache buffers (big-endian)
- 0Ch DWORD number of cache read requests (big-endian)
- 10h DWORD number of cache write requests (big-endian)
- 14h DWORD number of cache hits (big-endian)
- 18h DWORD number of cache misses (big-endian)
- 1Ch DWORD number of physical read requests (big-endian)
- 20h DWORD number of physical write requests (big-endian)
- 24h WORD number of physical read errors (big-endian)
- 26h WORD number of physical write errors (big-endian)
- 28h DWORD cache get requests (big-endian)
- 2Ch DWORD cache full write requests (big-endian)
- 30h DWORD cache partial write requests (big-endian)
- 34h DWORD background dirty writes (big-endian)
- 38h DWORD background aged writes (big-endian)
- 3Ch DWORD total cache writes (big-endian)
- 40h DWORD number of cache allocations (big-endian)
- 44h WORD thrashing count (big-endian)
- 46h WORD number of times LRU block was dirty (big-endian)
- 48h WORD number of reads on cache blocks not yet filled by writes
- (big-endian)
- 4Ah WORD number of times a fragmented write occurred (big-endian)
- 4Ch WORD number of cache hits on unavailable block (big-endian)
- 4Eh WORD number of times a cache block was scrapped (big-endian)
- --------N-21E3--SFD7-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET DRIVE MAPPING TABLE
- AH = E3h subfn D7h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=D6h,AH=E3h/SF=D9h,AH=E3h/SF=E6h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE D7h (subfunction "Get Drive Mapping Table")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 00ECh (length of following results buffer)
- 02h DWORD clock tick elapsed since system started (big-endian)
- 06h BYTE fault tolerance (SFT) level
- 07h BYTE number of logical drives attached to server
- 08h BYTE number of physical drives attached to server
- 09h 5 BYTEs disk channel types (00h none, 01h XT, 02h AT, 03h SCSI,
- 04h disk coprocessor drive, 32h-FFh value-added drive types)
- 0Eh WORD number of outstanding controller commands (big-endian)
- 10h 32 BYTEs drive mapping table (FFh = no such drive)
- 30h 32 BYTEs drive mirror table (secondary physical drive, FFh = none)
- 50h 32 BYTEs dead mirror table (last drive mapped to, FFh if never mirrored)
- 70h BYTE physical drive being remirrored (FFh = none)
- 71h BYTE reserved
- 72h DWORD remirrored block (big-endian)
- 76h 60 BYTEs SFT error table (internal error counters)
- --------N-21E3--SFD8-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET PHYSICAL DISK STATISTICS
- AH = E3h subfn D8h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=D9h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE D8h (subfunction "Get Physical Disk Statistics")
- 03h BYTE physical disk number
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 005Dh (size of following results record)
- 02h DWORD clock ticks since system started (big-endian)
- 06h BYTE physical disk channel
- 07h BYTE flag: drive removable if nonzero
- 08h BYTE physical drive type
- 09h BYTE drive number within controller
- 0Ah BYTE controller number
- 0Bh BYTE controller type
- 0Ch DWORD size of drive in 4K disk blocks (big-endian)
- 10h WORD number of cylinders on drive (big-endian)
- 12h BYTE number of heads
- 13h BYTE number of sectors per track
- 14h 64 BYTEs ASCIZ drive make and model
- 54h WORD number of I/O errors (big-endian)
- 56h DWORD start of Hot Fix table (big-endian)
- 5Ah WORD size of Hot Fix table (big-endian)
- 5Ch WORD number of Hot Fix blocks available (big-endian)
- 5Eh BYTE flag: Hot Fix disabled if nonzero
- --------N-21E3--SFD9-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET DISK CHANNEL STATISTICS
- AH = E3h subfn D9h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=D8h,AH=E3h/SF=E6h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE D9h (subfunction "Get Disk Channel Statistics")
- 03h BYTE channel number
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 00A8h (size of following results record)
- 02h DWORD clock ticks since system started (big-endian)
- 06h WORD channel run state (big-endian) (see below)
- 08h WORD channel synchronization state (big-endian) (see below)
- 0Ah BYTE driver type
- 0Bh BYTE major version of driver
- 0Ch BYTE minor version of driver
- 0Dh 65 BYTEs ASCIZ driver description
- 4Eh WORD first I/O address used (big-endian)
- 50h WORD length of first I/O address (big-endian)
- 52h WORD second I/O address used (big-endian)
- 54h WORD length of second I/O address (big-endian)
- 56h 3 BYTEs first shared memory address
- 59h 2 BYTEs length of first shared memory address
- 5Bh 3 BYTEs second shared memory address
- 5Eh 2 BYTEs length of second shared memory address
- 60h BYTE first interrupt number in-use flag
- 61h BYTE first interrupt number used
- 62h BYTE second interrupt number in-use flag
- 63h BYTE second interrupt number used
- 64h BYTE first DMA channel in-use flag
- 65h BYTE first DMA channel used
- 66h BYTE second DMA channel in-use flag
- 67h BYTE second DMA channel used
- 68h BYTE flags
- 69h BYTE reserved
- 6Ah 80 BYTEs ASCIZ configuration description
-
- Values for channel run state:
- 0000h running
- 0001h being stopped
- 0002h stopped
- 0003h nonfunctional
-
- Values for channel synchronization state:
- 0000h not in use
- 0002h used by NetWare, no other requests
- 0004h used by NetWare, other requests
- 0006h in use, not needed by NetWare
- 0008h in use, needed by NetWare
- 000Ah channel released, NetWare should use it
- --------N-21E3--SFDA-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET CONNECTION'S TASK INFORMATION
- AH = E3h subfn DAh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DBh,AH=E3h/SF=DFh,AH=E3h/SF=E1h,AH=E3h/SF=E5h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0003h (length of following data)
- 02h BYTE DAh (subfunction "Get Connection's Task Information")
- 03h WORD logical connection number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h BYTE lock status of connection (see below)
- 03h var Lock Status Information (see below)
- N BYTE number of records following
- N+1 Active Task Information Records [array]
- Offset Size Description
- 00h BYTE task number (01h-FFh)
- 01h BYTE task state
- 01h in TTS explicit transaction
- 02h in TTS implicit transaction
- 04h shared fileset lock active
-
- Values for lock status of connection:
- 00h no locks
- 01h waiting on physical record lock
- 02h waiting on file lock
- 03h waiting on logical record lock
- 04h waiting on semaphore
-
- Format of Lock Status Information:
- Offset Size Description
- ---lock status 00h---
- no fields
- ---lock status 01h---
- 00h BYTE number of waiting task
- 01h DWORD start address
- 05h DWORD end address
- 09h BYTE volume number
- 0Ah WORD directory entry number
- 0Ch 14 BYTEs ASCIZ filename
- ---lock status 02h---
- 00h BYTE number of waiting task
- 01h BYTE volume number
- 02h WORD directory entry number
- 04h 14 BYTEs ASCIZ filename
- ---lock status 03h---
- 00h BYTE number of waiting task
- 01h BYTE length of record name
- 02h N BYTEs ASCIZ record name
- ---lock status 04h---
- 00h BYTE number of waiting task
- 01h BYTE length of semaphore's name
- 02h N BYTEs ASCIZ semaphore name
- --------N-21E3--SFDB-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET CONNECTION'S OPEN FILES
- AH = E3h subfn DBh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E2h/SF=1Ah,AH=E3h/SF=C8h,AH=E3h/SF=DAh,AH=E3h/SF=DCh,AH=E3h/SF=DFh
- SeeAlso: AH=E3h/SF=E1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE DBh (subfunction "Get Connection's Open Files")
- 03h WORD logical connection number (big-endian)
- 05h WORD last record seen (big-endian)
- 0000h on first call
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD next request record (place in "last record" field on next call)
- 0000h if no more records
- 04h BYTE number of records following
- 05h var array of File Information Records (see below)
-
- Format of File Information Record:
- Offset Size Description
- 00h BYTE task number
- 01h BYTE lock flags (see below)
- 02h BYTE access flags (see below)
- 03h BYTE lock type
- 00h no lock
- FEh file lock
- FFh locked by Begin Share File Set
- 04h BYTE volume number (00h-1Fh)
- 05h WORD directory entry (big-endian)
- 07h 14 BYTEs ASCIZ filename
-
- Bitfields for lock flags:
- bit 0 file is locked
- bit 1 file opened Shareable
- bit 2 logged
- bit 3 file opened Normal
- bit 6 TTS holding lock
- bit 7 Transaction Flag set on file
-
- Bitfields for access flags:
- bit 0 file open for reading by calling station
- bit 1 file open for writing by calling station
- bit 2 deny reads by other stations
- bit 3 deny writes by other stations
- bit 4 file detached
- bit 5 TTS Holding Detach
- bit 6 TTS Holding Open
- --------N-21E3--SFDC-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET CONNECTIONS USING A FILE
- AH = E3h subfn DCh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DAh,AH=E3h/SF=DBh,AH=E3h/SF=DFh,AH=E3h/SF=E1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 104h)
- 02h BYTE DCh (subfunction "Get Connections Using a File")
- 03h WORD last record (big-endian)
- 0000h on first call
- 05h BYTE directory handle
- 06h BYTE length of file path
- 07h N BYTEs ASCIZ file path
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD count of tasks which have opened or logged file (big-endian)
- 04h WORD count of tasks which have opened file (big-endian)
- 06h WORD count of opens for reading (big-endian)
- 08h WORD count of opens for writing (big-endian)
- 0Ah WORD deny read count (big-endian)
- 0Ch WORD deny write count (big-endian)
- 0Eh WORD next request record (place in "last record" field on next call)
- 0000h if no more records
- 10h BYTE locked flag
- 00h not locked exclusively
- else locked exclusively
- 11h BYTE number of records following
- 12h var array of File Usage Information Records (see below)
-
- Format of File Usage Information Record:
- Offset Size Description
- 00h WORD logical connection number (big-endian)
- 02h BYTE task number
- 03h BYTE lock flags (see AH=E3h/SF=DBh)
- 04h BYTE access flags (see AH=E3h/SF=DBh)
- 05h BYTE lock type
- 00h no lock
- FEh file lock
- FFh locked by Begin Share File Set
- --------N-21E3--SFDD-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET PHYSICAL RECORD LOCKS BY CONN&FILE
- AH = E3h subfn DDh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- FFh file not open
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DEh,AH=E3h/SF=DFh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0016h (length of following data)
- 02h BYTE DDh (subfunction "Get Physical Record Locks by Connection and
- File")
- 03h WORD logical connection number (big-endian)
- 05h WORD last record seen (big-endian)
- 0000h on first call
- 07h BYTE volume number (00h-1Fh)
- 08h WORD directory handle (big-endian)
- 0Ah 14 BYTEs ASCIZ filename
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD next request record (place in "last record" on next call)
- 0000h if no more records
- 04h BYTE number of physical record locks
- 05h BYTE number of records following
- 06h var array of Physical Record Lock Info records (see below)
-
- Format of Physical Record Lock Info:
- Offset Size Description
- 00h BYTE task number
- 01h BYTE lock status (see below)
- 02h DWORD starting offset of record in file (big-endian)
- 06h DWORD ending offset of record in file (big-endian)
-
- Bitfields for lock status:
- bit 0 exclusive lock
- bit 1 shareable lock
- bit 2 logged
- bit 6 lock held by TTS
- --------N-21E3--SFDE-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET PHYSICAL RECORD LOCKS BY FILE
- AH = E3h subfn DEh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- FFh file not open
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DDh,AH=E3h/SF=DFh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 104h)
- 02h BYTE DEh (subfunction "Get Physical Record Locks by File")
- 03h WORD last record seen (big-endian)
- 0000h on first call
- 05h BYTE directory handle
- 06h BYTE length of filename
- 07h N BYTEs ASCIZ filename
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD next request record (place in "last record" on next call)
- 0000h if no more records
- 04h BYTE number of physical record locks
- 05h BYTE number of records following
- 06h var array of Physical Record Lock Info records (see below)
-
- Format of Physical Record Lock Info:
- Offset Size Description
- 00h WORD number of tasks logging record (big-endian)
- 02h WORD number of tasks with shareable lock (big-endian)
- 04h DWORD starting offset of record in file (big-endian)
- 08h DWORD ending offset of record in file (big-endian)
- 0Ch WORD logical connection number (big-endian)
- 0Eh BYTE task number
- 0Fh BYTE lock type
- 00h none
- FEh file lock
- FFh Begin Share File Set lock
- --------N-21E3--SFDF-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET LOGICAL RECORDS BY CONNECTION
- AH = E3h subfn DFh
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DDh,AH=E3h/SF=E0h,AH=E3h/SF=E2h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE DFh (subfunction "Get Logical Records By Connection")
- 03h WORD logical connection number (big-endian)
- 05h WORD last record seen (big-endian)
- 0000h on first call
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD next request record (place in "last record" field on next call)
- 0000h if no more locked records
- 09h BYTE number of records following
- 0Ah var array of Logical Lock Information Records (see below)
-
- Format of Logical Lock Information Record:
- Offset Size Description
- 00h BYTE task number
- 01h BYTE lock status (see AH=E3h/SF=DDh)
- 02h BYTE length of logical lock's name
- 03h N BYTEs logical lock's name
- --------N-21E3--SFE0-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET LOGICAL RECORD INFORMATION
- AH = E3h subfn E0h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DDh,AH=E3h/SF=DFh,AH=E3h/SF=E2h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 67h)
- 02h BYTE E0h (subfunction "Get Logical Record Information")
- 03h WORD last record seen (big-endian)
- 0000h on first call
- 05h BYTE length of logical record's name
- 06h N BYTEs logical record's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 200h)
- 02h WORD number of logical connections logging the record (big-endian)
- 04h WORD number of logical connections with shareable lock (big-endian)
- 06h WORD next request record (place in "last record" field on next call)
- 08h BYTE locked exclusively if nonzero
- 09h BYTE number of records following
- 0Ah var array of Task Information Records (see below)
-
- Format of Task Information Record:
- Offset Size Description
- 00h WORD logical connection number (big-endian)
- 02h BYTE task number
- 03h BYTE lock status (see AH=E3h/SF=DDh)
- --------N-21E3--SFE1-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET CONNECTION'S SEMAPHORES
- AH = E3h subfn E1h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DBh,AH=E3h/SF=DFh,AH=E3h/SF=E2h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE E1h (subfunction "Get Connection's Semaphores")
- 03h WORD logical connection number (big-endian)
- 05h WORD last record seen (big-endian)
- 0000h on first call
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results record (max 1FEh)
- 02h WORD next request record (place in "last record" field on next call)
- 04h BYTE number of records following
- 05h var array of Semaphore Information Records
-
- Format of Semaphore Information Record:
- Offset Size Description
- 00h WORD open count (big-endian)
- 02h BYTE semaphore value (-128 to 127)
- 03h BYTE task number
- 04h BYTE lock type
- 05h BYTE length of semaphore's name
- 06h N BYTEs semaphore's name
- 14 BYTEs filename
- --------N-21E3--SFE2-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET SEMAPHORE INFORMATION
- AH = E3h subfn E2h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=E1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD length of following data (max 83h)
- 02h BYTE E2h (subfunction "Get LAN Driver's Configuration Information")
- 03h WORD last record seen (big-endian)
- 0000h on first call
- 05h BYTE length of semaphore's name (01h-7Fh)
- 06h N BYTEs semaphore's name
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 1FEh)
- 02h WORD next request record (place in "last record" on next call)
- 0000h if no more
- 04h WORD number of logical connections opening semaphore (big-endian)
- 06h BYTE semaphore value (-127 to 128)
- 07h BYTE number of records following
- 08h var array of Semaphore Information records (see below)
-
- Format of Semaphore Information:
- Offset Size Description
- 00h WORD logical connection number (big-endian)
- 02h BYTE task number
- --------N-21E3--SFE3-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET LAN DRIVER'S CONFIGURATION INFO
- AH = E3h subfn E3h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- the calling workstation must have console operator privileges
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=E7h,AH=E3h/SF=E8h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE E3h (subfunction "Get LAN Driver's Configuration Information")
- 03h BYTE LAN board (00h-03h)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 00ACh (size of following results buffer)
- 02h 4 BYTEs network number
- 06h 6 BYTEs node number
- 0Ch BYTE LAN driver installed (00h no--remaining fields invalid)
- 0Dh BYTE option number selected at configuration time
- 0Eh 160 BYTEs configuration text
- ASCIZ hardware type
- ASCIZ hardware settings
- --------N-21E3--SFE5-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET CONNECTION'S USAGE STATISTICS
- AH = E3h subfn E5h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- one must have console operator privileges to get statistics for logical
- connections other than one's own
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=DAh,AH=E3h/SF=DBh,AH=E3h/SF=E1h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0003h (length of following data)
- 02h BYTE E5h (subfunction "Get Connection's Usage Statistics")
- 03h WORD logical connection number (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0014h (size of following results record)
- 02h DWORD clock ticks since server started (big-endian)
- 06h 6 BYTEs bytes read
- 0Ch 6 BYTEs bytes written
- 12h DWORD total request packets (big-endian)
- --------N-21E3--SFE6-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET BINDERY OBJECT DISK SPACE LEFT
- AH = E3h subfn E6h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Notes: this function is supported by Advanced NetWare 2.1+
- one must have console operator privileges to get the free space for
- other bindery objects
- SeeAlso: AH=E3h/SF=C8h,AH=E3h/SF=E8h,AH=E3h/SF=E9h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0005h (length of following data)
- 02h BYTE E6h (subfunction "Get Bindery Object Disk Space Left")
- 03h DWORD object ID (big-endian)
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 000Fh (size of following results buffer)
- 02h DWORD clock ticks elapsed since server started (big-endian)
- 06h DWORD object ID (big-endian)
- 0Ah DWORD 4K disk blocks available to user (big-endian)
- 0Eh BYTE restrictions (00h enforced, FFh not enforced)
- --------N-21E3--SFE7-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER LAN I/O STATISTICS
- AH = E3h subfn E7h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=0Eh,AH=E3h/SF=11h,AH=E3h/SF=D3h,AH=E3h/SF=E8h,AH=E7h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE E7h (subfunction "Get File Server LAN I/O Statistics")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0042h (size of following results buffer)
- 02h DWORD clock ticks since system started
- 06h WORD total routing buffers
- 08h WORD maximum routing buffers used
- 0Ah WORD current routing buffers used
- 0Ch DWORD total file service packets
- 10h WORD number of file service packets buffered
- 12h WORD number of invalid connection packets
- 14h WORD packets with bad logical connection numbers
- 16h WORD number of packets received during processing
- 18h WORD number of requests reprocessed
- 1Ah WORD packets with bad sequence numbers
- 1Ch WORD number of duplicate replies sent
- 1Eh WORD number of acknowledgements sent
- 20h WORD number of packets with bad request types
- 22h WORD requests to attach to ws for which a request is being processed
- 24h WORD requests to attach from ws which is already attaching
- 26h WORD number of forged detach requests
- 28h WORD detach requests with bad connection number
- 2Ah WORD requests to detach from ws for which requests pending
- 2Ch WORD number of cancelled replies
- 2Eh WORD packets discarded due to excessive hop count
- 30h WORD packets discarded due to unknown net
- 32h WORD incoming packets discarded for lack of DGroup buffer
- 34h WORD outgoing packets discarded due to lack of buffer
- 36h WORD received packets destined for B,C, or D side drivers
- 38h DWORD number of NetBIOS packets propagated through net
- 3Ch DWORD total number of non-file-service packets
- 40h DWORD total number of routed packets
- Note: all fields except the first are big-endian
- --------N-21E3--SFE8-------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER MISC INFORMATION
- AH = E3h subfn E8h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- C6h no console rights
- Note: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=E3h/SF=0Eh,AH=E3h/SF=11h,AH=E3h/SF=CDh,AH=E3h/SF=E7h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0001h (length of following data)
- 02h BYTE E8h (subfunction "Get File Server Misc Information")
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) size of following results buffer (max 0048h)
- 02h DWORD clock ticks since system started
- 06h BYTE CPU type
- 00h Motorola 68000
- 01h Intel 8086, 8088, or V20
- 02h Intel 80286+
- 07h BYTE reserved
- 08h BYTE number of service processes in server
- 09h BYTE server utilization in percent
- 0Ah WORD maximum bindery objects set by configuration (big-endian)
- 0000h = unlimited
- 0Ch WORD maximum number of bindery objects used (big-endian)
- 0Eh WORD current number of bindery objects in use (big-endian)
- 10h WORD total server memory in K (big-endian)
- 12h WORD wasted server memory in K (big-endian)
- normally 0000h
- 14h WORD number of records following (01h-03h)
- 16h var array of Dynamic Memory Information records (see below)
-
- Format of Dynamic Memory Information:
- Offset Size Description
- 00h DWORD total dynamic space (big-endian)
- 04h DWORD maximum dynamic space used (big-endian)
- 08h DWORD current dynamic space usage (big-endian)
- --------N-21E3--SFE9-------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET VOLUME INFORMATION
- AH = E3h subfn E9h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (see below)
- Return: AL = status
- 00h successful
- Notes: this function is supported by Advanced NetWare 2.1+
- SeeAlso: AH=DAh,AH=E2h/SF=15h
-
- Format of request buffer:
- Offset Size Description
- 00h WORD 0002h (length of following data)
- 02h BYTE E9h (subfunction "Get Volume Information")
- 03h BYTE directory handle
-
- Format of reply buffer:
- Offset Size Description
- 00h WORD (call) 0028h (length of following results buffer)
- 02h DWORD elapsed system time (big-endian)
- 06h BYTE volume number
- 07h BYTE logical drive number
- 08h WORD sectors per block (big-endian)
- 0Ah WORD starting block (big-endian)
- 0Ch WORD total blocks on volume (big-endian)
- 0Eh WORD blocks available on volume (big-endian)
- 10h WORD total directory slots (big-endian)
- 12h WORD directory slots available (big-endian)
- 14h WORD maximum directory entries actually used (big-endian)
- 16h BYTE flag: volume hashed if nonzero
- 17h BYTE flag: volume cached if nonzero
- 18h BYTE flag: volume removable if nonzero
- 19h BYTE flag: volume mounted if nonzero
- 1Ah 16 BYTEs NUL-padded volume name
- --------N-21E4-------------------------------
- INT 21 O - Novell NetWare - SET FILE ATTRIBUTES (FCB)
- AH = E4h
- CL = file attributes (see below)
- DX:DX -> FCB (see AH=0Fh)
- Return: AL = error code
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- SeeAlso: AX=4301h
-
- Bitfields for file attributes:
- bit 0 read only
- bit 1 hidden
- bit 2 system
- bit 7 shareable
- --------v-21E4-------------------------------
- INT 21 - VIRUS - "Anarkia" - INSTALLATION CHECK
- AH = E4h
- Return: AH = 04h if resident
- SeeAlso: AH=E1h"VIRUS",AH=E7h"VIRUS"
- --------T-21E400-----------------------------
- INT 21 - DoubleDOS - INSTALLATION CHECK/PROGRAM STATUS
- AX = E400h
- Return: AL = 00h if DoubleDOS not present
- = 01h if running in visible DoubleDOS partition
- = 02h if running in the invisible DoubleDOS partition
- SeeAlso: AH=E5h"DoubleDOS",AX=F400h
- --------E-21E400-----------------------------
- INT 21 - OS/286, OS/386 - CHAIN TO REAL-MODE HANDLER
- AX = E400h
- ???
- Return: ???
- Note: protected mode only???
- --------E-21E402-----------------------------
- INT 21 - OS/286, OS/386 - SET PROTECTED-MODE TASK GATE
- AX = E402h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=E403h
- --------E-21E403-----------------------------
- INT 21 - OS/286, OS/386 - REMOVE PROTECTED-MODE TASK GATE
- AX = E403h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=E402h
- --------N-21E5-------------------------------
- INT 21 O - Novell NetWare - UPDATE FILE SIZE (FCB)
- AH = E5h
- DS:DX -> FCB (see AH=0Fh)
- Return: AL = (unreliable) return code
- Notes: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- on success, NetWare sets AL to zero; on errors it restores AL
- Return: AL = error code
- --------T-21E5-------------------------------
- INT 21 - DoubleDOS - OTHER PROGRAM STATUS
- AH = E5h
- Return: AL = 00h no program in other partition
- = 01h program in other partition is running
- = 02h program in other partition is suspended
- SeeAlso: AX=E400h"DoubleDOS",AH=F5h"DoubleDOS"
- --------E-21E500-----------------------------
- INT 21 - OS/286, OS/386 - HEAP MANAGEMENT STRATEGY
- AX = E500h
- ???
- Return: ???
- SeeAlso: AX=E501h
- --------E-21E501-----------------------------
- INT 21 - OS/286, OS/386 - FORCE HEAP COMPACTION
- AX = E501h
- ???
- Return: ???
- SeeAlso: AX=E500h
- --------N-21E6-------------------------------
- INT 21 O - Novell NetWare - COPY FILE TO FILE (FCB)
- AH = E6h
- CX:DX = number of bytes to copy
- DS:SI -> opened source FCB
- ES:DI -> opened destination FCB
- Return: AL = error code
- CX = ???
- DX = ???
- Note: this function was added in NetWare 4.0, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- --------E-21E6-------------------------------
- INT 21 P - OS/286, OS/386 - ISSUE REAL PROCEDURE SIGNAL FROM PROTECTED MODE
- AH = E6h
- ???
- Return: ???
- SeeAlso: AH=E2h"OS/286"
- --------N-21E7-------------------------------
- INT 21 - Novell NetWare - FILE SERVER - GET FILE SERVER DATE AND TIME
- AH = E7h
- DS:DX -> date/time buffer (see below)
- Return: AL = error code
- 00h successful
- FFh unsuccessful
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+,
- Alloy NTNX, and Banyan VINES
- SeeAlso: AH=2Ah,AH=2Ch,AX=5FC0h,AH=E3h/SF=CAh
-
- Format of date/time buffer:
- Offset Size Description
- 00h BYTE year (80-99 = 1980-1999, 0-79 = 2000-2079)
- 01h BYTE month (1=Jan)
- 02h BYTE day
- 03h BYTE hours
- 04h BYTE minutes
- 05h BYTE seconds
- 06h BYTE day of week (0 = Sunday) (Novell and NTNX only)
- --------E-21E7-------------------------------
- INT 21 - OS/286, OS/386 - CREATE CODE SEGMENT
- AH = E7h
- ???
- Return: ???
- SeeAlso: AH=E8h"OS/286",AH=E9h"OS/286",AH=EAh"OS/286"
- --------v-21E7-------------------------------
- INT 21 - VIRUS - "Spyer"/"Kiev" - INSTALLATION CHECK
- AH = E7h
- Return: AH = 78h if resident
- SeeAlso: AH=E4h"VIRUS",AX=EC59h
- --------N-21E8-------------------------------
- INT 21 O - Novell NetWare, Alloy NTNX - SET FCB RE-OPEN MODE
- AH = E8h
- DL = mode
- 00h no automatic re-open
- 01h auto re-open
- Return: AL = error code
- Desc: provided backward compatibility with a bug in CP/M and early DOS vers
- Note: this function was added in NetWare 4.6, but was removed some time prior
- to Advanced NetWare 2.15, and is no longer listed in current Novell
- documentation
- --------E-21E8-------------------------------
- INT 21 - OS/286, OS/386 - SEGMENT CREATION
- AH = E8h
- AL = type
- 00h data segment
- 01h data window/alias
- 02h real segment
- 03h real window/alias
- 06h shareable segment
- ???
- Return: ???
- SeeAlso: AH=E7h"OS/286",AH=E9h"OS/286"
- --------T-21E8-------------------------------
- INT 21 - DoubleDOS - SET/RESET KEYBOARD CONTROL FLAGS
- AH = E8h
- AL = 00h set flags for this program
- = 01h set flags for other program
- DX = keyboard control flags (see below)
- Return: DX = previous flags
- Notes: disabling Ctrl-PrtSc will allow the program to intercept the keystroke;
- disabling any of the other keystrokes disables them completely
- identical to AH=F8h
- SeeAlso: AH=E1h"DoubleDOS",AH=E2h"DoubleDOS",AH=E3h"DoubleDOS"
- SeeAlso: AH=F8h"DoubleDOS"
-
- Bitfields for keyboard control flags:
- bit 0 menu
- bit 1 exchange
- bit 2 entire keyboard enable/disable
- bit 3 Ctrl-C
- bit 4 Ctrl-PrtSc
- bit 5 Alt/Erase
- bit 6 Ctrl-Break
- bit 7 Ctrl-NumLock
- bit 8 shift-PrtSc
- bit 9-13 undefined
- bit 14 cancel key (clear keyboard buffer)
- bit 15 suspend key
- Note: setting a bit enables the corresponding key or operatin, clearing a
- bit disables it
- --------E-21E9-------------------------------
- INT 21 P - OS/286, OS/386 - CHANGE SEGMENTS
- AH = E9h
- AL = function
- 01h change code segment parameters
- 02h change data segment parameters
- 05h adjust segment limit
- 06h change segment base address
- ???
- Return: ???
- SeeAlso: AH=E7h"OS/286",AH=E8h"OS/286",AH=EAh"OS/286",AH=EDh"OS/286"
- SeeAlso: INT 31/AX=0007h,INT 31/AX=0008h
- --------T-21E9-------------------------------
- INT 21 - DoubleDOS - SET TIMESHARING PRIORITY
- AH = E9h
- AL = 00h visible program gets 70%, invisible gets 30% (default)
- = 01h visible program gets 50%, invisible gets 50%
- = 02h visible program gets 30%, invisible gets 70%
- = 03h Top program gets 70%, bottom program gets 30%
- = 04h Top program gets 30%, bottom program gets 70%
- = 05h get current priority
- Return: AL = priority setting
- Note: identical to AH=F9h
- SeeAlso: AH=EAh"DoubleDOS",AH=EBh"DoubleDOS",AH=F9h"DoubleDOS"
- --------N-21E900-----------------------------
- INT 21 - Novell NetWare - DIRECTORY SERVICES - GET DIRECTORY HANDLE
- AX = E900h
- DX = drive number to check (0 = A:, ..., 25 = Z:, 26 ... 31)
- Return: AL = directory handle
- AH = flags (drive not mapped if none set)
- bit 0: permanent handle
- bit 1: temporary handle
- bit 7: mapped to local drive
- Note: this function is supported by NetWare 4.0+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E2h/SF=00h,AH=E2h/SF=01h,AH=E2h/SF=0Ah
- --------N-21E905-----------------------------
- INT 21 - Novell NetWare shell 3.01 - MAP A FAKE ROOT DIRECTORY
- AX = E905h
- BL = drive number (0=default, 1=A:, ...)
- DS:DX -> ASCIZ path for fake root (may include server name or be empty)
- Return: CF set on error
- AL = error code (03h,0Fh,11h) (see AH=59h)
- CF clear if successful
- Note: if drive is not currently mapped, a drive mapping will be created
- SeeAlso: AX=E906h
- --------N-21E906-----------------------------
- INT 21 - Novell NetWare shell 3.01 - DELETE FAKE ROOT DIRECTORY
- AX = E906h
- BL = drive number (0=default, 1=A:, ...)
- Note: drive remains mapped
- SeeAlso: AX=E905h
- --------N-21E907-----------------------------
- INT 21 - Novell NetWare shell 3.01 - GET RELATIVE DRIVE DEPTH
- AX = E907h
- BL = drive number (0=default, 1=A:, ...)
- Return: AL = number of directories below the fake root
- FFh if no fake root assigned
- SeeAlso: AX=E905h
- --------N-21E908BL00-------------------------
- INT 21 - Novell NetWare shell 3.01 - SET SHOW DOTS
- AX = E908h
- BL = 00h don't return '.' or '..' during directory scans
- = nonzero directory scans will return '.' or '..' entries
- Return: BL = previous show-dots setting
- --------N-21EA-------------------------------
- INT 21 - Novell NetWare, Alloy NTNX - RETURN SHELL VERSION
- AH = EAh
- AL = return version environment string
- 00h don't return string
- nonzero return string in 40-byte buffer pointed to by ES:DI
- Return: buffer filled with three null-terminated entries:
- major operating system
- version
- hardware type
- Return: AH = operating system (00h = MS-DOS)
- AL = hardware type
- 00h IBM PC
- 01h Victor 9000
- BH = major shell version
- BL = minor shell version
- CH = (v3.01+) shell type
- 00h conventional memory
- 01h expanded memory
- 02h extended memory
- CL = shell revision number
- Note: this function is supported by NetWare 4.6 and Advanced NetWare 1.0+
- --------T-21EA-------------------------------
- INT 21 - DoubleDOS - TURN OFF TASK SWITCHING
- AH = EAh
- Return: task switching turned off
- SeeAlso: AH=E9h"DoubleDOS",AH=EBh"DoubleDOS",AH=FAh"DoubleDOS"
- SeeAlso: INT FA"DoubleDOS"
- --------E-21EA-------------------------------
- INT 21 - OS/286, OS/386 - ALLOCATE HUGE SEGMENT
- AH = EAh
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AH=E7h"OS/286",AH=E8h"OS/286",AH=E9h"OS/286"
- --------N-21EB-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - LOG FILE
- AH = EBh
- DS:DX -> ASCIZ filename
- if function C6h lock mode 01h:
- AL = flags
- 00h log file only
- 01h lock as well as log file
- BP = lock timeout in timer ticks (1/18 second)
- 0000h = don't wait if file already locked
- Return: AL = error code
- 00h successful
- 96h no dynamic memory for file
- FEh timed out
- FFh failed
- Desc: add the location and size of the specified file to the log table and
- optionally lock the file
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=BCh"NetWare",AH=CAh,AH=D0h,AH=ECh"NetWare",AH=EDh"NetWare"
- --------T-21EB-------------------------------
- INT 21 - DoubleDOS - TURN ON TASK SWITCHING
- AH = EBh
- Return: task switching turned on
- SeeAlso: AH=E9h"DoubleDOS",AH=EAh"DoubleDOS",AH=FBh"DoubleDOS"
- SeeAlso: INT FB"DoubleDOS"
- --------E-21EB00-----------------------------
- INT 21 - OS/386 VMM - GET A PAGE TABLE ENTRY BY LINEAR ADDRESS
- AX = EB00h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB02h,AX=EB04h,INT 31/AX=0506h
- --------E-21EB02-----------------------------
- INT 21 - OS/386 VMM - GET A PAGE TABLE ENTRY BY 16-BIT SEGMENT:OFFSET
- AX = EB02h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB00h,AX=EB04h
- --------E-21EB03-----------------------------
- INT 21 - OS/386 VMM - FREE MAPPED PAGES
- AX = EB03h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB05h,INT 31/AX=0801h
- --------E-21EB04-----------------------------
- INT 21 - OS/386 VMM - GET A PAGE TABLE ENTRY BY 32-BIT SEGMENT:OFFSET
- AX = EB04h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB00h,AX=EB02h
- --------E-21EB05-----------------------------
- INT 21 - OS/386 VMM - MAP PAGES
- AX = EB05h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB03h,INT 31/AX=0800h
- --------E-21EB06-----------------------------
- INT 21 - OS/386 VMM - LOCK PAGES IN MEMORY
- AX = EB06h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB07h,INT 31/AX=0600h
- --------E-21EB07-----------------------------
- INT 21 - OS/386 VMM - UNLOCK MEMORY PAGES
- AX = EB07h
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AX=EB06h,INT 31/AX=0601h
- --------N-21EC-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - RELEASE FILE
- AH = ECh
- DS:DX -> ASCIZ filename
- Return: AL = status
- 00h successful
- FFh file not found
- Desc: unlock the specified file but retain it in the log table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=CDh,AH=EBh"NetWare",AH=EDh"NetWare"
- --------T-21EC-------------------------------
- INT 21 - DoubleDOS - GET VIRTUAL SCREEN ADDRESS
- AH = ECh
- Return: ES = segment of virtual screen
- Desc: determine the address of the virtual screen to which the program
- should write instead of the actual video memory, so that the
- multitasked programs do not interfere with each other's output
- Notes: screen address can change if task-switching is on!!
- identical to AH=FCh
- SeeAlso: INT 10/AH=FEh,AH=FCh"DoubleDOS",INT FC"DoubleDOS"
- --------E-21EC-------------------------------
- INT 21 - OS/286, OS/386 - BLOCK TRANSFER
- AH = ECh
- ???
- Return: ???
- --------v-21EC59-----------------------------
- INT 21 - VIRUS - "Terror" - INSTALLATION CHECK
- AX = EC59h
- Return: BP = EC59h if resident
- SeeAlso: AH=E7h"VIRUS",AH=EEh"VIRUS"
- --------N-21ED-------------------------------
- INT 21 - Novell NetWare - SYNCHRONIZATION SERVICES - CLEAR FILE
- AH = EDh
- DS:DX -> ASCIZ filename
- Return: AL = status
- 00h successful
- FFh no files found
- Desc: unlock the file and remove it from the log table
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=CBh"NetWare",AH=CEh,AH=CFh,AH=EBh"NetWare",AH=ECh"NetWare"
- --------E-21ED-------------------------------
- INT 21 - OS/286, OS/386 - GET SEGMENT OR WINDOW DESCRIPTOR
- AH = EDh
- ???
- Return: ???
- Note: protected mode only???
- SeeAlso: AH=E9h"OS/286"
- --------N-21EE-------------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - GET PHYSICAL STATION ADDRESS
- AH = EEh
- Return: CX:BX:AX = six-byte physical address
- Note: this function is supported by NetWare 4.6+, Advanced NetWare 1.0+, and
- Alloy NTNX
- SeeAlso: AH=E3h/SF=13h
- --------T-21EE-------------------------------
- INT 21 - DoubleDOS - GIVE AWAY TIME TO OTHER TASKS
- AH = EEh
- AL = number of 55ms time slices to give away
- Return: returns after giving away time slices
- SeeAlso: AH=FEh"DoubleDOS",INT FE"DoubleDOS"
- --------v-21EE-------------------------------
- INT 21 - VIRUS - "Jerusalem-G", "Pregnant" - INSTALLATION CHECK
- AH = EEh
- Return: AX = 0300h if "Jerusalem-G" resident
- AL = 05h if "Pregnant" resident
- SeeAlso: AH=DDh"VIRUS",AX=EC59h,AH=F0h"VIRUS"
- --------N-21EF00-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET DRIVE HANDLE TABLE
- AX = EF00h
- Return: ES:SI -> network shell's 32-byte drive handle table
- AX = 0000h
- Notes: this function is supported by Advanced NetWare 1.0+
- each byte in the drive handle table contains the directory handle for
- the corresponding drive, or 00h if not mapped to a directory
- SeeAlso: AX=EF01h,AX=EF02h,AX=EF03h,AX=EF04h
- --------N-21EF01-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET DRIVE FLAG TABLE
- AX = EF01h
- Return: ES:SI -> network shell's 32-byte drive flag table (see below)
- AX = 0000h
- Notes: this function is supported by Advanced NetWare 1.0+
- each byte in the drive flag table corresponds to a drive
- SeeAlso: AX=EF00h,AX=EF02h,AX=EF03h
-
- Values in drive flag table:
- 00h drive is not mapped
- 01h permanent network drive
- 02h temporary network drive
- 80h mapped to local drive
- 81h local drive used as permanent network drive
- 82h local drive used as temporary network drive
- --------N-21EF02-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET DRIVE CONNECTION ID TABLE
- AX = EF02h
- Return: ES:SI -> network shell's 32-byte drive conection ID table
- AX = 0000h
- Notes: this function is supported by Advanced NetWare 1.0+
- each byte in the connection ID table corresponds to a drive and
- contains either the connection ID (1-8) of the server for that drive
- or 00h if the drive is not mapped to a file server
- SeeAlso: AX=EF01h,AX=EF03h,AX=F002h
- --------N-21EF03-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET CONNECTION ID TABLE
- AX = EF03h
- Return: ES:SI -> network shell's connection ID table (see below)
- AX = 0000h
- Note: this function is supported by Advanced NetWare 1.0+
- SeeAlso: AX=EF00h,AX=EF02h,AX=EF04h,AX=F002h
-
- Format of connection ID table [one entry of eight-element array]:
- Offset Size Description
- 00h BYTE in use flag
- E0h AES temporary
- F8h IPX in critical section
- FAh processing
- FBh holding
- FCh AES waiting
- FDh waiting
- FEh receiving
- FFh sending
- 01h BYTE order number assigned to server (1-8)
- 02h DWORD file server's network address (big-endian)
- 06h 6 BYTEs file server's node address (big-endian)
- 0Ch WORD socket number (big-endian)
- 0Eh WORD base receive timeout in clock ticks (big-endian)
- 10h 6 BYTEs preferred routing node (big-endian)
- 16h BYTE packet sequence number
- 17h BYTE connection number (FFh = no connection)
- 18h BYTE connection status (00h if active)
- 19h WORD maximum receive timeout in clock ticks (big-endian)
- 1Bh 5 BYTEs reserved
- --------N-21EF04-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET FILE SERVER NAME TABLE
- AX = EF04h
- Return: ES:SI -> network shell's file server name table (see below)
- AX = 0000h
- Notes: this function is supported by Advanced NetWare 1.0+
- the name table consists of eight 48-byte entries, each consisting of
- an ASCIZ server name for the corresponding entry in the connection
- ID table
- SeeAlso: AX=EF03h
- --------T-21F0-------------------------------
- INT 21 - DoubleDOS - MENU CONTROL
- AH = F0h
- AL = subfunction
- 01h exchange tasks
- 73h resume invisible job if suspended
- 74h kill other job
- 75h suspend invisible job
- Note: identical to AH=E0h
- SeeAlso: AH=E0h"DoubleDOS"
- --------v-21F0-------------------------------
- INT 21 - VIRUS - "Frere Jacques" - INSTALLATION CHECK
- AH = F0h
- Return: AX = 0300h if resident
- SeeAlso: AH=EEh"VIRUS",AH=F1h"VIRUS"
- --------N-21F000-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - SET PREFERRED CONNECTION ID
- AX = F000h
- DL = connection ID of prefered file server (1-8) or 00h for none
- Notes: this function is supported by Advanced NetWare 1.0+
- the preferred connection ID is set to 00h by the shell on EOJ
- SeeAlso: AH=D6h,AX=EF03h,AX=F001h,AX=F002h,AX=F005h
- --------N-21F001-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET PREFERRED CONNECTION ID
- AX = F001h
- Return: AL = connection ID of preferred file server (1-8), 00h if not set
- Notes: this function is supported by Advanced NetWare 1.0+
- the preferred connection ID is set to 00h by the shell on EOJ
- SeeAlso: AH=D6h,AX=EF03h,AX=F000h,AX=F002h,AX=F005h
- --------N-21F002-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET DEFAULT CONNECTION ID
- AX = F002h
- Return: AL = connection ID of current default file server (1-8) (see AX=EF03h)
- Note: this function is supported by Advanced NetWare 1.0+
- SeeAlso: AX=EF03h,AX=F000h,AX=F004h
- --------N-21F003-----------------------------
- INT 21 - Novell NetWare - PRINT SERVICES - GET LPT CAPTURE STATUS
- AX = F003h
- Return: AH = status
- 00h not active
- FFh active
- AL = connection ID (01h-08h)
- Note: this function is supported by Advanced NetWare 1.0+
- SeeAlso: AX=B800h,AX=B804h,AH=DFh/DL=00h,AH=DFh/DL=04h
- --------N-21F004-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - SET PRIMARY CONNECTION ID
- AX = F004h
- DL = connection ID of primary file server (1-8) or 00h for none
- Note: this function is supported by Advanced NetWare 2.0+
- SeeAlso: AH=D6h,AX=EF03h,AX=F000h,AX=F002h,AX=F005h
- --------N-21F005-----------------------------
- INT 21 - Novell NetWare - WORKSTATION - GET PRIMARY CONNECTION ID
- AX = F005h
- Return: AL = connection ID of primary file server (1-8), 00h if not set
- Notes: this function is supported by Advanced NetWare 2.0+
- by default, the primary file server is the one from which the login
- script executed; it is set to 00h if the workstation is not logged in
- and when it detaches from its primary file server
- SeeAlso: AH=D6h,AX=EF03h,AX=F000h,AX=F002h,AX=F004h
- --------N-21F1-------------------------------
- INT 21 - Novell NetWare - CONNECTION SERVICES - FILE SERVER CONNECTION
- AH = F1h
- AL = subfunction
- 00h attach to file server
- DL = preferred file server (01h-08h)
- 01h detach from file server
- DL = connection ID
- 02h logout from file server
- DL = connection ID
- Return: AL = status
- 00h successful
- F8h already attached to server
- F9h connection table full
- FAh no more server slots
- FCh unknown file server
- FEh server bindery locked
- FFh no response from server, or connection does not exist
- Note: these functions are supported by Advanced NetWare 1.0+
- SeeAlso: AH=D7h"NetWare",AH=E3h/SF=14h
- --------T-21F1-------------------------------
- INT 21 - DoubleDOS - CLEAR KEYBOARD BUFFER FOR CURRENT JOB
- AH = F1h
- SeeAlso: AH=E1h"DoubleDOS",AH=F2h"DoubleDOS",AH=F3h"DoubleDOS"
- SeeAlso: AH=F8h"DoubleDOS"
- --------v-21F1-------------------------------
- INT 21 - VIRUS - "F1-337" - ???
- AH = F1h
- ???
- Return: ???
- SeeAlso: AH=F0h"VIRUS",AX=F2AAh
- --------N-21F2-------------------------------
- INT 21 u - Novell NetWare v3.01+ shell interface - MULTIPLEXOR
- AH = F2h
- AL = function
- 15h broadcast services (see AH=E1h"NetWare")
- 16h file/directory services (see AH=E2h"NetWare")
- 17h connection control (see AH=E3h"NetWare")
- CX = length of request buffer in bytes
- DX = length of reply buffer in bytes
- DS:SI -> request buffer (contents vary by function)
- ES:DI -> reply buffer (contents vary by function)
- Return: AL = status
- reply buffer filled as appropriate for function
- Note: this is a multiplexor providing a "raw" interface to the underlying
- Netware Core Protocol. Many functions which were accessed via a
- separate AH function in older versions can also be accessed here
- (the function number in AL is added to CCh to get the old function
- number which is desired), but some NetWare 3.x calls appear to be
- available only here.
- SeeAlso: AX=F244h
- --------T-21F2-------------------------------
- INT 21 - DoubleDOS - SEND CHARACTER TO KEYBOARD BUFFER OF OTHER JOB
- AH = F2h
- AL = character
- Return: AL = 00h successful
- 01h buffer full (128 characters)
- SeeAlso: AH=E2h"DoubleDOS",AH=F1h"DoubleDOS",AH=F3h"DoubleDOS"
- SeeAlso: AH=F8h"DoubleDOS"
- --------N-21F244-----------------------------
- INT 21 - Novell NetWare - FILE SERVICES - ERASE FILES
- AX = F244h
- DS:SI -> request buffer (see below)
- ES:DI -> reply buffer (ignored???)
- Return: AL = status
- 00h successful
- 98h nonexistent volume
- 9Bh invaid directory handle
- 9Ch invalid path
- FFh no files found
- Note: this function only marks the file for deletion; use AH=E2h/SF=CEh to
- actually delete all marked files
- SeeAlso: AH=13h,AH=41h,AH=E2h/SF=0Bh,AH=E3h/SF=CEh
-
- Format of request buffer:
- Offset Size Description
- 00h BYTE directory handle
- 01h BYTE search attributes (see AX=4301h)
- 02h BYTE length of filespec
- 03h N BYTEs ASCIZ filespec (may include wildcards)
- --------v-21F2AA-----------------------------
- INT 21 - VIRUS - "PcVrsDs" - INSTALLATION CHECK
- AX = F2AAh
- Return: AH = AAh if resident
- SeeAlso: AH=F1h"VIRUS",AH=F3h"VIRUS"
- --------N-21F3-------------------------------
- INT 21 - Novell NetWare - FILE SERVICES - FILE SERVER FILE COPY
- AH = F3h
- ES:DI -> request buffer (see below)
- Return: AL = status/error code
- CX:DX = number of bytes copied
- Notes: this function is supported by Advanced NetWare 2.0+
- both source and destination must be on the same file server
- SeeAlso: AH=3Ch,AH=3Fh
-
- Format of request buffer:
- Offset Size Description
- 00h WORD source file handle (as returned by AH=3Ch or AH=3Dh)
- 02h WORD destination file handle
- 04h DWORD starting offset in source
- 08h DWORD starting offset in destination
- 0Ch DWORD number of bytes to copy
- --------T-21F3-------------------------------
- INT 21 - DoubleDOS - ADD CHARACTER TO KEYBOARD BUFFER OF CURRENT JOB
- AH = F3h
- AL = character
- Return: AL = 00h successful
- 01h buffer full (128 characters)
- SeeAlso: AH=E3h"DoubleDOS",AH=F1h"DoubleDOS",AH=F2h"DoubleDOS"
- SeeAlso: AH=F8h"DoubleDOS"
- --------v-21F3-------------------------------
- INT 21 - VIRUS - "Carfield" - INSTALLATION CHECK
- AH = F3h
- Return: AX = 0400h if resident
- SeeAlso: AH=D5h"Carfield",AX=F2AAh,AH=F7h"VIRUS"
- --------T-21F400-----------------------------
- INT 21 - DoubleDOS - INSTALLATION CHECK/PROGRAM STATUS
- AX = F400h
- Return: AL = 00h if DoubleDOS not present
- = 01h if running in visible DoubleDOS partition
- = 02h if running in the invisible DoubleDOS partition
- SeeAlso: AX=E400h,AH=F5h"DoubleDOS"
- --------T-21F5-------------------------------
- INT 21 - DoubleDOS - OTHER PROGRAM STATUS
- AH = F5h
- Return: AL = 00h no program in other partition
- = 01h program in other partition is running
- = 02h program in other partition is suspended
- SeeAlso: AH=E5h"DoubleDOS",AX=F400h"DoubleDOS"
- --------v-21F7-------------------------------
- INT 21 - VIRUS - "GP1" - INSTALLATION CHECK
- AH = F7h
- Return: AX = 0300h if resident
- SeeAlso: AH=F0h"VIRUS",AH=FBh"VIRUS"
- --------D-21F8-------------------------------
- INT 21 - DOS v2.11 - SET OEM INT 21 HANDLER
- AH = F8h
- DS:DX -> OEM INT 21 handler for functions F9h to FFh
- FFFFh:FFFFh disables OEM handler
- Notes: this function is supported by Toshiba T1000 ROM MS-DOS 2.11
- calls to AH=F9h through AH=FFH will return AL=00h if no handler set
- handler is called with all registers exactly as set by caller, and
- should exit with IRET
- SeeAlso: AH=F9h"OEM"
- --------T-21F8-------------------------------
- INT 21 - DoubleDOS - SET/RESET KEYBOARD CONTROL FLAGS
- AH = F8h
- AL = 00h set flags for this program
- = 01h set flags for other program
- DX = keyboard control flags (see AH=E8h"DoubleDOS")
- Return: DX = previous flags
- Notes: disabling Ctrl-PrtSc will allow the program to intercept the keystroke;
- disabling any of the other keystrokes disables them completely
- this function is identical to AH=E8h
- SeeAlso: AH=E8h"DoubleDOS",AH=F1h"DoubleDOS",AH=F2h"DoubleDOS"
- SeeAlso: AH=F3h"DoubleDOS"
- --------D-21F9-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = F9h
- SeeAlso: AH=F8h"OEM",AH=FAh"OEM"
- --------T-21F9-------------------------------
- INT 21 - DoubleDOS - SET TIMESHARING PRIORITY
- AH = F9h
- AL = 00h visible program gets 70%, invisible gets 30% (default)
- = 01h visible program gets 50%, invisible gets 50%
- = 02h visible program gets 30%, invisible gets 70%
- = 03h Top program gets 70%, bottom program gets 30%
- = 04h Top program gets 30%, bottom program gets 70%
- = 05h get current priority
- Return: AL = priority setting
- Note: identical to AH=E9h
- SeeAlso: AH=E9h"DoubleDOS",AH=FAh"DoubleDOS",AH=FBh"DoubleDOS"
- --------D-21FA-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FAh
- SeeAlso: AH=F8h"OEM",AH=F9h"OEM",AH=FBh"OEM"
- --------T-21FA-------------------------------
- INT 21 - DoubleDOS - TURN OFF TASK SWITCHING
- AH = FAh
- Return: task switching turned off
- SeeAlso: AH=EAh"DoubleDOS",AH=F9h"DoubleDOS",AH=FBh"DoubleDOS"
- SeeAlso: INT FA"DoubleDOS"
- --------v-21FA--DX5945-----------------------
- INT 21 U - PC Tools v7+ VDEFEND, VSAFE, VWATCH - API
- AH = FAh
- DX = 5945h
- AL = function (00h-02h for VDEFEND, 00h-07h for VSAFE and VWATCH)
- Return: varies by function
- Note: this API is identical to the API on INT 13/AH=FAh and INT 16/AH=FAh,
- so it is listed in its entirety only under INT 16/AX=FA00h and
- following
- SeeAlso: INT 13/AX=FA00h,INT 16/AX=FA00h
- --------D-21FB-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FBh
- SeeAlso: AH=F8h"OEM",AH=FAh"OEM",AH=FCh"OEM"
- --------T-21FB-------------------------------
- INT 21 - DoubleDOS - TURN ON TASK SWITCHING
- AH = FBh
- Return: task switching turned on
- SeeAlso: AH=EBh"DoubleDOS",AH=F9h"DoubleDOS",AH=FAh"DoubleDOS"
- SeeAlso: INT FB"DoubleDOS"
- --------v-21FB-------------------------------
- INT 21 - VIRUS - "Cinderella" - INSTALLATION CHECK
- AH = FBh
- Return: AH = 00h if resident
- SeeAlso: AH=F7h"VIRUS",AX=FB0Ah
- --------v-21FB0A-----------------------------
- INT 21 - VIRUS - "dBASE" - INSTALLATION CHECK
- AX = FB0Ah
- Return: AX = 0AFBh if resident
- SeeAlso: AH=FBh"VIRUS",AH=FCh"VIRUS"
- --------D-21FC-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FCh
- SeeAlso: AH=F8h"OEM",AH=FBh"OEM",AH=FDh"OEM"
- --------T-21FC-------------------------------
- INT 21 - DoubleDOS - GET VIRTUAL SCREEN ADDRESS
- AH = FCh
- Return: ES = segment of virtual screen
- Desc: Determine the address of the virtual screen to which the program
- should write instead of the actual video memory, so that the
- multitasked programs do not interfere with each other's output.
- Notes: screen address can change if task-switching is on!!
- identical to AH=ECh
- SeeAlso: AH=ECh"DoubleDOS",INT FC"DoubleDOS"
- --------v-21FC-------------------------------
- INT 21 - VIRUS - "Troi" - INSTALLATION CHECK
- AH = FCh
- Return: AL = A5h if resident
- SeeAlso: AH=FB0Ah"VIRUS",AH=FDh"VIRUS"
- --------D-21FD-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FDh
- SeeAlso: AH=F8h"OEM",AH=FCh"OEM",AH=FEh"DOS"
- --------v-21FD-------------------------------
- INT 21 - VIRUS - "Border" - INSTALLATION CHECK
- AH = FDh
- Return: AH = 13h if resident
- SeeAlso: AH=FCh"VIRUS",AH=FEh"VIRUS"
- --------D-21FE-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FEh
- SeeAlso: AH=F8h"OEM",AH=FDh"OEM",AH=FFh"OEM"
- --------T-21FE-------------------------------
- INT 21 - DoubleDOS - GIVE AWAY TIME TO OTHER TASKS
- AH = FEh
- AL = number of 55ms time slices to give away
- Return: returns after giving away time slices
- SeeAlso: AH=EEh"DoubleDOS",INT FE"DoubleDOS"
- --------v-21FE-------------------------------
- INT 21 - VIRUS - "483" - INSTALLATION CHECK
- AH = FEh
- Return: AH = 00h if resident
- SeeAlso: AH=FDh"VIRUS",AX=FE01h
- --------v-21FE01-----------------------------
- INT 21 - VIRUS - "Flip" - INSTALLATION CHECK
- AX = FE01h
- Return: AX = 01FEh if resident
- SeeAlso: AH=FEh"VIRUS",AX=FE02h
- --------v-21FE02-----------------------------
- INT 21 - VIRUS - "2468"/"Tequila" - INSTALLATION CHECK
- AX = FE02h
- Return: AX = 01FDh if resident
- SeeAlso: AX=FE01h,AX=FEDCh"VIRUS"
- --------d-21FEDC-----------------------------
- INT 21 - PCMag PCMANAGE/DCOMPRES - INSTALLATION CHECK
- AX = FEDCh
- Return: AX = CDEFh if installed
- Program: the PCMANAGE/DCOMPRES combination from PC Magazine permits
- infrequently-used files to be compressed to save space and
- transparently expanded when accessed
- SeeAlso: AH=DCh,INT 2D/AL=10h"dLite"
- --------v-21FEDC-----------------------------
- INT 21 - VIRUS - "Black Monday" - INSTALLATION CHECK
- AX = FEDCh
- Return: AL = DCh if resident
- SeeAlso: AX=FE02h,AH=FFh"VIRUS"
- --------D-21FF-------------------------------
- INT 21 - DOS v2.11 - OEM FUNCTION
- AH = FFh
- SeeAlso: AH=F8h"OEM",AH=FEh"OEM"
- --------K-21FF-------------------------------
- INT 21 - CED (Command EDitor) - INSTALLABLE COMMANDS
- AH = FFH
- AL = subfunction
- 00h add installable command
- BL = mode - bit 0 = 1 callable from DOS prompt
- bit 1 = 1 callable from application
- DS:SI -> CR-terminated command name
- ES:DI -> FAR routine entry point
- 01h remove installable command
- DS:SI -> CR-terminated command name
- 02h reserved, may be used to test for CED installation
- Return: CF clear if successful
- CF set on error
- AX = 01h invalid function
- 02h command not found (subfunction 01h only)
- 08h insufficient memory (subfunction 00h only)
- 0Eh bad data (subfunction 00h only)
- AH = FFh if CED not installed
- Program: CED is a shareware DOS command-line enhancer by Christopher J. Dunford
- SeeAlso: AX=0A00h
- --------E-21FF-------------------------------
- INT 21 - DJ GO32.EXE 80386+ DOS extender - DOS EXTENSIONS
- AH = FFh
- AL = function
- 01h create file
- 02h open file
- 03h get file statistics
- 04h get time of day
- 05h set time of day
- 06h stat
- 07h system
- Program: GO32.EXE is a DOS extender included as part of the 80386 port of the
- GNU C/C++ compiler by DJ Delorie and distributed as DJGPP
- SeeAlso: INT 10/AH=FFh"GO32"
- --------K-21FF-------------------------------
- INT 21 - DOSED.COM - INSTALLATION CHECK
- AH = FFh
- DS:SI -> "DOSED"
- ES = 0000h
- Return: ES:DI -> "DOSED" if installed
- Program: DOSED is a free DOS commandline editor/history buffer by Sverre H.
- Huseby
- --------N-21FF-------------------------------
- INT 21 - Topware Network Operating System - ???
- AH = FFh
- ???
- Return: ???
- SeeAlso: INT 2F/AX=FF00h
- --------v-21FF-------------------------------
- INT 21 - VIRUS - "Sunday", "Tumen 0.5", "Hero" - INSTALLATION CHECK
- AH = FFh
- Return: AH = 00h if "Tumen 0.5" or "Hero" resident
- AX = 0400h if "Sunday" resident
- SeeAlso: AX=FEDCh"VIRUS",AX=FF0Fh
- --------E-21FF-------------------------------
- INT 21 UP - Rational Systems DOS/4GW - API
- AH = FFh
- DH = function (00h-17h) (see also separate entries below)
- DL = subfunction or argument
- Return: CF clear if valid function number
- AX = status???
- CF set if invalid function
- SeeAlso: INT 15/AX=BFDCh
- --------E-21FF--DH02-------------------------
- INT 21 UP - Rational Systems DOS/4GW - SET ???
- AH = FFh
- DH = 02h
- DL = ???
- Return: CF clear
- --------E-21FF--DH05-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 05h
- BX = ???
- Return: ???
- --------E-21FF--DH06-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 06h
- BX = ???
- Return: ???
- --------E-21FF--DH07-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 07h
- BX = ???
- Return: ???
- --------E-21FF--DH08-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 08h
- BX = ???
- CX = ???
- ES = ???
- Return: ???
- --------E-21FF--DH09-------------------------
- INT 21 UP - Rational Systems DOS/4GW - GET ???
- AH = FFh
- DH = 09h
- Return: ES:BX -> ???
- --------E-21FF--DH0A-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 0Ah
- AL = ???
- BX = ???
- CX = ???
- Return: ES = ??? or 0000h
- --------E-21FF--DH0B-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 0Bh
- AL = ???
- BX = ???
- CX = ???
- Return: ???
- --------E-21FF--DH0C-------------------------
- INT 21 UP - Rational Systems DOS/4GW - GET/SET ???
- AH = FFh
- DH = 0Ch
- DL = ??? (00h or 01h)
- Return: CF clear if successful
- AL = previous value of ???
- CF set on error (DL out of range)
- AX = FFFFh
- --------E-21FF--DH0D-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 0Dh
- ???
- Return: ???
- --------E-21FF--DH0E-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 0Eh
- Return: DX:AX -> XBRK structure (see INT 15/AX=BF02h)
- BX = ???
- CX = ???
- SeeAlso: INT 15/AX=BF02h
- --------E-21FF--DH0F-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 0Fh
- ???
- Return: ???
- --------E-21FF--DH10-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 10h
- AL = ???
- BX = ???
- CX = ???
- DI = ???
- SI = ???
- Return: ???
- Note: among other things, frees two memory blocks via INT 21/AH=49h
- --------E-21FF--DH11-------------------------
- INT 21 UP - Rational Systems DOS/4GW - NOP
- AH = FFh
- DH = 11h
- --------E-21FF--DH12-------------------------
- INT 21 UP - Rational Systems DOS/4GW - EXCHANGE ??? POINTERS
- AH = FFh
- DH = 12h
- DS:SI -> new ???
- ES:DI -> new ???
- Return: DS:SI -> previous ???
- ES:DI -> previous ???
- --------E-21FF--DH13-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 13h
- AL = ???
- ES = ???
- Return: ???
- --------E-21FF--DH14-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFh
- DH = 14h
- BX = ???
- CX = ???
- Return: CF clear
- AX = ???
- DX = ???
- --------E-21FF--DH15-------------------------
- INT 21 UP - Rational Systems DOS/4GW - GET ??? FUNCTIONS
- AH = FFh
- DH = 15h
- Return: CF clear
- DX:AX -> FAR function for ???
- CX:BX -> FAR function for ???
- SI:DI -> FAR function for ???
- --------E-21FF--DH16-------------------------
- INT 21 UP - Rational Systems DOS/4GW - GET ???
- AH = FFh
- DH = 16h
- Return: AX = ???
- --------E-21FF--DH17-------------------------
- INT 21 UP - Rational Systems DOS/4GW - ???
- AH = FFH
- DH = 17h
- AL = ???
- DL = ???
- Return: ???
- --------E-21FF00DX0078-----------------------
- INT 21 - Rational Systems DOS/4G - INSTALLATION CHECK
- AX = FF00h
- DX = 0078h
- Return: AL <> 00h if installed
- GS = segment of kernel if nonzero
- SeeAlso: INT 15/AX=BF02h
- --------v-21FF0F-----------------------------
- INT 21 - FLU_SHOT+ v1.83 - INSTALLATION CHECK
- AX = FF0Fh
- Return: AX = 0101h if resident
- Program: FLU_SHOT+ is an antivirus/antitrojan program by Ross M. Greenberg and
- Software Concepts Design
- Note: the "PSQR/1720" virus calls this function to determine whether
- FLU_SHOT+ is present
- SeeAlso: AH=FFh"VIRUS",AX=FF10h
- --------v-21FF10-----------------------------
- INT 21 - VIRUS - "Twins" - INSTALLATION CHECK
- AX = FF10h
- Return: AL = 07h if resident
- SeeAlso: AX=FF0Fh,AX=FFFEh
- --------v-21FFFE-----------------------------
- INT 21 - VIRUS - "08/15"/"Many Fingers" - INSTALLATION CHECK
- AX = FFFEh
- Return: AX = 0815h if resident
- SeeAlso: AX=FF10h,AX=FFFFh
- --------v-21FFFF-----------------------------
- INT 21 - VIRUS - "Ontario", "Year 1992"/"B1M92" - INSTALLATION CHECK
- AX = FFFFh
- Return: AX = 0000h if "Ontario" resident
- AX = 1992h if "Year 1992"/"B1M92" resident
- SeeAlso: AX=FF0Fh,AX=FFFFh/CX=0000h,INT 6B"VIRUS"
- --------v-21FFFFCX0000-----------------------
- INT 21 - VIRUS - "Revenge" - INSTALLATION CHECK
- AX = FFFFh
- CX = 0000h
- Return: CX = 0006h if resident
- SeeAlso: AX=FFFFh,INT 6B"VIRUS"
- --------D-22---------------------------------
- INT 22 - DOS 1+ - PROGRAM TERMINATION ADDRESS
- Desc: this vector specifies the address of the routine which is to be given
- control after a program is terminated; it should never be called
- directly, since it does not point at an interrupt handler
- Notes: this vector is restored from the DWORD at offset 0Ah in the PSP during
- termination, and then a FAR JMP is performed to the address in INT 22
- normally points at the instruction immediately following INT 21/AH=4Bh
- call which loaded the current program
- SeeAlso: INT 20,INT 21/AH=00h,INT 21/AH=31h,INT 21/AH=4Ch
- --------G-22---------------------------------
- INT 22 - COMTROL HOSTESS i/ISA DEBUGGER - CHANGE FIRMWARE DEBUGGING PORT
- AL = new firmware debugging port
- Return: ???
- SeeAlso: INT 21"COMTROL HOSTESS",INT 23"COMTROL HOSTESS"
- --------D-23---------------------------------
- INT 23 - DOS 1+ - CONTROL-C/CONTROL-BREAK HANDLER
- ---DOS 1.x---
- Return: AH = 00h abort program
- if all registers preserved, restart DOS call
- ---DOS 2+---
- CF clear
- Return: all registers preserved
- return via RETF or RETF 2 with CF set
- DOS will abort program with errorlevel 0
- else (RETF/RETF 2 with CF clear or IRET)
- interrupted DOS call is restarted
- Notes: this interrupt is invoked whenever DOS detects a ^C or ^Break; it
- should never be called directly
- MS-DOS 1.25 also invokes INT 23 on a divide overflow (INT 00)
- DOS remembers the stack pointer before calling INT 23, and if it is
- not the same on return, pops and discards the top word; this is what
- permits a return with RETF as well as IRET or RETF 2
- any DOS call may safely be made within the INT 23 handler, although
- the handler must to check for a recursive invocation if it does
- call DOS
- SeeAlso: INT 1B
- --------G-23---------------------------------
- INT 23 - COMTROL HOSTESS i/ISA DEBUGGER - GET CONFIGURATION INFORMATION
- AL = query type
- 00h get old config map
- Return: AX = old config map
- 01h get dual-ported RAM map
- Return: BX:AX = dual-ported RAM map
- 02h get SCC port map
- Return: BX:AX = SCC port map
- SeeAlso: INT 22"COMTROL HOSTESS",INT 26"COMTROL HOSTESS"
- --------D-24---------------------------------
- INT 24 - DOS 1+ - CRITICAL ERROR HANDLER
- Note: invoked when a critical (usually hardware) error is encountered; should
- never be called directly
- SeeAlso: INT 21/AH=95h
-
- Critical error handler is invoked with:
- AH = type and processing flags
- bit 7 clear = disk I/O error
- set = -- if block device, bad FAT image in memory
- -- if char device, error code in DI
- bit 6 unused
- bit 5 = 1 if Ignore allowed, 0 if not (DOS 3+)
- bit 4 = 1 if Retry allowed, 0 if not (DOS 3+)
- bit 3 = 1 if Fail allowed, 0 if not (DOS 3+)
- bit 2 \ disk area of error 00 = DOS area 01 = FAT
- bit 1 / 10 = root dir 11 = data area
- bit 0 = 1 if write, 0 if read
- AL = drive number if AH bit 7 clear
- BP:SI -> device driver header (BP:[SI+4] bit 15 set if char device)
- DI low byte contains error code if AH bit 7 set
- 00h write-protection violation attempted
- 01h unknown unit for driver
- 02h drive not ready
- 03h unknown command given to driver
- 04h data error (bad CRC)
- 05h bad device driver request structure length
- 06h seek error
- 07h unknown media type
- 08h sector not found
- 09h printer out of paper
- 0Ah write fault
- 0Bh read fault
- 0Ch general failure
- 0Dh (DOS 3+) sharing violation
- 0Eh (DOS 3+) lock violation
- 0Fh invalid disk change
- 10h (DOS 3+) FCB unavailable
- 11h (DOS 3+) sharing buffer overflow
- 12h (DOS 4+) code page mismatch
- 13h (DOS 4+) out of input
- 14h (DOS 4+) insufficient disk space
- STACK: DWORD return address for INT 24 call
- WORD flags pushed by INT 24
- WORD original AX on entry to INT 21
- WORD BX
- WORD CX
- WORD DX
- WORD SI
- WORD DI
- WORD BP
- WORD DS
- WORD ES
- DWORD return address for INT 21 call
- WORD flags pushed by INT 21
- Handler must return:
- AL = action code
- 00h ignore error and continue processing request
- 01h retry operation
- 02h terminate program through the equivalent of INT 21/AH=4Ch
- (INT 20h for DOS 1.x)
- 03h fail system call in progress
- SS,SP,DS,ES,BX,CX,DX preserved
- Notes: the only DOS calls the handler may make are INT 21/AH=01h-0Ch,30h,59h
- if the handler returns to the application by popping the stack, DOS
- will be in an unstable state until the first call with AH > 0Ch
- for DOS 3.1+, IGNORE (AL=00h) is turned into FAIL (AL=03h) on network
- critical errors
- if IGNORE specified but not allowed, it is turned into FAIL
- if RETRY specified but not allowed, it is turned into FAIL
- if FAIL specified but not allowed, it is turned into ABORT
- (DOS 3+) if a critical error occurs inside the critical error handler,
- the DOS call is automatically failed
- --------D-25---------------------------------
- INT 25 - DOS 1+ - ABSOLUTE DISK READ (except partitions > 32M)
- AL = drive number (00h = A:, 01h = B:, etc)
- CX = number of sectors to read
- DX = starting logical sector number (0000h - highest sector on drive)
- DS:BX -> buffer for data
- Return: CF clear if successful
- CF set on error
- AH = status
- 80h device failed to respond (timeout)
- 40h seek operation failed
- 20h controller failed
- 10h data error (bad CRC)
- 08h DMA failure
- 04h requested sector not found
- 03h write-protected disk (INT 26 only)
- 02h bad address mark
- 01h bad command
- AL = error code (same as passed to INT 24 in DI)
- AX = 0207h if more than 64K sectors on drive
- may destroy all other registers except segment registers
- Notes: original flags are left on stack, and must be popped by caller
- this call bypasses the DOS filesystem
- BUG: DOS 3.1 through 3.3 set the word at ES:[BP+1Eh] to FFFFh if AL is an
- invalid drive number
- SeeAlso: INT 13/AH=02h,INT 26
- --------D-25---------------------------------
- INT 25 - DOS 3.31+ - ABSOLUTE DISK READ (>32M hard-disk partition)
- AL = drive number (0=A, 1=B, etc)
- CX = FFFFh
- DS:BX -> disk read packet (see below)
- Return: same as above
- Notes: partition is potentially >32M (and requires this form of the call) if
- bit 1 of device attribute word in device driver is set
- original flags are left on stack, and must be removed by caller
- this call bypasses the DOS filesystem
- SeeAlso: INT 13/AH=02h,INT 26
-
- Format of disk read packet:
- Offset Size Description
- 00h DWORD sector number
- 04h WORD number of sectors to read
- 06h DWORD transfer address
- --------d-25CDCD-----------------------------
- INT 25 - Stacker - GET DEVICE DRIVER ADDRESS
- AX = CDCDh
- DS:BX -> buffer for address (see below)
- CX = 0001h
- DX = 0000h
- Return: AX = CDCDh if Stacker installed
- DS:BX buffer filled
-
- Format of driver address buffer:
- Offset Size Description
- 00h WORD signature CDCDh
- 02h WORD ??? 0001h
- 04h DWORD pointer to start of Stacker device driver
-
- Format of device driver:
- Offset Size Description
- 00h WORD signature A55Ah
- 02h WORD Stacker version * 64h
- 04h WORD offset of volume-specific information offset table
- (list of WORDs, one per drive, containing offsets to various
- information)
- 06h 56 BYTEs n/a
- 3Eh BYTE volume number, set after INT 21/AX=4404h
- (use to index into volume-specific info offset table)
- 3Fh 19 BYTEs n/a
- 52h 4 BYTEs ASCII string "SWAP"
- 56h 26 BYTEs drive mapping table (one byte for each drive A: through Z:)
-
- Format of Stacker boot record:
- Offset Size Description
- 1F0h 8 BYTEs Stacker signature (first byte is CDh)
- 1F8h DWORD pointer to start of Stacker device driver
- 1FCh WORD Stacker volume number
- 1FEh WORD ???
- --------c-25--FFSI4358-----------------------
- INT 25 - PC-CACHE.SYS - INSTALLATION CHECK
- AL = FFh
- SI = 4358h
- Return: SI = 6378h if installed
- CX = segment of device driver PC-CACHE.SYS
- DX = version (major in DH, minor in DL)
- Program: PC-CACHE.SYS is a small device driver used by PC-Cache v5.x to obtain
- access to certain disk drivers for devices such as Bernoulli drives
- SeeAlso: INT 13/AH=A0h
- --------D-26---------------------------------
- INT 26 - DOS 1+ - ABSOLUTE DISK WRITE (except partitions > 32M)
- AL = drive number (00h = A:, 01h = B:, etc)
- CX = number of sectors to write
- DX = starting logical sector number (0000h - highest sector on drive)
- DS:BX -> data to write
- Return: CF clear if successful
- CF set on error
- AH = status
- 80h device failed to respond (timeout)
- 40h seek operation failed
- 20h controller failed
- 10h data error (bad CRC)
- 08h DMA failure
- 04h requested sector not found
- 03h write-protected disk (INT 26 only)
- 02h bad address mark
- 01h bad command
- AL = error code (same as passed to INT 24 in DI)
- AX = 0207h if more than 64K sectors on drive
- may destroy all other registers except segment registers
- Notes: original flags are left on stack, and must be popped by caller
- this call bypasses the DOS filesystem, though DOS 5+ invalidates any
- disk buffers referencing sectors which are written with this call
- BUG: DOS 3.1 through 3.3 set the word at ES:[BP+1Eh] to FFFFh if AL is an
- invalid drive number
- SeeAlso: INT 13/AH=03h,INT 25
- --------D-26---------------------------------
- INT 26 - DOS 3.31+ - ABSOLUTE DISK WRITE (>32M hard-disk partition)
- AL = drive number (0=A, 1=B, etc)
- CX = FFFFh
- DS:BX -> disk write packet (see below)
- Return: same as above
- Notes: partition is potentially >32M (and requires this form of the call) if
- bit 1 of device attribute word in device driver is set
- original flags are left on stack, and must be removed by caller
- this call bypasses the DOS filesystem, though DOS 5+ invalidates any
- disk buffers referencing sectors which are written with this call
- SeeAlso: INT 13/AH=03h,INT 25
-
- Format of disk write packet:
- Offset Size Description
- 00h DWORD sector number
- 04h WORD number of sectors to read
- 06h DWORD transfer address
- --------G-26---------------------------------
- INT 26 - COMTROL HOSTESS i/ISA DEBUGGER - ENTER/EXIT EXTENDED ADDRESSING MODE
- ???
- Return: ???
- SeeAlso: INT 23"COMTROL HOSTESS",INT 27"COMTROL HOSTESS"
- --------D-27---------------------------------
- INT 27 - DOS 1+ - TERMINATE AND STAY RESIDENT
- DX = number of bytes to keep resident (max FFF0h)
- CS = segment of PSP
- Return: never
- Notes: this is an obsolete call
- INT 22, INT 23, and INT 24 are restored from the PSP
- does not close any open files
- the minimum number of bytes which will remain resident is 110h for
- DOS 2.x and 60h for DOS 3+; there is no minimum for DOS 1.x, which
- implements this service in COMMAND.COM rather than the DOS kernel
- SeeAlso: INT 21/AH=31h
- --------G-27---------------------------------
- INT 27 - COMTROL HOSTESS i/ISA DEBUGGER - INVOKE REMOTE TURBO DEBUGGER KERNEL
- ???
- Return: ???
- Desc: invoke a copy of the remote Turbo Debugger kernel on the Hostess i
- controller
- SeeAlso: INT 20"COMTROL HOSTESS",INT 26"COMTROL HOSTESS"
- ---------------------------------------------
-