reactos/drivers/storage/ide/uniata/scsi.h
2021-06-11 15:33:08 +03:00

2939 lines
83 KiB
C

/*++
Copyright (c) 2002-2005 Alexandr A. Telyatnikov (Alter)
Module Name:
scsi.h
Abstract:
This file contains SCSI protocol definitions
Author:
Alexander A. Telyatnikov (Alter)
Environment:
kernel mode only
Notes:
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Revision History:
--*/
#ifndef __CDRW_DEVICE_H__
#define __CDRW_DEVICE_H__
#include "srb.h"
#pragma pack(push, 1)
// Command Descriptor Block. Passed by SCSI controller chip over the SCSI bus
typedef union _CDB {
// Generic 6-Byte CDB
struct _CDB6 {
UCHAR OperationCode;
UCHAR Immediate : 1;
UCHAR CommandUniqueBits : 4;
UCHAR Lun : 3;
UCHAR CommandUniqueBytes[3];
UCHAR Link : 1;
UCHAR Flag : 1;
UCHAR Reserved : 4;
UCHAR VendorUnique : 2;
} CDB6, *PCDB6;
struct _REQUEST_SENSE {
UCHAR OperationCode;
UCHAR Reserved0 : 5;
UCHAR Lun : 3;
UCHAR Reserved1[2];
UCHAR AllocationLength;
UCHAR Link : 1;
UCHAR Flag : 1;
UCHAR Reserved2 : 6;
} REQUEST_SENSE, *PREQUEST_SENSE;
// Standard 6-byte CDB
struct _CDB6READWRITE {
UCHAR OperationCode;
UCHAR LBA2 : 5;
UCHAR Lun : 3;
UCHAR LBA0[2];
UCHAR NumOfBlocks;
UCHAR Control;
} CDB6READWRITE, *PCDB6READWRITE;
// SCSI Inquiry CDB
struct _CDB6INQUIRY {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR PageCode;
UCHAR IReserved;
UCHAR AllocationLength;
UCHAR Control;
} CDB6INQUIRY, *PCDB6INQUIRY;
// SCSI Format CDB
struct _ERASE {
UCHAR OperationCode;
UCHAR Long : 1;
UCHAR Immediate : 1;
UCHAR Reserved1 : 3;
UCHAR Lun : 3;
UCHAR Reserved2[3];
UCHAR Control;
} ERASE, *PERASE;
struct _ERASE10 {
UCHAR OperationCode;
UCHAR Reserved : 1;
UCHAR Immediate : 1;
UCHAR ERA : 1;
UCHAR Reserved1 : 2;
UCHAR Lun : 3;
UCHAR LBA[4];
UCHAR Reserved2;
UCHAR TransferBlocks[2];
UCHAR Control;
} ERASE10, *PERASE10;
#define FormatUnit_Code_Mask 0x07
#define FormatUnit_Cmp 0x08
#define FormatUnit_Fmt 0x10
struct _CDB6FORMAT {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR FormatCode : 3;
UCHAR Cmp:1;
UCHAR Fmt:1;
UCHAR Lun : 3;
} Fields;
} Byte1;
UCHAR FReserved1;
UCHAR Interleave[2];
UCHAR FReserved2;
} CDB6FORMAT, *PCDB6FORMAT;
// Standard 10-byte CDB
struct _CDB10 {
UCHAR OperationCode;
UCHAR RelativeAddress : 1;
UCHAR Reserved1 : 2;
UCHAR ForceUnitAccess : 1;
UCHAR DisablePageOut : 1;
UCHAR Lun : 3;
UCHAR LBA[4];
UCHAR Reserved2;
UCHAR TransferBlocks[2];
UCHAR Control;
} CDB10, *PCDB10;
// Service Action 16-byte CDB
struct _SERVICE_ACTION16 {
UCHAR OperationCode; // 0x9E
UCHAR ServiceAction : 5;
UCHAR Reserved1 : 3;
UCHAR Data[14];
} SERVICE_ACTION16, *PSERVICE_ACTION16;
// CD Rom Audio CDBs
#define PauseResume_Pause 0x00
#define PauseResume_Resume 0x01
struct _PAUSE_RESUME {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR Reserved2[6];
UCHAR Action;
UCHAR Control;
} PAUSE_RESUME, *PPAUSE_RESUME;
// Read Table of Contents (TOC)
#define ReadTOC_Format_Mask 0x0f
#define ReadTOC_Format_TOC 0x00
#define ReadTOC_Format_SesInfo 0x01
#define ReadTOC_Format_FullTOC 0x02
#define ReadTOC_Format_PMA 0x03
#define ReadTOC_Format_ATIP 0x04
#define ReadTOC_Format_CdText 0x05
struct _READ_TOC {
UCHAR OperationCode;
UCHAR Reserved0 : 1;
UCHAR Msf : 1; // HMSF MMC-3
UCHAR Reserved1 : 3;
UCHAR Lun : 3;
union {
UCHAR Flags;
struct {
UCHAR Format : 4;
UCHAR Reserved : 4;
} Fields;
} Byte2;
UCHAR Reserved2[3];
UCHAR Start_TrackSes;;
UCHAR AllocationLength[2];
UCHAR Control : 6;
UCHAR Format : 2;
} READ_TOC, *PREAD_TOC;
// Play Audio MSF
struct _PLAY_AUDIO_MSF {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR Reserved2;
UCHAR StartingMSF[3];
UCHAR EndingMSF[3];
UCHAR Control;
} PLAY_AUDIO_MSF, *PPLAY_AUDIO_MSF;
// Read SubChannel Data
#define SubChannel_SubQ_Header 0x00
#define SubChannel_SubQ_Block 0x01
struct _SUBCHANNEL {
UCHAR OperationCode;
UCHAR Reserved0 : 1;
UCHAR Msf : 1;
UCHAR Reserved1 : 3;
UCHAR Lun : 3;
UCHAR Reserved2 : 6;
UCHAR SubQ : 1;
UCHAR Reserved3 : 1;
UCHAR Format;
UCHAR Reserved4[2];
UCHAR TrackNumber;
UCHAR AllocationLength[2];
UCHAR Control;
} SUBCHANNEL, *PSUBCHANNEL;
// Read CD (by LBA/MSF). Used by Atapi for raw sector reads.
#define ReadCD_SecType_Mask 0x1c
#define ReadCD_SecType_Any 0x00
#define ReadCD_SecType_CDDA 0x04
#define ReadCD_SecType_M1 0x08
#define ReadCD_SecType_M2 0x0c
#define ReadCD_SecType_M2F1 0x10
#define ReadCD_SecType_M2F2 0x14
struct _READ_CD_MSF {
UCHAR OperationCode;
UCHAR Reserved0 : 2;
UCHAR ExpectedSectorType : 3;
UCHAR Reserved1 : 3;
UCHAR Reserved2;
UCHAR Starting_MSF[3];
UCHAR Ending_MSF[3];
UCHAR Reserved3 : 1;
UCHAR ErrorFlags : 2;
UCHAR IncludeEDC : 1;
UCHAR IncludeUserData : 1;
UCHAR HeaderCode : 2;
UCHAR IncludeSyncData : 1;
UCHAR SubChannelSelection : 3;
UCHAR Reserved4 : 5;
UCHAR Control;
} READ_CD_MSF, *PREAD_CD_MSF;
struct _READ_CD {
UCHAR OperationCode;
UCHAR Reserved0 : 2;
UCHAR ExpectedSectorType : 3;
UCHAR Reserved1 : 3;
UCHAR LBA[4];
UCHAR NumOfBlocks[3];
UCHAR Reserved3 : 1;
UCHAR ErrorFlags : 2;
UCHAR IncludeEDC : 1;
UCHAR IncludeUserData : 1;
UCHAR HeaderCode : 2;
UCHAR IncludeSyncData : 1;
UCHAR SubChannelSelection : 3;
UCHAR Reserved4 : 5;
UCHAR Control;
} READ_CD, *PREAD_CD;
#define WriteCd_RELADR 0x01
#define WriteCd_FUA 0x08
#define WriteCd_DPO 0x10
struct _WRITE_CD {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR RELADR : 1;
UCHAR Reserved0 : 2;
UCHAR FUA : 1;
UCHAR DPO : 1;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR LBA [4];
UCHAR Reserved1;
UCHAR NumOfBlocks [2];
UCHAR Reserved2 [3];
} WRITE_CD, *PWRITE_CD;
// Mode sense
struct _MODE_SENSE {
UCHAR OperationCode;
UCHAR Reserved1 : 3;
UCHAR Dbd : 1;
UCHAR Reserved2 : 1;
UCHAR Lun : 3;
UCHAR PageCode : 6;
UCHAR Pc : 2;
UCHAR Reserved3;
UCHAR AllocationLength;
UCHAR Control;
} MODE_SENSE, *PMODE_SENSE;
struct _MODE_SENSE10 {
UCHAR OperationCode;
UCHAR Reserved1 : 3;
UCHAR Dbd : 1;
UCHAR Reserved2 : 1;
UCHAR Lun : 3;
UCHAR PageCode : 6;
UCHAR Pc : 2;
UCHAR Reserved3[4];
UCHAR AllocationLength[2];
UCHAR Control;
} MODE_SENSE10, *PMODE_SENSE10;
// Mode select
struct _MODE_SELECT {
UCHAR OperationCode;
UCHAR SPBit : 1;
UCHAR Reserved1 : 3;
UCHAR PFBit : 1;
UCHAR Lun : 3;
UCHAR Reserved2[2];
UCHAR ParameterListLength;
UCHAR Control;
} MODE_SELECT, *PMODE_SELECT;
struct _MODE_SELECT10 {
UCHAR OperationCode;
UCHAR SPBit : 1;
UCHAR Reserved1 : 3;
UCHAR PFBit : 1;
UCHAR Lun : 3;
UCHAR Reserved2[5];
UCHAR ParameterListLength[2];
UCHAR Control;
} MODE_SELECT10, *PMODE_SELECT10;
struct _LOGSENSE {
UCHAR OperationCode;
UCHAR SPBit : 1;
UCHAR PPCBit : 1;
UCHAR Reserved1 : 3;
UCHAR Lun : 3;
UCHAR PageCode : 6;
UCHAR PCBit : 2;
UCHAR Reserved2;
UCHAR Reserved3;
UCHAR ParameterPointer[2]; // [0]=MSB, [1]=LSB
UCHAR AllocationLength[2]; // [0]=MSB, [1]=LSB
UCHAR Control;
} LOGSENSE, *PLOGSENSE;
struct _SEEK {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR LBA[4];
UCHAR Reserved2[3];
UCHAR Control;
} SEEK, *PSEEK;
#define StartStop_Start 0x01
#define StartStop_Load 0x02
struct _START_STOP {
UCHAR OperationCode;
UCHAR Immediate: 1;
UCHAR Reserved1 : 4;
UCHAR Lun : 3;
UCHAR Reserved2;
UCHAR FormatLayerNumber : 2;
UCHAR Reserved2_2 : 6;
UCHAR Start : 1;
UCHAR LoadEject : 1;
UCHAR FL : 1;
UCHAR Reserved3 : 1;
UCHAR PowerConditions : 4;
UCHAR Control;
} START_STOP, *PSTART_STOP;
#define StartStop_Power_NoChg 0x00
#define StartStop_Power_Idle 0x02
#define StartStop_Power_Standby 0x03
#define StartStop_Power_Sleep 0x05
struct _MEDIA_REMOVAL {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR Reserved2[2];
UCHAR Prevent;
UCHAR Control;
} MEDIA_REMOVAL, *PMEDIA_REMOVAL;
struct _READ_FORMAT_CAPACITIES {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR Reserved0 : 5;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR Reserved0[5];
UCHAR AllocationLength[2];
UCHAR Control;
} READ_FORMAT_CAPACITIES, *PREAD_FORMAT_CAPACITIES;
// Atapi 2.5 Changer 12-byte CDBs
#define LoadUnload_Start 0x01
#define LoadUnload_Load 0x02
struct _LOAD_UNLOAD {
UCHAR OperationCode;
UCHAR Immediate : 1;
UCHAR Reserved1 : 7;
UCHAR Reserved2[2];
UCHAR Start : 1;
UCHAR LoadEject : 1;
UCHAR Reserved3: 6;
UCHAR Reserved4[3];
UCHAR Slot;
UCHAR Reserved5[3];
} LOAD_UNLOAD, *PLOAD_UNLOAD;
struct _MECH_STATUS {
UCHAR OperationCode;
UCHAR Reserved0[7];
UCHAR AllocationLength[2];
UCHAR Reserved2[2];
} MECH_STATUS, *PMECH_STATUS;
struct _LOCK_DOOR {
UCHAR OperationCode;
UCHAR Reserved0[9];
} LOCK_DOOR, *PLOCK_DOOR;
#define EventStat_Immed 0x01
#define EventStat_Class_OpChange 0x02
#define EventStat_Class_PM 0x04
#define EventStat_Class_ExternalReq 0x08
#define EventStat_Class_Media 0x10
#define EventStat_Class_MultiInit 0x20
#define EventStat_Class_DevBusy 0x40
struct _GET_EVENT_STATUS {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR Immed : 1;
UCHAR Reserved0 : 7;
} Fields;
} Byte1;
UCHAR Reserved0[2];
UCHAR NotificationClass;
UCHAR Reserved1[2];
UCHAR AllocationLength[2];
UCHAR Control;
} GET_EVENT_STATUS, *PGET_EVENT_STATUS;
struct _READ_DISC_INFO {
UCHAR OperationCode;
UCHAR Reserved0[6];
UCHAR AllocationLength[2];
UCHAR Reserved2[3];
} READ_DISC_INFO, *PREAD_DISC_INFO;
#define ReadTrackInfo_Type_Mask 0x01
#define ReadTrackInfo_Type_LBA 0x00
#define ReadTrackInfo_Type_Track 0x01
#define ReadTrackInfo_LastTrk 0xff
struct _READ_TRACK_INFO {
UCHAR OperationCode;
UCHAR Track : 1;
UCHAR Reserved0 : 7;
UCHAR LBA_TrkNum [4];
UCHAR Reserved1;
UCHAR AllocationLength[2];
UCHAR Reserved2[3];
} READ_TRACK_INFO, *PREAD_TRACK_INFO;
#define ReadTrackInfo3_Type_Mask 0x03
#define ReadTrackInfo3_Type_LBA ReadTrackInfo_Type_LBA
#define ReadTrackInfo3_Type_Track ReadTrackInfo_Type_Track
#define ReadTrackInfo3_Type_Ses 0x02
#define ReadTrackInfo3_LastTrk ReadTrackInfo_LastTrk
#define ReadTrackInfo3_DiscLeadIn 0x00 // for Track type
struct _READ_TRACK_INFO_3 {
UCHAR OperationCode;
UCHAR DataType : 2;
UCHAR Reserved0 : 6;
UCHAR LBA_TrkNum [4];
UCHAR Reserved1;
UCHAR AllocationLength[2];
UCHAR Reserved2[3];
} READ_TRACK_INFO_3, *PREAD_TRACK_INFO_3;
struct _RESERVE_TRACK {
UCHAR OperationCode;
UCHAR Reserved0[4];
UCHAR Size[4];
UCHAR Reserved2[3];
} RESERVE_TRACK, *PRESERVE_TRACK;
#define CloseTrkSes_Immed 0x01
#define CloseTrkSes_Trk 0x01
#define CloseTrkSes_Ses 0x02
#define CloseTrkSes_LastTrkSes 0xff
#define CloseTrkSes_Delay DEF_I64(3100000000) // 310 s
struct _CLOSE_TRACK_SESSION {
UCHAR OperationCode;
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 Reserved1 [2];
UCHAR TrackNum;
UCHAR Reserved2 [6];
} CLOSE_TRACK_SESSION, *PCLOSE_TRACK_SESSION;
struct _SET_CD_SPEED {
UCHAR OperationCode;
UCHAR Reserved0;
UCHAR ReadSpeed [2]; // Kbyte/sec
UCHAR WriteSpeed [2]; // Kbyte/sec
UCHAR Reserved1[6];
} SET_CD_SPEED, *PSET_CD_SPEED;
#define SyncCache_RELADR 0x01
#define SyncCache_Immed 0x02
struct _SYNCHRONIZE_CACHE {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR RELADR : 1;
UCHAR Immed : 1;
UCHAR Reserved0 : 6; // All these are unused by drive
} Fields;
} Byte1;
UCHAR LBA [4];
UCHAR Reserved1;
UCHAR NumOfBlocks [2];
UCHAR Reserved2 [3];
/*
UCHAR Unused [11];*/
} SYNCHRONIZE_CACHE, *PSYNCHRONIZE_CACHE;
#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
struct _BLANK_MEDIA {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR BlankType : 3;
UCHAR Reserved0 : 1;
UCHAR Immed : 1;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR StartAddr_TrkNum [4];
UCHAR Reserved2 [6];
} BLANK_MEDIA, *PBLANK_MEDIA;
#define SendKey_ReportAGID 0x00
#define SendKey_ChallengeKey 0x01
#define SendKey_Key1 0x02
#define SendKey_Key2 0x03
#define SendKey_TitleKey 0x04
#define SendKey_ReportASF 0x05
#define SendKey_InvalidateAGID 0x3F
struct _SEND_KEY {
UCHAR OperationCode;
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR Reserved2[6];
UCHAR ParameterListLength[2];
UCHAR KeyFormat : 6;
UCHAR AGID : 2;
UCHAR Control;
} SEND_KEY, *PSEND_KEY;
struct _REPORT_KEY {
UCHAR OperationCode; // 0xA4
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR LBA[4]; // for title key
UCHAR Reserved2[2];
UCHAR AllocationLength[2];
UCHAR KeyFormat : 6;
UCHAR AGID : 2;
UCHAR Control;
} REPORT_KEY, *PREPORT_KEY;
struct _READ_DVD_STRUCTURE {
UCHAR OperationCode; // 0xAD
UCHAR Reserved1 : 5;
UCHAR Lun : 3;
UCHAR RMDBlockNumber[4];
UCHAR LayerNumber;
UCHAR Format;
UCHAR AllocationLength[2]; // [0]=MSB, [1]=LSB
UCHAR Reserved3 : 6;
UCHAR AGID : 2;
UCHAR Control;
} READ_DVD_STRUCTURE, *PREAD_DVD_STRUCTURE;
struct _READ_BUFFER_CAPACITY {
UCHAR OperationCode;
UCHAR Reserved0 [6];
UCHAR AllocationLength[2];
UCHAR Reserved1 [3];
} READ_BUFFER_CAPACITY, *PREAD_BUFFER_CAPACITY;
struct _GET_CONFIGURATION {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR RT : 2;
UCHAR Reserved0 : 6;
} Fields;
} Byte1;
UCHAR StartFeatureNum [2];
UCHAR Reserved0 [3];
UCHAR AllocationLength[2];
UCHAR Control;
} GET_CONFIGURATION, *PGET_CONFIGURATION;
struct _SET_READ_AHEAD {
UCHAR OperationCode;
UCHAR Reserved0;
UCHAR TriggerLBA[4];
UCHAR ReadAheadLBA[4];
UCHAR Reserved1;
UCHAR Control;
} SET_READ_AHEAD, *PSET_READ_AHEAD;
struct _REPORT_LUNS {
UCHAR OperationCode; // 0xA0 - SCSIOP_REPORT_LUNS
UCHAR Reserved1[5];
UCHAR AllocationLength[4];
UCHAR Reserved2[1];
UCHAR Control;
} REPORT_LUNS, *PREPORT_LUNS;
#define SendOpc_DoOpc 0x01
struct _SEND_OPC_INFO {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR DoOpc : 1;
UCHAR Reserved0 : 4;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR Reserved0 [5];
UCHAR AllocationLength[2];
UCHAR Control;
} SEND_OPC_INFO, *PSEND_OPC_INFO;
struct _SEND_CUE_SHEET {
UCHAR OperationCode;
UCHAR Reserved0 [5];
UCHAR AllocationLength[3];
UCHAR Control;
} SEND_CUE_SHEET, *PSEND_CUE_SHEET;
struct _CDB12 {
UCHAR OperationCode;
UCHAR Params[11];
} CDB12, *PCDB12;
struct _CDB12READWRITE {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR RELADR : 1;
UCHAR Reserved0 : 2;
UCHAR FUA : 1;
UCHAR DPO : 1;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR LBA [4];
UCHAR NumOfBlocks [4];
UCHAR Reserved1[2];
} CDB12READWRITE, *PCDB12READWRITE;
struct _CDB16READWRITE {
UCHAR OperationCode;
union {
UCHAR Flags;
struct {
UCHAR RELADR : 1;
UCHAR Reserved0 : 2;
UCHAR FUA : 1;
UCHAR DPO : 1;
UCHAR Reserved1 : 3;
} Fields;
} Byte1;
UCHAR LBA [8];
UCHAR NumOfBlocks [4];
UCHAR GroupNumber:5;
UCHAR Reserved14_5_6:2;
UCHAR Restricted:1; // MMC-4
UCHAR Reserved1[1];
} CDB16READWRITE, *PCDB16READWRITE;
// Plextor Read CD-DA
struct _PLXTR_READ_CDDA {
UCHAR OperationCode;
UCHAR Reserved0 : 5;
UCHAR Lun :3;
UCHAR LBA[4];
UCHAR TransferBlock[4];
UCHAR SubCode;
UCHAR Control;
} PLXTR_READ_CDDA, *PPLXTR_READ_CDDA;
// NEC Read CD-DA
struct _NEC_READ_CDDA {
UCHAR OperationCode;
UCHAR Reserved0;
UCHAR LBA[4];
UCHAR Reserved1;
UCHAR TransferBlock[2];
UCHAR Control;
} NEC_READ_CDDA, *PNEC_READ_CDDA;
} CDB, *PCDB;
// Command Descriptor Block constants.
#define CDB6GENERIC_LENGTH 6
#define CDB10GENERIC_LENGTH 10
#define CDB12GENERIC_LENGTH 12
#define MAXIMUM_NUMBER_OF_TRACKS 100
#define MAXIMUM_NUMBER_OF_SESSIONS 1024 //maximal number of entries in Read Full TOC
#define SETBITON 1
#define SETBITOFF 0
// Mode Sense/Select page constants.
#define MODE_PAGE_ERROR_RECOVERY 0x01
#define MODE_PAGE_WRITE_PARAMS 0x05
#define MODE_PAGE_VERIFY_ERROR 0x07 // shall not be used
#define MODE_PAGE_CACHING 0x08 // undocumented, but used by DirectCd
#define MODE_PAGE_MEDIUM_TYPES 0x0B // shall not be used
#define MODE_PAGE_CD_DEVICE_PARAMS 0x0D
#define MODE_PAGE_CD_AUDIO_CONTROL 0x0E
#define MODE_PAGE_POWER_CONDITION 0x1A
#define MODE_PAGE_FAIL_REPORT 0x1C
#define MODE_PAGE_TIMEOUT_AND_PROTECT 0x1D
#define MODE_PAGE_PHILIPS_SECTOR_TYPE 0x21
#define MODE_PAGE_CAPABILITIES 0x2A
#define MODE_SENSE_RETURN_ALL 0x3f
#define MODE_SENSE_CURRENT_VALUES 0x00
#define MODE_SENSE_CHANGEABLE_VALUES 0x40
#define MODE_SENSE_DEFAULT_VAULES 0x80
#define MODE_SENSE_SAVED_VALUES 0xc0
// SCSI CDB operation codes
#define SCSIOP_TEST_UNIT_READY 0x00
#define SCSIOP_REZERO_UNIT 0x01
#define SCSIOP_REWIND 0x01
#define SCSIOP_REQUEST_BLOCK_ADDR 0x02
#define SCSIOP_REQUEST_SENSE 0x03
#define SCSIOP_FORMAT_UNIT 0x04
#define SCSIOP_READ_BLOCK_LIMITS 0x05
#define SCSIOP_REASSIGN_BLOCKS 0x07
#define SCSIOP_READ6 0x08
#define SCSIOP_RECEIVE 0x08
#define SCSIOP_WRITE6 0x0A
#define SCSIOP_PRINT 0x0A
#define SCSIOP_SEND 0x0A
#define SCSIOP_SEEK6 0x0B
#define SCSIOP_TRACK_SELECT 0x0B
#define SCSIOP_SLEW_PRINT 0x0B
#define SCSIOP_SEEK_BLOCK 0x0C
#define SCSIOP_PARTITION 0x0D
#define SCSIOP_READ_REVERSE 0x0F
#define SCSIOP_WRITE_FILEMARKS 0x10
#define SCSIOP_FLUSH_BUFFER 0x10
#define SCSIOP_SPACE 0x11
#define SCSIOP_INQUIRY 0x12
#define SCSIOP_VERIFY6 0x13
#define SCSIOP_RECOVER_BUF_DATA 0x14
#define SCSIOP_MODE_SELECT 0x15
#define SCSIOP_RESERVE_UNIT 0x16
#define SCSIOP_RELEASE_UNIT 0x17
#define SCSIOP_COPY 0x18
#define SCSIOP_ERASE 0x19
#define SCSIOP_MODE_SENSE 0x1A
#define SCSIOP_START_STOP_UNIT 0x1B
#define SCSIOP_STOP_PRINT 0x1B
#define SCSIOP_LOAD_UNLOAD 0x1B
#define SCSIOP_RECEIVE_DIAGNOSTIC 0x1C
#define SCSIOP_SEND_DIAGNOSTIC 0x1D
#define SCSIOP_MEDIUM_REMOVAL 0x1E
#define SCSIOP_READ_FORMAT_CAPACITY 0x23
#define SCSIOP_READ_CAPACITY 0x25
#define SCSIOP_READ 0x28
#define SCSIOP_WRITE 0x2A
#define SCSIOP_WRITE_CD 0x2A
#define SCSIOP_SEEK 0x2B
#define SCSIOP_LOCATE 0x2B
#define SCSIOP_ERASE10 0x2C
#define SCSIOP_WRITE_VERIFY 0x2E
#define SCSIOP_VERIFY 0x2F
#define SCSIOP_SEARCH_DATA_HIGH 0x30
#define SCSIOP_SEARCH_DATA_EQUAL 0x31
#define SCSIOP_SEARCH_DATA_LOW 0x32
#define SCSIOP_SET_LIMITS 0x33
#define SCSIOP_READ_POSITION 0x34
#define SCSIOP_SYNCHRONIZE_CACHE 0x35
#define SCSIOP_COMPARE 0x39
#define SCSIOP_COPY_COMPARE 0x3A
#define SCSIOP_COPY_VERIFY 0x3A
#define SCSIOP_WRITE_DATA_BUFF 0x3B
#define SCSIOP_READ_DATA_BUFF 0x3C
#define SCSIOP_CHANGE_DEFINITION 0x40
#define SCSIOP_PLAY_AUDIO10 0x41
#define SCSIOP_READ_SUB_CHANNEL 0x42
#define SCSIOP_READ_TOC 0x43
#define SCSIOP_READ_HEADER 0x44
#define SCSIOP_PLAY_AUDIO 0x45
#define SCSIOP_GET_CONFIGURATION 0x46
#define SCSIOP_PLAY_AUDIO_MSF 0x47
#define SCSIOP_PLAY_TRACK_INDEX 0x48
#define SCSIOP_PLAY_TRACK_RELATIVE 0x49
#define SCSIOP_GET_EVENT_STATUS 0x4A
#define SCSIOP_PAUSE_RESUME 0x4B
#define SCSIOP_LOG_SELECT 0x4C
#define SCSIOP_LOG_SENSE 0x4D
#define SCSIOP_STOP_PLAY_SCAN 0x4E
#define SCSIOP_READ_DISC_INFO 0x51
#define SCSIOP_READ_TRACK_INFO 0x52
#define SCSIOP_RESERVE_TRACK 0x53
#define SCSIOP_SEND_OPC_INFO 0x54
#define SCSIOP_MODE_SELECT10 0x55
#define SCSIOP_REPAIR_TRACK 0x58 // obsolete
#define SCSIOP_READ_MASTER_CUE 0x59
#define SCSIOP_MODE_SENSE10 0x5A
#define SCSIOP_CLOSE_TRACK_SESSION 0x5B
#define SCSIOP_READ_BUFFER_CAPACITY 0x5C
#define SCSIOP_SEND_CUE_SHEET 0x5D
#define SCSIOP_READ16 0x88
#define SCSIOP_WRITE16 0x8A
#define SCSIOP_VERIFY16 0x8F
#define SCSIOP_SERVICE_ACTION16 0x9E
#define SCSIOP_SA_READ_CAPACITY16 0x10
#define SCSIOP_REPORT_LUNS 0xA0
#define SCSIOP_BLANK 0xA1
#define SCSIOP_SEND_KEY 0xA3
#define SCSIOP_REPORT_KEY 0xA4
#define SCSIOP_PLAY_AUDIO12 0xA5
#define SCSIOP_LOAD_UNLOAD_SLOT 0xA6
#define SCSIOP_SET_READ_AHEAD 0xA7
#define SCSIOP_READ12 0xA8
#define SCSIOP_WRITE12 0xAA
#define SCSIOP_VERIFY12 0xAF
#define SCSIOP_SEEK12 0xAB
#define SCSIOP_GET_PERFORMANCE 0xAC
#define SCSIOP_READ_DVD_STRUCTURE 0xAD
#define SCSIOP_WRITE_VERIFY12 0xAE
#define SCSIOP_VERIFY12 0xAF
#define SCSIOP_SET_STREAMING 0xB6
#define SCSIOP_READ_CD_MSF 0xB9
#define SCSIOP_SET_CD_SPEED 0xBB
#define SCSIOP_MECHANISM_STATUS 0xBD
#define SCSIOP_READ_CD 0xBE
#define SCSIOP_SEND_DVD_STRUCTURE 0xBF
#define SCSIOP_DOORLOCK 0xDE // lock door on removable drives
#define SCSIOP_DOORUNLOCK 0xDF // unlock door on removable drives
// If the IMMED bit is 1, status is returned as soon
// as the operation is initiated. If the IMMED bit
// is 0, status is not returned until the operation
// is completed.
#define CDB_RETURN_ON_COMPLETION 0
#define CDB_RETURN_IMMEDIATE 1
// end_ntminitape
// CDB Force media access used in extended read and write commands.
#define CDB_FORCE_MEDIA_ACCESS 0x08
// Denon CD ROM operation codes
#define SCSIOP_DENON_EJECT_DISC 0xE6
#define SCSIOP_DENON_STOP_AUDIO 0xE7
#define SCSIOP_DENON_PLAY_AUDIO 0xE8
#define SCSIOP_DENON_READ_TOC 0xE9
#define SCSIOP_DENON_READ_SUBCODE 0xEB
// Philips/Matshushita CD-R(W) operation codes
#define SCSIOP_PHILIPS_GET_NWA 0xE2
#define SCSIOP_PHILIPS_RESERVE_TRACK 0xE4
#define SCSIOP_PHILIPS_WRITE_TRACK 0xE6
#define SCSIOP_PHILIPS_LOAD_UNLOAD 0xE7
#define SCSIOP_PHILIPS_CLOSE_TRACK_SESSION 0xE9
#define SCSIOP_PHILIPS_RECOVER_BUF_DATA 0xEC
#define SCSIOP_PHILIPS_READ_SESSION_INFO 0xEE
// Plextor operation codes
#define SCSIOP_PLEXTOR_READ_CDDA 0xD8
// NEC operation codes
#define SCSIOP_NEC_READ_CDDA 0xD4
// SCSI Bus Messages
#define SCSIMESS_ABORT 0x06
#define SCSIMESS_ABORT_WITH_TAG 0x0D
#define SCSIMESS_BUS_DEVICE_RESET 0X0C
#define SCSIMESS_CLEAR_QUEUE 0X0E
#define SCSIMESS_COMMAND_COMPLETE 0X00
#define SCSIMESS_DISCONNECT 0X04
#define SCSIMESS_EXTENDED_MESSAGE 0X01
#define SCSIMESS_IDENTIFY 0X80
#define SCSIMESS_IDENTIFY_WITH_DISCON 0XC0
#define SCSIMESS_IGNORE_WIDE_RESIDUE 0X23
#define SCSIMESS_INITIATE_RECOVERY 0X0F
#define SCSIMESS_INIT_DETECTED_ERROR 0X05
#define SCSIMESS_LINK_CMD_COMP 0X0A
#define SCSIMESS_LINK_CMD_COMP_W_FLAG 0X0B
#define SCSIMESS_MESS_PARITY_ERROR 0X09
#define SCSIMESS_MESSAGE_REJECT 0X07
#define SCSIMESS_NO_OPERATION 0X08
#define SCSIMESS_HEAD_OF_QUEUE_TAG 0X21
#define SCSIMESS_ORDERED_QUEUE_TAG 0X22
#define SCSIMESS_SIMPLE_QUEUE_TAG 0X20
#define SCSIMESS_RELEASE_RECOVERY 0X10
#define SCSIMESS_RESTORE_POINTERS 0X03
#define SCSIMESS_SAVE_DATA_POINTER 0X02
#define SCSIMESS_TERMINATE_IO_PROCESS 0X11
// SCSI Extended Message operation codes
#define SCSIMESS_MODIFY_DATA_POINTER 0X00
#define SCSIMESS_SYNCHRONOUS_DATA_REQ 0X01
#define SCSIMESS_WIDE_DATA_REQUEST 0X03
// SCSI Extended Message Lengths
#define SCSIMESS_MODIFY_DATA_LENGTH 5
#define SCSIMESS_SYNCH_DATA_LENGTH 3
#define SCSIMESS_WIDE_DATA_LENGTH 2
// SCSI extended message structure
typedef struct _SCSI_EXTENDED_MESSAGE {
UCHAR InitialMessageCode;
UCHAR MessageLength;
UCHAR MessageType;
union _EXTENDED_ARGUMENTS {
struct {
UCHAR Modifier[4];
} Modify;
struct {
UCHAR TransferPeriod;
UCHAR ReqAckOffset;
} Synchronous;
struct{
UCHAR Width;
} Wide;
}ExtendedArguments;
}SCSI_EXTENDED_MESSAGE, *PSCSI_EXTENDED_MESSAGE;
// SCSI bus status codes.
#define SCSISTAT_GOOD 0x00
#define SCSISTAT_CHECK_CONDITION 0x02
#define SCSISTAT_CONDITION_MET 0x04
#define SCSISTAT_BUSY 0x08
#define SCSISTAT_INTERMEDIATE 0x10
#define SCSISTAT_INTERMEDIATE_COND_MET 0x14
#define SCSISTAT_RESERVATION_CONFLICT 0x18
#define SCSISTAT_COMMAND_TERMINATED 0x22
#define SCSISTAT_QUEUE_FULL 0x28
// Enable Vital Product Data Flag (EVPD)
// used with INQUIRY command.
#define CDB_INQUIRY_EVPD 0x01
// retry time (in deci-seconds)
#define NOT_READY_RETRY_INTERVAL 20
// Defines for format CDB
#define LUN0_FORMAT_SAVING_DEFECT_LIST 0
#define USE_DEFAULTMSB 0
#define USE_DEFAULTLSB 0
#define START_UNIT_CODE 0x01
#define STOP_UNIT_CODE 0x00
// Inquiry buffer structure. This is the data returned from the target
// after it receives an inquiry.
//
// This structure may be extended by the number of bytes specified
// in the field AdditionalLength. The defined size constant only
// includes fields through ProductRevisionLevel.
//
// The NT SCSI drivers are only interested in the first 36 bytes of data.
#define INQUIRYDATABUFFERSIZE 36
typedef struct _INQUIRYDATA {
UCHAR DeviceType : 5;
UCHAR DeviceTypeQualifier : 3;
UCHAR DeviceTypeModifier : 7;
UCHAR RemovableMedia : 1;
UCHAR Versions;
UCHAR ResponseDataFormat;
UCHAR AdditionalLength;
UCHAR Reserved[2];
UCHAR SoftReset : 1;
UCHAR CommandQueue : 1;
UCHAR Reserved2 : 1;
UCHAR LinkedCommands : 1;
UCHAR Synchronous : 1;
UCHAR Wide16Bit : 1;
UCHAR Wide32Bit : 1;
UCHAR RelativeAddressing : 1;
union {
UCHAR DeviceIdentificationString[28];
struct {
UCHAR VendorId[8];
UCHAR ProductId[16];
UCHAR ProductRevisionLevel[4];
};
};
UCHAR VendorSpecific[20];
UCHAR Reserved3[40];
} INQUIRYDATA, *PINQUIRYDATA;
// Inquiry defines. Used to interpret data returned from target as result
// of inquiry command.
// DeviceType field
#define DIRECT_ACCESS_DEVICE 0x00 // disks
#define SEQUENTIAL_ACCESS_DEVICE 0x01 // tapes
#define PRINTER_DEVICE 0x02 // printers
#define PROCESSOR_DEVICE 0x03 // scanners, printers, etc
#define WRITE_ONCE_READ_MULTIPLE_DEVICE 0x04 // worms
#define READ_ONLY_DIRECT_ACCESS_DEVICE 0x05 // cdroms
#define SCANNER_DEVICE 0x06 // scanners
#define OPTICAL_DEVICE 0x07 // optical disks
#define MEDIUM_CHANGER 0x08 // jukebox
#define COMMUNICATION_DEVICE 0x09 // network
#define LOGICAL_UNIT_NOT_PRESENT_DEVICE 0x7F
#define DEVICE_QUALIFIER_NOT_SUPPORTED 0x03
// DeviceTypeQualifier field
#define DEVICE_CONNECTED 0x00
// Sense Data Format
typedef struct _SENSE_DATA {
UCHAR ErrorCode:7;
UCHAR Valid:1;
UCHAR SegmentNumber;
UCHAR SenseKey:4;
UCHAR Reserved:1;
UCHAR IncorrectLength:1;
UCHAR EndOfMedia:1;
UCHAR FileMark:1;
UCHAR Information[4];
UCHAR AdditionalSenseLength;
UCHAR CommandSpecificInformation[4];
UCHAR AdditionalSenseCode;
UCHAR AdditionalSenseCodeQualifier;
UCHAR FieldReplaceableUnitCode;
UCHAR SenseKeySpecific[3];
} SENSE_DATA, *PSENSE_DATA;
// Default request sense buffer size
#define SENSE_BUFFER_SIZE 18
// Sense keys
#define SCSI_SENSE_NO_SENSE 0x00
#define SCSI_SENSE_RECOVERED_ERROR 0x01
#define SCSI_SENSE_NOT_READY 0x02
#define SCSI_SENSE_MEDIUM_ERROR 0x03
#define SCSI_SENSE_HARDWARE_ERROR 0x04
#define SCSI_SENSE_ILLEGAL_REQUEST 0x05
#define SCSI_SENSE_UNIT_ATTENTION 0x06
#define SCSI_SENSE_DATA_PROTECT 0x07
#define SCSI_SENSE_BLANK_CHECK 0x08
#define SCSI_SENSE_UNIQUE 0x09
#define SCSI_SENSE_COPY_ABORTED 0x0A
#define SCSI_SENSE_ABORTED_COMMAND 0x0B
#define SCSI_SENSE_EQUAL 0x0C
#define SCSI_SENSE_VOL_OVERFLOW 0x0D
#define SCSI_SENSE_MISCOMPARE 0x0E
#define SCSI_SENSE_RESERVED 0x0F
// Additional Sense codes
// SK = 0x00
#define SCSI_ADSENSE_NO_SENSE 0x00
// SK = 0x01
#define SCSI_ADSENSE_WARNING 0x0B
#define SCSI_ADSENSE_REC_DATA_NOECC 0x17
#define SCSI_ADSENSE_REC_DATA_ECC 0x18
#define SCSI_ADSENSE_ROUNDED_PARAM 0x37
#define SCSI_ADSENSE_FAILURE_PREDICTED 0x5D
#define SCSI_ADSENSE_CD_CONTROL_ERR 0x73
// SK = 0x02
#define SCSI_ADSENSE_LUN_NOT_READY 0x04
#define SCSI_ADSENSE_INCOMPATIBLE_MEDIA 0x30
#define SCSI_ADSENSE_INVALID_MEDIA SCSI_ADSENSE_INCOMPATIBLE_MEDIA // for w2k
#define SCSI_ADSENSE_NO_MEDIA_IN_DEVICE 0x3A
#define SCSI_ADSENSE_POSITION_ERROR 0x3B
#define SCSI_ADSENSE_NOT_SELF_CONFIGURED 0x3E
// SK = 0x03
#define SCSI_ADSENSE_NO_SEEK 0x02
#define SCSI_ADSENSE_NO_REFERENCE 0x06
#define SCSI_ADSENSE_CD_WRITE_ERROR 0x0C
#define SCSI_ADSENSE_CD_READ_ERROR 0x11
#define SCSI_ADSENSE_TRACK_ERROR 0x14
#define SCSI_ADSENSE_SEEK_ERROR 0x15
#define SCSI_ADSENSE_FORMAT_CORRUPTED 0x31
#define SCSI_ADSENSE_ENCLOSURE_FAILURE 0x34
#define SCSI_ADSENSE_ENCLOSURE_SERVICE 0x35
#define SCSI_ADSENSE_ERASE_ERROR 0x51
#define SCSI_ADSENSE_UNRECOVERED_TOC 0x57
#define SCSI_ADSENSE_SESSION_FIXATION 0x71
//#define SCSI_ADSENSE_CD_CONTROL_ERR 0x73 // redefinition
// SK = 0x04
#define SCSI_ADSENSE_CLEAN_REQUEST 0x00
#define SCSI_ADSENSE_SELECT 0x04
#define SCSI_ADSENSE_COMMUNICATION 0x08
#define SCSI_ADSENSE_LOST_STREAMING 0x09
#define SCSI_ADSENSE_SYNC_ERROR 0x1B
#define SCSI_ADSENSE_MECH_ERROR 0x3B
#define SCSI_ADSENSE_LUN_ERROR 0x3E
#define SCSI_ADSENSE_DIAGNOSTIC 0x40
#define SCSI_ADSENSE_INTERNAL 0x44
#define SCSI_ADSENSE_SOFT_RESET 0x46
#define SCSI_ADSENSE_SCSI_PARITY 0x47
#define SCSI_ADSENSE_CMD_PHASE 0x4A
#define SCSI_ADSENSE_DATA_PHASE 0x4B
#define SCSI_ADSENSE_SELF_CONFIG 0x4C
#define SCSI_ADSENSE_MEDIUM_REMOVAL 0x53
#define SCSI_ADSENSE_VOLTAGE 0x65
// SK = 0x05
#define SCSI_ADSENSE_AUDIO_PLAY 0x00
#define SCSI_ADSENSE_MULTISELECT 0x07
#define SCSI_ADSENSE_INVALID_PARAM_LENGTH 0x1A
#define SCSI_ADSENSE_ILLEGAL_COMMAND 0x20
#define SCSI_ADSENSE_ILLEGAL_BLOCK 0x21
#define SCSI_ADSENSE_INVALID_CDB 0x24
#define SCSI_ADSENSE_INVALID_LUN 0x25
#define SCSI_ADSENSE_INVALID_VALUE 0x26
#define SCSI_ADSENSE_WRITE_PROTECT 0x27
#define SCSI_ADSENSE_CANT_DISCONNECT 0x2B
#define SCSI_ADSENSE_INVALID_CMD_SEQUENCE 0x2C
#define SCSI_ADSENSE_INVALID_SESSION_MODE 0x30
#define SCSI_ADSENSE_SAVE_NOT_SUPPORTED 0x35
#define SCSI_ADSENSE_INVALID_BITS_IN_IDENT_MSG 0x3D
#define SCSI_ADSENSE_MSG_ERROR 0x43
//#define SCSI_ADSENSE_MEDIUM_REMOVAL 0x53 // redefinition
#define SCSI_ADSENSE_SYS_RESOURCE_FAILURE 0x55
#define SCSI_ADSENSE_OUT_OF_SPACE 0x63
#define SCSI_ADSENSE_ILLEGAL_MODE_FOR_THIS_TRACK 0x64
#define SCSI_ADSENSE_CD_COPY_ERROR 0x6F
#define SCSI_ADSENSE_INCOMPLETE_DATA 0x72
#define SCSI_ADSENSE_VENDOR_UNIQUE 0x80
#define SCSI_ADSENSE_MUSIC_AREA 0xA0
#define SCSI_ADSENSE_DATA_AREA 0xA1
#define SCSI_ADSENSE_VOLUME_OVERFLOW 0xA7
// SK = 0x06
#define SCSI_ADSENSE_LOG_OVERFLOW 0x0A
#define SCSI_ADSENSE_MEDIUM_CHANGED 0x28
#define SCSI_ADSENSE_BUS_RESET 0x29
#define SCSI_ADSENSE_PARAM_CHANGE 0x2A
#define SCSI_ADSENSE_CMD_CLEARED_BY_ANOTHER 0x2F
#define SCSI_ADSENSE_MEDIA_STATE 0x3B
#define SCSI_ADSENSE_FUNCTIONALTY_CHANGE 0x3F
#define SCSI_ADSENSE_OPERATOR 0x5A
#define SCSI_ADSENSE_MAX_LOG 0x5B
#define SCSI_ADSENSE_POWER 0x5E
// SK = 0x0B
#define SCSI_ADSENSE_READ_LOST_STREAMING 0x11
#define SCSI_ADSENSE_RESELECT_FAILURE 0x45
#define SCSI_ADSENSE_ERR_MSG_DETECTED 0x48
#define SCSI_ADSENSE_INVALID_ERR_MSG 0x49
#define SCSI_ADSENSE_TEGGED_OVERLAPPED 0x4D
#define SCSI_ADSENSE_OVERLAPPED_ATTEMPT 0x4E
// Additional sense code qualifier
#define SCSI_SENSEQ_NO_SENSE 0x00
// SK:ASC = 02:04
//#define SCSI_SENSEQ_NO_SENSE 0x00
#define SCSI_SENSEQ_CAUSE_NOT_REPORTABLE 0x00
#define SCSI_SENSEQ_BECOMING_READY 0x01
#define SCSI_SENSEQ_INIT_COMMAND_REQUIRED 0x02
#define SCSI_SENSEQ_MANUAL_INTERVENTION_REQUIRED 0x03
#define SCSI_SENSEQ_FORMAT_IN_PROGRESS 0x04
#define SCSI_SENSEQ_OPERATION_IN_PROGRESS 0x07
#define SCSI_SENSEQ_LONG_WRITE_IN_PROGRESS 0x08
// SK:ASC = 02:30
#define SCSI_SENSEQ_INCOMPATIBLE_MEDIA_INSTALLED 0x00
#define SCSI_SENSEQ_UNKNOWN_FORMAT 0x01
#define SCSI_SENSEQ_INCOMPATIBLE_FORMAT 0x02
#define SCSI_SENSEQ_CLEANING_CARTRIDGE_INSTALLED 0x03
#define SCSI_SENSEQ_WRITE_UNKNOWN_FORMAT 0x04
#define SCSI_SENSEQ_WRITE_INCOMPATIBLE_FORMAT 0x05
#define SCSI_SENSEQ_FORMAT_INCOMPATIBLE_MEDIUM 0x06
#define SCSI_SENSEQ_CLEANING_FAILURE 0x07
// SK:ASC = 02:3A
#define SCSI_SENSEQ_TRAY_CLOSED 0x01
#define SCSI_SENSEQ_TRAY_OPEN 0x02
// SK:ASC = 03:0C
#define SENSEQ_W_RECOVERY_NEEDED 0x07
#define SENSEQ_W_RECOVERY_FAILED 0x08
#define SENSEQ_LOST_STREAMING 0x09
#define SENSEQ_PADDING_BLOCKS_ADDED 0x0A
// SK:ASC = 03:72
//#define SCSI_SENSEQ_NO_SENSE 0x00
#define SCSI_SENSEQ_LEAD_IN_ERROR 0x01
#define SCSI_SENSEQ_LEAD_OUT_ERRROR 0x02
#define SCSI_SENSEQ_INCOMPLETE_TRACK 0x03
#define SCSI_SENSEQ_INCOMPLETE_RESERVED_TRACK 0x04
#define SCSI_SENSEQ_NO_MORE_RESERVATION 0x05
// SK:ASC = 05:26
#define SCSI_SENSEQ_PARAM_NOT_SUPPORTED 0x01
#define SCSI_SENSEQ_PARAM_INVALID_VALUE 0x02
#define SCSI_SENSEQ_THRESHOLD_PARAM_NOT_SUPPORTED 0x03
#define SCSI_SENSEQ_INVALID_RELEASE_OF_PERSISTENT_RESERVATION 0x04
// SK:ASC = 05:27
#define SCSI_SENSEQ_HW_PROTECTION 0x01
#define SCSI_SENSEQ_LUN_SOFT_PROTECTION 0x02
#define SCSI_SENSEQ_ASSOCIATED_PROTECTION 0x03
#define SCSI_SENSEQ_PERSIST_PROTECTION 0x04
#define SCSI_SENSEQ_PERMANENT_PROTECTION 0x05
// SK:ASC = 05:2C
#define SCSI_SENSEQ_PROGRAMM_AREA_NOT_EMPTY 0x03
#define SCSI_SENSEQ_PROGRAMM_AREA_EMPTY 0x04
// SK:ASC = 05:30
#define SCSI_SENSEQ_APP_CODE_MISSMATCH 0x08
#define SCSI_SENSEQ_NOT_FIXED_FOR_APPEND 0x09
// SK:ASC = 05:6F
#define SCSI_SENSEQ_AUTHENTICATION_FAILURE 0x00
#define SCSI_SENSEQ_KEY_NOT_PRESENT 0x01
#define SCSI_SENSEQ_KEY_NOT_ESTABLISHED 0x02
#define SCSI_SENSEQ_READ_OF_SCRAMBLED_SECTOR_WITHOUT_AUTHENTICATION 0x03
#define SCSI_SENSEQ_MEDIA_CODE_MISMATCHED_TO_LOGICAL_UNIT 0x04
#define SCSI_SENSEQ_LOGICAL_UNIT_RESET_COUNT_ERROR 0x05
// SK:ASC = 06:28
#define SCSI_SENSEQ_IMPORT_OR_EXPERT_ELEMENT_ACCESS 0x01
// SK:ASC = 06:29
#define SCSI_SENSEQ_POWER_ON 0x01
#define SCSI_SENSEQ_SCSI_BUS 0x02
#define SCSI_SENSEQ_BUS_DEVICE_FUNCTION 0x03
#define SCSI_SENSEQ_DEVICE_INTERNAL 0x04
// SK:ASC = 06:2A
#define SCSI_SENSEQ_MODE_PARAMETERS 0x01
#define SCSI_SENSEQ_LOG_PARAMETERS 0x02
#define SCSI_SENSEQ_RESERVATIONS_PREEMPTED 0x03
// SK:ASC = 06:3B
#define SCSI_SENSEQ_DESTINATION_ELEMENT_FULL 0x0D
#define SCSI_SENSEQ_SOURCE_ELEMENT_EMPTY 0x0E
#define SCSI_SENSEQ_END_OF_MEDIUM 0x0F
#define SCSI_SENSEQ_MAGAZINE_NOT_ACCESSIBLE 0x11
#define SCSI_SENSEQ_MAGAZINE_REMOVED 0x12
#define SCSI_SENSEQ_MAGAZINE_INSERTED 0x13
#define SCSI_SENSEQ_MAGAZINE_LOCKED 0x14
#define SCSI_SENSEQ_MAGAZINE_UNLOCKED 0x15
// SK:ASC = 06:3F
#define SCSI_SENSEQ_MICROCODE 0x01
#define SCSI_SENSEQ_OPERATION_DEFINITION 0x02
#define SCSI_SENSEQ_INQUIRY_DATA 0x03
// SK:ASC = 06:5A
#define SCSI_SENSEQ_MEDIUM_CHANGE_REQ 0x01
#define SCSI_SENSEQ_W_PROTECT_SELECTED 0x02
#define SCSI_SENSEQ_W_PROTECT_PERMITED 0x03
// SK:ASC = 06:5E
#define SCSI_SENSEQ_LOW_POWER_COND 0x00
#define SCSI_SENSEQ_IDLE_BY_TIMER 0x01
#define SCSI_SENSEQ_STANDBY_BY_TIMER 0x02
#define SCSI_SENSEQ_IDLE_BY_CMD 0x03
#define SCSI_SENSEQ_STANDBY_BY_CMD 0x04
#define SCSI_SENSEQ_FILEMARK_DETECTED 0x01
#define SCSI_SENSEQ_SETMARK_DETECTED 0x03
#define SCSI_SENSEQ_END_OF_MEDIA_DETECTED 0x02
#define SCSI_SENSEQ_BEGINNING_OF_MEDIA_DETECTED 0x04
// SCSI IO Device Control Codes
#define FILE_DEVICE_SCSI 0x0000001b
#define IOCTL_SCSI_EXECUTE_IN ((FILE_DEVICE_SCSI << 16) + 0x0011)
#define IOCTL_SCSI_EXECUTE_OUT ((FILE_DEVICE_SCSI << 16) + 0x0012)
#define IOCTL_SCSI_EXECUTE_NONE ((FILE_DEVICE_SCSI << 16) + 0x0013)
// SMART support in atapi
#define IOCTL_SCSI_MINIPORT_SMART_VERSION ((FILE_DEVICE_SCSI << 16) + 0x0500)
#define IOCTL_SCSI_MINIPORT_IDENTIFY ((FILE_DEVICE_SCSI << 16) + 0x0501)
#define IOCTL_SCSI_MINIPORT_READ_SMART_ATTRIBS ((FILE_DEVICE_SCSI << 16) + 0x0502)
#define IOCTL_SCSI_MINIPORT_READ_SMART_THRESHOLDS ((FILE_DEVICE_SCSI << 16) + 0x0503)
#define IOCTL_SCSI_MINIPORT_ENABLE_SMART ((FILE_DEVICE_SCSI << 16) + 0x0504)
#define IOCTL_SCSI_MINIPORT_DISABLE_SMART ((FILE_DEVICE_SCSI << 16) + 0x0505)
#define IOCTL_SCSI_MINIPORT_RETURN_STATUS ((FILE_DEVICE_SCSI << 16) + 0x0506)
#define IOCTL_SCSI_MINIPORT_ENABLE_DISABLE_AUTOSAVE ((FILE_DEVICE_SCSI << 16) + 0x0507)
#define IOCTL_SCSI_MINIPORT_SAVE_ATTRIBUTE_VALUES ((FILE_DEVICE_SCSI << 16) + 0x0508)
#define IOCTL_SCSI_MINIPORT_EXECUTE_OFFLINE_DIAGS ((FILE_DEVICE_SCSI << 16) + 0x0509)
#define IOCTL_SCSI_MINIPORT_ENABLE_DISABLE_AUTO_OFFLINE ((FILE_DEVICE_SCSI << 16) + 0x050a)
#define IOCTL_SCSI_MINIPORT_READ_SMART_LOG ((FILE_DEVICE_SCSI << 16) + 0x050b)
#define IOCTL_SCSI_MINIPORT_WRITE_SMART_LOG ((FILE_DEVICE_SCSI << 16) + 0x050c)
// Read Capacity Data - returned in Big Endian format
typedef struct _READ_CAPACITY_DATA {
ULONG LogicalBlockAddress;
ULONG BytesPerBlock;
} READ_CAPACITY_DATA, *PREAD_CAPACITY_DATA;
typedef struct _READ_CAPACITY16_DATA {
ULONGLONG LogicalBlockAddress;
ULONG BytesPerBlock;
UCHAR Prot_EN:1;
UCHAR RTO_EN:1;
UCHAR Reserved:6;
UCHAR Reserved1[20];
} READ_CAPACITY16_DATA, *PREAD_CAPACITY16_DATA;
// CD ROM Read Table Of Contents (TOC) structures
// Format 0 - Get table of contents
#define TocControl_TrkMode_Mask WParam_TrkMode_Mask
#define TocControl_TrkMode_Audio WParam_TrkMode_Audio
#define TocControl_TrkMode_Audio_PreEmph WParam_TrkMode_Audio_PreEmph
#define TocControl_TrkMode_Data WParam_TrkMode_Data
#define TocControl_TrkMode_IncrData WParam_TrkMode_IncrData
#define TocControl_TrkMode_QAudio_PreEmph WParam_TrkMode_QAudio_PreEmph
#define TocControl_TrkMode_AllowCpy WParam_TrkMode_AllowCpy
typedef struct _TOC_TRACK_INFO {
UCHAR Reserved;
UCHAR Control : 4;
UCHAR Adr : 4;
UCHAR TrackNum;
UCHAR Reserved1;
UCHAR LBA[4];
} TOC_TRACK_INFO, *PTOC_TRACK_INFO;
typedef struct _READ_TOC_HEADER {
UCHAR Length[2];
UCHAR First_TrackSes;
UCHAR Last_TrackSes;
} READ_TOC_HEADER, *PREAD_TOC_HEADER;
#define TOC_LastTrack_ID 0xAA
typedef struct _READ_TOC_TOC {
READ_TOC_HEADER Tracks;
TOC_TRACK_INFO TrackData[MAXIMUM_NUMBER_OF_TRACKS+1];
} READ_TOC_TOC, *PREAD_TOC_TOC;
// Format 1 - Session Info
typedef struct _READ_TOC_SES {
READ_TOC_HEADER Sessions;
TOC_TRACK_INFO LastSes_1stTrack; // First Track Number In Last Complete Session
} READ_TOC_SES, *PREAD_TOC_SES;
// Format 2,3 - Full TOC, PMA
// ADR = 1
#define POINT_StartPositionOfTrack_Min 0x01
#define POINT_StartPositionOfTrack_Max 0x63
#define POINT_FirstTrackNum 0xA0
#define POINT_LastTrackNum 0xA1
#define POINT_StartPositionOfLeadOut 0xA2
// ADR = 5
#define POINT_SkipInterval_Min 0x01
#define POINT_SkipInterval_Max 0x40
#define POINT_StartPositionOfNextProgramArea 0xB0
#define POINT_NumOfSkips 0xB1
#define POINT_SkipTrackAssignmet_Min 0xB2
#define POINT_SkipTrackAssignmet_Max 0xB4
#define POINT_StartPositionOfFirstLeadIn 0xC0
#define POINT_CopyOfAdditionalAreaInATIP 0xC1
typedef struct _TOC_SES_INFO {
UCHAR SesNumber;
UCHAR Control : 4;
UCHAR Adr : 4;
UCHAR TNO;
UCHAR POINT;
union {
struct {
UCHAR MSF[3];
UCHAR Reserved;
UCHAR P_MSF[3];
} GENERIC;
// ADR = 1:
//0x01 - 0x63
struct {
UCHAR ATIME[3];
UCHAR Zero;
UCHAR MSF[3];
} StartPositionOfTrack;
//0xA0
#define FullTOC_DiscType_CDDA_or_M1 WParam_SesFmt_CdRom // 0x00
#define FullTOC_DiscType_CDI WParam_SesFmt_CdI // 0x10
#define FullTOC_DiscType_CDXA_M2 WParam_SesFmt_CdRomXa // 0x20
struct {
UCHAR ATIME[3];
UCHAR Zero;
UCHAR FirstTrackNum;
UCHAR DiscType;
UCHAR Zero1;
} FirstTrackNum;
//0xA1
struct {
UCHAR ATIME[3];
UCHAR Zero;
UCHAR LastTrackNum;
UCHAR Zero1[2];
} LastTrackNum;
//0xA2
struct {
UCHAR ATIME[3];
UCHAR Zero;
UCHAR MSF[3];
} StartPositionOfLeadOut;
// ADR = 5:
//0x01 - 0x40
struct {
UCHAR End_MSF[3];
UCHAR Reserved;
UCHAR Start_MSF[3];
} SkipInterval;
//0xB0
struct {
UCHAR Program_MSF[3];
UCHAR NumOfPointers_M5;
UCHAR MaxLeadOut_MSF[3];
} StartPositionOfNextProgramArea;
//0xB1
struct {
UCHAR Zero[4];
UCHAR Intervals;
UCHAR Tracks;
UCHAR Zero1;
} NumOfSkips;
//0xB2 - 0xB4
struct {
UCHAR SkipNum[7];
} SkipTrackAsignment;
//0xC0
struct {
UCHAR OptimumRecordingPower;
UCHAR SpecInfoATIP[3];
UCHAR LeadIn_MSF[3];
} StartPositionOfFirstLeadIn;
//0xC1
struct {
UCHAR Bytes[7];
} AdditionalAreaInATIP;
} Params;
} TOC_SES_INFO, *PTOC_SES_INFO;
typedef struct _READ_TOC_FULL_TOC {
READ_TOC_HEADER Sessions;
TOC_SES_INFO SessionData[MAXIMUM_NUMBER_OF_SESSIONS];
} READ_TOC_FULL_TOC, *PREAD_TOC_FULL_TOC;
typedef READ_TOC_FULL_TOC READ_TOC_PMA;
typedef PREAD_TOC_FULL_TOC PREAD_TOC_PMA;
// Format 4 - ATIP
typedef struct _READ_TOC_ATIP {
UCHAR Length[2];
UCHAR Reserved[2];
#define ATIP_SpeedRef_Mask 0x07
#define ATIP_SpeedRef_2X 0x01
#define ATIP_WritingPower_Mask 0x07
union {
UCHAR Flags;
struct {
UCHAR SpeedRef: 3;
UCHAR Reserved: 1;
UCHAR WritingPower: 3;
UCHAR One: 1;
} Fields;
} Flags1;
#define ATIP_URU 0x40
union {
UCHAR Flags;
struct {
UCHAR Reserved: 6;
UCHAR URU: 1;
UCHAR Zero: 1;
} Fields;
} Flags2;
#define ATIP_A1 0x01 // 16-18 are valid
#define ATIP_A2 0x02 // 20-22 are valid
#define ATIP_A3 0x04 // 24-26 are valid
#define ATIP_SubType_Mask 0x38 // shall be set to zero
#define ATIP_Type_Mask 0x40
#define ATIP_Type_CDR 0x00
#define ATIP_Type_CDRW 0x40
union {
UCHAR Flags;
struct {
UCHAR A1: 1;
UCHAR A2: 1;
UCHAR A3: 1;
UCHAR SubType: 3;
UCHAR Type: 1;
UCHAR One: 1;
} Fields;
} DiscType;
UCHAR Reserved0;
UCHAR LeadIn_MSF[3];
UCHAR Reserved1;
UCHAR LeadOut_MSF[3];
UCHAR Reserved2;
#define ATIP_MinSpeedCVL_Mask 0x70
#define ATIP_MinSpeedCVL_2X 0x10
#define ATIP_MaxSpeedCVL_Mask 0x0f
#define ATIP_MaxSpeedCVL_2X 0x01
#define ATIP_MaxSpeedCVL_4X 0x02
#define ATIP_MaxSpeedCVL_6X 0x03
#define ATIP_MaxSpeedCVL_8X 0x04
union {
UCHAR Flags;
struct {
UCHAR MaxSpeedCVL: 4;
UCHAR MinSpeedCVL: 3;
UCHAR Zero: 1;
} Fields;
} Speed;
#define ATIP_Power_Y_Mask 0x0e
#define ATIP_Power_P_Mask 0x70
union {
UCHAR Flags;
struct {
UCHAR Reserved: 1;
UCHAR Y_value: 3;
UCHAR P_factor: 3;
UCHAR Zero: 1;
} Fields;
} Power;
#define ATIP_PW_ratio_Mask 0x70
union {
UCHAR Flags;
struct {
UCHAR Reserved: 4;
UCHAR P_W_ratio: 3;
UCHAR Zero: 1;
} Fields;
} ErasePower;
UCHAR Reserved3;
UCHAR A1_value[3];
UCHAR Reserved4;
UCHAR A2_value[3];
UCHAR Reserved5;
UCHAR A3_value[3];
} READ_TOC_ATIP, *PREAD_TOC_ATIP;
// Format 5 - CD-TEXT
typedef struct _CD_TEXT_PACK_DATA {
#define CdText_ID1_Title 0x80 // ID2 = 0 - Album, ID2 = 1-63 - Track
#define CdText_ID1_Performer 0x81
#define CdText_ID1_Songwriter 0x82
#define CdText_ID1_Composer 0x83
#define CdText_ID1_Arranger 0x84
#define CdText_ID1_Message 0x85
#define CdText_ID1_DiscID 0x86
#define CdText_ID1_GenreInfo 0x87
#define CdText_ID1_TOC 0x88
#define CdText_ID1_TOC2 0x89
#define CdText_ID1_Special 0x8D
#define CdText_ID1_UPC_EAN_ISRC 0x8E
#define CdText_ID1_BlockSizeInfo 0x8F
UCHAR ID1;
UCHAR ID2;
UCHAR ID3;
#define CdText_CharPos_Mask 0x0f
#define CdText_BlkNum_Mask 0x70
union {
UCHAR Flags;
struct {
UCHAR CharPos: 4;
UCHAR BlkNum: 3;
UCHAR DBCC: 1; // used to indicate Double Byte text encoding (Unicode ?)
} Fields;
} BlkNum_CharPos;
UCHAR TextData[12];
UCHAR CRC[2];
} CD_TEXT_PACK_DATA, *PCD_TEXT_PACK_DATA;
typedef struct _READ_TOC_CD_TEXT {
UCHAR Length[2];
UCHAR Reserved[2];
CD_TEXT_PACK_DATA Chunk0;
} READ_TOC_CD_TEXT, *PREAD_TOC_CD_TEXT;
// OPC block
typedef struct _OPC_INFO_BLOCK {
UCHAR Speed[2];
UCHAR OpcValue[6];
} OPC_INFO_BLOCK, *POPC_INFO_BLOCK;
// Buffer Capacity format
typedef struct _BUFFER_CAPACITY_BLOCK {
UCHAR DataLength[2];
UCHAR Reserved0[2];
UCHAR BufferLength[4];
UCHAR BlankBufferLength[4];
} BUFFER_CAPACITY_BLOCK, *PBUFFER_CAPACITY_BLOCK;
// Format Unit structures
typedef struct _FORMAT_LIST_HEADER {
UCHAR Reserved0;
#define FormatHeader_VS 0x01
#define FormatHeader_Immed 0x02
#define FormatHeader_DSP 0x04
#define FormatHeader_IP 0x08
#define FormatHeader_STPF 0x10
#define FormatHeader_DCRT 0x20
#define FormatHeader_DPRY 0x40
#define FormatHeader_FOV 0x80
union {
UCHAR Flags;
struct {
UCHAR VS: 1;
UCHAR Immed: 1;
UCHAR DSP: 1;
UCHAR IP: 1;
UCHAR STPF: 1;
UCHAR DCRT: 1;
UCHAR DPRY: 1;
UCHAR FOV: 1;
} Fields;
} Flags;
UCHAR FormatDescriptorLength[2]; // =0x0008
} FORMAT_LIST_HEADER, *PFORMAT_LIST_HEADER;
typedef struct _CDRW_FORMAT_DESCRIPTOR {
#define FormatDesc_Grow 0x40
#define FormatDesc_Ses 0x80
union {
UCHAR Flags;
struct {
UCHAR Reserved0: 6;
UCHAR Grow: 1;
UCHAR Ses: 1;
} Fields;
} Flags;
UCHAR Reserved1[3];
UCHAR FormatSize[4];
} CDRW_FORMAT_DESCRIPTOR, *PCDRW_FORMAT_DESCRIPTOR;
typedef struct _FORMAT_UNIT_PARAMETER_LIST {
FORMAT_LIST_HEADER Header;
UCHAR InitPatternDescr[4];
CDRW_FORMAT_DESCRIPTOR FormatDescr;
} FORMAT_UNIT_PARAMETER_LIST, *PFORMAT_UNIT_PARAMETER_LIST;
// define Read Format Capacities info blocks
typedef struct _CAPACITY_LIST_HEADER {
UCHAR Reserved[3];
UCHAR Length;
} CAPACITY_LIST_HEADER, *PCAPACITY_LIST_HEADER;
typedef struct _FORMATTABLE_CAPACITY_DESCRIPTOR {
UCHAR NumOfBlocks [4];
union {
UCHAR Flags;
struct {
UCHAR DescType: 2;
UCHAR Reserved0: 6;
} Fields;
} Flags;
UCHAR BlockSize [3];
} FORMATTABLE_CAPACITY_DESCRIPTOR, *PFORMATTABLE_CAPACITY_DESCRIPTOR;
typedef struct _FORMAT_CAPACITIES_DATA {
CAPACITY_LIST_HEADER Header;
} FORMAT_CAPACITIES_DATA, *PFORMAT_CAPACITIES_DATA;
// Define Event Status info blocks
typedef struct _EVENT_STAT_HEADER {
UCHAR DataLength[2];
#define EventRetStat_Class_Mask 0x07
#define EventRetStat_Class_OpChange 0x01
#define EventRetStat_Class_PM 0x02
#define EventRetStat_Class_Media 0x04
#define EventRetStat_Class_DevBusy 0x06
#define EventRetStat_NEA 0x80
union {
UCHAR Flags;
struct {
UCHAR Class: 3;
UCHAR Reserved0: 4;
UCHAR NEA: 1;
} Fields;
} Flags;
UCHAR SupportedClasses; // see command format
} EVENT_STAT_HEADER, *PEVENT_STAT_HEADER;
typedef struct _EVENT_STAT_OPERATIONAL_BLOCK {
EVENT_STAT_HEADER Header;
#define EventStat_OpEvent_Mask 0x0f
union {
UCHAR Flags;
struct {
UCHAR OpEvent : 4;
UCHAR Reserved0: 4;
} Fields;
} Byte0;
#define EventStat_OpStat_Mask 0x0f
#define EventStat_OpStat_Ready 0x00
#define EventStat_OpStat_TempBusy 0x01
#define EventStat_OpStat_Busy 0x02
union {
UCHAR Flags;
struct {
UCHAR OpStatus : 4;
UCHAR Reserved0 : 3;
UCHAR PersistentPrevent: 1;
} Fields;
} Byte1;
#define EventStat_OpReport_NoChg 0x00
#define EventStat_OpReport_Change 0x01
#define EventStat_OpReport_AddChg 0x02
#define EventStat_OpReport_Reset 0x03
#define EventStat_OpReport_FirmwareChg 0x04 // microcode change
#define EventStat_OpReport_InquaryChg 0x05
#define EventStat_OpReport_CtrlReq 0x06
#define EventStat_OpReport_CtrlRelease 0x07
UCHAR OpReport[2];
} EVENT_STAT_OPERATIONAL_BLOCK, *PEVENT_STAT_OPERATIONAL_BLOCK;
typedef struct _EVENT_STAT_PM_BLOCK {
EVENT_STAT_HEADER Header;
#define EventStat_PowerEvent_Mask 0x0f
#define EventStat_PowerEvent_NoChg 0x00
#define EventStat_PowerEvent_ChgOK 0x01
#define EventStat_PowerEvent_ChgFail 0x02
union {
UCHAR Flags;
struct {
UCHAR PowerEvent : 4;
UCHAR Reserved0 : 4;
} Fields;
} Byte0;
#define EventStat_PowerStat_Mask 0x0f
#define EventStat_PowerStat_Active 0x01
#define EventStat_PowerStat_Idle 0x02
#define EventStat_PowerStat_Standby 0x03
#define EventStat_PowerStat_Sleep 0x04
union {
UCHAR Flags;
struct {
UCHAR PowerStatus: 4;
UCHAR Reserved0 : 4;
} Fields;
} Byte1;
UCHAR Reserved0[2];
} EVENT_STAT_PM_BLOCK, *PEVENT_STAT_PM_BLOCK;
typedef struct _EVENT_STAT_MEDIA_BLOCK {
EVENT_STAT_HEADER Header;
#define EventStat_MediaEvent_Mask 0x0f
#define EventStat_MediaEvent_None 0x00
#define EventStat_MediaEvent_EjectReq 0x01
#define EventStat_MediaEvent_New 0x02
#define EventStat_MediaEvent_Removal 0x03
#define EventStat_MediaEvent_Chg 0x04
union {
UCHAR Flags;
struct {
UCHAR MediaEvent : 4;
UCHAR Reserved0 : 4;
} Fields;
} Byte0;
#define EventStat_MediaStat_DoorOpen 0x01
#define EventStat_MediaStat_Present 0x02
union {
UCHAR Flags;
struct {
UCHAR DoorOpen : 1;
UCHAR Present : 1;
UCHAR Reserved0 : 6;
} Fields;
} Byte1;
UCHAR StartSlot;
UCHAR EndSlot;
} EVENT_STAT_MEDIA_BLOCK, *PEVENT_STAT_MEDIA_BLOCK;
typedef struct _EVENT_STAT_DEV_BUSY_BLOCK {
EVENT_STAT_HEADER Header;
#define EventStat_BusyEvent_Mask 0x0f
#define EventStat_BusyEvent_None 0x00
#define EventStat_BusyEvent_Busy 0x01
union {
UCHAR Flags;
struct {
UCHAR BusyEvent : 4;
UCHAR Reserved0 : 4;
} Fields;
} Byte0;
#define EventStat_BusyStat_Mask 0x0f
#define EventStat_BusyStat_NoEvent 0x00
#define EventStat_BusyStat_Power 0x01
#define EventStat_BusyStat_Immed 0x02
#define EventStat_BusyStat_Deferred 0x03
union {
UCHAR Flags;
struct {
UCHAR BusyStatus: 4;
UCHAR Reserved0 : 4;
} Fields;
} Byte1;
UCHAR Time[2];
} EVENT_STAT_DEV_BUSY_BLOCK, *PEVENT_STAT_DEV_BUSY_BLOCK;
// Define mode disc info block.
typedef struct _DISC_INFO_BLOCK { //
UCHAR DataLength [2];
#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
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;
#define DiscInfo_URU 0x20
#define DiscInfo_DBC_V 0x40
#define DiscInfo_DID_V 0x80
union {
UCHAR Flags;
struct {
UCHAR Reserved1: 5;
UCHAR URU : 1;
UCHAR DBC_V : 1; // 0
UCHAR DID_V : 1;
} Fields;
} Flags;
#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 ;)
UCHAR DiskType;
UCHAR NumOfSes2; // MSB MMC-3
UCHAR FirstTrackNumLastSes2; // MSB MMC-3
UCHAR LastTrackNumLastSes2; // MSB MMC-3
UCHAR DiskId [4];
UCHAR LastSesLeadInTime [4]; // MSF
UCHAR LastSesLeadOutTime [4]; // MSF
UCHAR DiskBarCode [8];
UCHAR Reserved3;
UCHAR OPCNum;
} DISC_INFO_BLOCK, *PDISC_INFO_BLOCK;
// Define track info block.
typedef struct _TRACK_INFO_BLOCK {
UCHAR DataLength [2];
UCHAR TrackNum;
UCHAR SesNum;
UCHAR Reserved0;
#define TrkInfo_Trk_Mask 0x0F
#define TrkInfo_Trk_Mode1 0x01
#define TrkInfo_Trk_Mode2 0x02
#define TrkInfo_Trk_XA 0x02
#define TrkInfo_Trk_DDCD 0x04 // MMC-3
#define TrkInfo_Trk_NonCD 0x04 // MMC-3
#define TrkInfo_Trk_Inc 0x05 // MMC-3
#define TrkInfo_Trk_unknown 0x0F
#define TrkInfo_Copy 0x10
#define TrkInfo_Damage 0x20
UCHAR TrackParam;
/* UCHAR TrackMode : 4;
UCHAR Copy : 1;
UCHAR Damage : 1;
UCHAR Reserved1 : 2; */
#define TrkInfo_Dat_Mask 0x0F
#define TrkInfo_Dat_Mode1 0x01
#define TrkInfo_Dat_Mode2 0x02
#define TrkInfo_Dat_XA 0x02
#define TrkInfo_Dat_DDCD 0x02
#define TrkInfo_Dat_unknown 0x0F
#define TrkInfo_FP 0x10
#define TrkInfo_Packet 0x20
#define TrkInfo_Blank 0x40
#define TrkInfo_RT 0x80
UCHAR DataParam;
/* UCHAR DataMode : 4;
UCHAR FP : 1;
UCHAR Packet : 1;
UCHAR Blank : 1;
UCHAR RT : 1; */
#define TrkInfo_NWA_V 0x01
#define TrkInfo_LRA_V 0x02 // MMC-3
UCHAR NWA_V;
/* UCHAR NWA_V : 1;
UCHAR LRA_V : 1;
UCHAR Reserved : 6; */
UCHAR TrackStartAddr [4];
UCHAR NextWriteAddr [4];
UCHAR FreeBlocks [4];
UCHAR FixPacketSize [4];
UCHAR TrackLength [4];
// MMC-3
UCHAR LastRecordedAddr [4];
UCHAR TrackNum2; // MSB
UCHAR SesNum2; // MSB
UCHAR Reserved2[2];
}TRACK_INFO_BLOCK, *PTRACK_INFO_BLOCK;
// Mode data structures.
// Define Mode parameter header.
#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_NoDiscPresent 0x70
#define MediaType_DoorOpen 0x71
//*********************************************************************************************
typedef struct _MODE_PARAMETER_HEADER {
UCHAR ModeDataLength;
UCHAR MediumType;
UCHAR DeviceSpecificParameter;
UCHAR BlockDescriptorLength;
} MODE_PARAMETER_HEADER, *PMODE_PARAMETER_HEADER;
typedef struct _MODE_PARAMETER_HEADER10 {
UCHAR ModeDataLength[2];
UCHAR MediumType;
UCHAR DeviceSpecificParameter;
UCHAR Reserved[2];
UCHAR BlockDescriptorLength[2];
} MODE_PARAMETER_HEADER10, *PMODE_PARAMETER_HEADER10;
#define MODE_FD_SINGLE_SIDE 0x01
#define MODE_FD_DOUBLE_SIDE 0x02
#define MODE_FD_MAXIMUM_TYPE 0x1E
#define MODE_DSP_FUA_SUPPORTED 0x10
#define MODE_DSP_WRITE_PROTECT 0x80
// Define the mode parameter block.
typedef struct _MODE_PARAMETER_BLOCK {
UCHAR DensityCode;
UCHAR NumberOfBlocks[3];
UCHAR Reserved;
UCHAR BlockLength[3];
} MODE_PARAMETER_BLOCK, *PMODE_PARAMETER_BLOCK;
typedef struct _MODE_PARM_READ_WRITE {
MODE_PARAMETER_HEADER ParameterListHeader; // List Header Format
MODE_PARAMETER_BLOCK ParameterListBlock; // List Block Descriptor
} MODE_PARM_READ_WRITE_DATA, *PMODE_PARM_READ_WRITE_DATA;
//*********************************************************************************************
// Define read write recovery page
typedef struct _MODE_READ_WRITE_RECOVERY_PAGE { // 0x01
UCHAR PageCode : 6;
UCHAR Reserved1 : 1;
UCHAR PSBit : 1;
UCHAR PageLength;
union {
UCHAR Flags;
struct {
UCHAR DCRBit : 1;
UCHAR DTEBit : 1;
UCHAR PERBit : 1;
UCHAR EERBit : 1;
UCHAR RCBit : 1;
UCHAR TBBit : 1;
UCHAR ARRE : 1;
UCHAR AWRE : 1;
} Fields;
} ErrorRecoveryParam;
UCHAR ReadRetryCount;
UCHAR CorrectionSpan; //SCSI CBS only
UCHAR HeadOffsetCount; //SCSI CBS only
UCHAR DataStrobOffsetCount; //SCSI CBS only
UCHAR Reserved4;
UCHAR WriteRetryCount;
UCHAR Reserved5;
UCHAR RecoveryTimeLimit[2]; // 0
} MODE_READ_WRITE_RECOVERY_PAGE, *PMODE_READ_WRITE_RECOVERY_PAGE;
// Define Read Recovery page - cdrom
typedef struct _MODE_READ_RECOVERY_PAGE { // 0x01
UCHAR PageCode : 6;
UCHAR Reserved1 : 1;
UCHAR PSBit : 1;
UCHAR PageLength;
UCHAR DCRBit : 1;
UCHAR DTEBit : 1;
UCHAR PERBit : 1;
UCHAR Reserved2 : 1;
UCHAR RCBit : 1;
UCHAR TBBit : 1;
UCHAR Reserved3 : 2;
UCHAR ReadRetryCount;
UCHAR Reserved4[4];
} MODE_READ_RECOVERY_PAGE, *PMODE_READ_RECOVERY_PAGE;
//*********************************************************************************************
// Define mode write parameters page.
typedef struct _MODE_WRITE_PARAMS_PAGE { // 0x05
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x32
#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
union {
UCHAR Flags;
struct {
UCHAR WriteType: 4; // 1
UCHAR TestWrite: 1;
UCHAR LS_V: 1;
UCHAR BUFF: 1;
UCHAR Reserved1: 1;
} Fields;
} Byte2;
#define WParam_TrkMode_Mask 0x0d // xx0x
#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
union {
UCHAR Flags;
struct {
UCHAR TrackMode: 4; // 4
UCHAR Copy : 1; // 0
UCHAR FP : 1; // 0
UCHAR Multisession: 2; // 11
} Fields;
} Byte3;
#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_VendorSpec1 0x07
#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
#define WParam_BlkType_VendorSpec2 0x0f
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;
#define WParam_SesFmt_CdRom 0x00
#define WParam_SesFmt_CdI 0x10
#define WParam_SesFmt_CdRomXa 0x20
UCHAR SesFmt; // 0
UCHAR Reserved5;
UCHAR PacketSize[4]; // 0
UCHAR AudioPause[2]; // 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, *PMODE_WRITE_PARAMS_PAGE;
typedef struct _MODE_WRITE_PARAMS_PAGE_3 {
MODE_WRITE_PARAMS_PAGE Standard;
UCHAR VendorSpec[4];
} MODE_WRITE_PARAMS_PAGE_3, *PMODE_WRITE_PARAMS_PAGE_3;
//*********************************************************************************************
// Define Caching page.
typedef struct _MODE_CACHING_PAGE { // 0x08
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength;
UCHAR ReadDisableCache : 1;
UCHAR MultiplicationFactor : 1;
UCHAR WriteCacheEnable : 1;
UCHAR Reserved2 : 5;
UCHAR WriteRetensionPriority : 4;
UCHAR ReadRetensionPriority : 4;
UCHAR DisablePrefetchTransfer[2];
UCHAR MinimumPrefetch[2];
UCHAR MaximumPrefetch[2];
UCHAR MaximumPrefetchCeiling[2];
} MODE_CACHING_PAGE, *PMODE_CACHING_PAGE;
//*********************************************************************************************
// Define CD Parameters page.
typedef struct _MODE_CD_PARAMS_PAGE { // 0x0D
UCHAR PageCode : 6;
UCHAR Reserved : 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x06
UCHAR Reserved1;
#define CdParams_InactvityTime_Mask 0x0f
union {
UCHAR Flags;
struct {
UCHAR InactivityTime: 4; // 1 - 125ms, 2 - 250ms... 9 - 32s, A - 1min...
UCHAR Reserved0 : 4;
} Fields;
} Byte2;
UCHAR SUnits_per_MUnit[2];
UCHAR FUnits_per_SUnit[2];
} MODE_CD_PARAMS_PAGE, *PMODE_CD_PARAMS_PAGE;
//*********************************************************************************************
// Define CD Audio Control Mode page.
typedef struct _CDDA_PORT_CONTROL {
#define CddaPort_Channel_Mask 0x0f
#define CddaPort_Channel_Mute 0x00
#define CddaPort_Channel_0 0x01
#define CddaPort_Channel_1 0x02
#define CddaPort_Channel_0_1 0x03
#define CddaPort_Channel_2 0x04
#define CddaPort_Channel_3 0x08
UCHAR ChannelSelection;
UCHAR Volume;
} CDDA_PORT_CONTROL, *PCDDA_PORT_CONTROL;
typedef struct _MODE_CD_AUDIO_CONTROL_PAGE { // 0x0E
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x0E
#define CdAudio_SOTC 0x02
#define CdAudio_Immed 0x04
union {
UCHAR Flags;
struct {
UCHAR Reserved0 : 1;
UCHAR SOTC : 1;
UCHAR Immed : 1;
UCHAR Reserved1 : 5;
} Fields;
} Byte2;
UCHAR Reserved2[2];
UCHAR LbaFormat;
UCHAR LogicalBlocksPerSecond[2];
CDDA_PORT_CONTROL Port[4];
} MODE_CD_AUDIO_CONTROL_PAGE, *PMODE_CD_AUDIO_CONTROL_PAGE;
//*********************************************************************************************
// Define Power Condition Mode page.
typedef struct _MODE_POWER_CONDITION_PAGE { // 0x1A
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x0A
UCHAR Reserved2;
#define PowerCond_Standby 0x01
#define PowerCond_Idle 0x02
union {
UCHAR Flags;
struct {
UCHAR Standby : 1;
UCHAR Idle : 1;
UCHAR Reserved1 : 6;
} Fields;
} Byte3;
UCHAR IdleTimer[4]; // 1unit = 100ms
UCHAR StandbyTimer[4]; // 1unit = 100ms
} MODE_POWER_CONDITION_PAGE, *PMODE_POWER_CONDITION_PAGE;
//*********************************************************************************************
// Define Fault/Failure Reporting Control page.
typedef struct _MODE_FAIL_REPORT_PAGE { // 0x1C
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x0A
#define FailReport_LogErr 0x01
#define FailReport_Test 0x04
#define FailReport_DExcept 0x08
#define FailReport_Perf 0x80
union {
UCHAR Flags;
struct {
UCHAR LogErr : 1;
UCHAR Reserved1 : 1;
UCHAR Test : 1;
UCHAR DExcept : 1;
UCHAR Reserved2 : 3;
UCHAR Perf : 1;
} Fields;
} Byte2;
union {
UCHAR Flags;
struct {
UCHAR MRIE : 4;
UCHAR Reserved1 : 4;
} Fields;
} Byte3;
UCHAR IntervalTimer[4]; // 1unit = 100ms
UCHAR ReportCount[4];
} MODE_FAIL_REPORT_PAGE, *PMODE_FAIL_REPORT_PAGE;
//*********************************************************************************************
// Define Time-out and Protect page.
typedef struct _MODE_TIMEOUT_AND_PROTECT_PAGE { // 0x1D
UCHAR PageCode : 6;
UCHAR Reserved1: 1;
UCHAR PageSavable : 1;
UCHAR PageLength; // 0x08
UCHAR Reserved2[2];
#define Timeout_SW 0x01
#define Timeout_DISP 0x02
#define Timeout_TMOE 0x04
union {
UCHAR Flags;
struct {
UCHAR SW : 1;
UCHAR DISP : 1;
UCHAR TMOE : 1;
UCHAR Reserved : 5;
} Fields;
} Byte4;
UCHAR Reserved3;
UCHAR Group1_Timeout[2]; // 1unit = 1s
UCHAR Group2_Timeout[2]; // 1unit = 1s
} MODE_TIMEOUT_AND_PROTECT_PAGE, *PMODE_TIMEOUT_AND_PROTECT_PAGE;
//*********************************************************************************************
// Define Philips CD-R(W) Sector Mode page.
typedef struct _MODE_PHILIPS_SECTOR_TYPE_PAGE { // 0x21
UCHAR PageCode : 6;
UCHAR Reserved1 : 1;
UCHAR PSBit : 1;
UCHAR PageLength;
UCHAR Reserved0[2];
union {
UCHAR Flags;
struct {
UCHAR DataBlockType: 4; // 8
UCHAR Reserved2: 4;
} Fields;
} Byte4;
#define WParams_Philips_CreateNewTrack 0
UCHAR Track;
UCHAR ISRC[9];
UCHAR Reserved3[2];
} MODE_PHILIPS_SECTOR_TYPE_PAGE, *PMODE_PHILIPS_SECTOR_TYPE_PAGE;
//*********************************************************************************************
// Define CD-X Capabilities and Mechanical Status page.
typedef struct _MODE_CAPABILITIES_PAGE2 { // 0x2A
UCHAR PageCode : 6;
UCHAR Reserved1 : 1;
UCHAR PSBit : 1;
UCHAR PageLength;
#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
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;*/
#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
UCHAR WriteCap; // DevCap_*_write
/* UCHAR cd_r_write : 1; // reserved in 1.2
UCHAR cd_rw_write : 1; // reserved in 1.2
UCHAR test_write : 1;
UCHAR reserved3a : 1;
UCHAR dvd_r_write : 1;
UCHAR dvd_ram_write : 1;
UCHAR Reserved3 : 2;*/
#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
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;*/
#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
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;*/
#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)
UCHAR Capabilities2;
/* UCHAR lock : 1;
UCHAR lock_state : 1;
UCHAR prevent_jumper : 1;
UCHAR eject : 1;
UCHAR Reserved6 : 1;
UCHAR mechtype : 3;*/
#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
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;*/
UCHAR MaximumSpeedSupported[2];
UCHAR NumberVolumeLevels[2];
UCHAR BufferSize[2];
UCHAR CurrentSpeed[2];
UCHAR Reserved8;
UCHAR SpecialParameters0;
/* UCHAR Reserved9 : 1;
UCHAR BCK : 1;
UCHAR RCK : 1;
UCHAR LSBF : 1;
UCHAR Length : 2;
UCHAR Reserved10 : 2;*/
UCHAR MaximumWriteSpeedSupported[2];
UCHAR CurrentWriteSpeed[2];
UCHAR CopyManagementRevision[2];
UCHAR Reserved11[2];
// MMC3
UCHAR Reserved12;
UCHAR SpecialParameters1;
/* UCHAR RCS : 2; // rotation control selected
UCHAR Reserved13 : 6; */
UCHAR CurrentWriteSpeed3[2];
UCHAR LunWPerfDescriptorCount[2];
// LUN_WRITE_PERF_DESC LunWPerfDescriptor[0];
} MODE_CAPABILITIES_PAGE2, *PMODE_CAPABILITIES_PAGE2;
typedef struct _LUN_WRITE_PERF_DESC {
UCHAR Reserved;
#define LunWPerf_RotCtrl_Mask 0x07
#define LunWPerf_RotCtrl_CLV 0x00
#define LunWPerf_RotCtrl_CAV 0x01
UCHAR RotationControl;
UCHAR WriteSpeedSupported[2]; // kbps
} LUN_WRITE_PERF_DESC, *PLUN_WRITE_PERF_DESC;
// Mode parameter list block descriptor -
// set the block length for reading/writing
#define MODE_BLOCK_DESC_LENGTH 8
#define MODE_HEADER_LENGTH 4
#define MODE_HEADER_LENGTH10 8
#define CDB_USE_MSF 0x01
// Atapi 2.5 changer
typedef struct _MECHANICAL_STATUS_INFORMATION_HEADER {
UCHAR CurrentSlot : 5;
UCHAR ChangerState : 2;
UCHAR Fault : 1;
UCHAR Reserved : 5;
UCHAR MechanismState : 3;
UCHAR CurrentLogicalBlockAddress[3];
UCHAR NumberAvailableSlots;
UCHAR SlotTableLength[2];
} MECHANICAL_STATUS_INFORMATION_HEADER, *PMECHANICAL_STATUS_INFORMATION_HEADER;
typedef struct _SLOT_TABLE_INFORMATION {
UCHAR DiscChanged : 1;
UCHAR Reserved : 6;
UCHAR DiscPresent : 1;
UCHAR Reserved2[3];
} SLOT_TABLE_INFORMATION, *PSLOT_TABLE_INFORMATION;
typedef struct _MECHANICAL_STATUS {
MECHANICAL_STATUS_INFORMATION_HEADER MechanicalStatusHeader;
SLOT_TABLE_INFORMATION SlotTableInfo[1];
} MECHANICAL_STATUS, *PMECHANICAL_STATUS;
// DVD structure blocks
typedef struct _DVD_DESCRIPTOR_HEADER {
UCHAR Length[2];
UCHAR Reserved[2];
} DVD_DESCRIPTOR_HEADER, *PDVD_DESCRIPTOR_HEADER;
typedef struct _DVD_LAYER_DESCRIPTOR {
DVD_DESCRIPTOR_HEADER Header;
UCHAR Length[2];
UCHAR BookVersion : 4;
UCHAR BookType : 4;
UCHAR MinimumRate : 4;
UCHAR DiskSize : 4;
UCHAR LayerType : 4;
UCHAR TrackPath : 1;
UCHAR NumberOfLayers : 2;
UCHAR Reserved1 : 1;
UCHAR TrackDensity : 4;
UCHAR LinearDensity : 4;
UCHAR StartingDataSector[4];
UCHAR EndDataSector[4];
UCHAR EndLayerZeroSector[4];
UCHAR Reserved5 : 7;
UCHAR BCAFlag : 1;
UCHAR Reserved6;
} DVD_LAYER_DESCRIPTOR, *PDVD_LAYER_DESCRIPTOR;
typedef struct _DVD_COPYRIGHT_INFORMATION {
UCHAR CopyrightProtectionSystemType;
UCHAR RegionManagementInformation;
UCHAR Reserved[2];
} DVD_COPYRIGHT_INFORMATION, *PDVD_COPYRIGHT_INFORMATION;
typedef struct _DVD_DISK_KEY_STRUCTURES {
UCHAR DiskKeyData[2048];
} DVD_DISK_KEY_STRUCTURES, *PDVD_DISK_KEY_STRUCTURES;
typedef struct _CDVD_KEY_HEADER {
UCHAR DataLength[2];
UCHAR Reserved[2];
} CDVD_KEY_HEADER, *PCDVD_KEY_HEADER;
typedef struct _CDVD_REPORT_AGID_DATA {
CDVD_KEY_HEADER Header;
UCHAR Reserved1[3];
UCHAR Reserved2 : 6;
UCHAR AGID : 2;
} CDVD_REPORT_AGID_DATA, *PCDVD_REPORT_AGID_DATA;
typedef struct _CDVD_CHALLENGE_KEY_DATA {
CDVD_KEY_HEADER Header;
UCHAR ChallengeKeyValue[10];
UCHAR Reserved[2];
} CDVD_CHALLENGE_KEY_DATA, *PCDVD_CHALLENGE_KEY_DATA;
typedef struct _CDVD_KEY_DATA {
CDVD_KEY_HEADER Header;
UCHAR Key[5];
UCHAR Reserved[3];
} CDVD_KEY_DATA, *PCDVD_KEY_DATA;
typedef struct _CDVD_REPORT_ASF_DATA {
CDVD_KEY_HEADER Header;
UCHAR Reserved1[3];
UCHAR Success : 1;
UCHAR Reserved2 : 7;
} CDVD_REPORT_ASF_DATA, *PCDVD_REPORT_ASF_DATA;
typedef struct _CDVD_TITLE_KEY_HEADER {
CDVD_KEY_HEADER Header;
UCHAR DataLength[2];
UCHAR Reserved1[1];
UCHAR Reserved2 : 3;
UCHAR CGMS : 2;
UCHAR CP_SEC : 1;
UCHAR CPM : 1;
UCHAR Zero : 1;
CDVD_KEY_DATA TitleKey;
} CDVD_TITLE_KEY_HEADER, *PCDVD_TITLE_KEY_HEADER;
typedef struct _DVD_COPYRIGHT_DESCRIPTOR {
UCHAR CopyrightProtectionType;
UCHAR RegionManagementInformation;
UCHAR Reserved[2];
} DVD_COPYRIGHT_DESCRIPTOR, *PDVD_COPYRIGHT_DESCRIPTOR;
typedef struct _DVD_RPC_KEY {
UCHAR UserResetsAvailable:3;
UCHAR ManufacturerResetsAvailable:3;
UCHAR TypeCode:2;
UCHAR RegionMask;
UCHAR RpcScheme;
UCHAR Reserved2[1];
} DVD_RPC_KEY, * PDVD_RPC_KEY;
typedef struct _REPORT_LUNS_INFO_HDR {
UCHAR ListLength[4];
UCHAR Reserved[4];
} REPORT_LUNS_INFO_HDR, *PREPORT_LUNS_INFO_HDR;
#pragma pack(pop)
#endif //__CDRW_DEVICE_H__