Multi-Media Commands - 6 Kapitel 6.5: Mit dem GET CONFIGURATION Command werden Informationen über die Eigenschaften des Laufwerkes ermittelt. Mit dem AACS FEATURE (Kapitel 5.3.44) lässt sich ermitteln, ob dieses System zum digitalen Rechtemanagement unterstützt wird.
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 = $010D | |||||||
| 3 | ||||||||
| 4 | Reserviert | |||||||
| 5 | ||||||||
| 6 | ||||||||
| 7 | Allocation Length = $10 | |||||||
| 8 | ||||||||
| 9 | Control | |||||||
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 AACS FEATURE hat die Featurenummer $010D.
Byte 7 und 8: Länge der Antwortstruktur. Die Beschreibung des AACS 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 AACS FEATURE Beschreibung, falls dieses Feature unterstützt wird:
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
| 0 | Feature Code = $010D | |||||||
| 1 | ||||||||
| 2 | Reserviert | Version = 0010b | Persistent | Current | ||||
| 3 | Additional Length = $04 | |||||||
| 4 | Reserviert | RDC | RMC | WBE | BEC | BNG | ||
| 5 | Block Count for Binding Nonce | |||||||
| 6 | Reserviert | Number of AGIDs | ||||||
| 7 | AACS Version | |||||||
Byte 9: Control - ?
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_AACS = $010D;
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_AACS;
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;
Nach der Ausführung wird die Antwortstruktur ausgewertet.
type
TGetConfigurationHeader = record
DataLength : DWord;
CurrentProfile : Word;
end;
TFeatureAACS = record
FeatureCode : Word;
Version : Byte;
Persistent : Boolean;
Current : Boolean;
AddLength : Byte;
RDC : Boolean;
RMC : Boolean;
WBE : Boolean;
BEC : Boolean;
BNG : Boolean;
BlockCount : Byte;
nAGIDS : Byte;
AACSVersion : 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];
AACS.FeatureCode := GET_CONFIGURATION_CDB.Data[0] shl 8 or
GET_CONFIGURATION_CDB.Data[1];
AACS.Version := GET_CONFIGURATION_CDB.Data[2] and $3C shr 2;
AACS.Persistent := GET_CONFIGURATION_CDB.Data[2] and $02 > 0;
AACS.Current := GET_CONFIGURATION_CDB.Data[2] and $01 > 0;
AACS.AddLength := GET_CONFIGURATION_CDB.Data[3];
AACS.RDC := GET_CONFIGURATION_STD.Data[4] and $10 > 0;
AACS.RMC := GET_CONFIGURATION_STD.Data[4] and $08 > 0;
AACS.WBE := GET_CONFIGURATION_STD.Data[4] and $04 > 0;
AACS.BEC := GET_CONFIGURATION_STD.Data[4] and $02 > 0;
AACS.BNG := GET_CONFIGURATION_STD.Data[4] and $01 > 0;
AACS.BlockCount := GET_CONFIGURATION_STD.Data[5];
AACS.nAGIDS := GET_CONFIGURATION_STD.Data[6] and $0F;
AACS.AACSVersion := 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 AACS Feature mit der Featurenummer $010D.
Version - Ist in der MMC-6 0010b.
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.
RDC - Gibt an. ob das Laufwerk für AACS lizensiert ist.
RMC - Gibt an, ob das READ DISC STRUCTURE command mit Formatcode $86 unterstützt wird.
WBE, BEC - Betreffen die Unterstützung der Busverschlüsselung.
BNG - Gibt an, ob Binding Nonce Generating unterstützt wird.
Block Count for Binding Nonce - Gibt an, wieviele Mediablöcke zum Speichern der Bindung Nonce benötigt werden.
Number of AGIDs - Gibt an, wieviele AGIDs maximal gleichzeitig unterstützt werden.
AACS Version - Gibt die AACS Version an. Der Wert ist null oder eins.
Demo, welche diese Funktion nutzt:

Hardware AACS (podHardAACS.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