Date: May 12, 1999 To: T10 Committee From: Richard Moore (QLogic Corporation) Subject: Release Glitch Management for QAS (99-191r0)

## 1. Background

At the May SPI-3 Working Group meeting it was pointed out that Table 23 in SPI-3 rev 5, which describes release glitch management, does not provide for glitch management during QAS. (In fact, April's Working Group pointed out that the table was not applicable to QAS but it was not certain whether glitch management was covered in the QAS protocol. It is now ascertained that QAS will require release glitch management).

The phase control lines (MSG, C/D, and I/O) already contain release glitch management measures. The first measure is the requirement for the disconnecting target to release these lines within a QAS release delay (200 ns) of detecting SEL true, ensuring that the release glitches on these signals will be gone within 800 ns of the assertion of SEL. The second measure is the requirement for the winning device to wait a QAS arbitration delay (1000 ns) after asserting SEL, before changing any other bits (including asserting the ID of the device it wants to select). This ensures that the selected device doesn't see the release glitch on I/O as an indicator of a reselection when a selection is intended. However, Table 23 does not take these existing measures into account and should be made compatible with QAS.

11.1.2.2.1 calls for the target to release REQ directly from the asserted state. This is implied in item c in the list under "procedure for a target to indicate it wants to release the bus". If this interpretation is maintained then REQ is already immune to release glitches following the QAS message (although the release requirement should be made explicit). If the intention is to have the target actively negate REQ following the QAS message, this section will need to be changed to state this requirement and release glitch management for REQ during QAS will need to be defined. This proposal presents two alternatives, the first based on maintaining the existing REQ release requirement and the second based on actively negating REQ following the QAS message. Both alternatives also provide release glitch management for ACK and ATN.

## 2. Proposal (First Alternative)

I propose the following changes to SPI-3 to address this issue. Paragraph, table, and note numbering is based on SPI-3 rev 5; the editor should make any necessary adjustments.

- 1. Change the caption of Table 23 from "Non-QAS glitch management requirements for SCSI devices using LVD drivers" to "Glitch management requirements for SCSI devices using LVD drivers". Delete the Editor's Note at the bottom of the table.
- 2. Change "ACK, ATN" in the first column of Table 23 to "ACK, ATN during transitions to BUS FREE".
- 3. Add this row after the "ACK, ATN during transitions to BUS FREE" row in Table 23:

| ACK, ATN during QAS | Ι | R | The initiator shall wait until | Starting no later than two |
|---------------------|---|---|--------------------------------|----------------------------|
|                     |   |   | two system deskew delays       | system deskew delays       |
|                     |   |   | after it detects C/D, I/O, and | after negating C/D, I/O,   |
|                     |   |   | MSG false before releasing     | and MSG, the target shall  |
|                     |   |   | the ACK and ATN signals        | ignore the ACK and         |
|                     |   |   | from the actively negated      | ATN signals until a        |
|                     |   |   | state.                         | subsequent connection.     |

- 4. Change "REQ" in the first column of Table 23 to "REQ during transitions to BUS FREE".
- 5. Add this row after the "REQ during transitions to BUS FREE" row in Table 23 (NOTE: "R/P" means "required prior to assertion of REQ for the QAS message, prohibited thereafter"; this may be indicated by whatever means the editor believes to be best):

| REQ during QAS | Т | R/P | After detecting ACK true<br>while sending a QAS<br>message, the target shall<br>release the REQ signal from<br>the asserted state without | No glitch management required. |
|----------------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
|                |   |     | actively negating the REQ signal.                                                                                                         |                                |

- 6. Change "C/D, I/O, MSG" in the first column of Table 23 to "C/D, I/O, MSG except during SELECTION and RESELECTION phases of QAS".
- Add this row after the "C/D, I/O, MSG except during SELECTION and RESELECTION phases of QAS" row in Table 23:

| C/D, I/O, MSG during      | Т | Р | After detecting SEL true       | No glitch management |
|---------------------------|---|---|--------------------------------|----------------------|
| SELECTION and             |   |   | following QAS arbitration,     | required.            |
| <b>RESELECTION</b> phases |   |   | the target shall release these |                      |
| of QAS                    |   |   | signals within a QAS           |                      |
|                           |   |   | release delay.                 |                      |

- 8. Make the following changes in 11.1.2.2.1, "QAS phase" under "The procedure for a target to indicate it wants to release the bus":
  - a. Change item (c) as follows: "After detection of the last ACK signal being false and if there is no attention condition, the target shall release the REQ signal without actively negating it. The target shall then release all SCSI signals except the BSY, MSG, C/D, and I/O signals, and the target shall negate the MSG, C/D, and I/O signals within two system deskew delays."
  - b. Add the following note after item (e): "NOTE 32 The release of MSG, C/D, and I/O may cause release glitches; this requirement ensures these glitches occur at a time when no connection is established on the bus so that they do not interfere with proper operation."
  - c. Editorial change: Change "asserted" to "true" in both places in item (g). Also, change "delay, if" in this item to "delay. If".
- 9. Editorial change: Fix the list under "The procedure for an SCSI device to obtain control of the SCSI bus". In rev 5, there are two item (b)s and in the subordinate list under item (d) there are two item (A)s. In the third item of the subordinate list, change "asserted" to "true".

## 3. Proposal (Second Alternative)

The alternative to the above proposal is for the target to actively negate the REQ signal at the end of the QAS message, and to add glitch management for REQ.

- 1. Change the caption of Table 23 from "Non-QAS glitch management requirements for SCSI devices using LVD drivers" to "Glitch management requirements for SCSI devices using LVD drivers". Delete the Editor's Note at the bottom of the table.
- 2. Change "ACK, ATN" in the first column of Table 23 to "ACK, ATN during transitions to BUS FREE".

3. Add this row after the "ACK, ATN during transitions to BUS FREE" row in Table 23:

| ACK, ATN during QAS | Ι | R | The initiator shall wait until | Starting no later than two |
|---------------------|---|---|--------------------------------|----------------------------|
|                     |   |   | two system deskew delays       | system deskew delays       |
|                     |   |   | after it detects C/D, I/O, and | after negating C/D, I/O,   |
|                     |   |   | MSG false before releasing     | and MSG, the target shall  |
|                     |   |   | the ACK and ATN signals        | ignore the ACK and         |
|                     |   |   | from the actively negated      | ATN signals until a        |
|                     |   |   | state.                         | subsequent connection.     |

- 4. Change "REQ" in the first column of Table 23 to "REQ during transitions to BUS FREE".
- 5. Add this row after the "REQ during transitions to BUS FREE" row in Table 23:

| REQ during QAS | Т | R | The target shall wait two<br>system deskew delays after<br>negating C/D, I/O, and MSG<br>before releasing the REQ<br>signal from the actively<br>negated state. | Starting no later than a<br>Bus Settle Delay after<br>detecting C/D, I/O, and<br>MSG false, the initiator<br>shall ignore the REQ<br>signal until a subsequent |
|----------------|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |   |   | negated state.                                                                                                                                                  | connection.                                                                                                                                                    |

- 6. Change "C/D, I/O, MSG" in the first column of Table 23 to "C/D, I/O, MSG except during SELECTION and RESELECTION phases of QAS".
- Add this row after the "C/D, I/O, MSG except during SELECTION and RESELECTION phases of QAS" row in Table 23:

| C/D, I/O, MSG during<br>SELECTION and | Т | Р | After detecting SEL true following QAS arbitration, | No glitch management required. |
|---------------------------------------|---|---|-----------------------------------------------------|--------------------------------|
| <b>RESELECTION</b> phases             |   |   | the target shall release these                      |                                |
| of QAS                                |   |   | signals within a QAS release                        |                                |
|                                       |   |   | delay.                                              |                                |

- 8. Make the following changes in 11.1.2.2.1, "QAS phase" under "The procedure for a target to indicate it wants to release the bus":
  - a. Change item (c) as follows: "After detection of the last ACK signal being false and if there is no attention condition, the target shall negate REQ. The target shall release all SCSI signals except the BSY, MSG, C/D, I/O, and REQ signals, and shall negate the MSG, C/D, and I/O signals within two system deskew delays after negating REQ. The target shall wait two system deskew delays after negating the C/D, I/O, and MSG signals before releasing the REQ signal."
  - b. Add the following note after item (e): "NOTE 32 The release of MSG, C/D, and I/O may cause release glitches; this requirement ensures these glitches occur at a time when no connection is established on the bus so that they do not interfere with proper operation."
  - c. Editorial change: Change "asserted" to "true" in both places in item (g). Also, change "delay, if" in this item to "delay. If".
- 9. Editorial change: Fix the list under "The procedure for an SCSI device to obtain control of the SCSI bus". In rev 5, there are two item (b)s and in the subordinate list under item (d) there are two item (A)s. In the third item of the subordinate list, change "asserted" to "true".