Date:  Dec 28, 1989                             X3T9.2/90-006

To:  X3T9.2 Committee (SCSI)
From:  George Penokie (IBM)

Subject:  16/32 bit P/L cable stand alone document


Section 3 Issues

-Redefine SCSI address and SCSI ID terms


Section 4 Issues

-Termination of the cable

     -The maximum number of devices should be made to be 16 if the
      P cable is used.

     -The maximum number of devices should be made to be 32 if the
      L cable is used.

     -Disallow B connector devices from connecting to P or L
      type devices.

-Add in the L cable changes.

     -Make the L cable have the same pin positions for data lines as
      the P cable.

Section 5 Issues

-Some wording changes in section 5.1.2 ARBITRATION Phase are
 required to indicate there are now 32 devices allowed on the bus.

-Some changes in section 5.1.5.3 Wide Data Transfer are required
 to indicate there is another cabling option.

-Add in the L cable changes

Section 7 Issues

-The copy commands segment Descriptor does not have room for a 5
 bit source address and a 5 bit destination address.

     -Make a new set of Descriptors to handle a larger number of
      addresses.

-Add into the Inquiry data the 16/32 bit addressing information.

Section 8, 9, 10, 12, 13, 14, 15, and 16 Issues

-The Release command and Reserve command do not have room for a 5
 bit third party device ID

     -Make 10 byte commands for both the Release and Reserve
      commands
 Section 3 changes recommended to implement a single 68 pin connector


3.1.  Glossary 

SCSI address.  The Hexadecimal Representation of the unique
address (0-31) assigned to an SCSI device.  This address would
normally be assigned and set in the SCSI device during system
installation.

SCSI ID.  The bit-significant representation of the SCSI address
referring to one of the signal lines DB(31-0).

4. Physical Characteristics

  This section contains the physical definition of an alternative
cableing for 16 bit and 32 bit data paths on SCSI-2 devices.  The connectors,
cables, signals, terminators, and bus timing values needed to implement the
interface are covered.

4.1. Physical Description

  SCSI devices are daisy-chained together using a common 68-conductor P cable
or a 110-conductor L cable.  Both ends of each cable are terminated.  All
signals are common between all SCSI devices on the P cable and the L cable.
Various width SCSI devices may be mixed.

  Physical devices with P cable connectors shall connect the low data byte
(DB0-DB7,P) to the P connector.  The high data byte (DB8-DB15,P1) may be
connected to the P connector.  Physical devices with L cable connectors shall
connect the low data byte (DB0-DB7,P) to the L connector.  The three high data
bytes (DB8-DB15,P1,DB16-DB24,P2,DB25-DB32) may be connected to the L connector.

  Two driver/receiver alternatives are specified:
  (1) Single-ended drivers and receivers, which allow a maximum cable length
of six meters (primarily for connection within a cabinet).
  (2) Differential drivers and receivers, which allow a maximum cable length
of 25 meters (primarily for connection outside of a cabinet).

  The A/B cable and P/L cable alternatives are mutually exclusive within a
system.  Physical devices with A cable connectors may be attached to P cables
or L cables.  Physical devices with P cable connectors may be attached
to L cables.  Physical devices with B cable connectors shall not be attached
to P or L cables.  Physical devices with P and L cable connectors shall not be
attached to A or A/B cables.

  The single-ended and differential alternatives are mutually exclusive within
a system.

  IMPLEMENTORS NOTE:  Use of single-ended drivers and receivers with the fast
  synchronous data transfer option is not recommended.

4.2. Cable Requirements  

  An ideal impedance match with cable terminators implies a cable
characteristic impedance of 132 ohms (singled-ended option) or 122 ohms
(differential option).  The cable characteristic impedance shall be no less
than 90 ohms and no greater than 140 ohms.  It is recommended that the cable
characteristic impedance be greater than 100 ohms for all cable types.  See
4.2.3 for cable requirements when implementing the fast synchronous data
transfer option.

  A minimum conductor size of 0.08042 square mm (28 AWG) should be used to
minimize noise effects and ensure proper distribution of terminator power.

  IMPLEMENTORS NOTES:
  (1) To minimize discontinuities and signal reflections, cables of different
  impedances should not be used in the same bus.  Implementations may require
  trade-offs in shielding effectiveness, cable length, the number of loads,
  transfer rates, and cost to achieve satisfactory system operation.
  (2) To minimize discontinuities due to local impedance variation, a flat
  cable should be spaced at least 1.27 mm (0.050 in) from other cables, any
  other conductor, or the cable itself when the cable is folded.
  (3) Regulatory agencies may require use of larger wire size.

4.2.1. Single-Ended Cable

  A 68-conductor flat cable or 34-signal twisted-pair cable shall be used for
the P cable.  A 110-conductor flat cable or 55-signal twisted-pair cable shall
be used for the L cable.  The maximum cumulative cable length shall be 6.0
meters.  If twisted-pair cables are used, then twisted pairs in the cable shall
be wired to physically opposing contacts in the connector.

  A stub length of no more than 0.1 meters is allowed off the mainline
interconnection within any connected equipment or from any connected point.

  IMPLEMENTORS NOTE:  Stub clustering should be avoided.  Stubs should be
  spaced at least 0.3 meters apart.

  SCSI bus termination shall be at each end of the cable and may be internal
to the SCSI devices that are at the ends of the cable.

4.2.2. Differential Cable

  A 68-conductor flat cable or 34-signal twisted-pair cable shall be used for
the P cable.  A 110-conductor flat cable or 55-signal twisted-pair cable shall
be used for the L cable.  The maximum cumulative cable length shall be 25
meters.  If twisted-pair cables are used, then twisted pairs in the cable shall
be wired to physically opposing contacts in the connector.

  A stub length of no more than 0.2 meters is allowed off the mainline
interconnection within any connected equipment or from any connected point.

  SCSI bus termination shall be at each end of the cable and may be internal
to the SCSI devices that are at the ends of the cable.

  IMPLEMENTORS NOTE:  The use of twisted pair cable (either twisted-flat or
  discrete wire twisted pairs) is strongly recommended.  Without twisted
  pairs, even at slow data rates and very short distances, crosstalk between
  adjacent signals causes spurious pulses with differential signals.

4.2.3. Cable Requirements for Fast Synchronous Data Transfer

  In systems which use the fast synchronous data transfer option (see 4.8),
the P and L cables should meet the conductor size recommendation in 4.2.  The
cable should have an overall shield suitable for termination in a shielded
connector.

  In such systems, the cables shall have the following electrical
characteristics:
     Characteristic Impedance:  90 to 132 ohms
     Signal Attenuation:  0.095 dB maximum per meter at 5 MHz
     Pair-to-Pair Propagation Delay Delta:  0.20 ns maximum per meter
     DC Resistance:  0.230 ohms maximum per meter at 20 degrees C


4.3. Connector Requirements

  Two types of connectors are defined: nonshielded and shielded.  The
nonshielded connectors are typically used for in-cabinet applications.
Shielded connectors are typically used for external applications where
electromagnetic compatibility (EMC) and electrostatic discharge (ESD)
protection may be required.  Either type of connector may be used with the
single-ended or differential drivers.

4.3.1. Nonshielded Connector Requirements

  One nonshielded connector is specified for the P and L cables.

4.3.1.1. Nonshielded Connector - P Cable and L Cable 

  The nonshielded high-density SCSI device connector for the P (Figure 4-1)
shall be a 68-conductor connector consisting of two rows of 34 female contacts
with adjacent contacts 1.27 mm (0.05 in) apart.  The nonshielded high-density
SCSI device connector for the L (Figure 4-1) shall be a 110-conductor connector
consisting of two rows of 55 female contacts with adjacent contacts 1.27 mm
(0.05 in) apart.  The nonmating portion of the connector is shown for reference
only.

  The nonshielded high-density cable connector for the P (Figure 4-2) shall be
a 68-conductor connector consisting of two rows of 34 male contacts with
adjacent contacts 1.27 mm (0.05 in) apart.  The nonshielded high-density cable
connector for the L (Figure 4-2) shall be a 110-conductor connector consisting
of two rows of 55 male contacts with adjacent contacts 1.27 mm (0.05 in) apart.
The nonmating portion of the connector is shown for reference only.

4.3.2. Shielded Connector Requirements

  One shielded connector is specified for the P and L cables.  The connector
shielding system should provide a dc resistance of less than 10 milliohms from
the cable shield at its termination point to the SCSI device enclosure.

  In order to support daisy-chain connections, SCSI devices that use shielded
connectors should provide two shielded device connectors on the device
enclosure.  These two connectors may be wired "one-to-one" with a stub to the
SCSI device's drivers and receivers provided the maximum stub length is not
violated.  Alternatively, two cables may be run from the two shielded
connectors to the drivers and receivers so that the maximum stub length is not
violated.  The length of the cable within the device enclosure is included
when calculating the total cable length of the SCSI bus.

4.3.2.1. Shielded Connector - P Cable and L Cable

  The shielded high-density SCSI device connector for the P (Figure 4-3) is a
68-conductor connector consisting of two rows of 34 female contacts with
adjacent contacts 1.27 mm (0.05 in) apart.  The shielded high-density SCSI
device connector for the L (Figure 4-3) is a 110-conductor connector consisting
of two rows of 55 female contacts with adjacent contacts 1.27 mm (0.05 in)
apart.  The nonmating portion of the connector is shown for reference only.

  The shielded high-density cable connector for the P (Figure 4-4) is a
68-conductor connector consisting of two rows of 34 male contacts with adjacent
contacts 1.27 mm (0.05 in) apart.  The shielded high-density cable connector
for the L (Figure 4-4) is a 110-conductor connector consisting of two rows of
55 male contacts with adjacent contacts 1.27 mm (0.05 in) apart.  The nonmating
portion of the connector is shown for reference only.

   Figure 4-1: 68/110-Contact Nonshielded High-Density SCSI Device Connector
                              (P Cable/L Cable)

      Figure 4-2: 68/110-Contact Nonshielded High-Density Cable Connector
                              (P Cable/L Cable)

    Figure 4-3: 68/110-Contact Shielded High-density SCSI Device Connector
                              (P Cable/L Cable)

       Figure 4-4: 68/110-Contact Shielded High-density Cable Connector
                              (P Cable/L Cable)

4.3.3. Connector Contact Assignments

  The connector contact assignments are defined in Tables 4-1 through 4-5.
Table 4-1 defines which of the other four tables to use and which set of
contact assignments to use.

    Table 4-1: Cross-Reference to Connector Contact Assignments

==============================================================================
                              Driver/                        Contact
                             Receiver           Connector  Assignment  Contact
    Connector Type             Type      Cable    Figure      Table      Set
------------------------------------------------------------------------------
Nonshielded Alternative 1  Single-Ended    P    4-1 & 4-2      4-2
Nonshielded Alternative 1  Single-Ended    L    4-1 & 4-2      4-3
Nonshielded Alternative 1  Differential    P    4-1 & 4-2      4-4
Nonshielded Alternative 1  Differential    L    4-1 & 4-2      4-5

Shielded Alternative 1     Single-Ended    P    4-3 & 4-4      4-2
Shielded Alternative 1     Single-Ended    L    4-3 & 4-4      4-3
Shielded Alternative 1     Differential    P    4-3 & 4-4      4-4
Shielded Alternative 1     Differential    L    4-3 & 4-4      4-5
==============================================================================

            Table 4-2: Single-Ended Contact Assignments - P cable

==============================================================================
                    Connector       Cable        Connector
      Signal         Contact      Conductor       Contact        Signal
       Name           Number       Number          Number         Name
------------------------------------------------------------------------------
      GROUND            1           1 3  2          35           -DB(12)
      GROUND            2           3 3  4          36           -DB(13)
      GROUND            3           5 3  6          37           -DB(14)
      GROUND            4           7 3  8          38           -DB(15)
      GROUND            5           9 3 10          39           -DB(P1)
      GROUND            6          11 3 12          40           -DB(0)
      GROUND            7          13 3 14          41           -DB(1)
      GROUND            8          15 3 16          42           -DB(2)
      GROUND            9          17 3 18          43           -DB(3)
      GROUND           10          19 3 20          44           -DB(4)
      GROUND           11          21 3 22          45           -DB(5)
      GROUND           12          23 3 24          46           -DB(6)
      GROUND           13          25 3 26          47           -DB(7)
      GROUND           14          27 3 28          48           -DB(P)
      GROUND           15          29 3 30          49           GROUND
      GROUND           16          31 3 32          50           GROUND
      TERMPWR          17          33 3 34          51           TERMPWR
      TERMPWR          18          35 3 36          52           TERMPWR
      RESERVED         19          37 3 38          53           RESERVED
      GROUND           20          39 3 40          54           GROUND
      GROUND           21          41 3 42          55           -ATN
      GROUND           22          43 3 44          56           GROUND
      GROUND           23          45 3 46          57           -BSY
      GROUND           24          47 3 48          58           -ACK
      GROUND           25          49 3 50          59           -RST
      GROUND           26          51 3 52          60           -MSG
      GROUND           27          53 3 54          61           -SEL
      GROUND           28          55 3 56          62           -C/D
      GROUND           29          57 3 58          63           -REQ
      GROUND           30          59 3 60          64           -I/O
      GROUND           31          61 3 62          65           -DB(8)
      GROUND           32          63 3 64          66           -DB(9)
      GROUND           33          65 3 66          67           -DB(10)
      GROUND           34          67 3 68          68           -DB(11)
==============================================================================

         NOTES:
           (1) The minus sign next to a signal indicates active low.
           (2) The conductor number refers to the conductor position when
         using 0.025- inch centerline flat ribbon cable.  Other cable types
         may be used to implement equivalent contact assignments.
           (3) 8 bit devices which connected to the P-cable shall leave the
         following signals open:
         -DB(12) -DB(13) -DB(14) -DB(15) -DB(P1) -DB(8) -DB(9) -DB(10) -DB(11)
         All other signals shall be connected as defined.


            Table 4-3: Single-Ended Contact Assignments - L cable

==============================================================================
                    Connector       Cable        Connector
      Signal         Contact      Conductor       Contact        Signal
       Name           Number       Number          Number         Name
------------------------------------------------------------------------------
      GROUND            1           1 |  2          56           GROUND
      GROUND            2           3 |  4          57           -DB(24)
      GROUND            3           5 |  6          58           -DB(25)
      GROUND            4           7 |  8          59           -DB(26)
      GROUND            5           9 | 10          60           -DB(27)
      GROUND            6          11 | 12          61           -DB(28)
      GROUND            7          13 | 14          62           -DB(29)
      GROUND            8          15 | 16          63           -DB(30)
      GROUND            9          17 | 18          64           -DB(31)
      GROUND           10          19 | 20          65           -DB(P3)
      GROUND           11          21 | 22          66           -DB(12)
      GROUND           12          23 | 24          67           -DB(13)
      GROUND           13          25 | 26          68           -DB(14)
      GROUND           14          27 | 28          69           -DB(15)
      GROUND           15          29 | 30          70           -DB(P1)
      GROUND           16          31 | 32          71           -DB(0)
      GROUND           17          33 | 34          72           -DB(1)
      GROUND           18          35 | 36          73           -DB(2)
      GROUND           19          37 | 38          74           -DB(3)
      GROUND           20          39 | 40          75           -DB(4)
      GROUND           21          41 | 42          76           -DB(5)
      GROUND           22          43 | 44          77           -DB(6)
      GROUND           23          45 | 46          78           -DB(7)
      GROUND           24          47 | 48          79           -DB(P)
      GROUND           25          49 | 50          80           GROUND
      GROUND           26          51 | 52          81           GROUND
      TERMPWR          27          53 | 54          82           TERMPWR
      TERMPWR          28          55 | 56          83           TERMPWR
      TERMPWR          29          57 | 58          84           TERMPWR
      GROUND           30          59 | 60          85           GROUND
      GROUND           31          61 | 62          86           -ATN
      GROUND           32          63 | 64          87           GROUND
      GROUND           33          65 | 66          88           -BSY
      GROUND           34          67 | 68          89           -ACK
      GROUND           35          69 | 70          90           -RST
      GROUND           36          71 | 72          91           -MSG
      GROUND           37          73 | 74          92           -SEL
      GROUND           38          75 | 76          93           -C/D
      GROUND           39          77 | 78          94           -REQ
      GROUND           40          79 | 70          95           -I/O
      GROUND           41          81 | 82          96           -DB(8)
      GROUND           42          83 | 84          97           -DB(9)
      GROUND           43          85 | 86          98           -DB(10)
      GROUND           44          87 | 88          99           -DB(11)
      GROUND           45          89 | 90          100          GROUND
      GROUND           46          91 | 92          101          -DB(16)
      GROUND           47          93 | 94          102          -DB(17)
      GROUND           48          95 | 96          103          -DB(18)
      GROUND           49          97 | 98          104          -DB(19)
      GROUND           50          99 | 100         105          -DB(20)
      GROUND           51         101 | 102         106          -DB(21)
      GROUND           52         103 | 104         107          -DB(22)
      GROUND           53         105 | 106         108          -DB(23)
      GROUND           54         107 | 108         109          -DB(P2)
      GROUND           55         109 | 110         110          GROUND
