* errno.cc (errmap): Map ERROR_BEGINNING_OF_MEDIA and
ERROR_SETMARK_DETECTED to EIO instead of ESPIPE. Handle ERROR_FILEMARK_DETECTED. * fhandler_tape.cc (TAPE_FUNC): Add comment that ERROR_BUS_RESET has still to be handled correctly. (fhandler_dev_tape::open): Accomodate fact that get.mt_dsreg also contains density code. (fhandler_dev_tape::ioctl): Rearrange slightly. Reset devbuf also on MTNOP, MTWSM, MTSETBLK, MTSETDRVBUFFER, MTSETPART and MTMKPART. (fhandler_dev_tape::tape_set_pos): Rearrange. Match behaviour to the Linux tape driver. (fhandler_dev_tape::tape_status): Call IOCTL_STORAGE_GET_MEDIA_TYPES_EX if available. Return device type and density code in appropriate mtget members. * wincap.h (wincaps::has_ioctl_storage_get_media_types_ex): New element. * wincap.cc: Implement above element throughout. * include/cygwin/mtio.h: Add tape device types as returned by IOCTL_STORAGE_GET_MEDIA_TYPES_EX. (MT_TAPE_INFO): Use above type codes. (struct mtget): Change mt_dsreg comment.
This commit is contained in:
parent
83a74ea24a
commit
6644f5097c
@ -1,7 +1,30 @@
|
||||
2004-03-12 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
* errno.cc (errmap): Map ERROR_BEGINNING_OF_MEDIA and
|
||||
ERROR_SETMARK_DETECTED to EIO instead of ESPIPE.
|
||||
Handle ERROR_FILEMARK_DETECTED.
|
||||
* fhandler_tape.cc (TAPE_FUNC): Add comment that ERROR_BUS_RESET
|
||||
has still to be handled correctly.
|
||||
(fhandler_dev_tape::open): Accomodate fact that get.mt_dsreg
|
||||
also contains density code.
|
||||
(fhandler_dev_tape::ioctl): Rearrange slightly. Reset devbuf also on
|
||||
MTNOP, MTWSM, MTSETBLK, MTSETDRVBUFFER, MTSETPART and MTMKPART.
|
||||
(fhandler_dev_tape::tape_set_pos): Rearrange. Match behaviour to
|
||||
the Linux tape driver.
|
||||
(fhandler_dev_tape::tape_status): Call IOCTL_STORAGE_GET_MEDIA_TYPES_EX
|
||||
if available. Return device type and density code in appropriate
|
||||
mtget members.
|
||||
* wincap.h (wincaps::has_ioctl_storage_get_media_types_ex): New element.
|
||||
* wincap.cc: Implement above element throughout.
|
||||
* include/cygwin/mtio.h: Add tape device types as returned by
|
||||
IOCTL_STORAGE_GET_MEDIA_TYPES_EX.
|
||||
(MT_TAPE_INFO): Use above type codes.
|
||||
(struct mtget): Change mt_dsreg comment.
|
||||
|
||||
2004-03-14 Pierre Humblet <pierre.humblet@ieee.org>
|
||||
|
||||
* dir.cc (rmdir): Construct real_dir with flag PC_FULL.
|
||||
Use a loop instead of recursion to handle the current directory.
|
||||
* dir.cc (rmdir): Construct real_dir with flag PC_FULL.
|
||||
Use a loop instead of recursion to handle the current directory.
|
||||
|
||||
2004-03-14 Christopher Faylor <cgf@redhat.com>
|
||||
|
||||
|
@ -102,8 +102,8 @@ static NO_COPY struct
|
||||
X (NOT_OWNER, EPERM),
|
||||
X (END_OF_MEDIA, ENOSPC),
|
||||
X (EOM_OVERFLOW, ENOSPC),
|
||||
X (BEGINNING_OF_MEDIA, ESPIPE),
|
||||
X (SETMARK_DETECTED, ESPIPE),
|
||||
X (BEGINNING_OF_MEDIA, EIO),
|
||||
X (SETMARK_DETECTED, EIO),
|
||||
X (NO_DATA_DETECTED, ENOSPC),
|
||||
X (POSSIBLE_DEADLOCK, EDEADLOCK),
|
||||
X (CRC, EIO),
|
||||
@ -115,6 +115,7 @@ static NO_COPY struct
|
||||
X (INVALID_ADDRESS, EOVERFLOW),
|
||||
X (INVALID_BLOCK_LENGTH, EIO),
|
||||
X (BUS_RESET, EIO),
|
||||
X (FILEMARK_DETECTED, EIO),
|
||||
{ 0, NULL, 0}
|
||||
};
|
||||
|
||||
|
@ -12,7 +12,9 @@ details. */
|
||||
#include "winsup.h"
|
||||
#include <sys/termios.h>
|
||||
#include <unistd.h>
|
||||
#include <stdlib.h>
|
||||
#include <sys/mtio.h>
|
||||
#include <ddk/ntddstor.h>
|
||||
#include "cygerrno.h"
|
||||
#include "perprocess.h"
|
||||
#include "security.h"
|
||||
@ -24,6 +26,10 @@ details. */
|
||||
/* Media changes and bus resets are sometimes reported and the function
|
||||
hasn't been executed. We repeat all functions which return with one
|
||||
of these error codes. */
|
||||
/* FIXME: Note that this is wrong! The correct behaviour after getting
|
||||
an ERROR_BUS_RESET is to raise a flag and then to block any access,
|
||||
except for MTREW, MTOFFL, MT_RETEN, MTERASE, MTSEEK and MTEOM, and
|
||||
to set errno to EIO in all other cases. */
|
||||
#define TAPE_FUNC(func) do { \
|
||||
lasterr = (func); \
|
||||
} while (lasterr == ERROR_MEDIA_CHANGED \
|
||||
@ -127,12 +133,16 @@ fhandler_dev_tape::open (int flags, mode_t)
|
||||
(varlen = sizeof dp, &varlen), &dp));
|
||||
|
||||
if (!ioctl (MTIOCGET, &get))
|
||||
/* Tape drive supports and is set to variable block size. */
|
||||
if (get.mt_dsreg == 0)
|
||||
devbufsiz = get.mt_maxblksize;
|
||||
else
|
||||
devbufsiz = get.mt_dsreg;
|
||||
varblkop = get.mt_dsreg == 0;
|
||||
{
|
||||
long blksize = (get.mt_dsreg & MT_ST_BLKSIZE_MASK)
|
||||
>> MT_ST_BLKSIZE_SHIFT;
|
||||
/* Tape drive supports and is set to variable block size. */
|
||||
if (blksize == 0)
|
||||
devbufsiz = get.mt_maxblksize;
|
||||
else
|
||||
devbufsiz = blksize;
|
||||
varblkop = blksize == 0;
|
||||
}
|
||||
|
||||
if (devbufsiz > 1L)
|
||||
devbuf = new char [devbufsiz];
|
||||
@ -319,9 +329,11 @@ fhandler_dev_tape::ioctl (unsigned int cmd, void *buf)
|
||||
ret = tape_set_pos (TAPE_REWIND, 0);
|
||||
break;
|
||||
case MTOFFL:
|
||||
case MTUNLOAD:
|
||||
ret = tape_prepare (TAPE_UNLOAD);
|
||||
break;
|
||||
case MTNOP:
|
||||
reset_devbuf ();
|
||||
break;
|
||||
case MTRETEN:
|
||||
if (!tape_get_feature (TAPE_DRIVE_END_OF_DATA))
|
||||
@ -350,63 +362,59 @@ fhandler_dev_tape::ioctl (unsigned int cmd, void *buf)
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
case MTSETBLK:
|
||||
{
|
||||
if (!tape_get_feature (TAPE_DRIVE_SET_BLOCK_SIZE))
|
||||
{
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
}
|
||||
if ((devbuf && (size_t) op->mt_count == devbufsiz)
|
||||
|| (!devbuf && op->mt_count == 0))
|
||||
{
|
||||
/* Nothing has changed. */
|
||||
ret = 0;
|
||||
break;
|
||||
}
|
||||
if ((op->mt_count == 0
|
||||
&& !tape_get_feature (TAPE_DRIVE_VARIABLE_BLOCK))
|
||||
|| (op->mt_count > 0
|
||||
&& ((DWORD) op->mt_count < dp.MinimumBlockSize
|
||||
|| (DWORD) op->mt_count > dp.MaximumBlockSize)))
|
||||
{
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
}
|
||||
if (devbuf && devbufend - devbufstart > 0
|
||||
&& (op->mt_count == 0
|
||||
|| (op->mt_count > 0
|
||||
&& (size_t) op->mt_count < devbufend - devbufstart)))
|
||||
{
|
||||
/* Not allowed if still data in devbuf. */
|
||||
ret = ERROR_INVALID_BLOCK_LENGTH; /* EIO */
|
||||
break;
|
||||
}
|
||||
if (!(ret = tape_set_blocksize (op->mt_count)))
|
||||
{
|
||||
char *buf = NULL;
|
||||
if (op->mt_count > 1L && !(buf = new char [op->mt_count]))
|
||||
{
|
||||
ret = ERROR_OUTOFMEMORY;
|
||||
break;
|
||||
}
|
||||
if (devbufsiz > 1L && op->mt_count > 1L)
|
||||
{
|
||||
memcpy (buf, devbuf + devbufstart,
|
||||
devbufend - devbufstart);
|
||||
devbufend -= devbufstart;
|
||||
}
|
||||
else
|
||||
devbufend = 0;
|
||||
devbufstart = 0;
|
||||
delete [] devbuf;
|
||||
devbuf = buf;
|
||||
devbufsiz = op->mt_count;
|
||||
varblkop = op->mt_count == 0;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case MTSETDENSITY:
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
if (!tape_get_feature (TAPE_DRIVE_SET_BLOCK_SIZE))
|
||||
{
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
}
|
||||
if ((devbuf && (size_t) op->mt_count == devbufsiz)
|
||||
|| (!devbuf && op->mt_count == 0))
|
||||
{
|
||||
/* Nothing has changed. */
|
||||
ret = 0;
|
||||
break;
|
||||
}
|
||||
if ((op->mt_count == 0
|
||||
&& !tape_get_feature (TAPE_DRIVE_VARIABLE_BLOCK))
|
||||
|| (op->mt_count > 0
|
||||
&& ((DWORD) op->mt_count < dp.MinimumBlockSize
|
||||
|| (DWORD) op->mt_count > dp.MaximumBlockSize)))
|
||||
{
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
}
|
||||
if (devbuf && devbufend - devbufstart > 0
|
||||
&& (op->mt_count == 0
|
||||
|| (op->mt_count > 0
|
||||
&& (size_t) op->mt_count < devbufend - devbufstart)))
|
||||
{
|
||||
/* Not allowed if still data in devbuf. */
|
||||
ret = ERROR_INVALID_BLOCK_LENGTH; /* EIO */
|
||||
break;
|
||||
}
|
||||
if (!(ret = tape_set_blocksize (op->mt_count)))
|
||||
{
|
||||
char *buf = NULL;
|
||||
if (op->mt_count > 1L && !(buf = new char [op->mt_count]))
|
||||
{
|
||||
ret = ERROR_OUTOFMEMORY;
|
||||
break;
|
||||
}
|
||||
if (devbufsiz > 1L && op->mt_count > 1L)
|
||||
{
|
||||
memcpy (buf, devbuf + devbufstart,
|
||||
devbufend - devbufstart);
|
||||
devbufend -= devbufstart;
|
||||
}
|
||||
else
|
||||
devbufend = 0;
|
||||
devbufstart = 0;
|
||||
delete [] devbuf;
|
||||
devbuf = buf;
|
||||
devbufsiz = op->mt_count;
|
||||
varblkop = op->mt_count == 0;
|
||||
}
|
||||
reset_devbuf ();
|
||||
break;
|
||||
case MTSEEK:
|
||||
if (tape_get_feature (TAPE_DRIVE_ABSOLUTE_BLK)
|
||||
@ -420,9 +428,6 @@ fhandler_dev_tape::ioctl (unsigned int cmd, void *buf)
|
||||
if (!(ret = tape_get_pos (&block)))
|
||||
op->mt_count = block;
|
||||
break;
|
||||
case MTSETDRVBUFFER:
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
case MTFSS:
|
||||
ret = tape_set_pos (TAPE_SPACE_SETMARKS, op->mt_count);
|
||||
break;
|
||||
@ -431,6 +436,7 @@ fhandler_dev_tape::ioctl (unsigned int cmd, void *buf)
|
||||
break;
|
||||
case MTWSM:
|
||||
ret = tape_write_marks (TAPE_SETMARKS, op->mt_count);
|
||||
reset_devbuf ();
|
||||
break;
|
||||
case MTLOCK:
|
||||
ret = tape_prepare (TAPE_LOCK);
|
||||
@ -441,14 +447,14 @@ fhandler_dev_tape::ioctl (unsigned int cmd, void *buf)
|
||||
case MTLOAD:
|
||||
ret = tape_prepare (TAPE_LOAD);
|
||||
break;
|
||||
case MTUNLOAD:
|
||||
ret = tape_prepare (TAPE_UNLOAD);
|
||||
break;
|
||||
case MTCOMPRESSION:
|
||||
ret = tape_compression (op->mt_count);
|
||||
break;
|
||||
case MTSETPART:
|
||||
case MTMKPART:
|
||||
case MTSETDENSITY:
|
||||
case MTSETDRVBUFFER:
|
||||
reset_devbuf ();
|
||||
default:
|
||||
ret = ERROR_INVALID_PARAMETER;
|
||||
break;
|
||||
@ -541,67 +547,29 @@ fhandler_dev_tape::_tape_set_pos (int mode, long count)
|
||||
int
|
||||
fhandler_dev_tape::tape_set_pos (int mode, long count, bool sfm_func)
|
||||
{
|
||||
unsigned long pos, tgtpos;
|
||||
|
||||
switch (mode)
|
||||
{
|
||||
case TAPE_SPACE_RELATIVE_BLOCKS:
|
||||
if (tape_get_pos (&pos))
|
||||
return lasterr;
|
||||
|
||||
tgtpos = pos + count;
|
||||
|
||||
while (count && (_tape_set_pos (mode, count), IS_EOF (lasterr)))
|
||||
{
|
||||
if (tape_get_pos (&pos))
|
||||
return lasterr;
|
||||
count = tgtpos - pos;
|
||||
}
|
||||
|
||||
if (lasterr == ERROR_BEGINNING_OF_MEDIA && !tgtpos)
|
||||
lasterr = NO_ERROR;
|
||||
|
||||
break;
|
||||
case TAPE_SPACE_FILEMARKS:
|
||||
if (count < 0)
|
||||
if (!count)
|
||||
{
|
||||
if (pos > 0)
|
||||
{
|
||||
if (!_tape_set_pos (TAPE_SPACE_RELATIVE_BLOCKS, -1)
|
||||
|| (sfm_func))
|
||||
++count;
|
||||
_tape_set_pos (TAPE_SPACE_RELATIVE_BLOCKS, 1);
|
||||
}
|
||||
|
||||
while (!_tape_set_pos (mode, -1) && count++ < 0)
|
||||
;
|
||||
|
||||
if (lasterr == ERROR_BEGINNING_OF_MEDIA)
|
||||
{
|
||||
if (!count)
|
||||
lasterr = NO_ERROR;
|
||||
}
|
||||
else if (!sfm_func)
|
||||
_tape_set_pos (mode, 1);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (sfm_func)
|
||||
{
|
||||
if (_tape_set_pos (TAPE_SPACE_RELATIVE_BLOCKS, 1)
|
||||
== ERROR_FILEMARK_DETECTED)
|
||||
++count;
|
||||
_tape_set_pos (TAPE_SPACE_RELATIVE_BLOCKS, -1);
|
||||
}
|
||||
|
||||
if (!_tape_set_pos (mode, count) && sfm_func)
|
||||
_tape_set_pos (mode, -1);
|
||||
lasterr = 0;
|
||||
return tape_error ("tape_set_pos");
|
||||
}
|
||||
break;
|
||||
case TAPE_ABSOLUTE_BLOCK:
|
||||
if (!tape_get_feature (TAPE_DRIVE_ABSOLUTE_BLK))
|
||||
if (!tape_get_feature (TAPE_DRIVE_ABSOLUTE_BLK))
|
||||
mode = TAPE_LOGICAL_BLOCK;
|
||||
_tape_set_pos (mode, count);
|
||||
break;
|
||||
}
|
||||
_tape_set_pos (mode, count);
|
||||
switch (mode)
|
||||
{
|
||||
case TAPE_SPACE_FILEMARKS:
|
||||
if (!lasterr && sfm_func)
|
||||
return tape_set_pos (mode, count > 0 ? -1 : 1, false);
|
||||
break;
|
||||
case TAPE_ABSOLUTE_BLOCK:
|
||||
/* Workaround bug in Tandberg SLR device driver, which pretends
|
||||
to support absolute block positioning but instead returns
|
||||
ERROR_INVALID_FUNCTION. */
|
||||
@ -612,13 +580,7 @@ fhandler_dev_tape::tape_set_pos (int mode, long count, bool sfm_func)
|
||||
_tape_set_pos (TAPE_LOGICAL_BLOCK, count);
|
||||
}
|
||||
break;
|
||||
case TAPE_SPACE_SETMARKS:
|
||||
case TAPE_SPACE_END_OF_DATA:
|
||||
case TAPE_REWIND:
|
||||
_tape_set_pos (mode, count);
|
||||
break;
|
||||
}
|
||||
|
||||
return tape_error ("tape_set_pos");
|
||||
}
|
||||
|
||||
@ -693,10 +655,37 @@ fhandler_dev_tape::tape_status (struct mtget *get)
|
||||
}
|
||||
|
||||
if (tape_get_feature (TAPE_DRIVE_SET_BLOCK_SIZE) && !notape)
|
||||
get->mt_dsreg = mp.BlockSize;
|
||||
get->mt_dsreg = (mp.BlockSize << MT_ST_BLKSIZE_SHIFT)
|
||||
& MT_ST_BLKSIZE_MASK;
|
||||
else
|
||||
get->mt_dsreg = dp.DefaultBlockSize;
|
||||
|
||||
get->mt_dsreg = (dp.DefaultBlockSize << MT_ST_BLKSIZE_SHIFT)
|
||||
& MT_ST_BLKSIZE_MASK;
|
||||
if (wincap.has_ioctl_storage_get_media_types_ex ())
|
||||
{
|
||||
DWORD size = sizeof (GET_MEDIA_TYPES) + 10 * sizeof (DEVICE_MEDIA_INFO);
|
||||
void *buf = alloca (size);
|
||||
if (DeviceIoControl (get_handle (), IOCTL_STORAGE_GET_MEDIA_TYPES_EX,
|
||||
NULL, 0, buf, size, &size, NULL)
|
||||
|| GetLastError () == ERROR_MORE_DATA)
|
||||
{
|
||||
PGET_MEDIA_TYPES gmt = (PGET_MEDIA_TYPES) buf;
|
||||
for (DWORD i = 0; i < gmt->MediaInfoCount; ++i)
|
||||
{
|
||||
PDEVICE_MEDIA_INFO dmi = &gmt->MediaInfo[i];
|
||||
#define TINFO DeviceSpecific.TapeInfo
|
||||
if (dmi->TINFO.MediaCharacteristics & MEDIA_CURRENTLY_MOUNTED)
|
||||
{
|
||||
get->mt_type = dmi->DeviceSpecific.TapeInfo.MediaType;
|
||||
if (dmi->TINFO.BusType == BusTypeScsi)
|
||||
get->mt_dsreg |=
|
||||
(dmi->TINFO.BusSpecificData.ScsiInformation.DensityCode
|
||||
<< MT_ST_DENSITY_SHIFT)
|
||||
& MT_ST_DENSITY_MASK;
|
||||
}
|
||||
#undef TINFO
|
||||
}
|
||||
}
|
||||
}
|
||||
if (notape)
|
||||
get->mt_gstat |= GMT_DR_OPEN (-1);
|
||||
|
||||
|
@ -89,8 +89,8 @@ struct mtget {
|
||||
* Cygwin: remaining KB.
|
||||
*/
|
||||
/* the following registers are device dependent */
|
||||
long mt_dsreg; /* status register, Cygwin returns current
|
||||
blocksize here. */
|
||||
long mt_dsreg; /* status register, Contains blocksize and
|
||||
density code. See MT_ST_xxx macros below */
|
||||
long mt_gstat; /* generic (device independent) status */
|
||||
long mt_erreg; /* error register */
|
||||
/* The next two fields are not always used */
|
||||
@ -157,6 +157,8 @@ struct mtpos {
|
||||
/*
|
||||
* Constants for mt_type. Not all of these are supported,
|
||||
* and these are not all of the ones that are supported.
|
||||
*
|
||||
* Only used when not colliding with Windows codes (see below)
|
||||
*/
|
||||
#define MT_ISUNKNOWN 0x01
|
||||
#define MT_ISQIC02 0x02 /* Generic QIC-02 tape streamer */
|
||||
@ -177,6 +179,41 @@ struct mtpos {
|
||||
#define MT_ISSCSI1 0x71 /* Generic ANSI SCSI-1 tape unit */
|
||||
#define MT_ISSCSI2 0x72 /* Generic ANSI SCSI-2 tape unit */
|
||||
|
||||
/* More constants for mt_type. These are the codes used by Windows >= 5.1 */
|
||||
#define MT_ISDDS_4mm 0x20
|
||||
#define MT_ISMiniQic 0x21
|
||||
#define MT_ISTravan 0x22
|
||||
#define MT_ISQIC 0x23
|
||||
#define MT_ISMP_8mm 0x24
|
||||
#define MT_ISAME_8mm 0x25
|
||||
#define MT_ISAIT1_8mm 0x26
|
||||
#define MT_ISDLT 0x27
|
||||
#define MT_ISNCTP 0x28
|
||||
#define MT_ISIBM_3480 0x29
|
||||
#define MT_ISIBM_3490E 0x2a
|
||||
#define MT_ISIBM_Magstar_3590 0x2b
|
||||
#define MT_ISIBM_Magstar_MP 0x2c
|
||||
#define MT_ISSTK_DATA_D3 0x2d
|
||||
#define MT_ISSONY_DTF 0x2e
|
||||
#define MT_ISDV_6mm 0x2f
|
||||
#define MT_ISDMI 0x30
|
||||
#define MT_ISSONY_D2 0x31
|
||||
#define MT_ISCLEANER_CARTRIDGE 0x32
|
||||
#define MT_ISAVATAR_F2 0x4f
|
||||
#define MT_ISMP2_8mm 0x50
|
||||
#define MT_ISDST_S 0x51
|
||||
#define MT_ISDST_M 0x52
|
||||
#define MT_ISDST_L 0x53
|
||||
#define MT_ISVXATape_1 0x54
|
||||
#define MT_ISVXATape_2 0x55
|
||||
#define MT_ISSTK_9840 0x56
|
||||
#define MT_ISLTO_Ultrium 0x57
|
||||
#define MT_ISLTO_Accelis 0x58
|
||||
#define MT_ISAIT_8mm 0x5a
|
||||
#define MT_ISADR_1 0x5b
|
||||
#define MT_ISADR_2 0x5c
|
||||
#define MT_ISSTK_9940 0x5d
|
||||
|
||||
struct mt_tape_info {
|
||||
long t_type; /* device type id (mt_type) */
|
||||
char *t_name; /* descriptive name */
|
||||
@ -196,7 +233,39 @@ struct mt_tape_info {
|
||||
{MT_ISQIC02_ALL_FEATURES, "Generic QIC-02 tape, all features"}, \
|
||||
{MT_ISWT5099EEN24, "Wangtek 5099-een24, 60MB"}, \
|
||||
{MT_ISTEAC_MT2ST, "Teac MT-2ST 155mb data cassette drive"}, \
|
||||
{MT_ISEVEREX_FT40A, "Everex FT40A, QIC-40"}, \
|
||||
{MT_ISDDS_4mm, "DDS"}, \
|
||||
{MT_ISMiniQic, "MiniQic"}, \
|
||||
{MT_ISTravan, "Travan tape"}, \
|
||||
{MT_ISQIC, "QIC tape"}, \
|
||||
{MT_ISMP_8mm, "8mm Exabyte metal particle tape"}, \
|
||||
{MT_ISAME_8mm, "8mm Exabyte advanced metal evap tape"}, \
|
||||
{MT_ISAIT1_8mm, "8mm Sony AIT1 tape"}, \
|
||||
{MT_ISDLT, "DLT compact tape)"}, \
|
||||
{MT_ISNCTP, "Philips NCTP tape"}, \
|
||||
{MT_ISIBM_3480, "IBM 3480 tape"}, \
|
||||
{MT_ISIBM_3490E, "IBM 3490E tape"}, \
|
||||
{MT_ISIBM_Magstar_3590, "IBM Magstar 3590 tape"}, \
|
||||
{MT_ISIBM_Magstar_MP, "IBM Magstar MP tape"}, \
|
||||
{MT_ISSTK_DATA_D3, "STK data D3 tape"}, \
|
||||
{MT_ISSONY_DTF, "Sony DTF tape"}, \
|
||||
{MT_ISDV_6mm, "6mm digital video tape"}, \
|
||||
{MT_ISDMI, "Exabyte DMI tape"}, \
|
||||
{MT_ISSONY_D2, "Sony D2S or D2L tape"}, \
|
||||
{MT_ISCLEANER_CARTRIDGE, "Cleaner (all drive types that support cleaners)"}, \
|
||||
{MT_ISAVATAR_F2, "Avatar 2"}, \
|
||||
{MT_ISMP2_8mm, "8mm Hitachi tape"}, \
|
||||
{MT_ISDST_S, "Ampex DST small tape"}, \
|
||||
{MT_ISDST_M, "Ampex DST medium tape"}, \
|
||||
{MT_ISDST_L, "Ampex DST large tape"}, \
|
||||
{MT_ISVXATape_1, "Ecrix 8mm tape"}, \
|
||||
{MT_ISVXATape_2, "Ecrix 8mm tape"}, \
|
||||
{MT_ISSTK_9840, "STK 9840"}, \
|
||||
{MT_ISLTO_Ultrium, "LTO Ultrium (IBM, HP, Seagate)"}, \
|
||||
{MT_ISLTO_Accelis, "LTO Accelis (IBM, HP, Seagate)"}, \
|
||||
{MT_ISAIT_8mm, "AIT tape (AIT2 or higher)"}, \
|
||||
{MT_ISADR_1, "OnStream ADR1"}, \
|
||||
{MT_ISADR_2, "OnStream ADR2"}, \
|
||||
{MT_ISSTK_9940, "STK 9940"}, \
|
||||
{MT_ISSCSI1, "Generic SCSI-1 tape"}, \
|
||||
{MT_ISSCSI2, "Generic SCSI-2 tape"}, \
|
||||
{0, NULL} \
|
||||
|
@ -52,7 +52,8 @@ static NO_COPY wincaps wincap_unknown = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_95 = {
|
||||
@ -96,7 +97,8 @@ static NO_COPY wincaps wincap_95 = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:true
|
||||
cant_debug_dll_entry:true,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_95osr2 = {
|
||||
@ -140,7 +142,8 @@ static NO_COPY wincaps wincap_95osr2 = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:true
|
||||
cant_debug_dll_entry:true,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_98 = {
|
||||
@ -184,7 +187,8 @@ static NO_COPY wincaps wincap_98 = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:true
|
||||
cant_debug_dll_entry:true,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_98se = {
|
||||
@ -228,7 +232,8 @@ static NO_COPY wincaps wincap_98se = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:true
|
||||
cant_debug_dll_entry:true,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_me = {
|
||||
@ -272,7 +277,8 @@ static NO_COPY wincaps wincap_me = {
|
||||
pty_needs_alloc_console:false,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:true
|
||||
cant_debug_dll_entry:true,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_nt3 = {
|
||||
@ -316,7 +322,8 @@ static NO_COPY wincaps wincap_nt3 = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:false,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_nt4 = {
|
||||
@ -360,7 +367,8 @@ static NO_COPY wincaps wincap_nt4 = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:true,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_nt4sp4 = {
|
||||
@ -404,7 +412,8 @@ static NO_COPY wincaps wincap_nt4sp4 = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:false,
|
||||
has_switch_to_thread:true,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_2000 = {
|
||||
@ -448,7 +457,8 @@ static NO_COPY wincaps wincap_2000 = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:true,
|
||||
has_switch_to_thread:true,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:false
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_xp = {
|
||||
@ -492,7 +502,8 @@ static NO_COPY wincaps wincap_xp = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:true,
|
||||
has_switch_to_thread:true,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:true
|
||||
};
|
||||
|
||||
static NO_COPY wincaps wincap_2003 = {
|
||||
@ -536,7 +547,8 @@ static NO_COPY wincaps wincap_2003 = {
|
||||
pty_needs_alloc_console:true,
|
||||
has_terminal_services:true,
|
||||
has_switch_to_thread:true,
|
||||
cant_debug_dll_entry:false
|
||||
cant_debug_dll_entry:false,
|
||||
has_ioctl_storage_get_media_types_ex:true
|
||||
};
|
||||
|
||||
wincapc wincap;
|
||||
|
@ -54,6 +54,7 @@ struct wincaps
|
||||
unsigned has_terminal_services : 1;
|
||||
unsigned has_switch_to_thread : 1;
|
||||
unsigned cant_debug_dll_entry : 1;
|
||||
unsigned has_ioctl_storage_get_media_types_ex : 1;
|
||||
};
|
||||
|
||||
class wincapc
|
||||
@ -112,6 +113,7 @@ public:
|
||||
bool IMPLEMENT (has_terminal_services)
|
||||
bool IMPLEMENT (has_switch_to_thread)
|
||||
bool IMPLEMENT (cant_debug_dll_entry)
|
||||
bool IMPLEMENT (has_ioctl_storage_get_media_types_ex)
|
||||
|
||||
#undef IMPLEMENT
|
||||
};
|
||||
|
Loading…
x
Reference in New Issue
Block a user