Multi-Media Commands - 6: Mit dem GET CONFIGURATION Command (Kap. 6.5) und dem BD READ FEATURE (Feature Number $0040 - Kap. 5.3.29) erhält man Auskunft darüber, ob das Laufwerk BD lesen kann.
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 = $0040 | |||||||
| 3 | ||||||||
| 4 | Reserviert | |||||||
| 5 | ||||||||
| 6 | ||||||||
| 7 | Allocation Length = $28 | |||||||
| 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 auszugebenden Feature an. Das BD READ
FEATURE hat die Featurenummer $0040.
Byte 7 und 8: Länge der Antwortstruktur. Die Länge muss so groß gewählt werden, dass die erwartete Antwort hineinpasst. Die Beschreibung des BD READ FEATURE ist 32 Byte lang. Mit den acht Byte des FEATURE HEADER ergibt sich eine Länge von 40 ($28). Die Struktur sieht dann beginnend mit dem Feature Header so aus:
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
| 0 | Data Length | |||||||
| 1 | ||||||||
| 2 | ||||||||
| 3 | ||||||||
| 4 | Reserviert | |||||||
| 5 | ||||||||
| 6 | Current Profile | |||||||
| 7 | ||||||||
BD READ FEATURE Beschreibung:
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
| 0 | Feature Code = $0040 | |||||||
| 1 | ||||||||
| 2 | Reserviert | Version = 0001b | Persistent | Current | ||||
| 3 | Additional Length = $1C | |||||||
| 4 | Reserved | BCA | ||||||
| 5 | Reserved | |||||||
| 6 | ||||||||
| 7 | ||||||||
| 8 | Veraltet | |||||||
| 9 | Veraltet | RE2 | RE1 | Veraltet | ||||
| 10 | Veraltet | |||||||
| 11 | ||||||||
| 12 | ||||||||
| 13 | ||||||||
| 14 | ||||||||
| 15 | ||||||||
| 16 | ||||||||
| 17 | Veraltet | R | Veraltet | |||||
| 18 | Veraltet | |||||||
| 19 | ||||||||
| 20 | ||||||||
| 21 | ||||||||
| 22 | ||||||||
| 23 | ||||||||
| 24 | ||||||||
| 25 | Veraltet | ROM | Veraltet | |||||
| 26 | Veraltet | |||||||
| 27 | ||||||||
| 28 | ||||||||
| 29 | ||||||||
| 30 | ||||||||
| 31 | ||||||||
Bei den veralteten Daten handelte es sich in der Version $00 um Class Bitmaps für BD-RE und BD-R.
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_BD_READ = $0040;
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_BD_READ = record
Header : array[0..7] of Byte;
Data : array[0..31] 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.StartingFeatureNr := FEATURE_BD_READ;
GET_CONFIGURATION_CDB.AllocationLength := SizeOf(TGET_CONFIGURATION_BD_READ);
{
* 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;
TFeatureBDRead = record
FeatureCode : Word;
Version : Byte;
Persistent : Boolean;
Current : Boolean;
AddLength : Byte;
BCA : Boolean;
RE2 : Boolean;
RE1 : Boolean;
R : Boolean;
ROM : Boolean;
end;
...
begin
...
{
* Befehl ausführen
}
if GET_SCSI_PASS_THROUGH_DIRECT(aDrive, aCDB, @GET_CONFIGURATION_BD_READ,
SizeOf(TGET_CONFIGURATION_BD_READ))
then begin
ConfigHeader.DataLength := GET_CONFIGURATION_BD_READ.Header[0] shl 24 or
GET_CONFIGURATION_BD_READ.Header[1] shl 16 or
GET_CONFIGURATION_BD_READ.Header[2] shl 8 or
GET_CONFIGURATION_BD_READ.Header[3];
ConfigHeader.CurrentProfile := GET_CONFIGURATION_BD_READ.Header[6] shl 8 or
GET_CONFIGURATION_BD_READ.Header[7];
BDRead.FeatureCode := GET_CONFIGURATION_BD_READ.Data[0] shl 8 or
GET_CONFIGURATION_BD_READ.Data[1];
BDRead.Version := GET_CONFIGURATION_BD_READ.Data[2] and $3C shr 2;
BDRead.Persistent := GET_CONFIGURATION_BD_READ.Data[2] and $02 > 0;
BDRead.Current := GET_CONFIGURATION_BD_READ.Data[2] and $01 > 0;
BDRead.AddLength := GET_CONFIGURATION_BD_READ.Data[3];
BDRead.BCA := GET_CONFIGURATION_BD_READ.Data[4] and $01 > 0;
BDRead.RE2 := GET_CONFIGURATION_BD_READ.Data[9] and $04 > 0;
BDRead.RE1 := GET_CONFIGURATION_BD_READ.Data[9] and $02 > 0;
BDRead.R := GET_CONFIGURATION_BD_READ.Data[17] and $02 > 0;
BDRead.ROM := GET_CONFIGURATION_BD_READ.Data[25] and $02 > 0;
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 36.
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. Hier war das BD READ Feature $0040 ausgewählt.
Version - Die Versionsnummer muss 0001b sein.
Persistent - gibt an, ob sich der Wert ändern kann. Wenn das Flag gesetzt ist, ist die Eigenschaft immer aktiv und ändert sich nicht.
Current - gibt an, ob die Eigenschaft zur Zeit aktiv ist. Das heißt, ob ein entsprechendes Medium eingelegt ist.
Additional Length - Der Wert muss 28 betragen.
BCA - Gibt an, ob das Laufwerk BCA Daten über das READ DISC STRUCTURE command mit dem Media Type $1 und dem Format Code $03 lesen kann.
RE2 - Gibt an, ob das Laufwerk BD-RE Version 2 Medien lesen kann.
RE1 - Gibt an, ob das Laufwerk BD-RE Version 1 Medien lesen kann.
R - Gibt an, ob das Laufwerk BD-R Version 1 Medien lesen kann.
ROM - Gibt an, ob das Laufwerk BD-ROM Version 1 Medien lesen kann.
Demo, welche diese Funktion nutzt:

Hardware BD READ (podHardBDRead.7z - 256 kb) MD5 (1 kb). Stand: 10. Januar 2012
Das Feature wird natürlich nicht unterstützt, da es sich um einen DVD-Brenner handelt.
Fr_An - Erstellt: 10. Januar 2012 - Letzte Änderung: 21. Januar 2012
seit 28. Juli 2010