Small Computer Systems Interface MB87030 Synchronous/Asynchronous Protocol Controller **Users Manual** Fujitsu Limited Fujitsu Microelectronics, Inc. Fujitsu Mikroelektronik GmbH Small Computer Systems Interface MB87030 Synchronous/Asynchronous Protocol Controller **Users Manual** Copyright © 1986 by Fujitsu Limited and Fujitsu Microelectronics, Inc. This Publication contains information considered proprietary by Fujitsu Limited, Tokyo, Japan and Fujitsu Microelectronics, Inc. No part of this document may be copied or reproduced in any form or by any means or transferred to any third party without the prior written consent of Fujitsu Limited. Circuit diagrams utilizing Fujitsu products are included as a means of illustrating typical applications; consequently complete information sufficient for construction purposes is not necessarily given. The information in this publication has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for any inaccuracies. The information conveyed in this publication does not convey any license under the patent rights of Fujitsu Limited. Fujitsu reserves the right to change specifications without notice. MB87030 Synchronous/Asychronous Protocol Controller User's Manual is published by the U.S. Technical Publications Department, Fujitsu Microelectronics, 3320 Scott Blvd., Santa Clara, CA 95054-3197, (408) 727-1700 ext. 2414. Printed in the U.S.A. Edition 1.0 (Phase 1) May, 1986 ## **Fujitsu Limited** Furukawa Sogo Bldg., 6-1 Marunouchi 2-Chome, Chiyoda-ku Tokyo 100, Japan Phone National (03) 216-3211 Phone International 81-3-216-3211 Telex: 2224361 FT TOR J ## Fujitsu Microelectronics, Inc. 3320 Scott Blvd. Santa Clara, CA 95054-3197 Phone: (408) 727-1700 Telex: (910) 338-0190 ## Fujitsu Mikroelektronik GmbH Arabella Center 9, OG/A Lyoner Straβe 44–48 D–6000 Frankfurt 71, F.R. Germany Phone 069/66 320 Telex 0411 963 #### PRFFACE The Fujitsu MB87030 (SPC: SCSI Protocol Controller) is a CMOS LSI circuit developed to control the small computer system interface (SCSI). This manual explains the functions and use of the MB87030. It consists of the following chapters: CHAPTER 1 OUTLINE CHAPTER 2 INPUT/OUTPUT TERMINALS CHAPTER 3 FUNCTIONS CHAPTER 4 OPERATIONAL DESCRIPTION CHAPTER 5 EXAMPLES OF EXTERNAL CIRCUIT CONNECTIONS CHAPTER 6 AC CHARACTERISTICS To effectively apply this LSI circuit's functions, you must be familiar with SCSI functions and interface control procedures. Note: Fujitsu reserves the right to change functions or characteristics to improve the design of the LSI circuit without prior notice. #### CONTENTS | | Page | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | CHAPTER 1 OUTLINE 1.1 GENERAL DESCRIPTION 1.2 FEATURES 1.3 ELECTRICAL CHARACTERISTICS 1.3.1 Absolute Maximum Ratings 1.3.2 Recommended Operating Conditions 1.3.3 DC Characteristics 1.3.4 Input/output Capacitance 1.4 PHYSICAL DIMENSIONS | 1 1 1 2 2 | | CHAPTER 2 INPUT/OUTPUT TERMINALS 2.1 PIN ASSIGNMENTS 2.2 INPUT/OUTPUT SIGNALS | 4 | | CHAPTER 3 FUNCTIONS 3.1 FUNCTIONAL BLOCKS 3.2 INTERNAL REGISTER 3.2.1 Addressing 3.2.2 Internal Register Assignments 3.3 MAJOR OPERATIONS 3.3.1 MPU Interface Control Block 3.3.2 Bus Phase Control Block 3.3.3 Arbitration/Selection Sequence Control Block 3.3.4 Transfer Sequence Control Block 3.3.5 Transfer Byte Counter Block 3.3.6 Data Buffer Register Block | 10 11 11 14 14 14 14 14 14 | | CHAPTER 4 OPERATIONAL DESCRIPTION 4.1 BDID REGISTER 4.2 SCTL REGISTER 4.3 SCMD REGISTER 4.3.1 Register Functions 4.3.2 Command Functions 4.3.3 Command Termination Report 4.3.4 Command Issuance Timing 4.4 TMOD REGISTER 4.4.1 Register Functions 4.4.2 Transfer Mode Setting Timing 4.5 PCTL REGISTER 4.6 DATA BUFFER REGISTER (DREG) 4.7 TEMP REGISTER 4.8 TRANSFER BYTE COUNTER (TCH, TCM, TCL) 4.9 PSNS REGISTER 4.10 SSTS REGISTER 4.10 Register Functions | 16 18 21 30 31 32 34 35 36 37 37 | | 4.10.2 SPC Status 4.11 INTS REGISTER 4.11.1 Register Functions 4.11.2 Interrupt Processing 4.12 SERR REGISTER 4.12.1 Register Functions | 38<br>39<br>39<br>47 | | 4.12.2 Error Reset 4.13 MBC REGISTER 4.14 EXTERMA: BIFFER REGOSTER (EXBF) 4.15 SDGC REGISTER 4.16 INITIALIZATION | 49<br>50 | ## CONTENTS (Cont'd) | | | Page | |-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | 5.1.1<br>5.1.2 | EXAMPLES OF EXTERNAL CIRCUIT CONNECTIONS I DRIVER/RECEIVER CIRCUITS Single Ended Type Differential Type ERNAL DATA BUFFER | . 54<br>. 54<br>. 57 | | 6.2.1<br>6.2.2<br>6.2.3 | AC CHARACTERISTICS INTERFACE Clock Signal Reset Signal Write Cycle Read Cycle Interrupt INTERFACE Access Timing Input Operation Output Operation INTERFACE SELECTION Phase RESELECTION Phase Transfer Phase Attention Condition (INITIATOR) BUS FREE | . 63<br>. 63<br>. 63<br>. 65<br>. 67<br>. 67<br>. 68<br>. 69<br>. 70<br>. 78<br>. 82<br>. 97 | | 6.3.6 | Reset Condition | | ## **ILLUSTRATIONS AND TABLES** | ILLUSTRATIONS | age | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------| | Fig. 1.4.1 Dimensions of package Fig. 2.1.1 Pin assignments Fig. 3.1.1 SPC functional block diagram Fig. 4.3.1 Status transitions in Select command execution Fig. 4.3.2 ATN signal generation in data transfer Fig. 4.3.3 ATN signal resetting in MESSAGE OUT phase Fig. 4.3.4 Manual transfer procedure (SPC serving as a TARGET) Fig. 4.3.5 Manual transfer procedure (SPC serving as an INITIATOR) Fig. 4.3.6 Command execution timing Fig. 4.4.1 Transfer period setting Fig. 4.6.1 DREG access procedure in program transfer mode Fig. 4.7.1 Data bus save in manual transfer input operation Fig. 4.11.2 Service required interrupt processing procedure (1) Fig. 4.11.3 Example of control processing for SPC-detected error (1) Fig. 4.11.4 Example of control processing for SPC-detected error (2) Fig. 4.11.5 Example of control processing for SPC-detected error (2) Fig. 4.12.1 Specified input cycle of REQ/ACK signal Fig. 4.12.1 Specified input cycle of REQ/ACK signal Fig. 4.12.1 SPC initialization (at power-on) Fig. 5.1.1 Examples of external circuit connections Fig. 5.1.2 Example of single ended type SCSI driver/receiver circuit Fig. 5.1.3 Example of differential type SCSI driver/receiver circuit Fig. 5.2.1 Transfer with external data buffer (output operation) Transfer to external data buffer (output operation) | 3<br>5<br>10<br>24<br>25<br>25<br>28<br>31<br>32<br>43<br>44<br>45<br>50<br>52<br>55<br>55<br>56<br>61 | | TABLES | age | | Table 2.1.1 Input/output signals | 6<br>11<br>12 | | Select command | 22<br>33<br>38<br>48 | | circuit (example) | 54<br>57 | #### CHAPTER 1 #### OUTLINE #### 1.1 GENERAL DESCRIPTION The MB87030 (SPC: SCSI Protocol Controller) is a CMOS LSI circuit designed to make control of the small computer system interface (SCSI) easier. The MB87030, which can control all the SCSI interface signals and handle almost all the interface control procedures, can be used as a peripheral LSI circuit for an 8- or 16-bit MPU to realize high-level SCSI control. This LSI circuit has an 8-byte FIFO data buffer register and a transfer byte counter that is 24 bits long. Its wide range of applications allows not only asynchronous mode transfer but also synchronous mode transfer with an offset of 8 bytes at maximum. Furthermore, MB87030 can serve as either an INITIATOR or a TARGET device for the SCSI, and can therefore be used for either an I/O controller or a host adapter. (Note: In this manual, MB87030 is referred to as SPC) #### 1.2 FEATURES - Full support for SCSI control - Serves as either INITIATOR or TARGET device - · Synchronous mode transfer with a programmable offset, up to eight bytes - Data transfer speed programmable at four rates (in synchronous mode transfer) - · Data transfer up to 4 MBPS allowed - Eight-byte data buffer register incorporated - Transfer byte counter, 24 bits long, incorporated - Independent data transfer bus - Applicable to the single-ended alternative and the differential alternative for SCSI - Single +5 V supply - Low power dissipation - TTL-compatible inputs/outputs - PGA 88-pin ceramic package #### 1.3 ELECTRICAL CHARACTERISTICS #### 1.3.1 Absolute Maximum Ratings\* | Rating | Symbol- | Min. | Max. | Unit | |----------------------------------|-------------------|-------------------------|-----------------------|------| | Supply Voltage | v <sub>DD</sub> | Vss**- 0.5 | 7.0 | ٧ | | Input Voltage | ٧ <sub>I</sub> | V <sub>SS</sub> **- 0.5 | V <sub>DD</sub> + 0.5 | V | | Output Voltage | v <sub>o</sub> | V <sub>SS</sub> **- 0.5 | V <sub>DD</sub> + 0.5 | V | | Storage Temperature (Ceramic) | T <sub>stg</sub> | -65 | +150 | °C | | Temperature Under Bias (Ceramic) | T <sub>bias</sub> | -40 | +125 | °C | | Output Current*** | Ios | -40 | +70 | mA | <sup>\*</sup> Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of the data sheet. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. <sup>\*\*</sup> $V_{SS} = 0 V$ <sup>\*\*\*</sup> Not more than one output may be shorted at a time for a maximum duration of one second. ## 1.3.2 Recommended Operating Conditions | Parameter | Symbol | Min. | Typ. | Max. | Unit | |-----------------------|-----------------|------|------|------|------| | Supply Voltage | v <sub>DD</sub> | 4.75 | 5.0 | 5.25 | ٧ | | Input High Voltage | VIH | 2.2 | | | V | | Input Low Voltage | VIL | | | 0.8 | ٧ | | Operating Temperature | TA | 0 | | 70 | °C | ## 1.3.3 DC Characteristics (Recommended Operating Conditions unless otherwise noted) | Parameter | Symbol | Condition | Min. | Typ. | Max. | Unit | |-----------------------|------------------|------------------------------------------------|-----------------|------|-----------------|------| | Power Supply Current | I <sub>DDS</sub> | *<br>Steady state | | | 100 | μΑ | | Power Dissipation | PD | | | 300 | | mW | | Output High Voltage | v <sub>ОН</sub> | I <sub>OH</sub> = -0.4mA | 4.2 | | V <sub>DD</sub> | ٧ | | Output Low Voltage | V <sub>OL</sub> | I <sub>OL</sub> = 3.2mA | V <sub>SS</sub> | | 0.4 | ٧ | | Input High Voltage | ν <sub>IH</sub> | | 2.2 | | | ٧ | | Input Low Voltage | VIL | | | | 0.8 | ٧ | | Input Leakage Current | ILI | V <sub>I</sub> =0 - V <sub>DD</sub> | -10 | | 10 | μА | | Input Leakage Current | I <sub>LZ</sub> | 3-state<br>V <sub>I</sub> =0 - V <sub>DD</sub> | -10 | | 10 | μΑ | <sup>\*</sup> Note: VIH = VDD , VIL = VSS # 1.3.4 Capacitance $(T_A = 25$ °C, $V_{DD} = V_I = 0$ V, f = 1 MHz) | Parameter | Symbol | Min. | Тур. | Max. | Unit | |------------------------|------------------|------|------|------|------| | Input Pin Capacitance | CIN | | | 9 | pF | | Output Pin Capacitance | C <sub>OUT</sub> | | | 9 | pF | | I/O Pin Capacitance | c <sub>I/0</sub> | | | 11 | pF | #### 1.4 PHYSICAL DIMENSIONS The MB87030 is packaged in an 88-pin ceramic package. Figure 1.4.1 shows the dimensions of the package. Figure 1.4.1 Dimensions of Package #### CHAPTER 2 ## INPUT/OUTPUT TERMINALS #### 2.1 PIN ASSIGNMENTS Figure 2.1.1 shows the arrangement of pins on this LSI. ## 2.2 INPUT/OUTPUT SIGNALS Table 2.1.1 lists the input/output signals and their functions. In this table, the plus and minus signs have the following meaning: +: Indicates an active-high signal. -: Indicates an active-low signal. | No. | 1/0 | Signal<br>name | No. | 1/0 | Signal<br>name | No. | 1/0 | Signal<br>name | No. | 1/0 | Signal<br>name | |-----|-----|----------------|-----|-----|----------------|-----|-----|----------------|-----|--------------|----------------| | 1 | I | HIN | 23 | 0 | SDBOP | 45 | I | Al | 67 | 0 | SDBE5 | | 2 | I/O | HDB0 | 24 | 0 | SDBE7 | 46 | I | A2 | 68 | 0 | SDBE4 | | 3 | 1/0 | 1 | 25 | I | SDBI7 | 47 | I | A3 | 69 | I | SDB14 | | 4 | I/O | 2 | 26 | 0 | SDBE6 | 48 | I/O | D4 | 70 | 0 | SDB03 | | 5 | I/O | 3 | 27 | 0 | SDB05 | 49 | 1/0 | <b>D</b> 5 | 71 | I | SDBI2 | | 6 | I/O | 4 | 28 | I | SDBI5 | 50 | 1/0 | D6 | 72 | 0 | SDB01 | | 7 | I/O | 5 | 29 | 0 | SDB04 | 51 | I/O | D7 | 73 | 0 | SDBE0 | | 8 | I/O | 6 | 30 | 0 | SDBE3 | 52 | 1/0 | DP | 74 | I | SDBIO | | 9 | I/O | 7 | 31 | I | SDBI3 | 53 | 0 | INTR | 75 | I | RST | | 10 | I/O | P | 32 | 0 | SDB02 | 54 | I | I/OI | 76 | 0 | DREQ | | 11 | 0 | INIT | 33 | 0 | SDBE2 | 55 | I | C/DI | 77 | I | WT | | 12 | 0 | TARG | 34 | I | SDB11 | 56 | I | SELI | 78 | I | WIG | | 13 | 0 | 1/00 | 35 | 0 | SDBE1 | 57 | I | MSG1 | 79 | 1/0 | D2 | | 14 | 0 | C/DO | 36 | 0 | SDBOO | 58 | I | REQI | -80 | 1/0 | D3 | | 15 | 0 | SELO | 37 | I | <del>cs</del> | 59 | I | RSTI | 81 | Power supply | VSS | | 16 | 0 | MSGO | 38 | I. | CLK | 60 | I | ACKI | 82 | Power supply | ADD | | 17 | 0 | REQO | 39 | I | RD | 61 | I | BSYI | 83 | Power supply | VDD | | 18 | 0 | RSTO | 40 | I | RDG | 62 | I | ANTI | 84 | Power supply | vss | | 19 | 0 | ACKO | 41 | I | DRESP | 63 | I | SDBIP | 85 | Power supply | VSS | | 20 | 0 | BSYO | 42 | 1/0 | DO | 64 | 0 | SDB07 | 86 | Power supply | VDD | | 21 | 0 | ATNO | 43 | 1/0 | Dl | 65 | 0 | SDB06 | 87 | Power supply | VDD | | 22 | 0 | SDBEP | 44 | I | A0 | 66 | I | SDB16 | 88 | Power supply | vss | Figure 2.1.1 Pin assignments Table 2.1.1 Input/output signals (Continued on next sheet) | Signal<br>name | Pola-<br>rity | I/0 | Pin | Q'ty | Function | |----------------------|---------------|-----|----------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>DD</sub> | | I | 82<br>83<br>86<br>87 | 4 | +5 V power supply | | V <sub>SS</sub> | | I | 81<br>84<br>85<br>88 | 4 | Ground (0 V) | | CLK | - | I | 38 | 1 | A clock input for controlling the SPC internal operation and the data transfer speed. | | RST | - | I | 75 | 1 | An asynchronous reset signal for clearing the internal circuits in SPC. | | CS | - | I | 37 | 1 | A selection enable signal for accessing an internal register in SPC. When this input signal is active, the following input/output signals are valid: RD, RDG WT, WTG A3 to A0 D7 to D0, DP | | A3<br>A2<br>A1<br>A0 | + | I | 47<br>46<br>45<br>44 | 4 | Address input signals for selecting an internal register in SPC. MSB: A3, LSB: A0 When $\overline{\text{CS}}$ input is active, read/write is enabled in an internal register selected by these address inputs via data bus lines D7 to D0 and DP. | | RD<br>RDG | - | I | 39<br>40 | 2 | These strobe inputs are used for reading out the contents of the SPC internal register, and are effective only when $\overline{\text{CS}}$ input is active. While RDG input is active, the contents of an internal register selected by A3 to A0 inputs are placed on data bus lines D7 to D0 and DP. For a data transfer cycle in the program transfer mode, the trailing edge of $\overline{\text{RD}}$ input is used as a timing signal indicating the end of data read. | | WT | _ | I | 77 | 1 | This strobe input is used for writing data into an SPC internal register, and is effective only when $\overline{\text{CS}}$ input is active. On the trailing edge of this signal, data placed on data bus lines D7 to D0 and DP are loaded into an internal register selected by A3 to A0 inputs. (Except when A3 = A2 = A1 = A0 = 'H') For a data transfer cycle in the program transfer mode, the trailing edge of this signal is used as a timing signal indicating data-ready state. | | WTG | _ | I | 78 | 1 | While this signal is active, data placed on data bus lines D7 to D0 and DP are output to HDB7 to HDB0 and HDBP if the following input conditions are satisfied: $\overline{\text{CS}} = \text{'L'}$ A3 = A2 = A1 = A0 = 'H' HIN = 'H' | Table 2.1.1 Input/output signals (Continued on next sheet) | Signal<br>name | Pola-<br>rity | I/0 | Pin | Q'ty | Function | |-------------------------------------------------------------------------------|---------------|-----|----------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D7<br>D6<br>D5<br>D4<br>D3<br>D2<br>D1<br>D0<br>DP | + | I/O | 51<br>50<br>49<br>48<br>80<br>79<br>43<br>42<br>52 | 9 | Used for write/read data into/from an internal register in SPC. This data bus is three-state and bidirectional. MSB: D7 LSB: D0 Odd parity bit: DP When the CS and RDG inputs are active, the contents of the internal register are output to the data bus (read operation). In operations other than read, this data bus is kept at a high impedance level. | | INTR | + | 0 | 53 | 1 | Requests an interrupt to indicate completion of SPC. internal operation or occurrence of an error. Interrupt masking is allowed except for an interrupt caused by RSTI input (reset condition in SCSI). When an interrupt request is permitted, the INTR signal remains active until the cause of the interrupt is cleared. | | SDBI7<br>SDBI6<br>SDBI5<br>SDBI4<br>SDBI3<br>SDBI2<br>SDBI1<br>SDBI0<br>SDBIP | + | I | 25<br>66<br>28<br>69<br>31<br>71<br>34<br>74<br>63 | 9 | Used as input from the SCSI data bus. MSB: SDBI7 LSB: SDBI0 Odd parity bit: SDBIP Parity checking for the SCSI data bus is programmable. | | SDB07<br>SDB06<br>SDB05<br>SDB04<br>SDB03<br>SDB02<br>SDB01<br>SDB00<br>SDB0P | + | 0 | 64<br>65<br>27<br>29<br>70<br>32<br>72<br>36<br>23 | 9 | Used as outputs to the SCSI data bus. MSB: SDB07 LSB: SDB00 Odd parity bit: SDB0P If the bus driver is an open collector type, there signals can be supplied directly to the driver circuit. If the bus driver is a three-state type, these signals are used as data, and the SDBE7 to SDBE0 and SDBEP signals are used as drive enable signals. | | SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1<br>SDBE0<br>SDBEP | + | 0 | 24<br>26<br>67<br>68<br>30<br>33<br>35<br>73<br>22 | 9 | Used as drive enable signals (corresponding to respective bit positions) where a three-state buffer is used for the SCSI data bus. SDBE7 to SDBE0 and SDBEP correspond to SDBO7 to SDB00 and SDBOP, respectively. The relationship with SCSI bus phase is shown below. SCSI bus phase SDBON SDBEN | Table 2.1.1 Input/output signals (Continued on next sheet) | Signal<br>name | Pola-<br>rity | I/0 | Pin | Q'ty | Function | |----------------------------------------------------------------------|---------------|-----|----------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SELI<br>BSYI<br>REQI<br>ACKI<br>MSGI<br>C/DI<br>I/OI<br>ATNI<br>RSTI | + | I | 56<br>61<br>58<br>60<br>57<br>55<br>54<br>62<br>59 | 9 | Used for receiving SCSI control signals. The outputs of the SCSI receiver circuit can be connected directly. Note: Waveform distortion or any other disturbance should not occur in the REQI and ACKI signals which are used as timing control signals for sequencing data transfer. | | SELO<br>BSYO<br>REQO<br>ACKO<br>MSGO<br>C/DO<br>I/OO<br>ATNO<br>RSTO | + | 0 | 15<br>20<br>17<br>19<br>16<br>14<br>13<br>21 | 9 | Used for outputting SCSI control signals. The following signals become active only when SPC serves as a TARGET; otherwise, these signals are always low. REQD, MSGO, C/DO, I/OO The following signals become active only when SPC serves as an INITIATOR; otherwise, these signals are always low. ACKO, ATNO | | INIT<br>TARG | + | 0 | 11<br>12 | 2 | Used for indicating the SPC operation state. These signals are also available as control signals for the SCSI driver/receiver circuit. INIT TARG Status | | DREQ | + | 0 | 76 | 1 | At a data transfer cycle in DMA mode, the DREQ signal is used to indicate a request for data transfer between SPC and the external buffer memory. In DMA mode, data is routed as shown below. • Output operation External buffer memory HDB7 to HDB0, and HDBP pins SPC internal data buffer register (8 bytes) SDB07 to SDB00 and SDB0P pins (SCSI) | Table 2.1.1 Input/output signals (Continued) | Signal<br>name | Pola-<br>rity | I/0 | Pin | Q'ty | Function | |----------------------------------------------------------------------|---------------|-----|--------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | • Input operation (SCSI) SDBI7 to SDBIO and SDBIP pins Provided internal data buffer register (8 bytes) HDB7 to HDBO and HDBP pins External buffer memory In an output operation, this signal becomes active to request data transfer from the external buffer memory when the SPC internal data buffer register has free space available. In an input operation, it becomes active to request data transfer to the external buffer memory when the SPC internal buffer register contains valid data. | | DRESP | + | I | 41 | 1 | Used as an response signal to the above data transfer request signal (DREQ) in DMA mode data transfer cycle. Pin DRESP must be supplied with a pulse signal at the end of each byte that is transferred. In an output operation, SPC uses the trailing edge of the DRESP signal for sampling data on HDB7 to HDB0 and HDBP bus lines. In an input operation, SPC holds data to be transferred onto HDB7 to HDB0 and HDBP bus lines until the trailing edge of the DRESP signal. | | HDB7<br>HDB6<br>HDB5<br>HDB4<br>HDB3<br>HDB2<br>HDB1<br>HDB0<br>HDBP | + | 1/0 | 9<br>8<br>7<br>6<br>5<br>4<br>3<br>2 | 9 | Three-state, bidirectional data bus for transferring data to/from the external buffer memory in DMA mode data transfer cycle. MSB: HDB7 LSB: HDB0 Odd parity bit: HDBP The data transmission direction depends on the HIN input signal. HIN HDBn Operation TL Input mode Output 'H' Output mode Input | | HIN | + | I | 1 | 1 | This signal indicates transmission direction along data bus lines HDB7 to HDB0 and HDBP in DMA transfer mode. Transmission direction must be coordinated with the SPC internal operation to be executed. When the HIN signal is low, data bus lines HDB7 to HDB0 and HDBP are put in the high impedance state (input mode). When the HIN signal is high, they are put in the output mode. | #### CHAPTER 3 #### FUNCTIONS ## 3.1 FUNCTIONAL BLOCKS Figure 3.1.1 shows the SPC functional block diagram. SPC mainly consists of the following functional blocks: - Internal register block (1) - MPU interface control block (2) (3) - Bus phase control block - Arbitration/selection sequence control block (4) - - Transfer sequence control block (5) - Transfer byte counter block (6) - Data buffer register block (7) Figure 3.1.1 SPC functional block diagram #### 3.2 INTERNAL REGISTER SPC has internal registers consisting of 17 bytes that are accessible from an external circuit. These internal registers are used for controlling SPC internal operation and indicating SPC processing status/result status. #### 3.2.1 Addressing A unique address is assigned to each internal register, and a particular register is identified by address bits A3 to A0. Table 3.2.1 shows internal register addressing. ## 3.2.2 Internal Register Assignments Table 3.2.2 shows the bit assignment to each internal register. When accessing an internal register (in read/write), remember the following: - (1) The internal register block includes the read-only/write-only register and those having different meanings in read and write operations. - (2) A write to the read-only register is ignored. - (3) If the write-only register is read out, the data and parity bit are undefined. - (4) At bit positions indicating "\_\_\_ " for a write in Table 3.2.2, either 1 of 0, or may be written. Table 3.2.1 Internal register addressing | <del>CS</del> | А3 | A2 | A1 | Α0 | OP | Register Name | Abbr. | |---------------|----|----|----|----|--------|------------------------------------|-------| | 0 | 0 | 0 | 0 | 0 | R<br>W | Bus Device ID | BDID | | 0 | 0 | 0 | 0 | 1 | R<br>W | SPC Control | SCTL | | 0 | 0 | 0 | 1 | 0 | R | Command | SCMD | | 0 | 0 | 0 | 1 | 1 | R | Transfer Mode | TMOD | | 0 | 0 | 1 | 0 | 0 | R<br>W | Interrupt Sense<br>Reset Interrupt | INTS | | 0 | 0 | 1 | 0 | 1 | R | Phase Sense | PSNS | | " | U | 1 | U | 1 | W | SPC Diagnostic Control | SDGC | | 0 | 0 | • | 1 | 0 | R | SPC Status | SSTS | | ן ט | U | 1 | 1 | U | W | | | | | | | _ | _ | R | SPC Error Status | SERR | | 0 | 0 | 1 | 1 | 1 | W | | | | 0 | 1 | 0 | 0 | 0 | R | Phase Control | PCTL | | | | | _ | - | R | Modified Byte Counter | MBC | | 0 | 1 | 0 | 0 | 1 | W | | | | 0 | 1 | 0 | 1 | 0 | R<br>W | Data Register | DREG | | 0 | 1 | 0 | 1 | 1 | R | Temporary Register | TEMP | | 0 | 1 | 1 | 0 | 0 | R<br>W | Transfer Counter High | TCH | | 0 | 1 | 1 | 0 | 1 | R<br>W | Transfer Counter Middle | TCM | | 0 | 1 | 1 | 1 | 0 | R<br>W | Transfer Counter Low | TCL | | 0 | 1 | 1 | 1 | 1 | R<br>W | External Buffer | EXBF | Table 3.2.2 Internal register bit assignment (Continued on next sheet) | Device ID Representation Representation Representation Representation Representation Representation Representation Representation Reset | No. | Name<br>(Abbr.) | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------|-----|--------|----------|----------|-------------|----------|----------|---------------------------------------------------|--------|----------| | BDID | 1 | Bus | R | | | | | | | | | | | SPC Control | | | 14/ | #7 | #6 | #5 | #4 | #3 | | | | '0' | | Control (SCTL) | | (8010) | w | | | | | | | | | - | | SCTL W Discolate Able Bit Command Code RST Intercept Command Code RST Intercept Command Code RST Intercept Command Code RST Command Code RST Command Code C | 2 | | R | | | | | | | | | | | SCMD | | | 1,7 | | Reset | Mode | Enable | Enable | Enable | Enable | Enable | | | Command (SCMD) R Command Code RST Inter- | | (SUIL) | w | | | | | | | | | | | W | 3 | Command | R | abic | | | | | Trans | fer Modif | ier | Р | | | | (SCMD) | | Comm | and Code | | | | | | _ | | | Transfer Node | | | W | | 1 | ı | Out | cept | 1 | '0' | | | | Mode | 4 | Transfer | R | Sync. | | | L | VIEL | Aller. | | Mode | | | | | Mode | | | Max. | Transfe | r | Min. Tr | ansfer | 101 | '0' | Р | | Second Control (PCTL) | | (TMOD) | W | | | | | | | | | | | Control (PCTL) | - | Phase | Б | Ruc | 4 | 2 | 1 | 2 | 1 | | | | | PCTL W | | | " | | | | | | Tran | sfer Phas | e l | | | Enable E | | | W | Inter- | | 1 | 0' | | MSG | C/D | I/D | P | | Register | | | | | | | | | Out | Out | Out | | | Sense | - | Phase | Ь | | | ATN | CEI | RCV | MSG | C/D | 7.70 | D | | Transfer R Transfer Counter High (MSB) P | " | | | KLQ | AUN | AIN | JLL | 1 1001 | Mod | 6/6 | 1/0 | ' | | Register (DREG) W Bit7 6 5 4 3 2 1 0 | | (PSNS) | W | | | · | _ | _ | <b>.</b> | | | | | Register (DREG) W Bit7 6 5 4 3 2 1 0 | | Dete | _ | | T | 1 D-+ | - D4-4 | (O. D. | +- FIFO | <del>, </del> | | | | Counter | ' | | | | inter | na i Dat | a kegist | er (8 by | te FIFU | ) | | P | | Counter | | | W | Bit7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | • | | Counter | | | | | | | | | | | | | | High (TCH) | 8 | | R | | | <br>Tmn | nefon Co | <br> | ab (MSD | l, | | ь | | Transfer | | | W | Bit.23 | 22 | | | | | | 16 | | | Counter Mid. W Bit15 | | (TCH) | 1 | 5.020 | | | | | 1 | ] <u>-</u> | - | | | Mid. (TCM) | 9 | | R | | _ | | | | | | | P | | CTCM | | | - | Ri+15 | | | | | | e)<br>a | Q | | | 10 Transfer R | | | " | PICTO | 14 | 13 | 1 | 1 | 1 | | | | | Low (TCL) | 10 | Transfer | R | | | | | | | | | | | CTCL | | | | 07+7 | | | | | w (ĽSB) | | • | P | | The content of | | | W | BIT/ | ь | 5 | 4 | 3 | 2 | 1 | U | | | Sense (INTS) Cted lected Con- nected Com- Re- quired W Reset Interrupt 12 SPC Status (SSTS) R Connected SPC Status (SSTS) R Connected Busy Pro- RST FULL EMPTY | 11 | | R | Sele- | Rese- | Dis- | Com- | Ser- | Time | SPC | Reset | | | Plete quired | | Sense | | cted | lected | | | vice | Out | | | P | | W Reset Interrupt — 12 SPC R Connected SPC Xfer in SCSI TC=0 DREG Status P Status (SSTS) RINIT TARG Busy Pro- RST FULL EMPTY | | (INTS) | | | | nected | | | | Error | tion | | | Reset Interrupt — 12 SPC R Connected SPC Xfer in SCSI TC=0 DREG Status P Status (SSTS) | | | W | | L | <u> </u> | <del></del> | | <u> </u> | L | L | <b> </b> | | Status INIT TARG Busy Pro- RST FULL EMPTY gress | | | | | | | | | | | | - | | (SSTS) gress | 12 | | R | | | | | | TC=0 | | | Р | | | | | | INIT | TARG | Busy | l ' | RST | · | FULL | EMPTY | 1 | | | | (3313) | W | | <u> </u> | <u> </u> | gress | I | 1 | l | l | | | | | | " | | | | | | | | | | Table 3.2.2 Internal register bit assignment (Continued) | No. | Name<br>(Abbr.) | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |-----|---------------------|----|--------------|----------------|---------|----------|----------------|----------------|-----------------|-----------------|---| | 13 | SPC Error<br>Status | R | Data<br>SCSI | Error<br> SPC | '0' | 101 | TC P-<br>Error | Phase<br>Error | Short<br>Period | Offset<br>Error | Р | | | (SERR) | W | | | | _ | | | | | _ | | 14 | Temporary | R | | | emporar | y Data ( | [Input: F | | I) | | P | | 1 1 | Register | | Bit7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | (TEMP) | W | | | emporar | y Data ( | Output: | to SCSI | ) | | P | | | | | Bit7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 15 | External | R | | | | | | | | | | | | Buffer | | | | | Exterr | nal Buffe | r | | | P | | | (EXBF) | W | Bit7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 1 | | | | | | | | | | | | ] | | | 16 | Modified | R | | | | | | М | BC | | Р | | | Byte | | | I | 0' | | Bit3 | 2 | 1 | 0 | | | | Counter<br>(MBC) | W | | | | | | | | | _ | | 17 | SPC | R | | | | | | | | | | | | Diagnostic | | | | | | | | | | _ | | | Control (SDGC) | W | Diag<br>REQ | Diag<br>ACK | _ | _ | Diag<br>BSY | Diag<br>MSG | Diag<br>C/D | Diag<br>I/O | _ | #### 3.3 MAJOR OPERATIONS #### 3 3.1 MPU Interface Control Block The MPU interface control block selects a specified internal register and controls a read/write operation. Also, this block generates an interrupt and indicates its cause. (This is done to report the result status of SPC internal operation, and the detection of an error, if encountered.) #### 3.3.2 Bus Phase Control Block The bus phase control block generates a specified bus phase for SCSI and controls its sequence of executions. Also, this block supervises SCSI status, and responds to the bus phase being executed if necessary. #### 3.3.3 Arbitration/Selection Sequence Control Block This sequence control block executes the ARBITRATION phase with the SCSI-specified timing and obtains permission to use the SCSI bus. Then, it carries out the SELECTION/RESELECTION phase and checks the response from the selected/reselected device. Also, this block detects the SELECTION/RESELECTION phase on SCSI, and checks the bus device ID specified in the internal register against that specified on the SCSI data bus. Then, if this block finds that SPC has been selected by another SCSI bus device, it executes the response sequence for the SELECTION/RESELECTION phase. #### 3.3.4 Transfer Sequence Control Block This sequence control block controls the DATA IN/OUT, COMMAND, STATUS, and MESSAGE IN/OUT phases to be executed in SCSI. The following two modes are available for execution of these transfer phases: - (1) Manual transfer mode In manual transfer mode, the MPU interface is used for transferring data and sending/receiving/checking the REO/ACK signals on SCSI. - (2) Hardware transfer mode In hardware transfer mode, SPC controls the SCSI transfer sequence according to the transfer mode and transfer byte count specified in the internal registers, and reports the end result of transfer. Asynchronous and synchronous mode transfer operations can be executed. In the asynchronous mode transfer operation, the REQ and ACK signals are controlled by the interlock protocol. In the synchronous mode transfer operation, a maximum of eight-byte offset is available for the DATA IN/OUT phase. The hardware transfer mode is subdivided into two according to the data routing: - (a) Program transfer mode Data is routed via MPU interface in the following data paths: SCSI ←→ Data buffer register ←→ Data bus lines D7 to D0 and DP. - (b) DMA mode Data is routed using DREQ and DRESP signals for DMA control in the following data paths: SCSI ←→ Data buffer register ←→ Data bus lines HDB7 to HDB0 and HDBP. #### 3.3.5 Transfer Byte Counter Block This counter indicates the transfer byte count used for hardware transfer mode operation in SPC. It consists of 24 bits. Except for execution of a special transfer operation (padding), the transfer byte counter is decresed by one each time one byte of data is transferred on SCSI. The transfer byte counter is also used as a timer for supervising the waiting time for a response to be returned from the selected SCSI bus device during execution of the selection/reselection phase. On the MPU interface, the transfer byte counter is treated as three separate internal registers (TCH, TCM, TCL), each being one byte long. #### 3.3.6 Data Buffer Register Block The data buffer register block is used in execution of a hardware transfer mode operation in SPC. It has a capacity of eight bytes, and operates on the FIFO principle for each byte. In an input operation (from SCSI to SPC), data received from SCSI is loaded into the buffer register. In DMA mode, transfer request signal DREQ is generated to the external buffer memory. Also, in program transfer mode, data can be read out from this buffer register. In an output operation (from SPC to SCSI), data supplied from the MPU interface (program transfer mode) or external buffer memory (DMA mode) is loaded into the buffer register and then sent to SCSI. In this case, a maximum of eight bytes of data is prefetched into SPC. The MPU interface treats 8-byte data buffer register as if it was a one-byte internal register. In an input operation, the byte locations holding valid data are selected in succession for reading out. In an output operation, the empty byte locations are selected in succession for writing in. #### 4.1 BDID REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|----|----|--------------|------------------|----------------|---------------|-----------------|-------------|-----| | R | #7 | #6 | Bit Si<br>#5 | gnifican<br> #4 | t Bus De<br>#3 | vice ID<br>#2 | #1 | #0 | '0' | | W | | | _ | | | SCSI B<br>ID4 | us Devic<br>ID2 | e ID<br>ID1 | _ | ### Write Operation (Bits 2 to 0): The BDID register specifies an SCSI bus device identifier (ID) with a three-bit binary number. This setting must be completed before resetting the SCTL register's bit 7 (Reset & Disable). Bits 2 to 0 are not affected by any resetting except power on reset. #### Read Operation: The BDID register indicates an SCSI physical device address (bus device ID) with each bit. An SCSI physical device address is decoded from the values at bits 2 to 0 specified in a write operation to the BDID register described above. One of the bits is 'one', the others are all 'zeros'. The SCSI bus usage priority is assigned in descending order from bit 7 to bit 0. Using a bus device ID indicated in this register, SPC executes the ARBITRATION phase. Also, if a SELECTION/RESELECTION phase condition occurs in SCSI, the value of the SCSI data bus is checked against the contents of this register to see whether the SPC has been selected/reselected or not. #### 4.2 SCTL REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |--------|-----------------------|---|---|---|---|------------------|--------------------|---------------|---| | R<br>W | Reset<br>&<br>Disable | | | | | Select<br>Enable | Reselect<br>Enable | INT<br>Enable | Р | #### Bit 7: Reset & Disable Bit 7 indicates a reset instruction to the internal registers and control circuits in SPC. When this bit is 1, SPC is reset and logically disconnected from SCSI (put in the disable state). Execution of the hardware reset ( $\overline{RST}$ input = 'L') causes this bit to be 1. To enable the SCSI operation, bit 7 must be made zero to release the disable state. #### Bit 6: Control Reset Bit 6 instructs resetting of the data transfer control circuit in SPC. That is, the data transfer control circuit is reset when this bit is 1. Even if the control reset is executed by this bit during the SPC operates with SCSI, the SPC keeps connected state with SCSI. The reset function of this bit should be used for resetting the data transfer control circuit while it is connected with SCSI. More specifically, it should be used when an error is indicated by bit 1 (SPC Hardware Error) of the INTS register during execution of the SCSI transfer phase or when a timeout occurs before completion of Transfer command execution (supervised by the MPU program). Bit 1 (SPC Hardware Error) of the INTS register and the SERR register are cleared by the reset function of this bit. Note: This reset function initializes the SPC transfer control circuit. So, when the SPC serves as an INTIATOR, the following consideration is required: - Since the REQ signal may be received during resetting, the first byte should be transferred in manual mode after resetting. #### Bit 5: Diagnostic Mode When bit 5 is 1, SPC enters a diagnostic mode and is disconnected from SCSI. A diagnostic mode allows pseudo-execution of the SCSI operation using the SDGC register (to be explained later). #### Bit 4: Arbitration Enable Bit 4 indicates whether the ARBITRATION phase is executable in SCSI or not. 1 ... ARBITRATION phase executable O ... ARBITRATION phase nonexecutable With this bit set to 1, the Select command causes SPC to execute the ARBITRATION phase. And, if the SPC win the arbitration, it executes the SELECTION/RESELECTION phase. With this bit set to 0, the Select command causes SPC to execute the SELECTION phase without the ARBITRATION phase. As long as bit 4 is 0, SPC returns no response to a reselection request from other SCSI bus device. That is, no response is made even if bit 1 (Reselect Enable) of this register is set to 1. Remember that bit 4 must be set correctly before clearing bit 7 (Reset & Disable) of the SCTL register. Note also that this bit should not be changed in other than a diagnostic mode after clearing bit 7 of the SCTL register. #### Bit 3: Parity Enable Bit 3 indicates whether the parity of data received from the SCSI data bus is to be checked or not. 1 ... Parity of the data received from the SCSI data bus is checked. O... Parity of the data received from the SCSI data bus is not checked. Regardless of the value of this bit, the parity of the data to be sent to the SCSI data bus is ensured. Also, the parity of the data on the SPC internal data bus is always checked. While SPC is connected with SCSI, this bit should not be changed. A parity check is carried out in the following cases: (1) When checking an ID value placed on the data bus upon detection of the SELECTION/RESELECTION phase in SCSI: Detection of a parity error causes no response to the SELECTION/RESELECTION phase even if the SCSI bus device ID has been matched. (2) When receiving data from SCSI in an input transfer sequence: If a parity error is detected in a data byte, the relevant parity bit value is corrected and the data byte with the corrected parity is sent to the MPU/DMA data bus. #### Bit 2: Select Enable - 1 ... SPC responds as a TARGET device to the SELECTION phase in SCSI. - 0 ... SPC does not respond to the SELECTION phase in SCSI. Note: If SPC has already detected the SELECTION phase during an attempt to set this bit to 0, SPC responds to the SELECTION phase as a TARGET device. In this case, the 0 setting is effective for the subsequent SELECTION phase (with no response). #### Bit 1: Reselect Enable - 1 ... SPC responds as an INITIATOR to the RESELECTION phase in SCSI. - 0 ... SPC does not respond to the RESELECTION phase in SCSI. Note: If SPC has already detected the RESELECTION phase during an attempt to set this bit to 0, SPC responds to the RESELECTION phase as an INITIATOR. In this case, the 0 setting is effective for the subsequent RESELECTION phase (with no response). #### Bit 0: Interrupt Enable Bit 0 serves as a mask for enabling/disabling an interrupt (INTR) output from the SPC. - 1 ... Interrupt enabled - 0 ... Interrupt disabled An interrupt due to a RESET condition detected in SCSI cannot be masked. Regardless of the value of this bit, an interrupt event is always indicated in the INTS register. This makes available poll-mode control in an interrupt disabled state. #### 4.3 SCMD REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |--------|----|---------|-----|------------|--------|--------------|---------|----------------|---| | R<br>/ | Со | mmand C | ode | RST<br>Out | Inter- | Trans<br>PRG | fer Mod | ifier<br>Term. | р | | W | | | | | Xfer | Xfer | | Mode | | #### 4.3.1 Register Functions The SCMD register is used for giving a command to SPC. Writing into this register causes SPC to initiate the command processing specified at bits 7 to 5. #### Bit 7 to 5: Command Code | Bit | 7 | 6 | 5 | Command | |-----|---|---|---|----------------| | | 0 | 0 | 0 | Bus Release | | | 0 | 0 | 1 | Select | | | 0 | 1 | 0 | Reset ATN | | | 0 | 1 | 1 | Set ATN | | | 1 | 0 | 0 | Transfer | | | 1 | 0 | 1 | Transfer Pause | | | 1 | 1 | 0 | Reset ACK/REQ | | | 1 | 1 | 1 | Set ACK/REQ | #### Bit 4: RST Out If bit 7 (Reset & Disable) of the SCTL register is 0, setting 1 in bit 4 of this SCMD register sends the RST signal (RSTO pin) to SCSI. When bit 4 is set to 1, a command being executed or waiting for execution in SPC is cleared and all signals to SCSI other than RST are deactivated. To ensure for the SCSI timing requirements, MPU must maintain this bit at 1 for more than 25 microseconds. Note: If the RST signal (RSTI pin) is received from SCSI with this bit set to 0, the operation sequence is as follows: - · A command being executed or waiting for execution in the SPC is cleared. - All signals to the SCSI are deactivated. - An interrupt condition (non-maskable) is generated. Whenever bit 7 (Reset & Disable) of the SCTL register is 0, the SPC always accepts the RST signal from the SCSI. #### Bit 3: Intercept Transfer Bit 3 specifies the special data transfer mode. It is valid only when SPC serves as an INITIATOR. This bit should be set to 1 together with the Set ATN, Set ACK/REQ, or Bus Release command (Bus Release command has no effect when SPC has been connected with SCSI as an INITIATOR). And, this bit should be reset together with the Reset ACK/REQ command. (When two or more bytes are transferred using the Set ACK/REQ and Reset ACK/REQ commands, this bit must be reset on issuance of the Reset ACK/REQ command for the last byte.) With bit 3 of SCMD register set to 1, executing manual transfer (MPUcontrolled transfer using the Set ACK/REQ and Reset ACK/REQ commands) does not change the contents of the eight-byte data buffer register in SPC. Therefore, if a TARGET changes bus phase to such as MESSAGE IN during execution of the DATA OUT phase, this intercept transfer mode makes it possible to optionally restart the DATA OUT phase at the end of the interrupting phase. The phase change during transfer execution is reported by a 'service required' interrupt. To execute this intercept transfer mode, bit 3 of SCMD register must be set to 1 prior to the resetting of an interrupt (an interrupt must be reset after bit 3 is set to 1). Even when not using the intercept transfer mode, bit 3 may be specified for resetting a 'service required' interrupt. In this case, bit 3 must be set/reset together with the Bus Release command. For more details, see the description of bit 3 (Service Required) of the INTS register. #### Bits 2 to 0: Transfer Modifier Bits 2 to 0 are used as a field for specifying the execution mode of the information transfer phase. A value must be set in this field when the Transfer command is issued. If any of the following commands are issued during execution of the Transfer command, this field's value must not be changed: - Set ATN - Transfer Pause - Reset ACK/REQ #### Bit 2: Program Transfer - 1 ... Data is transferred between the MPU and the data buffer register in SPC. - 0 ... Data is transferred in the DMA mode in which the SPC signals a transfer request to the external buffer memory. #### Bit 1: Unused Bit 1 must always be set to 0. ### Bit O: Termination Mode Bit O provides different functions depending on the SPC operation mode. When SPC serves as an INITIATOR, bit O specifies the following operations: - 1 ... Even after the transfer byte counter reaches 0 during execution of the Transfer command, data transfer is continued if the REQ signal arrives from a TARGET in the same phase. if an output operation is in progress, all 0 bits (with a parity bit set to 1) are transmitted as data. During an input operation, the received data is ignored. But parity is checked if it is enabled (Parity Enable). The above data transfer is referred to as padding transfer, which is effective only when the DATA IN or DATA OUT phase is executed. Padding transfer is executed only within SPC, and a transfer request is not signalled to the external buffer memory even if the DMA transfer mode is specified. Padding transfer is maintained until a TARGET changes the bus phase. In the padding transfer mode, if the Transfer command is issued with the initial value of the transfer byte counter set to 0, execution of padding transfer is started with the first byte. To carry out an output operation in this case, the TEMP register must be set to X'00' prior to issuance of the Transfer command. - 0 ... Transfer command execution terminates when the transfer byte counter reaches 0. The Transfer command must be reissued for receiving the next REQ signal from a TARGET. When SPC serves as a TARGET, bit O specifies the following operations: - 1 ... If a parity error is detected in the received data during execution of the Transfer command for input, the current transfer sequence is immediately stopped to terminate Transfer command execution. - 0 ... Even if a parity error is detected in the received data during execution of the Transfer command for input, the current transfer sequence is continued until the transfer byte counter reaches 0. #### 4.3.2 Command Functions - (1) Bus Release command When SPC acts as a TARGET role, the Bus Release command instructs a transition to the BUS FREE phase. During execution of the information transfer phase, the Transfer Pause command must be issued to halt the data transfer operation prior to this command. Otherwise, the SCSI bus sequence is not ensured. The Bus Release command may also be used to cancel the Select command waiting for the bus to become free. Note that the Bus Release command is ignored if SPC has already started the ARBITRATION or SELECTION phase. - (2) Select command The select command requests the SELECTION/RESELECTION phase to be started. It shall be issued only when the SPC is not connected with SCSI. When the SPC receives this command, it carries out the following operation upon detection of the BUS FREE phase is SCSI. - a. When bit 4 (Arbitration Enable) of the SCTL register is set to 1: After the BUS FREE phase has been detected, SPC executes the ARBITRATION phase to try to obtain bus usage permission. If the SPC has lost the arbitration, the Select command terminates its execution. If the SPC has won the arbitration, SPC executes the SELECTION or RESELECTION phase. The SELECTION phase is executed when bit 0 (I/O Out) of the PCTL register is set to 0, and the RESELECTION phase is executed when it is set to 1. - b. When bit 4 (Arbitration Enable) of the SCTL register is set to 0: After the BUS FREE phase has been detected, SPC executes the SELECTION phase. Before this command is issued, the following settings must be made in either of the above cases: - a. PCTL register - Specify the phase to be executed at bit O(I/O Out). - 0 ... SELECTION phase to be executed - 1 ... RESELECTION phase to be executed Note that whenever bit 4 (Arbitration Enable) of the SCTL register is set to 0, the SELECTION phase is executed regardless a value of bit 0 (I/O Out) of the PCTL register. - b. Set ATN command Issue the Set ATN command if it is required to assert an ATN signal at the SELECTION phase. - c. TEMP register In the TEMP register, specify a value to be sent to the SCSI data bus during execution of the SELECTION/RESELECTION phase. - d. TCH and TCM registers Specify a response (BSY signal) waiting supervisory time for execution of the SELECTION/RESELECTION phase. The supervisory time $T_{SL}$ should be calculated as follows: Assuming that the value of TCH and TCM is N (MSB: TCH, LSB: TCM); When N does not equal 0, $T_{SL} = (N \times 256 + 15) \times T_{CLF} \times 2$ . When N equals 0, $T_{SL} = infinite$ . Where, $T_{CLF}$ is a cycle time of the clock signal supplied to the $\overline{CLK}$ pin of SPC. e. TCL register Specify a period of time (TWAIT) from the moment when both BSY and SEL signals become inactive on SCSI upon detection of the BUS FREE phase to the moment when SPC initiates the ARBITRATION/SELECTION phase. Parameters (X'00') to (X'0F') can be specified in the TCL register. The average TWAIT value can be derived using the following equation: $T_{WAIT} = [(TCL + 6] \times T_{CLF} [(TCL) + 7] \times T_{CLF}]$ Where, (TCL): A set value in the TCL register. $T_{CLF}$ : A cycle time of the clock signal supplied to the $\overline{CLK}$ pin of SPC. Table 4.3.1 lists the values recommended to be set in the TCL register. Table 4.3.1 Values recommended to be set in TCL register for use of Select command | T <sub>CLF</sub> (ns) | TCL | T <sub>WAIT</sub> (average) (ns) | |-----------------------|--------------------|----------------------------------| | 125 - 180 | <sup>(04)</sup> 16 | 1,250 - 1,980 | | 140 - 200 | <sup>(03)</sup> 16 | 1,260 - 2,000 | In ARBITRATION phase execution by the Select command, the bus device identifier (ID) which is sent to the SCSI data bus is the value specified in the BDID register. The following equation can be used to obtain the period of time (TARB) required from the moment when the arbitration is started (BSY signal assertion) to the moment when the bus usage priority is examined: TARB = 32 x T<sub>CLF</sub> Where, T<sub>CLF</sub> indicates a cycle time of the clock signal supplied to the $\overline{\text{CLK}}$ pin of SPC. After SELECTION/RESELECTION phase execution is started, a time-out interrupt occurs if no response is acknowledged within the supervisory time specified in the TCH and TCM registeres. When a time-out interrupt occurs, the SPC holds the current execution state of SELECTION/RESELECTION phase for SCSI. However, until the time-out interrupt condition is reset, SPC executes no operation to the response from the bus device being selected. Either of the following procedures can be used for a time-out interrupt: a. Restart of SELECTION/RESELECTION phase After specifying a new supervisory time in the TCH, TCM and TCL registers, reset the time-out interrupt condition. Then, SPC will restart the SELECTION/RESELECTION phase in progress. At this time, changing the TEMP register contents can alter the value being sent to the SCSI data bus. New supervisory time TsL' is expressed as follows: Assuming TCH, TCM and TCL value to be N' (MSB: TCH, LSB: TCL); $T_{SL}' = N' \times T_{CLF} \times 2 (N' \neq 0)$ Where, $T_{CLF}$ indicates a cycle time of the clock signal supplied to $\overline{CLK}$ pin of the SPC. b. Termination of SELECTION/RESELECTION phase When a time-out interrupt occurs, the values of TCH, TCM and TCL registers are 0. Resetting the time-out interrupt condition in this state causes SPC to deactivate all signals to SCSI and terminate the SELECTION/RESELECTION phase unless the BSY signal is returned. If the BSY signal is returned when the interrupt condition is being reset, then SPC executes a normal sequence to complete the Select command. To reset a time-out interrupt condition, set bit 2 of the INTS register to 1. If the Select command has been issued with initial setting of 0 for TCH and TCM registers, the time-out interrupt does not occur. However, the above time-out interrupt resetting procedure must be carried out to terminate the SELECTION/RESELECTION phase in progress. If SPC recognizes a response from the selected/reselected device during SELECTION/RESELECTION phase execution, SPC executes an interface sequence to serve as an INITIATOR (at SELECTION phase) or TARGET (at RESELECTION phase), then SPC is connected with SCSI as a relevant role. When the Select command is issued, the SPC status is indicated in the SSTS register. Figure 4.3.1 shows the status transitions. Fig. 4.3.1 Status transitions in Select command execution - \*1: Check the SPC status after the elapsed time (shown below) following issuance of the Select command: - (1) If Arbitration Enable bit is set to 0 the minimum waiting time is $22 \times (Clock\ cycle:\ T_{Cl}\ F)$ - (2) If Arbitration Enable bit is set to 1 the minimum waiting time is (55 + Set value in TCL) x (Clock cycle: T<sub>CLF</sub>) - \*2: The Select command waiting for BUS FREE phase can be canceled using the Bus Release command. However, if the bus becomes free simultaneously with issuance of the Bus Release command, the Select command remains valid to execute the ARBITRATION and SELECTION/RESELECTION phases. The MPU program must make sure that the Select command has been canceled after more than four clock cycles passed since the Bus Release command (write to SCMD register) was issued. - \*3: If the SPC lost the arbitration, the Select command terminates automatically (a command complete interrupt does not occur). In this case, note that the TCL register contents are unpredictable. When issuing the Select command again, be sure to specify the relevant value (see (2)-e, TCL register in Section 4.3.2) again in the TCL register. #### (3) Set ATN command The Set ATN command is valid only when the SPC will act as an INITIATOR role. If this command is issued prior to the Select command, the ATN signal is sent to SCSI at SELECTION phase execution. If the Set ATN command is issued while the SPC is connected with SCSI as an INITIATOR, the ATN signal is sent to SCSI immediately. When the parity checking for the SCSI data bus is enabled and SPC detects a parity error in the data received from SCSI (during execution of the input transfer operation in hardware transfer mode), the ATN signal is sent to SCSI regardless of the Set ATN command. (See Figure 4.3.2) The assertion of ATN signal is retained until the condition described on item (4) Reset ATN command in this section is satisfied. However, the ATN signaling condition held in SPC, by the Set ATN command issued prior to the Select command, is cleared, if: a. the Select command is canceled by the Bus Release command, or b. a selected/reselected interrupt occurs before execution of the SELECTION phase. Fig. 4.3.2 ATN signal generation in data transfer #### (4) Reset ATN command The Reset ATN command is used to reset the ATN signal being sent to SCSI. If SPC generates an ATN signal (due to a parity error in the received data) during execution of the hardware transfer mode operation, do not issue this command to reset the ATN signal until execution of the current Transfer command has completed. Also, to reset the ATN signal in manual transfer mode, execute the Reset ATN command before the ACK signal is sent to SCSI. In the following cases, SPC automatically resets the ATN signal without the Reset ATN command: a. On occurrence of a disconnected interrupt. b. On sending the last byte during execution of the MESSAGE OUT phase in hardware transfer mode. (See Figure 4.3.3.) Fig. 4.3.3 ATN signal resetting in MESSAGE OUT phase ### (5) Transfer command The transfer command executes the following information transfer phases in SCSI: - DATA IN/OUT phase - STATUS phase - · COMMAND phase - MESSAGE IN/OUT phase The transfer operation initiated by this command is referred to as a hardware transfer operation, the sequence of which is controlled by SPC. Before issuing the Transfer command, be sure to set up the following: - a. Transfer byte counters (TCH, TCM, TCL) Set the byte count of the data to be transferred. (MSB: TCH, LSB: TCL) - b. Bits 2 to 0 of the PCTL register Set a pattern indicating the phase to be executed. - c. TMOD register Set detailed transfer mode. When SPC serves as a TARGET, it executes the information transfer phase specified in the PCTL register and terminates the Transfer command when any of the following conditions is encountered: - a. End of transferring data of the byte count specified in the transfer byte counter. - b. Receipt of the Transfer Pause command. - c. Detection of a parity error in the received data during an input operation with bit 0 (Termination Mode) of the SCMD register set to 1. (When the parity checking is enabled) When SPC serves as an INITIATOR, it starts the transfer operation as follows: - a. If the REQ signal is received before the Transfer command is issued, SPC compares the phase requested by the SCSI with that specified in the PCTL register at receipt of this command. Then, if they match, SPC starts the transfer operation. - b. If the REQ signal has not been received when the Transfer command is issued, SPC makes this command wait for execution. Then, if the phase specified in the PCTL register matches that requested by SCSI on receipt of the REQ signal, SPC starts the transfer operation. In the above phase comparison, if a phase mismatch occurs, the Transfer command is nullified, then SPC generates a service required interrupt. On occurrence of this interrupt, check the PSNS register for the phase requested by SCSI, and issue the Transfer command again or carry out manual transfer. When SPC serves as an INITIATOR, Transfer command execution terminates when any of the following conditions is encountered: - a. In other than the padding transfer mode, Transfer command execution terminates when the transfer of data of the byte count specified in the transfer byte counter is completed, or when another information transfer phase is requested by the TARGET. - b. In the padding transfer mode, Transfer command execution terminates when another information transfer phase is requested by the TARGET. - c. Transfer command execution terminates when disconnected interrupt occurs. ## (6) Transfer Pause command The Transfer Pause command prematurely halts a hardware transfer operation initiated by the Transfer command when SPC serves as a TARGET. Note that the Transfer Pause command cannot be used when SPC serves as an INITIATOR. On receipt of this command, SPC performs the following: - a. Stops sending a new REQ signal to SCSI, in an input operation. - b. Stops sending a transfer request (DREQ) signal to the external buffer memory, in a DMA mode output operation. Note: For an output operation in program transfer mode, a write to the data buffer register is not allowed after this command has been issued. Then, the hardware transfer operation terminates when the internal data buffer register in SPC becomes empty. ## (7) Set ACK/REQ command The Set ACK/REQ command is used to set ACK or REQ signals for SCSI during execution of manual transfer. When SPC acts as an INITIATOR, this command causes the ACK signal to be sent. When SPC acts as a TARGET, it causes the REQ signal to be sent. In manual transfer mode, data is transferred via the TEMP register. In this case, the pattern (kind) of the information transfer phase to be executed must be preset at bits 2 to 0 of the PCTL register. During execution of manual transfer, the transfer byte counter remains unchanged. Figures 4.3.4 and 4.3.5 show the manual transfer procedures. ## (8) Reset ACK/REQ command The Reset ACK/REQ command is used to reset the ACK or REQ signals for SCSI. When SPC acts as an INITIATOR, this command resets the ACK signal. When SPC acts as a TARGET, it resets the REQ signal. Use this command in execution of manual transfer. See Figure 4.3.4 and 4.3.5 for the manual transfer procedures. Also, when SPC serves as an INITIATOR, the Reset ACK/REQ command must be issued to reset the ACK signal for the last byte in the MESSAGE IN phase of the hardware transfer mode. In the MESSAGE IN phase, the end of the Transfer command is reported with the ACK signal for the last byte being asserted. The MPU program checks the validity of the received message first, then issues this command. In this case, the ATN signal, if necessary, may be sent out using the Set ATN command prior to this command. Fig. 4.3.4 Manual transfer procedure (SPC serving as a TARGET) Fig. 4.3.5 Manual transfer procedure (SPC serving as an INITIATOR) ### 4.3.3 Command Termination Report ### (1) Immediate commands The followings are immediate type commands which terminate operations immediately after being issued. For these commands, SPC does not report termination. - Set ATN - Reset ATN - Set ACK/REQ - Reset ACK/REO ## (2) Interrupt commands For the following commands, an interrupt occurs at the end of execution. The interrupt cause is indicated in the INTS register. - Select - Transfer ## (3) Non-interrupt commands The following commands terminate with different timings depending on the SPC operation being executed. Check the termination status according to the status information in the SSTS register. | | Termination status (SSTS register) | | | | | | | | | |----------------|---------------------------------------------|---|---|---|--|--|--|--|--| | | Bit 7 6 5 4 INIT TARG SPC Busy Xfer in Prg. | | | | | | | | | | Transfer Pause | 0 | 1 | 0 | 0 | | | | | | | Bus Release *1 | 0 | 0 | 0 | 0 | | | | | | <sup>\*1:</sup> If a selected/reselected interrupt condition is detected immediately after termination of the Bus Release command, an interrupt occurs and either the INIT or TARG bit is set. ### 4.3.4 Command Issuance Timing Issuance of a command requires a write to the SCMD register. SPC synchronizes a write to the SCMD register with a clock supplied from the $\overline{\text{CLK}}$ pin, and then starts executing the command specified at bits 7 to 5. Figure 4.3.6 shows the command execution timing. When issuing commands successively, leave an interval between them for more than the sync-loss period (four clock cycles) in SPC. Fig. 4.3.6 Command execution timing # 4.4 TMOD REGISTER | | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |---|-----|---------------|--------|---------|--------|---|------------------|-----|-----|---| | | R/W | Sync.<br>Xfer | MAX. T | ransfer | Offset | | ransfer<br>eriod | 101 | '0' | Р | | ١ | | | 4 | 2 | 1 | 2 | 1 | | | | ## 4.4.1 Register Functions ## Bit 7: Synchronous Transfer - 1 .. Indicates that the DATA IN/OUT phase is executed in synchronous transfer mode. The COMMAND, STATUS, and MESSAGE IN/OUT phases are executed in asynchronous transfer mode disregarding the setting at this bit. - 0 .. Indicates that the DATA IN/OUT phase is executed in asynchronous transfer mode. # Bits 6 to 4: Maximum Transfer Offset Bits 6 to 4 indicate a maximum value of the REQ/ACK offset to be used in synchronous transfer mode. | Bit | 6 | Bit 5 | Bit 4 | Maximum offset value | |-----|---|-------|-------|----------------------| | 0 | 1 | 0 | 0 | 8 | | 0 - | 1 | 0 - 1 | 1 - 1 | 1 - 7 | When SPC serves as a TARGET, it sends the REQ signal in advance within the specified maximum offset value. When SPC serves as an INITIATOR, it can receive the REQ signal and input data within the specified maximum offset value. If the maximum offset value is exceeded in reception of the REQ signal, an error condition is detected at bit 0 (Transfer Offset Error) of the SERR register. # Bits 3 and 2: Transfer Period Bits 3 and 2 indicate a parameter for determining the minimum repeat cycle of the REQ and ACK signals in synchronous transfer mode. Specify a period between the trailing edge of the REQ (ACK) signal and the leading edge of the next REQ (ACK) signal in multiples of a clock signal cycle ( $T_{CLF}$ ) supplying at the $\overline{CLK}$ pin of SPC. Figure 4.4.1 shows an example of transfer period setting. In synchronous transfer mode, the REQ (ACK) signal pulse width (Typical) equals a cycle of the clock signal ( $T_{CLF}$ ) supplied to the $\overline{CLK}$ pin. | | | | Setting examples; Maximum transfer speeds | | | | | |-------|-------|---|-------------------------------------------|---------------------------|---------------------------|--|--| | Bit 3 | Bit 2 | n | T <sub>CLF</sub> = 125 ns | T <sub>CLF</sub> = 136 ns | T <sub>CLF</sub> = 166 ns | | | | 0 | 0 | 1 | 4.00 MBPS | 3.68 MBPS | 3.01 MBPS | | | | 0 | 1 | 2 | 2.67 | 2.45 | 2.01 | | | | 1 | 0 | 3 | 2.00 | 1.84 | 1.51 | | | | 1 | 1 | 4 | 1.60 | 1.47 | 1.21 | | | Fig. 4.4.1 Transfer period setting # 4.4.2 Transfer Mode Setting Timing The TMOD register value determines the way the DATA IN/OUT phase is executed. When SPC serves as a TARGET, specify the DATA IN/OUT phase (C/D, MSG = 00) in the PCTL register. And, before issuing the Transfer command, be sure to complete TMOD register setting. When SPC acts as an INITIATOR, be sure to specify a correct value before the target initiates the DATA IN/OUT phase. A TARGET's phase changing time and the period from it until transmission of the first REQ signal are unpredictable; therefore, set the transfer mode with the following timing: ## (1) After completion of SELECTION phase - a. Before issuing the Transfer command for execution of the COMMAND phase, or - b. Before resetting the ACK signal for the last byte in the MESSAGE IN phase (before issuing the Reset ACK command) if a SYNCHRONOUS DATA TRANSFER REQUEST message is transmitted at the end of the command phase. ### (2) After reselected interrupt a. Before issuing the Reset ACK command in the MESSAGE IN phase (IDENTIFY). ## 4.5 PCTL REGISTER | ОР | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |-----|---------------------------------|---|---|----|---|------------|------------|------------|---| | R/W | Bus Free<br>Interrupt<br>Enable | | | 01 | | MSG<br>Out | C/D<br>Out | I/O<br>Out | Р | ## Bit 7: Bus Free Interrupt Enable With bit 7 set to 1, detection of the BUS FREE phase on the SCSI causes a disconnected interrupt to occur. To prevent an undesired interrupt occurring, be sure to set bit 7 to 0 when: - · Issuing the Select command, or - Resetting a 'disconnected' interrupt. Bit 2: MSG Out Bit 1: C/D Out Bit 0: I/O Out When SPC serves as a TARGET, specify the information transfer phase to be executed in SCSI. These bit values are sent to SCSI as MSG, C/D and I/O signals. When SPC acts as an INITIATOR, specify the pattern indicating the transfer phase to be executed. Before executing the transfer operation, the specified transfer phase pattern is compared with a bus phase actually requested by the TARGET. Then, if they match, the transfer operation is initiated. Table 4.5.1 shows how to set a transfer phase. Use bit 0 (I/O Out) to specify the phase to be executed with the Select command. See 4.3.2 (2) - Select command for details. Table 4.5.1 Transfer phase setting | Bit 2<br>MSG Out | Bit 1<br>C/D Out | Bit 0<br>I/O Out | SCSI transfer phase | |------------------|------------------|------------------|---------------------| | 0 | 0 | 0 | Data Out | | 0 | 0 | 1 | Data In | | 0 | 1 | 0 | Command | | 0 | 1 | 1 | Status | | 1 | 0 | 0 | Unused | | 1 | 0 | 1 | Unused | | 1 | 1 | 0 | Message Out | | 1 | 1 | 1 | Message IN | ## 4.6 DATA BUFFER REGISTER (DREG) | | OP | 7 | 6 | 5 | 4 | 3 | 2. | 1 | 0 | Р | | |---|-----|---------------------------------------|-----|---|---|---|----|---|---|---|--| | Ī | R/W | Internal Data Register (8 Bytes FIFO) | | | | | | | | | | | | · | Bit 7 | , 6 | 5 | 4 | 3 | 2 | Ì | 0 | P | | SPC's internal data buffer register consists of eight bytes and operates on the FIFO principle. When executing the Transfer command in program transfer mode, MPU transfers data using this register. Figure 4.6.1 shows the DREG access procedure to be taken in program transfer mode. A write to/read from this register is performed on the FIFO principle. Therefore, never repeat accessing more than the number of times required. Fig. 4.6.1 DREG access procedure in program transfer mode ### 4.7 TEMP REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |-----|-------|---|---------|--------|---------|--------|-------|-----|---| | R | D:+ 7 | I | emporar | y Data | (Input: | From | SCSI) | ۱ ۵ | - | | | Bit 7 | 6 | 5 | 4 | 3 | | 11 | U | Р | | l W | | Ţ | emporar | y Data | (Output | : To S | CSI) | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | P | The TEMP register is used for controlling the SCSI data bus except when hardware transfer is executed. It consists of two bytes, each of which is dedicated exclusively to receiving/sending data. ## (1) Data receiving element (read only) - a. When a SELECTION/RESELECTION phase is detected in SCSI, the contents on the SCSI data bus are saved in the TEMP register. If a selected/reselected interrupt occurs, a bus device can be identified by the TEMP register contents. - b. For a manual transfer input operation, the contents on the SCSI data bus are saved in the timing sequence shown in Figure 4.7.1 Fir. 4.7.1 Data bus save in manual transfer input operation ## (2) Data sending element (write only) - Before issuing the Select command, set the contents to be sent to the SCSI data bus in the SELECTION/RESELECTION phase. - 2) For a manual transfer output operation, set the data to be sent out. ### 4.8 TRANSFER BYTE COUNTER (TCH, TCM, TCL) | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | | | |-----|--------|----------------------------------|------|---------|---------|---------|----|----|---|--|--| | R/W | | | TCH: | Transfe | r Count | er (MSB | ) | | | | | | İ | Bit 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Р | | | | R/W | | TCM: Transfer Counter (2nd Byte) | | | | | | | | | | | | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | P | | | | R/W | | | TCL: | Transfe | r Count | er (LSB | ) | | | | | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | P | | | The transfer byte counter consists of three bytes and functions as a down counter. In execution of a hardware transfer operation, it is decreased by one each time one byte of data is transferred over SCSI. It indicates the remaining byte count of data to be transferred. In the Select command execution, this counter operates as a response waiting time supervisory timer and sequence control counter. See 4.3.2 (2) - Select command and (5) - Transfer command for transfer byte counter initialization. While the transfer byte counter is operating, do not carry out a read/write. ### 4.9 PSNS REGISTER | OP | 7. | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|-----|-----|-----|-----|-----|-----|-----|-----|---| | R | REQ | ACK | ATN | SEL | BSY | MSG | C/D | I/0 | Р | When bit 5 (Diagnostic Mode) of the SCTL register is set to 0, the PSNS register indicates the control signal status on SCSI (input signals to SPC). - SPC input pins - | Bit | 7 | REQ | REQI | |-----|---|-----|------| | | 6 | ACK | ACKI | | | 5 | ATN | ATNI | | | 4 | SEL | SELI | | | 3 | BSY | BSYI | | | 2 | MSG | MSGI | | | 1 | C/D | C/DI | | | 0 | I/0 | I/OI | When bit 5 (diagnostic Mode) of the SCTL register is set to 1, the PSNS register indicates the status of control signals sent from SPC to SCSI. In the SCSI pseudo operation using the SDGC register, the PSNS register can be used to check the SCSI control signal status. A read from this register is allowed at any time regardless of the SPC condition. Bit 5 (ATN) of this register indicates the ATN signal status on SCSI: When SPC serves as a TARGET, receipt of the ATN signal is indicated in this register but does not have any effect on other operations. The MPU program examines the ATN signal status at the following times in sequence and responds to the ATTENTION condition from SCSI: - (1) When a selected interrupt occurs - (2) When the RESELECTION phase has completed - (3) When the Transfer command has been completed - (4) During execution of the Transfer command When the ATN signal is detected, the Transfer Pause command can halt the transfer operation for transition to the MESSAGE OUT phase. ## (5) During execution of manual transfer ### 4.10 SSTS REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|---------------|---|---|---------------------|---|------|--------------|-----------------|---| | R | Conne<br>INIT | | | Xfer in<br>Progress | | TC=0 | DREG<br>FULL | Status<br>EMPTY | Р | ## 4.10.1 Register Functions The SSTS register indicates the SPC internal status, which can be read out at any time. ## Bit 7 and 6: Connected (INIT, TARG) These bits indicate the Connecting status between the SPC and SCSI. | Bit 7: INIT | Bit 6: TARG | State | |-------------|-------------|----------------------------------------------------------------------| | 0 | 0 | Not connected with SCSI. | | 1 | 0 | SPC serves as an INITIATOR: | | | | <ul> <li>During execution of the SELECTION phase and</li> </ul> | | | | after its completion. | | | | After a reselected interrupt | | 0 | 1 | SPC serves as a TARGET: | | 1 | | <ul> <li>During execution of the RESELECTION phase and at</li> </ul> | | | · | its completion. | | | , | After a selected interrupt | | 1 | 1 | Undefined | ## Bit 5: SPC Busy Bit 5 indicates that a command is being executed or is waiting to be executed. ## Bit 4: Transfer in Progress Bit 4 indicates that a hardware transfer operation is being executed or the SCSI is requesting information transfer phase. ## Bit 3: SCSI Reset In Bit 3 indicates the RST signal status on SCSI (input signal to the RSTI pin of SPC). # Bit 2: TC = 0 (Transfer Counter Zero) Bit 2 indicates that the transfer byte counter (TCH, TCM, TCL) has reached 0. ## Bits 1 and 0: DREG Status (Full, Empty) These bits indicate the status of the internal data buffer register. When executing a hardware transfer operation in program transfer mode, determine the data buffer register access timing by using these bit values. | Bit 1: FULL | Bit O: EMPTY | Data buffer register status | |-------------|--------------|-----------------------------------------------| | 0 | 0 | Holds 1 to 7 bytes of data. | | 0 | 1 | Empty. | | 1 | 0 | Holds 8 bytes of data, leaving no free space. | | 1 | 1 | Undefined | ## 4.10.2 SPC Status SPC status is represented by combinations of status bits 7 to 4 of this register. Table 4.10.1 lists the combinations of these bits and SPC status. Table 4.10.1 SPC operating status indications | | SSTS re | gister | | | |----------------|----------------|-----------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 7:<br>INIT | Bit 6:<br>TARG | Bit 5:<br>SPC<br>Busy | Bit 4:<br>Xfer in<br>Progress | SPC operating status | | 0 | 0 | 0 | 0 | SPC is not connected with SCSI. SPC does not hold a command waiting to be execution. | | 0 | 0 | 1 | 0 | SPC is not connected with SCSI. But SPC holds the Select command, which is waiting for BUS FREE phase. Or it is executing ARBITRATION phase. | | 0 | 1 | 0 | 0 | SPC serves as a TARGET. No operation is being executed in SCSI, or manual transfer is being executed. | | 0 | 1 | 1 | 0 | SPC is executing RESELECTION phase on SCSI. | | 0 | 1 | 1 | 1 | SPC serves as a TARGET. Hardware transfer operation (Transfer command) is being executed. | | 1 | 0 | 0 | 0 | SPC serves as an INITIATOR. No operation is being executed in SCSI, or manual transfer is being executed. | | 1 | 0 | 0 | 1 | SPC serves as an INITIATOR. Although SPC has received a REQ signal from SCSI, it is not ready to start transfer operation because no Transfer command has been issued or transfer phase does not match. | | 1 | 0 | 1 | 0 | SPC is executing the SELECTION phase on SCSI. | | 1 | 0 | 1 | 1 | SPC serves as an INITIATOR. Hardware<br>transfer operation (Transfer command) is<br>being executed. | #### 4.11 INTS REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|---------------|-----------------|-------------------|---------------------|---------------------|-------------|--------------------------|-------------------------|---| | R | Sele-<br>cted | Resele-<br>cted | Dis-<br>Connected | Command<br>Complete | Service<br>Required | Time<br>Out | SPC<br>Hardware<br>Error | Reset<br>Condi-<br>tion | Р | | W | | | | Reset Int | errupt | | | | - | ### 4.11.1 Register Functions The INTS register is used to indicate the cause of an interrupt and reset it. An interrupt issued by SPC (INTR pin) can be masked by bit 0 (INT Enable) of the SCTL register (except an interrupt whose cause is indicated at bit 0 [RESET condition]). To clear an interrupt, set 1 at the corresponding bit position in this register. Note that only the interrupt condition specified by 1 is reset. The bit positions having 0s remain unchanged (corresponding interrupt conditions are maintained). In this register, two or more interrupts may be reset at the same time. ### 4.11.2 Interrupt Processing ### (1) Selected interrupt (Bit 7) Bit 7 indicates that SELECTION phase in SCSI has resulted in SPC being selected from another bus device (INITIATOR). When the SELECTION phase is detected, SPC checks the contents of the SCSI data bus. If the following conditions are satisfied, SPC executes a response sequence on SCSI, then generate a selected interrupt. - a. The ID specified in the BDID register is selected. - b. There or more bits not including the parity bit are not set to 1. - c. When the parity checking is enabled, a parity bit value is correct. In the SELECTION phase, the TEMP register holds the value of SCSI data bus. SPC serves as a TARGET from when this interrupt occurs until when the Bus Release command is issued or the RESET condition is detected in SCSI. During this period, SPC asserts BSY signal to SCSI. Before issuing the Bus Release command, be sure to reset the cause of this interrupt. ### (2) Reselected interrupt (Bit 6) Bit 6 indicates that RESELECTION phase in SCSI has resulted in SPC being reselected from another bus device (TARGET). When the RESELECTION phase is detected, SPC checks the contents of the SCSI data bus. If the following conditions are satisfied, SPC executes a response sequence on SCSI, then generate a reselected interrupt. - a. The ID specified in the BDID register is selected. - b. Only two bits not including the parity bit are set to 1. - c. When the parity checking is enabled, a parity bit value is correct. In the RESELECTION phase, the TEMP register holds the value of the SCSI data bus. SPC serves as an INITIATOR from when this interrupt occurs until when the disconnected interrupt occurs or the RESET condition is detected in SCSI. Before starting the transfer operation in SCSI, be sure to reset the cause of this interrupt. If the disconnected interrupt is indicated together with the reselected interrupt, reset both of these interrupts simultaneously. ## (3) Disconnected interrupt (Bit 5) Bit 5 indicates that the BUS FREE phase has been detected in SCSI when bit 7 (Bus Free Interrupt Enable) the PCTL register is set to 1. Also, when SPC serves as on INITIATOR, bit 5 indicates transition to the BUS FREE phase in SCSI. After this interrupt condition has occurred, the next SELECTION/RESELECTION phase may be executed in SCSI. But, SPC does not respond to SCSI until this interrupt condition is reset. If the disconnected interrupt condition is detected during hardware transfer (Transfer command) execution with SPC serving as an INITIATOR, the SCSI operation stops but the SPC internal transfer sequence continues until one of the following events is encountered: - a. The internal data buffer register becomes empty in an input operation. - b. The data prefetch sequence to the internal data buffer register is completed in an output operation. When a disconnected interrupt occurs, check the SSTS register to confirm if the transfer operation has been completed. ### (4) Command complete interrupt (Bit 4) Bit 4 indicates that the Select command/Transfer command operation has been completed. - a. Completion of Select command This interrupt indicates that SPC has acknowledged a response (BSY signal) from the selected bus device in SELECTION/RESELECTION phase execution. It indicates that the SELECTION/RESELECTION phase has completed in SCSI. SPC serves as an INITIATOR after the SELECTION phase has been executed, and it serves as a TARGET after the RESELECTION phase has been executed. - b. Completion of Transfer command (when SPC serves as a TARGET) This interrupt indicates that the transferring data of the byte count specified in the transfer byte counter has been completed. Or, in an input operation with bit 0 (Termination Mode) of the SCMD register set to 1, this interrupt indicates the stop of transfer due to parity error is detected in the data received from SCSI. In either case, this interrupt occurs after checking that the ACK signal for the REQ signal of the last byte is inactive on SCSI at asynchronous mode transfer. Or, this interrupt occurs after checking that the number of ACK signals received matches the number of REQ signals transmitted at synchronous mode transfer. - c. Completion of Transfer command (when SPC serves as an INITIATOR) When padding mode transfer is not specified, this interrupt indicates that the transferring data of the byte count specified in the transfer byte counter has been completed. When padding mode transfer is performed, this interrupt indicates that the current transfer operation has been terminated due to another transfer phase is requested in SCSI. In this case, the service required interrupt occurs at the same time. In the MESSAGE IN phase, this interrupt occurs while the ACK signal to the last byte is held active. Before resetting this interrupt, be sure to issue the Reset ACK/REQ command. ### (5) Service required interrupt (Bit 3) This interrupt occurs if the SPC serving as an INITIATOR is put in either of the following conditions. It indicates a request for MPU program intervention. - a. SPC has received the Transfer command, but cannot start the transfer operation because the transfer phase specified by bits 2 to 0 of the PCTL register does not match that requested in SCSI. - b. SPC has stopped the current hardware transfer operation (Transfer command) because of a request for another transfer phase in SCSI. In this case, the transfer operation in SCSI stops immediately, but the SPC internal transfer sequence continues until one of the following events is encountered: - Input operation The internal data buffer register becomes empty. - Output operation The data prefetch sequence to the internal data buffer register is completed. Therefore, when this interrupt occurs, read out the SSTS register and check if the SPC internal transfer operation is completed. If the service required interrupt occurs during an output operation, the data prefetched in the SPC internal data buffer register may remain (not be sent to SCSI). For how to handle the remaining data (up to eight bytes), see the interrupt processing procedure described below. When the service required interrupt occurs, the MPU program examines a transfer phase request from SCSI and proceeds to execute the transfer operation using one of the following procedures. Figures 4.11.1 and 4.11.2 show examples of interrupt processing procedure. - a. Hardware transfer The MPU program specifies the transfer phase pattern requested by SCSI as bit 2 to 0 of the PCTL register, and reissues the Transfer command. - b. Manual transfer If this interrupt occurs during an output operation, the remaining data in the SPC internal data buffer register may have to be preserved. In this case, with bit 3 (Intercept Transfer) of the SCMD register set to 1, perform manual transfer and interrupt resetting. When the interrupted original transfer phase (output) is requested again after manual transfer by the above processing procedure, the suspended transfer operation can be restarted using the remaining data held in the data buffer register. - \*1. An interrupt needs not always be reset. The interrupt is reset automatically when the Transfer command starts hardware transfer. - \*2. If the interrupt is reset, the data prefetched in the internal data buffer register before a change of phase is detected is lost. Fig. 4.11.1 Service required interrupt processing procedure (1) \*1: An interrupt need not always be reset. The interrupt (service required) is reset automatically when the Transfer command starts hardware transfer. Fig. 4.11.2 Service required interrupt processing procedure (2) ### (6) Time-out interrupt (Bit 2) This interrupt indicates that the selected bus device has not responded within the predetermined supervisory time after SPC initiates the SELECTION/RESELECTION phase. See 4.3.2 (2) - Select command for details of the supervisory time setting procedure and the interrupt processing procedure. ### (7) SPC hardware error interrupt (Bit 1) This interrupt indicates that SPC has detected one of the following error indications in the SERR register: - TC parity error - Phase error - Short transfer period - Transfer offset error See 4.12 - SERR register for details of these errors. When this interrupt occurs, SPC does not stop the operation being executed (for any error cause). Since the normal operational sequence and end report cannot always be guaranteed in this case, the MPU program must be used for SPC control and bus phase control of SSCI. Figures 4.11.3 to 4.11.5 show examples of error control processing. # In execution of ARBITRATION/SELECTION/RESELECTION phase \*1: Normal SPC time-out supervision cannot always be guaranteed. Be sure to perform time supervision using the MPU program. Fig. 4.11.3 Example of control processing for SPC-detected error (1) Fig. 4.11.4 Example of control processing for SPC-detected error (2) Fig. 4.11.5 Example of control processing for SPC-detected error (3) ## (8) Reset condition interrupt (Bit 0) This interrupt indicates that the RESET condition has been detected in SCSI. Note that this interrupt cannot be masked. The reset condition persists for an unpredictable period of time. After making sure that bit 3 (Reset In) of the SSTS register becomes to 0, MPU must reset this interrupt condition. The reset condition interrupt may occur regardless of whether SPC is connected with SCSI or not. When SPC is connected with SCSI, occurrence of this interrupt causes SPC to immediately deactivate a signal being sent to SCSI. Then SPC proceeds to the BUS FREE phase. When SPC is executing a command, occurrence of this interrupt causes SPC to terminate its operation and reset its internal state. However, the following internal registers hold the control information unchanged: - BDID register - SCMD register - PCTL register - SCTL register - TMOD register - Transfer byte counter Until this interrupt is reset, the SPC internal reset state is maintained even if the RESET condition is released in SCSI. Therefore, SPC does not respond even when a new bus phase (e.g. SELECTION) is executed in SCSI. ### 4.12 SERR REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|--------------|--------------|-----|-----|-----------------------|----------------|------|-------------------------|---| | R | Data<br>SCSI | Error<br>SPC | 101 | 101 | TC<br>Parity<br>Error | Phase<br>Error | Xfer | Xfer<br>Offset<br>Error | Р | ### 4.12.1 Register Functions The SERR register provides details of an error detected in SPC. An SPC hardware error interrupt occurs if an error is indicated at any of bits 3 to 0. ### Bits 7 and 6: Data Error These bits indicate that a parity error has been detected in the transferred data during transfer phase execution in SCSI. Table 4.12.1 lists the data error indication bit patterns and the relevant SPC operations. When changing the transfer phase in SCSI, these error indication bits must be reset. Table 4.12.1 Data error indication bit patterns in transfer phase | Bit 7 | Bit 6 | | |--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Data<br>SCSI | Error<br>SPC | SPC operations | | 0 | 0 | No parity error was detected in the transferred data. | | 0 | 1 | During execution of an output operation in hardware transfer mode, a parity error was detected in the data to be sent to SCSI. The parity is checked regardless of the value of bit 3 (Parity Enable) of the SCTL register. The erroneous data (parity bit value) is corrected and then sent to SCSI. | | 1 | 1 | A parity error was detected in the data received from SCSI during an input operation. The parity is checked only when bit 3 (Parity Enable) of the SCTL register is set to 1. After an error is detected, the parity bit is corrected. If the SPC serving as an INITIATOR detects this error during hardware transfer execution, it generates an ATN signal to SCSI. (See Figure 4.3.2) In this case, the MPU program must reset this error condition before the ATN signal is reset. If the SPC serving as a TARGET detects this error during hardware transfer execution, it follows the specification at bit 0 (Termination Mode) of the SCMD register. See 4.3 - SCMD register for detailed. | | 1 | 0 | Undefined | ## Bit 3: TC Parity Error Bit 3 indicates that a parity error occurred while the transfer byte counter (TCH, TCM, TCL) was being decreased. ## Bit 2: Phase Error When SPC serves as an INITIATOR, the transfer phase has been changed in SCSI during hardware transfer mode operation (service required interrupt occurs). In this case, bit 2 indicates that: - (1) The new phase is a synchronous transfer mode DATA IN phase. - (2) The REQ signal has been received two or more times before the MPU program complete an interrupt processing and issue the Transfer command for the new phase. In this case, SPC cannot receive data and return the ACK signal normally. ## Bit 1: Short Transfer Period Bit 1 indicates that the REQ/ACK signal (input signal to REQI/ACKI pin) has a cycle exceeding the specified input range. (See Figure 4.12.1.) If this error occurs, the transfer sequence executed by SPC is not guaranteed. TCIF: A cycle of the clock signal supplied to SPC. Fig. 4.12.1 Specified input cycle of REQ/ACK signal ## Bit O: Transfer Offset Error Bit O indicates that one of the following errors has been detected during synchronous mode transfer. The offset value referred to below denotes the REQ ACK maximum offset value specified in the TMOD register. - (1) When SPC serves as a TARGET: - · The number of ACK signals received exceeds that of REQ signals transmitted. - The number of REQ signals transmitted exceeds the offset value (SPC malfunction). - (2) When SPC serves as an INITIATOR: - The number of REQ signals received exceeds the offset value. - The number of ACK signals transmitted exceeds that of REQ signals received (SPC malfunction). If this error occurs, the transfer sequence executed by SPC is not guaranteed. ### 4.12.2 Error Reset To reset an error indication in the SERR register, do one of the following: - Generate SCSI RESET condition (X'10' → SCMD) - (2) Reset & disable (Bit 7 of SCTL register) - (3) Control reset (Bit 6 of SCTL register) - (4) Interrupt (SPC hardware error) reset (X'02' → INTS) Bits 7 and 6 (Data Error) of this register do not cause an interrupt, but can be reset by this means. ### 4.13 MBC REGISTER | | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |---|----|---|-----|---|---|-------|----|---|---|---| | 1 | R | | '0' | | | | MB | С | | | | - | | | | | | Bit 3 | 2 | 1 | 0 | P | The MBC register controls the data count during transfer between the SPC internal data buffer register and the MPU (program transfer mode) or external buffer memory (DMA mode). When data is written into the TCL register, its four low-order bits are set as an initial value for MBC register. In an output operation, data is prefetched into the SPC internal data buffer register. Each time one byte is prefetched, the MBC register is decreased by one. Data prefetch stops when the transfer byte counter is decreased below 15 and the MBC register reaches 0. In an input operation, data received from SCSI is stored in the internal data buffer register. Each time data is sent to the MPU or external buffer memory, the MBC register is decreased. The difference between the transfer byte counter and the MBC register corresponds to the byte count of data remaining in the internal data buffer register. While SPC is executing a DMA mode transfer operation, this register must not be read out. # 4.14 EXTERNAL BUFFER REGISTER (EXBF) | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |-----|-------|---|---|---------|--------|---|---------------------------------------|---|---| | R/W | | | E | xternal | Buffer | | · · · · · · · · · · · · · · · · · · · | | Р | | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | This register's address is reserved for access from the MPU data bus (D7 to D0, DP) to the DMA data bus (HDB7 to HDB0, HDBP) (not exist as an internal register in SPC). As shown in Fig. 4.14.1, the MPU program can execute a write/read to/from the external buffer memory by using this virtual register. Fig. 4.14.1 Access from MPU to external buffer memory ### 4.15 SDGC REGISTER | OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Р | |----|-------------|-------------|---|---|-------------|-------------|-------------|-------------|---| | W | Diag<br>REQ | Diag<br>ACK | | | Diag<br>BSY | Diag<br>MSG | Diag<br>C/D | Diag<br>I/O | | The SDGC register is used to operate SPC in diagnostic mode (with bit 5 [Diag Mode] of the SCTL register set to 1). To simulate the SCSI operation, the SDGC register bits are used as having alternative SCSI control signal lines. In diagnostic mode, the SDGC register is used to check SPC internal operation. The diagnostic mode stops signaling to SCSI and nullifies input signals from SCSI except the data bus signals. The SPC internal operation can be performed in the ordinary manner. To check SPC internal operation, the MPU can manipulate the SDGC register's bits to generate input signals from SCSI. The following bus phases can be simulated: 1) BUS FREE 2) ARBITRATION (Always win) - 3) SELECTION (For INITIATE operation) - 4) RESELECTION (For TARGET operation) - Information transfer (Input data manipulation not allowed in an input operation) ### 4.16 INITIALIZATION SPC is in the reset state when the input to $\overline{\text{RST}}$ pin is low (hardware reset) or bit 7 (Reset & Disable) of the SCTL register is set to 1. SPC-SCSI operation is disabled until the SPC reset state is released. The MPU program shall release the reset state after initializing the SPC internal registers. The following SPC internal registers remain unchanged even in the SPC reset state: - BDID register - TMOD register - Transfer byte counter - SCMD register - PCTL register - TEMP register (for sending) At the moment power is turned on, the contents of these internal registers are unpredictable even though hardware reset ( $\overline{RST}$ input = low) is executed. After $\overline{RST}$ input is released, the MPU program shall initialize SPC as shown in Figure 4.16.1. Fig. 4.16.1 SPC initialization (at power-on) ### EXAMPLES OF EXTERNAL CIRCUIT CONNECTIONS Figure 5.1.1 shows the external circuit blocks that can be connected with this LSI circuit. The external circuit configuration depends on the application environment, purpose of use and performance required of this LSI. Examples of application of this LSI circuit are given below. Fig. 5.1.1 Examples of external circuit connections # 5.1 SCSI DRIVER/RECEIVER CIRCUITS # 5.1.1 Single Ended Type Figure 5.1.2 shows a example of the connection of the SPC and the SCSI single ended type driver/receiver circuit. Table 5.1.1 lists the major components of this SCSI driver/receiver circuit. Table 5.1.1 Major components of single ended type SCSI driver/receiver circuit (example) | Component | Part No. | Manufacturer | Characteristics | Q'ty | |--------------------------------------------------------------------------------------|-------------------------------------|------------------------|-----------------------------------------------------------------------------|---------------------| | REQ/ACK signal driver | MB412 * | Fujitsu | (Tri-state buffer circuit) 2 circuits/DIP 14 | 1 | | REQ/ACK signal receiver | MB413 * Resistor Resistor Capacitor | Fujitsu<br>-<br>-<br>- | 4 circuits/DIP 16<br>390Ω ±2% 1/4 W<br>200Ω ±2% 1/4 W<br>0.1uF/50 V Ceramic | 1<br>1<br>1 | | Other signal driver | MB463 * | Fujitsu | (Open-collector buffer circuit) 4 circuits/DIP 14 | 4 | | Other signal receiver | 74LS240 | Fujitsu<br>TI | (Schmitt trigger inverter)<br>8 circuits/DIP 20 | 2 | | Terminator (Required only when the driver/receiver is located at either end of SCSI) | - | - | (Signal) \$\bigsim \frac{+5}{220 \Omega}\$ 330 \Omega | 18<br>ele-<br>ments | <sup>\*</sup> Note : The MB412 is compatible with the SN7519. The MB413 is compatible with the Am26LS32. The MB463 is compatible with the SN7438. Fig. 5.1.2 Example of single ended type SCSI driver/receiver circuit (continued on next sheet) \*1: It is recommended to protect against noise generated at power on/off. Fig. 5.1.2 Example of single ended type SCSI driver/receiver circuit (continued) # 5.1.2 Differential Type Figure 5.1.3 shows a example of the connection of the SPC and the SCSI differential type driver/receiver circuit. Table 5.1.2 lists the major components of this SCSI driver/receiver. Table 5.1.2 Major components of differential type SCSI driver/receiver circuit (example) | Component | Part No. | Manufacturer | Characteristics | Q'ty | |--------------------------------------------------------------------------------------|----------|--------------|-----------------------------------------------------------------------|---------------------| | Driver/receiver<br>(Common to all<br>signals) | SN75176 | TI | (Differential transceiver)<br>1DV +1RV/Dip 8 | 18 | | Terminator (Required only when the driver/receiver is located at either end of SCSI) | - | - | (Positive signal) $+5$ $330\Omega$ (Negative signal) $+5$ $330\Omega$ | 18<br>ele-<br>ments | Fig. 5.1.3 Example of differential type SCSI driver/receiver circuit (continued on next sheet) Fig. 5.1.3 Example of differential type SCSI driver/receiver circuit (continued) ### 5.2 EXTERNAL DATA BUFFER To provide a buffer area for high-speed data transfer or a temporary storage for data to be transferred, the external data buffer memory can be connected to SPC as shown in Figure 5.1.1. In this case, a buffer control circuit is required to control the timing of data transfer between SPC and external buffer memory. To execute the transfer phase on SCSI, specify DMA transfer mode for SPC. SPC accesses the external buffer memory with the timing sequences shown in Figures 5.2.1 and 5.2.2. Data is transferred via the DMA data bus lines (HDB7 to HDBO, HDBP). The transfer direction must be specified externally using the HIN signal. When requesting access to the external buffer memory, SPC makes the DREO signal active. In an input operation, the DREQ signal is sent out when the SPC internal data buffer register (8 bytes) holds data received from SCSI. In an output operation, the DREQ signal is sent out when data corresponding to the byte count specified in the transfer byte counter is not all prefetched, and when the internal data buffer register has free byte locations available. The external buffer control circuit must return the DRESP signal in response to the DREO signal on completion of transferring each byte. DRESP is a pulse signal whose trailing edge is used to indicate the end of transfer. The DREO signal is held active as long as the above conditions exist in SPC (this signal is not a transfer request signal for each byte). The access interface signals (DREQ, DRESP, HIN, HDB7 to HDB0, HDBP) to the external buffer memory are asynchronous with an SPC clock signal supplied to the $\overline{\text{CLK}}$ pin. - (1) HIN signal puts the DMA data bus (HDB7 to 0, P) in an output mode. However, the value on the DMA data bus is unpredictable until data is loaded into the SPC internal data buffer register from SCSI. - (2) After receiving data from SCSI, SPC issues the DREQ signal (transfer request) to the external buffer memory. At this time, valid data is placed on the DMA data bus. - (3) Data on the DMA data bus is held until the trailing edge of the DRESP signal. - (4) After the DRESP signal is received, valid data is unloaded from the SPC internal data buffer register. Then, the DREQ signal becomes inactive to stop transfer with the external buffer memory until the next data becomes available. Fig. 5.2.1 Transfer with external data buffer (input operation) - As long as the HIN signal is low, the DMA data bus (HDB7 to O, P) is in an input mode. - (2) A transfer request (DREQ) signal is issued when the SPC internal data buffer register has free byte locations available for prefetching data. - (3) The external buffer control circuit puts data onto the DMA data bus and also sends the DRESP signal in response. On the trailing edge of the DRESP signal, SPC loads data from the DMA bus into the internal data buffer register. - (4) When no free location is available in the SPC internal data buffer register, the DREQ signal becomes inactive. Then, transfer from the external buffer memory is stopped until the next data prefetch becomes available. Fig. 5.2.2 Transfer to external data buffer (output operation) CHAPTER 6 AC CHARACTERISTICS In this chapter, the input/output signal timing is specified, under the following conditions: (1) Operating temperature $$T_A = 0$$ to 70 °C (2) Power supply voltage $$V_{DD} = 4.75 \text{ to } 5.25 \text{ V}$$ (3) Input/output condition The input/output condition in section 1.3 "Electrical Specifications" should be satisfied. (4) Timing measurement To be specified at the input/output pins of this LSI circuit. ### 6.1 MPU INTERFACE ## 6.1.1 Clock Signal | Symbol | Parameter | MIN | TYP | MAX | Unit | |--------|-------------------------|-----|-----|-----|------| | tCLF | Clock Cycle | 125 | | 200 | ns | | tCHCL | Clock High | 65 | | | ns | | tCLCH | Clock Pulse Width (Low) | 40 | | | ns | ## 6.1.2 Reset Signal | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-------------------|-----|-----|-----|------| | <sup>t</sup> RSTW | Reset Pulse Width | 50 | | | ns | ## 6.1.3 Write Cycle ## (1) Registers other than EXBF | Symbol | Parameter | MIN | TYP | MAX | Unit | |------------------|----------------|-----|-----|-----|------| | t <sub>AWS</sub> | Address Setup | 35 | | | ns | | <sup>t</sup> AWH | Address Hold | 5 | | | ns | | tcws | CS Setup | 20 | | | ns | | t <sub>CWH</sub> | CS Hold | 5 | | | ns | | tDWS | Data Bus Setup | 25 | | | ns | | <sup>t</sup> DWH | Data Bus Hold | 20 | | | ns | | t <sub>WT</sub> | WT pulse Width | 50 | | | ns | # (2) EXBF register | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-------------------------------------------------------|-----|-----|-----|------| | tAWSE | Address Setup | 20 | | | ns | | <sup>t</sup> AWHE | Address Hold | 5 | | | ns | | tcwsE | CS Setup | 5 | | | ns | | tCWHE | CS Hold | 5 | | | ns | | tWLHD | WTG Low → DMA Data Bus<br>(HDB7 to 0, P) | | | 60 | ns | | twhhD | WTG High → DMA Data Bus<br>(HDB7 to 0, P) | 10 | | | ns | | tDHD | MPU Data Bus (D7 to 0, P) DMA Data Bus (HDB7 to 0, P) | 10 | | 50 | ns | ## 6.1.4 Read Cycle # (1) Registers other than EXBF | Symbol | Parameter | MIN | TYP | MAX | Unit | |------------------|--------------------------------------------------------------|-----|-----|-----|------| | <sup>t</sup> ARS | Address Setup | 35 | | | ns | | tarh | Address Hold | 5 | | | ns | | tcrs | CS Setup (RD) | 5 | | | ns | | tcRH | CS Hold | 5 | | | ns | | t <sub>RD</sub> | RD Pulse Width | 50 | | | ns | | tRLNZ | RDG Low → Data Output | 10 | | 45 | ns | | tRHHZ | $\overline{\text{RDG}}$ High $\rightarrow$ D7 to 0, P High Z | | | 40 | ns | | tRLD | RD Low → Data Establish | | | 85 | ns | | tRHD | RD High → Data hold | 10 | | | n,s | | tCRGS | CS Setup (RDG) | 5 | | | ns | # (2) EXBF register | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-------------------------------------------------------------|-----|-----|-----|------| | <sup>t</sup> ARSE | Address Setup | 35 | | | ns | | tARHE | Address Hold | 5 | | | ns | | tCRSE | CS Setup | 5 | | | ns | | tCRHE | CS Hold | 5 | | | ns | | t <sub>RLNZ</sub> | RDG Low → Data Output | 10 | | 45 | ns | | tRHHZ | $\overline{RDG}$ High $\rightarrow$ D7 to 0,P High Z | | | 40 | ns | | tHDD | DMA Data Bus (HDB7 to 0, P)<br>to MPU Data Bus (D7 to 0, P) | 5 | | 50 | ns | ## 6.1.5 Interrupt | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------------------|-----------------------|-----|------------------------|------| | t <sub>CHIR</sub> | CLK High → INTR High | 5 | | 45 | ns | | tIRWL | INTR → WT | 5 | | | ns | | tWHIR | WT High → INTR Low<br>(Interrupt Reset) | t <sub>CLF</sub> + 10 | | 2t <sub>CLF</sub> + 50 | ńs | | twrcy | Interrupt Reset Cycle time *1 | 4t <sub>CLF</sub> | | | ns | t<sub>CLF</sub> : See 6.1.1 \*1 : When interrupt reset is continued. ### 6.2 DMA INTERFACE # 6.2.1 Access Timing | Symbol | Parameter | MIN | TYP | · MAX | Unit | |-------------------|------------------------|-------------------|-----|-------|------| | tDRRP | DREQ High → DRESP High | tCLF | | | ns | | t <sub>RPDR</sub> | DRESP High → DREQ Low | | | 80 | ns | | tDLDH | DREQ Low → DREQ High | 5 | | | ns | | tRPSW | DRESP Pulse Width | 50 | | | ns | | tRPCY | DRESP Cycle Time (1) | 2t <sub>CLF</sub> | | | ns | | tRLRH | DRESP Cycle Time (2) | 3t <sub>CLF</sub> | | | ns | t<sub>CLF</sub> : See 6.1.1 ### 6.2.2 Input Operation (SPC to External data buffer) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|----------------------------------------|-----|-----|-----|------| | tHINZ | HIN High → HDB7 to O, P<br>Data Output | 10 | | 40 | ns | | <sup>t</sup> DRDV | DREQ High → Data Establish | | | 85 | ns | | t <sub>RPDV</sub> | DRESP Low → Data Change | 15 | | 75 | ns | #### 6.2.3 Output Operation (External data buffer to SPC) | Symbol | Parameter | MIN | TYP | MAX | Unit | |--------|------------------------------|-----|-----|-------------------|------| | tHIHZ | HIN Low → HDB7 to 0,P High Z | | | 35 | ns | | tHDBS | Data Bus Setup | 20 | | | ns | | tHDBH | Data Bus Hold | 20 | | | ns | | tDLRP | DREQ Low → DRESP *1 | | | 5t <sub>CLF</sub> | ns | t<sub>CLF</sub>: See 6.1.1 - \*1 In the following cases, the DREQ signal becomes inactive asynchronously with the DRESP signal to stop refetching data during an output operation: - When the Transfer Pause command is issued in the SPC serving as a TARGET - When the Transfer Phase is changed in the SPC serving as an INITIATOR In these cases, the last DRESP signal response must not exceed $t_{\mbox{DLRP}}$ . #### 6.3 SCSI INTERFACE ## 6.3.1 SELECTION Phase # (1) INITIATOR (With arbitration) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|----------------------------------------------------|---------------------------------|-----|----------------------------------|------| | tBFR | Bus Free Time | 4t <sub>CLF</sub> + 50 | | | ns | | t <sub>BFBO</sub> | BSYI Low → BSYO High<br>(Start of arbitration) | (6+n) x<br>t <sub>CLF</sub> + 5 | | (7+n) x<br>t <sub>CLF</sub> + 65 | ns | | <sup>t</sup> BHID | BSYO High → ID Bit High | 5 | | 55 | ns | | <sup>t</sup> ARB | BSYO High → Prioritize | 32t <sub>CLF</sub> - 40 | | | ns | | t <sub>AIDV</sub> | Data Bus Valid (High Priority<br>Bit) → Prioritize | 70 | | | ns | | ANIDA | Data Bus Valid (Low Priority<br>Bit) → Prioritize | 5 | | | ns | | t <sub>AWSO</sub> | Bus Usage Permission Granted<br>→ SELO High | 5 | | 45 | ns | | tsoid | SELO High → Data Bus (ID) Send | 11t <sub>CLF</sub> - 30 | | | ns | | t <sub>SOIT</sub> | SELO High → INIT High | 11t <sub>CLF</sub> - 50 | | | ns | | tITAT | INIT High → ATNO High | 10 | | 55 | ns | | tIDBL | Data Bus (ID) Send → BSYO Low | 2t <sub>CLF</sub> - 80 | | | ns | | t <sub>BOBI</sub> | BSYO Low → BSYI Low | 5 | | <sup>‡</sup> CLF | ns | | tBISO | BSYI High → SELO Low | 2t <sub>CLF</sub> + 5 | | | ns | | <sup>t</sup> BIDH | BSYI High → Data Bus (ID) Hold | 2t <sub>CLF</sub> + 5 | | | ns | | tSCIR | SELO Low → INTR High | | | 75 | ns | | tSBCR | SELI High → BSYO, ID Bit Low | | | 3t <sub>CLF</sub> + 115 | ns | | tpBCR | Prioritize → BSYO, ID Bit Low | | | 125 | ns | t<sub>CLF</sub> : See 6.1.1 n : TCL register set value (See 4.3.2 (2) - Select command.) # (2) INITIATOR (Without arbitration) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|--------------------------------|---------------------------------|-----|----------------------------------|------| | tFRID | Bus Free → Data Bus (ID) Send | (6+n) x<br>t <sub>CLF</sub> + 5 | | (7+n) x<br>t <sub>CLF</sub> + 85 | ns | | tIDSO | ID Send → SELO High | 11t <sub>CLF</sub> - 80 | | | ns | | tIDIT | ID Send → INIT High | 11t <sub>CLF</sub> - 80 | | | ns | | tITAT | INIT High → ATNO High | 10 | | 55 | ns | | tBIS0 | BSYI High → SELO Low | 2t <sub>CLF</sub> + 5 | | | ns | | t <sub>BIDH</sub> | BSYI High → Data Bus (ID) Hold | 2t <sub>CLF</sub> + 5 | | | ns | | tSCIR | SELO Low → INTR High | | | 75 | ns | t<sub>CLF</sub> : See 6.1.1 n : TCL register set value (See 4.3.2 (2) - Select command.) # (3) TARGET (With arbitration) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------------------|-----------------------|-----|------------------------|------| | tFIBI | SELI High → BSYI Low | 5 | | | ns | | tIDBI | Data Bus (ID) Valid → BSYI Low | 5 | | | ns | | tIIBI | I/OI Low → BSYI Low | 5 | | | ns | | t <sub>SLBO</sub> | BSYI Low → BSYO High<br>(Response time) | 4t <sub>CLF</sub> + 5 | | 5t <sub>CLF</sub> + 60 | ns | | tBOID | BSYO High → Data Bus (ID) Hold | 15 | | | ns | | tBOSI | BSYO High → SELI Low | 5 | | | ns | | <sup>t</sup> ATSI | ATNI High → SELI Low | 5 | | | ns | | tSLTG | SELI Low → TARG High | 3t <sub>CLF</sub> + 5 | | 4t <sub>CLF</sub> + 60 | ns | | <sup>t</sup> TGPH | TARG High → Phase Signal Output | 10 | | | ns | | tIODE | I/OO High → Data Bus Enable | 3t <sub>CLF</sub> + 5 | | | ns | | t <sub>SLIR</sub> | SELI Low → INTR High | | | 3t <sub>CLF</sub> + 65 | ns | t<sub>CLF</sub> : See 6.1.1 # (4) TARGET (Without arbitration) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|------------------------------------------|-----------------------|-----|------------------------|------| | tIDSI | Data Bus (ID) Valid → SELI High | 5 | | | ns | | tIISI | I/OI Low → SELI High | 5 | | | ns | | <sup>t</sup> SLBO | SELI High → BSYO High<br>(Response time) | 2t <sub>CLF</sub> + 5 | | 3t <sub>CLF</sub> + 65 | ns | | tBOID | BSYO High → Data Bus (ID) Hold | 15 | | | ns | | tBOSI | BSYO High → SELI Low | 5 | | | ns | | tATSI | ATNI High → SELI Low | 5 | | | ns | | <sup>t</sup> SLTG | SELI Low → TARG High | 3t <sub>CLF</sub> + 5 | | 4t <sub>CLF</sub> + 60 | ns | | <sup>t</sup> TGPH | TARG High → Phase Signal Output | 10 | | | ns | | tIODE | I/OO High → Data Bus Enable | 3t <sub>CLF</sub> + 5 | | | ns | | tSLIR | SELI Low → INTR High | | | 3t <sub>CLF</sub> + 65 | ns | t<sub>CLF</sub> : See 6.1.1 ### 6.3.2 RESELECTION Phase ## (1) TARGET | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|----------------------------------------------------|---------------------------------|-----|----------------------------------|------| | t <sub>BFR</sub> | Bus Free Time | 4t <sub>CLF</sub> + 50 | | | ns | | t <sub>BFBO</sub> | BYSI Low → BSYO High<br>(Start of Arbitration) | (6+n) x<br>t <sub>CLF</sub> + 5 | | (7+n) x<br>t <sub>CLF</sub> + 65 | ns | | t <sub>BHID</sub> | BSYO High → ID Bit High | 5 | | 55 | ns | | tARB | BSYO High → Prioritize | 32t <sub>CLF</sub> - 40 | | | ns | | tAIDT | Data Bus Valid (High Priority<br>Bit) → Prioritize | 70 | | | ns | | ,,,,,, | Data Bus Valid (Low Priority<br>Bit) → Prioritize | 5 | | | ns | | <sup>t</sup> AWSO | Bus Usage Permission Grant →<br>SELO High | 5 | | 45 | ns | | tsoid | SELO High → Data Bus (ID) Send | 11t <sub>CLF</sub> - 30 | | | ns | | <sup>t</sup> SOTG | SELO High → TARG High | 11t <sub>CLF</sub> - 50 | | | ns | | <sup>t</sup> TGPH | TARG High → Phase Signal Send | | | 35 | . ns | | tIOBL | I/OO High → BSYO Low | 2t <sub>CLF</sub> - 80 | | | ns | | tIDBL | Data Bus (ID) Send → BSYO Low | 2t <sub>CLF</sub> - 80 | | | ns | | tBOBI | BSYO Low → BSYI Low | 5 | | t <sub>CLF</sub> | ns | | t <sub>BISO</sub> | BSYI High → SELO Low | 2t <sub>CLF</sub> + 5 | | | ns | | <sup>t</sup> BIDH | BSYI High → Data Bus (ID) Hold | 2t <sub>CLF</sub> + 5 | | | ns | | tSCIR | SELO Low → INTR High | | | 75 | ns | | tSBCR | SELI High → BSYO, ID Bit Low | | | 3t <sub>CLF</sub> + 115 | ns | | tpBCR | Prioritize → BSYO, ID Bit Low | | | 125 | ns | t<sub>CLF</sub> : See 6.1.1 n : tCL register set value (See 4.3.2 (2) - Select command.) # (2) INITIATOR | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|---------------------------------------------------------|------------------------|-----|------------------------|------| | tSIBI | SELI High → BSYI Low | 5 | | | ns | | tIDBI | Data Bus (ID) Valid → BSYI Low | 5 | | | ns | | tIIBI | I/OI Low → BSYI Low | 5 | | | ns | | t <sub>SLBO</sub> | BSYI Low → BSYO High<br>(Response time) | 4t <sub>CLF</sub> + 5 | | 5t <sub>CLF</sub> + 60 | ns | | tBOID | BSYO High → Data Bus (ID) Hold | 15 | | | ns | | tBOSI | BSYO High → SELI Low | 5 | | | ns | | tSIBO | SELI Low → BSYO Low | 2t <sub>CLF</sub> + 5 | | 3t <sub>CLF</sub> + 15 | ns | | tSIIH | SELI Low → I/OI Hold | 3t <sub>CLF</sub> + 20 | | | ns | | tSLIR | SELI Low → INTR High | | | 3t <sub>CLF</sub> + 65 | ns | | tSLIT | SELI Low → INIT High | 3t <sub>CLF</sub> + 5 | | 4t <sub>CLF</sub> + 65 | ns | | tITDE | INIT High → Data Bus Enable<br>(With I/OI at low level) | 10 | | | ns | t<sub>CLF</sub> : See 6.1.1 #### 6.3.3 Transfer Phase ## (1) Asynchronous transfer output (TARGET) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------|------------------------|-----|-----|------| | tIODE | I/OO High → Data Bus Enable | 3t <sub>CLF</sub> + 5 | , | | ns | | <sup>t</sup> DVRQ | Data Bus Valid → REQO High | 2t <sub>CLF</sub> - 80 | | | ns | | <sup>t</sup> AKDV | ACKI High → Data Bus Hold | 15 | | | ns | | <sup>‡</sup> RHAH | REQO High → ACKI High | 20 | | | ns | | tAHRL | ACKI High → REQO Low | 10 | | 55 | ns | | tRLAL | REQO Low → ACKI Low | -5 | | | ns | | <sup>‡</sup> ALRH | ACKL Low → REQO High | 10 | | | ns | | <sup>t</sup> AHRH | ACKI High → REQO High | 2t <sub>CLF</sub> + 5 | | | ns | t<sub>CLF</sub> : See 6.1.1 ## (2) Asynchronous transfer input (TARGET) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------|-----------------------|-----|-----|------| | tIODD | I/OO Low → Data Bus Disable | | | 40 | ns | | <sup>t</sup> DVAK | Data Bus Valid → ACKI High | 10 | | | ns | | tRLDV | REQO Low → Data Bus Hold | 25 | | | ns | | <sup>t</sup> RHAH | REQO High → ACKI High | 20 | | | ns | | <sup>t</sup> AHRL | ACKI High → REQO Low | 10 | | 55 | ns | | tRLAL | REQO Low → ACKI Low | 5 | | | ns | | tALRH | ACKI Low → REQO High | 10 | | | ns | | t <sub>AHRH</sub> | ACKI High → REQO High | 2t <sub>CLF</sub> + 5 | | | ns | t<sub>CLF</sub> : See 6.1.1. ### (3) Asynchronous transfer output (INITIATOR) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|----------------------------|------------------------|-----|-----|------| | tIIDE | I/OI Low → Data Bus Enable | 20 | | | ns | | tPHRQ | Phase Specify → REQI High | 100 | | | ns | | tALPH | ACKO Low → Phase Change | 10 | | | ns | | tRATL<br>*1 | REQI High → ATNO Low | 2t <sub>CLF</sub> + 5 | | | ns | | tATLA<br>*1 | ATNO Low → ACKO High | t <sub>CLF</sub> - 20 | | | ns | | <sup>t</sup> DVAK | Data Bus Valid → ACKO High | 2t <sub>CLF</sub> - 80 | | | ns | | <sup>t</sup> RLDV | REQI Low → Data Bus Hold | 20 | | | ns | | <sup>t</sup> RHAH | REQI High → ACKO High | 15 | | | ns | | <sup>t</sup> AHRL | ACKO High → REQI Low | 5 | | | ns | | <sup>t</sup> RLAL | REQI Low → ACKO Low | 10 | | | ns | | tALRH | ACKO Low → REQI High | 10 | | | ns | | <sup>t</sup> RLNA | REQI Low → ACKO High | 2t <sub>CLF</sub> + 5 | | | ns | t<sub>CLF</sub> : See 6.1.1 $^{\star}1$ : With these timings, the ATNO signal is reset only when the last byte is sent at the MESSAGE OUT phase. ## (4) Asynchronous transfer input (INITIATOR) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------------|------------------------------|-----------------------|-----|-----|------| | tIIDD | I/OI High → Data Bus Disable | | | 70 | ns | | <sup>t</sup> PHRQ | Phase Specify → REQI High | 100 | | | ns | | <sup>t</sup> ALPH | ACKO Low → Phase Change | 10 | | | ns | | <sup>t</sup> DVRQ | Data Bus Valid → REQI High | 10 | | | ns | | <sup>t</sup> AKDV | ACKO High → Data Bus Hold | 15 | | | ns | | <sup>t</sup> RHAH | REQI High → ACKO High | 15 | | | ns | | tAHRL | ACKO High → REQI Low | 5 | | | ns | | tRLAL | REQI Low → ACKO Low | 10 | | | ns | | <sup>t</sup> ALRH | ACKO Low → REQI High | 10 | | | ns | | <sup>t</sup> RLNA | REQI Low → ACKO High | t <sub>CLF</sub> + 5 | | | ns | | <sup>t</sup> ATAL<br>*1 | ATNO High → ACKO Low | t <sub>CLF</sub> - 20 | | | ns | t<sub>CLF</sub> : See 6.1.1 <sup>\*1</sup> With this timing, the ATNO signal is sent only when the parity checking is enabled and a parity error is detected in the input data. # (5) Synchronous transfer output (TARGET) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------|------------------------------------------------------|-----|-----|------| | tIODE | I/OO High → Data Bus Enable | 3t <sub>CLF</sub> + 5 | | | ns | | t <sub>DVRQ</sub> | Data Bus Valid → REQO High | t <sub>CLF</sub> + 5<br>or<br>nt <sub>CLF</sub> - 40 | | | ns | | tRQAP | REQO Assertion Period | t <sub>CLF</sub> - 10 | | | ns | | tRNAP | REQO Nonassertion Period | nt <sub>CLF</sub> - 10 | | | ns | | <sup>t</sup> RLDH | REQO Low → Data Bus Hold | 5 | | | ns | | tRHAH | REQO High → ACKI High | 5 | | | ns | | tAKF1 | ACKI cycle time (1) | <sup>t</sup> CLF | | | ns | | tAKF2 | ACKI cycle time (2) | 3t <sub>CLF</sub> | | | ns | | tAKAP | ACKI Assertion Period | 50 | | | ns | | tANAP | ACKI Nonassertion Period | 50 | | | ns | t<sub>CLF</sub> : See 6.1.1 n : TMOD register set value (See Fig. 4.4.1) # (6) Synchronous transfer input (TARGET) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------|-----------------------|-----|-----|------| | tIODD | I/OO Low → Data Bus Disable | | | 40 | ns | | <sup>t</sup> RQAP | REQO Assertion Period | t <sub>CLF</sub> - 10 | | | ns | | tRNAP | REQO Nonassertion Period | nt <sub>CLF</sub> -10 | | | ns | | tRHAH | REQO High → ACKI High | 5 | | | ns | | tAKAP | ACKI Assertion Period | 50 | | | ns | | tANAP | ACKI Nonassertion Period | 50 | | | ns | | tAKF1 | ACKI Cycle time (1) | <sup>t</sup> CLF | | | ns | | tAKF2 | ACKI Cycle time (2) | 3t <sub>CLF</sub> | | | ns | | <sup>t</sup> DVAK | Data Bus Valid → ACKI High | 10 | | | ns | | <sup>t</sup> AKDH | ACKI High → Data Bus Hold | 40 | | | ns | t<sub>CLF</sub> : See 6.1.1 n : TMOD register set value (See Fig. 4.4.1) ## (7) Synchronous transfer Output (INITIATOR) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|----------------------------|------------------------------------------------------|-----|-----|------| | tIIDE | I/OI Low → Data Bus Enable | 20 | | | ns | | <sup>t</sup> PHRQ | Phase Specify → REQI High | 100 | | | ns | | tALPH | ACKO Low → Phase Change | 10 | | | ns | | <sup>t</sup> RQAP | REQI Assertion Period | 50 | | | ns | | tRNAP | REQI Nonassertion Period | 50 | | | ns | | tRQF1 | REQI Cycle time (1) | tCLF | | | ns | | tRQF2 | REQI Cycle time (2) | 3t <sub>CLF</sub> | | | ns | | <sup>t</sup> RHAH | REQI High → ACKO High | 3t <sub>CLF</sub> + 5 | | | ns | | <sup>t</sup> AKAP | ACKO Assertion Period | t <sub>CLF</sub> - 10 | | | ns | | tANAP | ACKO Nonassertion Period | nt <sub>CLF</sub> - 10 | | | ns | | <sup>t</sup> DTAK | Data Bus Valid → ACKO High | t <sub>CLF</sub> + 5<br>or<br>nt <sub>CLF</sub> - 40 | | | ns | | <sup>t</sup> ALDH | ACKO Low → Data Bus Hold | 5 | | | ns | t<sub>CLF</sub> : See 6.1.1 n : TMOD register set value (See Fig. 4.4.1) ### (8) Synchronous transfer input (INITIATOR) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|------------------------------|------------------------|-----|-----|------| | t <sub>IDD</sub> | I/OI High → Data Bus Disable | | | 70 | ns | | tpHRQ | Phase Specify → REQI High | 100 | | | ns | | <sup>t</sup> ALPH | ACKO Low → Phase Change | 10 | | | ns | | <sup>t</sup> DVRQ | Data Bus Valid → REQI High | 10 | | | ns | | <sup>t</sup> RQDH | REQI High → Data Bus Hold | 40 | | | ns | | <sup>t</sup> RQAP | REQI Assertion Period | 50 | | | ns | | <sup>t</sup> RNAP | REQI Nonassertion Period | 50 | | | ns | | <sup>t</sup> RQF1 | REQI Cycle time (1) | <sup>t</sup> CLF | | | ns | | <sup>t</sup> RQF2 | REQI Cycle time (2) | 3t <sub>CLF</sub> | | | ns | | <sup>t</sup> RHAH | REQI High → ACKO High | 3t <sub>CLF</sub> + 5 | | | ns | | <sup>t</sup> AKAP | ACKO Assertion Period | t <sub>CLF</sub> - 10 | | | ns | | tANAP | ACKO Nonassertion Period | nt <sub>CLF</sub> - 10 | | | ns | | tRATH<br>*1 | REQI High → ATNO High | 3t <sub>CLF</sub> + 5 | | | ns | t<sub>CLF</sub> : See 6.1.1 n : TMOD register set value (See Fig. 4.4.1) \*1 ANTO signal is sent only when the parity checking is enabled and a parity error is detected in the input data. ## (9) Transfer phase change (TARGET) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------------------------|-----|-----|-----|------| | <sup>t</sup> PHCH | WT High → MSGO, C/DO, I/OO<br>(PCTL register) | 15 | | 70 | ns | ## (10) Manual transfer | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------------------------------|-----------------------|-----|------------------------|------| | t <sub>WTDV</sub> | WT High → Data Bus Valid<br>(TEMP register output) | | | 60 | ns | | <sup>t</sup> STRA | WT High → REQO, ACKO High<br>(Set ACK/REQ command) | 2t <sub>CLF</sub> + 5 | | 3t <sub>CLF</sub> + 60 | ns | | <sup>t</sup> RTRA | WT High → REQO, ACKO Low<br>(Reset ACK/REQ command) | 2t <sub>CLF</sub> + 5 | | 3t <sub>CLF</sub> + 60 | ns | tCLF : See 6.1.1 Note: Timing sequences not shown here conform to the asynchronous transfer timing sequence. # 6.3.4 Attention Condition (INITIATOR) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|-----------------------------------------------------------------------|-----------------------|-----|------------------------|------| | t <sub>ATNO</sub> | WT High → ATNO High/Low<br>(Set ATN command and Reset<br>ATN command) | 2t <sub>CLF</sub> + 5 | | 3t <sub>CLF</sub> + 60 | ns | t<sub>CLF</sub> : See 6.1.1 ## 6.3.5 BUS FREE # (1) INITIATOR (Disconnected) | Symbol | Parameter | MIN | TYP | MAX | Unit | |--------|----------------------|-----|-----|------------------------|------| | tBLIT | BSYI Low → INIT Low | | | 5t <sub>CLF</sub> + 70 | ns | | tITCR | INIT Low → Bus Clear | | | 5t <sub>CLF</sub> + 65 | ns | | tBLIR | BSYI Low → INTR High | | | 6t <sub>CLF</sub> + 75 | ns | t<sub>CLF</sub> : See 6.1.1 ## (2) TARGET (Bus Release command) | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|---------------------------------------|-----|-----|------------------------|------| | twRLS | WT High → BSYO Low<br>(SCMD register) | | | 3t <sub>CLF</sub> + 55 | ns | | twTGL | WT High → TARG Low<br>(SCMD register) | | | 3t <sub>CLF</sub> + 55 | ns | | <sup>t</sup> TGCR | TARG Low → Bus Clear | | | 95 | ns | t<sub>CLF</sub> : See 6.1.1 ## (3) SELECTION / RESELECTION phase stop (time-out) | Symbol | Parameter | MIN | TYP | MAX | Unit | |--------|-----------------------------------------------|-------------------------|-----|------------------------|------| | twsL | WT High → SELO Low<br>(INTS register) | | | 3t <sub>CLF</sub> + 55 | ns | | tWDBL | WT High → Data Bus<br>Disable (INTS register) | 3t <sub>CLF</sub> + 100 | | ns | | | tWTIL | WT High → TARG or<br>INIT Low (INTS register) | | | 3t <sub>CLF</sub> + 70 | ns | | tTGI0 | TARG Low → I/OO Low | | | 30 | ns | | tWIRL | WT High → INTR Low<br>(INTS register) | | | 3t <sub>CLF</sub> + 65 | ns | t<sub>CLF</sub> : See 6.1.1. ### 6.3.6 Reset Condition ### (1) RST signal sending | Symbol | Parameter | MIN | TYP | MAX | Unit | |--------|-----------------------------------------|-----|-----|-----|------| | tRSTO | WT High (bit 4 of SCMD register) → RSTO | 5 | | 35 | ns | | tRSOD | Reset Delay | | | 115 | ns | ### (2) RST signal receiving | Symbol | Parameter | MIN | TYP | MAX | Unit | |-------------------|------------------|-------------------|-----|-------------------------|------| | <sup>t</sup> SRIN | RSTI Pulse Width | 3t <sub>CLF</sub> | | | ns | | tRSID | Reset Delay | | | 4t <sub>CLF</sub> + 115 | ns | t<sub>CLF</sub> : See 6.1.1 # FUJITSU LIMITED Communications and Electronics 6-1, Marunouchi 1-chome, Chiyoda-ku, Tokyo 100, Japan Phone: National (03) 216-3211 International (Int'l Prefix) 81-3-216-3211 Telex: J22833 Cable: "FUJITSULIMITED TOKYO" For further information please contact: **FUJITSU LIMITED** Semiconductors Marketing: Fürükawa Sogo Bldg., 6:1, Marunouchi 2-chome, Chiyoda-ku, Tokyo 100, Japani Phone: National (03) 216-3211 International (Int'l Prefix) 81-3-216-3211 Telex: 2224361 FTTOR J FUJITSU MICROELECTRONICS, INC.: 3320 Scott Blvd., Santa Clara, CA95054-3197, U.S.A. Phone: 408-727-1700 Telex: 910-338-0190 FUJITSU SNTA FUJITSU MIKROELEKTRONIK GmbH.: Arabella Center 9. OG./A Lyoner Straße 44-48 D-6000 Frankfurt 71, F.R. Germany Phone: 069/66 320 Telex: 0411 963