Multi-Media Commands - 6 Kapitel 6.5: Mit dem GET CONFIGURATION Command werden Informationen über die Eigenschaften des Laufwerkes ermittelt. Mit dem optionalen DVD-R/-RW WRITE Feature werden Schreibeigenschaften für DVD-R (SL und DL) und DVD-RW ermitteln.
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 = $002F | |||||||
| 3 | ||||||||
| 4 | Reserviert | |||||||
| 5 | ||||||||
| 6 | ||||||||
| 7 | Allocation Length = $10 | |||||||
| 8 | ||||||||
| 9 | Control | |||||||
Byte 0: Operation Code - $46
Byte 1: RT - 01b Request Type:
| 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, welche ausgegeben werden soll, an.
Byte 7 und 8: Länge der Antwortstruktur. Die Länge muss mindestens so groß gewählt werden, dass die erwartete Antwort auf jeden Fall hineinpasst. Die Beschreibung des DVD-R/-RW Write Feature ist acht Byte lang. Da der Header ebenfalls acht Byte lang ist, muss hier 16 angegeben werden. Die Antwort beginnt standardmäßig mit dem 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 die DVD-R/RW Write Feature Beschreibung, falls dieses Feature unterstützt wird:
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
| 0 | Feature Code = $002F | |||||||
| 1 | ||||||||
| 2 | Reserviert | Version = 0010b | Persistent | Current | ||||
| 3 | Additional Length = $04 | |||||||
| 4 | Reserviert | BUF | Reserviert | RDL | Test Write | DVD-RW SL | Reserviert | |
| 5 | Reserviert | |||||||
| 6 | ||||||||
| 7 | ||||||||
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_DVDmRRW_WRITE = $002F;
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_DVDmRRW_WRITE;
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;
TFeatureDVDmRRWWrite = record
FeatureCode : Word;
Version : Byte;
Persistent : Boolean;
Current : Boolean;
AddLength : Byte;
BUF : Boolean;
RDL : Boolean;
TestWrite : Boolean;
DVDRW_SL : Boolean;
end;
...
begin
...
{
* Befehl ausführen
}
if GET_SCSI_PASS_THROUGH_DIRECT(aDrive, aCDB, @GET_CONFIGURATION_STD,
SizeOf(TGET_CONFIGURATION_STD))
then begin
ConfigHead.DataLength := GET_CONFIGURATION_STD.Header[0] shl 24 or
GET_CONFIGURATION_STD.Header[1] shl 16 or
GET_CONFIGURATION_STD.Header[2] shl 8 or
GET_CONFIGURATION_STD.Header[3];
ConfigHead.CurrentProfile := GET_CONFIGURATION_STD.Header[6] shl 8 or
GET_CONFIGURATION_STD.Header[7];
DVDmRRWWrite.FeatureCode := GET_CONFIGURATION_STD.Data[0] shl 8 or
GET_CONFIGURATION_STD.Data[1];
DVDmRRWWrite.Version := GET_CONFIGURATION_STD.Data[2] and $3C shr 2;
DVDmRRWWrite.Persistent := GET_CONFIGURATION_STD.Data[2] and $02 > 0;
DVDmRRWWrite.Current := GET_CONFIGURATION_STD.Data[2] and $01 > 0;
DVDmRRWWrite.AddLength := GET_CONFIGURATION_STD.Data[3];
DVDmRRWWrite.BUF := GET_CONFIGURATION_STD.Data[4] and $40 > 0;
DVDmRRWWrite.RDL := GET_CONFIGURATION_STD.Data[4] and $08 > 0;
DVDmRRWWrite.TestWrite := GET_CONFIGURATION_STD.Data[4] and $04 > 0;
DVDmRRWWrite.DVDRW_SL := GET_CONFIGURATION_STD.Data[4] and $02 > 0;
end;
...
end;
Data Length - Die Datenlänge im Header gibt die Länge des noch folgenden Headerrestes und der Feature Bechreibungen an. Hier müsste der Wert 12 betragen weil noch vier Byte Header und acht Byte Feature Removable Medium Beschreibung folgen.
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 DVD-R/RW WRITE Feature $002F ausgewählt.
Version: Die Version ist vom unterstützen MMC-Standard abhängig. In MMC-3 ist es Version 0001b, ab MMC-5 0010b.
Persistent: Der Wert 0 gibt an, dass das Medium auswechselbar ist.
Current: Gibt an, ob ein entsprechendes Medium eingelegt ist.
Additional Length: Der Wert muss vier betragen, weil noch vier Byte der Feature Beschreibung folgen.
BUF: Gibt an, ob mit dem Laufwerk Buffer Underrun freie Aufnahmen unterstützt werden.
RDL: Gibt an, ob DVD-R Dual Layer Medien unterstützt werden.
Test Write: Gibt an, ob Testaufnahmen unterstützt werden.
DVD-RW SL: Gibt an, ob das Schreiben und Löschen von DVD-RW Single Layer Medien unterstützt wird.
Demo, welche diese Funktion nutzt:

Hardware DVD-R/RW Write (podHardDVDmRRWWrite.7z - 256 kb)
MD5 (1 kb).
Stand: 20. Januar 2012
Fr_An - Erstellt: 20.01.2012 - Letzte Änderung: 21. Januar 2012
seit 28. Juli 2010