==============================================================================

        NOTES:
          (1) The minus sign next to a signal indicates active low.
          (2) The conductor number refers to the conductor position when
        using 0.025- inch centerline flat ribbon cable.  Other cable types
        may be used to implement equivalent contact assignments.
          (3) 8 bit devices which connect to the L-cable shall leave the
        following signals open:
        -DB(12) -DB(13) -DB(14) -DB(15) -DB(P1) -DB(8) -DB(9) -DB(10) -DB(11)
        -DB(20) -DB(21) -DB(22) -DB(23) -DB(P2) -DB(16) -DB(17) -DB(18) -DB(19)
        -DB(28) -DB(29) -DB(30) -DB(31) -DB(P3) -DB(24) -DB(25) -DB(26) -DB(27)
        All other signals shall be connected as defined.
          (4) 16 bit devices which connect to the L-cable shall leave the
        following signals open:
        -DB(20) -DB(21) -DB(22) -DB(23) -DB(P2) -DB(16) -DB(17) -DB(18) -DB(19)
        -DB(28) -DB(29) -DB(30) -DB(31) -DB(P3) -DB(24) -DB(25) -DB(26) -DB(27)
        All other signals shall be connected as defined.

            Table 4-4: Differential Contact Assignments - P cable

==============================================================================
                    Connector       Cable        Connector
      Signal         Contact      Conductor       Contact        Signal
       Name           Number       Number          Number         Name
------------------------------------------------------------------------------
      +DB(12)           1           1 3  2          35           -DB(12)
      +DB(13)           2           3 3  4          36           -DB(13)
      +DB(14)           3           5 3  6          37           -DB(14)
      +DB(15)           4           7 3  8          38           -DB(15)
      +DB(P1)           5           9 3 10          39           -DB(P1)
      GROUND            6          11 3 12          40           GROUND
      +DB(0)            7          13 3 14          41           -DB(0)
      +DB(1)            8          15 3 16          42           -DB(1)
      +DB(2)            9          17 3 18          43           -DB(2)
      +DB(3)           10          19 3 20          44           -DB(3)
      +DB(4)           11          21 3 22          45           -DB(4)
      +DB(5)           12          23 3 24          46           -DB(5)
      +DB(6)           13          25 3 26          47           -DB(6)
      +DB(7)           14          27 3 28          48           -DB(7)
      +DB(P)           15          29 3 30          49           -DB(P)
      DIFFSENS         16          31 3 32          50           GROUND
      TERMPWR          17          33 3 34          51           TERMPWR
      TERMPWR          18          35 3 36          52           TERMPWR
      RESERVED         19          37 3 38          53           RESERVED
      +ATN             20          39 3 40          54           -ATN
      GROUND           21          41 3 42          55           GROUND
      +BSY             22          43 3 44          56           -BSY
      +ACK             23          45 3 46          57           -ACK
      +RST             24          47 3 48          58           -RST
      +MSG             25          49 3 50          59           -MSG
      +SEL             26          51 3 52          60           -SEL
      +C/D             27          53 3 54          61           -C/D
      +REQ             28          55 3 56          62           -REQ
      +I/O             29          57 3 58          63           -I/O
      GROUND           30          59 3 60          64           GROUND
      +DB(8)           31          61 3 62          65           -DB(8)
      +DB(9)           32          63 3 64          66           -DB(9)
      +DB(10)          33          65 3 66          67           -DB(10)
      +DB(11)          34          67 3 68          68           -DB(11)
==============================================================================

         NOTES:
           (1) The conductor number refers to the conductor position
         when using 0.025- inch centerline flat ribbon cable.  Other cable
         types may be used to implement equivalent contact assignments.
           (2) 8 bit devices which connected to the P-cable shall leave the
         following signals open:
         -DB(12) -DB(13) -DB(14) -DB(15) -DB(P1) -DB(8) -DB(9) -DB(10) -DB(11)
         +DB(12) +DB(13) +DB(14) +DB(15) +DB(P1) +DB(8) +DB(9) +DB(10) +DB(11)
         All other signals shall be connected as defined.

            Table 4-5: Differential Contact Assignments - L cable

==============================================================================
                    Connector       Cable        Connector
      Signal         Contact      Conductor       Contact        Signal
       Name           Number       Number          Number         Name
------------------------------------------------------------------------------
      GROUND            1           1 |  2          56           GROUND
      +DB(24)           2           3 |  4          57           -DB(24)
      +DB(25)           3           5 |  6          58           -DB(25)
      +DB(26)           4           7 |  8          59           -DB(26)
      +DB(27)           5           9 | 10          60           -DB(27)
      +DB(28)           6          11 | 12          61           -DB(28)
      +DB(29)           7          13 | 14          62           -DB(29)
      +DB(30)           8          15 | 16          63           -DB(30)
      +DB(31)           9          17 | 18          64           -DB(31)
      +DB(P3)          10          19 | 20          65           -DB(P3)
      +DB(12)          11          21 | 22          66           -DB(12) 
      +DB(13)          12          23 | 24          67           -DB(13) 
      +DB(14)          13          25 | 26          68           -DB(14) 
      +DB(15)          14          27 | 28          69           -DB(15) 
      +DB(P1)          15          29 | 30          70           -DB(P1) 
      GROUND           16          31 | 32          71           GROUND  
      +DB(0)           17          33 | 34          72           -DB(0)  
      +DB(1)           18          35 | 36          73           -DB(1)  
      +DB(2)           19          37 | 38          74           -DB(2)  
      +DB(3)           20          39 | 40          75           -DB(3)  
      +DB(4)           21          41 | 42          76           -DB(4)  
      +DB(5)           22          43 | 44          77           -DB(5)  
      +DB(6)           23          45 | 46          78           -DB(6)  
      +DB(7)           24          47 | 48          79           -DB(7)  
      +DB(P)           25          49 | 50          80           -DB(P)  
      DIFFSENS         26          51 | 52          81           GROUND
      TERMPWR          27          53 | 54          82           TERMPWR 
      TERMPWR          28          55 | 56          83           TERMPWR 
      TERMPWR          29          57 | 58          84           TERMPWR 
      +ATN             30          59 | 60          85           -ATN    
      GROUND           31          61 | 62          86           GROUND  
      +BSY             32          63 | 64          87           -BSY    
      +ACK             33          65 | 66          88           -ACK    
      +RST             34          67 | 68          89           -RST    
      +MSG             35          69 | 70          90           -MSG    
      +SEL             36          71 | 72          91           -SEL    
      +C/D             37          73 | 74          92           -C/D    
      +REQ             38          75 | 76          93           -REQ    
      +I/O             39          77 | 78          94           -I/O    
      GROUND           40          79 | 70          95           GROUND  
      +DB(8)           41          81 | 82          96           -DB(8)  
      +DB(9)           42          83 | 84          97           -DB(9)  
      +DB(10)          43          85 | 86          98           -DB(10) 
      +DB(11)          44          87 | 88          99           -DB(11) 
      GROUND           45          89 | 90          100          GROUND
      +DB(16)          46          91 | 92          101          -DB(16)
      +DB(17)          47          93 | 94          102          -DB(17)
      +DB(18)          48          95 | 96          103          -DB(18)
      +DB(19)          49          97 | 98          104          -DB(19)
      +DB(20)          50          99 | 100         105          -DB(20)
      +DB(21)          51         101 | 102         106          -DB(21)
      +DB(22)          52         103 | 104         107          -DB(22)
      +DB(23)          53         105 | 106         108          -DB(23)
      +DB(P2)          54         107 | 108         109          -DB(P2)
      GROUND           55         109 | 110         110          GROUND
==============================================================================

         NOTES:
           (1) The minus sign next to a signal indicates active low.
           (2) The conductor number refers to the conductor position when
         using 0.025- inch centerline flat ribbon cable.  Other cable types
         may be used to implement equivalent contact assignments.
          (3) 8 bit devices which connect to the L-cable shall leave the
        following signals open:
        -DB(12) -DB(13) -DB(14) -DB(15) -DB(P1) -DB(8) -DB(9) -DB(10) -DB(11)
        +DB(12) +DB(13) +DB(14) +DB(15) +DB(P1) +DB(8) +DB(9) +DB(10) +DB(11)
        -DB(20) -DB(21) -DB(22) -DB(23) -DB(P2) -DB(16) -DB(17) -DB(18) -DB(19)
        +DB(20) +DB(21) +DB(22) +DB(23) +DB(P2) +DB(16) +DB(17) +DB(18) +DB(19)
        -DB(28) -DB(29) -DB(30) -DB(31) -DB(P3) -DB(24) -DB(25) -DB(26) -DB(27)
        +DB(28) +DB(29) +DB(30) +DB(31) +DB(P3) +DB(24) +DB(25) +DB(26) +DB(27)
        All other signals shall be connected as defined.
          (4) 16 bit devices which connect to the L-cable shall leave the
        following signals open:
        -DB(20) -DB(21) -DB(22) -DB(23) -DB(P2) -DB(16) -DB(17) -DB(18) -DB(19)
        +DB(20) +DB(21) +DB(22) +DB(23) +DB(P2) +DB(16) +DB(17) +DB(18) +DB(19)
        -DB(28) -DB(29) -DB(30) -DB(31) -DB(P3) -DB(24) -DB(25) -DB(26) -DB(27)
        +DB(28) +DB(29) +DB(30) +DB(31) +DB(P3) +DB(24) +DB(25) +DB(26) +DB(27)
        All other signals shall be connected as defined.

4.4. Electrical Description

  For the measurements in this section, SCSI bus termination is assumed to be
external to the SCSI device.  See 4.4.1 for the terminating requirements for
the RESERVED lines.  SCSI devices may have the provision for allowing optional
internal termination.

4.4.1. Single-Ended Alternative

  All signals not defined as RESERVED, GROUND, OPEN, or TERMPWR shall be
terminated at both ends of the cable.  The implementor may choose one of the
following two methods to terminate each end (see Figure 4-5):

  (1) The termination of each signal shall consist of 220 ohms (+_5%) to the
TERMPWR line and 330 ohms (+_5%) to ground.  Using resistors with +_1%
tolerance improves noise margins.
  (2) The termination of each signal shall meet these requirements:
     (a) The terminators shall each supply a characteristic impedance between
  100 and 132 ohms.
     (b) The terminators shall be powered by the TERMPWR line and may receive
  additional power from other sources but shall not require such additional
  power for proper operation (see 4.4.3).
     (c) The current available to any signal line driver shall not exceed
  48 milliamps when the driver asserts the line and pulls it to 0.5 volts dc.
  Only 44.8 mA of this current shall be available from the two terminators.
     (d) The voltage on all released signal lines shall be at least 2.5 volts
  dc when the TERMPWR line is within specified values (see 4.4.3).
     (e) These conditions shall be met with any legal configuration of targets
  and initiators as long as at least one device is supplying TERMPWR.

  The first termination method above is the same as in SCSI-1.  The second
termination method is recommended for better signal quality.

4.4.1.1. Output Characteristics
  All signals shall use open-collector or three-state drivers.  Each signal
driven by an SCSI device shall have the following output characteristics when
measured at the SCSI device's connector:
  VOL (Low-level output voltage) = 0.0 to 0.5 volts dc at 48 mA sinking
                                   (signal assertion)
  VOH (High-level output voltage) = 2.5 to 5.25 volts dc (signal negation)

4.4.1.2. Input Characteristics
  SCSI devices with power on shall meet the following electrical
characteristics on each signal (including both receivers and passive drivers):
  VIL (Low-level input voltage) = 0.0 to 0.8 volts dc (signal true)
  VIH (High-level input voltage) = 2.0 to 5.25 volts dc (signal false)
  IIL (Low-level input current) = -0.4 to 0.0 mA at VI = 0.5 volts dc
  IIH (High-level input current) = 0.0 to 0.1 mA at VI = 2.7 volts dc
  Minimum input hysteresis = 0.2 volts dc
  Maximum input capacitance = 25 pF (measured at the device connector closest
                              to the stub, if any, within the device)

  It is recommended that SCSI devices with power off also meet the above IIL
and IIH electrical characteristics on each signal.

  To achieve maximum noise immunity and to assure proper operation with
complex cable configurations, it is recommended that the nominal switching
threshold be approximately 1.4 volts.

4.4.2. Differential Alternative

  All signals consist of two lines denoted +SIGNAL and -SIGNAL.  A signal is
true when +SIGNAL is more positive than -SIGNAL, and a signal is false when
-SIGNAL is more positive than +SIGNAL.  All assigned signals of the P and Q
cables described in 4.6 shall be terminated at each end of the cable with a
terminator network as shown in Figure 4-6.  Resistor tolerances in the
terminator network shall be +_5% or less.

  The DIFFSENS signal of the connector is used as an active high enable for
the differential drivers.  If a single-ended device or terminator is
inadvertently connected, this signal is grounded, disabling the differential
drivers (see Figure 4-4 and Figure 4-5).

4.4.2.1. Output Characteristics
  Each signal driven by an SCSI device shall have the following output
characteristics when measured at the SCSI device's connector:
  VOL (Low-level output voltage) = 1.7 V maximum at IOL (Low-level output
                                   current) = 55 mA.
  VOH (High-level output voltage) = 2.7 V minimum at IOH (High-level output
                                    current) = -55 mA.
  VOD (Differential output voltage) = 1.0 V minimum with common-mode voltage
                                      ranges from -7 to +12 volts dc.

  VOL and VOH shall be as measured between the output terminal and the SCSI
device's logic ground reference.

  The output characteristics shall additionally conform to ISO 8482.

4.4.2.2. Input Characteristics
  SCSI devices shall meet the following electrical characteristics on each
signal (including both receivers and passive drivers):
  II (Input current on either input) = +_ 2.0 mA maximum.
  Maximum input capacitance = 25 pF.

  The II requirement shall be met with the input voltage varying between -7
and +12 volts dc, with power on or off, and with the hysteresis equaling 35
millivolts, minimum.

  The input characteristics shall additionally conform to ISO 8482.

4.4.3. Terminator Power

  SCSI initiators shall supply terminator power to the TERMPWR contact(s) This
power shall be supplied through a diode or similar semiconductor that prevents
backflow of power to the SCSI device.  Targets and SCSI devices that become
temporary initiators (e.g., targets which implement the COPY command or
asynchronous event notification) are not required to supply terminator power.
Any SCSI device may supply terminator power.  Interface error rates are lower
if the termination voltage is maintained at the extreme ends of the cable.

  All terminators independent of location shall be powered from the TERMPWR
contact(s).  The use of keyed connectors is recommended in SCSI devices that
provide terminator power to prevent accidental grounding or misconnection of
terminator power.

  IMPLEMENTORS NOTE:  Regulatory agencies may require limiting maximum (short
  circuit) current to the terminator power lines.  Recommended current limiting
  is 2 amperes for TERMPWR.  For systems utilizing multiple initiators, the
  initiators may be configured with option straps or current limiting devices.
  Maximum available current should not exceed 5 amperes.

  SCSI devices shall sink no more than 1.0 mA from TERMPWR except to power an
optional internal terminator.

   Single-ended SCSI devices providing terminator power on cable P and
cable L shall have the following characteristics:
  VTerm = 4.25 to 5.25 volts dc
          1500 mA minimum source drive capability

  Differential SCSI devices providing terminator power on cable P and
cable L shall have the following characteristics:
  VTerm = 4.0 to 5.25 volts dc
          1000 mA minimum source drive capability

  IMPLEMENTORS NOTE:  It is recommended that the terminator power lines be
  decoupled at each terminator with at least a 2.2 microfarad high-frequency
  capacitor to improve signal quality.


                          Alternative 1 Termination


                          Alternative 2 Termination

               Figure 4-5: Termination for Single-Ended Devices


               Figure 4-6: Termination for Differential Devices


              Figure 4-7: Differential Driver Protection Circuit

4.4.4. RESERVED Lines

  The lines labeled RESERVED shall be open on all SCSI devices.

4.5. SCSI Bus

  Communication on the SCSI bus is allowed between only two SCSI devices at
any given time.  There is a maximum of 16 SCSI devices on a P cabled system
and 32 SCSI devices on a L cabled system.  Each SCSI device
has an SCSI ID bit assigned as shown in Figure 4-8.  Three sample system
configurations are shown in Figure 4-9.

  When two SCSI devices communicate on the SCSI bus, one acts as an initiator
and the other acts as a target.  The initiator originates an operation and the
target performs the operation.  An SCSI device usually has a fixed role as an
initiator or target, but some devices may be able to assume either role.

  An initiator may address up to 16 peripheral devices that are connected to a
