To: X3T9.2 Committee (SCSI) From: Scott Smyers (Apple Computer) Subject: Proposal to add a "disconnect unconditionally after command phase" mode bit in the SCSI-3 standard Date: August 26, 1992 This proposal is for a new bit in mode page 2. This bit controls whether the target is required to disconnect unconditionally or not following the receipt of a command with the disconnect privilege bit set. After disconnecting, the target may attempt to reconnect according to the setting of the "disconnect time limit" field in mode page 2. Below is a representation of the proposed change as it would appear if it were to be incorporated into the SCSI-2 standard. Change bars to the right indicate changes from the SCSI-2 rev 10h document. (Note that this proposal is for SCSI-3 and that the text below is only for illustration). | | | | | Table ! | 98: D | iscon | nect | -Rec | onnec | t Pag | e _ | | |-------------------|-----------|----------|----------------------|-----------------------|------------|---------|--------|------|---------------------|-------|------------|----------------------| | Bit | ĺ | l 6 I | 5 | 4 | ]<br> <br> | 3 | !<br>! | 2 | ==-==<br> <br> <br> | 1 | ]<br> <br> | 0 I | | =====-<br> 0<br> | l PS | Reserved | .22222 | Page C | ode ( | (0Zh) | | | | | | <del></del><br> <br> | | 1 1 | <br> <br> | | | Page L | ength | 1 (0E | (ו | | | | | | | 1 2 | <br> | | | Buffer | Full | . Rati | .0 | | | | | | | 1 3 | <br> <br> | | | Buffer | Empt | y Rat | io | | | | | | | 1 4 | (MSB) | | | Don Tarakiniko Lini: | | | | | | | | | | 1 5 | <b>,</b> | | Bus Inactivity Limit | | | | | | | | (LSB) I | | | 6 <br> 6 | (MSB) | | | D: | | <b></b> | | | | | | | | 17 | | | | Disconnect Time Limit | | | | | | | | (LSB) I | | 8 1 | (MSB) | | | | <br>· | | | | | | | <br> | | 9 1 | | | | Connect Time Limit | | | | | | | | (LSB) I | | i 10 | (MSB) | | | | | | | | | | | I | | 11 | +<br> | | | Maximum Burst Size | | | | | | | | (LSB) I | | 1 12 | | Reser | ved | | 1 | DImm | 1 | | | DTDC | | | | 13 | | | | Reserve | ed | | | | | | | <br>! | | 14 | | | | Reserve | ed | | | | | | | I<br> | | 15 | | | | Reserve | <br>≥d | | | | | | | <br> | Changes to the text would include adding the following immediately before section 7.3.3.3: Table 99: Data Transfer Disconnect Control | D | ΓDC | ı | Description | |-----|---------|---------|---------------------------------------------------------------------| | | 000b | +-<br>! | Data transfer disconnect control is not used. Disconnect is | | | | - 1 | controlled by the other fields in this page. | | | 001b | - 1 | A target shall not attempt to disconnect once the data transfer of | | | | - 1 | a command has started until all data the command is to transfer has | | | | 1 | been transferred. The connect time limit and bus inactivity limit | | | | 1 | are ignored during the data transfer. | | | 010b | ľ | Reserved | | | 011b | - 1 | A target shall not attempt to disconnect once the data transfer of | | | | 1 | a command has started until the command is complete. The connect | | | | Ì | time limit and bus inactivity limit are ignored once data transfer | | | | 1 | has started. | | 100 | b - 113 | ldI | Reserved | If DTDC is nonzero and the maximum burst size is nonzero the target shall return CHECK CONDITION status. The sense key shall be set to ILLEGAL REQUEST and the additional sense code set to ILLEGAL FIELD IN PARAMETER LIST. The Disconnect Immediate (DImm) bit allows the Initiator to control the disconnect behaviour of a Target following the Command Phase of data transfer commands (Read, Write and Write and Verify). If the Disconnect Immediate (DImm) bit is set to one, the target should disconnect after the command phase (if the previous Identify message does not grant the target the privilege of disconnection, then the target does not disconnect.) NOTE: After disconnecting, the target may reconnect for this command if the target's internal control algorithms and other disconnect/reconnect control parameters indicate that this is appropriate and permissible. If the DImm bit is set to zero, then the target has no requirements to disconnect or not disconnect other than those imposed upon it by the other parameters in this mode page. IMPLEMENTORS NOTE: When the DImm bit is set to one, it is very likely that the target is operating in an environment where there are several targets operating at the same time to satisfy a single request (e.g., in a disk array). Therefore, when the DImm bit is set to one, it is highly desirable for the target to attempt to reconnect only when the buffer full or empty ratios are met. It is also highly desirable in this situation for the target to disconnect immediately when the buffer is completely empty, in the case of a read, or completely full in the case of a write. ## 7.3.3.3 Peripheral Device Page