Avatar
www.fr-an.de

Hardwareinformationen

Content Scramble System

GET CONFIGURATION Command - Operation Code $46
DVD CSS FEATURE - Feature Number $0106

Multi-Media Commands - 6 Kapitel 6.5: Mit dem GET CONFIGURATION Command werden Informationen über die Eigenschaften des Laufwerkes ermittelt. Mit dem DVD CSS FEATURE (Kapitel 5.3.38) lässt sich ermitteln, ob das Content Scramble System unterstützt wird. Dieses System verschlüsselt den Videostream. Ohne Entschlüsselung erhält man ein grünes Bild.

Der GET CONFIGURATION Command Descriptor Block:

  7 6 5 4 3 2 1 0
0 Operation Code ($46)
1 Reserviert RT = 01b
2 Starting Feature Number = $0106
3
4 Reserviert
5
6
7 Allocation Length = $10
8
9 Control

 

Die zu setzenden Werte:

Byte 0: Operation Code - $46

Byte 1: RT - Request Type 01b:

Wert Beschreibung
00b Das Laufwerk soll den Feature Header und alle durch das Laufwerk unterstützten Feature Beschreibungen zurückgeben ohne Rücksicht auf Geltung.
01b Das Laufwerk soll den Feature Header und nur die gewählte Feature Beschreibung zurückgeben.
10b Das Laufwerk soll den Feature Header und nur die gewählte Feature Beschreibung zurückgeben. Wird das Feature nicht unterstützt, soll nur der Feature Header zurückgegeben werden.
11b Reserviert

 
Byte 2 und 3: Starting Feature Number - Gibt die Nummer des Feature, welches ausgegeben werden soll, an. Das DVD CSS FEATURE hat die Featurenummer $0106.

Byte 7 und 8: Länge der Antwortstruktur. Die Beschreibung des DVD CSS FEATURE hat eine Länge von acht Byte. Mit den acht Byte des Feature Headers ergeben sich 16 Byte. Zuerst der Feature Header:

  7 6 5 4 3 2 1 0
0 Data Length
1
2
3
4 Reserviert
5
6 Current Profile
7

 
Anschließend folgt die DVD CSS FEATURE Beschreibung, falls dieses Feature unterstützt wird:

  7 6 5 4 3 2 1 0
0 Feature Code = $0106
1
2 Reserviert Version = 0000b Persistent Current
3 Additional Length = $04
4 Reserviert
5
6
7 CSS Version

 
Byte 9: Control - ?

 

Deklaration und Vorbereitung

Die Werte werden ein- und übertragen. Das Beispiel ist vielleicht etwas umständlich, aber übersichtlicher und eben nur ein Beispiel:

 
  const
    SCSIOP_GET_CONFIGURATION = $46;
    FEATURE_DVD_CSS          = $0106;
    RT_All                   = 0;
    RT_Current               = 1;
    RT_Identified            = 2;
 
  type
    TGET_CONFIGURATION_CDB = record
      OperationCode         : Byte;
      RequestType           : Byte;
      StartingFeatureNumber : Word;
      AllocationLength      : Word;
    end;
 
  type
    TGET_CONFIGURATION_STD = record
      Header : array[0..7] of Byte;
      Data   : array[0..7] of Byte;
    end;
 
    ...
 
  begin
 
    ...
 
    {
    *  Den Command Descriptor Block füllen.
    }
    ZeroMemory(@GET_CONFIGURATION_CDB, SizeOf(TGET_CONFIGURATION_CDB));
    GET_CONFIGURATION_CDB.OperationCode         := SCSIOP_GET_CONFIGURATION;
    GET_CONFIGURATION_CDB.RequestType           := RT_Identified;
    GET_CONFIGURATION_CDB.StartingFeatureNumber := FEATURE_DVD_CSS;
    GET_CONFIGURATION_CDB.AllocationLength      := SizeOf(TGET_CONFIGURATION_STD);
    {
    *  Den Command Descriptor Block übertragen.
    }
    SetLength(aCDB, 10);
    aCDB[0] := GET_CONFIGURATION_CDB.OperationCode;
    aCDB[1] := GET_CONFIGURATION_CDB.RequestType;
    aCDB[2] := HiByte(GET_CONFIGURATION_CDB.StartingFeatureNumber);
    aCDB[3] := LoByte(GET_CONFIGURATION_CDB.StartingFeatureNumber);
    aCDB[7] := HiByte(GET_CONFIGURATION_CDB.AllocationLength);
    aCDB[8] := LoByte(GET_CONFIGURATION_CDB.AllocationLength);
 
    ...
 
  end;
        

 

