Avatar
www.fr-an.de

Hardwareinformationen

Interface

GET CONFIGURATION Command - Operation Code $46
CORE FEATURE - Feature Number $0001

Multi-Media Commands - 6 Kapitel 6.5: Mit dem GET CONFIGURATION Command werden Informationen über die Eigenschaften des Laufwerkes ermittelt. Die Eigenschaften können insgesamt oder einzeln abgerufen werden.

Der GET CONFIGURATION Command Descriptor Block:

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

 

Die zu setzenden Werte:

Byte 0: Operation Code - $46

Byte 1: RT - 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, welches zuerst ausgegeben werden soll, an. Abhängig vom Request Type kann es auch das einzige sein.

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.

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_CORE             = $0001;
    RT_All                   = 0;
    RT_Current               = 1;
    RT_Identified            = 2;
 
  type
    TGET_CONFIGURATION_CDB = record
      OperationCode         : Byte;
      RequestType           : Byte;
      StartingFeatureNumber : Word;
      AllocationLength      : Word;
    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_CORE;
    GET_CONFIGURATION_CDB.AllocationLength      := SizeOf(TGET_CONFIGURATION_CORE);
    {
    *  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;
        

 

Die Antwortstruktur - Core Feature:

Diese Struktur ist 20 Byte lang. 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 die Core Feature Beschreibung:

  7 6 5 4 3 2 1 0
0 Feature Code = $0001
1
2 Reserviert Version = 0010b Persistent Current
3 Additional Length = 8
4 Physical Interface Standard
5
6
7
8 Reserviert INQ2 DBE = 1
9 Reserviert
10
11
 
  type
    TGET_CONFIGURATION_CORE = record
      Header   : array[0..7] of Byte;
      CoreData : array[0..11] of Byte;
    end;
        

 

Ausführung und Auswertung

Nach der Ausführung wird die Antwortstruktur ausgewertet.

 
  type
    TGetConfigurationHeader = record
      DataLength     : DWord;
      CurrentProfile : Word;
    end;
 
    TFeatureCore = record
      FeatureCode : Word;
      Version     : Byte;
      Persistent  : Boolean;
      Current     : Boolean;
      AddLength   : Byte;
      PhysIntfStd : DWord;
    end;
 
    ...
 
  begin
 
    ...
 
    {
    *  Befehl ausführen
    }
    if GET_SCSI_PASS_THROUGH_DIRECT(aDrive, aCDB, @GET_CONFIGURATION_CORE,
                                    SizeOf(TGET_CONFIGURATION_CORE))
    then begin
      ConfigHeader.DataLength     := GET_CONFIGURATION_CORE.Header[0] shl 24 or
                                     GET_CONFIGURATION_CORE.Header[1] shl 16 or
                                     GET_CONFIGURATION_CORE.Header[2] shl  8 or
                                     GET_CONFIGURATION_CORE.Header[3];
      ConfigHeader.CurrentProfile := GET_CONFIGURATION_CORE.Header[6] shl 8 or
                                     GET_CONFIGURATION_CORE.Header[7];
      ConfigCore.FeatureCode := GET_CONFIGURATION_CORE.CoreData[0] shl 8 or
                                GET_CONFIGURATION_CORE.CoreData[1];
      ConfigCore.Version     := GET_CONFIGURATION_CORE.CoreData[2] and $3C shr 2;
      ConfigCore.Persistent  := GET_CONFIGURATION_CORE.CoreData[2] and $02 > 0;
      ConfigCore.Current     := GET_CONFIGURATION_CORE.CoreData[2] and $01 > 0;
      ConfigCore.AddLength   := GET_CONFIGURATION_CORE.CoreData[3];
      ConfigCore.PhysIntfStd := GET_CONFIGURATION_CORE.CoreData[4] shl 24 or
                                GET_CONFIGURATION_CORE.CoreData[5] shl 16 or
                                GET_CONFIGURATION_CORE.CoreData[6] shl  8 or
                                GET_CONFIGURATION_CORE.CoreData[7];
      ConfigCore.INQ2        := GET_CONFIGURATION_CORE.CoreData[8] and $02 > 0;
      ConfigCore.DBE         := GET_CONFIGURATION_CORE.CoreData[8] and $01 > 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 16 betragen weil noch vier Byte Header und zwölf Byte Feature Core 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 Core Feature $0001 ausgewählt.

Version - Die Versionsnummer muss 0010b sein.

Persistent und Current müssen jeweils 1b sein.

Physical Interface Standard - Interface, mit welchem das Gerät angebunden ist:

Physical Interface Standard Beschreibung
$00000000 Unspezifiziert
$00000001 SCSI
$00000002 ATAPI
$00000003 IEEE 1394 - 1995
$00000004 IEEE 1394A
$00000005 Fibre Channel
$00000006 IEEE 1394B
$00000007 Serail ATAPI
$00000008 USB (1.1 und 2.0)
$00000009 - $0000FFFE Reserviert
$0000FFFF Hersteller
$00010000 - $0001FFFF Definiert durch INCITS
$00020000 - $0002FFFF Definiert durch SFF
$00030000 - $0003FFFF Definiert durch IEEE
$00040000 - $FFFFFFFF Reserviert

 
INQ2 - Gibt an, ob bestimmte Eigenschaften des Befehls INQUIRY unterstützt werden. Wenn INQ2 gesetzt ist, soll der Laufwerk EVPD, Page Code und 16bit Allocation Length wie in SPC-3 beschrieben unterstützen.

DBE - Device Busy Event muss gesetzt sein.

 

Demo, welche diese Funktion nutzt:

Hardware Interface (podHardIntf.7z - 274 kb) MD5 (1 kb). Stand: 10. Januar 2012

 

Fr_An - Erstellt: 7. Janaur 2012 - Letzte Änderung: 21. Januar 2012

seit 28. Juli 2010