en:docs:dos:api:int21:40

Note: This API call is for DOS and Win16 personality only. Use Family API for portability.

2018/09/07 05:04 · prokushev · 0 Comments

Int 21H, AH=40H

Version

2 and higher

Brief

“WRITE” - WRITE TO FILE OR DEVICE

Family API

Input

      AH = 40h
      BX = file handle
      CX = number of bytes to write
      DS:DX -> data to write

Return

CF clear if successful

          AX = number of bytes actually written
      CF set on error
          AX = error code (05h,06h) (see #01680 at AH=59h/BX=0000h)

Notes

if CX is zero, no data is written, and the file is truncated or extended to the current position

data is written beginning at the current file position, and the file position is updated after a successful write

for FAT32 drives, the file must have been opened with AX=6C00h with the “extended size” flag in order to expand the file beyond 2GB; otherwise the write will fail with error code 0005h (access denied)

the usual cause for AX < CX on return is a full disk

BUG: a write of zero bytes will appear to succeed when it actually failed if the write is extending the file and there is not enough disk space for the expanded file (DOS 5.0-6.0); one should therefore check whether the file was in fact extended by seeking to 0 bytes from the end of the file (INT 21/AX=4202h/CX=0000h/DX=0000h)

under the FlashTek X-32 DOS extender, the pointer is in DS:EDX

See also

AH=28h,AH=3Fh,INT 2F/AX=1109h

Note

2018/09/04 17:23 · prokushev · 0 Comments