Ausführung und Auswertung

Nach der Ausführung wird die Antwortstruktur ausgewertet.

 
  type
    TGetConfigurationHeader = record
      DataLength     : DWord;
      CurrentProfile : Word;
    end;
 
    TFeatureDVDCSS = record
      FeatureCode  : Word;
      Version      : Byte;
      Persistent   : Boolean;
      Current      : Boolean;
      AddLength    : Byte;
      CSSVersion   : Byte;
    end;
 
    ...
 
  begin
 
    ...
 
    {
    *  Befehl ausführen
    }
    if GET_SCSI_PASS_THROUGH_DIRECT(aDrive, aCDB, @GET_CONFIGURATION_CDB,
                                    SizeOf(TGET_CONFIGURATION_CDB))
    then begin
      ConfigHead.DataLength     := GET_CONFIGURATION_CDB.Header[0] shl 24 or
                                   GET_CONFIGURATION_CDB.Header[1] shl 16 or
                                   GET_CONFIGURATION_CDB.Header[2] shl  8 or
                                   GET_CONFIGURATION_CDB.Header[3];
      ConfigHead.CurrentProfile := GET_CONFIGURATION_CDB.Header[6] shl 8 or
                                   GET_CONFIGURATION_CDB.Header[7];
      DVDCSS.FeatureCode := GET_CONFIGURATION_CDB.Data[0] shl 8 or
                            GET_CONFIGURATION_CDB.Data[1];
      DVDCSS.Version     := GET_CONFIGURATION_CDB.Data[2] and $3C shr 2;
      DVDCSS.Persistent  := GET_CONFIGURATION_CDB.Data[2] and $02 > 0;
      DVDCSS.Current     := GET_CONFIGURATION_CDB.Data[2] and $01 > 0;
      DVDCSS.AddLength   := GET_CONFIGURATION_CDB.Data[3];
      DVDCSS.CSSVersion  := GET_CONFIGURATION_CDB.Data[7];
    end;
 
    ...
 
  end;
        

 

Data Length - Die Datenlänge im Header gibt die Länge des noch folgenden Headerrestes und der Feature Bechreibung an. Wird das Feature nicht unterstützt ist der Wert vier, sonst zwölf.

Current Profile - Gibt das aktive Profil an. Das Profil ist vom Laufwerk und dem eingelegten Datenträger abhängig. Sind mehrere Profile aktiv wird das Profil mit der höchsten Nummer angegeben. (Liste der Profile in einem Fenster öffnen.)

Feature Code - Muss der selbe wie im CDB sein. Das DVD CSS Feature mit der Featurenummer $0106.

Version - Es gibt nur die Versionsnummer 0000b.

Persistent, Current - Gibt an, ob die Eigenschaft geändert werden kann und ob sie zur Zeit aktiv ist.

Additional Length - Der Wert muss $04 betragen.

CSS Version - Gibt die CSS Version an. Der Wert muss eins sein.

 

Demo, welche diese Funktion nutzt:

Hardware DVD CSS (podHardDVDCSS.7z - 256 kb) MD5 (1 kb). Stand: 23. Januar 2012

 

Fr_An - Erstellt: 23. Januar 2012 - Letzte Änderung: 23. Januar 2012

seit 28. Juli 2010