target on a P cabled system.  An initiator may address up to 32 peripheral
devices that are connected to a target on a L cabled system.  Three sample
system configurations are shown in Figure 4-8.

        SCSI ID bits for P and L peripheral devices:

    DB(7) DB(6) DB(5) DB(4) DB(3) DB(2) DB(1) DB(0)  <-- DATA BUS
    |     |     |     |     |     |     |     |
    |     |     |     |     |     |     |     SCSI ID = 0
    |     |     |     |     |     |     |
    |     |     |     |     |     |     SCSI ID = 1
    |     |     |     |     |     |
    |     |     |     |     |     SCSI ID = 2
    |     |     |     |     |
    |     |     |     |     SCSI ID = 3
    |     |     |     |
    |     |     |     SCSI ID = 4
    |     |     |
    |     |     SCSI ID = 5
    |     |
    |     SCSI ID = 6
    |
    SCSI ID = 7


        SCSI ID bits for P, and L peripheral devices:

    DB(15) DB(14) DB(13) DB(12) DB(11) DB(10) DB(9) DB(8)  <-- DATA BUS
    |      |      |      |      |      |      |     |
    |      |      |      |      |      |      |     SCSI ID = 8
    |      |      |      |      |      |      |
    |      |      |      |      |      |      SCSI ID = 9
    |      |      |      |      |      |
    |      |      |      |      |      SCSI ID = 10
    |      |      |      |      |
    |      |      |      |      SCSI ID = 11
    |      |      |      |
    |      |      |      SCSI ID = 12
    |      |      |
    |      |      SCSI ID = 13
    |      |
    |      SCSI ID = 14
    |
    SCSI ID = 15


        SCSI ID bits for L peripheral devices:

    DB(23) DB(22) DB(21) DB(20) DB(19) DB(18) DB(17) DB(16)  <-- DATA BUS
    |      |      |      |      |      |      |      |
    |      |      |      |      |      |      |      SCSI ID = 16
    |      |      |      |      |      |      |
    |      |      |      |      |      |      SCSI ID = 17
    |      |      |      |      |      |
    |      |      |      |      |      SCSI ID = 18
    |      |      |      |      |
    |      |      |      |      SCSI ID = 19
    |      |      |      |
    |      |      |      SCSI ID = 20
    |      |      |
    |      |      SCSI ID = 21
    |      |
    |      SCSI ID = 22
    |
    SCSI ID = 23


        SCSI ID bits for L peripheral devices:

    DB(31) DB(30) DB(29) DB(28) DB(27) DB(26) DB(25) DB(24)  <-- DATA BUS
    |      |      |      |      |      |      |      |
    |      |      |      |      |      |      |      SCSI ID = 24
    |      |      |      |      |      |      |
    |      |      |      |      |      |      SCSI ID = 25
    |      |      |      |      |      |
    |      |      |      |      |      SCSI ID = 26
    |      |      |      |      |
    |      |      |      |      SCSI ID = 27
    |      |      |      |
    |      |      |      SCSI ID = 28
    |      |      |
    |      |      SCSI ID = 29
    |      |
    |      SCSI ID = 30
    |
    SCSI ID = 31

                          Figure 4-8: SCSI ID Bits


                    Figure 4-9: Sample SCSI Configurations

  Up to 16 SCSI devices can be supported on the SCSI bus on P cabled systems.
Up to 32 SCSI devices can be supported on the SCSI bus on L cabled systems.
They can be any combination of initiators and targets provided there is at
least one of each.

  Certain SCSI bus functions are assigned to the initiator and certain SCSI
bus functions are assigned to the target.  The initiator may arbitrate for the
SCSI bus and select a particular target.  The target may request the transfer
of COMMAND, DATA, STATUS, or other information on the DATA BUS, and in some
cases it may arbitrate for the SCSI bus and reselect an initiator for the
purpose of continuing an operation.

  Information transfers on the DATA BUS are asynchronous and follow a defined
REQ/ACK handshake protocol.  One or two byte(s) of information may be
transferred with each handshake on the P cable.  One, two, or four bytes of
information may be transferred with each handshake on the L cable.  An option
is defined for synchronous data transfer.

4.6. SCSI Bus Signals

  There are a total of 27 signals on the P cable and 45 signals on the L
cable.  A total of 11 signals are used for control and 36 are used for data
(messages, commands, status, and data), including parity.  These signals are
described as follows:

BSY (BUSY).  An "OR-tied" signal that indicates that the bus is being used.

SEL (SELECT).  An "OR-tied" signal used by an initiator to select a target or
by a target to reselect an initiator.

C/D  (CONTROL/DATA).  A signal driven by a target that indicates whether
CONTROL or DATA information is on the DATA BUS.  True indicates CONTROL.

I/O (INPUT/OUTPUT).  A signal driven by a target that controls the direction
of data movement on the DATA BUS with respect to an initiator. True indicates
input to the initiator.  This signal is also used to distinguish between
SELECTION and RESELECTION phases.

MSG (MESSAGE).  A signal driven by a target during the MESSAGE phase.

REQ (REQUEST).  A signal driven by a target on the P cable to indicate a
request for a REQ/ACK data transfer handshake.

ACK (ACKNOWLEDGE).  A signal driven by an initiator on the P cable to
indicate an acknowledgment for a REQ/ACK data transfer handshake.

ATN (ATTENTION).  A signal driven by an initiator to indicate the ATTENTION
condition.

RST (RESET).  An "OR-tied" signal that indicates the RESET condition.

DB(7-0,P) (DATA BUS).  Eight data-bit signals, plus a parity-bit signal that
form a DATA BUS.  DB(7) is the most significant bit and has the highest
priority during the ARBITRATION phase.  Bit number, significance, and priority
decrease downward to DB(0).  A data bit is defined as one when the signal
value is true and is defined as zero when the signal value is false.  Data
parity DB(P) shall be odd.  Parity is undefined during the ARBITRATION phase.

DB(31-8,P1,P2,P3) (DATA BUS). Twenty-four data-bit signals, plus three
parity-bit signals that form an extension to the DATA BUS.  DB(P1,P2,P3) are
parity bits for DB(15-8), DB(23-16), and DB(31-24) respectively.  On SCSI
devices which support 16 IDs DB(15) has the highest priority in the DB(15-8)
byte during the ARBITRATION phase.  The priority decreases downward to DB(8).
DB(15) has a lower priority than DB(0).  On SCSI devices which support 32 IDs
DB(23) has the highest priority in the DB(23-16) byte and DB(31) has the
highest priority in the DB(31-24) byte during the ARBITRATION phase.  The
priority decreases downward to DB(16) in the DB(23-16) byte and to DB(24) in
the DB(31-24) byte.  DB(23) has a lower priority than DB(8) and DB(31) has a
lower priority than DB(16).  A data bit is defined as one when the signal value
is true and is defined as zero when the signal value is false.  Data parity
DB(Px) shall be odd.

4.6.1. Signal Values

  Signals may assume true or false values.  There are two methods of driving
these signals.  In both cases, the signal shall be actively driven true, or
asserted.  In the case of OR-tied drivers, the driver does not drive the
signal to the false state, rather the bias circuitry of the bus terminators
pulls the signal false whenever it is released by the drivers at every SCSI
device.  If any driver is asserted, then the signal is true.  In the case of
non-OR-tied drivers, the signal may be actively driven false.  In this
standard, wherever the term negated is used, it means that the signal may be
actively driven false, or may be simply released (in which case the bias
circuitry pulls it false), at the option of the implementor.  The advantage to
actively driving signals false during information transfer is that the
transition from true to false occurs more quickly and the noise margin is much
higher than if the signal is simply released.  This facilitates reliable data
transfer at high rates, especially at the longer cable lengths used with
differential drivers.

4.6.2. OR-Tied Signals

  The BSY, SEL, and RST signals shall be OR-tied only.  In the ordinary
operation of the bus, the BSY and RST signals may be simultaneously driven
true by several drivers.  No signals other than BSY, RST, and DB(P) are
simultaneously driven by two or more drivers, and any signal other than BSY,
SEL, and RST may employ OR-tied or non-OR-tied drivers.  DB(P) shall not be
driven false during the ARBITRATION phase but may be driven false in other
phases.  There is no operational problem in mixing OR-tied and non-OR-tied
drivers on signals other than BSY and RST.

4.6.3. Signal Sources

  Table 4-6 indicates which type of SCSI device is allowed to source each
signal.  No attempt is made to show if the source is driving asserted, driving
negated, or is passive.  All SCSI device drivers that are not active sources
shall be in the passive state.  The RST signal may be asserted by any SCSI
device at any time.


                          Table 4-6: Signal Sources

===============================================================================
                      P cable Signals
              -----------------------------------------
                          C/D,        8,16,32  16,32 ID
                          I/O,        ID Dev   Device
                          MSG,  ACK,  DB(7-0)  DB(15-8)
 Bus Phase    BSY   SEL   REQ   ATN   DB(P)    DB(P1)
 -----------  ----  ----  ----  ----  -------  --------
 BUS FREE     None  None  None  None  None     None
 ARBITRATION  All   Win   None  None  S ID     S ID
 SELECTION    I&T   Init  None  Init  Init     Init
 RESELECTION  I&T   Targ  Targ  Init  Targ     Targ
 COMMAND      Targ  None  Targ  Init  Init     None
 DATA IN      Targ  None  Targ  Init  Targ     Targ
 DATA OUT     Targ  None  Targ  Init  Init     Init
 STATUS       Targ  None  Targ  Init  Targ     None
 MESSAGE IN   Targ  None  Targ  Init  Targ     None
 MESSAGE OUT  Targ  None  Targ  Init  Init     None
==============================================================================
                               L cable Signals
              --------------------------------------------------
                          C/D,        8,16,32  16,32 ID  32 ID
                          I/O,        ID Dev   Device    Device
                          MSG,  ACK,  DB(7-0)  DB(15-8)  DB(31-16)
 Bus Phase    BSY   SEL   REQ   ATN   DB(P)    DB(P1)    DB(P2,P3)
 -----------  ----  ----  ----  ----  -------  --------  --------
 BUS FREE     None  None  None  None  None     None      None
 ARBITRATION  All   Win   None  None  S ID     S ID      S ID
 SELECTION    I&T   Init  None  Init  Init     Init      Init
 RESELECTION  I&T   Targ  Targ  Init  Targ     Targ      Targ
 COMMAND      Targ  None  Targ  Init  Init     None      None
 DATA IN      Targ  None  Targ  Init  Targ     Targ      Targ
 DATA OUT     Targ  None  Targ  Init  Init     Init      Init
 STATUS       Targ  None  Targ  Init  Targ     None      None
 MESSAGE IN   Targ  None  Targ  Init  Targ     None      None
 MESSAGE OUT  Targ  None  Targ  Init  Init     None      None
==============================================================================


All:    The signal shall be driven by all SCSI devices that are actively
        arbitrating.

S ID:   A unique data bit (the SCSI ID) shall be driven by each SCSI device
        that is actively arbitrating; the other data bits shall be
        released (i.e., not driven) by this SCSI device.  The parity bit
        (DB(P)) may be released or driven to the true state, but shall never
        be driven to the false state during this phase.

I&T:    The signal shall be driven by the initiator, target, or both, as
        specified in the SELECTION phase and RESELECTION phase.

Init:   If driven, this signal shall be driven only by the active initiator.

None:   The signal shall be released; that is, not be driven by any SCSI
        device.  The bias circuitry of the bus terminators pulls the signal to
        the false state.

Win:    The signal shall be driven by the one SCSI device that wins
        arbitration.

Targ:   If the signal is driven, it shall be driven only by the active target.


4.7. SCSI Bus Timing

  Unless otherwise indicated, the delay-time measurements for each SCSI
device, shown in Table 4-7, shall be calculated from signal conditions
existing at that SCSI device's own SCSI bus connection.  Thus, these
measurements (except cable skew delay) can be made without considering delays
in the cable.  The timing characteristics of each signal are described in the
following paragraphs.

                      Table 4-7: SCSI Bus Timing Values

        ==============================================================
        Arbitration Delay . . . . . . . . 2.4 microseconds
        Assertion Period  . . . . . . . .  90 nanoseconds
        Bus Clear Delay . . . . . . . . . 800 nanoseconds
        Bus Free Delay  . . . . . . . . . 800 nanoseconds
        Bus Set Delay . . . . . . . . . . 1.8 microseconds
        Bus Settle Delay  . . . . . . . . 400 nanoseconds
        Cable Skew Delay  . . . . . . . .  10 nanoseconds
        Data Release Delay  . . . . . . . 400 nanoseconds
        Deskew Delay  . . . . . . . . . .  45 nanoseconds
        Disconnection Delay . . . . . . . 200 microseconds
        Hold Time . . . . . . . . . . . .  45 nanoseconds
        Negation Period . . . . . . . . .  90 nanoseconds
        Power-On to Selection Time  . . .  10 seconds recommended
        Reset to Selection Time . . . . . 250 milliseconds recommended
        Reset Hold Time . . . . . . . . .  25 microseconds
        Selection Abort Time  . . . . . . 200 microseconds
        Selection Time-out Delay  . . . . 250 milliseconds recommended
        Transfer Period . . . . . . . . . set during an SDTR message
        Fast Assertion Period . . . . . .  30 nanoseconds
        Fast Cable Skew Delay . . . . . .   5 nanoseconds
        Fast Deskew Delay . . . . . . . .  20 nanoseconds
        Fast Hold Time  . . . . . . . . .  10 nanoseconds
        Fast Negation Period  . . . . . .  30 nanoseconds
        ==============================================================


4.7.1. Arbitration Delay 

  The minimum time an SCSI device shall wait from asserting BSY for
arbitration until the DATA BUS can be examined to see if arbitration has been
won.  There is no maximum time.

4.7.2. Assertion Period 

  The minimum time that a target shall assert REQ while using synchronous data
transfers.  Also, the minimum time that an initiator shall assert ACK while
using synchronous data transfers.

4.7.3. Bus Clear Delay 

  The maximum time for an SCSI device to stop driving all bus signals after:
  (1) The BUS FREE phase is detected (BSY and SEL both false for a bus settle
  delay)
  (2) SEL is received from another SCSI device during the ARBITRATION phase
  (3) The transition of RST to true.

  For the first condition above, the maximum time for an SCSI device to clear
the bus is 1200 nanoseconds from BSY and SEL first becoming both false.  If an
SCSI device requires more than a bus settle delay to detect BUS FREE phase, it
shall clear the bus within a bus clear delay minus the excess time.

4.7.4. Bus Free Delay 

  The minimum time that an SCSI device shall wait from its detection of the
BUS FREE phase (BSY and SEL both false for a bus settle delay) until its
assertion of BSY when going to the ARBITRATION phase.

4.7.5. Bus Set Delay 

  The maximum time for an SCSI device to assert BSY and its SCSI ID bit on the
DATA BUS after it detects BUS FREE phase (BSY and SEL both false for a bus
settle delay) for the purpose of entering the ARBITRATION phase.

4.7.6. Bus Settle Delay 

  The minimum time to wait for the bus to settle after changing certain
control signals as called out in the protocol definitions.

4.7.7. Cable Skew Delay 

  The maximum difference in propagation time allowed between any two SCSI bus
signals measured between any two SCSI devices.

4.7.8. Data Release Delay 

  The maximum time for an initiator to release the DATA BUS signals following
the transition of the I/O signal from false to true.

4.7.9. Deskew Delay 

  The minimum time required for deskew of certain signals.

4.7.10. Disconnection Delay 

  The minimum time that a target shall wait after releasing BSY before
participating in an ARBITRATION phase when honoring a DISCONNECT message from
the initiator.

4.7.11. Hold Time 

  The minimum time added between the assertion of REQ or ACK and the changing
of the data lines to provide hold time in the initiator or target while using
synchronous data transfers.

4.7.12. Negation Period 

  The minimum time that a target shall negate REQ while using synchronous data
transfers.  Also, the minimum time that an initiator shall negate ACK while
using synchronous data transfers.

4.7.13. Power-On to Selection Time 

  The recommended maximum time from power application until an SCSI target is
able to respond with appropriate status and sense data to the TEST UNIT READY,
INQUIRY, and REQUEST SENSE commands.

4.7.14. Reset to Selection Time 

  The recommended maximum time after a hard RESET condition until an SCSI
target is able to respond with appropriate status and sense data to the TEST
UNIT READY, INQUIRY, and REQUEST SENSE commands.

4.7.15. Reset Hold Time 

  The minimum time for which RST is asserted.  There is no maximum time.

4.7.16. Selection Abort Time 

  The maximum time that a target (or initiator) shall take from its most
recent detection of being selected (or reselected) until asserting a BSY
response.  This time-out is required to ensure that a target (or initiator)
does not assert BSY after a SELECTION (or RESELECTION) phase has been aborted.
This is not the selection time-out period; see 5.1.3.1 and 5.1.4.2 for a
complete description.

4.7.17. Selection Time-out Delay 

  The minimum time that an initiator (or target) should wait for a BSY
response during the SELECTION (or RESELECTION) phase before starting the time-
out procedure.  Note that this is only a recommended time period.

4.7.18. Transfer Period 

  The Transfer Period specifies the minimum time allowed between the leading
edges of successive REQ pulses and of successive ACK pulses while using
synchronous data transfers.  (See 5.1.5.2 and 5.6.21.)

4.8. Fast Synchronous Transfer Option

  When devices negotiate a synchronous data transfer period between 100 ns and
200 ns they are said to be using "fast synchronous data transfers".  Devices
which negotiate a synchronous data transfer period greater than 200 ns use
timing parameters specified in 4.7.  When a fast synchronous data transfer
period is negotiated, those specific times redefined in this section are used;
those not redefined remain the same.  The minimum synchronous data transfer
period is 100 ns.

4.8.1. Fast Assertion Period 

  This value is the minimum time that a target shall assert REQ while using
fast synchronous data transfers.  Also, the minimum time that an initiator
shall assert ACK while using fast synchronous data transfers.

4.8.2. Fast Cable Skew Delay 

  This value is the maximum difference in propagation time allowed between any
two SCSI bus signals measured between any two SCSI devices while using fast
synchronous data transfers.

4.8.3. Fast Deskew Delay 

  This value is the minimum time required for deskew of certain signals while
using fast synchronous data transfers.

4.8.4. Fast Hold Time 

  This value is the minimum time added between the assertion of REQ or ACK and
the changing of the data lines to provide hold time in the initiator or target,
respectively, while using fast synchronous data transfers.

4.8.5. Fast Negation Period 

  This value is the minimum time that a target shall negate REQ
while using fast synchronous data transfers.  Also, the minimum time that an
initiator shall negate ACK while using fast synchronous data
transfers.

5. Logical Characteristics

5.1. SCSI Bus Phases

  The SCSI architecture includes eight distinct phases:

  BUS FREE phase
  ARBITRATION phase
  SELECTION phase
  RESELECTION phase
  COMMAND phase  \
  DATA phase      \   These phases are collectively termed the
  STATUS phase    /   information transfer phases.
  MESSAGE phase  /

  The SCSI bus can never be in more than one phase at any given time.  In the
