|
Tape Input and Output
The Win32 API provides several functions that applications can use to perform
input and output (I/O) on a tape drive. Tape I/O is similar to I/O performed on
a communications device.
When performing tape I/O, some tape drives store tape firmware information in
the first few blocks on a tape, typically using some portion of the first 100
blocks. Applications should not use those blocks. More specific information on
this subject is available from individual tape system manufacturers. In general,
an application that skips the first 100 blocks on a tape will avoid tape drive
idiosyncracies.
The GetTapePosition and SetTapePosition functions retrieve and move the current tape position. The WriteTapemark function writes a specified number of setmarks, filemarks, short filemarks,
and long filemarks. The EraseTape function erases all or part of a tape.
The ReadFile and WriteFile functions read and write file data from and to the tape. The data is read and
written in complete blocks. If the tape's block size is 512 bytes, all read
and write operations must use buffers that are simple integer multiples of that
block size: 512, 1024, 1536, 2048, and so on. Most, if not all, drives only
allow a write operation after the tape is rewound or after a read operation
produces an end-of-data error message.
If ReadFile encounters a filemark, the data up to the filemark is read and the function
fails. (The GetLastError function returns an error code indicating the type of filemark that was
encountered.) To continue reading beyond the filemark, an application must move the
tape past the filemark and call ReadFile again.
ReadFile and WriteFile read and write only the data stream. The BackupRead and BackupWrite functions read and write all the streams associated with a file. These
include data, extended attributes, security, and alternative data streams. The
security and alternate data streams are relevant only on the new technology file
system (NTFS) partition.
The BackupSeek function seeks forward in a file initially accessed by BackupRead or BackupWrite. This function enables an application to skip information that causes access
errors.
If an application needs to access only the file data, it should use ReadFile and WriteFile. These functions can also read alternative data streams if the streams were
created by using the CreateFile function.
A tape-backup application must use BackupRead and BackupWrite to copy all information pertaining to a file. However, these functions do not
read or write file characteristics such as attributes, file creation time, and
so on. Applications must use the file input and output functions, such as GetFileAttributes and SetFileAttributes, to retrieve and set those values.
Related Links
Software for Delphi and C++ Builder developers
Software for Visual Studio .NET developers
Software for Visual Basic 6 developers
Delphi Tips&Tricks
MegaDetailed.NET
More Online Helps
Win32 Multimedia Programmer's Reference (mmedia.hlp)
OLE Programmer's Reference (ole.hlp)
Microsoft Windows Pen API Programmer's Reference (penapi.hlp)
Microsoft Windows Sockets 2 Reference (sock2.hlp)
Microsoft Windows Telephony API (TAPI) Programmer's Reference (tapi.hlp)
Unix Manual Pages
|