shithub: libdvdcss

Download patch

ref: 7437133762469e397253814824ab38796f6ff017
parent: 36eaed48543affde3b3ee233901313d411625972
author: Gildas Bazin <[email protected]>
date: Sat Oct 12 08:41:24 EDT 2002

* src/ioctl.c, src/ioctl.h: fix in ioctl_ReadCopyright to try to work around
   the buggy IOCTL_DVD_READ_STRUCTURE on WinNT/2k/XP.


--- a/src/ioctl.c
+++ b/src/ioctl.c
@@ -2,7 +2,7 @@
  * ioctl.c: DVD ioctl replacement function
  *****************************************************************************
  * Copyright (C) 1999-2001 VideoLAN
- * $Id: ioctl.c,v 1.14 2002/10/10 12:44:28 gbazin Exp $
+ * $Id: ioctl.c,v 1.15 2002/10/12 12:41:24 gbazin Exp $
  *
  * Authors: Markus Kuespert <[email protected]>
  *          Samuel Hocevar <[email protected]>
@@ -251,22 +251,34 @@
         else
         {
             /* We don't have the privileges to send a SCSI_PASS_THROUGH
-               command, let's try the buggy IOCTL_DVD_READ_STRUCTURE anyway */
+               command, let's try to read a title key to check if the DVD is
+               encrypted. */
 
-            DVD_READ_STRUCTURE dvd_struct;
-            DVD_COPYRIGHT_DESCRIPTOR dvd_descr;
+            int i_agid;
+            u8 buffer[DVD_DISK_KEY_LENGTH];
+            PDVD_COPY_PROTECT_KEY key = (PDVD_COPY_PROTECT_KEY) &buffer;
 
-            memset( &dvd_struct, 0, sizeof( DVD_READ_STRUCTURE ) );
+            if( ioctl_ReportAgid( i_fd, &i_agid ) < 0 )
+                return -1;
 
-            dvd_struct.Format = DvdCopyrightDescriptor;
-            dvd_struct.LayerNumber = i_layer;
+            memset( &buffer, 0, sizeof( buffer ) );
 
-            i_ret = DeviceIoControl( (HANDLE) i_fd, IOCTL_DVD_READ_STRUCTURE,
-                                 &dvd_struct, sizeof(DVD_READ_STRUCTURE),
-                                 &dvd_descr, sizeof(DVD_COPYRIGHT_DESCRIPTOR),
-                                 &tmp, NULL ) ? 0 : -1;
+            key->KeyLength  = DVD_DISK_KEY_LENGTH;
+            key->SessionId  = i_agid;
+            key->KeyType    = DvdDiskKey;
+            key->KeyFlags   = 0;
 
-            *pi_copyright = dvd_descr.CopyrightProtectionType;
+            i_ret = DeviceIoControl( (HANDLE) i_fd, IOCTL_DVD_READ_KEY, key, 
+                    key->KeyLength, key, key->KeyLength, &tmp, NULL ) ? 0 : -1;
+            if( i_ret < 0 )
+            {   
+                /* Ok, let's assume the disc is not encrypted */
+                *pi_copyright = 0;
+                i_ret = 0;
+            }
+
+            *pi_copyright = ((key->KeyFlags & DVD_SECTOR_PROTECT_MASK) ==
+                             DVD_SECTOR_PROTECTED) ? 0 : 1;
         }
     }
     else
--- a/src/ioctl.h
+++ b/src/ioctl.h
@@ -2,7 +2,7 @@
  * ioctl.h: DVD ioctl replacement function
  *****************************************************************************
  * Copyright (C) 1999-2001 VideoLAN
- * $Id: ioctl.h,v 1.8 2002/10/10 12:44:28 gbazin Exp $
+ * $Id: ioctl.h,v 1.9 2002/10/12 12:41:24 gbazin Exp $
  *
  * Authors: Samuel Hocevar <[email protected]>
  *
@@ -197,6 +197,14 @@
 #define DVD_DISK_KEY_LENGTH             (2048 + sizeof(DVD_COPY_PROTECT_KEY))
 #define DVD_ASF_LENGTH                  (sizeof(DVD_ASF) + sizeof(DVD_COPY_PROTECT_KEY))
 #define DVD_REGION_LENGTH               (sizeof(DVD_REGION))
+
+#define DVD_COPYRIGHT_MASK              0x00000040
+#define DVD_NOT_COPYRIGHTED             0x00000000
+#define DVD_COPYRIGHTED                 0x00000040
+
+#define DVD_SECTOR_PROTECT_MASK         0x00000020
+#define DVD_SECTOR_NOT_PROTECTED        0x00000000
+#define DVD_SECTOR_PROTECTED            0x00000020
 
 #define SCSI_IOCTL_DATA_OUT             0
 #define SCSI_IOCTL_DATA_IN              1