following descriptions, signals that are not mentioned shall not be asserted.

5.1.2. ARBITRATION Phase

  The ARBITRATION phase allows one SCSI device to gain control of the SCSI bus
so that it can initiate or resume an I/O process.

  The procedure for an SCSI device to obtain control of the SCSI bus is as
follows:
  (1) The SCSI device shall first wait for the BUS FREE phase to occur.  The
BUS FREE phase is detected whenever both the BSY and SEL signals are
simultaneously and continuously false for a minimum of a bus settle delay.

  IMPLEMENTORS NOTE:  This bus settle delay is necessary because a
  transmission line phenomenon known as a "wired-OR glitch" may cause the BSY
  signal to briefly appear false, even though it is being driven true.

  (2) The SCSI device shall wait a minimum of a bus free delay after detection
of the BUS FREE phase (i.e. after the BSY and SEL signals are both false for a
bus settle delay) before driving any signal.
  (3) Following the bus free delay in Step (2), the SCSI device may arbitrate
for the SCSI bus by asserting both the BSY signal and its own SCSI ID, however
the SCSI device shall not arbitrate (i.e. assert the BSY signal and its SCSI
ID) if more than a bus set delay has passed since the BUS FREE phase was last
observed.

  IMPLEMENTORS NOTE:  There is no maximum delay before asserting the BSY
  signal and the SCSI ID following the bus free delay in Step (2) as long as
  the bus remains in the BUS FREE phase.  However, SCSI devices that delay
  longer than a bus settle delay plus a bus set delay from the time when the
  BSY and SEL signals first become false may fail to participate in
  arbitration when competing with faster SCSI devices.

  (4) After waiting at least an arbitration delay (measured from its assertion
of the BSY signal) the SCSI device shall examine the DATA BUS.  If a higher
priority SCSI ID bit is true on the DATA BUS (DB(7) is the highest), then the
SCSI device has lost the arbitration and the SCSI device may release its
signals and return to Step (1).  If no higher priority SCSI ID bit is true on
the DATA BUS, then the SCSI device has won the arbitration and it shall assert
the SEL signal.  Any SCSI device other than the winner has lost the
arbitration and shall release the BSY signal and its SCSI ID bit within a bus
clear delay after the SEL signal becomes true.  An SCSI device that loses
arbitration may return to Step (1).

  The SCSI ID priority is shown below:
                                     Priority
                    Highest             -->              Lowest
                    SCSI ID                              SCSI ID

        P Cable        7         0                15        8
        L Cable        7    0    15    8    23    16   31   24


  IMPLEMENTORS NOTE:  It is recommended that new implementations wait for the
  SEL signal to become true before releasing the BSY signal and SCSI ID bit
  when arbitration is lost.

  (5)  The SCSI device that wins arbitration shall wait at least a bus clear
delay plus a bus settle delay after asserting the SEL signal before changing
any signals.

  NOTE:  The SCSI ID bit is a single bit on the DATA BUS that corresponds to
  the SCSI device's unique SCSI address.  All other DATA BUS bits shall be
  released by the SCSI device.  Parity is not valid during the ARBITRATION
  phase.  During the ARBITRATION phase, DB(PX) may be released or asserted, but
  shall not be actively driven false.

5.1.5. Information Transfer Phases

  NOTE:  The COMMAND, DATA, STATUS, and MESSAGE phases are all grouped
  together as the information transfer phases because they are all used to
  transfer data or control information via the DATA BUS.  The actual content
  of the information is beyond the scope of this section.

  The C/D, I/O, and MSG signals are used to distinguish between the different
information transfer phases (see Table 5-1).  The target drives these three
signals and therefore controls all changes from one phase to another.  The
initiator can request a MESSAGE OUT phase by asserting the ATN signal, while
the target can cause the BUS FREE phase by releasing the MSG, C/D, I/O, and
BSY signals.

  The information transfer phases use one or more REQ/ACK handshakes to
control the information transfer.  Each REQ/ACK handshake allows the transfer
of one byte of information.  During the information transfer phases the BSY
signal shall remain true and the SEL signal shall remain false.  Additionally,
during the information transfer phases, the target shall continuously envelope
the REQ/ACK handshake(s) with the C/D, I/O, and MSG signals in such a manner
that these control signals are valid for a bus settle delay before the
assertion of the REQ signal of the first handshake and remain valid until
after the negation of the ACK signal at the end of the handshake of the last
transfer of the phase.

  IMPLEMENTORS NOTES:
  (1) After the negation of the ACK signal of the last transfer of the phase,
  the target may prepare for a new phase by asserting or negating the C/D,
  I/O, and MSG signals.  These signals may be changed together or
  individually.  They may be changed in any order and may be changed more than
  once.  It is desirable that each line change only once.  A new phase does
  not begin until the REQ signal is asserted for the first byte of the new
  phase.
  (2) A phase is defined as ending when the C/D, I/O, or MSG signals change
  after the negation of the ACK signal.  The time between the end of a phase
  and the assertion of the REQ signal beginning a new phase is undefined.  An
  initiator is allowed to anticipate a new phase based on the previous phase,
  the expected new phase, and early information provided by changes in the
  C/D, I/O, and MSG signals.  However, the anticipated phase is not valid
  until the REQ signal is asserted at the beginning of a the next phase.

                   Table 5-1: Information Transfer Phases

==============================================================================
   Signal
-----------
MSG C/D I/O   Phase Name          Direction Of Transfer         Comment
------------------------------------------------------------------------------
 0   0   0    DATA OUT            Initiator to target     \     Data
 0   0   1    DATA IN             Initiator from target   /     Phase
 0   1   0    COMMAND             Initiator to target
 0   1   1    STATUS              Initiator from target
 1   0   0    *
 1   0   1    *
 1   1   0    MESSAGE OUT         Initiator to target     \     Message
 1   1   1    MESSAGE IN          Initiator from target   /     Phase
==============================================================================

  Key:  0 = False,  1 = True,  * = Reserved for future standardization.

5.1.5.3. Wide Data Transfer
  Wide data transfer is optional and may be used in the DATA phase only if a
nonzero wide data transfer agreement is in effect.  The messages determine the
use of wide mode by both SCSI devices and establish a data path width to be
used during the DATA phase.

  Wide data transfers of 16- or 32-bits may be established.  Although not
mandatory, it is recommended that targets and initiators that support 32-bit
wide transfers also support 16-bit wide transfers as well.  All SCSI devices
shall support 8-bit data transfers.

  During 16-bit wide data transfers, the first and second logical data bytes
for each data phase shall be transferred across the DB(7-0,P) and DB(15-8,P2)
signals, respectively, on the P cable.  Subsequent pairs of data bytes are
likewise transferred in parallel across the P cable (see Figure 5-1).

  During 32-bit wide data transfers, the first, second, third, and fourth
logical data bytes for each data phase shall be transferred across the
DB(7-0,P), DB(15-8,P2), DB(23-16,P2), and DB(31-24,P3) signals, respectively,
on the L cable.  Subsequent pairs of data bytes are likewise transferred in
parallel across the L cable (see Figure 5-1).


    When transferring bytes W, X, Y and Z across the three bus widths,
    they are transferred as shown below:

    Hand-  8-bit           16-bit                      32-bit
    shake                                  ______  _____  _______ ______
      #   P Cable         P cable         /           L Cable           \
         +-------+   +---------------+   +-------------------------------+
      1  |   W   |   |   X   |   W   |   |   Z   |   Y   |   X   |   W   |
         |-------|   |-------+-------|   +-------------------------------+
      2  |   X   |   |   Z   |   Y   |    31...24 23...16 15....8 7.....0
         |-------|   +---------------+               Bit Number
      3  |   Y   |    15....8 7.....0
         |-------|
      4  |   Z   |       Bit Number
         +-------+
          7.....0

         Bit Number

     NOTE: This figure does not represent how these bytes are stored in
           the initiator's memory, which may be different.


                     Figure 5-1: Wide SCSI Byte Ordering


  If the last data byte transferred for a command does not fall on the DB(15-
8,P1) signals for a 16-bit wide transfer or the DB(31-24,P3) signals for a 32-
bit wide transfer, then the values of the remaining higher-numbered bits are
undefined.  However, parity bits for these undefined bytes shall be valid for
whatever data is placed on the bus.

7. All Device Types

7.2. Commands for All Device Types

  The operation codes for commands that apply to all device types are listed
in Table 7-1.

                  Table 7-1: Commands for All Device Types

==============================================================================
                                   Operation
Command Name                         Code       Type    Section
------------------------------------------------------------------------------
CHANGE DEFINITION                     40h        O       7.2.1
COMPARE                               39h        O       7.2.2
COPY                                  18h        O       7.2.3
COPY AND VERIFY                       3Ah        O       7.2.4
INQUIRY                               12h        M       7.2.5
LOG SELECT                            4Ch        O       7.2.6
LOG SENSE                             4Dh        O       7.2.7
MODE SELECT(6)                        15h        Z       7.2.8
MODE SELECT(10)                       55h        Z       7.2.9
MODE SENSE(6)                         1Ah        Z       7.2.10
MODE SENSE(10)                        5Ah        Z       7.2.11
READ BUFFER                           3Ch        O       7.2.12
RECEIVE DIAGNOSTIC RESULTS            1Ch        O       7.2.13
REQUEST SENSE                         03h        M       7.2.14
SEND DIAGNOSTIC                       1Dh        O       7.2.15
TEST UNIT READY                       00h        M       7.2.16
WRITE BUFFER                          3Bh        O       7.2.17
==============================================================================

  Key:  M = Command implementation is mandatory.
        O = Command implementation is optional.
        Z = Command implementation is device type specific.

