mirror of
https://github.com/reactos/reactos.git
synced 2025-01-03 21:09:19 +00:00
1827 lines
64 KiB
C
1827 lines
64 KiB
C
////////////////////////////////////////////////////////////////////
|
|
// Copyright (C) Alexander Telyatnikov, Ivan Keliukh, Yegor Anchishkin, SKIF Software, 1999-2013. Kiev, Ukraine
|
|
// All rights reserved
|
|
// This file was released under the GPLv2 on June 2015.
|
|
////////////////////////////////////////////////////////////////////
|
|
/*
|
|
|
|
Module Name:
|
|
|
|
cdrw_usr.h
|
|
|
|
Abstract:
|
|
|
|
This file defines the interface between CD-Writer's driver & user
|
|
applications.
|
|
|
|
Environment:
|
|
|
|
NT kernel mode or Win32 app
|
|
*/
|
|
|
|
#ifndef __CDRW_PUBLIC_H__
|
|
#define __CDRW_PUBLIC_H__
|
|
|
|
#define CDRW_SIGNATURE_v1 "ALWA CD-R/W v1"
|
|
|
|
//#define CDRW_RESTRICT_ACCESS // require W-acces rights for some IOCTLs
|
|
|
|
#include "cdrw_hw.h"
|
|
//#include "ntdddisk.h"
|
|
|
|
#include <ntddcdrm.h>
|
|
#include <ntddcdvd.h>
|
|
|
|
#ifndef CTL_CODE
|
|
#pragma pack(push, 8)
|
|
#include "winioctl.h"
|
|
#pragma pack(pop)
|
|
#endif
|
|
|
|
#if defined(CDRW_EXPORTS) || defined(FileSys_EXPORTS)
|
|
#include "mountmgr.h"
|
|
#endif
|
|
|
|
#ifndef FILE_DEVICE_SECURE_OPEN
|
|
#define FILE_DEVICE_SECURE_OPEN 0x00000100
|
|
#endif //FILE_DEVICE_SECURE_OPEN
|
|
|
|
#pragma pack(push, 1)
|
|
|
|
#ifndef IRP_MJ_PNP
|
|
#define IRP_MJ_PNP IRP_MJ_PNP_POWER // Obsolete....
|
|
#endif //IRP_MJ_PNP
|
|
|
|
#ifndef FILE_DEVICE_CDRW
|
|
#define FILE_DEVICE_CDRW 0x00000999
|
|
#endif
|
|
|
|
#define IOCTL_CDROM_MEDIA_REMOVAL CTL_CODE(IOCTL_CDROM_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_CDROM_EJECT_MEDIA CTL_CODE(IOCTL_CDROM_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_CDROM_LOAD_MEDIA CTL_CODE(IOCTL_CDROM_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
|
|
#ifdef CDRW_RESTRICT_ACCESS
|
|
|
|
#define CDRW_CTL_CODE_R(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA)
|
|
#define CDRW_CTL_CODE_W(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA)
|
|
#define CDRW_CTL_CODE_W(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_WRITE_DATA )
|
|
#define CDRW_CTL_CODE_A(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA | FILE_WRITE_DATA )
|
|
|
|
#else //CDRW_RESTRICT_ACCESS
|
|
|
|
#define CDRW_CTL_CODE_R(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA)
|
|
#define CDRW_CTL_CODE_W(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA)
|
|
#define CDRW_CTL_CODE_A(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_READ_DATA)
|
|
#define CDRW_CTL_CODE_X(a,b) CTL_CODE(FILE_DEVICE_CDRW, a,b, FILE_ANY_ACCESS )
|
|
|
|
#endif //CDRW_RESTRICT_ACCESS
|
|
|
|
#define IOCTL_CDRW_LOCK_DOOR CDRW_CTL_CODE_R(0x801, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_SPEED CDRW_CTL_CODE_R(0x802, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SYNC_CACHE CDRW_CTL_CODE_W(0x803, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_CAPABILITIES CDRW_CTL_CODE_X(0x804, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_SPEED IOCTL_CDRW_GET_CAPABILITIES
|
|
#define IOCTL_CDRW_GET_MEDIA_TYPE CDRW_CTL_CODE_X(0x805, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_WRITE_MODE CDRW_CTL_CODE_R(0x806, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_WRITE_MODE CDRW_CTL_CODE_W(0x807, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_RESERVE_TRACK CDRW_CTL_CODE_W(0x808, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_BLANK CDRW_CTL_CODE_R(0x809, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_CLOSE_TRK_SES CDRW_CTL_CODE_W(0x80a, METHOD_BUFFERED)
|
|
//#define IOCTL_CDRW_LL_WRITE CDRW_CTL_CODE_R(0x80b, METHOD_OUT_DIRECT)
|
|
#define IOCTL_CDRW_LL_WRITE CDRW_CTL_CODE_R(0x80b, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_TRACK_INFO CDRW_CTL_CODE_R(0x80c, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_READ_DISC_INFO CDRW_CTL_CODE_R(0x80d, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_BUFFER_CAPACITY CDRW_CTL_CODE_A(0x80e, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_GET_SIGNATURE CDRW_CTL_CODE_X(0x80f, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_RESET_DRIVER CDRW_CTL_CODE_A(0x810, METHOD_BUFFERED)
|
|
//#ifndef WITHOUT_FORMATTER
|
|
#define IOCTL_CDRW_FORMAT_UNIT CDRW_CTL_CODE_W(0x811, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_RANDOM_ACCESS CDRW_CTL_CODE_W(0x812, METHOD_BUFFERED)
|
|
//#endif //WITHOUT_FORMATTER
|
|
#define IOCTL_CDRW_TEST_UNIT_READY CDRW_CTL_CODE_X(0x813, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_RESET_WRITE_STATUS CDRW_CTL_CODE_X(0x814, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_LAST_ERROR CDRW_CTL_CODE_R(0x815, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_MODE_SENSE CDRW_CTL_CODE_X(0x816, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_MODE_SELECT CDRW_CTL_CODE_R(0x817, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_READ_AHEAD CDRW_CTL_CODE_R(0x818, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_DEFAULT_SESSION CDRW_CTL_CODE_R(0x819, METHOD_BUFFERED) // RESERVED !!!
|
|
#define IOCTL_CDRW_NOTIFY_MEDIA_CHANGE CDRW_CTL_CODE_X(0x81a, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SEND_OPC_INFO CDRW_CTL_CODE_W(0x81b, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_LL_READ CDRW_CTL_CODE_R(0x81c, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SEND_CUE_SHEET CDRW_CTL_CODE_W(0x81d, METHOD_OUT_DIRECT)
|
|
#define IOCTL_CDRW_INIT_DEINIT CDRW_CTL_CODE_A(0x81e, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_FULL_TOC CDRW_CTL_CODE_R(0x81f, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_PMA CDRW_CTL_CODE_R(0x820, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_SESSION_INFO CDRW_CTL_CODE_R(0x821, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_ATIP CDRW_CTL_CODE_R(0x822, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_CD_TEXT CDRW_CTL_CODE_R(0x823, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_READ_TOC_EX CDRW_CTL_CODE_R(0x824, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_DEVICE_INFO CDRW_CTL_CODE_R(0x825, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_EVENT CDRW_CTL_CODE_R(0x826, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_GET_DEVICE_NAME CDRW_CTL_CODE_R(0x827, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_RESET_DRIVER_EX CDRW_CTL_CODE_A(0x828, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_GET_MEDIA_TYPE_EX CDRW_CTL_CODE_X(0x829, METHOD_BUFFERED)
|
|
#ifndef WITHOUT_FORMATTER
|
|
#define IOCTL_CDRW_GET_MRW_MODE CDRW_CTL_CODE_X(0x82a, METHOD_BUFFERED)
|
|
#define IOCTL_CDRW_SET_MRW_MODE CDRW_CTL_CODE_X(0x82b, METHOD_BUFFERED)
|
|
#endif //WITHOUT_FORMATTER
|
|
#define IOCTL_CDRW_READ_CAPACITY CDRW_CTL_CODE_R(0x82c, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_GET_DISC_LAYOUT CDRW_CTL_CODE_R(0x82d, METHOD_IN_DIRECT)
|
|
#define IOCTL_CDRW_SET_STREAMING CDRW_CTL_CODE_W(0x82e, METHOD_BUFFERED)
|
|
|
|
#define IOCTL_CDRW_UNLOAD_DRIVER IOCTL_CDROM_UNLOAD_DRIVER
|
|
|
|
#define IOCTL_CDRW_READ_TOC IOCTL_CDROM_READ_TOC
|
|
#define IOCTL_CDRW_GET_CONTROL IOCTL_CDROM_GET_CONTROL
|
|
#define IOCTL_CDRW_PLAY_AUDIO_MSF IOCTL_CDROM_PLAY_AUDIO_MSF
|
|
#define IOCTL_CDRW_SEEK_AUDIO_MSF IOCTL_CDROM_SEEK_AUDIO_MSF
|
|
#define IOCTL_CDRW_STOP_AUDIO IOCTL_CDROM_STOP_AUDIO
|
|
#define IOCTL_CDRW_PAUSE_AUDIO IOCTL_CDROM_PAUSE_AUDIO
|
|
#define IOCTL_CDRW_RESUME_AUDIO IOCTL_CDROM_RESUME_AUDIO
|
|
#define IOCTL_CDRW_GET_VOLUME IOCTL_CDROM_GET_VOLUME
|
|
#define IOCTL_CDRW_SET_VOLUME IOCTL_CDROM_SET_VOLUME
|
|
#define IOCTL_CDRW_READ_Q_CHANNEL IOCTL_CDROM_READ_Q_CHANNEL
|
|
#define IOCTL_CDRW_GET_LAST_SESSION IOCTL_CDROM_GET_LAST_SESSION
|
|
#define IOCTL_CDRW_RAW_READ IOCTL_CDROM_RAW_READ
|
|
#define IOCTL_CDRW_DISK_TYPE IOCTL_CDROM_DISK_TYPE
|
|
|
|
#define IOCTL_CDRW_CHECK_VERIFY IOCTL_CDROM_CHECK_VERIFY
|
|
#define IOCTL_CDRW_MEDIA_REMOVAL IOCTL_CDROM_MEDIA_REMOVAL
|
|
#define IOCTL_CDRW_EJECT_MEDIA IOCTL_CDROM_EJECT_MEDIA
|
|
#define IOCTL_CDRW_LOAD_MEDIA IOCTL_CDROM_LOAD_MEDIA
|
|
#define IOCTL_CDRW_RESERVE IOCTL_CDROM_RESERVE
|
|
#define IOCTL_CDRW_RELEASE IOCTL_CDROM_RELEASE
|
|
#define IOCTL_CDRW_FIND_NEW_DEVICES IOCTL_CDROM_FIND_NEW_DEVICES
|
|
|
|
#ifndef IOCTL_DVD_READ_STRUCTURE
|
|
#define IOCTL_DVD_READ_STRUCTURE CTL_CODE(IOCTL_DVD_BASE, 0x0450, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
|
|
#define IOCTL_DVD_START_SESSION CTL_CODE(IOCTL_DVD_BASE, 0x0400, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_READ_KEY CTL_CODE(IOCTL_DVD_BASE, 0x0401, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_SEND_KEY CTL_CODE(IOCTL_DVD_BASE, 0x0402, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_END_SESSION CTL_CODE(IOCTL_DVD_BASE, 0x0403, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_SET_READ_AHEAD CTL_CODE(IOCTL_DVD_BASE, 0x0404, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_GET_REGION CTL_CODE(IOCTL_DVD_BASE, 0x0405, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DVD_SEND_KEY2 CTL_CODE(IOCTL_DVD_BASE, 0x0406, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
|
|
#endif //IOCTL_DVD_READ_STRUCTURE
|
|
|
|
#ifndef IOCTL_DISK_GET_DRIVE_GEOMETRY
|
|
#define IOCTL_DISK_GET_DRIVE_GEOMETRY CTL_CODE(IOCTL_DISK_BASE, 0x0000, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define IOCTL_DISK_VERIFY CTL_CODE(IOCTL_DISK_BASE, 0x0005, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define IOCTL_DISK_FORMAT_TRACKS CTL_CODE(IOCTL_DISK_BASE, 0x0006, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
|
|
#define IOCTL_DISK_IS_WRITABLE CTL_CODE(IOCTL_DISK_BASE, 0x0009, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#define IOCTL_DISK_FORMAT_TRACKS_EX CTL_CODE(IOCTL_DISK_BASE, 0x000b, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
|
|
|
|
#define IOCTL_DISK_CHECK_VERIFY CTL_CODE(IOCTL_DISK_BASE, 0x0200, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_MEDIA_REMOVAL CTL_CODE(IOCTL_DISK_BASE, 0x0201, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_EJECT_MEDIA CTL_CODE(IOCTL_DISK_BASE, 0x0202, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_LOAD_MEDIA CTL_CODE(IOCTL_DISK_BASE, 0x0203, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_RESERVE CTL_CODE(IOCTL_DISK_BASE, 0x0204, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_RELEASE CTL_CODE(IOCTL_DISK_BASE, 0x0205, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_FIND_NEW_DEVICES CTL_CODE(IOCTL_DISK_BASE, 0x0206, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#define IOCTL_DISK_GET_MEDIA_TYPES CTL_CODE(IOCTL_DISK_BASE, 0x0300, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
#endif //IOCTL_DISK_GET_DRIVE_GEOMETRY
|
|
|
|
#ifndef IOCTL_STORAGE_SET_READ_AHEAD
|
|
#define IOCTL_STORAGE_SET_READ_AHEAD CTL_CODE(IOCTL_STORAGE_BASE, 0x0100, METHOD_BUFFERED, FILE_READ_ACCESS)
|
|
#endif //IOCTL_STORAGE_SET_READ_AHEAD
|
|
|
|
#ifndef IOCTL_STORAGE_GET_MEDIA_TYPES_EX
|
|
#define IOCTL_STORAGE_GET_MEDIA_TYPES_EX CTL_CODE(IOCTL_STORAGE_BASE, 0x0301, METHOD_BUFFERED, FILE_ANY_ACCESS)
|
|
|
|
typedef enum _STORAGE_MEDIA_TYPE {
|
|
//
|
|
// Following are defined in ntdddisk.h in the MEDIA_TYPE enum
|
|
//
|
|
// Unknown, // Format is unknown
|
|
// F5_1Pt2_512, // 5.25", 1.2MB, 512 bytes/sector
|
|
// F3_1Pt44_512, // 3.5", 1.44MB, 512 bytes/sector
|
|
// F3_2Pt88_512, // 3.5", 2.88MB, 512 bytes/sector
|
|
// F3_20Pt8_512, // 3.5", 20.8MB, 512 bytes/sector
|
|
// F3_720_512, // 3.5", 720KB, 512 bytes/sector
|
|
// F5_360_512, // 5.25", 360KB, 512 bytes/sector
|
|
// F5_320_512, // 5.25", 320KB, 512 bytes/sector
|
|
// F5_320_1024, // 5.25", 320KB, 1024 bytes/sector
|
|
// F5_180_512, // 5.25", 180KB, 512 bytes/sector
|
|
// F5_160_512, // 5.25", 160KB, 512 bytes/sector
|
|
// RemovableMedia, // Removable media other than floppy
|
|
// FixedMedia, // Fixed hard disk media
|
|
// F3_120M_512, // 3.5", 120M Floppy
|
|
// F3_640_512, // 3.5" , 640KB, 512 bytes/sector
|
|
// F5_640_512, // 5.25", 640KB, 512 bytes/sector
|
|
// F5_720_512, // 5.25", 720KB, 512 bytes/sector
|
|
// F3_1Pt2_512, // 3.5" , 1.2Mb, 512 bytes/sector
|
|
// F3_1Pt23_1024, // 3.5" , 1.23Mb, 1024 bytes/sector
|
|
// F5_1Pt23_1024, // 5.25", 1.23MB, 1024 bytes/sector
|
|
// F3_128Mb_512, // 3.5" MO 128Mb 512 bytes/sector
|
|
// F3_230Mb_512, // 3.5" MO 230Mb 512 bytes/sector
|
|
// F8_256_128, // 8", 256KB, 128 bytes/sector
|
|
//
|
|
|
|
DDS_4mm = 0x20, // Tape - DAT DDS1,2,... (all vendors)
|
|
MiniQic, // Tape - miniQIC Tape
|
|
Travan, // Tape - Travan TR-1,2,3,...
|
|
QIC, // Tape - QIC
|
|
MP_8mm, // Tape - 8mm Exabyte Metal Particle
|
|
AME_8mm, // Tape - 8mm Exabyte Advanced Metal Evap
|
|
AIT1_8mm, // Tape - 8mm Sony AIT1
|
|
DLT, // Tape - DLT Compact IIIxt, IV
|
|
NCTP, // Tape - Philips NCTP
|
|
IBM_3480, // Tape - IBM 3480
|
|
IBM_3490E, // Tape - IBM 3490E
|
|
IBM_Magstar_3590, // Tape - IBM Magstar 3590
|
|
IBM_Magstar_MP, // Tape - IBM Magstar MP
|
|
STK_DATA_D3, // Tape - STK Data D3
|
|
SONY_DTF, // Tape - Sony DTF
|
|
DV_6mm, // Tape - 6mm Digital Video
|
|
DMI, // Tape - Exabyte DMI and compatibles
|
|
SONY_D2, // Tape - Sony D2S and D2L
|
|
CLEANER_CARTRIDGE, // Cleaner - All Drive types that support Drive Cleaners
|
|
CD_ROM, // Opt_Disk - CD
|
|
CD_R, // Opt_Disk - CD-Recordable (Write Once)
|
|
CD_RW, // Opt_Disk - CD-Rewriteable
|
|
DVD_ROM, // Opt_Disk - DVD-ROM
|
|
DVD_R, // Opt_Disk - DVD-Recordable (Write Once)
|
|
DVD_RW, // Opt_Disk - DVD-Rewriteable
|
|
MO_3_RW, // Opt_Disk - 3.5" Rewriteable MO Disk
|
|
MO_5_WO, // Opt_Disk - MO 5.25" Write Once
|
|
MO_5_RW, // Opt_Disk - MO 5.25" Rewriteable (not LIMDOW)
|
|
MO_5_LIMDOW, // Opt_Disk - MO 5.25" Rewriteable (LIMDOW)
|
|
PC_5_WO, // Opt_Disk - Phase Change 5.25" Write Once Optical
|
|
PC_5_RW, // Opt_Disk - Phase Change 5.25" Rewriteable
|
|
PD_5_RW, // Opt_Disk - PhaseChange Dual Rewriteable
|
|
ABL_5_WO, // Opt_Disk - Ablative 5.25" Write Once Optical
|
|
PINNACLE_APEX_5_RW, // Opt_Disk - Pinnacle Apex 4.6GB Rewriteable Optical
|
|
SONY_12_WO, // Opt_Disk - Sony 12" Write Once
|
|
PHILIPS_12_WO, // Opt_Disk - Philips/LMS 12" Write Once
|
|
HITACHI_12_WO, // Opt_Disk - Hitachi 12" Write Once
|
|
CYGNET_12_WO, // Opt_Disk - Cygnet/ATG 12" Write Once
|
|
KODAK_14_WO, // Opt_Disk - Kodak 14" Write Once
|
|
MO_NFR_525, // Opt_Disk - Near Field Recording (Terastor)
|
|
NIKON_12_RW, // Opt_Disk - Nikon 12" Rewriteable
|
|
IOMEGA_ZIP, // Mag_Disk - Iomega Zip
|
|
IOMEGA_JAZ, // Mag_Disk - Iomega Jaz
|
|
SYQUEST_EZ135, // Mag_Disk - Syquest EZ135
|
|
SYQUEST_EZFLYER, // Mag_Disk - Syquest EzFlyer
|
|
SYQUEST_SYJET, // Mag_Disk - Syquest SyJet
|
|
AVATAR_F2, // Mag_Disk - 2.5" Floppy
|
|
MP2_8mm, // Tape - 8mm Hitachi
|
|
DST_S, // Ampex DST Small Tapes
|
|
DST_M, // Ampex DST Medium Tapes
|
|
DST_L, // Ampex DST Large Tapes
|
|
VXATape_1, // Ecrix 8mm Tape
|
|
VXATape_2, // Ecrix 8mm Tape
|
|
STK_EAGLE, // STK Eagle
|
|
LTO_Ultrium, // IBM, HP, Seagate LTO Ultrium
|
|
LTO_Accelis // IBM, HP, Seagate LTO Accelis
|
|
} STORAGE_MEDIA_TYPE, *PSTORAGE_MEDIA_TYPE;
|
|
|
|
#endif //IOCTL_STORAGE_GET_MEDIA_TYPES_EX
|
|
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SET_CD_SPEED_USER_IN {
|
|
ULONG ReadSpeed; // Kbyte/sec 176 = 1X
|
|
ULONG WriteSpeed; // Kbyte/sec
|
|
} SET_CD_SPEED_USER_IN, *PSET_CD_SPEED_USER_IN;
|
|
|
|
typedef struct _SET_CD_SPEED_EX_USER_IN {
|
|
ULONG ReadSpeed; // Kbyte/sec 176 = 1X
|
|
ULONG WriteSpeed; // Kbyte/sec
|
|
UCHAR RotCtrl;
|
|
UCHAR Reserved[3];
|
|
} SET_CD_SPEED_EX_USER_IN, *PSET_CD_SPEED_EX_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SET_STREAMING_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR RA : 1; // Random Access
|
|
UCHAR Exact : 1;
|
|
UCHAR RDD : 1; // Restore Defaults
|
|
UCHAR WRC : 2;
|
|
UCHAR Reserved0 : 3;
|
|
} Fields;
|
|
} Options;
|
|
|
|
UCHAR Reserved1[3];
|
|
|
|
ULONG StartLBA;
|
|
ULONG EndLBA;
|
|
|
|
ULONG ReadSize; // KBytes
|
|
ULONG ReadTime; // ms
|
|
|
|
ULONG WriteSize; // KBytes
|
|
ULONG WriteTime; // ms
|
|
} SET_STREAMING_USER_IN, *PSET_STREAMING_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef SyncCache_RELADR
|
|
#define SyncCache_RELADR 0x01
|
|
#define SyncCache_Immed 0x02
|
|
#endif //SyncCache_RELADR
|
|
*/
|
|
|
|
typedef struct _SYNC_CACHE_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR RELADR : 1;
|
|
UCHAR Immed : 1;
|
|
UCHAR Reserved0 : 6;
|
|
} Fields;
|
|
} Byte1;
|
|
ULONG LBA;
|
|
USHORT NumOfBlocks;
|
|
} SYNC_CACHE_USER_IN, *PSYNC_CACHE_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _BUFFER_CAPACITY_BLOCK_USER_OUT {
|
|
UCHAR Reserved0[4];
|
|
ULONG BufferLength;
|
|
ULONG BlankBufferLength;
|
|
ULONG WriteStatus;
|
|
BOOLEAN LostStreaming;
|
|
ULONG MaximumPhysicalPages;
|
|
ULONG MaximumTransferLength;
|
|
ULONG ActualMaximumTransferLength;
|
|
} BUFFER_CAPACITY_BLOCK_USER_OUT, *PBUFFER_CAPACITY_BLOCK_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _TRACK_INFO_BLOCK_USER_OUT {
|
|
USHORT DataLength;
|
|
UCHAR _TrackNum;
|
|
UCHAR _SesNum;
|
|
UCHAR Reserved0;
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR TrackMode : 4;
|
|
UCHAR Copy : 1;
|
|
UCHAR Damage : 1;
|
|
UCHAR Reserved1 : 2;
|
|
} Fields;
|
|
} TrackParam;
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR DataMode : 4;
|
|
UCHAR FP : 1;
|
|
UCHAR Packet : 1;
|
|
UCHAR Blank : 1;
|
|
UCHAR RT : 1;
|
|
} Fields;
|
|
} DataParam;
|
|
|
|
UCHAR NWA_V;
|
|
ULONG TrackStartLBA;
|
|
ULONG NextWriteLBA;
|
|
ULONG FreeBlocks;
|
|
ULONG FixPacketSize;
|
|
ULONG TrackLength;
|
|
|
|
// MMC-3
|
|
|
|
ULONG LastRecordedAddr;
|
|
UCHAR _TrackNum2; // MSB
|
|
UCHAR _SesNum2; // MSB
|
|
UCHAR Reserved2[2];
|
|
|
|
// MMC-5
|
|
|
|
ULONG ReadCompatLBA;
|
|
|
|
// Additional
|
|
|
|
UCHAR TrackStartMSF[3];
|
|
UCHAR NextWriteMSF[3];
|
|
ULONG TrackNum;
|
|
ULONG SesNum;
|
|
|
|
} TRACK_INFO_BLOCK_USER_OUT, *PTRACK_INFO_BLOCK_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _TRACK_INFO_BLOCK_USER_IN {
|
|
BOOLEAN Track;
|
|
ULONG LBA_TrkNum;
|
|
} TRACK_INFO_BLOCK_USER_IN, *PTRACK_INFO_BLOCK_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef READ_CAPACITY_DATA READ_CAPACITY_USER_OUT;
|
|
typedef PREAD_CAPACITY_DATA PREAD_CAPACITY_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _GET_SIGNATURE_USER_OUT {
|
|
ULONG MagicDword;
|
|
USHORT VersiomMajor ;
|
|
USHORT VersiomMinor ;
|
|
USHORT VersiomId ; // alfa/beta/...
|
|
USHORT Reserved;
|
|
UCHAR VendorId[32];
|
|
} GET_SIGNATURE_USER_OUT, *PGET_SIGNATURE_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef BlankMedia_Mask
|
|
#define BlankMedia_Mask 0x07
|
|
#define BlankMedia_Complete 0x00
|
|
#define BlankMedia_Minimal 0x01
|
|
#define BlankMedia_Track 0x02
|
|
#define BlankMedia_UnreserveTrack 0x03
|
|
#define BlankMedia_TrackTail 0x04
|
|
#define BlankMedia_UncloseLastSes 0x05
|
|
#define BlankMedia_EraseSes 0x06
|
|
#define BlankMedia_Immed 0x10
|
|
#endif //BlankMedia_Mask
|
|
*/
|
|
|
|
typedef struct _BLANK_MEDIA_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
ULONG Reserved;
|
|
struct {
|
|
UCHAR BlankType : 3;
|
|
UCHAR Reserved0 : 1;
|
|
UCHAR Immed : 1;
|
|
UCHAR Reserved1 : 3;
|
|
} Fields;
|
|
} Byte1;
|
|
ULONG StartAddr_TrkNum;
|
|
} BLANK_MEDIA_USER_IN, *PBLANK_MEDIA_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _RESERVE_TRACK_USER_IN {
|
|
ULONG Size;
|
|
} RESERVE_TRACK_USER_IN, *PRESERVE_TRACK_USER_IN;
|
|
|
|
#define RESERVE_TRACK_EX_SIZE 0x0
|
|
#define RESERVE_TRACK_EX_START_LBA 0x1
|
|
#define RESERVE_TRACK_EX_RMZ 0x2
|
|
|
|
typedef struct _RESERVE_TRACK_EX_USER_IN {
|
|
ULONG Flags;
|
|
union {
|
|
ULONG Size;
|
|
ULONG StartLBA;
|
|
};
|
|
} RESERVE_TRACK_EX_USER_IN, *PRESERVE_TRACK_EX_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _LL_WRITE_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
ULONG Reserved;
|
|
struct {
|
|
UCHAR RELADR : 1;
|
|
UCHAR Reserved0 : 2;
|
|
UCHAR FUA : 1;
|
|
UCHAR DPO : 1;
|
|
UCHAR Reserved1 : 3;
|
|
} Fields;
|
|
} Flags;
|
|
ULONG LBA;
|
|
USHORT NumOfBlocks;
|
|
UCHAR Reserved1[2];
|
|
} LL_WRITE_USER_IN, *PLL_WRITE_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
//#ifndef WITHOUT_FORMATTER
|
|
|
|
/*
|
|
#ifndef FormatDesc_Grow
|
|
#define FormatDesc_Grow 0x40
|
|
#define FormatDesc_Ses 0x80
|
|
#endif
|
|
*/
|
|
|
|
#define FORMAT_UNIT_FORCE_STD_MODE 0x80000000
|
|
#define FORMAT_UNIT_FORCE_FULL_FMT 0x40000000
|
|
#define FORMAT_UNIT_RESTART_MRW 0x01000000
|
|
|
|
typedef struct _FORMAT_CDRW_PARAMETERS_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
ULONG FlagsEx;
|
|
struct {
|
|
UCHAR Reserved0: 6;
|
|
UCHAR Grow: 1;
|
|
UCHAR Ses: 1;
|
|
} Fields;
|
|
} Flags;
|
|
LONG BlockCount;
|
|
} FORMAT_CDRW_PARAMETERS_USER_IN, *PFORMAT_CDRW_PARAMETERS_USER_IN;
|
|
|
|
//#endif //WITHOUT_FORMATTER
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef CloseTrkSes_Immed
|
|
#define CloseTrkSes_Immed 0x01
|
|
|
|
#define CloseTrkSes_Trk 0x01
|
|
#define CloseTrkSes_Ses 0x02
|
|
|
|
#define CloseTrkSes_LastTrkSes 0xff
|
|
#endif
|
|
*/
|
|
|
|
typedef struct _CLOSE_TRK_SES_USER_IN {
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR Immed : 1;
|
|
UCHAR Reserved0 : 7;
|
|
} Fields;
|
|
} Byte1;
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR Track : 1;
|
|
UCHAR Session : 1;
|
|
UCHAR Reserved0 : 6;
|
|
} Fields;
|
|
} Byte2;
|
|
UCHAR TrackNum;
|
|
} CLOSE_TRK_SES_USER_IN, *PCLOSE_TRK_SES_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _PREVENT_MEDIA_REMOVAL_USER_IN {
|
|
BOOLEAN PreventMediaRemoval;
|
|
} PREVENT_MEDIA_REMOVAL_USER_IN, *PPREVENT_MEDIA_REMOVAL_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SET_RANDOM_ACCESS_USER_IN {
|
|
BOOLEAN RandomAccessMode;
|
|
} SET_RANDOM_ACCESS_USER_IN, *PSET_RANDOM_ACCESS_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef DiscInfo_Disk_Mask
|
|
#define DiscInfo_Disk_Mask 0x03
|
|
#define DiscInfo_Disk_Empty 0x00
|
|
#define DiscInfo_Disk_Appendable 0x01
|
|
#define DiscInfo_Disk_Complete 0x02
|
|
|
|
#define DiscInfo_Ses_Mask 0x0C
|
|
#define DiscInfo_Ses_Empty 0x00
|
|
#define DiscInfo_Ses_Incomplete 0x04
|
|
#define DiscInfo_Ses_Complete 0x0C
|
|
|
|
#define DiscInfo_Disk_Erasable 0x10
|
|
|
|
#define DiscInfo_URU 0x10
|
|
#define DiscInfo_DBC_V 0x20
|
|
#define DiscInfo_DID_V 0x40
|
|
|
|
#define DiscInfo_Type_cdrom 0x00 // CD-DA / CD-ROM
|
|
#define DiscInfo_Type_cdi 0x10 // CD-I
|
|
#define DiscInfo_Type_cdromxa 0x20 // CD-ROM XA
|
|
#define DiscInfo_Type_unknown 0xFF // HZ ;)
|
|
|
|
#endif
|
|
*/
|
|
|
|
typedef struct _DISC_STATUS_INFO_USER_OUT {
|
|
UCHAR ErrorCode;
|
|
UCHAR SenseKey;
|
|
UCHAR AdditionalSenseCode;
|
|
UCHAR AdditionalSenseCodeQualifier;
|
|
UCHAR SrbStatus;
|
|
BOOLEAN RandomAccessMode;
|
|
BOOLEAN CUE_sent;
|
|
UCHAR Flags;
|
|
LARGE_INTEGER MediaChangeTime;
|
|
|
|
UCHAR LastSesLeadInMSF[4];
|
|
UCHAR LastSesLeadOutMSF[4];
|
|
|
|
ULONG NumOfSes;
|
|
ULONG FirstTrackNumLastSes;
|
|
ULONG LastTrackNumLastSes;
|
|
ULONG Reserved1; // this is used to align data
|
|
|
|
} DISC_STATUS_INFO_USER_OUT, *PDISC_STATUS_INFO_USER_OUT;
|
|
|
|
#define DiscStatus_Formattable 0x01
|
|
|
|
typedef struct _DISC_INFO_BLOCK_USER_OUT { //
|
|
|
|
DISC_STATUS_INFO_USER_OUT Status;
|
|
|
|
USHORT DataLength;
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR DiscStat : 2;
|
|
UCHAR LastSesStat : 2;
|
|
UCHAR Erasable : 1;
|
|
UCHAR Reserved0: 3;
|
|
} Fields;
|
|
} DiscStat;
|
|
|
|
UCHAR FirstTrackNum;
|
|
UCHAR NumOfSes;
|
|
UCHAR FirstTrackNumLastSes;
|
|
UCHAR LastTrackNumLastSes;
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR Reserved1: 5;
|
|
UCHAR URU : 1;
|
|
UCHAR DBC_V : 1; // 0
|
|
UCHAR DID_V : 1;
|
|
} Fields;
|
|
} Flags;
|
|
|
|
UCHAR DiskType;
|
|
UCHAR NumOfSes2; // MSB MMC-3
|
|
UCHAR FirstTrackNumLastSes2; // MSB MMC-3
|
|
UCHAR LastTrackNumLastSes2; // MSB MMC-3
|
|
UCHAR DiskId [4];
|
|
ULONG LastSesLeadInLBA;
|
|
ULONG LastSesLeadOutLBA;
|
|
UCHAR DiskBarCode [8];
|
|
UCHAR Reserved3;
|
|
UCHAR OPCNum;
|
|
} DISC_INFO_BLOCK_USER_OUT, *PDISC_INFO_BLOCK_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _TEST_UNIT_READY_USER_IN {
|
|
ULONG MaxReadyRetry;
|
|
} TEST_UNIT_READY_USER_IN, *PTEST_UNIT_READY_USER_IN;
|
|
|
|
typedef struct _TEST_UNIT_READY_USER_OUT {
|
|
UCHAR ErrorCode;
|
|
UCHAR SenseKey;
|
|
UCHAR AdditionalSenseCode;
|
|
UCHAR AdditionalSenseCodeQualifier;
|
|
} TEST_UNIT_READY_USER_OUT, *PTEST_UNIT_READY_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef MediaType_Unknown
|
|
|
|
#define MediaType_Unknown 0x00
|
|
#define MediaType_120mm_CDROM_DataOnly 0x01
|
|
#define MediaType_120mm_CDROM_AudioOnly 0x02 //CDDA
|
|
#define MediaType_120mm_CDROM_DataAudioCombined 0x03
|
|
#define MediaType_120mm_CDROM_Hybrid_PhotoCD 0x04
|
|
#define MediaType_80mm_CDROM_DataOnly 0x05
|
|
#define MediaType_80mm_CDROM_AudioOnly 0x06 //CDDA
|
|
#define MediaType_80mm_CDROM_DataAudioCombined 0x07
|
|
#define MediaType_80mm_CDROM_Hybrid_PhotoCD 0x08
|
|
|
|
#define MediaType_UnknownSize_CDR 0x10
|
|
#define MediaType_120mm_CDR_DataOnly 0x11
|
|
#define MediaType_120mm_CDR_AudioOnly 0x12 //CDDA
|
|
#define MediaType_120mm_CDR_DataAudioCombined 0x13
|
|
#define MediaType_120mm_CDR_Hybrid_PhotoCD 0x14
|
|
#define MediaType_80mm_CDR_DataOnly 0x15
|
|
#define MediaType_80mm_CDR_AudioOnly 0x16 //CDDA
|
|
#define MediaType_80mm_CDR_DataAudioCombined 0x17
|
|
#define MediaType_80mm_CDR_Hybrid_Photo_CD 0x18
|
|
|
|
#define MediaType_UnknownSize_CDRW 0x20
|
|
#define MediaType_120mm_CDRW_DataOnly 0x21
|
|
#define MediaType_120mm_CDRW_AudioOnly 0x22 //CDDA
|
|
#define MediaType_120mm_CDRW_DataAudioCombined 0x23
|
|
#define MediaType_120mm_CDRW_Hybrid 0x24
|
|
#define MediaType_80mm_CDRW_DataOnly 0x25
|
|
#define MediaType_80mm_CDRW_AudioOnly 0x26 //CDDA
|
|
#define MediaType_80mm_CDRW_DataAudioCombined 0x27
|
|
#define MediaType_80mm_CDRW_Hybrid 0x28
|
|
|
|
#define MediaType_UnknownSize_Unknown 0x30
|
|
|
|
#define MediaType_NoDiscPresent 0x70
|
|
#define MediaType_DoorOpen 0x71
|
|
|
|
#endif
|
|
*/
|
|
|
|
typedef struct _GET_MEDIA_TYPE_USER_OUT {
|
|
UCHAR MediaType;
|
|
} GET_MEDIA_TYPE_USER_OUT, *PGET_MEDIA_TYPE_USER_OUT;
|
|
|
|
typedef struct _GET_MEDIA_TYPE_EX_USER_OUT {
|
|
UCHAR OldStyleMediaType; // see GET_MEDIA_TYPE_USER_OUT
|
|
UCHAR MediaClass;
|
|
UCHAR MediaSize;
|
|
UCHAR DataType;
|
|
UCHAR MediaClassEx;
|
|
UCHAR DataClassEx;
|
|
UCHAR CapFlags;
|
|
UCHAR Layers; // Number of layers - 1 (e.g. 0 => 1 layer)
|
|
UCHAR Reserved[8]; // for future implementation
|
|
} GET_MEDIA_TYPE_EX_USER_OUT, *PGET_MEDIA_TYPE_EX_USER_OUT;
|
|
|
|
#define CdMediaClass_CDROM 0x00
|
|
#define CdMediaClass_CDR 0x01
|
|
#define CdMediaClass_CDRW 0x02
|
|
#define CdMediaClass_DVDROM 0x03
|
|
#define CdMediaClass_DVDRAM 0x05
|
|
#define CdMediaClass_DVDR 0x06
|
|
#define CdMediaClass_DVDRW 0x07
|
|
#define CdMediaClass_DVDpR 0x08
|
|
#define CdMediaClass_DVDpRW 0x09
|
|
#define CdMediaClass_DDCDROM 0x0a
|
|
#define CdMediaClass_DDCDR 0x0b
|
|
#define CdMediaClass_DDCDRW 0x0c
|
|
#define CdMediaClass_BDROM 0x0d
|
|
#define CdMediaClass_BDRE 0x0e
|
|
#define CdMediaClass_BDR 0x0f
|
|
#define CdMediaClass_HD_DVDROM 0x10
|
|
#define CdMediaClass_HD_DVDRAM 0x11
|
|
#define CdMediaClass_HD_DVDR 0x12
|
|
#define CdMediaClass_HD_DVDRW 0x13
|
|
#define CdMediaClass_NoDiscPresent 0x70
|
|
#define CdMediaClass_DoorOpen 0x71
|
|
#define CdMediaClass_Unknown 0xff
|
|
|
|
#define CdMediaClass_Max CdMediaClass_HD_DVDRW
|
|
|
|
#define CdMediaSize_Unknown 0
|
|
#define CdMediaSize_120mm 1
|
|
#define CdMediaSize_80mm 2
|
|
|
|
#define CdDataType_Unknown 0
|
|
#define CdDataType_DataOnly 1
|
|
#define CdDataType_AudioOnly 2 //CDDA
|
|
#define CdDataType_DataAudioCombined 3
|
|
#define CdDataType_Hybrid 4
|
|
#define CdDataType_DataOnlyMRW 5
|
|
|
|
#define CdMediaClassEx_CD 0x00
|
|
#define CdMediaClassEx_DVD 0x01
|
|
#define CdMediaClassEx_DDCD 0x02
|
|
#define CdMediaClassEx_BD 0x03
|
|
#define CdMediaClassEx_HD_DVD 0x04
|
|
#define CdMediaClassEx_None 0x70
|
|
#define CdMediaClassEx_Unknown 0xff
|
|
|
|
#define CdDataClassEx_ROM 0x00
|
|
#define CdDataClassEx_R 0x01
|
|
#define CdDataClassEx_RW 0x02
|
|
#define CdDataClassEx_Unknown 0xff
|
|
|
|
#define CdCapFlags_Writable 0x01
|
|
#define CdCapFlags_Erasable 0x02
|
|
#define CdCapFlags_Formatable 0x04
|
|
#define CdCapFlags_WriteParamsReq 0x08
|
|
#define CdCapFlags_RandomWritable 0x10
|
|
#define CdCapFlags_Cav 0x20
|
|
|
|
#define CdrwMediaClassEx_IsRAM(MediaClassEx) ( \
|
|
((MediaClassEx) == CdMediaClass_DVDRAM) || \
|
|
((MediaClassEx) == CdMediaClass_BDRE) || \
|
|
((MediaClassEx) == CdMediaClass_HD_DVDRAM) )
|
|
|
|
#define CdrwIsDvdOverwritable(MediaClassEx) \
|
|
((MediaClassEx) == CdMediaClass_DVDRW || \
|
|
(MediaClassEx) == CdMediaClass_DVDpRW || \
|
|
(MediaClassEx) == CdMediaClass_DVDRAM || \
|
|
(MediaClassEx) == CdMediaClass_BDRE || \
|
|
(MediaClassEx) == CdMediaClass_HD_DVDRW || \
|
|
(MediaClassEx) == CdMediaClass_HD_DVDRAM \
|
|
)
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef MAX_PAGE_SIZE
|
|
#define MAX_PAGE_SIZE 0x100
|
|
#endif
|
|
*/
|
|
|
|
typedef struct _MODE_SENSE_USER_IN {
|
|
union {
|
|
UCHAR Byte;
|
|
struct {
|
|
UCHAR PageCode : 6;
|
|
UCHAR Reserved0: 1;
|
|
UCHAR PageSavable : 1;
|
|
} Fields;
|
|
} PageCode;
|
|
} MODE_SENSE_USER_IN, *PMODE_SENSE_USER_IN;
|
|
|
|
typedef struct _MODE_SENSE_USER_OUT {
|
|
MODE_PARAMETER_HEADER Header;
|
|
} MODE_SENSE_USER_OUT, *PMODE_SENSE_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _MODE_SELECT_USER_IN {
|
|
MODE_PARAMETER_HEADER Header;
|
|
} MODE_SELECT_USER_IN, *PMODE_SELECT_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _MODE_WRITE_PARAMS_PAGE_USER { // 0x05
|
|
UCHAR PageCode : 6;
|
|
UCHAR Reserved0: 1;
|
|
UCHAR PageSavable : 1;
|
|
|
|
UCHAR PageLength; // 0x32
|
|
|
|
/*
|
|
#ifndef WParam_WType_Mask
|
|
#define WParam_WType_Mask 0x0f
|
|
#define WParam_WType_Packet 0x00
|
|
#define WParam_WType_TAO 0x01
|
|
#define WParam_WType_Ses 0x02
|
|
#define WParam_WType_Raw 0x03
|
|
#define WParam_TestWrite 0x10
|
|
#define WParam_LS_V 0x20
|
|
#define WParam_BUFF 0x40
|
|
#endif
|
|
*/
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR WriteType: 4; // 1
|
|
UCHAR TestWrite: 1;
|
|
UCHAR LS_V: 1;
|
|
UCHAR BUFF: 1;
|
|
UCHAR Reserved1: 1;
|
|
} Fields;
|
|
} Byte2;
|
|
|
|
/*
|
|
#ifndef WParam_TrkMode_Mask
|
|
#define WParam_TrkMode_Mask 0x0f
|
|
#define WParam_TrkMode_None 0x00
|
|
#define WParam_TrkMode_Audio 0x00
|
|
#define WParam_TrkMode_Audio_PreEmph 0x01
|
|
#define WParam_TrkMode_Data 0x04
|
|
#define WParam_TrkMode_IncrData 0x05
|
|
#define WParam_TrkMode_QAudio_PreEmph 0x08
|
|
#define WParam_TrkMode_AllowCpy 0x02
|
|
#define WParam_Copy 0x10
|
|
#define WParam_FP 0x20
|
|
#define WParam_MultiSes_Mask 0xc0
|
|
#define WParam_Multises_None 0x00
|
|
#define WParam_Multises_Final 0x80
|
|
#define WParam_Multises_Multi 0xc0
|
|
#endif
|
|
*/
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR TrackMode: 4; // 4
|
|
UCHAR Copy : 1; // 0
|
|
UCHAR FP : 1; // 0
|
|
UCHAR Multisession: 2; // 11
|
|
} Fields;
|
|
} Byte3;
|
|
|
|
/*
|
|
#ifndef WParam_BlkType_Mask
|
|
#define WParam_BlkType_Mask 0x0f
|
|
#define WParam_BlkType_Raw_2352 0x00
|
|
#define WParam_BlkType_RawPQ_2368 0x01
|
|
#define WParam_BlkType_RawPW_2448 0x02
|
|
#define WParam_BlkType_RawPW_R_2448 0x03
|
|
#define WParam_BlkType_M1_2048 0x08
|
|
#define WParam_BlkType_M2_2336 0x09
|
|
#define WParam_BlkType_M2XAF1_2048 0x0a
|
|
#define WParam_BlkType_M2XAF1SH_2056 0x0b
|
|
#define WParam_BlkType_M2XAF2_2324 0x0c
|
|
#define WParam_BlkType_M2XAFXSH_2332 0x0d
|
|
#endif
|
|
*/
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR DataBlockType: 4; // 8
|
|
UCHAR Reserved2: 4;
|
|
} Fields;
|
|
} Byte4;
|
|
|
|
UCHAR LinkSize;
|
|
UCHAR Reserved3;
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR HostAppCode : 6; // 0
|
|
UCHAR Reserved4: 2;
|
|
} Fields;
|
|
} Byte7;
|
|
|
|
/*
|
|
#ifndef WParam_SesFmt_CdRom
|
|
#define WParam_SesFmt_CdRom 0x00
|
|
#define WParam_SesFmt_CdI 0x10
|
|
#define WParam_SesFmt_CdRomXa 0x20
|
|
#endif
|
|
*/
|
|
|
|
UCHAR SesFmt; // 0
|
|
UCHAR Reserved5;
|
|
ULONG PacketSize; // 0
|
|
USHORT AudioPause; // 150
|
|
|
|
UCHAR Reserved6: 7;
|
|
UCHAR MCVAL : 1;
|
|
|
|
UCHAR N[13];
|
|
UCHAR Zero;
|
|
UCHAR AFRAME;
|
|
|
|
UCHAR Reserved7: 7;
|
|
UCHAR TCVAL : 1;
|
|
|
|
UCHAR I[12];
|
|
UCHAR Zero_2;
|
|
UCHAR AFRAME_2;
|
|
UCHAR Reserved8;
|
|
|
|
struct {
|
|
union {
|
|
UCHAR MSF[3];
|
|
struct _SubHdrParams1 {
|
|
UCHAR FileNum;
|
|
UCHAR ChannelNum;
|
|
|
|
/*
|
|
#define WParam_SubHdr_SubMode0 0x00
|
|
#define WParam_SubHdr_SubMode1 0x08
|
|
*/
|
|
|
|
UCHAR SubMode;
|
|
} Params1;
|
|
} Params;
|
|
|
|
/*
|
|
#define WParam_SubHdr_Mode_Mask 0x03
|
|
#define WParam_SubHdr_Mode0 0x00
|
|
#define WParam_SubHdr_Mode1 0x01
|
|
#define WParam_SubHdr_Mode2 0x02
|
|
#define WParam_SubHdr_Format_Mask 0xe0
|
|
#define WParam_SubHdr_Format_UserData 0x00
|
|
#define WParam_SubHdr_Format_RunIn4 0x20
|
|
#define WParam_SubHdr_Format_RunIn3 0x40
|
|
#define WParam_SubHdr_Format_RunIn2 0x60
|
|
#define WParam_SubHdr_Format_RunIn1 0x80
|
|
#define WParam_SubHdr_Format_Link 0xa0
|
|
#define WParam_SubHdr_Format_RunOut2 0xc0
|
|
#define WParam_SubHdr_Format_RunOut1 0xe0
|
|
*/
|
|
|
|
union {
|
|
UCHAR Flags;
|
|
struct {
|
|
UCHAR Mode : 2;
|
|
UCHAR Reserved : 3;
|
|
UCHAR Format : 3;
|
|
} Fields;
|
|
} Mode;
|
|
} SubHeader;
|
|
} MODE_WRITE_PARAMS_PAGE_USER, *PMODE_WRITE_PARAMS_PAGE_USER;
|
|
|
|
typedef MODE_WRITE_PARAMS_PAGE_USER GET_WRITE_MODE_USER_OUT;
|
|
typedef PMODE_WRITE_PARAMS_PAGE_USER PGET_WRITE_MODE_USER_OUT;
|
|
|
|
typedef MODE_WRITE_PARAMS_PAGE_USER SET_WRITE_MODE_USER_IN;
|
|
typedef PMODE_WRITE_PARAMS_PAGE_USER PSET_WRITE_MODE_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
#ifndef WITHOUT_FORMATTER
|
|
|
|
typedef MODE_MRW_PAGE GET_MRW_MODE_USER_OUT;
|
|
typedef PMODE_MRW_PAGE PGET_MRW_MODE_USER_OUT;
|
|
|
|
typedef MODE_MRW_PAGE SET_MRW_MODE_USER_IN;
|
|
typedef PMODE_MRW_PAGE PSET_MRW_MODE_USER_IN;
|
|
|
|
#endif //WITHOUT_FORMATTER
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SET_READ_AHEAD_USER_IN {
|
|
ULONG TriggerLBA;
|
|
ULONG ReadAheadLBA;
|
|
} SET_READ_AHEAD_USER_IN, *PSET_READ_AHEAD_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _GET_CAPABILITIES_USER_OUT {
|
|
UCHAR PageCode : 6;
|
|
UCHAR Reserved1 : 1;
|
|
UCHAR PSBit : 1;
|
|
|
|
UCHAR PageLength;
|
|
|
|
/*
|
|
#ifndef DevCap_read_cd_r
|
|
#define DevCap_read_cd_r 0x01 // reserved in 1.2
|
|
#define DevCap_read_cd_rw 0x02 // reserved in 1.2
|
|
#define DevCap_method2 0x04
|
|
#define DevCap_read_dvd_rom 0x08
|
|
#define DevCap_read_dvd_r 0x10
|
|
#define DevCap_read_dvd_ram 0x20
|
|
#endif //DevCap_cd_r_read
|
|
*/
|
|
|
|
UCHAR ReadCap; // DevCap_*_read
|
|
/* UCHAR cd_r_read : 1; // reserved in 1.2
|
|
UCHAR cd_rw_read : 1; // reserved in 1.2
|
|
UCHAR method2 : 1;
|
|
UCHAR dvd_rom : 1;
|
|
UCHAR dvd_r_read : 1;
|
|
UCHAR dvd_ram_read : 1;
|
|
UCHAR Reserved2 : 2;*/
|
|
|
|
/*
|
|
#ifndef DevCap_write_cd_r
|
|
#define DevCap_write_cd_r 0x01 // reserved in 1.2
|
|
#define DevCap_write_cd_rw 0x02 // reserved in 1.2
|
|
#define DevCap_test_write 0x04
|
|
#define DevCap_write_dvd_r 0x10
|
|
#define DevCap_write_dvd_ram 0x20
|
|
#endif //DevCap_cd_r_write
|
|
*/
|
|
|
|
UCHAR WriteCap; // DevCap_*_write
|
|
/* UCHAR cd_r_write : 1; // reserved in 1.2
|
|
UCHAR cd_rw_write : 1; // reserved in 1.2
|
|
UCHAR dvd_ram_write : 1;
|
|
UCHAR dvd_r_write : 1;
|
|
UCHAR reserved3a : 1;
|
|
UCHAR test_write : 1;
|
|
UCHAR Reserved3 : 2;*/
|
|
|
|
/*
|
|
#ifndef DevCap_audio_play
|
|
#define DevCap_audio_play 0x01
|
|
#define DevCap_composite 0x02
|
|
#define DevCap_digport1 0x04
|
|
#define DevCap_digport2 0x08
|
|
#define DevCap_mode2_form1 0x10
|
|
#define DevCap_mode2_form2 0x20
|
|
#define DevCap_multisession 0x40
|
|
#endif //DevCap_audio_play
|
|
*/
|
|
|
|
UCHAR Capabilities0;
|
|
/* UCHAR audio_play : 1;
|
|
UCHAR composite : 1;
|
|
UCHAR digport1 : 1;
|
|
UCHAR digport2 : 1;
|
|
UCHAR mode2_form1 : 1;
|
|
UCHAR mode2_form2 : 1;
|
|
UCHAR multisession : 1;
|
|
UCHAR Reserved4 : 1;*/
|
|
|
|
/*
|
|
#ifndef DevCap_cdda
|
|
#define DevCap_cdda 0x01
|
|
#define DevCap_cdda_accurate 0x02
|
|
#define DevCap_rw_supported 0x04
|
|
#define DevCap_rw_corr 0x08
|
|
#define DevCap_c2_pointers 0x10
|
|
#define DevCap_isrc 0x20
|
|
#define DevCap_upc 0x40
|
|
#define DevCap_read_bar_code 0x80
|
|
#endif //DevCap_cdda
|
|
*/
|
|
|
|
UCHAR Capabilities1;
|
|
/* UCHAR cdda : 1;
|
|
UCHAR cdda_accurate : 1;
|
|
UCHAR rw_supported : 1;
|
|
UCHAR rw_corr : 1;
|
|
UCHAR c2_pointers : 1;
|
|
UCHAR isrc : 1;
|
|
UCHAR upc : 1;
|
|
UCHAR Reserved5 : 1;*/
|
|
|
|
/*
|
|
#ifndef DevCap_lock
|
|
#define DevCap_lock 0x01
|
|
#define DevCap_lock_state 0x02
|
|
#define DevCap_prevent_jumper 0x04
|
|
#define DevCap_eject 0x08
|
|
#define DevCap_mechtype_mask 0xE0
|
|
#define DevCap_mechtype_caddy 0x00
|
|
#define DevCap_mechtype_tray (0x01<<5)
|
|
#define DevCap_mechtype_popup (0x02<<5)
|
|
#define DevCap_mechtype_individual_changer (0x04<<5)
|
|
#define DevCap_mechtype_cartridge_changer (0x05<<5)
|
|
#endif //DevCap_lock
|
|
*/
|
|
|
|
UCHAR Capabilities2;
|
|
/* UCHAR lock : 1;
|
|
UCHAR lock_state : 1;
|
|
UCHAR prevent_jumper : 1;
|
|
UCHAR eject : 1;
|
|
UCHAR Reserved6 : 1;
|
|
UCHAR mechtype : 3;*/
|
|
|
|
/*
|
|
#ifndef DevCap_separate_volume
|
|
#define DevCap_separate_volume 0x01
|
|
#define DevCap_separate_mute 0x02
|
|
#define DevCap_disc_present 0x04 // reserved in 1.2
|
|
#define DevCap_sw_slot_select 0x08 // reserved in 1.2
|
|
#define DevCap_change_side_cap 0x10
|
|
#define DevCap_rw_leadin_read 0x20
|
|
#endif //DevCap_separate_volume
|
|
*/
|
|
|
|
UCHAR Capabilities3;
|
|
/* UCHAR separate_volume : 1;
|
|
UCHAR separate_mute : 1;
|
|
UCHAR disc_present : 1; // reserved in 1.2
|
|
UCHAR sss : 1; // reserved in 1.2
|
|
UCHAR Reserved7 : 4;*/
|
|
|
|
USHORT MaximumSpeedSupported;
|
|
USHORT NumberVolumeLevels;
|
|
USHORT BufferSize;
|
|
USHORT CurrentSpeed;
|
|
|
|
UCHAR Reserved8;
|
|
|
|
UCHAR SpecialParameters0;
|
|
/* UCHAR Reserved9 : 1;
|
|
UCHAR BCK : 1;
|
|
UCHAR RCK : 1;
|
|
UCHAR LSBF : 1;
|
|
UCHAR Length : 2;
|
|
UCHAR Reserved10 : 2;*/
|
|
|
|
USHORT MaximumWriteSpeedSupported;
|
|
USHORT CurrentWriteSpeed;
|
|
USHORT CopyManagementRevision;
|
|
UCHAR Reserved11[2];
|
|
|
|
} GET_CAPABILITIES_USER_OUT, *PGET_CAPABILITIES_USER_OUT;
|
|
|
|
typedef struct _GET_CAPABILITIES_3_USER_OUT {
|
|
|
|
UCHAR PageCode : 6;
|
|
UCHAR Reserved1 : 1;
|
|
UCHAR PSBit : 1;
|
|
|
|
UCHAR PageLength;
|
|
UCHAR ReadCap; // DevCap_*_read
|
|
UCHAR WriteCap; // DevCap_*_write
|
|
UCHAR Capabilities0;
|
|
UCHAR Capabilities1;
|
|
UCHAR Capabilities2;
|
|
UCHAR Capabilities3;
|
|
USHORT MaximumSpeedSupported;
|
|
USHORT NumberVolumeLevels;
|
|
USHORT BufferSize;
|
|
USHORT CurrentSpeed;
|
|
|
|
UCHAR Reserved8;
|
|
UCHAR SpecialParameters0;
|
|
|
|
USHORT MaximumWriteSpeedSupported;
|
|
USHORT CurrentWriteSpeed;
|
|
USHORT CopyManagementRevision;
|
|
UCHAR Reserved11[2];
|
|
|
|
// MMC 3
|
|
|
|
UCHAR Reserved12;
|
|
|
|
UCHAR SpecialParameters1;
|
|
/* UCHAR RCS : 2; // rotation control selected
|
|
UCHAR Reserved13 : 6; */
|
|
|
|
USHORT CurrentWriteSpeed3;
|
|
USHORT LunWPerfDescriptorCount;
|
|
|
|
// LUN_WRITE_PERF_DESC_USER WritePerfDescs[0];
|
|
|
|
} GET_CAPABILITIES_3_USER_OUT, *PGET_CAPABILITIES_3_USER_OUT;
|
|
|
|
typedef struct _LUN_WRITE_PERF_DESC_USER {
|
|
UCHAR Reserved;
|
|
|
|
#define LunWPerf_RotCtrl_Mask 0x07
|
|
#define LunWPerf_RotCtrl_CLV 0x00
|
|
#define LunWPerf_RotCtrl_CAV 0x01
|
|
|
|
UCHAR RotationControl;
|
|
USHORT WriteSpeedSupported; // kbps
|
|
|
|
} LUN_WRITE_PERF_DESC_USER, *PLUN_WRITE_PERF_DESC_USER;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SEND_OPC_INFO_USER_IN {
|
|
USHORT Speed;
|
|
UCHAR OpcValue[6];
|
|
} SEND_OPC_INFO_USER_IN, *PSEND_OPC_INFO_USER_IN;
|
|
|
|
typedef struct _SEND_OPC_INFO_HEADER_USER_IN {
|
|
BOOLEAN DoOpc;
|
|
USHORT OpcBlocksNumber;
|
|
} SEND_OPC_INFO_HEADER_USER_IN, *PSEND_OPC_INFO_HEADER_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _LL_READ_USER_IN {
|
|
|
|
#define ReadCd_BlkType_Mask 0x1c
|
|
#define ReadCd_BlkType_Any (0x00<<2)
|
|
#define ReadCd_BlkType_CDDA (0x01<<2)
|
|
#define ReadCd_BlkType_M1 (0x02<<2)
|
|
#define ReadCd_BlkType_M2FX (0x03<<2)
|
|
#define ReadCd_BlkType_M2F1 (0x04<<2)
|
|
#define ReadCd_BlkType_M2F2 (0x05<<2)
|
|
|
|
UCHAR ExpectedBlkType;
|
|
|
|
ULONG LBA; // negative value (-1) indicates tha (H)MSF must be used
|
|
ULONG NumOfBlocks;
|
|
|
|
#define ReadCd_Error_Mask 0x0006
|
|
#define ReadCd_Error_None 0x0000
|
|
#define ReadCd_Error_C2 0x0002
|
|
#define ReadCd_Error_C2ex 0x0004
|
|
#define ReadCd_Include_EDC 0x0008
|
|
#define ReadCd_Include_UsrData 0x0010
|
|
#define ReadCd_Header_Mask 0x0060
|
|
#define ReadCd_Header_None 0x0000
|
|
#define ReadCd_Header_Hdr 0x0020
|
|
#define ReadCd_Header_SubHdr 0x0040
|
|
#define ReadCd_Header_AllHdr 0x0060
|
|
#define ReadCd_Include_SyncData 0x0080
|
|
#define ReadCd_SubChan_Mask 0x0700
|
|
#define ReadCd_SubChan_None 0x0000
|
|
#define ReadCd_SubChan_Raw 0x0100
|
|
#define ReadCd_SubChan_Q 0x0200
|
|
#define ReadCd_SubChan_PW 0x0400
|
|
#define ReadCd_SubChan_All ReadCd_SubChan_Mask
|
|
|
|
union {
|
|
USHORT Flags;
|
|
struct {
|
|
UCHAR Reserved2 : 1;
|
|
UCHAR ErrorFlags : 2;
|
|
UCHAR IncludeEDC : 1;
|
|
UCHAR IncludeUserData : 1;
|
|
UCHAR HeaderCode : 2;
|
|
UCHAR IncludeSyncData : 1;
|
|
|
|
UCHAR SubChannelSelection : 3;
|
|
UCHAR Reserved3 : 5;
|
|
} Fields;
|
|
} Flags;
|
|
|
|
BOOLEAN UseMFS;
|
|
CHAR Starting_MSF[3];
|
|
CHAR Ending_MSF[3];
|
|
|
|
} LL_READ_USER_IN, *PLL_READ_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _GET_LAST_ERROR_USER_OUT {
|
|
|
|
UCHAR ErrorCode;
|
|
UCHAR SenseKey;
|
|
UCHAR AdditionalSenseCode;
|
|
UCHAR AdditionalSenseCodeQualifier;
|
|
UCHAR SrbStatus;
|
|
ULONG LastError;
|
|
BOOLEAN RandomAccessMode;
|
|
LARGE_INTEGER MediaChangeTime;
|
|
ULONG MediaChangeCount;
|
|
|
|
} GET_LAST_ERROR_USER_OUT, *PGET_LAST_ERROR_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _RAW_READ_USER_IN {
|
|
LARGE_INTEGER DiskOffset;
|
|
ULONG SectorCount;
|
|
TRACK_MODE_TYPE TrackMode;
|
|
} RAW_READ_USER_IN, *PRAW_READ_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _PLAY_AUDIO_MSF_USER_IN {
|
|
UCHAR StartingMSF[3];
|
|
UCHAR EndingMSF[3];
|
|
} PLAY_AUDIO_MSF_USER_IN, *PPLAY_AUDIO_MSF_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
#define AudioStatus_NotSupported 0x00
|
|
#define AudioStatus_InProgress 0x11
|
|
#define AudioStatus_Paused 0x12
|
|
#define AudioStatus_PlayComplete 0x13
|
|
#define AudioStatus_PlayError 0x14
|
|
#define AudioStatus_NoStatus 0x15
|
|
|
|
#define IOCTL_CDROM_SUB_Q_CHANNEL 0x00
|
|
#define IOCTL_CDROM_CURRENT_POSITION 0x01
|
|
#define IOCTL_CDROM_MEDIA_CATALOG 0x02
|
|
#define IOCTL_CDROM_TRACK_ISRC 0x03
|
|
|
|
typedef struct _SUB_Q_CHANNEL_DATA_USER_IN {
|
|
UCHAR Format;
|
|
UCHAR Track;
|
|
} SUB_Q_CHANNEL_DATA_USER_IN, *PSUB_Q_CHANNEL_DATA_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _SEEK_AUDIO_MSF_USER_IN {
|
|
UCHAR MSF[3];
|
|
} SEEK_AUDIO_MSF_USER_IN, *PSEEK_AUDIO_MSF_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _AUDIO_CONTROL_USER_OUT {
|
|
UCHAR LbaFormat;
|
|
USHORT LogicalBlocksPerSecond;
|
|
} AUDIO_CONTROL_USER_OUT, *PAUDIO_CONTROL_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef READ_TOC_TOC READ_TOC_USER_OUT;
|
|
typedef PREAD_TOC_TOC PREAD_TOC_USER_OUT;
|
|
|
|
typedef READ_TOC_SES GET_LAST_SESSION_USER_OUT;
|
|
typedef PREAD_TOC_SES PGET_LAST_SESSION_USER_OUT;
|
|
|
|
typedef READ_TOC_FULL_TOC READ_FULL_TOC_USER_OUT;
|
|
typedef PREAD_TOC_FULL_TOC PREAD_FULL_TOC_USER_OUT;
|
|
|
|
typedef READ_TOC_FULL_TOC READ_PMA_USER_OUT;
|
|
typedef PREAD_TOC_FULL_TOC PREAD_PMA_USER_OUT;
|
|
|
|
typedef READ_TOC_ATIP READ_ATIP_USER_OUT;
|
|
typedef PREAD_TOC_ATIP PREAD_ATIP_USER_OUT;
|
|
|
|
typedef READ_TOC_CD_TEXT READ_CD_TEXT_USER_OUT;
|
|
typedef PREAD_TOC_CD_TEXT PREAD_CD_TEXT_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _INIT_DEINIT_USER_IN {
|
|
BOOLEAN PassThrough;
|
|
BOOLEAN Reserved; // For separate device (de)initialization
|
|
} INIT_DEINIT_USER_IN, *PINIT_DEINIT_USER_IN;
|
|
|
|
typedef INIT_DEINIT_USER_IN INIT_DEINIT_USER_OUT;
|
|
typedef PINIT_DEINIT_USER_IN PINIT_DEINIT_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _READ_SESSION_INFO_USER_IN {
|
|
BOOLEAN UseLBA;
|
|
UCHAR Session;
|
|
} READ_SESSION_INFO_USER_IN, *PREAD_SESSION_INFO_USER_IN;
|
|
|
|
typedef READ_TOC_SES READ_SESSION_INFO_USER_OUT;
|
|
typedef PREAD_TOC_SES PREAD_SESSION_INFO_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _READ_TOC_EX_USER_IN {
|
|
BOOLEAN UseLBA;
|
|
UCHAR Track;
|
|
} READ_TOC_EX_USER_IN, *PREAD_TOC_EX_USER_IN;
|
|
|
|
typedef READ_TOC_SES READ_TOC_EX_USER_OUT;
|
|
typedef PREAD_TOC_SES PREAD_TOC_EX_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
#define DefSession_LastAvailable 0xff
|
|
|
|
typedef struct _SET_DEFAULT_SESSION_USER_IN {
|
|
UCHAR LastSes;
|
|
} SET_DEFAULT_SESSION_USER_IN, *PSET_DEFAULT_SESSION_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _NOTIFY_MEDIA_CHANGE_USER_IN {
|
|
BOOLEAN Autorun;
|
|
} NOTIFY_MEDIA_CHANGE_USER_IN, *PNOTIFY_MEDIA_CHANGE_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef DISK_GEOMETRY GET_DRIVE_GEOMETRY_USER_OUT;
|
|
typedef PDISK_GEOMETRY PGET_DRIVE_GEOMETRY_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _GET_DEVICE_INFO_OLD_USER_OUT {
|
|
UCHAR WModes [4][16];
|
|
UCHAR VendorId[25];
|
|
UCHAR SimulatedWModes [4][16];
|
|
ULONG DeviceNumber;
|
|
ULONG Features;
|
|
INQUIRYDATA InquiryData;
|
|
ULONG Features2[4]; // form GET_CONFIG 0 - 128
|
|
} GET_DEVICE_INFO_OLD_USER_OUT, *PGET_DEVICE_INFO_OLD_USER_OUT;
|
|
|
|
typedef struct _GET_DEVICE_INFO_USER_OUT {
|
|
ULONG Tag;
|
|
ULONG Length;
|
|
UCHAR WModes [4][16];
|
|
UCHAR VendorId[25];
|
|
UCHAR SimulatedWModes [4][16];
|
|
ULONG DeviceNumber;
|
|
ULONG Features;
|
|
INQUIRYDATA InquiryData;
|
|
ULONG Features2[4]; // from GET_CONFIG
|
|
ULONG Features2ex[64-4]; // from GET_CONFIG (reserved for higher values)
|
|
ULONG WriteCaps; // CDRW_DEV_CAPABILITY_xxx
|
|
ULONG ReadCaps; // CDRW_DEV_CAPABILITY_xxx
|
|
} GET_DEVICE_INFO_USER_OUT, *PGET_DEVICE_INFO_USER_OUT;
|
|
|
|
#define CDRW_DEV_CAPABILITY_TAG 0xCA10AB11
|
|
|
|
#define WMODE_SUPPORTED 0x01
|
|
#define WMODE_SUPPORTED_FP 0x02
|
|
#define WMODE_SUPPORTED_VP 0x04
|
|
#define WMODE_NOT_SUPPORTED 0xff
|
|
#define WMODE_NOT_TESTED 0x00
|
|
|
|
#define CDRW_FEATURE_OPC 0x00000001 // use OPC regardless of OPCn in DISK_INFO
|
|
#define CDRW_FEATURE_EVENT 0x00000002
|
|
#define CDRW_FEATURE_GET_CFG 0x00000004
|
|
#define CDRW_FEATURE_NO_LOCK_REP 0x00000008 // device doesn't report tray lock state
|
|
#define CDRW_FEATURE_SYNC_ON_WRITE 0x00000010 // device preferes Sync Cache after each Write
|
|
#define CDRW_FEATURE_BAD_RW_SEEK 0x00000020 // seek error occures with status Illegal Sector Mode For This Track
|
|
// on old CdRoms when they attempt to read outer sectors on FP formatted
|
|
// disk. Workaround: perform sequence of seeks from lower address
|
|
// to required with step about 0x800 blocks.
|
|
#define CDRW_FEATURE_FP_ADDRESSING_PROBLEM 0x00000040
|
|
#define CDRW_FEATURE_MRW_ADDRESSING_PROBLEM 0x00000080
|
|
#define CDRW_FEATURE_FORCE_SYNC_ON_WRITE 0x00000100 // device requires Sync Cache after each Write
|
|
#define CDRW_FEATURE_BAD_DVD_LAST_LBA 0x00000200 // device cannot determile LastLba on not closed DVD disks
|
|
#define CDRW_FEATURE_FULL_BLANK_ON_FORMAT 0x00000400 // device cannot format disk until it is full-blanked
|
|
#define CDRW_FEATURE_STREAMING 0x00000800 // device supports streaming read/write
|
|
#define CDRW_FEATURE_FORCE_SYNC_BEFORE_READ 0x00001000 // device requires Sync Cache on Write -> Read state transition
|
|
#define CDRW_FEATURE_CHANGER 0x80000000
|
|
|
|
#define DEV_CAP_GET_PROFILE(arr, pf) \
|
|
(((pf) > PFNUM_Max) ? 0 : (((arr)[(pf)/32] >> (pf)%32) & 1))
|
|
|
|
#define CDRW_DEV_CAPABILITY_CDROM ((ULONG)1 << CdMediaClass_CDROM )
|
|
#define CDRW_DEV_CAPABILITY_CDR ((ULONG)1 << CdMediaClass_CDR )
|
|
#define CDRW_DEV_CAPABILITY_CDRW ((ULONG)1 << CdMediaClass_CDRW )
|
|
#define CDRW_DEV_CAPABILITY_DVDROM ((ULONG)1 << CdMediaClass_DVDROM )
|
|
#define CDRW_DEV_CAPABILITY_DVDRAM ((ULONG)1 << CdMediaClass_DVDRAM )
|
|
#define CDRW_DEV_CAPABILITY_DVDR ((ULONG)1 << CdMediaClass_DVDR )
|
|
#define CDRW_DEV_CAPABILITY_DVDRW ((ULONG)1 << CdMediaClass_DVDRW )
|
|
#define CDRW_DEV_CAPABILITY_DVDpR ((ULONG)1 << CdMediaClass_DVDpR )
|
|
#define CDRW_DEV_CAPABILITY_DVDpRW ((ULONG)1 << CdMediaClass_DVDpRW )
|
|
#define CDRW_DEV_CAPABILITY_DDCDROM ((ULONG)1 << CdMediaClass_DDCDROM)
|
|
#define CDRW_DEV_CAPABILITY_DDCDR ((ULONG)1 << CdMediaClass_DDCDR )
|
|
#define CDRW_DEV_CAPABILITY_DDCDRW ((ULONG)1 << CdMediaClass_DDCDRW )
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef ULONG CHECK_VERIFY_USER_OUT, *PCHECK_VERIFY_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
/*
|
|
#ifndef EventStat_Class_OpChange
|
|
#define EventStat_Class_OpChange 0x01
|
|
#define EventStat_Class_PM 0x02
|
|
#define EventStat_Class_Media 0x04
|
|
#define EventStat_Class_DevBusy 0x06
|
|
#endif // end EventStat_Class_OpChange
|
|
*/
|
|
|
|
typedef struct _GET_EVENT_USER_IN {
|
|
UCHAR EventClass;
|
|
BOOLEAN Immed;
|
|
} GET_EVENT_USER_IN, *PGET_EVENT_USER_IN;
|
|
|
|
typedef union _GET_EVENT_USER_OUT {
|
|
EVENT_STAT_OPERATIONAL_BLOCK Operational;
|
|
EVENT_STAT_PM_BLOCK PowerManagement;
|
|
EVENT_STAT_EXT_REQ_BLOCK ExternalReq;
|
|
EVENT_STAT_MEDIA_BLOCK MediaChange;
|
|
EVENT_STAT_DEV_BUSY_BLOCK DeviceBusy;
|
|
} GET_EVENT_USER_OUT, *PGET_EVENT_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef ULONG DVD_SESSION_ID, *PDVD_SESSION_ID;
|
|
|
|
typedef struct _DVD_READ_STRUCTURE_USER_IN {
|
|
LARGE_INTEGER BlockByteOffset;
|
|
DVD_STRUCTURE_FORMAT Format;
|
|
DVD_SESSION_ID SessionId;
|
|
UCHAR LayerNumber;
|
|
} DVD_READ_STRUCTURE_USER_IN, *PDVD_READ_STRUCTURE_USER_IN;
|
|
|
|
typedef struct _DVD_READ_STRUCTURE_USER_OUT {
|
|
USHORT Length;
|
|
UCHAR Reserved[2];
|
|
// UCHAR Data[0];
|
|
} DVD_READ_STRUCTURE_USER_OUT, *PDVD_READ_STRUCTURE_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _DVD_START_SESSION_USER_OUT {
|
|
DVD_SESSION_ID SessionId;
|
|
} DVD_START_SESSION_USER_OUT, *PDVD_START_SESSION_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _DVD_READ_KEY_USER_IN {
|
|
ULONG KeyLength;
|
|
DVD_SESSION_ID SessionId;
|
|
DVD_KEY_TYPE KeyType;
|
|
ULONG KeyFlags;
|
|
union {
|
|
HANDLE FileHandle;
|
|
LARGE_INTEGER TitleOffset;
|
|
} Parameters;
|
|
// UCHAR KeyData[0];
|
|
} DVD_READ_KEY_USER_IN, *PDVD_READ_KEY_USER_IN;
|
|
|
|
typedef DVD_READ_KEY_USER_IN DVD_READ_KEY_USER_OUT;
|
|
typedef PDVD_READ_KEY_USER_IN PDVD_READ_KEY_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef DVD_START_SESSION_USER_OUT DVD_END_SESSION_USER_IN;
|
|
typedef PDVD_START_SESSION_USER_OUT PDVD_END_SESSION_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
// Predefined (Mt. Fuji) key sizes
|
|
// Add sizeof(DVD_COPY_PROTECT_KEY) to get allocation size for
|
|
// the full key structure
|
|
|
|
#define DVD_CHALLENGE_KEY_LENGTH (12 + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_BUS_KEY_LENGTH (8 + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_TITLE_KEY_LENGTH (8 + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_DISK_KEY_LENGTH (2048 + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_RPC_KEY_LENGTH (sizeof(DVD_RPC_KEY) + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_SET_RPC_KEY_LENGTH (sizeof(DVD_SET_RPC_KEY) + sizeof(DVD_COPY_PROTECT_KEY))
|
|
#define DVD_ASF_LENGTH (sizeof(DVD_ASF) + sizeof(DVD_COPY_PROTECT_KEY))
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _DISK_VERIFY_USER_IN {
|
|
LONGLONG StartingOffset;
|
|
ULONG Length;
|
|
} DISK_VERIFY_USER_IN, *PDISK_VERIFY_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _CDROM_DISK_DATA_USER_OUT {
|
|
|
|
ULONG DiskData;
|
|
|
|
} CDROM_DISK_DATA_USER_OUT, *PCDROM_DISK_DATA_USER_OUT;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _CDRW_RESET_DRIVER_USER_IN {
|
|
BOOLEAN UnlockTray;
|
|
BOOLEAN Reserved[3];
|
|
ULONG MagicWord;
|
|
} CDRW_RESET_DRIVER_USER_IN, *PCDRW_RESET_DRIVER_USER_IN;
|
|
|
|
//**********************************************************************************************
|
|
|
|
typedef struct _MediaTrackMap {
|
|
ULONG FirstLba;
|
|
ULONG LastLba;
|
|
ULONG NWA;
|
|
ULONG PacketSize;
|
|
ULONG Session;
|
|
UCHAR TrackParam;
|
|
UCHAR DataParam;
|
|
UCHAR NWA_V;
|
|
|
|
UCHAR Flags;
|
|
#define TrackMap_AllowCopyBit_variated 0x01
|
|
#define TrackMap_CopyBit_variated 0x02
|
|
#define TrackMap_Try_variation 0x04
|
|
#define TrackMap_Use_variation 0x08
|
|
#define TrackMap_FixFPAddressing 0x10
|
|
#define TrackMap_FixMRWAddressing 0x20
|
|
|
|
// are used only if FixFPAddressing is enabled
|
|
ULONG TrackFPOffset;
|
|
ULONG PacketFPOffset;
|
|
|
|
} MediaTrackMap, *PMediaTrackMap;
|
|
|
|
typedef struct _GET_DISK_LAYOUT_USER_OUT {
|
|
ULONG Tag;
|
|
ULONG Length;
|
|
ULONG DiskLayoutFlags;
|
|
// Number of last session
|
|
ULONG LastSession;
|
|
ULONG FirstTrackNum;
|
|
ULONG LastTrackNum;
|
|
// First & Last LBA of the last session
|
|
ULONG FirstLBA;
|
|
ULONG LastLBA;
|
|
// Last writable LBA
|
|
ULONG LastPossibleLBA;
|
|
// First writable LBA
|
|
ULONG NWA;
|
|
// sector type map
|
|
struct _MediaTrackMap* TrackMap;
|
|
//
|
|
ULONG BlockSize;
|
|
ULONG WriteBlockSize;
|
|
// disk state
|
|
BOOLEAN FP_disc;
|
|
UCHAR OPCNum;
|
|
UCHAR MediaClassEx;
|
|
UCHAR DiscStat;
|
|
ULONG PhSerialNumber;
|
|
UCHAR PhErasable;
|
|
UCHAR PhDiskType;
|
|
UCHAR MRWStatus;
|
|
} GET_DISK_LAYOUT_USER_OUT, *PGET_DISK_LAYOUT_USER_OUT;
|
|
|
|
#define DiskLayout_FLAGS_TRACKMAP (0x00002000)
|
|
#define DiskLayout_FLAGS_RAW_DISK (0x00040000)
|
|
|
|
//**********************************************************************************************
|
|
|
|
// Error codes returned by IOCTL_CDRW_GEL_LAST_ERROR
|
|
|
|
//#ifndef CDRW_ERR_NO_ERROR
|
|
|
|
#define CDRW_ERR_NO_ERROR 0x0000
|
|
#define CDRW_ERR_WRITE_IN_PROGRESS_BUSY 0x0001
|
|
#define CDRW_ERR_FORMAT_IN_PROGRESS_BUSY 0x0002
|
|
#define CDRW_ERR_CLOSE_IN_PROGRESS_BUSY 0x0003
|
|
#define CDRW_ERR_BAD_ADDR_ALIGNMENT 0x0004
|
|
#define CDRW_ERR_BAD_SIZE_ALIGNMENT 0x0005
|
|
#define CDRW_ERR_STREAM_LOSS 0x0006
|
|
#define CDRW_ERR_TEST_WRITE_UNSUPPORTED 0x0007
|
|
#define CDRW_ERR_UNHANDLED_WRITE_TYPE 0x0008
|
|
#define CDRW_ERR_CANT_ALLOC_TMP_BUFFER 0x0009
|
|
#define CDRW_ERR_BUFFER_IS_FULL 0x000a
|
|
#define CDRW_ERR_VERIFY_REQUIRED 0x000b
|
|
#define CDRW_ERR_PLAY_IN_PROGRESS_BUSY 0x000c
|
|
#define CDRW_ERR_TOO_LONG_BLOCK_TO_TRANSFER 0x000d
|
|
#define CDRW_ERR_INWALID_WRITE_PARAMETERS 0x000e // use SET_WRITE_PARAMS properly
|
|
#define CDRW_ERR_INVALID_IO_BUFFER_ADDRESS 0x000f
|
|
#define CDRW_ERR_INVALID_INPUT_BUFFER_SIZE 0x0010
|
|
#define CDRW_ERR_INVALID_OUTPUT_BUFFER_SIZE 0x0011
|
|
#define CDRW_ERR_UNRECOGNIZED_MEDIA 0x0012
|
|
#define CDRW_ERR_MEDIA_WRITE_PROTECTED 0x0013
|
|
#define CDRW_ERR_NO_MEDIA 0x0014
|
|
#define CDRW_ERR_TRAY_OPEN 0x0015
|
|
#define CDRW_ERR_MEDIA_NOT_APPENDABLE 0x0016
|
|
#define CDRW_ERR_INVALID_LBA 0x0017
|
|
#define CDRW_ERR_INVALID_FIXED_PACKET_SIZE 0x0018
|
|
#define CDRW_ERR_INVALID_WRITE_TYPE_FOR_MEDIA 0x0019
|
|
#define CDRW_ERR_CUE_SHEET_REQUIRED 0x001a // you sould send cue sheet before SAO
|
|
#define CDRW_ERR_CANT_DEINIT_IN_CLASS_MODE 0x001b // there is no underlayered driver
|
|
#define CDRW_ERR_INVALID_FORMAT_UNIT_SETTINGS 0x001c // use SET_WRITE_PARAMS properly before
|
|
// calling FormatUnit
|
|
#define CDRW_ERR_UNHANDLED_FORMAT_UNIT_MODE 0x001d // this mode is not supported by
|
|
// Workaround module
|
|
#define CDRW_ERR_CANT_READ_BUFFER_CAPACITY 0x001e
|
|
#define CDRW_ERR_DEVICE_WRITE_ERROR 0x001f
|
|
#define CDRW_ERR_UNHANDLED_IOCTL 0x0020
|
|
#define CDRW_ERR_UNHANDLED_FORMAT_WORKAROUND_MODE 0x0021 // check your Registry settings
|
|
#define CDRW_ERR_DOOR_LOCKED_BUSY 0x0022
|
|
#define CDRW_ERR_MAGIC_WORD_REQUIRED 0x0023
|
|
#define CDRW_ERR_INVALID_SECTOR_MODE 0x0024
|
|
#define CDRW_ERR_DVD_LICENSE_VIOLATION 0x0025
|
|
#define CDRW_ERR_INVALID_DVD_KEY_TYPE 0x0026
|
|
#define CDRW_ERR_INVALID_DVD_REGION_CODE 0x0027
|
|
#define CDRW_ERR_PAGE_IS_NOT_SUPPORTED 0x0028
|
|
#define CDRW_ERR_STD_FORMAT_REQUIRED 0x0029
|
|
//#define CDRW_ERR_ 0x00
|
|
//#define CDRW_ERR_ 0x00
|
|
//#define CDRW_ERR_ 0x00
|
|
//#define CDRW_ERR_ 0x00
|
|
|
|
//#endif
|
|
|
|
// Registry keys
|
|
#define REG_TIMEOUT_NAME_USER ("TimeOutValue")
|
|
#define REG_AUTORUN_NAME_USER ("Autorun")
|
|
#define REG_LOADMODE_NAME_USER ("LoadMode")
|
|
|
|
#define LOADMODE_CDRW_ONLY 0
|
|
#define LOADMODE_ALWAYS 1
|
|
#define LOADMODE_NEVER 2
|
|
|
|
#define REG_PACKETSIZE_NAME_USER ("PacketSize") // Initial packet size (FP)
|
|
|
|
#define PACKETSIZE_STREAM 0
|
|
#define PACKETSIZE_UDF 32
|
|
|
|
#ifndef WITHOUT_FORMATTER
|
|
#define REG_FORMATUNIT_NAME_USER ("FormatUnitMode") // FORMAT_UNIT workaround mode
|
|
|
|
#define FORMATUNIT_FP 0 // simulation via FP
|
|
#define FORMATUNIT_STD 1
|
|
#endif //WITHOUT_FORMATTER
|
|
|
|
#define REG_R_SPLIT_SIZE_NAME_USER ("ReadSplitSize") // Read request spliting limit
|
|
#define REG_W_SPLIT_SIZE_NAME_USER ("WriteSplitSize") // Write request spliting limit
|
|
|
|
#define REG_CDR_SIMULATION_NAME_USER ("CdRSimulationMode") // Influence on READ_DISC_INFO
|
|
// capability check on startup
|
|
#define CDR_SIMULATION_CDROM 0
|
|
#define CDR_SIMULATION_ALWAYS 1
|
|
#define CDR_SIMULATION_NEVER 2
|
|
|
|
#define REG_SPEEDMODE_NAME_USER ("SpeedDetectionMode")
|
|
|
|
#define SPEEDMODE_ASSUME_OK 0
|
|
#define SPEEDMODE_REREAD 1
|
|
|
|
//#define REG_MAX_WRITE_SPEED_R_NAME_USER ("MaxWriteSpeedCDR")
|
|
//#define REG_MAX_WRITE_SPEED_RW_NAME_USER ("MaxWriteSpeedCDRW")
|
|
|
|
//#define REG_SIMULATION_TABLE_NAME_USER ("WModeSimulationTable") // via Raw
|
|
|
|
#define REG_WMODE_SIMULATION_NAME_USER ("WModeSimulation") // via Raw
|
|
#define WMODE_SIMULATION_ON 1
|
|
#define WMODE_SIMULATION_OFF 0
|
|
#define WMODE_ASSUME_OK 2
|
|
|
|
#define REG_SYNC_PACKETS_NAME_USER ("SyncPacketsMode")
|
|
#define SYNC_PACKETS_ALWAYS 0
|
|
#define SYNC_PACKETS_RESET_DRV 1
|
|
#define SYNC_PACKETS_NEVER 2
|
|
#define SYNC_PACKETS_FP 3
|
|
#define SYNC_PACKETS_DISABLED 4
|
|
#define SYNC_PACKETS_VP_ONLY 5
|
|
#define SYNC_PACKETS_BY_W_THROUGH 6
|
|
|
|
#define REG_ASSURE_READY_NAME_USER ("AssureReadiness")
|
|
#define ASSURE_READY_TEST_UNIT 0
|
|
#define ASSURE_READY_DELAY_100 1
|
|
#define ASSURE_READY_NONE 2
|
|
|
|
#define REG_WAIT_PACKETS_NAME_USER ("WaitPackets")
|
|
#define WAIT_PACKETS_ALWAYS 0
|
|
#define WAIT_PACKETS_STREAM 1
|
|
|
|
#define REG_BAD_RW_SEEK_NAME_USER ("BadRWSeek")
|
|
|
|
#define REG_ALLOW_PACKET_ON_CDR_NAME_USER ("AllowPacketOnCdR")
|
|
#define ALLOW_PACKET_ON_CDR_OFF 0
|
|
#define ALLOW_PACKET_ON_CDR_ON 1
|
|
|
|
#define REG_MAX_READY_RETRY_NAME_USER ("MaxReadyRetry")
|
|
|
|
#define REG_BAD_DVD_READ_TRACK_INFO_NAME_USER ("DvdBadReadTrackInfo")
|
|
#define REG_BAD_DVD_READ_DISC_INFO_NAME_USER ("DvdBadReadDiscInfo")
|
|
#define REG_BAD_DVD_READ_CAPACITY_NAME_USER ("DvdBadReadCapacity")
|
|
#define REG_BAD_DVD_LAST_LBA_NAME_USER ("DvdBadLastLba")
|
|
#define REG_BAD_DVD_LAST_LBA_NAME_USER ("DvdBadLastLba")
|
|
|
|
#define REG_FULL_BLANK_ON_FORMAT_NAME_USER ("FullEraseBeforeFormat")
|
|
|
|
#define DEFAULT_LAST_LBA_FP_CD 276159
|
|
#define DEFAULT_LAST_LBA_DVD 0x23053f
|
|
#define DEFAULT_LAST_LBA_BD (25*1000*1000/2-1)
|
|
|
|
|
|
#pragma pack(pop)
|
|
|
|
#endif //__CDRW_PUBLIC_H__
|