ntddcdvd.h
上传用户:xjjlds
上传日期:2015-12-05
资源大小:22823k
文件大小:8k
源码类别:

多媒体编程

开发平台:

Visual C++

  1. /*++ BUILD Version: 0001    // Increment this if a change has global effects
  2. Copyright (c) Microsoft Corporation. All rights reserved.
  3. Module Name:
  4.     ntddcdvd.h
  5. Abstract:
  6.     This module contains structures and definitions
  7.     associated with DVD ioctls.
  8.     This module is used in conjunction with ntddcdrm.h which contains the
  9.     cdrom specific ioctls which will work on CDVD drives
  10. Author:
  11.     Peter Wieland
  12. Revision History:
  13. --*/
  14. // begin_winioctl
  15. #ifndef _NTDDCDVD_
  16. #define _NTDDCDVD_
  17. #if _MSC_VER > 1000
  18. #pragma once
  19. #endif
  20. #include <pshpack1.h>
  21. //
  22. // NtDeviceIoControlFile IoControlCode values for this device.
  23. //
  24. // Warning:  Remember that the low two bits of the code specify how the
  25. //           buffers are passed to the driver!
  26. //
  27. #define IOCTL_DVD_BASE                 FILE_DEVICE_DVD
  28. //
  29. // CDVD Device Control Functions
  30. //
  31. // Warning: Ioctls from 200 through 300 are used for the old common class
  32. // driver ioctls and should not be used for device specific functionality
  33. //
  34. //
  35. // Copyright ioctls
  36. //
  37. #define IOCTL_DVD_START_SESSION     CTL_CODE(IOCTL_DVD_BASE, 0x0400, METHOD_BUFFERED, FILE_READ_ACCESS)
  38. #define IOCTL_DVD_READ_KEY          CTL_CODE(IOCTL_DVD_BASE, 0x0401, METHOD_BUFFERED, FILE_READ_ACCESS)
  39. #define IOCTL_DVD_SEND_KEY          CTL_CODE(IOCTL_DVD_BASE, 0x0402, METHOD_BUFFERED, FILE_READ_ACCESS)
  40. #define IOCTL_DVD_END_SESSION       CTL_CODE(IOCTL_DVD_BASE, 0x0403, METHOD_BUFFERED, FILE_READ_ACCESS)
  41. #define IOCTL_DVD_SET_READ_AHEAD    CTL_CODE(IOCTL_DVD_BASE, 0x0404, METHOD_BUFFERED, FILE_READ_ACCESS)
  42. #define IOCTL_DVD_GET_REGION        CTL_CODE(IOCTL_DVD_BASE, 0x0405, METHOD_BUFFERED, FILE_READ_ACCESS)
  43. #define IOCTL_DVD_SEND_KEY2         CTL_CODE(IOCTL_DVD_BASE, 0x0406, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
  44. //
  45. // DVD Structure queries
  46. //
  47. #define IOCTL_DVD_READ_STRUCTURE    CTL_CODE(IOCTL_DVD_BASE, 0x0450, METHOD_BUFFERED, FILE_READ_ACCESS)
  48. //
  49. // The following file contains the IOCTL_STORAGE class ioctl definitions
  50. //
  51. #define IOCTL_STORAGE_SET_READ_AHEAD        CTL_CODE(IOCTL_STORAGE_BASE, 0x0100, METHOD_BUFFERED, FILE_READ_ACCESS)
  52. // end_winioctl
  53. //#include <ntddstor.h>
  54. #include "ntddstor.h"
  55. // begin_winioctl
  56. #ifdef __cplusplus
  57. extern "C" {
  58. #endif
  59. typedef enum {
  60.     DvdChallengeKey = 0x01,
  61.     DvdBusKey1,
  62.     DvdBusKey2,
  63.     DvdTitleKey,
  64.     DvdAsf,
  65.     DvdSetRpcKey = 0x6,
  66.     DvdGetRpcKey = 0x8,
  67.     DvdDiskKey = 0x80,
  68.     DvdInvalidateAGID = 0x3f
  69. } DVD_KEY_TYPE;
  70. typedef ULONG DVD_SESSION_ID, *PDVD_SESSION_ID;
  71. typedef struct _DVD_COPY_PROTECT_KEY {
  72.     ULONG KeyLength;
  73.     DVD_SESSION_ID SessionId;
  74.     DVD_KEY_TYPE KeyType;
  75.     ULONG KeyFlags;
  76.     union {
  77.         HANDLE FileHandle;
  78.         LARGE_INTEGER TitleOffset;
  79.     } Parameters;
  80.     UCHAR KeyData[0];
  81. } DVD_COPY_PROTECT_KEY, *PDVD_COPY_PROTECT_KEY;
  82. //
  83. // Predefined (Mt. Fuji) key sizes
  84. // Add sizeof(DVD_COPY_PROTECT_KEY) to get allocation size for
  85. // the full key structure
  86. //
  87. #define DVD_CHALLENGE_KEY_LENGTH    (12 + sizeof(DVD_COPY_PROTECT_KEY))
  88. #define DVD_BUS_KEY_LENGTH          (8 + sizeof(DVD_COPY_PROTECT_KEY))
  89. #define DVD_TITLE_KEY_LENGTH        (8 + sizeof(DVD_COPY_PROTECT_KEY))
  90. #define DVD_DISK_KEY_LENGTH         (2048 + sizeof(DVD_COPY_PROTECT_KEY))
  91. #define DVD_RPC_KEY_LENGTH          (sizeof(DVD_RPC_KEY) + sizeof(DVD_COPY_PROTECT_KEY))
  92. #define DVD_SET_RPC_KEY_LENGTH      (sizeof(DVD_SET_RPC_KEY) + sizeof(DVD_COPY_PROTECT_KEY))
  93. #define DVD_ASF_LENGTH              (sizeof(DVD_ASF) + sizeof(DVD_COPY_PROTECT_KEY))
  94. //
  95. // Used with IOCTL_DVD_END_SESSION to end all DVD sessions at once
  96. //
  97. #define DVD_END_ALL_SESSIONS ((DVD_SESSION_ID) 0xffffffff)
  98. //
  99. // CGMS Copy Protection Flags
  100. //
  101. #define DVD_CGMS_RESERVED_MASK      0x00000078
  102. #define DVD_CGMS_COPY_PROTECT_MASK  0x00000018
  103. #define DVD_CGMS_COPY_PERMITTED     0x00000000
  104. #define DVD_CGMS_COPY_ONCE          0x00000010
  105. #define DVD_CGMS_NO_COPY            0x00000018
  106. #define DVD_COPYRIGHT_MASK          0x00000040
  107. #define DVD_NOT_COPYRIGHTED         0x00000000
  108. #define DVD_COPYRIGHTED             0x00000040
  109. #define DVD_SECTOR_PROTECT_MASK     0x00000020
  110. #define DVD_SECTOR_NOT_PROTECTED    0x00000000
  111. #define DVD_SECTOR_PROTECTED        0x00000020
  112. /*++
  113. IOCTL_STORAGE_SET_READ_AHEAD
  114. Requests that the storage device skip to TargetAddress once it has run across
  115. TriggerAddress during the course of it's read-ahead caching operations.
  116. Input:
  117.     a STORAGE_SET_READ_AHEAD structure which contains:
  118.         * the trigger address
  119.         * the target address
  120. Output:
  121.     none
  122. --*/
  123. typedef struct _STORAGE_SET_READ_AHEAD {
  124.     LARGE_INTEGER TriggerAddress;
  125.     LARGE_INTEGER TargetAddress;
  126. } STORAGE_SET_READ_AHEAD, *PSTORAGE_SET_READ_AHEAD;
  127. /*++
  128. IOCTL_DVD_READ_STRUCTURE
  129. Issues a READ_DVD_STRUCTURE command to the drive.
  130. Input:
  131.     a DVD_READ_STRUCTURE describing what information is requested
  132. Output:
  133.     a DVD Layer Descriptor as defined below
  134. --*/
  135. typedef enum DVD_STRUCTURE_FORMAT {
  136.     DvdPhysicalDescriptor,
  137.     DvdCopyrightDescriptor,
  138.     DvdDiskKeyDescriptor,
  139.     DvdBCADescriptor,
  140.     DvdManufacturerDescriptor,
  141.     DvdMaxDescriptor
  142. } DVD_STRUCTURE_FORMAT, *PDVD_STRUCTURE_FORMAT;
  143. typedef struct DVD_READ_STRUCTURE {
  144.     LARGE_INTEGER BlockByteOffset;
  145.     DVD_STRUCTURE_FORMAT Format;
  146.     DVD_SESSION_ID SessionId;
  147.     UCHAR LayerNumber;
  148. } DVD_READ_STRUCTURE, *PDVD_READ_STRUCTURE;
  149. typedef struct _DVD_DESCRIPTOR_HEADER {
  150.     USHORT Length;
  151.     UCHAR Reserved[2];
  152.     UCHAR Data[0];
  153. } DVD_DESCRIPTOR_HEADER, *PDVD_DESCRIPTOR_HEADER;
  154. typedef struct _DVD_LAYER_DESCRIPTOR {
  155.     UCHAR BookVersion : 4;
  156.     UCHAR BookType : 4;
  157.     UCHAR MinimumRate : 4;
  158.     UCHAR DiskSize : 4;
  159.     UCHAR LayerType : 4;
  160.     UCHAR TrackPath : 1;
  161.     UCHAR NumberOfLayers : 2;
  162.     UCHAR Reserved1 : 1;
  163.     UCHAR TrackDensity : 4;
  164.     UCHAR LinearDensity : 4;
  165.     ULONG StartingDataSector;
  166.     ULONG EndDataSector;
  167.     ULONG EndLayerZeroSector;
  168.     UCHAR Reserved5 : 7;
  169.     UCHAR BCAFlag : 1;
  170.     UCHAR Reserved6;
  171. } DVD_LAYER_DESCRIPTOR, *PDVD_LAYER_DESCRIPTOR;
  172. typedef struct _DVD_COPYRIGHT_DESCRIPTOR {
  173.     UCHAR CopyrightProtectionType;
  174.     UCHAR RegionManagementInformation;
  175.     USHORT Reserved;
  176. } DVD_COPYRIGHT_DESCRIPTOR, *PDVD_COPYRIGHT_DESCRIPTOR;
  177. typedef struct _DVD_DISK_KEY_DESCRIPTOR {
  178.     UCHAR DiskKeyData[2048];
  179. } DVD_DISK_KEY_DESCRIPTOR, *PDVD_DISK_KEY_DESCRIPTOR;
  180. typedef struct _DVD_BCA_DESCRIPTOR {
  181.     UCHAR BCAInformation[0];
  182. } DVD_BCA_DESCRIPTOR, *PDVD_BCA_DESCRIPTOR;
  183. typedef struct _DVD_MANUFACTURER_DESCRIPTOR {
  184.     UCHAR ManufacturingInformation[2048];
  185. } DVD_MANUFACTURER_DESCRIPTOR, *PDVD_MANUFACTURER_DESCRIPTOR;
  186. typedef struct _DVD_RPC_KEY {
  187.     UCHAR UserResetsAvailable:3;
  188.     UCHAR ManufacturerResetsAvailable:3;
  189.     UCHAR TypeCode:2;
  190.     UCHAR RegionMask;
  191.     UCHAR RpcScheme;
  192.     UCHAR Reserved2[1];
  193. } DVD_RPC_KEY, * PDVD_RPC_KEY;
  194. typedef struct _DVD_SET_RPC_KEY {
  195.     UCHAR PreferredDriveRegionCode;
  196.     UCHAR Reserved[3];
  197. } DVD_SET_RPC_KEY, * PDVD_SET_RPC_KEY;
  198. typedef struct _DVD_ASF {
  199.     UCHAR Reserved0[3];
  200.     UCHAR SuccessFlag:1;
  201.     UCHAR Reserved1:7;
  202. } DVD_ASF, * PDVD_ASF;
  203. #if 0
  204. typedef struct _DVD_REGION {
  205.      UCHAR CopySystem;
  206.      UCHAR RegionData;                      // current media region (not playable when set)
  207.      UCHAR SystemRegion;                    // current drive region (playable when set)
  208.      UCHAR ResetCount;                      // number of resets available
  209. } DVD_REGION, *PDVD_REGION;
  210. #endif
  211. #ifdef __cplusplus
  212. }
  213. #endif
  214. #include <poppack.h>
  215. #endif  // _NTDDCDVD_
  216. // end_winioctl