7.2.3. COPY Command


                           Table 7-5: COPY Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (18h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      |              Reserved             |  Pad   |
-----+-----------------------------------------------------------------------|
 2   | (MSB)                                                                 |
- - -|- -                        Parameter List Length                    - -|
 4   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


  The COPY command (Table 7-5) provides a means to copy data from one logical
unit to another or the same logical unit.  The logical unit that receives and
performs the COPY command is called the copy manager.  The copy manager is
responsible for copying data from a logical unit (source device) to a logical
unit (destination device).  These logical units may reside on different SCSI
devices or the same SCSI device (in fact all three may be the same logical
unit).  Some SCSI devices that implement this command may not support copies
to or from another SCSI device, or may not support third party copies (i.e.,
both the source and the destination logical units reside on other SCSI
devices).

  The pad bit (7.2.3.7) is used in conjunction with the Cat bit (7.2.3.7) in
the segment descriptors to define what action should be taken when a segment
of the copy does not fit exactly into an integer number of destination blocks.
  The parameter list length field specifies the length in bytes of the
parameters that shall be sent during the DATA OUT phase of the command.  A
parameter list length of zero indicates that no data shall be transferred.
This condition shall not be considered as an error.

  The COPY parameter list (Table 7-6) begins with a four-byte header that
contains the COPY function code and priority.  Following the header is one or
more segment descriptors.

                       Table 7-6: COPY Parameter List

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |         COPY Function Code                 |         Priority         |
-----+-----------------------------------------------------------------------|
 1   |                           Vendor Specific                             |
-----+-----------------------------------------------------------------------|
 2   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 3   |                           Reserved                                    |
==============================================================================
     |                         Segment Descriptor(s)                         |
==============================================================================
 0 - |                           Segment Descriptor 0                        |
 xx  |                     (See specific table for length.)                  |
-----+-----------------------------------------------------------------------|
     |                                 .                                     |
     |                                 .                                     |
     |                                 .                                     |
-----+-----------------------------------------------------------------------|
 0 - |                           Segment Descriptor n                        |
 xx  |                     (See specific table for length.)                  |
==============================================================================


  The COPY function code field defines a specific format for the segment
descriptors.  The COPY function codes are defined in Table 7-7.  A target need
not support all function codes for its device type.

  The priority field of the COPY parameter list establishes the relative
priority of this COPY command to other commands being executed by the same
target.  All other commands are assumed to have a priority of 1.  Priority 0
is the highest priority with increasing values indicating lower priorities.

  The segment descriptor formats are determined by the COPY function code.
The segment descriptor format used for write-once devices, CD-ROM devices, and
optical-memory devices shall be the same as for direct-access devices.  The
segment descriptor format used for printer devices, communications, and
processor devices, shall be the same as for sequential-access devices.  Thus a
COPY from a write-once device to a printer device uses the same segment
descriptor format as for a COPY from a direct-access device to a sequential-
access device (see Table 7-7).  The segment descriptor formats are described
in Tables 7-8 through 7-11.  A maximum of 256 segment descriptors are
permitted.  The segment descriptors are identified by ascending numbers
beginning with zero.

                       Table 7-7: COPY Function Codes

==============================================================================
       Peripheral Device Type                COPY      Segment
       ----------------------              Function   Descriptor
Source                 Destination           Code       Table     Comments
------------------------------------------------------------------------------
Direct-Access          Sequential-Access       0         7-8
 (0,4,5,7)              (1,2,3,9)
Sequential-Access      Direct-Access           1         7-8
 (1,3,9)                (0,4,7)
Direct-Access          Direct-Access           2         7-9
 (0,4,5,7)              (0,4,7)
Sequential-Access      Sequential-Access       3         7-10
 (1,3,9)                (1,2,3,9)
Sequential-Access      Sequential-Access       4         7-11    Image Copy
 (1)                    (1)
Direct-Access          Sequential-Access       5         7-new1  32 address
 (0,4,5,7)              (1,2,3,9)
Sequential-Access      Direct-Access           6         7-new1  32 address
 (1,3,9)                (0,4,7)
Direct-Access          Direct-Access           7         7-new2  32 address
 (0,4,5,7)              (0,4,7)
Sequential-Access      Sequential-Access       8         7-new3  32 address
 (1,3,9)                (1,2,3,9)
Sequential-Access      Sequential-Access       9         7-new4  Image Copy;
 (1)                    (1)                                      32 address
==============================================================================


  The numbers in parenthesis are the peripheral device type codes (see Table
7-17).

COPY function code:  00h        Direct-access to sequential-access
                     01h        Sequential-access to writable direct-access
                     02h        Direct-access to writable direct-access
                     03h        Sequential-access to sequential-access
                     04h        Sequential-access image copy
                     05h        Direct-access to sequential-access
                     06h        Sequential-access to writable direct-access
                     07h        Direct-access to writable direct-access
                     08h        Sequential-access to sequential-access
                     09h        Sequential-access image copy
                     0Ah - 0Fh  Reserved
                     10h - 1Fh  Vendor specific

  For the COMPARE command the destination direct-access device does not have
to be a writable device.

7.2.3.1. Errors Detected by the Managing SCSI Device
  Two classes of exception conditions may occur during execution of a COPY
command.  The first class consists of those exception conditions detected by
the SCSI device that received the COPY command and is managing the execution
of the command.  These conditions include parity errors while transferring the
COPY command and status byte, invalid parameters in the COPY command, invalid
segment descriptors, and inability of the SCSI device controlling the COPY
functions to continue operating.  In the event of such an exception condition,
the SCSI device managing the COPY shall:
  (1) Terminate the COPY command with CHECK CONDITION status.
  (2) The valid bit in the sense data shall be set to one.  The segment number
shall contain the number of the segment descriptor being processed at the time
the exception condition is detected.  The sense key shall contain the sense
key code describing the exception condition (i.e., not COPY ABORTED).  The
information field shall contain the difference between the number of blocks
field in the segment descriptor being processed at the time of the failure and
the number of blocks successfully copied.  This number is the residue of
unprocessed blocks remaining for the segment descriptor.

7.2.3.2. Errors Detected by a Target
  The second class of errors consists of exception conditions detected by the
SCSI device transferring data at the request of the SCSI device managing the
transfer.  The SCSI device managing the COPY command detects exception
conditions by receiving CHECK CONDITION status from one of the SCSI devices it
is managing.  It then shall recover the sense data associated with the
exception condition.

  The SCSI device managing the COPY command may also be the source or
destination SCSI device (or both).  It shall distinguish between a failure of
the management of the COPY and a failure of the data transfer being requested.
It shall then create the appropriate sense data internally.

  After recovering the sense data associated with the detected error, the SCSI
device managing the COPY command shall:
  (1) Terminate the COPY command with CHECK CONDITION status.
  (2) The valid bit in the sense data shall be set to one.  The segment number
shall contain the number of the segment descriptor being processed at the time
the exception condition is detected.  The sense key shall be set to COPY
ABORTED.  The information field shall contain the difference between the
number of blocks field in the segment descriptor being processed at the time
of the failure and the number of blocks successfully copied.  This number is
the residue of unprocessed blocks remaining for the segment descriptor.

  The first byte of the command-specific information field shall specify the
starting byte number, relative to the first byte of sense data, of an area
that contains (unchanged) the source logical unit's status byte and sense
data.  A zero value indicates that no status byte or sense data is being
returned for the source logical unit.

  The second byte of the command-specific information field shall specify the
starting byte number, relative to the first byte of sense data, of an area
that contains (unchanged) the destination logical unit's status byte and sense
data.  A zero value indicates that no status byte or sense data is being
returned for the destination logical unit.

7.2.3.3. COPY Function Code 00h, 01h, 05h, and 06h
  The format for the segment descriptors for COPY transfers between direct-
access and sequential-access devices is specified in Table 7-8 and Table
7-new1.  These formats are required for COPY function codes 00h or 01h and
COPY function codes 05h and 06h, respectively.  The segment descriptor may be
repeated up to 256 times within the parameter list length specified in the
  command descriptor block.

      Table 7-8: Segment Descriptor for COPY Function Codes 00h and 01h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   | Source Address           |Reserved|  Cat   |     Source LUN           |
-----+--------------------------+-----------------+--------------------------|
 1   | Destination Address      |   Reserved      |     Destination LUN      |
-----+-----------------------------------------------------------------------|
 2   | (MSB)                                                                 |
-----+---             Sequential-Access Device Block Length               ---|
 3   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
- - -|- -             Direct-Access Device Number of Blocks               - -|
 7   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -             Direct-Access Device Logical Block Address          - -|
11   |                                                                 (LSB) |
==============================================================================


         Table 7-new1: Segment Descriptor for Function Codes 05h and 06h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                             Source Address                            |
-----+-----------------------------------------------------------------------|
 1   |  CAT   |   Reserved                        |        Source LUN        |
-----+-----------------------------------------------------------------------|
 2   |                          Destination Address                          |
-----+-----------------------------------------------------------------------|
 3   |            Reserved                        |     Destination LUN      |
-----+-----------------------------------------------------------------------|
 4   |                                Reserved                               |
-----+-----------------------------------------------------------------------|
 5   | (MSB)                                                                 |
-----+---             Sequential-Access Device Block Length               ---|
 7   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -             Direct-Access Device Number of Blocks               - -|
11   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
12   | (MSB)                                                                 |
- - -|- -             Direct-Access Device Logical Block Address          - -|
15   |                                                                 (LSB) |
==============================================================================


  The source address and source LUN fields specify the SCSI bus ID and logical
unit of the device to copy the data from for this segment of the COPY command.
The destination address and destination LUN fields specify the SCSI bus ID and
logical unit to copy the data to for this segment of the COPY command.  Some
SCSI devices may not support third-party COPY in which the copying SCSI device
is not the source or destination device.  Some SCSI devices only support COPY
within the SCSI device and not to other SCSI devices.  If an unsupported COPY
operation is requested, the command shall be terminated with CHECK CONDITION
status and the sense key shall be set to ILLEGAL REQUEST with an additional
sense code of INVALID FIELD IN PARAMETER LIST (see 7.2.3.1).

  A catenate (Cat) bit (optional) of one indicates that the COPY manager shall
catenate the last source block of a segment with the first source block of the
next segment if the last source block does not end exactly at the end of the
destination block.  The definition of a cat bit of zero depends on the setting
of the pad bit in the command descriptor block  (see 7.2.3.7).

  The sequential-access device block-length field specifies the block length
to be used on the sequential-access logical unit during this segment of the
COPY command.  If the SCSI device managing the COPY knows this block length is
not supported, the command shall be terminated with CHECK CONDITION status and
the sense key shall be set to ILLEGAL REQUEST with an additional sense code of
INVALID FIELD IN PARAMETER LIST . If the block length is found to be invalid
while executing a read or write operation to the sequential-access device, the
command shall be terminated with CHECK CONDITION status and the sense key
shall be set to COPY ABORTED (see 7.2.3.2).

  The direct-access device number of blocks field specifies the number of
blocks in the current segment to be copied.  A value of zero indicates that no
blocks shall be transferred in this segment.

  The direct-access device logical block address field specifies the starting
logical block address on the logical unit for this segment.

7.2.3.4. COPY Function Code 02hand 07h
  The format for the segment descriptors for COPY transfers among direct-
access devices is specified in Table 7-9 and Table 7-new2.  These formats are
required for COPY function code 02h and COPY function code 07h, respectively.
The segment descriptor may be repeated up to 256 times within the parameter
list length specified in the command descriptor block.

          Table 7-9: Segment Descriptor for COPY Function Code 02h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   | Source Address           |   DC   |  Cat   | Source LUN               |
-----+--------------------------+-----------------+--------------------------|
 1   | Destination Address      |   Reserved      | Destination LUN          |
-----+-----------------------------------------------------------------------|
 2   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 3   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
- - -|- -                Number of Blocks                                 - -|
 7   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -                Source Logical Block Address                     - -|
11   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
12   | (MSB)                                                                 |
- - -|- -                Destination Logical Block Address                - -|
15   |                                                                 (LSB) |
==============================================================================

          Table 7-new2: Segment Descriptor for COPY Function Code 07h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                             Source Address                            |
-----+-----------------------------------------------------------------------|
 1   |  CAT   |   Reserved                        |        Source LUN        |
-----+-----------------------------------------------------------------------|
 2   |                          Destination Address                          |
-----+-----------------------------------------------------------------------|
 3   |  DC    |   Reserved                        |     Destination LUN      |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
- - -|- -                Number of Blocks                                 - -|
 7   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -                Source Logical Block Address                     - -|
11   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
12   | (MSB)                                                                 |
- - -|- -                Destination Logical Block Address                - -|
15   |                                                                 (LSB) |
==============================================================================


  See 7.2.3.3 for definitions of the source address, the source LUN, the
destination address, the destination LUN, and CAT fields.

  A destination count (DC) bit of zero indicates that the number of blocks
field refers to the source logical unit.  A DC bit of one indicates that the
number of blocks field refers to the destination logical unit.

  The number of blocks field specifies the number of blocks to be transferred
to or from (depending on the DC bit) the device during this segment.  A value
of zero indicates that no blocks shall be transferred.

  The source logical block address field specifies the starting logical block
address on the source device.

  The destination logical block address field specifies the starting logical
block address on the destination device.

7.2.3.5. COPY Function Code 03h and 08h
  The format for the segment descriptors for COPY transfers among sequential-
access devices is specified by Table 7-10 and Table 7-new3.  These formats are
required for COPY function code 03h and COPY function code 08h, respectively.
The segment descriptor may be repeated up to 256 times within the parameter
list length specified in the command descriptor block.

          Table 7-10: Segment Descriptor for COPY Function Code 03h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   | Source Address           |   DC   |  Cat   | Source LUN               |
-----+--------------------------+-----------------+--------------------------|
 1   | Destination Address      |   Reserved      | Destination LUN          |
-----+-----------------------------------------------------------------------|
 2   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 3   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
-----+---                        Source Block Length                      ---|
 5   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 6   | (MSB)                                                                 |
-----+---                        Destination Block Length                 ---|
 7   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -                        Number of Blocks                         - -|
11   |                                                                 (LSB) |
==============================================================================


          Table 7-new3: Segment Descriptor for COPY Function Code 08h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                             Source Address                            |
-----+-----------------------------------------------------------------------|
 1   |  CAT   |   Reserved                        |        Source LUN        |
-----+-----------------------------------------------------------------------|
 2   |                          Destination Address                          |
-----+-----------------------------------------------------------------------|
 3   |  DC    |   Reserved                        |     Destination LUN      |
-----+-----------------------------------------------------------------------|
 4   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 4   |                              Reserved                                 |
-----+-----------------------------------------------------------------------|
 6   | (MSB)                                                                 |
-----+---                        Source Block Length                      ---|
 8   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 9   | (MSB)                                                                 |
-----+---                        Destination Block Length                 ---|
11   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
12   | (MSB)                                                                 |
- - -|- -                        Number of Blocks                         - -|
15   |                                                                 (LSB) |
==============================================================================


  See 7.2.3.3 for definitions of the source address, the source LUN, the
destination address, the destination LUN, and CAT fields.

  A destination count (DC) bit of zero indicates that the number of blocks
field refers to the source logical unit.  A DC bit of one indicates that the
number of blocks field refers to the destination logical unit.

  The source block length field specifies the block-length of the source
device for this segment of the COPY.  A zero in this field indicates variable
block-length.  For non-zero values, this field shall match the logical unit's
actual block-length.

  If block-length mismatches are detected prior to the beginning of the read
operation by the SCSI device managing the COPY, the command shall be
terminated with CHECK CONDITION status.  The sense key shall be set to ILLEGAL
REQUEST and the additional sense code shall be set to INVALID FIELD IN
PARAMETER LIST (see 7.2.3.1).

  If the mismatches are detected during the read operation by the COPY
manager, the command shall be terminated with CHECK CONDITION status.  The
sense key shall be set to COPY ABORTED (see 7.2.3.2).  and the additional
sense code shall be set to INVALID FIELD IN PARAMETER LIST.

  The destination block-length field specifies the block length to be used on
the destination logical unit during the COPY.  Destination block length
mismatches are handled in an analogous manner as source block length
mismatches.

  The number of blocks field specifies the number of blocks to be transferred
to or from (depending on the DC bit) the device during this segment.  A value
of zero indicates that no blocks shall be transferred.

7.2.3.6. COPY Function Code 04h and 09h
  The format for the segment descriptors for image COPY transfers between
sequential-access devices is specified in Table 7-11 and Table 7-new4.  These
formats are required for COPY function code 04h and COPY function code 09h,
respectively.  The segment descriptor may be repeated up to 256 times within
the parameter list length specified in the command descriptor block.

          Table 7-11: Segment Descriptor for COPY Function Code 04h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   | Source Address           |   Reserved      | Source LUN               |
-----+--------------------------+-----------------+--------------------------|
 1   | Destination Address      |   Reserved      | Destination LUN          |
-----+-----------------------------------------------------------------------|
 2   |                              Count                                    |
-----+-----------------------------------------------------------------------|
 3   |                                                                       |
- - -|- -                           Reserved                              - -|
 7   |                                                                       |
-----+-----------------------------------------------------------------------|
 8   |                                                                       |
- - -|- -                           Vendor Specific                       - -|
11   |                                                                       |
==============================================================================


          Table 7-new4: Segment Descriptor for COPY Function Code 09h

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                             Source Address                            |
-----+-----------------------------------------------------------------------|
 1   |            Reserved                        |        Source LUN        |
-----+-----------------------------------------------------------------------|
 2   |                          Destination Address                          |
-----+-----------------------------------------------------------------------|
 3   |            Reserved                        |     Destination LUN      |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
- - -|- -                           Count                                 - -|
 5   |                                                                (LSB)  |
-----+-----------------------------------------------------------------------|
 6   |                                                                       |
- - -|- -                           Reserved                              - -|
 7   |                                                                       |
-----+-----------------------------------------------------------------------|
 8   |                                                                       |
- - -|- -                           Vendor Specific                       - -|
11   |                                                                       |
==============================================================================


  See 7.2.3.3 for definitions of the source address, the source LUN, the
destination address, the destination LUN, and CAT fields.

  The image mode COPY command copies an exact image of the source device
medium to the destination device medium, beginning at their current positions.
The copy function terminates when the source device:
  (1) encounters an end-of-partition as defined by the source device
  (2) encounters an end-of-data as defined by the source device (i.e., BLANK
CHECK sense key)
  (3) has copied the number of consecutive filemarks specified in the count
field from the source device to the destination device
  (4) has copied the number of consecutive setmarks specified in the count
field from the source device to the destination device, if the RSmk bit in the
device configuration page (see 9.3.3.1) is one.

  A count field of zero indicates that the COPY command shall not terminate
due to any number of consecutive filemarks or setmarks.  Other error or
exception conditions (e.g., early-warning end-of-partition on the destination
device) may cause the COPY command to terminate prior to completion.  In such
cases, it is not possible to calculate a residue, so the information field in
the sense data shall be set to zero.

7.2.3.7. Copies With Unequal Block Lengths
  When copying data between two devices with unequal block lengths, it is
possible for the last source block to not completely fill the last destination
block for one or more segments in the COPY command.  Two optional bits are
defined to assist in controlling the copy manager's actions in this
circumstance.  The Pad bit (in the command descriptor block) and the Cat bit
(in each applicable segment descriptor) are defined in Table 7-12.

                    Table 7-12: Pad and Cat Bit Definition

==============================================================================
 Pad Cat   COPY Manager's Action
---- ----  -------------------------------------------------------------------
  0   0    On inexact segments, it is device specific whether the COPY manager
           rejects the COPY command with CHECK CONDITION status and ILLEGAL
           REQUEST sense key, the COPY manager writes or accepts short blocks
           (variable-block mode on sequential-access devices), or the COPY
           manager adds pad characters (00h) to the destination block or
           strips pad characters from the source block.

  1   0    On inexact segments, the COPY manager shall add pad characters
           (00h) to the destination block to completely fill the block or it
           shall strip pad characters from the source block, always stopping
           at the end of a complete block.

  X   1    The COPY manager shall always write or read complete blocks.  On
           inexact segments, the remainder of the block contains data from the
           next segment.  This code is not valid in the last segment of the
           COPY command.
==============================================================================


  IMPLEMENTORS NOTE:  Use of pad characters is intended to assist in managing
  COPY commands between devices of different block lengths where partial-block
  residues may occur.  The initiator which issued the COPY command is
  responsible for management of these pad areas (i.e., remembering where they
  are).  One possible method is to write the COPY parameter list information
  to the destination medium prior to issuing the COPY command for backup and
  to read this information prior to issuing the COPY command for restore.

7.2.5. INQUIRY Command


                         Table 7-14: INQUIRY Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (12h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      |                  Reserved         |  EVPD  |
-----+-----------------------------------------------------------------------|
 2   |                           Page Code                                   |
-----+-----------------------------------------------------------------------|
 3   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 4   |                           Allocation Length                           |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


  The INQUIRY command (Table 7-14) requests that information regarding
parameters of the target and its attached peripheral device(s) be sent to the
initiator.  An option allows the initiator to request additional information
about the target or logical unit (see 7.2.5.2).

  An enable vital product data (EVPD) bit of one specifies that the target
shall return the optional vital product data specified by the page code field.
If the target does not support vital product data and this bit is set to one,
the target shall return CHECK CONDITION status with the sense key set to
ILLEGAL REQUEST and an additional sense code of INVALID FIELD IN CDB.

  An EVPD bit of zero specifies that the target shall return the standard
INQUIRY data.  If the page code field is not zero, the target shall return
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and an
additional sense code of INVALID FIELD IN CDB.

  The page code field specifies which page of vital product data information
the target shall return (see 7.3.4).

  The INQUIRY command shall return CHECK CONDITION status only when the target
cannot return the requested INQUIRY data.

  IMPLEMENTORS NOTE:  It is recommended that the INQUIRY data be returned even
  though the peripheral device may not be ready for other commands.

  If an INQUIRY command is received from an initiator with a pending unit
attention condition (i.e., before the target reports CHECK CONDITION status),
the target shall perform the INQUIRY command and shall not clear the unit
attention condition (see 6.9).

  IMPLEMENTORS NOTES:
  (1) The INQUIRY command is typically used by the initiator after a reset or
  power-up condition to determine the device types for system configuration.
  To minimize delays after a reset or power-up condition the standard INQUIRY
  data should be available without incurring any media access delays.  If the
  target does store some of the INQUIRY data on the device it may return zeros
  or ASCII spaces (20h) in those fields until the data is available from the
  device.
  (2) The INQUIRY data may change as the target executes its initialization
  sequence or in response to a CHANGE DEFINITION command.  For example, the
  target may contain a minimum command set in its non-volatile memory and may
  load its final firmware from the device when it becomes ready.  After it has
  loaded the firmware it may support more options and therefore return
  different supported options information in the INQUIRY data.

7.2.5.1. Standard INQUIRY Data
  The standard INQUIRY data (Table 7-15) contains 36 required bytes, followed
by a variable number of vendor-specific parameters.  Bytes 56 through 95, if
returned, are reserved for future standardization.

  The standard INQUIRY data format is shown in Table 7-15.
                   Table 7-15: Standard INQUIRY Data Format

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   | Peripheral Qualifier     |           Peripheral Device Type           |
-----+-----------------------------------------------------------------------|
 1   |  RMB   |                  Device-Type Modifier                        |
-----+-----------------------------------------------------------------------|
 2   |   ISO Version   |       ECMA Version       |  ANSI-Approved Version   |
-----+-----------------+-----------------------------------------------------|
 3   |  AENC  | TrmIOP |     Reserved    |         Response Data Format      |
-----+-----------------------------------------------------------------------|
 4   |                           Additional Length (n-4)                     |
-----+-----------------------------------------------------------------------|
 5   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 6   |                           Reserved                  | Addr32 | Addr16 |
-----+-----------------------------------------------------+--------+--------|
 7   | RelAdr | WBus32 | WBus16 |  Sync  | Linked |Reserved| CmdQue | SftRe  |
-----+-----------------------------------------------------------------------|
 8   | (MSB)                                                                 |
- - -|- -                        Vendor Identification                    - -|
 15  |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 16  | (MSB)                                                                 |
- - -|- -                        Product Identification                   - -|
 31  |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 32  | (MSB)                                                                 |
- - -|- -                        Product Revision Level                   - -|
 35  |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 36  |                                                                       |
- - -|- -                        Vendor Specific                          - -|
 55  |                                                                       |
-----+-----------------------------------------------------------------------|
 56  |                                                                       |
- - -|- -                        Reserved                                 - -|
 95  |                                                                       |
==============================================================================
     |                       Vendor-Specific Parameters                      |
==============================================================================
96 to|                           Vendor-Specific                             |
 n   |                           Parameter Bytes                             |
==============================================================================


  The peripheral qualifier and peripheral device-type fields identify the
device currently connected to the logical unit.  If the target is not capable
of supporting a device on this logical unit, this field shall be set to 7Fh
(peripheral qualifier set to 011b and peripheral device type set to 1Fh).  The
peripheral qualifier is defined in Table 7-16 and the peripheral device type
is defined in Table 7-17.

                       Table 7-16: Peripheral Qualifier

==============================================================================
Qualifier     Description
---------     ----------------------------------------------------------------
  000b        The specified peripheral device type is currently connected to
              this logical unit.  If the target cannot determine whether or
              not a physical device is currently connected it shall also use
              this peripheral qualifier when returning the INQUIRY data.
              Note: This peripheral qualifier does not imply that the device
              is ready for access by the initiator.

  001b        The target is capable of supporting the specified peripheral
              device type on this logical unit, however the physical device is
              not currently connected to this logical unit.

  010b        Reserved

  011b        The target is not capable of supporting a physical device on
              this logical unit.  For this peripheral qualifier the peripheral
              device type shall be set to 1Fh to provide compatibility with
              previous versions of SCSI.  All other peripheral device type
              values are reserved for this peripheral qualifier.

  1XXb        Vendor specific
==============================================================================


                      Table 7-17: Peripheral Device Type

==============================================================================
  Code         Description
-----------    ---------------------------------------------------------------
  00h          Direct-access device (e.g., magnetic disk)
  01h          Sequential-access device (e.g., magnetic tape)
  02h          Printer device
  03h          Processor device
  04h          Write-once read-multiple device (e.g., some optical disks)
  05h          CD-ROM device
  06h          Scanner device
  07h          Optical memory device (e.g., some optical disks)
  08h          Medium Changer device (e.g., jukeboxes)
  09h          Communications device
  0Ah - 0Bh    Defined by ASC IT8 (Graphics Pre-Press Devices)
  0Ch - 1Eh    Reserved
  1Fh          Unknown or no device type
==============================================================================


  A removable medium (RMB) bit of zero indicates that the medium is not
removable.  A RMB bit of one indicates that the medium is removable.

  The device-type modifier field was defined in SCSI-1 to permit vendor-
specific qualification codes of the device type.  This field is retained for
compatibility with SCSI-1.  Targets that do not support this field should
return a value of zero.

  The usage of non-zero code values in the ISO version and ECMA version fields
are defined by the International Organization for Standardization and the
European Computer Manufacturers Association, respectively.  A zero code value
in these fields shall indicate that the target does not claim compliance to
the ISO version of SCSI (ISO IS 9316) or the ECMA version of SCSI (ECMA-111).
It is possible to claim compliance to more than one of these SCSI standards.

  The ANSI-approved version field indicates the implemented version of this
standard and is defined in Table 7-18.

                      Table 7-18: ANSI-Approved Version

==============================================================================
  Code        Description
------------------------------------------------------------------------------
   0h      The device might or might not comply to an ANSI-approved standard.
   1h      The device complies to ANSI X3.131-1986 (SCSI-1).
   2h      The device complies to this version of SCSI.  This code is reserved
           to designate this standard upon approval by ANSI.
   3h - 7h   Reserved
==============================================================================


  The asynchronous event notification capability (AENC) bit indicates that the
device supports the asynchronous event notification capability as defined in
6.5.5.
  (1) Processor device-type definition:  An AENC bit of one indicates that the
  processor device is capable of accepting asynchronous event notifications.
  An AENC bit of zero indicates that the processor device does not support
  asynchronous event notifications.
  (2) All other device-types:  This bit is reserved.

  A terminate I/O process (TrmIOP) bit of one indicates that the device
supports the TERMINATE I/O PROCESS message as defined in 5.6.22.  A value of
zero indicates that the device does not support the TERMINATE I/O PROCESS
message.

  A response data format value of zero indicates the INQUIRY data format is as
specified in SCSI-1.  A response data format value of one indicates
compatibility with some products that were designed prior to the development
of this standard (i.e., CCS).  A response data format value of two indicates
that the data shall be in the format specified in this standard.  Response
data format values greater than two are reserved.

  The additional length field shall specify the length in bytes of the
parameters.  If the allocation length of the command descriptor block is too
small to transfer all of the parameters, the additional length shall not be
adjusted to reflect the truncation.

  A wide SCSI address 32 (Addr32) bit of one indicates that the device supports
32-bit wide SCSI addresses.  A value of zero indicates that the device does not
support 32-bit wide SCSI addresses.

  A wide SCSI address 16 (Addr16) bit of one indicates that the device supports
16-bit wide SCSI addresses.  A value of zero indicates that the device does not
support 16-bit wide SCSI addresses.

        NOTE:  If the values of both the Addr16 and Addr32 bits are zero
        the device only supports 8-bit wide SCSI addresses.


  A relative addressing (RelAdr) bit of one indicates that the device supports
the relative addressing mode for this logical unit.  If this bit is set to one
the linked command (Linked) bit shall also be set to one since relative
addressing can only be used with linked commands.  A RelAdr bit of zero
indicates the device does not support relative addressing for this logical
unit.

  A wide bus 32 (WBus32) bit of one indicates that the device supports 32-bit
wide data transfers.  A value of zero indicates that the device does not
support 32-bit wide data transfers.

  A wide bus 16 (WBus16) bit of one indicates that the device supports 16-bit
wide data transfers.  A value of zero indicates that the device does not
support 16-bit wide data transfers.

  NOTE: If the values of both the WBus16 and WBus32 bits are zero the device
  only supports 8-bit wide data transfers.

  A synchronous transfer (Sync) bit of one indicates that the device supports
synchronous data transfer.  A value of zero indicates the device does not
support synchronous data transfer.

  A linked command (Linked) bit of one indicates that the device supports
linked commands for this logical unit.  A value of zero indicates the device
does not support linked commands for this logical unit.

  A command queuing (CmdQue) bit of one indicates that the device supports
tagged command queuing for this logical unit.  A value of zero indicates the
device does not support tagged command queuing for this logical unit.

  A soft reset (SftRe) bit of zero indicates that the device responds to the
RESET condition with the hard RESET alternative (see 5.2.2.1).  A SftRe bit of
one indicates that the device responds to the RESET condition with the soft
RESET alternative (see 5.2.2.2).

  ASCII data fields shall contain only graphic codes (i.e., code values 20h
through 7Eh).  Left-aligned fields shall place any unused bytes at the end of
the field (highest offset) and the unused bytes shall be filled with space
characters (20h).  Right-aligned fields shall place any unused bytes at the
start of the field (lowest offset) and the unused bytes shall be filled with
space characters (20h).

  The vendor identification field contains eight bytes of ASCII data
identifying the vendor of the product.  The data shall be left aligned within
this field.

  NOTE:  It is intended that this field provide a unique vendor identification
  of the manufacturer of the SCSI device.  In the absence of a formal
  registration procedure, X3T9.2 maintains a list of vendor identification
  codes in use.  Vendors are requested to voluntarily submit their
  identification codes to X3T9.2 to prevent duplication of codes (see Appendix
  J).

  The product identification field contains sixteen bytes of ASCII data as
defined by the vendor.  The data shall be left-aligned within this field.

  The product revision level field contains four bytes of ASCII data as
defined by the vendor.  The data shall be left-aligned within this field.

7.2.5.2. Vital Product Data
  Implementation of vital product data is optional.  The information returned
consists of configuration data (e.g., vendor identification, product
identification, model, serial number), manufacturing data (e.g., plant and
date of manufacture), field replaceable unit data and other vendor- or device-
specific data.

  The initiator requests the vital product data information by setting the
EVPD bit to one and specifying the page code of the desired vital product data
(see Table 7-72).  If the target does not implement the requested page it
shall return CHECK CONDITION status.  The a sense key shall be set to ILLEGAL
REQUEST and the additional sense code shall be set to INVALID FIELD IN CDB.

  IMPLEMENTORS NOTES:
  (1) It is recommended that the target have the ability to execute the
  INQUIRY command even when a device error occurs which prohibits normal
  command execution.  In such a case, CHECK CONDITION status would be returned
  for commands other than INQUIRY or REQUEST SENSE.  The sense data returned
  may contain the field replaceable unit code.  The vital product data would
  be obtained for the failing device using the INQUIRY command.
  (2) This standard defines a format which allows device-independent initiator
  software to display the vital product data returned by the INQUIRY command.
  For example, the initiator may display the data associated for the field
  replaceable unit returned in the sense data.  The contents of the data may
  be vendor-specific; therefore it may not be usable without detailed
  information about the device.
  (3) This standard does not define the location or method of storing the
  vital product data.  The retrieval of the data may require completion of
  initialization operations within the device which may induce delays before
  the data is available to the initiator.  Time-critical requirements are an
  implementation consideration and are not addressed in this standard.

8. Direct-Access Devices.

8.2. Commands for Direct-Access Devices.

  The commands for direct-access devices shall be as shown in Tables 8-1 and
8-2.

              Table 8-1: Commands for Direct-Access Devices(1)

==============================================================================
                                            Operation
 Command Name                                 Code      Type         Section
------------------------------------------------------------------------------
 CHANGE DEFINITION                             40h       O           7.2.1
 COMPARE                                       39h       O           7.2.2
 COPY                                          18h       O           7.2.3
 COPY AND VERIFY                               3Ah       O           7.2.4
 FORMAT UNIT                                   04h       M           8.2.1
 INQUIRY                                       12h       M           7.2.5
 LOCK/UNLOCK CACHE                             36h       O           8.2.2
 LOG SELECT                                    4Ch       O           7.2.6
 LOG SENSE                                     4Dh       O           7.2.7
 MODE SELECT(6)                                15h       O           7.2.8
 MODE SELECT(10)                               55h       O           7.2.9
 MODE SENSE(6)                                 1Ah       O           7.2.10
 MODE SENSE(10)                                5Ah       O           7.2.11
 PRE-FETCH                                     34h       O           8.2.3
 PREVENT/ALLOW MEDIUM REMOVAL                  1Eh       O           8.2.4
 READ(6)                                       08h       M           8.2.5
 READ(10)                                      28h       M           8.2.6
 READ BUFFER                                   3Ch       O           7.2.12
 READ CAPACITY                                 25h       M           8.2.7
 READ DEFECT DATA                              37h       O           8.2.8
 READ LONG                                     3Eh       O           8.2.9
 REASSIGN BLOCKS                               07h       O           8.2.10
 RECEIVE DIAGNOSTIC RESULTS                    1Ch       O           7.2.13
 RELEASE(6)                                    17h       M           8.2.11
 RELEASE(10)                                   57h       MP          8.2.11
 REQUEST SENSE                                 03h       M           7.2.14
 RESERVE(6)                                    16h       M           8.2.12
 RESERVE(10)                                   56h       MP          8.2.12
 REZERO UNIT                                   01h       O           8.2.13
==============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.

              Table 8-2: Commands for Direct-Access Devices(2)

==============================================================================
                                           Operation
Command Name                                 Code      Type         Section
------------------------------------------------------------------------------
SEARCH DATA EQUAL                             31h       O           8.2.14.1
SEARCH DATA HIGH                              30h       O           8.2.14.2
SEARCH DATA LOW                               32h       O           8.2.14.3
SEEK(6)                                       0Bh       O           8.2.15
SEEK(10)                                      2Bh       O           8.2.15
SEND DIAGNOSTIC                               1Dh       M           7.2.15
SET LIMITS                                    33h       O           8.2.16
START STOP UNIT                               1Bh       O           8.2.17
SYNCHRONIZE CACHE                             35h       O           8.2.18
TEST UNIT READY                               00h       M           7.2.16
VERIFY                                        2Fh       O           8.2.19
WRITE(6)                                      0Ah       M           8.2.20
WRITE(10)                                     2Ah       M           8.2.21
WRITE AND VERIFY                              2Eh       O           8.2.22
WRITE BUFFER                                  3Bh       O           7.2.17
WRITE LONG                                    3Fh       O           8.2.23
WRITE SAME                                    41h       O           8.2.24
==============================================================================

   Key: M  =  Command implementation is mandatory.
        MP =  Command implementation is mandatory on any device that addresses
              more than 8 devices.
        O  =  Command implementation is optional.

             The following operation codes are vendor-specific:  02h, 05h,
         06h, 09h, 0Ch, 0Dh, 0Eh, 0Fh, 10h, 11h, 13h, 14h, 19h, 20h, 21h,
         22h, 23h, 24h, 26h, 27h, 29h, 2Ch, 2Dh and C0h through FFh.  All
         remaining operation codes are reserved for future standardization.

8.2.11. RELEASE(6) and RELEASE(10) Commands


                         Table 8-23: RELEASE(6) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (17h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty | Third Party Device ID    | Extent |
-----+-----------------------------------------------------------------------|
 2   |                           Reservation Identification                  |
-----+-----------------------------------------------------------------------|
 3   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


                         Table 8-new1: RELEASE(10) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (57h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty |        Reserved          | Extent |
-----+-----------------------------------------------------------------------|
 2   |                           Reservation Identification                  |
-----+-----------------------------------------------------------------------|
 3   |                           Third Party Device ID                       |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 6   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 7   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 8   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 9   |                           Control Byte                                |
==============================================================================


  The RESERVE and RELEASE commands provide the basic mechanism for contention
resolution in multiple-initiator systems.  The RELEASE command (Table 8-23) is
used to release a previously reserved logical unit, or, if the extent release
option is implemented, to release previously reserved extents within a logical
unit.  It is not an error for an initiator to attempt to release a reservation
that is not currently valid.  In this case, the target returns GOOD status
without altering any other reservation.

8.2.11.1. Logical Unit Release (Mandatory)
  If the extent bit is zero, this command shall cause the target to terminate
all logical unit and extent reservations that are active from the initiator to
the specified logical unit.  The reservation ID field in the command
descriptor block is ignored by the target.

8.2.11.2. Extent Release (Optional)
  If the extent bit is one and the extent release option is not implemented,
then the RELEASE command shall be terminated with CHECK CONDITION status and
the sense key shall be set to ILLEGAL REQUEST.  This option shall be
implemented if the extent reservation option (see 8.2.12.2) is implemented.

  If the extent bit is one and the extent release option is implemented, this
command shall cause any reservation from the requesting initiator with a
matching reservation identification to be terminated.  Other reservations from
the requesting initiator shall remain in effect.

8.2.11.3. Third-Party Release (Mandatory)
  Third-party release allows an initiator to release a logical unit or extents
within a logical unit that were previously reserved using third-party
reservation (see 8.2.12.3).  Third-party release shall be implemented and is
intended for use in multiple-initiator systems that use the COPY command.

  If the third-party (3rdPty) bit is zero, then a third-party release is not
requested.  If the 3rdPty bit is one then the target shall release the
specified logical unit or extents, but only if the reservation was made using
a third-party reservation by the initiator that is requesting the release for
the same SCSI device as specified in the third-party device ID field.

  If the 3rdPty bit is one the target shall not modify the mode parameters for
commands received from the third-party device even if the target implements
the transfer of mode parameters with a third-party RESERVE command.

  IMPLEMENTORS NOTE:  If a target implements independent storage of mode
  parameters for each initiator, a third-party RESERVE command copies the
  current mode parameters for the initiator that sent the RESERVE command to
  the current mode parameters for the initiator specified as the third-party
  device (usually a copy master device).  A unit attention condition notifies
  the third-party of the changed mode parameters due to the the reservation.
  A successful third-party RELEASE command  does not return the third-party
  devices' current mode parameters back to their previous values.  The third-
  party device can issue MODE SENSE and MODE SELECT commands to query and
  modify the mode parameters.

8.2.12. RESERVE(6) and RESERVE(10) Commands


                         Table 8-24: RESERVE Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (16h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty | Third Party Device ID    | Extent |
-----+-----------------------------------------------------------------------|
 2   |                           Reservation Identification                  |
-----+-----------------------------------------------------------------------|
 3   | (MSB)                                                                 |
-----+---                        Extent List Length                       ---|
 4   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


                         Table 8-new2: RESERVE(10) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (16h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty |        Reserved          | Extent |
-----+-----------------------------------------------------------------------|
 2   |                           Reservation Identification                  |
-----+-----------------------------------------------------------------------|
 3   |                           Third Party Device ID                       |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 6   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 7   | (MSB)                                                                 |
-----+---                        Extent List Length                       ---|
 8   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 9   |                           Control Byte                                |
==============================================================================


  The RESERVE and RELEASE commands provide the basic mechanism for contention
resolution in multiple-initiator systems.  The RESERVE command (Table 8-24) is
used to reserve a logical unit or, if the extent reservation option is
implemented, extents within a logical unit.  The third-party reservation
allows logical units or extents to be reserved for another specified SCSI
device.

8.2.12.1. Logical Unit Reservation (Mandatory).

  If the extent bit is zero, this command shall request that the entire
logical unit be reserved for the exclusive use of the initiator until the
reservation is superseded by another valid RESERVE command from the initiator
that made the reservation or until released by a RELEASE command from the same
initiator that made the reservation, by a BUS DEVICE RESET message from any
initiator, by a hard RESET condition, or by a power on cycle.  A logical unit
reservation shall not be granted if the logical unit or any extent is reserved
by another initiator.  It shall be permissible for an initiator to reserve a
logical unit that is currently reserved by that initiator.  If the extent bit
is zero, the reservation identification and the extent list length shall be
ignored.

  If the logical unit, or any extent within the logical unit is reserved for
another initiator, the target shall return RESERVATION CONFLICT status.

  If, after honoring the reservation, any other initiator attempts to perform
any command on the reserved logical unit other than an INQUIRY command, a
REQUEST SENSE command, an ALLOW MEDIUM REMOVAL, or a RELEASE command, which
shall be ignored, then the command shall be rejected with RESERVATION CONFLICT
status.

8.2.12.2. Extent Reservation (Optional)
  The reservation identification field provides a means for an initiator to
identify each extent reservation.  This allows an initiator in a multiple
tasking environment, to have multiple reservations outstanding.  The
reservation identification is used in the RELEASE command to specify which
reservation is to be released.  It is also used in superseding RESERVE
commands to specify which reservation is to be superseded.

  If the extent reservation option is implemented, then the extent release
option (see 8.2.11.2) shall also be implemented.  These options permit
multiple extents within the logical unit to be reserved, each with a separate
reservation type.

  If the extent bit is one, and the extent reservation option is implemented,
then the target shall process the reservation request as follows:
  (1) The extent list shall be checked for the number of extents in the
reservation request.  If the extent list length is zero, no current
reservations shall be changed, no new reservations shall be created, and this
condition shall not be treated as an error.  If the extent list contains more
extents than are supported on the logical unit, the command shall be
terminated with CHECK CONDITION status and the sense key shall be set to
ILLEGAL REQUEST.  If the extent list contains more extents than are currently
available on the logical unit, then the target shall return a RESERVATION
CONFLICT status.
  (2) The extent list shall be checked for valid extent logical block
addresses.  If any logical block address is invalid for this logical unit, the
command shall be terminated with CHECK CONDITION status and the sense key
shall be set to ILLEGAL REQUEST.  The extent list shall be checked for invalid
extent overlaps (as defined by reservation type) with other extent descriptors
in the extent list and if invalid overlaps are found, the command shall be
terminated with CHECK CONDITION status and the sense key shall be set to
ILLEGAL REQUEST.
  (3) If the requested reservation does not conflict with an existing
reservation, the extents specified shall be reserved until superseded by
another valid RESERVE command from the initiator that made the reservation or
until released by a RELEASE command from the same initiator, by a BUS DEVICE
RESET message from any initiator, or by a hard RESET condition.  If either of
the last two conditions occur, the next command from each initiator shall be
terminated with CHECK CONDITION status and the sense key shall be set to UNIT
ATTENTION.
  (4) If the reservation request conflicts with an existing reservation, then
the target shall return a RESERVATION CONFLICT status.

  If the extent bit is one, and the extent reservation option is not
implemented, then the RESERVE command shall be rejected with CHECK CONDITION
status and the sense key shall be set to ILLEGAL REQUEST.

                Table 8-25: Data Format of Extent Descriptors

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |               Reserved                     | RelAdr | Reservation Type|
-----+-----------------------------------------------------------------------|
 1   | (MSB)                                                                 |
- - -|- -                        Number of Blocks                         - -|
 3   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 4   | (MSB)                                                                 |
- - -|- -                        Logical Block Address                    - -|
 7   |                                                                 (LSB) |
==============================================================================

  The size of the extent list shall be defined by the extent list length
field.  The extent list shall consist of zero or more descriptors as shown in
Table 8-25.  Each extent descriptor defines an extent beginning at the
specified logical block address for the specified number of blocks.  If the
number of blocks is zero, the extent shall begin at the specified logical
block address and continue through the last logical block address on the
logical unit.

  The reservation type field shall determine the type of reservation to be
effected for each extent.  Four types of reservations are possible as follows:

                        DB(1) DB(0)  Reservation Type
                        ----- -----  ----------------
                          1     0    Read Exclusive
                          0     1    Write Exclusive
                          1     1    Exclusive Access
                          0     0    Read Shared

  Read Exclusive.  While this reservation is active, no other initiator shall
be permitted read operations to the indicated extent.  This reservation shall
not inhibit write operations from any initiator or conflict with a write
exclusive reservation; however, read exclusive, exclusive access, and read
shared reservations that overlap this extent shall conflict with this
reservation.

  Write Exclusive.  While this reservation is active, no other initiator shall
be permitted write operations to the indicated extent.  This reservation shall
not inhibit read operations from any initiator or conflict with a read
exclusive reservation from any initiator.  This reservation shall conflict
with write exclusive, exclusive access, and read shared reservations that
overlap this extent.

  Exclusive Access.  While this reservation is active, no other initiator
shall be permitted any access to the indicated extent.  All reservation types
that overlap this extent shall conflict with this reservation.

  Read Shared.  While this reservation is active, no write operations shall be
permitted by any initiator to the indicated extent.  This reservation shall
not inhibit read operations from any initiator or conflict with a read shared
reservation.  Read exclusive, write exclusive, and exclusive access
reservations that overlap with this extent shall conflict with this
reservation.

  If the relative address bit is one, the logical block address in the extent
descriptor shall be treated as a two's complement displacement.  This
displacement shall be added to the logical block address last accessed on the
logical unit to form the logical block address for this extent.  This feature
is only available when linking commands and requires that a previous command
in the linked group has accessed a logical block on the logical unit; if not,
the RESERVE command shall be terminated with CHECK CONDITION status and the
sense key shall be set to ILLEGAL REQUEST.

  If an initiator attempts a command to a logical block that has been reserved
and that access is prohibited by the reservation, the command shall not be
performed and the command shall be terminated with a RESERVATION CONFLICT
status.  If a reservation conflict precludes any part of the command, none of
the command shall be performed.  COPY commands shall be terminated with CHECK
CONDITION status and the sense key shall be set to DATA PROTECT if any part of
the copy operation is prohibited by an active reservation.  If any extent in a
logical unit is reserved in any way, by any initiator, a FORMAT UNIT command
shall be rejected with a RESERVATION CONFLICT status.

8.2.12.3. Third Party Reservation (Mandatory).
  The third-party reservation for the RESERVE command allows an initiator to
reserve a logical unit or extents within a logical unit for another SCSI
device.  This is intended for use in multiple-initiator systems that use the
COPY command.  Third-party reservation is required.

  If the third-party (3rdPty) bit is zero, then a third-party reservation is
not requested.  If the 3rdPty bit is one then the target shall reserve the
specified logical unit or extents for the SCSI device specified in the third-
party device ID field.  The target shall preserve the reservation until it is
superseded by another valid RESERVE command from the initiator that made the
reservation or until it is released by the same initiator, by a BUS DEVICE
reset message from any initiator, or a hard reset condition.  The target shall
ignore any attempt to release the reservation made by any other initiator.

  If independent sets of parameters are implemented, a third party reservation
shall cause the target to transfer the set of parameters in effect for the
initiator of the RESERVE command to the parameters used for commands from the
third party device.  Any subsequent command issued by the third-party device
is executed according to the mode parameters in effect for the initiator that
sent the RESERVE command.

  IMPLEMENTORS NOTE:  This transfer of the mode parameters is applicable to
  target devices which store mode information independently for different
  initiators.  This mechanism allows an initiator to set the mode parameters
  of a target for the use of a copy master (i.e., the third-party device).
  The third-party copy master may subsequently issue a MODE SELECT command to
  modify the mode parameters.

8.2.12.4. Superseding Reservations (Mandatory)
  An initiator that holds a current reservation (unit or extent) may modify
that reservation by issuing another RESERVE command (unit or extent) to the
same logical unit.  The superseding RESERVE command shall release the previous
reservation state (unit or extent) when the new reservation request is
granted.  If the superseding reservation is for an extent reservation and the
current reservation is also an extent reservation, the current extent
reservation identification value is used for the superseding reservation.  The
current reservation shall not be modified if the superseding reservation
request cannot be granted.  If the superseding reservation cannot be granted
because of conflicts with a previous reservation (other than the reservation
being superseded), then the target shall return RESERVATION CONFLICT status.

  IMPLEMENTORS NOTE:  Superseding reservations allow the SCSI device ID to be
  changed on a reservation using the third-party reservation option.  This
  capability is necessary for certain situations when using COMPARE, COPY, and
  COPY AND VERIFY commands.

9. Sequential-Access Devices.

9.2. Commands for Sequential-Access Devices.

  The commands for Sequential-access devices shall be as shown in Table 9-1.

              Table 9-1: Commands for Sequential-Access Devices
==============================================================================
                                            Operation
 Command Name                                 Code      Type         Section
------------------------------------------------------------------------------
 CHANGE DEFINITION                             40h       O           7.2.1
 COMPARE                                       39h       O           7.2.2
 COPY                                          18h       O           7.2.3
 COPY AND VERIFY                               3Ah       O           7.2.4
 ERASE                                         19h       M           9.2.1
 INQUIRY                                       12h       M           7.2.5
 LOAD UNLOAD                                   1Bh       O           9.2.2
 LOCATE                                        2Bh       O           9.2.3
 LOG SELECT                                    4Ch       O           7.2.6
 LOG SENSE                                     4Dh       O           7.2.7
 MODE SELECT(6)                                15h       M           7.2.8
 MODE SELECT(10)                               55h       O           7.2.9
 MODE SENSE(6)                                 1Ah       M           7.2.10
 MODE SENSE(10)                                5Ah       O           7.2.11
 PREVENT/ALLOW MEDIUM REMOVAL                  1Eh       O           8.2.4
 READ                                          08h       M           9.2.4
 READ BLOCK LIMITS                             05h       M           9.2.5
 READ BUFFER                                   3Ch       O           7.2.12
 READ POSITION                                 34h       O           9.2.6
 READ REVERSE                                  0Fh       O           9.2.7
 RECEIVE DIAGNOSTIC RESULTS                    1Ch       O           7.2.13
 RECOVER BUFFERED DATA                         14h       O           9.2.8
 RELEASE UNIT (6)                              17h       M           9.2.9
 RELEASE UNIT (10)                             57h       MP          9.2.9
 REQUEST SENSE                                 03h       M           7.2.14
 RESERVE UNIT (6)                              16h       M           9.2.10
 RESERVE UNIT (10)                             56h       MP          9.2.10
 REWIND                                        01h       M           9.2.11
 SEND DIAGNOSTIC                               1Dh       M           7.2.15
 SPACE                                         11h       M           9.2.12
 TEST UNIT READY                               00h       M           7.2.16
 VERIFY                                        13h       O           9.2.13
 WRITE                                         0Ah       M           9.2.14
 WRITE BUFFER                                  3Bh       O           7.2.17
 WRITE FILEMARKS                               10H       M           9.2.15
==============================================================================

   Key: M  =  Command implementation is mandatory.
        MP =  Command implementation is mandatory on any device that addresses
              more than 8 devices.
        O  =  Command implementation is optional.

             The following operation codes are vendor-specific:  02h,
         06h, 07h, 09h, 0Ch, 0Dh, 0Eh.  All other command codes for
         sequential-access devices are reserved for future standardization.

9.2.9. RELEASE UNIT(6) and RELEASE UNIT(10) Commands


                       Table 9-12: RELEASE UNIT(6) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (17h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty | Third Party Device ID    |Reserved|
-----+-----------------------------------------------------------------------|
 2   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 3   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


                         Table 9-new1: RELEASE(10) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (57h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty |              Reserved             |
-----+-----------------------------------------------------------------------|
 2   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 3   |                           Third Party Device ID                       |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 6   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 7   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 8   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 9   |                           Control Byte                                |
==============================================================================


  The RESERVE UNIT and RELEASE UNIT commands provide the basic mechanism for
contention resolution in multiple-initiator systems.  The RELEASE UNIT command
(Table 9-12) is used to release previously reserved logical units for the
requesting initiator, or if it is a third-party release, to another specified
SCSI device.

  If a valid reservation exists for the I_T_L nexus, the target shall release
the reservation and return GOOD status.

  It is not an error to attempt to release a reservation that is not currently
valid.  In this case, the target shall return GOOD status without altering any
other reservation.

9.2.9.1. Third-Party Release 
  Third-party release allows an initiator to release a logical unit that was
previously reserved using a third-party reservation (see 9.2.10.1).

  If the third party (3rdPty) bit is zero, then a third-party release is not
requested.  If the 3rdPty bit is one, and if the reservation was made using a
third-party reservation by the initiator that is requesting the release for
the same SCSI device as specified in the third-party device ID, then the
target shall release the reservation.

  If the 3rdPty bit is one, the target shall not modify the mode parameters
for commands received from the third-party device even if the target
implements the transfer of mode parameters with a third-party RESERVE UNIT
command.

  IMPLEMENTORS NOTE:  When a target implements independent storage of mode
  parameters for each initiator, a third-party RESERVE UNIT command effects a
  transfer of the current mode parameters.  Those set up by the initiator of
  the RESERVE UNIT are to be set as the mode parameters used for commands from
  the third-party device (usually a copy master device).  A unit attention
  condition notifies the third-party device of the changed mode parameters.  A
  successful third-party RELEASE UNIT command leaves the transferred
  parameters intact.  The third-party device can issue MODE SENSE and MODE
  SELECT commands to query and modify the mode parameters.


9.2.10. RESERVE UNIT(6) and RESERVE UNIT(10) Commands


                       Table 9-13: RESERVE UNIT(6) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (16h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty | Third Party Device ID    |Reserved|
-----+-----------------------------------------------------------------------|
 2   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 3   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Control                                     |
==============================================================================


                         Table 9-new2: RESERVE(10) Command

==============================================================================
  Bit|   7    |   6    |   5    |   4    |   3    |   2    |   1    |   0    |
Byte |        |        |        |        |        |        |        |        |
==============================================================================
 0   |                           Operation Code (16h)                        |
-----+-----------------------------------------------------------------------|
 1   | Logical Unit Number      | 3rdPty |              Reserved             |
-----+-----------------------------------------------------------------------|
 2   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 3   |                           Third Party Device ID                       |
-----+-----------------------------------------------------------------------|
 4   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 5   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 6   |                           Reserved                                    |
-----+-----------------------------------------------------------------------|
 7   | (MSB)                                                                 |
-----+---                        Extent List Length                       ---|
 8   |                                                                 (LSB) |
-----+-----------------------------------------------------------------------|
 9   |                           Control Byte                                |
==============================================================================


  The RESERVE UNIT and RELEASE UNIT commands provide the basic mechanism for
contention resolution in multiple-initiator systems.  The RESERVE UNIT command
(Table 9-13) is used to reserve logical units for the exclusive use of the
requesting initiator, or if it is a third-party reservation, to another
specified SCSI device.

  This command requests that the entire logical unit be reserved for the
exclusive use of the initiator until the reservation is superseded by another
valid RESERVE UNIT command from the initiator that made the reservation or
until released by a RELEASE UNIT command from the same initiator that made the
reservation, by a BUS DEVICE RESET message from any initiator, by a hard reset
condition, or by a power on cycle.  The reservation shall not be granted if
the logical unit is reserved by another initiator.  It shall be permissible
for an initiator to reserve a logical unit that is currently reserved by that
initiator.

  If the logical unit is reserved for another initiator, the target shall
return RESERVATION CONFLICT status.

  If, after honoring the reservation, any other initiator attempts to perform
any command on the reserved logical unit other than an INQUIRY command, a
REQUEST SENSE command, or a RELEASE UNIT command, which shall be ignored, then
the command shall be rejected with RESERVATION CONFLICT status.


9.2.10.1. Third-Party Reservation
  Third-party reservation allows an initiator to reserve a logical unit for
another SCSI device.  This is intended for use in multiple-initiator systems
that use the COPY command.

  If the third-party (3rdPty) bit is zero, a third-party reservation is not
requested.  If the 3rdPty bit is one the target shall reserve the logical unit
for the SCSI device specified in the third-party device ID field. The target
shall preserve the reservation until it is superseded by another valid RESERVE
UNIT command from the initiator that made the reservation or until it is
released by the same initiator, by a BUS DEVICE RESET message from any
initiator, or a hard reset condition.  The target shall ignore any attempt to
release the reservation made by any other initiator.

  If independent sets of parameters are implemented, a third party reservation
shall cause the target to transfer the set of parameters in effect for the
initiator of the RESERVE command to the parameters used for commands from the
third party device.  Any subsequent command issued by the third-party device
is executed according to the mode parameters in effect for the initiator
that sent the RESERVE command.

  If independent sets of parameters are implemented, a third party reservation
shall cause the target to transfer the set of parameters in effect for the
initiator of the RESERVE command to the parameters used for commands from the
third party device.  Any subsequent command issued by the third-party device
is executed according to the mode parameters in effect for the initiator
that sent the RESERVE command.

  IMPLEMENTORS NOTE:  This transfer of the mode parameters is applicable to
  target devices which store mode information independently for different
  initiators.  This mechanism allows an initiator to set the mode parameters
  of a target for the use of a copy master (i.e., the third-party device).
  The third-party copy master may subsequently issue a MODE SELECT command to
  modify the mode parameters.

9.2.10.2. Superseding Reservations
  An initiator that currently has a logical unit reserved may modify the
current reservation by issuing another RESERVE UNIT command to the same
logical unit.  The superseding reservation shall release the current
reservation if the superseding reservation request is granted.  The current
reservation shall not be modified if the superseding reservation request
cannot be granted.  If the superseding reservation cannot be granted because
of conflicts with a previous reservation (other than the current reservation),
then the target shall return RESERVATION CONFLICT status.

  IMPLEMENTORS NOTE:  Superseding reservations allow the SCSI device ID to be
  changed on a reservation using the third-party reservation option.  This
  capability is necessary for certain situations when using COMPARE, COPY, and
  COPY AND VERIFY commands.

10. Commands for Printer Devices

10.2. Commands for Printer Devices


  The commands for printer devices shall be as shown in Table 10-1.

                   Table 10-1: Commands for Printer Devices

==============================================================================
                                Operation
Command Name                       Code   Type    Section  Page
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h      O      7.2.1
COMPARE                            39h      O      7.2.2
COPY                               18h      O      7.2.3
COPY AND VERIFY                    3Ah      O      7.2.4
FORMAT                             04h      O     10.2.1
INQUIRY                            12h      M      7.2.5
LOG SELECT                         4Ch      O      7.2.6
LOG SENSE                          4Dh      O      7.2.7
MODE SELECT(6)                     15h      O      7.2.8
MODE SELECT(10)                    55h      O      7.2.9
MODE SENSE(6)                      1Ah      O      7.2.10
MODE SENSE(10)                     5Ah      O      7.2.11
PRINT                              0Ah      M     10.2.2
READ BUFFER                        3Ch      O      7.2.12
RECEIVE DIAGNOSTIC RESULTS         1Ch      O      7.2.13
RECOVER BUFFERED DATA              14h      O     10.2.3
RELEASE UNIT (6)                   17h      M      9.2.9
RELEASE UNIT (10)                  57h      MP     9.2.9
REQUEST SENSE                      03h      M      7.2.14
RESERVE UNIT (6)                   16h      M      9.2.10
RESERVE UNIT (10)                  56h      MP     9.2.10
SEND DIAGNOSTIC                    1Dh      M      7.2.15
SLEW AND PRINT                     0Bh      O     10.2.4
STOP PRINT                         1Bh      O     10.2.5
SYNCHRONIZE BUFFER                 10h      O     10.2.6
TEST UNIT READY                    00h      M      7.2.16
WRITE BUFFER                       3Bh      O      7.2.17
==============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.

  The following operation codes are vendor specific: 01h, 02h, 05h, 06h, 07h,
08h, 09h, 0Ch, 0Dh, 0Eh, 0Fh, 11h, 13h, 19h, and C0h through FFh.  All
remaining operation codes for printer devices are reserved for future
standardization.

12. Write-Once Devices

12.2. Commands for Write-Once Devices

  The commands for write-once devices shall be as shown in Table 12-1 and
Table 12-2.

                Table 12-1: Commands for Write-Once Devices(1)

==============================================================================
Command Name                       Code    Type    Section
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h       O     7.2.1
COMPARE                            39h       O     7.2.2
COPY                               18h       O     7.2.3
COPY AND VERIFY                    3Ah       O     7.2.4
INQUIRY                            12h       M     7.2.5
LOCK UNLOCK CACHE                  36h       O     8.2.2
LOG SELECT                         4Ch       O     7.2.6
LOG SENSE                          4Dh       O     7.2.7
MEDIUM SCAN                        38h       O    15.2.3
MODE SELECT(6)                     15h       O     7.2.8
MODE SELECT(10)                    55h       O     7.2.9
MODE SENSE(6)                      1Ah       O     7.2.10
MODE SENSE(10)                     5Ah       O     7.2.11
PRE-FETCH                          34h       O     8.2.3
PREVENT ALLOW MEDIUM REMOVAL       1Eh       O     8.2.4
READ(6)                            08h       O     8.2.5
READ(10)                           28h       M     8.2.6
READ(12)                           A8h       O    15.2.4
READ BUFFER                        3Ch       O     7.2.12
READ CAPACITY                      25h       M     8.2.7
READ LONG                          3Eh       O     8.2.9
REASSIGN BLOCKS                    07h       O     8.2.10
RECEIVE DIAGNOSTIC RESULTS         1Ch       O     7.2.13
RELEASE (6)                        17h       M     8.2.11
RELEASE (10)                       57h       MP    8.2.11
REQUEST SENSE                      03h       M     7.2.14
RESERVE (6)                        16h       M     8.2.12
RESERVE (10)                       56h       MP    8.2.12
REZERO UNIT                        01h       O     8.2.13
==============================================================================

                Table 12-2: Commands for Write-Once Devices(2)

==============================================================================
Command Name                       Code    Type    Section
------------------------------------------------------------------------------
SEARCH DATA EQUAL(10)              31h       O     8.2.14.1
SEARCH DATA EQUAL(12)              B1h       O    15.2.8
SEARCH DATA HIGH(10)               30h       O     8.2.14.2
SEARCH DATA HIGH(12)               B0h       O    15.2.8
SEARCH DATA LOW(10)                32h       O     8.2.14.3
SEARCH DATA LOW(12)                B2h       O    15.2.8
SEEK(6)                            0Bh       O     8.2.15
SEEK(10)                           2Bh       O     8.2.15
SEND DIAGNOSTIC                    1Dh       M     7.2.15
SET LIMITS(10)                     33h       O     8.2.16
SET LIMITS(12)                     B3h       O    15.2.9
START STOP UNIT                    1Bh       O     8.2.17
SYNCHRONIZE CACHE                  35h       O     8.2.18
TEST UNIT READY                    00h       M     7.2.16
VERIFY(10)                         2Fh       O    15.2.11
VERIFY(12)                         AFh       O    15.2.12
WRITE(6)                           0Ah       O     8.2.20
WRITE(10)                          2Ah       M     8.2.21
WRITE(12)                          AAh       O    15.2.14
WRITE AND VERIFY(10)               2Eh       O     8.2.22
WRITE AND VERIFY(12)               AEh       O    15.2.16
WRITE BUFFER                       3Bh       O     7.2.17
WRITE LONG                         3Fh       O     8.2.23
==============================================================================

    Key: M  =  Command implementation is mandatory.
         MP =  Command implementation is mandatory on any device that addresses
               more than 8 devices.
         O  =  Command implementation is optional.

  The following command codes are vendor specific:  02h, 05h, 06h, 09h, 0Ch,
0Dh, 0Eh, 0Fh, 10h, 11h, 13h, 14h, 19h, 20h, 21h, 22h, 23h, 24h, 26h, 27h,
29h, and C0h through FFh.  All remaining command codes for write-once devices
are reserved for future standardization.


13. CD-ROM Devices

13.2. Commands for CD-ROM Devices

  The commands for CD-ROM devices shall be as shown in Table 13-3, and 13-4.

                  Table 13-3: Commands for CD-ROM Devices(1)

==============================================================================
                                Operation
Command Name                       Code   Type    Section
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h      O      7.2.1
COMPARE                            39h      O      7.2.2
COPY                               18h      O      7.2.3
COPY AND VERIFY                    3Ah      O      7.2.4
INQUIRY                            12h      M      7.2.5
LOCK/UNLOCK CACHE                  36h      O      8.2.2
LOG SELECT                         4Ch      O      7.2.6
LOG SENSE                          4Dh      O      7.2.7
MODE SELECT(6)                     15h      O      7.2.8
MODE SELECT(10)                    55h      O      7.2.9
MODE SENSE(6)                      1Ah      O      7.2.10
MODE SENSE(10)                     5Ah      O      7.2.11
PAUSE/RESUME                       4Bh      O     13.2.1
PLAY AUDIO(10)                     45h      O*    13.2.2
PLAY AUDIO(12)                     A5h      O*    13.2.3
PLAY AUDIO MSF                     47h      O*    13.2.4
PLAY AUDIO TRACK/INDEX             48h      O*    13.2.5
PLAY TRACK RELATIVE(10)            49h      O*    13.2.6
PLAY TRACK RELATIVE(12)            A9h      O*    13.2.7
PRE-FETCH                          34h      O      8.2.3
PREVENT/ALLOW MEDIUM REMOVAL       1Eh      O      8.2.4
READ(6)                            08h      O      8.2.5
READ(10)                           28h      M      8.2.6
READ(12)                           A8h      O     15.2.4
READ BUFFER                        3Ch      O      7.2.12
READ CD-ROM CAPACITY               25h      M     13.2.8
READ HEADER                        44h      O     13.2.9
READ LONG                          3Eh      O      8.2.9
READ SUB-CHANNEL                   42h      O     13.2.10
READ TOC                           43h      O     13.2.11
RECEIVE DIAGNOSTIC RESULTS         1Ch      O      7.2.13
RELEASE (6)                        17h      M      8.2.11
RELEASE (10)                       57h      MP     8.2.11
REQUEST SENSE                      03h      M      7.2.14
RESERVE (6)                        16h      M      8.2.12
RESERVE (10)                       56h      MP     8.2.12
REZERO UNIT                        01h      O      8.2.13
==============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.
       *  =  If any of the PLAY AUDIO commands (as indicated by an * in the
           'Type' column in Table 13-3) are implemented, the PLAY AUDIO
           command shall be implemented by the target.

                  Table 13-4: Commands for CD-ROM Devices(2)

==============================================================================
                                Operation
Command Name                       Code   Type    Section
------------------------------------------------------------------------------
SEARCH DATA EQUAL(10)              31h      O      8.2.14.1
SEARCH DATA EQUAL(12)              B1h      O     15.2.8
SEARCH DATA HIGH(10)               30h      O      8.2.14.2
SEARCH DATA HIGH(12)               B0h      O     15.2.8
SEARCH DATA LOW(10)                32h      O      8.2.14.3
SEARCH DATA LOW(12)                B2h      O     15.2.8
SEEK(6)                            0Bh      O      8.2.15
SEEK(10)                           2Bh      O      8.2.15
SEND DIAGNOSTIC                    1Dh      M      7.2.15
SET LIMITS(10)                     33h      O      8.2.16
SET LIMITS(12)                     B3h      O     15.2.9
START STOP UNIT                    1Bh      O      8.2.17
SYNCHRONIZE CACHE                  35h      O      8.2.18
TEST UNIT READY                    00h      M      7.2.16
VERIFY(10)                         2Fh      O     15.2.11
VERIFY(12)                         AFh      O     15.2.12
WRITE BUFFER                       3Bh      O      7.2.17
==============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.


  The following command codes are vendor specific:  02h, 05h, 06h, 09h, 0Ch,
0Dh, 0Eh, 0Fh, 10h, 11h, 13h, 14h, 19h, 20h, 21h, 22h, 23h, 24h, 26h, 27h,
29h, and C0h through FFh.  All remaining command codes for CD-ROM devices are
reserved for future standardization.

14. Scanner Devices

14.2. Commands for Scanner Devices

  The commands for scanner devices shall be as shown in Table 14-1.

                   Table 14-1: Commands for Scanner Devices

==============================================================================
                                Operation
Command Name                       Code   Type    Section     Page
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h      O      7.2.1
COMPARE                            39h      O      7.2.2
COPY                               18h      O      7.2.3
COPY AND VERIFY                    3Ah      O      7.2.4
GET DATA BUFFER STATUS             34h      O     14.2.1
GET WINDOW                         25h      O     14.2.2
INQUIRY                            12h      M      7.2.5
LOG SELECT                         4Ch      O      7.2.6
LOG SENSE                          4Dh      O      7.2.7
MODE SELECT(6)                     15h      O      7.2.8
MODE SELECT(10)                    55h      O      7.2.9
MODE SENSE(6)                      1Ah      O      7.2.10
MODE SENSE(10)                     5Ah      O      7.2.11
OBJECT POSITION                    31h      O     14.2.3
READ                               28h      M     14.2.4
READ BUFFER                        3Ch      O      7.2.12
RECEIVE DIAGNOSTIC RESULTS         1Ch      O      7.2.13
RELEASE UNIT (6)                   17h      M      9.2.9
RELEASE UNIT (10)                  57h      MP     9.2.9
REQUEST SENSE                      03h      M      7.2.14
RESERVE UNIT (6)                   16h      M      9.2.10
RESERVE UNIT (10)                  56h      MP     9.2.10
SCAN                               1Bh      O     14.2.5
SET WINDOW                         24h      M     14.2.6
SEND                               2Ah      O     14.2.7
SEND DIAGNOSTIC                    1Dh      M      7.2.15
TEST UNIT READY                    00h      M      7.2.16
WRITE BUFFER                       3Bh      O      7.2.17
==============================================================================


  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.

  All other operation codes for scanner devices are  reserved for future
standardization.

15. Optical Memory Devices

15.2. Commands for Optical Memory Devices

  The commands for optical memory devices shall be as shown in Table 15-1 and
15-2.

              Table 15-1: Commands for Optical Memory Devices(1)

==============================================================================
                                Operation
Command Name                       Code   Type    Section     Page
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h      O      7.2.1
COMPARE                            39h      O      7.2.2
COPY                               18h      O      7.2.3
COPY AND VERIFY                    3Ah      O      7.2.4
ERASE(10)                          2Ch      O     15.2.1
ERASE(12)                          ACh      O     15.2.2
FORMAT UNIT                        04h      O      8.2.1
INQUIRY                            12h      M      7.2.5
LOCK UNLOCK CACHE                  36h      O      8.2.2
LOG SELECT                         4Ch      O      7.2.6
LOG SENSE                          4Dh      O      7.2.7
MEDIUM SCAN                        38h      O     15.2.3
MODE SELECT(6)                     15h      O      7.2.8
MODE SELECT(10)                    55h      O      7.2.9
MODE SENSE(6)                      1Ah      O      7.2.10
MODE SENSE(10)                     5Ah      O      7.2.11
PRE-FETCH                          34h      O      8.2.3
PREVENT ALLOW MEDIUM REMOVAL       1Eh      O      8.2.4
READ(6)                            08h      O      8.2.5
READ(10)                           28h      M      8.2.6
READ(12)                           A8h      O     15.2.4
READ BUFFER                        3Ch      O      7.2.12
READ CAPACITY                      25h      M      8.2.7
READ DEFECT DATA(10)               37h      O      8.2.8
READ DEFECT DATA(12)               B7h      O     15.2.5
READ GENERATION                    29h      O     15.2.6
READ LONG                          3Eh      O      8.2.9
READ UPDATED BLOCK                 2Dh      O     15.2.7
REASSIGN BLOCKS                    07h      O      8.2.10
RECEIVE DIAGNOSTIC RESULTS         1Ch      O      7.2.13
RELEASE (6)                        17h      M      8.2.11
RELEASE (10)                       57h      MP     8.2.11
REQUEST SENSE                      03h      M      7.2.14
RESERVE (6)                        16h      MP     8.2.12
RESERVE (10)                       56h      M      8.2.12
REZERO UNIT                        01h      O      8.2.13
=============================================================================

              Table 15-2: Commands for Optical Memory Devices(2) 

==============================================================================
                                Operation
Command Name                       Code   Type    Section     Page
------------------------------------------------------------------------------
SEARCH DATA EQUAL(10)              31h      O      8.2.14.1
SEARCH DATA EQUAL(12)              B1h      O     15.2.8
SEARCH DATA HIGH(10)               30h      O      8.2.14.2
SEARCH DATA HIGH(12)               B0h      O     15.2.8
SEARCH DATA LOW(10)                32h      O      8.2.14.3
SEARCH DATA LOW(12)                B2h      O     15.2.8
SEEK(6)                            0Bh      O      8.2.15
SEEK(10)                           2Bh      O      8.2.15
SEND DIAGNOSTIC                    1Dh      M      7.2.15
SET LIMITS(10)                     33h      O      8.2.16
SET LIMITS(12)                     B3h      O     15.2.9
START STOP UNIT                    1Bh      O      8.2.17
SYNCHRONIZE CACHE                  35h      O      8.2.18
TEST UNIT READY                    00h      M      7.2.16
UPDATE BLOCK                       3Dh      O     15.2.10
VERIFY(10)                         2Fh      O     15.2.11
VERIFY(12)                         AFh      O     15.2.12
WRITE(6)                           0Ah      O      8.2.20
WRITE(10)                          2Ah      M     15.2.13
WRITE(12)                          AAh      O     15.2.14
WRITE AND VERIFY(10)               2Eh      O     15.2.15
WRITE AND VERIFY(12)               AEh      O     15.2.16
WRITE BUFFER                       3Bh      O      7.2.17
WRITE LONG                         3Fh      O      8.2.23
=============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.

  The following codes are vendor specific: 20h, 21h, 22h, 23h, and C0h through
FFh.  All remaining codes for optical memory devices are reserved for future
standardization.

16. Medium Changer Devices

16.2. Commands for Medium Changer Devices

  The commands for medium changer devices shall be as shown in Table 16-2.

               Table 16-2: Commands for Medium Changer Devices

==============================================================================
                                Operation
Command Name                      Code     Type   Section
------------------------------------------------------------------------------
CHANGE DEFINITION                  40h      O       7.2.1
EXCHANGE MEDIUM                    A6h      O      16.2.1
INITIALIZE ELEMENT STATUS          07h      O      16.2.2
INQUIRY                            12h      M       7.2.5
LOG SELECT                         4Ch      O       7.2.6
LOG SENSE                          4Dh      O       7.2.7
MODE SELECT(6)                     15h      O       7.2.8
MODE SELECT(10)                    55h      O       7.2.9
MODE SENSE(6)                      1Ah      O       7.2.10
MODE SENSE(10)                     5Ah      O       7.2.11
MOVE MEDIUM                        A5h      M      16.2.3
POSITION TO ELEMENT                2Bh      O      16.2.4
PREVENT ALLOW MEDIUM REMOVAL       1Eh      O       8.2.4
READ BUFFER                        3Ch      O       7.2.12
READ ELEMENT STATUS                B8h      O      16.2.5
RECEIVE DIAGNOSTIC RESULTS         1Ch      O       7.2.13
RELEASE (6)                        17h      O      16.2.6
RELEASE (10)                       57h      O      16.2.6
REQUEST VOLUME ELEMENT ADDRESS     B5h      O      16.2.7
REQUEST SENSE                      03h      M       7.2.14
RESERVE (6)                        16h      O      16.2.8
RESERVE (10)                       56h      O      16.2.8
REZERO UNIT                        01h      O       8.2.13
SEND DIAGNOSTIC                    1Dh      M       7.2.15
SEND VOLUME TAG                    B6h      O      16.2.9
TEST UNIT READY                    00h      M       7.2.16
WRITE BUFFER                       3Bh      O       7.2.17
==============================================================================

  Key: M  =  Command implementation is mandatory.
       MP =  Command implementation is mandatory on any device that addresses
             more than 8 devices.
       O  =  Command implementation is optional.

  Operation codes C0h through FFh are vendor specific.  All other operation
codes are reserved.