### Am85C80 ## Combined SCSI Controller and Serial Communications Controller #### DISTINCTIVE CHARACTERISTICS - The Am85C80 is an Enhanced Serial Communications Controller (ESCC) and Small Computer Systems Interface (SCSI) Controller - This chip replaces both the 85C30 Serial Communications Controller (SCC) and the 53C80 SCSI Controller in functionality, while combining the two chips into a single package - The sleep mode feature consumes very little power; this feature may be used in notebook computer and other battery operated portable systems #### **ESCC** - Fast Data Rate - 8.192 MHz/2.048 Mb/s - 16.384 MHz/4.096 Mb/s - Low Power CMOS Technology - Easily interfaced with most CPUs - Compatible with non-multiplexed bus - Two Independent Full-duplex Serial Channels - Asynchronous Mode Features - Programmable stop bits, clock divider, character length and parity - Break detection/divider - Error detection for framing, overrun and parity - Synchronous Mode Features - Supports IBM BISYNC, SDLC, SDLC Loop, HDLC and ADCCP Protocols - Programmable CRC generators and checkers - SDLC/HDLC support includes frame control, zero insertion and deletion, abort, and residue handling - External sync mode is supported on Channel A only #### Enhanced ESCC functions support high-speed frame reception using DMA - 14-bit frame byte counter - 10 × 19 SDLC/HDLC Frame Status FIFO - Independent Control on both channels - Enhanced operation does not allow special receive conditions to lock the three-byte DATA FIFO when the 10 × 19 FIFO is enabled - Local Loopback and Auto Echo Modes - Internal or External Character Synchronization - 2 Mb/s FM Encoding Transmit and Receive capability using Internal DPLL for 16.384 MHz product - Internal Synchronization between RxC to PCLK and TxC to PCLK - This allows the user to eliminate external sychronization hardware required by the NMOS device when transmitting or receiving data at the maximum rate of 1/4 PCLK frequency #### SCSI Interface - Asynchronous interface to 1.5 megabytes per second - Supports Initiator and Target roles - Parity generation with optional checking - Supports Arbitration - Direct control of all bus signals - High-current outputs drive SCSI Bus directly - Implements Glitch Eater circuitry that filters glitches upto 30 ns on the SCSI Bus - CPU Interface Supports - Memory or I/O-mapped interface - DMA or programmed I/O - Normal or Block mode DMA - Optional CPU interrupts Publication # 12582 Rev. C Amendment /0 issue Date: November 1991 #### **BLOCK DIAGRAM** Block Diagram #### GENERAL DESCRIPTION The Am85C80 is an Enhanced Serial Communications Controller and SCSI Interface Controller. The chip replaces both Am85C30 and Am53C80 in functionality, while combining the two chips into a single package. #### **ESCC** The Enhanced Serial Communications Controller (ESCC) is a high-speed, low-power, multi-protocol communications peripheral designed for use with 8- and 16-bit microprocessors. It has two independent, full duplex channels and functions as a serial-to-parallel, parallel-to-serial converter/controller. AMD's proprietary enhancements make the ESCC easier to interface and more effective in high-speed applications by reducing software overhead and eliminating the need for some external glue logic. The ESCC is easy to use due to a variety of sophisticated internal functions, including on-chip baud rate generators, digital phase-locked loops and crystal oscillators which dramatically reduce the need for external logic. The device can generate and check CRC codes in any SYNC mode, and can be programmed to check data integrity in various modes. The ESCC also has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O. This versatile device supports virtually any serial data transfer application such as laser beam printers, networks, modems, cassettes and tape drives. The ESCC is designed for non-multiplexed buses and is easily interfaced with most CPUs, such as 80188, 80186, 80286, 8080, 280, 6800, 68000 and MULTIBUS. Enhancements which allow the ESCC to be used more effectively in high-speed applications include: - a 10 × 19 bit SDLC/HDLC frame status FIFO array - a 14-bit SDLC/HDLC frame byte counter - automatic SDLC/HDLC opening frame flag transmission - TxD pin forced High in SDLC NRZI mode after closing flag - automatic SDLC/HDLC Tx underrun/EOM flag reset - automatic SDLC/HDLC Tx CRC generator reset/preset - RTS synchronization to closing SDLC/HDLC flag - DTR/REQ deactivation delay significantly reduced - external PCLK to RxC or TxC synchronization requirement eliminated for PCLK divide-by-four operation - 16 MHz operation Other enhancements to improve the ESCC interface capabilities include: - write data valid setup time to falling edge of WR requirement eliminated - reduced INT response time - reduced access recovery time (tac) to 3 PCLK best case (3 1/2 PCLK worst case) - improved Wait timing - write registers WR3, WR4, WR5, and WR10 made readable - lower priority interrupt masking without INTACK - complete SDLC/HDLC CRC character reception - Sleep mode feature saves all ESCC registers #### SCSI The Small Computer Systems Interface (SCSI) Interface Controller is a CMOS device designed to accommodate the SCSI as defined by the ANSI X3T9.2 committee. The Am85C80 operates in both the Initiator and Target roles and can, therefore, be used in host adaptor, host port, disk drive, and formatter designs. This device supports Arbitration, including Reselection. Special high-current open-collector output drivers, capable of sinking 48 mA at 0.5 V, allow for direct connection to the SCSI Bus. The Am85C80 communicates with the system microprocessor as a peripheral device. The chip is controlled by reading and writing several internal registers which may be addressed as standard or memory-mapped I/O. Minimal processor intervention is required for DMA transfers because the Am85C80 controls the necessary handshake signals. The Am85C80 interrupts the CPU when it detects a bus condition that requires attention. Normal and Block mode DMA is provided to match many popular DMA controllers. ## CONNECTION DIAGRAM Top View #### **PLCC** Note: Pin 1 is marked for orientation. 12582C-097A ## CONNECTION DIAGRAM Detailed Internal 12582C-098B ## ORDERING INFORMATION Commodity Products AMD commodity products are available in several packages and operating ranges. The ordering number (Valid Combination) is formed by a combination of: | Valid Combinations | | | | | |-------------------------|----|--|--|--| | Am85C80-8<br>Am85C80-16 | JC | | | | #### **Valid Combinations** Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations. #### PIN DESCRIPTION ESCC RTxCA, RTxCB #### Receive/Transmit Clocks (Inputs; Active Low) These pins can be programmed in several different modes of operation. In each channel, $\overline{\text{RTxC}}$ may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock of the digital phase-locked loop. $\overline{\text{RTxCA}}$ can also be programmed for use with the $\overline{\text{SYNCA}}$ pin as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchronous modes. # TRxCA, TRxCB Transmit/Receive Clocks (inputs/Outputs; Active Low) These pins can be <u>programmed</u> in several different modes of operation. TRxC may supply the receive clock or the transmit clock in the input mode or supply the output of the digital phase-locked loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode. ## Channel Controls for Modem, DMA, or Other #### DCDA. DCDB #### Data Carrier Detect (Inputs; Active Low) These pins function as receiver enables if they are programmed as Auto Enables; otherwise, they may be used as general-purpose input pins. Both are Schmitt-trigger buffered to accommodate slow rise-time signals. The ESCC detects pulses on these pins and may interrupt the CPU on both logic level transitions. # DTR/REQA, DTR/REQB Data Terminal Ready/Request (Outputs; Active Low) These outputs follow the inverted state programmed into the DTR bit in WR5. They can also be used as general-purpose outputs or as Request Lines for a DMA controller. #### RTSA RTSB #### Request to Send (Outputs; Active Low) When the Request to Send RTS bit in Write Register 5 is set, the RTS signal goes Low. When the RTS bit is reset in the asynchronous mode and Auto Enable is on, the signal goes High after the transmitter is empty. In SYNC mode or in asynchronous mode with Auto Enable off, the RTS pins strictly follow the inverted state of the RTS bit. Both pins can be used as general-purpose outputs. #### SYNCA #### Synchronization (Input/Output; Active Low) This pin can act either as input, output, or part of the crystal oscillator circuit. In the Asynchronous Receive mode (crystal oscillator option not selected), this pin is input similar to DCD. In this mode, transitions on this line affect the state of the Sync/Hunt status bits in Read Register 0 but have no other function. In External Synchronization mode with the crystal oscillator not selected, this line also acts as an input. In this mode, SYNCA must be driven Low two receive clock cycles after the last bit in the SYNC character is received. Character assembly begins on the rising edge of the receive clock immediately preceding the activation of SYNCA. In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator not selected, this pin acts as an output and is active only during the part of the receive clock cycle in which SYNC characters are recognized. The SYNC condition is not latched, so this output is active each time a SYNC pattern is recognized (regardless of character boundaries). In SDLC mode, this pin acts as an output and is valid on receipt of a flag. #### W/REQA, W/REQB ## Wait/Request (Outputs; Open drain when programmed for a Wait function, driven High or Low when programmed for a Request function) These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the ESCC data rate. The reset state is Wait. #### Control #### $A/\overline{B}$ #### Channel A/Channel B Select (Input) This signal selects the channel in which the read or write operation occurs. #### CE1 #### Chip Enable (Input; Active Low) This signal selects the ESCC for a read or write operation. #### $D/\overline{C}$ #### Data/Control Select (Input) This signal defines the type of information transferred to or from the ESCC. A High means data is transferred; a Low indicates a command is transferred. #### PIN DESCRIPTION (continued) #### Interrupt ĪNT Interrupt Request (Output; Active Low, Open Drain) This signal is activated when the ESCC requests an interrupt. #### INTACK #### Interrupt Acknowledge (Input; Active Low) This signal indicates an active interrupt acknowledge cycle. When $\overline{\text{RD}}$ becomes active, the ESCC places an interrupt vector on the data bus. $\overline{\text{INTACK}}$ is latched by the rising edge of PCLK. #### **Serial Data** RxDa, RxDB Receive Data (Inputs; Active High) These input signals receive serial data at standard TTL levels. #### TxDA, TxDB Transmit Data (Outputs; Active High) These output signals transmit serial data at standard TTL levels. #### Miscellaneous GND Ground VDD +5 Volts PCLK Clock (Input) This is the master ESCC clock used to synchronize internal signals. PCLK is not required to have any phase relationship with the master system clock. PCLK is a TTL-level signal. Maximum transmit rate is 1/4 PCLK. ## PIN DESCRIPTION (Continued) SCSI #### Microprocessor Interface Signals #### $A_0-A_2$ #### Address Lines (Input) These signals are used with $\overline{CE2}$ , $\overline{RD}$ or $\overline{WR}$ to address all internal registers. #### CE<sub>2</sub> #### Chip Enable (Input, Active Low) CE2 enables a read or write of the SCSI controller internal register selected by A<sub>0</sub>-A<sub>2</sub>. #### DACK #### **DMA Acknowledge (Input, Active Low)** DACK resets DRQ and selects the data register for input or output data transfers. #### DRQ #### **DMA Request (Output)** DRQ indicates that the data register is ready to be read or written. DRQ occurs only if DMA mode is TRUE in the Command Register. DRQ is cleared by $\overline{DACK}$ . #### **EOP** #### End of Process (Input, Active Low) EOP is used to terminate a DMA transfer. If asserted during a DMA cycle, the current byte will be transferred, but no additional bytes will be requested. #### IRO #### Interrupt Request (Output) IRQ alerts a microprocessor of an error condition or an event completion. #### RESET #### Reset (Input, Active Low) RESET clears all the SCSI controller registers. It does not force the SCSI RST signal to the active state. #### **SCSI Interface Signals** The following signals are all bidirectional, active-Low, open-collector signals. With 48-mA sink capability, all pins interface directly with the SCSI Bus. #### ACK ### Acknowledge (Input/Output; Open Collector, Active Low) Driven by an Initiator, $\overline{ACK}$ indicates an acknowledgment for a $\overline{REQ/ACK}$ data-transfer handshake. In the Target role, $\overline{ACK}$ is received as a response to the $\overline{REQ}$ signal. #### ATN ### Attention (Input/Output; Open Collector, Active Low) Driven by an Initiator, ATN indicates an Attention condition. This signal is received in the Target role. #### BSY #### Busy (Input/Output; Open Collector, Active Low) This signal indicates that the SCSI Bus is being used and can be driven by both the Initiator and the Target device. #### C/D ### Control/Data (Input/Output; Open Collector, Active Low) A signal driven by the Target, $\overline{\text{C/D}}$ indicates Control or Data information is on the Data Bus. This signal is received by the Initiator. #### Ī/O ### Input/Output (Input/Output; Open Collector, Active Low) I/O is a signal driven by a Target which controls the direction of data movement on the SCSI Bus. TRUE indicates input to the intitiator. This signal is also used to distinguish between Selection and Reselection phases. #### MSG #### Message (Input/Output; Open Collector, Active Low) MSG is a signal driven by the Target during the Message phase. This signal is received by the Initiator. #### REQ #### Request (Input/Output; Open Collector, Active Low) Driven by a Target, REQ indicates a request for a REQ/ACK data-transfer handshake. This signal is received by the Initiator. #### RST ### SCSI Bus RESET (Input/Output; Open Collector, Active Low) The $\overline{RST}$ Signal indicates an SCSI Bus RESET condition. An internal 30 $\mu A$ pull up transistor is built-in to prevent spurious interrupts. #### DBo-DB 7, DBP ## Data Bits, Parity Bit (Input/Output; Open Collector, Active Low) These eight data bits (DB<sub>0</sub>-DB<sub>7</sub>), plus a parity bit (DBP) form the Data Bus. DB7 is the most significant bit (MSB) and has the highest priority during the Arbitration phase. Data parity is odd. Parity is always generated and optionally checked. Parity is not valid during Arbitration. #### SEL #### Select (Input/Output; Open Collector, Active Low) SEL is used by an Initiator to select a Target, or by a Target to reselect an Initiator. #### PIN DESCRIPTION (continued) Common CPU Interface Signals RD Read (Input; Active Low) This signal indicates a read operation and when Am85C80 is selected, enables the Data Bus Drivers. During the interrupt acknowledge cycle for ESCC, this signal gates the interrupt vector onto the bus if the ESCC is the highest priority device requesting an interrupt. It also selects the SCSI input data register when used with DACK. #### WR Write (Input; Active Low) When Am85C80 is selected, along with either $\overline{\text{CE1}}$ or $\overline{\text{CE2}}$ , this signal indicates a write operation. The coincidence of $\overline{\text{RD}}$ and $\overline{\text{WR}}$ is interpreted as a reset for ESCC. It also selects the SCSI output data register when used with $\overline{\text{DACK}}$ . #### D<sub>0</sub>-D<sub>7</sub> Data (Input/Output; Active High) Common data lines for ESCC and SCSI. These lines transfer data into and out of the Am85C80. 3-12 Am85C80 #### SCSI FUNCTIONAL DESCRIPTION #### General The Small Computer Systems Interface (SCSI) device appears as a set of eight registers to the controlling CPU. By reading and writing the appropriate registers, the CPU may initiate any SCSI Bus activity or may sample and assert any signal on the SCSI Bus. This allows the user to implement all or portions of the SCSI protocol in software. These registers are read (written) by activating $\overline{\text{CE2}}$ with an address on $A_{\text{CM}} = A_{\text{CM}}$ and then issuing an $\overline{\text{RD}}$ ( $\overline{\text{WR}}$ ) pulse. This section describes the operation of the internal registers. Table 1. Register Summary Address A<sub>1</sub> A٥ R/W **Register Name** $A_2$ 0 **Current SCSI Data** 0 0 R Output Data 0 0 0 W Initiator Command R/W 0 0 1 0 0 R/W Mode 0 1 R/W Target Command Current SCSI Bus Status 1 0 0 R 1 0 0 W Select Enable **Bus and Status** 1 R 0 1 1 1 W Start DMA Send 0 Input Data 1 1 0 R 0 W Start DMA Target Receive 1 1 Reset Parity/Interrupts 1 1 R W Start DMA Initiator Receive #### **Data Registers** The data registers are used to transfer SCSI commands, data, status, and message bytes between the microprocessor Data Bus and the SCSI Bus. The Am85C80 does not interpret any information that passes through the data registers. The data registers consist of the transparent Current SCSI Data Register, the Output Data Register, and the Input Data Register. User note: a one in a register means the pin is Low. For example, when the ATN Pin is Low, ATN in the bus and status register will be High. ## Current SCSI Data Register—Address 0 (Read Only) The Current SCSI Data Register is a read-only register that allows the microprocessor to read the active SCSI Data Bus. This is accomplished by activating $\overline{CE2}$ with an address on $A_2\!\!-\!\!A_0$ of 000 and issuing an $\overline{RD}$ pulse. If parity checking is enabled, the SCSI Bus parity is checked at the beginning of the read cycle. This register is used during a programmed I/O data read or during Arbitration to check for higher priority arbitrating devices. Parity is not guaranteed valid during Arbitration. Figure 1. Current SCSI Data Register #### Output Data Register-Address 0 (Write Only) The Output Data Register is a write-only register that is used to send data to the SCSI Bus. This is accomplished by either using a normal CPU write, or under DMA control, by using $\overline{WR}$ and $\overline{DACK}$ . This register is also used to assert the proper ID bits or the SCSI Bus during the Arbitration and Selection phases. Figure 2. Output Data Register #### Input Data Register—Address 6 (Read Only) The Input Data Register is a read-only register that is used to read latched data from the SCSI Bus. Data is latched either during a DMA Target receive operation when $\overline{ACK}$ goes active or during a DMA Initiator receive when $\overline{REQ}$ goes active. The DMA Mode bit (port 2, bit 1) must be set before data can be latched in the Input Data Register. This register may be read under DMA control using $\overline{RD}$ and $\overline{DACK}$ . Parity is optionally checked when the Input Data Register is loaded. Figure 3. Input Data Register ## Initiator Command Register—Address 1 (Read/Write) The Initiator Command Register is a read/write register that is used to assert certain SCSI Bus signals, to monitor those signals, and to monitor the progress of bus arbitration. Many of these bits are significant only when being used as Initiators; however, most can be used during Target role operation. 12582C-007A Figure 4-1. Initiator Command Register—Register Read 12582C-008A Figure 4-2. Initiator Command Register—Register Write The following describes the operation of all bits in the Initiator Command Register. #### Bit 7—Assert RST Whenever a one is written to bit 7 of the Initiator Command Register, the RST signal is asserted on the SCSI Bus. The RST signal will remain asserted until this bit is reset or until an external RESET occurs. After this bit is set (1), IRQ goes active and all internal logic and control registers are reset (except for the interrupt latch and the Assert RST bit). Writing a zero to bit 7 of the Initiator Command Register de-asserts the RST signal. Reading this register simply reflects the status of this bit. #### Bit 6—AIP (Arbitration in Progress) (Read Bit) This bit is used to determine if Arbitration is in progress. For this bit to be active, the Arbitrate bit (port 2, bit 0) must have been set previously. It indicates that a Bus-Free condition has been detected and that the chip has asserted BSY and the contents of the Output Data Register (port 0) onto the SCSI Bus. AIP will remain active until the Arbitrate bit is reset. #### Bit 6—Test Mode (Write Bit) This bit may be written during a test environment to disable all output drivers, effectively removing the Am85C80 from the circuit. Resetting this bit returns the part to normal operation. #### Bit 5-LA (Lost Arbitration) (Read Bit) This bit, when active, indicates that the Am85C80 detected a Bus-Free condition, arbitrated for use of the bus by asserting BSY and its ID on the Data Bus, and lost Ar- bitration due to SEL being asserted by another bus device. For this bit to be active, the Arbitrate bit (port 2, bit 0) must be active. #### Bit 5-Diff Enbl (Differential Enable) (Write Bit) This bit should be written with a zero for proper operation. #### Bit 4-Assert ACK This bit is used by the bus initiator to assert $\overline{ACK}$ on the SCSI Bus. In order to assert $\overline{ACK}$ , the Targetmode bit (port 2, bit 6) must be False. Writing a zero to this bit resets $\overline{ACK}$ on the SCSI Bus. Reading this register simply reflects the status of this bit. #### Bit 3—Assert BSY Writing a one (1) into this bit position asserts $\overline{BSY}$ onto the SCSI Bus. Conversely, a zero resets the $\overline{BSY}$ signal. Asserting $\overline{BSY}$ indicates a successful selection or reselection and resetting this bit creates a Bus-Disconnect condition. Reading this register simply reflects the status of this bit. #### Bit 2—Assert SEL Writing a one (1) into this bit position asserts SEL onto the SCSI Bus. SEL is normally asserted after Arbitration has been successfully completed. SEL may be deasserted by resetting this bit to a zero. A read of this register simply reflects the status of this bit. #### Bit 1—Assert ATN ATN may be asserted on the SCSI Bus by setting this bit to a one (1) if the Targetmode bit (port 2, bit 6) is False. ATN is normally asserted by the initiator to request a Message Out bus phase. Note that since Assert SEL and Assert ATN are in the same register, a select with ATN may be implemented with one CPU write. ATN may be de-asserted by resetting this bit to zero. A read of this register simply reflects the status of this bit. #### Bit 0-Assert Data Bus The Assert Data Bus bit, when set, allows the contents of the Output Data Register to be enabled as chip outputs on the signals DB<sub>0</sub>–DB<sub>7</sub>. Parity is also generated and asserted on DBP. When connected as an initiator, the outputs are only enabled if the Targetmode bit (port 2, bit 6) is False, the received signal $\overline{I/O}$ is False, and the phase signals $\overline{(C/D)}$ , $\overline{I/O}$ , and $\overline{I/O}$ match the contents of the Assert $\overline{I/O}$ , Assert $\overline{I/O}$ , and Assert $\overline{MSG}$ in the Target Command Register. This bit should also be set during DMA send operations. #### Mode Register—Address 2 (Read/Write) The Mode Register is used to control the operation of the chip. This register determines whether the Am85C80 operates as an Initiator or a Target, whether DMA transfers are being used, whether parity is checked, and whether interrupts are generated on various external conditions. This register may be read to check the value of these 3-14 Am85C80 internal control bits. Figure 5 describes the operation of these control bits. Figure 5. Mode Register #### Bit 7-Block Mode DMA The Block Mode DMA bit controls the characteristics of the DMA DRQ-DACK handshake. When this bit is reset (0) and the DMA Mode bit is active (1), the DMA handshake uses the normal interlocked handshake, and the rising edge of DACK indicates the end of each byte being transferred. In block mode operations, Block Mode DMA bit set (1), and DMA Mode bit set (1), the end of RD or WR signifies the end of each byte transferred and DACK is allowed to remain active throughout the DMA operation. Ready can then be used to request the next transfer. #### Bit 6-Target Mode The Targetmode bit allows the Am85C80 to operate as either an SCSI Bus Initiator, bit reset (0), or as an SCSI Bus Target device, bit set (1). In order for the signals ATN and ACK to be asserted on the SCSI Bus, the Targetmode bit must be reset (0). In order for the signals C/D, I/O, MSG, and REQ to be asserted on the SCSI Bus, the Targetmode bit must be set (1). #### Bit 5—Enable Parity Checking The Enable Parity Checking bit determines whether parity errors will be ignored or saved in the parity error latch. If this bit is reset (0), parity will be ignored. Conversely, if this bit is set (1), parity errors will be saved. #### **Bit 4—ENABLE PARITY INTERRUPT** The Enable Parity Interrupt bit, when set (1), will cause an interrupt (IRQ) to occur if a parity error is detected. A parity interrupt will only be generated if the Enable Parity Checking bit (bit 5) is also enabled (1). #### Bit 3—Enable EOP Interrupt The Enable EOP Interrupt bit, when set (1), causes an interrupt to occur when the EOP (End of Process) signal is received from the DMA controller logic. #### Bit 2-Monitor Busy The Monitor Busy bit, when True (1), causes an interrupt to be generated for an unexpected loss of $\overline{BSY}$ . When the interrupt is generated due to loss of $\overline{BSY}$ , the lower six bits of the Initiator Command Register are reset (0) and all signals are removed from the SCSI Bus. #### Bit 1-DMA Mode The DMA Mode bit is normally used to enable a DMA transfer and must be set (1) prior to writing ports 5 through 7. Ports 5 through 7 are used to start DMA transfers. The Targetmode bit (port 2, bit 6) must be consis- tent with writes to port 6 and 7 [i.e., set (1) for a write to port 6 and reset (0) for a write to port 7]. The control bit Assert Data Bus (port 1, bit 0) must be True (1) for all DMA send operations. In the DMA mode, REQ and ACK are automatically controlled. The DMA Mode bit is not reset upon the receipt of an EOP signal. Any DMA transfer may be stopped by writing a zero into this bit location; however, care must be taken not to cause CE2 and DACK to be active simultaneously. #### Bit 0-Arbitrate The Arbitrate bit is set (1) to start the Arbitration process. Prior to setting this bit, the Output Data Register should contain the proper SCSI device ID value. Only one data bit should be active for SCSI Bus Arbitration. The Am85C80 will wait for a Bus-Free condition before entering the Arbitration phase. The results of the Arbitration phase may be determined by reading the status bits LA and AIP (port 1, bits 5 and 6, respectively). ## Target Command Register—Address 3 (Read/Write) When connected as a target device, the Target Command Register allows the CPU to control the SCSI Bus Information Transfer phase and/or to assert REQ simply by writing this register. The Targetmode bit (port 2, bit 6) must be True (1) for bus assertion to occur. The SCSI Bus phases are described in Table 2. Table 2. SCSI Information Transfer Phases | Bus Phase | Assert<br>I/O | Assert<br>C/D | Assert<br>MSG | |-------------|---------------|---------------|---------------| | Data Out | 0 | 0 | 0 | | Unspecified | 0 | 0 | 1 | | Command | 0 | 1 | 0 | | Message Out | 0 | 1 | 1 | | Data In | 1 | 0 | 0 | | Unspecified | 1 | 0 | 1 | | Status | 1 | 1 | 0 | | Message In | 1 | 1 | 1 1 | When connected as an Initiator with DMA Mode True, if the phase lines ( $\overline{I/O}$ , $\overline{C/D}$ , and $\overline{MSG}$ ) do not match the phase bits in the Target Command Register, a phase-mismatch interrupt is generated when $\overline{REQ}$ goes active. In order to send data as an Initiator, the Assert $\overline{I/O}$ , Assert $\overline{C/D}$ , and Assert $\overline{MSG}$ bits must match the corresponding bits in the Current SCSI Bus Status Register (port 4). The Assert $\overline{REQ}$ bit (bit 3) has no meaning when operating as an Initiator. Figure 6. Target Command Register The Am85C80 uses bit 7 of the SCSI Target Command Register to determine when the last byte of a DMA Am85C80 3-15 transfer is sent to the SCSI bus. This flag is necessary since the end of DMA bit in the Bus and Status Register only indicates when the last byte was received from the DMA. #### Current SCSI Bus Status Register— Address 4 (Read Only) The Current SCSI Bus Status Register is a read-only register that is used to monitor seven SCSI Bus control signals plus the Data Bus parity bit. For example, an Initiator device can use this register to determine the current bus phase and to poll REQ for pending data transfers. This register may also be used to determine why a particular interrupt occurred. Figure 7 describes the Current SCSI Bus Status Register. Figure 7. Current SCSI Bus Status Register The Am85C80 uses bit 7 of this register to determine when the last byte of a DMA transfer is sent to the SCSI bus. This flag is necessary since the end of DMA bit in the Bus and Status Register only reflects when the last byte was received from the DMA. ## Select Enable Register—Address 4 (Write Only) The Select Enable Register is a write-only register which is used as a mask to monitor a signal ID during a selection attempt. The simultaneous occurrence of the correct ID bit, BSY False, and SEL True will cause an interrupt. This interrupt can be disabled by resetting all bits in this register. If the Enable Parity Checking bit (port 2, bit 5) is active (1), parity will be checked during selection. Figure 8. Select Enable Register ## Bus and Status Register—Address 5 (Read Only) 3-16 The Bus and Status Register is a read-only register that can be used to monitor the remaining SCSI control signals not found in the Current SCSI Bus Status Register (ATN and ACK), as well as six other status bits. Individual descriptions of each bit of the Bus and Status Register follow. Figure 9. Bus and Status Register #### Bit 7-End of DMA Transfer The End Of DMA Transfer bit is set if EOP, DACK, and either RD or WR are simultaneously active for at least 100 ns. Since the EOP signal can occur during the last byte sent to the Output Data Register (port 0), the REQ and ACK signals should be monitored to ensure that the last byte has been transferred. This bit is reset when the DMA Mode bit is reset (0) in the Mode Register (port 2). #### Bit 6—DMA Request The DMA Request bit allows the CPU to sample the output pin DRQ. DRQ can be cleared by asserting DACK or by resetting the DMA Mode bit (bit 1) in the Mode Register (port 2). The DRQ signal does not reset when a phase-mismatch interrupt occurs. #### Bit 5-Parity Error This bit is set if a parity error occurs during a data receive or a device selection. The Parity Error bit can only be set (1) if the Enable Parity Check bit (port 2, bit 5) is active (1). This bit may be cleared by reading the Reset Parity/Interrupt Register (port 7). #### Bit 4—Interrupt Request Active This bit is set if an enabled interrupt condition occurs. It reflects the current state of the IRQ output and can be cleared by reading the Reset Parity/Interrupt Register (port 7). #### Bit 3-Phase Match The SCSI signals, MSG, C/D, and I/O, represent the current Information Transfer phase. The Phase Match bit indicates whether the current SCSI Bus phase matches the lower 3 bits of the Target Command Register. Phase Match is continuously updated and is only significant when operating as a Bus Initiator. A phase match is required for data transfers to occur on the SCSI Bus. #### Bit 2—Busy Error The Busy Error bit is active if an unexpected loss of the BSY signal has occurred. This latch is set whenever the Monitor Busy bit (port 2, bit 2) is True and BSY is False. An unexpected loss of BSY will disable any SCSI outputs and will reset the DMA MODE bit (port 2, bit 1). Am85C80 #### Bit 1—ATN This bit reflects the condition of the SCSI Bus control signal ATN. This signal is normally monitored by the Target device. #### Bit 0—ACK This bit reflects the condition of the SCSI Bus control signal ACK. This signal is normally monitored by the Target device. #### **DMA Registers** Three write-only registers are used to initiate all DMA activity. They are Start DMA Send (port 5), Start DMA Target Receive (port 6), and Start DMA Initiator Receive (port 7). Simply writing these registers starts the DMA transfers. Data presented to the Am85C80 on signals $D_0$ – $D_7$ during the register write is meaningless and has no effect on the operation. Prior to writing these registers, the Block Mode DMA bit (bit 7), the DMA Mode bit (bit 1) and the Targetmode bit (bit 6) in the Mode Register (port 2) must be appropriately set. The individual registers are briefly described as follows. #### Start DMA Send—Address 5 (Write Only) This register is written to initiate a DMA send, from the DMA to the SCSI Bus, for either Initiator or Target role operations. The DMA Mode bit (port 2, bit 1) must be set prior to writing this register. #### Start DMA Target Receive—Address 6 (Write Only) This register is written to initiate a DMA receive—from the SCSI Bus to the DMA—for Target operation only. The DMA Mode bit (bit 1) and the Targetmode bit (bit 6) in the Mode Register (port 2) must both be set (1) prior to writing this register. ### Start DMA Initiator Receive—Address 7 (Write Only) This register is written to initiate a DMA receive—from the SCSI Bus to the DMA, for Initiator operation only. The DMA Mode bit (bit 6) must be False (0) in the Mode Register (port 2) prior to writing this register. #### Reset Parity/Interrupt—Address 7 (Read Only) Reading this register resets the Parity Error bit (bit 5), the Interrupt Request bit (bit 4), and the Busy Error bit (bit 2) in the Bus and Status Register (port 5). #### On-Chip SCSI Hardware Support The Am85C80 is easy to use because of its simple architecture. The chip allows direct control and monitoring of the SCSI Bus by providing a latch for each signal. However, portions of the protocol define timings that are much too quick for traditional microprocessors to control. Therefore, hardware support has been provided for DMA transfers, bus arbitration, phase-change monitoring, bus disconnection, bus reset, parity generation, parity checking, and device selection/reselection. Arbitration is accomplished using a Bus-Free filter to continuously monitor $\overline{BSY}$ . If $\overline{BSY}$ remains inactive for at least 400 ns, then the SCSI Bus is considered free and Arbitration may begin. Arbitration will begin if the bus is free, $\overline{SEL}$ is inactive, and the Arbitration bit (port 2, bit 0) is active. Once arbitration has begun ( $\overline{BSY}$ asserted), an arbitration delay of 2.2 $\mu s$ must elapse before the Data Bus can be examined to determine if Arbitration has been won. This delay must be implemented in the controlling software driver. The Am85C80 has no clock. Delays such as bus-free delay, bus-set delay, and bus-settle delay are implemented using gate delays. These delays may differ between devices because of inherent process variations, but are well within the proposed ANSI X3T9.2 specification. #### Interrupts The Am85C80 provides an interrupt output (IRQ) to indicate a task completion or an abnormal bus occurrence. The use of interrupts is optional and may be disabled by resetting the appropriate bits in the Mode Register (port 2) or the Select Enable Register (port 4). When an interrupt occurs, the Bus and Status Register and the Current SCSI Bus Status Register must be read to determine which condition created the interrupt. IRQ can be reset simply by reading the Reset Parity/Interrupt Register (port 7) or by an external chip reset (RESET active for 100 ns). Assuming the Am85C80 has been properly initialized, an interrupt will be generated if the chip is selected or reselected, if an EOP signal occurs during a DMA transfer, if a SCSI Bus reset occurs, if a parity error occurs during a data transfer, if a bus phase mismatch occurs, or if a SCSI Bus disconnection occurs. #### Selection/Reselection The Am85C80 can generate a select interrupt if SEL is True (1), its device ID is True (1), and BSY is False for at least a bus-settle delay (400 ns). If I/O is active, this should be considered a reselect interrupt. The correct ID bit is determined by a match in the Select Enable Register (port 4). Only a single bit match is required to generate an interrupt. This interrupt may be disabled by writing zeros into all bits of the Select Enable Register. If parity is supported, parity should also be good during the selection phase. Therefore, if the Enable Parity bit (port 2, bit 5) is active, then the Parity Error bit should be checked to ensure that a proper selection has occurred. The Enable Parity Interrupt bit need not be set for this interrupt to be generated. The proposed SCSI specification also requires that no more than two device IDs be active during the selection process. To ensure this, the Current SCSI Data Register (port 0) should be read. The proper values for the Bus and Status Register (port 5) and the Current SCSI Bus Status Register (port 4) for Selection/Reselection interrupt are displayed in Figures 10 and 11, respectively. Figure 10. Condition of Bus and Status Register for Select Interrupt to Occur 12582C-014A Figure 11. Condition of Current SCSI Bus Status Register for Select Interrupt to Occur #### End of Process (EOP) Interrupt An End of Process signal (EOP) that occurs during a DMA transfer (DMA Mode True) will set the End Of DMA Status bit (port 5, bit 7) and will optionally generate an interrupt if the Enable EOP Interrupt bit (port 2, bit 3) is True. The EOP pulse will not be recognized (End Of DMA bit set) unless EOP, DACK, and either RD or WR are concurrently active for at least 100 ns. DMA transfers can still occur if EOP was not asserted at the correct time. This interrupt can be disabled by resetting the Enable EOP Interrupt bit (port 2, bit 3). The proper values for the Bus and Status Register (port 5) and the Current SCSI Bus Status Register (port 4) for this interrupt are shown in Figures 12 and 13, respectively. Figure 12. Condition of Bus and Status Register for End of Process Interrupt to Occur Figure 13. Condition of Current SCSI Bus Status Register for End of Process Interrupt to Occur The End Of DMA bit (port 5, bit 7) is used to determine when a block transfer is complete. Receive operations are complete when there are no data left in the chip and no additional handshakes occurring. The only exception to this is receiving data as an Initiator when the Target opts to send additional data for the same phase. In this case, REQ goes active and the new data is present in the Input Data Register (port 6). Since a phase-mismatch interrupt will not occur, REQ and ACK need to be sampled to determine that the Target is attempting to send more data For send operations, the End Of DMA bit (port 5, bit 7) is set when the DMA finishes its transfer, but the SCSI transfer may still be in progress. If connected as a Target, REQ and ACK should be sampled until both are False. If connected as an Initiator, a phase change interrupt can be used to signal the completion of the previous phase. It is possible for the Target to request additional data for the same phase. In this case, a phase change will not occur and both REQ and ACK must be sampled to determine when the last byte was transferred. #### SCSI Bus Reset The Am85C80 generates an interrupt when the $\overline{RST}$ signal transitions to True. The device releases all bus signals within a bus-clear delay (800 ns) of this transition. This interrupt also occurs after setting the Assert $\overline{RST}$ bit (port 1, bit 7). This interrupt cannot be disabled. (Note: $\overline{RST}$ is not latched in bit 7 of the Current SCSI Bus Status Register (port 4) and may not be active when this port is read. For this case, the Bus Reset interrupt may be determined by default.) The proper values for the Bus and Status Register (port 5) and the Current SCSI Bus Status Register (port 4) for this interrupt are displayed in Figures 14 and 15, respectively. Figure 14. Condition of Bus and Status Register for SCSI Bus Reset to Occur 12582C-018A Figure 15. Condition of Current SCSI Bus Status Register for SCSI Bus Reset to Occur #### **Parity Error** An interrupt is generated for a received parity error if the Enable Parity Check (bit 5) and the Enable Parity Interrupt (bit 4) bits are set (1) in the Mode Register (port 2). Parity is checked during a read of the Current SCSI Data Register (port 0) and during a DMA receive operation. A parity error can be detected without generating an interrupt by disabling the Enable Parity Interrupt bit (port 2, bit 4) and checking the Parity Error flag (port 5, bit 5). The proper values for the Bus and Status Register (port 5) and the Current SCSI Bus Status Register (port 4) for Parity Error interrupt are displayed in Figures 16 and 17, respectively. Figure 16. Condition of Bus and Status Register for Parity Error Interrupt to Occur 12582C-020A Figure 17. Condition of Current SCSI Bus Status Register for Parity Error Interrupt to Occur #### Bus Phase Mismatch The SCSI phase lines are composed of the signals $\overline{I/O}$ , $\overline{C/D}$ , and $\overline{MSG}$ . These signals are compared with the corresponding bits in the Target Command Register: Assert $\overline{I/O}$ (bit 0), Assert $\overline{C/D}$ (bit 1), and Assert $\overline{MSG}$ (bit 2). The comparison occurs continually and is reflected in the Phase Match bit (bit 3) of the Bus and Status Register (port 5). If the DMA Mode bit (port 2, bit 1) is active and a phase mismatch occurs when $\overline{REQ}$ changes from False to True, an interrupt (IRQ) is generated. A phase mismatch prevents the recognition of $\overrightarrow{REQ}$ and removes the chip from the bus during an initiator send operation $(\overrightarrow{DB_0}-\overrightarrow{DB_7}$ and $\overrightarrow{DBP}$ will not be driven even though the Assert Data Bus bit (port 1, bit 0) is active). This interrupt is only significant when connected as an initiator and may be disabled by resetting the DMA Mode bit. (Note: It is possible for this interrupt to occur when connected as a Target if another device is driving the phase lines to a different state.) The proper values for the Bus and Status Register (port 5) and the Current SCSI Bus Status Register (port 4) for Bus Phase Mismatch interrupt to occur are displayed in Figures 18 and 19, respectively. Figure 18. Condition of Bus and Status Register for Bus Phase Mismatch Interrupt to Occur 12582C-022A 3-19 Figure 19. Condition of Current SCSI Bus Status Register for Bus Phase Mismatch Interrupt to Occur #### Loss of BSY If the Monitor Busy bit (bit 2) in the Mode Register (port 2) is active, an interrupt will be generated if the BSY signal goes False for at least a bus-settle delay (400 ns). This interrupt may be disabled by resetting the Monitor Busy bit. Register values are displayed in Figures 20 and 21. Figure 20. Bus and Status Register 12582C-024A Figure 21. Current SCSI Bus Status Register #### **Reset Conditions** Three possible reset situations exist with the Am85C80. #### **Hardware Chip Reset** When the signal $\overline{RST}$ is active for at least 200 ns, the SCSI device is re-initialized and all internal logic and control registers of SCSI are cleared. This is a chip reset only and does not create an SCSI Bus-Reset condition. #### SCSI Bus Reset (RST) Received When an SCSI RST signal is received, an IRQ interrupt is generated and a SCSI chip reset is performed. All internal logic and registers are cleared, except for the IRQ interrupt latch and the Assert RST bit (bit 7) in the Initiator Command Register (port 1). (Note: The RST signal may be sampled by reading the Current SCSI Bus Status Register (port 4); however, this signal is not latched and may not be present when this port is read.) #### SCSI Bus Reset (RST) Issued If the CPU sets the Assert RST bit (bit 7) in the Initiator Command Register (port 1), the RST signal goes active on the SCSI Bus and an internal reset is performed. Again, all internal logic and registers are cleared except for the IRQ interrupt latch and the Assert RST bit (bit 7) in the Initiator Command Register (port 1). The RST signal will continue to be active until the Assert RST bit is reset or until a hardware reset occurs. #### **Data Transfers** Data may be transferred between SCSI Bus devices in one of four modes: (1) Programmed I/O, (2) Normal DMA, (3) Block Mode DMA, or (4) Pseudo DMA. The following sections describe these modes in detail. (Note: For all data transfer operations, DACK and CE2 should never be active simultaneously.) #### **Programmed I/O Transfers** Programmed I/O is the most primitive form of data transfer. The REQ and ACK handshake signals are individually monitored and asserted by reading and writing the appropriate register bits. This type of transfer is normally used when transferring small blocks of data, such as command blocks or message and status bytes. An Initiator send operation would begin by setting the $\overline{C/D}$ , $\overline{I/O}$ , and $\overline{MSG}$ bits in the Target Command Register to the correct state so that a phase match exists. In addition to the phase match condition, it is necessary for the Assert Data Bus bit (port 1, bit 0) to be True and the received I/O signal to be False for the Am85C80 to send data For each transfer, the data is loaded into the Output Data Register (port 0). The CPU then waits for the REQ bit (port 4, bit 5) to become active. Once REQ goes active, the Phase Match bit (port 5, bit 3) is checked and the Assert ACK bit (port 1, bit 4) is set. The REQ bit is sampled until it becomes False and the CPU resets the Assert ACK bit to complete the transfer. #### Normal DMA Mode DMA transfers are normally used for large block transfers. The SCSI chip outputs a DMA request (DRQ) whenever it is ready for a byte transfer. External DMA logic uses this DRQ signal to generate DACK and an RD or an WR pulse to the Am85C80. DRQ goes inactive when DACK is asserted, and DACK goes inactive some time after the minimum read or write pulse width. This process is repeated for every byte. For this mode, DACK should not be allowed to cycle unless a transfer is taking place. #### **Block Mode DMA** Some popular DMA controllers such as the Am9517A provide a Block Mode DMA transfer. This type of transfer allows the DMA controller to transfer blocks of data without relinquishing the use of the Data Bus to the CPU after each byte is transferred; thus, faster transfer rates are achieved by eliminating the repetitive access and release of the CPU Bus. If the Block Mode DMA bit (port 2, bit 7) is active, the Am85C80 will begin the transfer by asserting DRQ. The DMA controller then asserts DACK for the remainder of the block transfer. DRQ goes inactive for the duration of the transfer. Non–Block Mode DMA transfers end when DACK goes False, whereas Block mode transfers end when RD or WR becomes inactive. Since this is the case, DMA transfers may be started sooner in a Block Mode transfer. The methods described under "Halting a DMA Operation" apply for all DMA operations. #### Pseudo DMA Mode To avoid the tedium of monitoring and asserting the request/acknowledge handshake signals for programmed I/O transfers, the system may be designed to implement a pseudo DMA mode. This mode is implemented by programming the Am85C80 to operate in the DMA mode, but using the CPU to emulate the DMA handshake. DRQ may be detected by polling the DMA Request bit (bit 6) in the Bus and Status Register (port 5), by sampling the signal through an external port, or by using it to generate a CPU interrupt. Once DRQ is detected, the CPU can perform a read or write data transfer. This CPU read/write is externally decoded to generate the appropriate DACK and RD or WR signals. Am85C80 Often, external decoding logic is necessary to generate the Am85C80 CE2 signal. This same logic may be used to generate DACK at no extra system cost and provide an increased performance in programmed I/O transfers. #### Halting a DMA Operation The EOP signal is not the only way to halt a DMA transfer. A bus phase mismatch or a reset of the DMA Mode bit (port 2, bit 1) can also terminate a DMA cycle for the current bus phase. #### Using the EOP Signal If EOP is used, it should be asserted for at least 100 ns while DACK and RD or WR are simultaneously active. Note, however, that if RD or WR is not active an interrupt will be generated, but the DMA activity will continue. The EOP signal does not reset the DMA Mode bit. Since the EOP signal can occur during the last byte sent to the Output Data Register (port 0), the REQ and ACK signals should be monitored to ensure that the last byte has transferred. #### **Bus Phase Mismatch Interrupt** A bus phase mismatch interrupt may be used to halt the transfer if operating as an Initiator. Using this method frees the host from maintaining a data length counter and frees the DMA logic from providing the EOP signal. If performing an Initiator send operation, the Am85C80 requires DACK to cycle before ACK goes inactive. Since phase changes cannot occur if ACK is active, either DACK must be cycled after the last byte is sent or the DMA Mode bit must be reset in order to receive the phase mismatch interrupt. #### Resetting the DMA Mode Bit A DMA operation may be halted at any time simply by resetting the DMA Mode bit. It is recommended that the DMA Mode bit be reset after receiving an $\overline{\text{EOP}}$ or bus phase-mismatch interrupt. The DMA Mode bit must then be set before writing any of the start DMA registers for subsequent bus phases. If resetting the DMA Mode bit is used instead of $\overline{EOP}$ for Target role operation, then care must be taken to reset this bit at the proper time. If receiving data as a Target device, the DMA Mode bit must be reset once the last DRQ is received and before $\overline{DACK}$ is asserted to prevent an additional $\overline{REQ}$ from occurring. Resetting this bit causes DRQ to go inactive. However, the last byte received remains in the Input Data Register and may be obtained either by performing a normal CPU read or by cycling $\overline{DACK}$ and $\overline{RD}$ . In most cases $\overline{EOP}$ is easier to use when operating as a Target device. #### **Flowcharts** Flowcharts are provided (see Figures 22 through 25) as a guideline to facilitate your firmware development. Firmware will vary depending on the application and the level of the SCSI protocol being supported. Figure 22. Arbitration and (Re) Selection Am85C80 Figure 23. Command Transfer Phase (Target) Figure 24. Data Transfer to Host via Programmed I/O 12582C-027A 3-24 Am85C80 Figure 25. Data Transfer via DMA 12582C-028A Read Write ### Mode Register (02) Arbitration DMA Mode Monitor BSY Enable EOP Interrupt 12582C-029A Figure 26. Register Reference Chart Read Write | | Reset Parity/Interrupt (07) | | | | | | | | |---|-----------------------------|---|---|---|---|---|---|---| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1 | Х | Х | Х | Х | Х | х | Х | Х | Start DMA Initiator Receive (07) 7 6 5 4 3 2 1 0 X X X X X X X X DF006090 Note: X = Don't Care 12582C-030A Figure 26. Register Reference Chart (continued) #### **ESCC ARCHITECTURE** The ESCC internal structure includes two full-duplex channels, two $10 \times 19$ bit SDLC/HDLC frame status FIFOs, two baud rate generators, internal control and interrupt logic, and a bus interface to a non-multiplexed bus. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface with modems or other external devices (see Logic Symbol). The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are general-purpose in nature and can optionally be used for functions other than modem control. The register set for each channel includes ten control (write) registers, two SYNC character (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a write-only Master Interrupt Control register and three read registers: one containing the vector with status information (Channel B only), one containing the vector without status (A only), and one containing the interrupt Pending bits (A only). The registers for each channel are designated as follows: WR0-WR15—Write Registers 0 through 15. An additional write register, WR7 Prime (WR7'), is available for enabling or disabling additional SDLC/HDLC enhancements if bit D0 of WR15 is set. RR0-RR3, RR10, RR12, RR13, RR15—Read Registers 0 through 3, 10, 12, 13, 15. If bit D2 of WR15 is set, then two additional Read Registers, RR6 and RR7, are available. These registers are used with the $10\times19$ bit Frame Status FIFO. Table 3 lists the functions assigned to each read and write register. The ESCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel). 12582C-031A Figure 27. Block Diagram of ESCC Architecture #### **Data Path** The transmit and receive data path illustrated in Figure 28 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high-speed data. Incoming data are routed through one of several paths (data or CRC) depending on the selected mode (the character length in asynchronous modes also determines the data path). The transmitter has an 8-bit transmit data buffer register loaded from the internal data bus and a 20-bit transmit shift register that can be loaded either from the synccharacter registers or from the transmit data register. Depending on the operational mode, outgoing data are routed through one of four main paths before they are transmitted from the Transmit Data output (TxD). Table 3. Read and Write Register Functions | Read Register Functions | | | Write Register Functions | | | | |-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | RRO<br>RR1 | Transmit/Receive buffer status and External status<br>Special Receive Condition status<br>(also 10 x 19 bit FIFO Frame Reception Status if | WRO | Command Register, Register Pointers CRC initialize, initialization commands for the various modes, shift right/shift left command | | | | | RR2 | WR15 bit D2 is set) Modified interrupt vector | WR1 | Interrupt conditions and data transfer mode definition | | | | | nnz | Unmodified interrupt vector (Channel A only) | WR2<br>WR3<br>WR4 | Interrupt vector (accessed through either channel) Receive parameters and control Transmit/Receive miscellaneous parameters and | | | | | RR3 | Interrupt Pending bits | WR5 | modes | | | | | RR6 | (Channel A only) LSB Byte Count (14-bit counter) (if WR15 bit D2 set) | WR6<br>WR7 | Transmit parameters and controls Sync character or SDLC address field Sync character or SDLC flag | | | | | RR7 | MSB Byte Count (14-bit counter) and 10 × 19 bit FIFO Status (if WR15 bit D2 is set) | WR7′<br>WR8 | SDLC/HDLC enhancements (if bit D0 of WR15 set) Transmit buffer | | | | | RR8<br>RR10 | Receive buffer Miscellaneous XMTR, RCVR status | WR9 | Master interrupt control and reset (accessed through either channel) | | | | | RR12<br>RR13 | Lower byte of baud rate generator time constant<br>Upper byte of baud rate generator time constant | WR10 | Miscellaneous transmitter/receiver control bits, data encoding | | | | | RR15 | External/Status interrupt information | WR11<br>WR12<br>WR13<br>WR14<br>WR15 | Clock mode control, Rx and Tx clock source Lower byte of baud rate generator time constant Upper byte of baud rate generator time constant Miscellaneous control bits, DPLL control External/Status interrupt control | | | | 3-30 Am85C80 #### **DETAILED DESCRIPTION** The functional capabilities of the ESCC can be described from two different points of view; as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a microprocessor peripheral, it interacts with the CPU and provides vectored interrupts and handshaking signals. #### **Data Communications Capabilities** The ESCC provides two independent full-duplex channels programmable for use in any common asynchronous or SYNC data-communication protocol. Figure 29 and the following description briefly detail these protocols. #### **Asynchronous Modes** Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-a-half or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input. If the Low does not persist (as in the case of a transient), the character assembly process does not start. Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of framing error as a new start bit; a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins. The ESCC does not require symmetric transmit and receive clock signals—a feature allowing use of a wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In asynchronous modes, the SYNC pin may be programmed as an input used for functions, such as monitoring a ring indicator. #### **Synchronous Modes** The ESCC supports both byte-oriented and bit-oriented synchronous communication. SYNC byte-oriented protocols can be handled in several modes, allowing character synchronization with a 6-bit or 8-bit SYNC character (Monosync), any 12-bit or 16-bit SYNC pattern (Bisync), or with an external SYNC signal. Leading SYNC characters can be removed without interrupting the CPU. Five- or 7-bit SYNC characters are detected with 8- or 16-bit patterns in the ESCC by overlapping the larger pattern across multiple incoming SYNC characters as shown in Figure 30. Am85C80 CRC checking for Synchronous byte-oriented modes is delayed by one character time so that the CPU may disable CRC checking on specific characters. This permits the implementation of protocols, such as IBM BISYNC. Both CRC-16 ( $X^{16} + X^{15} + X^2 + 1$ ) and CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) error checking polynomials are supported. Either polynomial may be selected in BISYNC and MONOSYNC modes. Users may preset the CRC generator and checker to all "1"s or all "0"s. The ESCC also provides a feature that automatically transmits CRC data when no other data are available for transmission. This allows for high-speed transmissions under DMA control with no need for CPU intervention at the end of a message. When there are no data or CRC to send in SYNC modes, the transmitter inserts 6-, 8-, or 16-bit SYNC characters, regardless of the programmed character length. The ESCC supports SYNC bit-oriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero bit insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the ESCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The ESCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent allowing reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (end-offrame) can be selected. The receiver automatically deletes all "0"s inserted by the transmitter during character assembly. CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. In SDLC mode, the ESCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all "1"s or all "0"s. The CRC is inverted before transmission and the receiver checks against the bit pattern "0001110100001111." NRZ, NRZI or FM coding may be used in any 1X mode. The parity options available in asynchronous modes are available in synchronous modes. The ESCC can be conveniently used under DMA control to provide high-speed reception or transmission. In reception, for example, the ESCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The ESCC then issues an end-of-frame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the ESCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA. #### **SDLC Loop Mode** The ESCC supports SDLC Loop mode in addition to normal SDLC. In an SDLC Loop, there is a primary controller station that manages the message traffic flow and any number of secondary stations. In SDLC Loop mode, the ESCC performs the functions of a secondary station while an ESCC operating in regular SDLC mode can act as a controller (Figure 31). Figure 31. An SDLC Loop A secondary station in an SDLC Loop is always listening to the messages being sent around the loop and, in fact, must pass these messages to the rest of the loop by retransmitting them with a 1-bit time delay. The secondary station can place its own message on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an EOP (End of Poll), around the loop. The EOP character is the bit pattern "11111110." Because of zero insertion during messages, this bit pattern is unique and easily recognized. When a secondary station has a message to transmit and recognizes an EOP on the line, it changes the last binary one of the EOP to a zero before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations further down the loop with messages to transmit can then append their messages to the message of the first secondary station by the same process. Any secondary stations without messages to send merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP). SDLC Loop mode is a programmable option in the ESCC. NRZ, NRZI, and FM coding may all be used in SDLC Loop mode. #### **Baud Rate Generator** Each channel in the ESCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On start-up, the flip-flop on the output is set in a High state; the value in the time constant register is loaded into the counter; and the counter starts counting down. The output of the baud rate generator toggles upon reaching zero; the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter. The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the digital phase-locked loop (see next section). If the receive clock or transmit clock is not programmed to come from the $\overline{TRxC}$ pin, the output of the baud rate generator may be echoed out via the $\overline{TRxC}$ pin. The following formula relates the time constant to the baud rate where PCLK or RTxC is the baud rate generator input frequency in Hz. The clock mode is X1, X16, X32, or X64 as selected in Write Register 4, bits D6 and D7. Synchronous operation modes should select X1 and Asynchronous should select X16, X32, or X64. Time Constant = $$\left[\frac{\text{PCLK or RTxC Frequency}}{2 \text{ (Baud Rate)(Clock Mode)}}\right] - 2$$ The following formula relates the time constant to the baud rate. (The baud rate is in bits/second and the BR clock period is in seconds given by Clock Mode/Clock Frequency.) baud rate = $$\frac{1}{2 \text{ (Time Constant + 2)} \times \text{(BR Clock Period)}}$$ | Time Constant Values<br>for Standard Baud Rates at BR Clock<br>= 3.9936 MHz | | | | | | |-----------------------------------------------------------------------------|----------------|-----------------------------------------|---------------------|--|--| | Rate<br>(Baud) | | Time Constant<br>(decimal/Hex notation) | | | | | 19200<br>9600 | 102<br>206 | , , , | | | | | 7200<br>4800 | 275<br>414 | (0113)<br>(019E) | 0.12%<br>0<br>0.06% | | | | 3600<br>2400<br>2000 | 830<br>996 | | | | | | 1800<br>1200 | 1107<br>1662 | (0453)<br>(067E) | 0.04%<br>0.03%<br>0 | | | | 600<br>300 | 3326<br>6654 | (0CFE)<br>(19FE) | 0 | | | | 150<br>134.5 | 13310<br>14844 | (33FE)<br>(39FC) | 0<br>0.0007% | | | | 110<br>75 | 18151<br>26622 | (46E7)<br>(67FE) | 0.0015%<br>0 | | | | 50 | 39934 | (98FE) | 0 | | | #### **Digital Phase-Locked Loop** The ESCC contains a digital phase-locked loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the ESCC receive clock, the transmit clock, or both. For NRZI encoding, the DPLL counts the 32X clock to create nominal bit times. As the 32X clock is counted, the DPLL is searching the incoming data stream for edges (either 1/0 or 0/1). As long as no transitions are detected, the DPLL output will be free running and its input clock source will be divided by 32, producing an output clock without any phase jitter. Upon detecting a transition the DPLL will adjust its clock output (during the next counting cycle) by adding or subtracting a count of 1, thus producing a terminal count closer to the center of the bit cell. The adding or subtracting of a count of 1 will produce a phase jitter of ±5.63° on the output of the DPLL. Because the ESCC's DPLL uses both edges of the incoming signal to compare with its clock source, the mark-space ratio (50%) of the incoming signal should not deviate by more than $\pm 1.5\%$ if proper locking is to occur. For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15/16 counting transition. The 32X clock for the DPLL can be programmed to come from either the $\overline{RTxC}$ input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the ESCC via the $\overline{TRxC}$ pin (if this pin is not being used as an input). #### Crystal Oscillator When using a crystal oscillator to supply the receive or transmit clocks to a channel of the ESCC, the user should: - Select a crystal oscillator which satisfies the following specifications: - 30 ppm @ 25°C - 50 ppm over temperature of -20° to 70°C - 5 ppm/yr aging - 5 mW drive level - 2. Place crystal across RTxC and SYNC pins - Place 30 pF capacitors to ground from both RTxC and SYNC pins - 4. Set bit D<sub>7</sub> of WR11 to "1." #### Data Encoding The ESCC may be programmed to encode and decode the serial data in four different ways (Figure 6). In NRZ encoding, a "1" is represented by a High level, and a "0" is represented by a Low level. In NRZI encoding, a "1" is represented by no change in level, and a "0" is represented by a change in level. In FM1 (more properly, biphase mark), a transition occurs at the beginning of every bit cell. A "1" is represented by an additional transition at the center of the bit cell, and a "0" is represented by no additional transition at the center of the bit cell. In FMo (bi-phase space), a transition occurs at the beginning of every bit cell. A "0" is represented by an additional transition at the center of the bit cell, and a "1" is represented by no additional transition at the center of the bit cell. In addition to these four methods, the ESCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0/1, the bit is a "0." If the transition is 1/0, the bit is a "1." Figure 32. Data Encoding Methods #### 12302U-U30A #### Auto Echo and Local Loopback The ESCC is capable of automatically echoing everything it receives. This feature is useful mainly in asynchronous modes but works in SYNC and SDLC modes as well. In Auto Echo mode, TxD is RxD. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In this mode, the transmitter is actually bypassed, and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmit. The ESCC is also capable of Local Loopback. In this mode, TxD is RxD just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data, and RxD is ignored (except to be echoed out via TxD). The DCD input is also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works in asynchronous, SYNC and SDLC modes with NRZ, NRZI or FM coding of the data stream. #### I/O Interface Capabilities The ESCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. #### Polling All interrupts are disabled. Three status registers in the ESCC are automatically updated whenever any function is performed. For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer. An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register. #### Interrupts When an ESCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 34 and 35). To speed interrupt response time, the ESCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included. Each of the six sources of interrupts in the ESCC (Transmit, Receive and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write-only. In the ESCC, the IP bit signals a need for interrupt servicing. When an IP bit is set to "1" and the IEI input is High, the INT output is pulled Low, requesting an interrupt. In the ESCC, if the IE bit is set for an interrupt, then the IP for that source can never be set. The IP bits are readable in RR3A. There are three types of interrupts: Transmit, Receive and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receive, Transmit and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the Receive can interrupt the CPU in one of three ways: - Interrupt on First Receive Character or Special Receive condition - Interrupt on all Receive Characters or Special Receive condition - Interrupt on Special Receive condition only Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is one of the following: receiver overrun, framing error in asynchronous mode, end-of-frame in SDLC mode, and optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary Receive Character Available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first Receive Character Interrupt. The main function of the External/Status interrupt is to monitor the signal transitions of the DCD, and SYNCA pins; however, an External/Status interrupt is also caused by a Transmit Underrun condition, a zero count in the baud rate generator, the detection of a Break (asynchronous mode), Abort (SDLC mode) or EOP (SDLC Loop mode) sequence in the data stream. The interrupt caused by the Abort or EOP has a special feature allowing the ESCC to interrupt when the Abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode. In SDLC Loop mode, this feature allows secondary stations to recognize the wishes of the primary station to regain control of the loop during a poll sequence. #### **CPU/DMA Block Transfer** The ESCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the WAIT/REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the DMA Block Transfer mode. To a DMA controller, the ESCC REQUEST output indicates that the ESCC is ready to transfer data to or from memory. To the CPU, the WAIT line indicates that the ESCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The DTR/REQUEST can be used as the transmit request line, thus allowing full-duplex operation under DMA control. #### PROGRAMMING INFORMATION Each channel has fifteen Write registers that are individually programmed from the system bus to configure the functional personality of each channel. Each channel also has eight Read registers from which the system can read Status, Baud rate, or Interrupt information. On the ESCC, only four data registers (Read and Write for Channels A and B) are directly selected by a High on the $D/\overline{C}$ input and the appropriate levels on the $\overline{RD}$ , $\overline{WR}$ and $A/\overline{B}$ pins. All other registers are addressed indirectly by the content of Write Register 0 in conjunction with a Low on the $D/\overline{C}$ input and the appropriate levels on the $\overline{RD}$ , $\overline{WR}$ and $A/\overline{B}$ pins. If bit D3 in WR0 is 1 and bits 5 and 6 are 0, then bits 0, 1, 2 address the higher registers 8 through 15. If bits 4, 5, 6 contain a different code, bits 0, 1, 2 address the lower registers 0 through 7 as shown in Table 4. Writing to or reading from any register except RR0, WR0 and the Data Registers thus involves two operations: First, write the appropriate code into WR0, then follow this by a write or read operation on the register thus specified. Bits 0 through 4 in WR0 are automatically cleared after this operation, so that WR0 then points to WR0 or RR0 again. Channel A/Channel B selection is made by the A/ $\overline{B}$ input (HIGH = A, Low = B) The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first. Then the interrupt mode would be set and, finally, receiver or transmitter enable. **Table 4. Register Addressing** | D/C | "Point High"<br>Code In WR0: | D2, D1, D0<br>In WR0: | | Write<br>Register | Read<br>Register | | |------|------------------------------|-----------------------|---|-------------------|------------------|------| | HIGH | Either Way | x | x | х | Data | Data | | LOW | Not True | 0 | 0 | 0 | 0 | 0 | | LOW | Not True | 0 | 0 | 1 | 1 1 | 1 | | LOW | Not True | 0 | 1 | 0 | 2 | 2 | | LOW | Not True | 0 | 1 | 1 | 3 | 3 | | LOW | Not True | 1 | 0 | 0 | 4 | (0) | | LOW | Not True | 1 | 0 | 1 | 5 | (1) | | LOW | Not True | 1 | 1 | 0 | 6 | (2) | | LOW | Not True | 1 | 1 | 1 | 7 | (3) | | LOW | True | 0 | 0 | 0 | Data | Data | | LOW | True | 0 | 0 | 1 | 9 | - | | LOW | True | 0 | 1 | 0 | 10 | 10 | | Low | True | 0 | 1 | 1 | 11 | (15) | | LOW | True | 1 | 0 | 0 | 12 | 12 | | LOW | True | 1 | 0 | 1 | 13 | 13 | | LOW | True | 1 | 1 | 0 | 14 | (10) | | LOW | True | 1 | 1 | 1 | 15 | 15 | #### **Read Registers** The ESCC contains eight read registers [actually nine, counting the receive buffer (RR8) in each channel]. Four of these may be read to obtain status information (RR0, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). RR3 contains the Interrupt Pending (IP) bits (Channel A). In addition, if bit D2 of WR15 is set, RR6 and RR7 are available for providing frame status from the 10 × 19 bit Frame Status FIFO. Figure 33 shows the formats for each read register. The status bits of RR0 and RR1 are carefully grouped to simplify status monitoring, for example, when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1). Figure 33. Read Register Bit Functions Figure 33. Read Register Bit Functions (continued) #### Write Registers The ESCC contains 15 write registers (16 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. Two registers (WR9 and WR9) are shared by the two channels that can be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. In addition, if bit D0 of WR15 is set, write register seven prime (WR7') is available for programming additional SDLC/HDLC enhancements. When bit D0 of WR15 is set, executing a write to WR7 actually writes to WR7' to further enhance the functional "personality" of each channel. Figure 34 shows the format of each write register. Figure 34. Write Register Bit Functions 3\_38 Am85C80 Figure 34. Write Register Bit Functions (continued) 12582C-054A 12582C--055A Figure 34. Write Register Bit Functions (continued) Am85C80 Figure 34. Write Register Bit Functions (continued) ### **ESCC Timing** The ESCC generates internal control signals from WR and RD that are related to PCLK. Since PCLK has no phase relationship with WR and RD, the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the ESCC. The recovery time required for proper operation is specified from the falling edge of WR or RD in the first transaction involving the ESCC, to the falling edge of WR or RD in the second transaction involving the ESCC. This time must be at least 3 1/2 PCLK regardless of which register or channel is being accessed. #### Interrupt Acknowledge Cycle Timing Figure 37 illustrates Interrupt Acknowledge cycle timing. The ESCC may be programmed to respond to RD Low by ### Read Cycle Timing Figure 35 illustrates Read cycle timing. Addresses on A/B and D/C and the status on INTACK must remain stable throughout the cycle. If CE1 falls after RD falls or if it rises before RD rises, the effective RD is shortened. CE2 and DACK must be inactive. ### Write Cycle Timing Figure 36 illustrates Write Cycle timing. Addresses on A/B and D/C and the status on INTACK must remain stable throughout the cycle. If CE1 falls after WR falls or if it rises before WR rises, the effective WR is shortened. Data must be valid before the rising edge of WR. CE2 and DACK must be inactive. placing its interrupt vector on D0–D7 and it then sets the appropriate Interrupt-Under-Service latch internally. Figure 35. Read Cycle Timing Figure 36. Write Cycle Timing Figure 37. Interrupt Acknowledge Cycle Timing 3-42 Am85C80 ### **FIFO** #### **FIFO Enhancements** When used with a DMA controller, the ESCC Frame Status FIFO enhancement maximizes the ESCC's ability to receive high-speed back-to-back SDLC messages while minimizing frame overruns due to CPU latencies in responding to interrupts. Additional logic was added to the industry-standard NMOS Am8530H consisting of a 10-deep by 19-bit status FIFO, a 14-bit receive byte counter, and control logic as shown in Figure 38. The 10×19 bit status FIFO is separate from the existing three-byte receive data and Error FIFOs. All Sent bypasses MUX and equals contents of ESCC Status Register Parity bits bypasses MUX and does the same • EOF is set to 1 whenever reading from the FIFO 12582C-066A Figure 38. ESCC Status Register Modifications When the enhancement is enabled, the status in Read Register 1 (RR1) and byte count for the SDLC frame will be stored in the $10 \times 19$ bit status FIFO. This allows the DMA controller to transfer the next frame into memory while the CPU verifies that the message was properly received. Summarizing the operation, data is received, assembled, and loaded into the three-byte receive FIFO before being transferred to memory by the DMA controller. When a flag is received at the end of an SDLC frame, the frame byte count from the 14-bit counter and five status bits are loaded into the status FIFO for verification by the CPU. The CRC checker is automatically reset in preparation for the next frame which can begin immediately. Since the byte count and status are saved for each frame, the message integrity can be verified at a later time. Status information for up to 10 frames can be stored before a status FIFO overrun could occur. If receive interrupts are enabled while the $10 \times 19$ FIFO is enabled, an SDLC end-of-frame special condition will not lock the three-byte Receive data FIFO. An SDLC end-of-frame still locks the three-byte Receive data FIFO in "Interrupt on first Receive Character or Special Condition" and "Interrupt on Special Condition Only" modes when the $10 \times 19$ FIFO is disabled. This feature allows the 10 × 19 SDLC FIFO to accept multiple SDLC frames without CPU intervention at the end of each frame. #### FIFO Detail For a better understanding of details of the FIFO operation, refer to the block diagram contained in Figure 38. #### Enable/Disable This FIFO is implemented so that it is enabled when WR15 bit 2 is set and the ESCC is in the SDLC/HDLC mode, otherwise the status register contents bypass the FIFO and go directly to the bus interface (the FIFO pointer logic is reset either when disabled or via a channel or power-on reset). When the FIFO mode is disabled, the ESCC is completely downward-compatible with the NMOS Am8530H. The FIFO mode is disabled on powerup (WR15 bit 2 is set to "0" on reset). The effects of backward compatibility on the register set are that RR4 is an image of RR0, RR5 is an image of RR1, RR6 is an image of RR2, and RR7 is an image of RR3. For the details of the added registers, refer to Figure 15. The status of the FIFO Enable signal can be obtained by reading RR15 bit 2. If the FIFO is enabled, the bit will be set to "1"; otherwise, it will be reset. ### **Read Operation** When WR15 bit 2 is set and the FIFO is not empty, the next read to status register RR1 or the additional registers RR7 and RR6 will actually be from the FIFO. Reading status register RR1 causes one location of the FIFO to be emptied, so status should be read after reading the byte count, otherwise the count will be incorrect. Before the FIFO underflows, it is disabled. In this case, the multiplexer is switched to allow status to be read directly from the status register, and reads from RR7 and RR6 will contain bits that are undefined. Bit 6 of RR7 (FIFO Data Available) can be used to determine if status data is coming from the FIFO or directly from the status register, since it is set to "1" whenever the FIFO is not empty. Because not all status bits are stored in the FIFO, the All Sent, Parity, and EOF bits will bypass the FIFO. The status bits sent through the FIFO will be Residue Bits (3), Overrun, and CRC Error. The sequence for proper operation of the byte count and FIFO logic is to read the registers in the following order, RR7, RR6, and RR1 (reading RR6 is optional). Additional logic prevents the FIFO from being emptied by multiple reads from RR1. The read from RR7 latches the FIFO empty/full status bit (bit 6) and steers the status multiplexer to read from the ESCC megacell instead of the status FIFO (since the status FIFO is empty). The read from RR1 allows an entry to be read from the FIFO (if the FIFO was empty, logic is added to prevent a FIFO underflow condition). ### Write Operation When the end of an SDLC frame (EOF) has been received and the FIFO is enabled, the contents of the status and byte-count registers are loaded into the FIFO. The EOF signal is used to increment the FIFO. If the FIFO overflows, the MSB of RR7 (FIFO Overflow) is set to indicate the overflow. This bit and the FIFO control logic is reset by disabling and re-enabling the FIFO control bit (WR15 bit 2). For details of FIFO control timing during an SDLC frame, refer to Figure 39. Figure 39. SDLC Byte Counting Detail #### **Byte Counter Detail** The 14-bit byte counter allows for packets up to 16K bytes to be received. For a better understanding of its operation, refer to Figures 38 and 39. #### Enable The byte counter is enabled when the ESCC is in the SDLC/HDLC mode and WR15 bit 2 is set to "1." #### Reset The byte counter is reset whenever an SDLC flag character is received. The reset is timed so that the contents of the byte counter are successfully written into the FIFO. #### Increment The byte counter is incremented by writes to the data FIFO. The counter represents the number of bytes received by the ESCC, rather than the number of bytes transferred from the ESCC. (These counts may differ by up to the number of bytes in the receive data FIFO contained in the ESCC.) Am85C80 = No Change From NMOS Am8530H DFN 12582C-068A Figure 40. ESCC Additional Registers ESCC SDLC/HDLC Enhancement Register Access SDLC/HDLC enhancements on the ESCC are enabled or disabled via bits D2 or D0 in WR15. Bit D2 determines whether or not the 10 $\times$ 19 bit SDLC/HDLC frame status FIFO is enabled while bit D0 determines whether or not other enhancements are enabled via WR7'. Table 5 shows what functions on the ESCC are enabled when these bits are set. **Table 5. Enhancement Options** | WR15 Bit D2<br>10 × 19 Bit<br>FIFO Enabled | WR15 Bit D0<br>SDLC/HDLC<br>Enhancement Enabled | WR7' Bit D6<br>Extended<br>Read Enabled | Functions<br>Enabled | |--------------------------------------------|-------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------| | 1 | 0 | × | 10 × 19 bit FIFO enhancement enabled only | | o | 1 | 0 | SDLC/HDLC enhancements enabled only | | o | 1 | 1 | SDLC/HDLC enhancements<br>enabled with extended read<br>enabled | | 1 | 1 | 0 | 10 × 19 bit FIFO and<br>SDLC/HDLC enhancements<br>enabled | | 1 | 1 | 1 | 10 × 19 bit FIFO and SDLC/HDLC enhancements with extended read enabled | When bit D2 of WR15 is set to "1," two additional registers (RR6 and RR7) per channel specific to the $10 \times 19$ bit Frame Status FIFO are made available. The ESCC register map when this function is enabled is shown in Table 6. Table 6. 10 × 19 Bit FIFO Enabled | A/B | PNT₂ | PNT <sub>1</sub> | PNT₀ | Write | Read | |-------|------|------------------|----------------|-------|---------| | 0 | 0 | 0 | 0 | WR0B | RR0B | | 0 | 0 | 0 | 1 | WR1B | RR1B | | 0 | 0 | 1 | 0 | WR2 | RR2B | | 0 | 0 | 1 | 1 | WR3B | RR3B | | 0 | 1 | 0 | 0 | WR4B | (RR0B) | | 0 | 1 | 0 | 1 | WR5B | (RR1B) | | 0 | 1 | 1 | 0 | WR6B | RR6B | | 0 | 1 | 1 | 1 | WR7B | RR7B | | 1 | 0 | 0 | 0 | WR0A | RR0A | | 1 | 0 | 0 | 1 | WR1A | RR1A | | 1 | 0 | 1 | 0 | WR2 | RR2A | | 1 | 0 | 1 | 1 | WR3A | RR3A | | 1 | 1 | 0 | 0 | WR4A | (RR0A) | | 1 | 1 | 0 | 1 | WR5A | (RR1A) | | 1 | 1 | 1 | 0 | WR6A | RR6A | | 1 | 1 | 1 | 1 | WR7A | RR7A | | | | With the Pol | nt High commar | nd: | | | 0 | 0 | 0 | 0 | WR8B | RR8B | | 1 0 | 0 | 0 | 1 | WR9 | RR13B | | 0 | 0 | 1 | 0 | WR10B | RR10B | | l · o | 0 | 1 | 1 | WR11B | (RR15B) | | 0 | 1 | 0 | 0 | WR12B | RR12B | | 0 | 1 | Ö | 1 | WR13B | RR13B | | 0 | 1 | 1 | 0 | WR14B | (RR10B) | | 0 | 1 | 1 | 1 | WR15B | RR15B | | 1 1 | Ö | Ò | Ö | WR8A | RR8A | | 1 | Ö | Ö | 1 | WR9 | (RR13A) | | 1 1 | Ö | 1 | 0 | WR10A | RR10A | | 1 1 | ō | 1 | 1 | WR11A | (RR15A) | | 1 1 | 1 | Ó | Ö | WR12A | RR12A | | 1 1 | 1 | Õ | 1 | WR13A | RR13A | | 1 1 | 1 | 1 | 0 | WR14A | (RR10A) | | 1 | 1 | 1 | 1 | WR15A | RR15A | Bit D0 of WR15 determines whether or not other enhancements pertinent only to SDLC/HDLC Mode operation are available for programming via WR7' as shown below. Write Register 7 prime (WR7') can be written to when bit D0 of WR15 is set to "1." When this bit is set, writing to WR7 (flag register) actually writes to WR7'. If bit D6 of this register is set to "1," previously unreadable registers WR3, WR4, WR5, and WR10 are readable by the processor. In addition, WR7' is also readable by having this bit set. WR3 is read when a bogus RR9 register is accessed during a read cycle. WR10 is read by accessing RR11, and WR7' is accessed by executing a read to RR14. The ESCC register map with bit D0 of WR15 and bit D6 of WR7' set is shown in Table 7. | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |---------------------|---------------------|-----------------|----------------------|-------------------|----------------------------------|--------------------------------|------------------------------| | Must Be Set<br>to 0 | Ext. Read<br>Enable | Rx comp.<br>CRC | DTR/REQ<br>Fast Mode | Force TxD<br>High | SDLC/HDLC<br>Auto RTS<br>Turnoff | SDLC/HDLC<br>Auto EOM<br>Reset | SDLC/HDLC<br>Auto<br>Tx Flag | WR7'---SDLC/HDLC Programmable Enhancements\* #### \*Note: Options 3, 4, 5, and 6 may be used regardless of whether SDLC/HDLC mode is selected. 3-46 Am85C80 Table 7. SDLC/HDLC Enhancements Enabled | | | | | 144-14- | Dood | |------|------------------|------------------|----------------|---------|---------------| | A/B | PNT <sub>2</sub> | PNT <sub>1</sub> | PNT₀ | Write | Read | | 0 | 0 | 0 | 0 | WR0B | RR0B | | l ŏ. | Ö | 0 | 1 | WR1B | RR1B | | Ŏ | Ō | 1 | 0 | WR2 | RR2B | | 0 | Ō | 1 | 1 | WR3B | RR3B | | l ŏ | 1 | 0 | 0 | WR4B | RR4B (WR4B) | | l o | 1 | 0 | 1 | WR5B | RR5B (WR5B) | | 0 | 1 | 1 | 0 | WR6B | (RR2B) | | l ŏ | 1 | 1 | 1 | WR7B | (RR3B) | | 1 | 0 | 0 | 0 | WR0A | RR0A | | 1 | 0 | 0 | 1 | WR1A | RR1A | | 1 | 0 | 1 | 0 | WR2 | RR2A | | 1 1 | 0 | 1 | 1 | WR3A | RR3A | | 1 | 1 | 0 | 0 | WR4A | RR4A (WR4A) | | 1 | 1 | 0 | 1 | WR5A | RR5A (WR5A) | | 1 | 1 | 1 | 0 | WR6A | (RR2A) | | 1 | 1 | 1 | 1 | WR7A | (RR3A) | | | | With the Po | int High comma | ind: | | | 0 | 0 | 0 | 0 | WR8B | RR8B | | Ĭ | Ö | Ō | 1 | WR9 | RR9 (WR3B) | | ŏ | Ö | 1 | 0 | WR10B | RR10B | | ň | Ö | 1 | 1 | WR11B | RR11B (WR10B) | | l ŏ | 1 | 0 | 0 | WR12B | RR12B | | Ŏ | 1 | 0 | 1 | WR13B | RR13B | | 0 | 1 | 1 | 0 | WR14B | RR14B (WR7′B) | | 0 | 1 | 1 | 1 | WR15B | RR15B | | 1 1 | 0 | 0 | 0 | WR8A | RR8A | | 1 1 | Ō | 0 | 1 | WR9 | RR9A (WR3A) | | 1 | Ö | 1 | 0 | WR10A | RR10A | | 1 | 0 | 1 | 1 | WR11A | RR11A (WR10A) | | 1 | 1 | 0 | 0 | WR12A | RR12A | | 1 | 1 | 0 | 1 | WR13A | RR13A | | 1 | 1 | 1 | 0 | WR14A | RR14A (WR7A) | | 1 | 1 | 1 | 1 | WR15A | RR15A | If both bits D0 and D2 of WR15 are set to "1" and D6 of WR7' is set to "1," then the ESCC register map is as shown in Table 8. Table 8. SDLC/HDLC Enhancements and 10 imes 19 Bit FIFO Enabled | A/B | PNT <sub>2</sub> | PNT <sub>1</sub> | PNT₀ | Write | Read | |-----|------------------|------------------|---------------|-------|---------------| | 0 | 0 | 0 | 0 | WR0B | RR0B | | 0 | 0 | 0 | 1 | WR1B | RR1B | | 0 | 0 | 1 | 0 | WR2 | RR2B | | 0 | 0 | 1 | 1 | WR3B | RR3B | | 0 | 1 | 0 | 0 | WR4B | RR4B (WR4B) | | 0 | 1 | 0 | 1 | WR5B | RR5B (WR5B) | | 0 | 1 | 1 | 0 | WR6B | RR6B | | 0 | 1 | 1 | 1 | WR7B | RR7B | | 1 | 0 | 0 | 0 | WR0A | RR0A | | 1 | 0 | 0 | 1 | WR1A | RR1A | | 1 | 0 | 1 | 0 | WR2 | RR2A | | 1 | 0 | 1 | 1 | WR3A | RR3A | | 1 | 1 | 0 | 0 | WR4A | RR4A (WR4A) | | 1 | 1 | 0 | 1 | WR5A | RR5A (WR5A) | | 1 | 1 | 1 | 0 | WR6A | RR6A | | 1 | 1 | 1 | 1 | WR7A | RR7A | | | | With the Poi | nt High comma | nd: | | | 0 | 0 | 0 | 0 | WR8B | RR8B | | 0 | 0 | 0 | 1 | WR9 | RR9 (WR3B) | | 0 | 0 | 1 | 0 | WR10B | RR10B | | 0 | 0 | 1 | 1 | WR11B | RR11B (WR10B) | | 0 | 1 | 0 | 0 | WR12B | RR12B | | 0 | 1 | 0 | 1 | WR13B | RR13B | | 0 | 1 | 1 | 0 | WR14B | RR14B (WR7'B) | | 0 | 1 | 1 | 1 | WR15B | RR15B | | 1 | 0 | 0 | 0 | WR8A | RR8A | | 1 | 0 | 0 | 1 | WR9 | RR9A (WR3A) | | 1 | 0 | 1 | 0 | WR10A | RR10A | | 1 | 0 | 1 | 1 | WR11A | RR11A (WR10A) | | 1 | 1 | 0 | 0 | WR12A | RR12A ` | | 1 | 1 | 0 | 1 | WR13A | RR13A | | 1 | 1 | 1 | 0 | WR14A | RR14A (WR7'A) | | 1 | 1 | 1 | 1 | WR15A | RR15A | ## Auto RTS Reset On the CMOS ESCC, if bit D0 of WR15 and bit D2 of WR7' are set to "1" and the channel is in SDLC Mode, the RTS pin may be reset early in the Tx Underrun routine and the RTS pin will remain active until the last zero bit of the closing flag leaves the TxD pin as shown in Figure 16. Note that in order for this to function properly, bits D3 and D2 of WR10 must be set to "1" and "0" respectively. 12582C-069A Figure 41. Auto RTS Reset Mode 3-48 Am85C80 # CRC Character Reception NMOS Am8530H On the NMOS Am8530H, when the end-of-frame flag is detected, the contents of the Receive Shift Register are transferred to the Receive Data FIFO regardless of the number of bits accumulated. Because of the 3-bit delay between the Receive SYNC Register and Receive Shift Register, the last two bits of the CRC check character received are never transferred to the Receive Data FIFO. Thus, the received CRC characters are unavailable for use. ### **CMOS ESCC** PRELIMINARY On the ESCC, the option of being able to receive the complete CRC characters generated by the Transmitter is provided when both bit D0 of WR15 and bit D5 of WR7′ are set to "1." When these two bits are set and an end-of-frame flag is detected, the last two bits of the CRC will be clocked into the Receive Shift Register before its contents are transferred to the Receive Data FIFO.The data-CRC boundary and CRC character bit formatsfor each Residue Code provided is shown in Figures 42A through 42D for each character length selected. Residue Code 012 D D D D n D C<sub>1</sub> C₂ Сз D D D D Co C<sub>6</sub> TC7 Cs Cı C2 Сз C<sub>4</sub> C<sub>5</sub> C<sub>9</sub> C13 C10 C11 C12 C<sub>7</sub> Ĉ6 Cs C10 C11 C12 C13 C14 12582C-070A Figure 42A. 5 Bits/Character 12582C-071A Figure 42B. 6 Bits/Character Code 012 011 D D D D D D D D D D D D Co Ci D C2 C<sub>6</sub> C<sub>3</sub> C₄ Сs C7 C8 Cı C<sub>10</sub> C11 C<sub>12</sub> C13 C14 C15 12582C-072A Figure 42C. 7 Bits/Character 12582C-073A Figure 42D. 8 Bits/Character #### **Auto Flag Mode** On the NMOS Am8530H, if the transmitter is actively mark idling and a frame of data is ready to be transmitted, the MARK/FLAG idle bit must be set to "0" before data is written to WR8, otherwise the opening flag will not be sent properly. However, care must be exercised in doing this because the mark idle pattern (eight "1" bits) is transmitted eight bits at a time, and all eight bits must have transferred out the Transmit Shift Register before a flag may be loaded and sent. If data is written into the Transmit Buffer (WR8) before the flag is loaded into the Transmit Shift Register, the data character written to WR8 will supersede flag transmission and the opening flag will not be transmitted. On the CMOS ESCC, if bit D0 of WR15 is set to "1," and the ESCC is programmed for SDLC operation, an option is provided via bit D0 of WR7′ that eliminates this requirement. If bit D0 of WR7′ is set to "1" and a character is written to the Transmit Buffer while the Transmiter is mark/flag Idle bit in WR10 need not be reset to "0" in order to have the opening flag sent because the Transmitter will automatically send it before commencing to send data. In addition, as long as bit D0 of WR15 and bit D1 of WR7′ are set to "1," the CRC transmit generator will be automatically preset to the initial state programmed by bit D7 of WR10 (so the Reset Tx CRC Generator command is also not necessary), and the Tx Underrun/EOM latch will be reset automatically on every new frame sent. This ensures that an opening flag and proper CRC generation and transmission will always be sent without processor intervention under varying bus latency conditions. ### **Auto Transmit CRC Generator Preset** The NMOS Am8530H does not automatically preset the CRC generator prior to frame transmission. This must be done in software, usually during the initialization routine. This is accomplished by issuing the Reset Tx CRC Generator Command via WR0. For proper results, this command must be issued while the transmitter is enabled and idling and before any data are written to the Transmit Buffer. In addition, if CRC is to be used, the transmit CRC generator must be enabled by setting bit D0 of WR5 to "1." CRC is normally calculated on all characters between opening and closing flags, so this bit should be set to "1" at initialization and never changed. On the CMOS ESCC, setting bit D0 of WR15 to "1" will cause the transmit CRC generator to be preset automatically every time an opening flag is sent, so the Reset Tx CRC Generator Command is not necessary. #### Auto Tx Underrun/EOM Latch Reset On the ESCC, the transmission of the CRC check characters is controlled by the Transmit CRC Enable bit in WR5 (D0) and the Tx Underrun/EOM bit in RR0 (D6). However, if the Transmit Enable bit is set to "0" when a transmit underrun (i.e., both the Transmit Buffer and Transmit Shift Register go empty) occurs, the CRC check characters will not be sent regardless of the state of the Tx Underrun/EOM bit. If the Transmit Enable bit is set to "1" when an underrun occurs, then the state of the Tx Underrun/EOM bit and the Abort/Flag on Underrun bit in WR10 (D2) determine the action taken by the Transmitter. The Abort/Flag on Underrun bit may be set or reset by the processor, whereas, the Tx Underrun/EOM bit is set by the Transmitter and can only be reset by the processor via the Reset Tx Underrun/EOM Command in WR0. If the Tx Underrun/EOM bit is set to "1" when an underrun occurs, the Transmitter will close the frame by sending a flag; however, if this bit is set to "0," the frame data will be appended with either the accumulated CRC characters followed by a flag or an abort pattern followed by a flag, depending on the state of the Abort/Flag on Underrun bit in the WR10 (D2). In either case, after the closing flag is sent, the Transmitter will idle the transmission line as specified by the Mark/Flag Idle bit D3 in WR10. Hence, if the CRC check characters are to be properly appended to a frame, the Abort/Flag on Underrun bit must be set to "0," and the Reset Tx Underrun/EOM Command must be issued after the first but before the last character is written to the Transmit Buffer. This will ensure that either an abort or the CRC will be transmitted if an underrun occurs. Normally, the Abort/Flag on Underrun bit in WR10 should be set to "1" around the same time that the Tx Underrun/EOM bit is reset so that an abort will be sent if the transmitter accidentally underruns, and then set to "0" near the end of the frame to allow the correct transmission of CRC. On the ESCC, if bit D0 of WR15 is set to "1," the option of having the Tx Underrun/EOM bit reset automatically at the start of every frame is provided via bit D1 of WR7'. This helps alleviate the software burden of having to respond within one character time when high-speed data are being sent. ## SDLC/HDLC NRZI Transmitter Disabling On the NMOS Am8530H, if NRZI encoding is being used and the Transmitter is disabled, the state of the TxD pin will depend on the last bit sent. That is, the TxD pin may either idle in a Low or High state as shown in Figure 43. On the CMOS ESCC, an option is provided that allows setting the TxD pin High when operating in SDLC Mode with NRZI encoding enabled. If bit D0 of WR15 is set to "1," then bit D3 of WR7' can be used to set the TxD pin High. Note that the operation of this bit is independent of the Tx Enable bit in WR5. The Tx Enable bit in WR5 is used to disable and enable the transmitter, whereas bit D3 of WR7' acts as a pseudo transmitter disable and enable by just forcing the TxD pin High when set even though the transmitter may actually be mark or flag idling. Care must be used when setting this bit because any character being transmitted at the time this bit is set will be "chopped off," and data written to the Transmit Buffer while this bit is set will be lost. When the transmit underrun occurs and the CRC and closing flag have been sent, bit D3 can be set to pull TxD High. When ready to start sending data again this bit must be reset to "0" before the first character is written to the Transmit Buffer. Note that resetting this bit causes the TxD pin to take whatever state the NRZI encoder is in at the time so synchronization at the Receiver may take longer because the first transition seen on the TxD pin may not coincide with a bit boundary. Note that in order for this to function properly, bits D3 and D2 of WR10 must be set to "1" and "0" respectively. Figure 43. Transmitter Disabling with NRZI Encoding ## Interrupt Masking Without INTACK The NMOS Am8530H's ability to mask lower priority interrupts is done via the IUS bit. This bit is internal to the ESCC and is not observable by the processor. Being able to automatically mask lower priority interrupts allows a modular approach to coding interrupt joutines. However, using the masking capabilities of the NMOS ESCC requires that the INTACK cycle be generated. In stand-alone applications, having to generate INTACK through external hardware in order to use this capability is an unnecessary expense. On the CMOS ESCC, if bit D5 in WR9 is set to "1," the INTACK cycle does not need to be generated in order to have the IUS bit set. This allows the user to respond to ESCC interrupt requests with a software acknowledgment through RR2. When bit D5 in WR9 is set and an interrupt occurs, a read to RR2 emulates a hardware Interrupt Acknowledge cycle as it functions in Vectored Mode. In this case the CPU must first read RR2 to determine the interrupt routine. Reading RR2 sets the IUS bit for the highest priority IP. After the interrupting condition is cleared, the routine can then read RR3 to determine if any other IPs are set and clear them. At the end of the in- terrupt routine, a Reset IUS Command must be issued to unlock the internal daisy chain. Since the CPU can acknowledge the ESCC of highest priority with a read of its RR2 interrupt vector, there is no need for an external daisy chain. When acknowledging an ESCC interrupt request, the CPU must issue one read to RR2 per interrupt request. The modified interrupt vector can be read from Channel B, or the original vector stored in WR2 can be read from Channel A. Either action will produce the same internal actions on the IUS logic. Note that the No Vector and Vector Includes Status bits in WR9 are ignored when bit D5 in WR9 is set to "1." #### 1 Mb/s FM Data Transmission and Reception The 8-MHz version of the CMOS ESCC (ESCC-8) is capable of transmitting and receiving FM-encoded data at the rate of 1 Mb/s. This is accomplished by applying a 16-MHz clock to the RTxC pin and assigning this waveform to drive the Internal Digital Phase Locked Loop (DPLL) clock. This feature allows the user to send both clock and data information over the same line at 1 Mb/s and can eliminate external DPLLs required for high-speed NRZ data clock generation. Am85C80 ## **ABSOLUTE MAXIMUM RATINGS** Storage Temperature Voltage at any Pin Relative to Vss -65 to +150°C -0.5 to +7.0 V OPERATING RANGES Commercial (C) Devices Ambient Temperature (T<sub>A</sub>) Supply Voltage (Vcc) 0 to +70°C +5 V ± 5% Stresses above those listed under ABSOLUTE MAXI-MUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability. Operating ranges define those limits between which the functionality of the device is guaranteed. ## **DC CHARACTERISTICS over operating ranges** | Parameter<br>Symbol | Parameter<br>Description | Test Conditions | Min. | Max. | Unit | |---------------------|---------------------------|------------------------------------------------------------|---------------|-----------|------| | V <sub>IH</sub> | Input High Voltage | Commercial | 2.2 | Vcc +0.3* | ٧ | | VIL | Input Low Voltage | | <b>–</b> 0.3* | 0.8 | ٧ | | V <sub>OH1</sub> | Output High Voltage | I <sub>OH</sub> = -3.0 mA | 2.4 | | V | | V <sub>OH2</sub> | Output High Voltage | lo <sub>H</sub> = -250 μA (Note 2) | Vcc-0.8 | | ٧ | | V <sub>OL1</sub> | Output Low Voltage | loL = +2.4 mA | | 0.5 | V | | V <sub>OL2</sub> | Output Low Voltage | lo <sub>L</sub> = +48 mA (Note 1) | | 0.5 | V | | I <sub>IL</sub> | Input Leakage | $0.4 \text{ V} \le \text{V}_{\text{IN}} \le 2.4 \text{ V}$ | | ±10.0 | μΑ | | | SCSI Bus Pins | V <sub>IH</sub> = 5.25 V, | | | | | | Except RST | V <sub>IL</sub> = 0 | | ±50 | μΑ | | loL | Output Leakage | $0.4 \text{ V} \leq V_{\text{OUT}} \leq 2.4 \text{ V}$ | | ±10.0 | μΑ | | Icc | Vcc Supply Current | CLK = 8 MHz, inputs at | | 40 | mA | | | | voltage rails, output unloaded | | | | | Cin | Input Capacitance | Unmeasured pins returned | | 10 | рF | | Соит | Output Capacitance | to ground. f = 1 MHz over | | 15 | рF | | Смо | Bidirectional Capacitance | specified temperature range | | 20 | pF | | | Except SCSI Bus Pins | | | | | <sup>\*</sup> VIH Max, and VIL Min. not tested. Guaranteed by design. ## Notes: - 1. SCSI Bus Pins only. - 2. SCC outputs only. ## **Standard Test Conditions** The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: $$+4.75 \text{ V} \le \text{V}_{CC} \le +5.25 \text{ V}$$ GND = 0 V $0^{\circ}\text{C} \le \text{T}_{A} \le 70^{\circ}\text{C}$ ## **SWITCHING TEST CIRCUITS** ## **Standard Test Dynamic Load Circuit** ### Open-Drain Test Load 12582C-077A 12582C-075A ## SWITCHING TEST INPUT/OUTPUT WAVEFORM AC testing: Inputs are driven at 2.4 V for a logic "1" and 0.4 V for a logic "0." Timing measurements are made at 2.0 V for a logic "1" and 0.8 V for logic "0." ## **KEY TO SWITCHING WAVEFORMS** | WAVEFORM | INPUTS | OUTPUTS | |-------------------|----------------------------------------|-----------------------------------------------------| | | Must be<br>Steady | Will be<br>Steady | | | May<br>Change<br>from H to L | Will be<br>Changing<br>from H to L | | | May<br>Change<br>from L to H | Will be<br>Changing<br>from L to H | | | Don't Care,<br>Any Change<br>Permitted | Changing,<br>State<br>Unknown | | $\longrightarrow$ | Does Not<br>Apply | Center<br>Line is High-<br>Impedance<br>"Off" State | # ESCC SWITCHING CHARACTERISTICS over COMMERCIAL operating range General Timing (see Figure 44) | | Parameter | | 8.192 MHz | | 16.38 | 4 MHz | | |-----|-------------|---------------------------------------------------|-----------|------|-------|-------|------| | No. | Symbol | Parameter Description | Min. | Max. | Min. | Max. | Unit | | 1 | TdPC(REQ) | PCLK ↓ to W/REQ Valid Delay | | 250 | | 80 | ns | | 2 | TdPC(W) | PCLK ↓ to Wait Inactive Delay | | 350 | | 180 | ns | | 3 | TsRXC(PC) | RxC ↑ to PCLK ↑ Setup Time<br>(Notes 1, 4 & 8) | NA | NA | NA | NA | | | 4 | TsRXD(RXCr) | RxD to RxC ↑ Setup Time<br>(Xi Mode) (Note 1) | 0 | | 0 | | ns | | 5 | ThRXD(RXCr) | RxD to RxC ↑ Hold Time<br>(XI Mode) (Note 1) | 150 | | 50 | | ns | | 6 | TsRXD(RXCf) | RxD to RxC ↓ Setup Time<br>(XI Mode) (Notes 1, 5) | 0 | | 0 | _ | ns | | 7 | ThRXD(RXCf) | RxD to RxC ↓ Hold Time<br>(XI Mode) (Notes 1, 5) | 150 | | 50 | | ns | | 8 | TsSY(RXC) | SYNCA to RxC ↑ Setup Time (Note 1) | -200 | | -100 | | ns | | 9 | ThSY(RXC) | SYNCA to RxC ↑ Hold Time<br>(Note 1) | 5TcPc | | 5TcPc | | ns | | 10 | TsTXC(PC) | TxC ↓ to PCLK ↑ Setup Time<br>(Notes 2, 4 & 8) | NA | | NA | | | | 11 | TdTXCf(TXD) | TxC ↓ to TxD Delay (XI Mode)<br>(Note 2) | | 200 | | 80 | ns | | 12 | TdTXCr(TXD) | TxC ↑ to TxD Delay (XI Mode)<br>(Notes 2, 5) | | 200 | | 80 | ns | | 13 | TdTXD(TRX) | TxD to TRxC Delay<br>(Send Clock Echo) | | 200 | | 80 | ns | | 14a | TwRTXh | RTxC High Width (Note 6) | 150 | | 80 | | ns | | 14b | TwRTxh(E) | RTxC High Width (Note 9) | 50 | | 15.6 | | ns | | 15a | TwRTXI | RTxC Low Width (Note 6) | 150 | | 80 | | ns | | 15b | TwRTXI(E) | RTxC Low Width (Note 9) | 50 | | 15.6 | | ns | | 16a | TcRTX | RTxC Cycle Time (Notes 6, 7) | 488 | | 244 | | ns | | 16b | TcRTx(E) | RTxC Cycle Time (Note 9) | 125 | | 31.25 | | ns | | 17 | TcRTXX | Crystal Oscillator Period (Note 3) | 125 | 1000 | 62 | 1000 | ns | | 18 | TwTRXh | TRxC High Width (Note 6) | 150 | | 80 | | ns | | 19 | TwTRXI | TRxC Low Width (Note 6) | 150 | | 80 | | ns | | 20 | TcTRX | TRxC Cycle Time (Notes 6, 7) | 488 | | 244 | | ns | | 21 | TwEXT | DCD Pulse Width | 200 | | 70 | | ns | | 22 | TwSY | SYNCA Pulse Width | 200 | ļ | 70 | | ns | ### Notes: - 1. RxC is RTxC or TRxC, whichever is supplying the receive clock. - 2. TxC is TRxC or RTxC, whichever is supplying the transmit clock. - 3. Both RTxC and SYNCA have 30-pF capacitors to ground connected to them. - 4. Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required. - 5. Parameter applies only to FM encoding/decoding. - 6. Parameter applies only for transmitter and receiver, DPLL and baud rate generator timing requirements are identical to chip PCLK requirements. - 7. The maximum receive or transmit data is 1/4 PCLK. - 8. External PCLK to RxC or TxC synchronization requirement eliminated for PCLK divide-by-four operation. TRxC and RTxC rise and fall times are identical to PCLK. Reference timing specs Tfpc and Trpc. Tx and Rx input clock slow rates should be kept to a maximum of 30 nsec. All parameters related to input CLK edges should be referenced at the point at which the transition begins or ends, whichever is worst case. - 9. ENHANCED FEATURE— RTxC used as input to internal DPLL only. Figure 44. General Timing 3–58 Am85C80 # ESCC SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) System Timing (see Figure 45) | | Parameter | | 8.192 MHz | | 16.38 | 84 MHz | | |-----|-------------|----------------------------------------------|-----------|------|-------|--------|------| | No. | Symbol | Parameter Description | Min. | Max. | Min. | Max. | Unit | | 1 | TdRXC(REQ) | RXC ↑ W/REQ Valid Delay<br>(Note 2) | 8 | 12 | 8 | 12 | ТсРс | | 2 | TdRXC(W) | RXC ↑ to Wait Inactive Delay<br>(Notes 1, 2) | 8 | 14 | 8 | 14 | ТсРс | | 3 | TdRXC(SY) | RxC ↑ to SYNC Valid Delay<br>(Note 2) | 4 | 7 | 4 | 7 | TcPc | | 4 | TdRXC(INT) | RxC ↑ to INT Valid Delay<br>(Notes 1, 2) | 10 | 16 | 10 | 16 | TcPc | | 5 | TdTXC(REQ) | TxC ↑ to W/REQ Valid Delay (Note 3) | 5 | 8 | 5 | 8 | TcPc | | 6 | TdTXC(W) | TxC ↓ to Wait Inactive Delay (Notes 1, 3) | 5 | 11 | 5 | 11 | TcPc | | 7a | TdTXC(DRQ) | TxC ↓ to DTR/REQ Valid Delay (Note 3) | 4 | 7 | 4 | 7 | TcPc | | 7b | TdTXC(EDRQ) | TxC ↓ to DTR/REQ Valid Delay (Notes 3, 4) | 5 | 8 | 5 | 8 | TcPc | | 8 | TdTXC(INT) | TxC ↓ to INT Valid Delay (Notes 1, 3) | 6 | 10 | 6 | 10 | TcPc | | 9 | TdSY(INT) | SYNCA Transition to INT Valid Delay (Note 1) | 2 | 6 | 2 | 6 | ТсРс | | 10 | TdEXT(INT) | DCD Transition to INT Valid Delay (Note 1) | 2 | 6 | 2 | 6 | TcPc | ## Notes: - 1. Open-drain output, measured with open-drain test load. - 2. RXC is RTxC or TRxC, whichever is supplying the receive clock. - 3. TxC is TRxC or RTxC, whichever is supplying the transmit clock. - 4. Parameter applies to Enhanced Request mode only. # ESCC SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) Read and Write Timing (see Figure 46) | | Parameter | | 8.192 | MHz | 16.384 MHz | | | |-----|-----------|-------------------------------------------|-------|------|------------|------|------| | No. | Symbol | Parameter Description | Min. | Max. | Min. | Max. | Unit | | 1 | TwPCI | PCLK Low Width | 50 | 2000 | 26 | 2000 | ns | | 2 | TwPCh | PCLK High Width | 50 | 2000 | 26 | 2000 | ns | | 3 | TfPC | PCLK Fall Time | | 15 | | 8 | ns | | 4 | TrPC | PCLK Rise Time | | 15 | | 8 | ns | | 5 | TcPC | PCLK Cycle Time | 122 | 4000 | 61 | 4000 | กร | | 6 | TsA(WR) | Address to WR ↓ Setup Time | 70 | | 35 | | ns | | 7 | ThA(WR) | Address to WR ↑ Hold Time | 0 | | 0 | | ns | | 8 | TsA(RD) | Address to RD ↓ Setup Time | 70 | | 35 | | ns | | 9 | ThA(RD) | Address to RD ↑ Hold Time | 0 | | 0 | | ns | | 10 | TsIA(PC) | INTACK to PCLK ↑ Setup Time | 20 | | 15 | | ns | | 11 | TsIA(WR) | INTACK to WR ↓ Setup Time<br>(Note 1) | 145 | | 70 | | ns | | 12 | ThIA(WR) | INTACK to WR ↑ Hold Time | 0 | | 0 | | ns | | 13 | TsIA(RD) | INTACK to RD ↓ Setup Time<br>(Note 1) | 145 | | 70 | | ns | | 14 | ThIAi(RD) | INTACK to RD ↑ Hold Time | 0 | | 0 | | ns | | 15 | ThIA(PC) | INTACK to PCLK ↑ Hold Time | 40 | | 15 | | ns | | 16 | TsCEI(WR) | CE1 Low to WR ↓ Setup Time | 0 | | 0 | | ns | | 17 | ThCE(WR) | CE1 to WR ↑ Hold Time | 0 | | 0 | | ns | | 18 | TsCFh(WR) | CF1 High to WB ↓ Setup Time | 60 | | 30 | | ns | | 19 | TsCEI(RD) | CE1 Low to RD ↓ Setup Time<br>(Note 1) | 0 | | 0 | | ns | | 20 | ThCE(RD) | CE1 to RD ↑ Hold Time (Note1) | 0 | | 0 | | ns | | 21 | TsCEh(RD) | CET High to RD ↓ Setup Time<br>(Note 1) | 60 | | 30 | | ns | | 22 | TwRDL | RD Low Width (Note 1) | 150 | | 75 | | ns | | 23 | TdRD(DRA) | RD ↓ to Read Data Active Delay | 0 | | 0 | | ns | | 24 | TdRDr(DR) | RD ↑ to Read Data Not Valid<br>Delay | 0 | | 0 | | ns | | 25 | TdRDf(DR) | RD ↓ to Read Data Valid Delav | | 140 | | 70 | ns | | 26 | TdRD(DRz) | RD ↑ to Read Data Float Delay<br>(Note 2) | | 40 | | 20 | ns | ### Notes: - 1. Parameter does not apply to Interrupt Acknowledge transactions. - 2. Float delay is defined as the time at which the data bus is released from its drive state with a maximum DC Load and minimum AC load. Figure 45. System Timing 12582C-080A Figure 46. Read and Write Timing # ESCC SWITCHING CHARACTERISTICS over COMMERCIAL operating range (continued) Interrupt Acknowledge Timing, Reset Timing, Cycle Timing (see Figures 47–49) | | Parameter | | 8.19 | 2 MHz | 16.3 | 84 MHz | | |-----|-------------|----------------------------------------------------|------|---------|------|---------|------| | No. | Symbol | Parameter Description | Min. | Max. | Min. | Max. | Unit | | 27 | TdA(DR) | Address Required Valid to Read<br>Data Valid Delay | | 220 | | 100 | ns | | 28 | TwWRI | WR Low Width | 150 | | 75 | | ns | | 29 | TdWRf(DW) | WR ↓ to Write Data Valid | | 35 | | 20 | ns | | 30 | ThDW(WR) | Write Data to WR ↑ Hold Time | 0 | T | 10 | | ns | | 31 | TdWR(W) | WR ↓ to Wait Valid Delay (Note 2) | | 170 | | 50 | ns | | 32 | TdRD(W) | RD ↓ to Wait Valid Delay (Note 2) | | 170 | | 50 | ns | | 33 | TdWRf(REQ) | WR ↓ to W/REQ Not Valid Delay | | 170 | | 70 | ns | | 34 | TdRDf(REQ) | RD ↓ to W/REQ Not Valid Delay | | 170 | | 70 | ns | | 35a | TdWRr(REQ) | WR ↓ to DTR/REQ Not Valid Delay | | 4.0TcPc | | 4.0TcPc | ns | | 35b | TdWRr(EREQ) | WR ↓ to DTR/REQ Not Valid Delay | | 120 | | 70 | ns | | 36 | TdRDr(REQ) | RD ↑ DTR/REQ Not Valid Delay | | NA | | NA | ns | | 37 | TdPC(INT) | PCLK ↓ to INT Valid Delay<br>(Note 2) | | 500 | | 175 | ns | | 38 | TdlAi(RD) | INTACK to RD ↓ (Acknowledge) Delay | 150 | | 50 | | ns | | 39 | TwRDA | RD (Acknowledge) Width | 150 | | 75 | | ns | | 40 | TdRDA(DR) | RD ↓ (Acknowledge) to Read<br>Data Valid Delay | | 140 | | 70 | ns | | 41 | TslEI(RDA) | IEI to RD ↓ (Acknowledge) Setup<br>Time | | | 50 | | ns | | 42 | ThIEI(RDA) | IEI to RD ↑ (Acknowledge) Hold<br>Time | | | 0 | | ns | | 43 | TdIE(IEO) | IEI to IEO Delay Time | | | | 45 | ns | | 44 | TdPC(IEO) | PCLK ↑ to IEO Delay | | 1 | | 80 | ns | | 45 | TdRDA(INT) | RD ↓ to INT Inactive Delay<br>(Note 2) | | 450 | | 200 | ns | | 46 | TdRD(WRQ) | RD ↑ to WR ↓ Delay for No Reset | 15 | | 10 | | ns | | 47 | TdWRQ(RD) | WR ↑ to RD ↓ Delay for No Reset | 15 | | 10 | | ns | | 48 | TwRES | WR and RD Coincident Low for Reset | 150 | | 75 | | ns | | 49 | Trc | Valid Access Recovery Time<br>(Note 1) | 3.5 | | 3.5 | | ТсРо | ### Notes: Parameter applies only between transactions involving the ESCC, if WR/RD falling edge is synchronized to PCLK falling edge, then TrC = 3TcPc. <sup>2.</sup> Open-drain output, measured with open-drain test load. Figure 47. Reset Timing 12582C-081A Figure 48. Cycle Timing Figure 49. Interrupt Acknowledge Timing 3-64 Am85C80 # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS DMA Write (Non-Block Mode) Target Send Cycle (see Figure 50) | Parameter | Parameter | | | | |------------|------------------------------------|------|------|------| | Symbol | Description | Min. | Max. | Unit | | T1 | DRQ False from DACK True | | 100 | ns | | T2 | DACK False to DRQ True | 30 | | ns | | T3 | Write Enable Width* | 70 | | ns | | T4 | DACK Hold from End of WR | 0 | | ns | | <b>T</b> 5 | Data Setup to End of Write Enable* | 30 | | ns | | Т6 | Data Hold Time from End of WR | 40 | | ns | | Т7 | Width of EOP Pulse (Note 1) | 70 | | ns | | Т8 | ACK True to REQ False | | 125 | ns | | Т9 | REQ from End of DACK (ACK False) | | 120 | ns | | T10 | ACK True to DRQ True (Target) | | 110 | ns | | T11 | REQ from End of ACK (DACK False) | | 120 | ns | | T12 | Data Hold from Write Enable | *0 | | ns | | T13 | Data Setup to REQ True (Target) | 60 | | ns | <sup>\*</sup>Write Enable is the occurrence of $\overline{\text{WR}}$ and $\overline{\text{DACK}}$ #### Note: 1. EOP, WR, and DACK must be concurrently True for at least T7 for proper recognition of the EOP pulse. 12582C-084A Figure 50. DMA Write (Non-Block Mode) Target Send Cycle # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) DMA Write (Non-Block Mode) Initiator Send Cycle (see Figure 51) | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|------------------------------------|------|------|------| | T1 | DRQ False from DACK True | | 100 | ns | | T2 | DACK False to DRQ True | 30 | | ns | | Т3 | Write Enable Width* | 70 | | ns | | T4 | DACK Hold from End of WR | 0 | | ns | | <b>T</b> 5 | Data Setup to End of Write Enable* | 30 | | ns | | Т6 | Data Hold Time from End of WR | 40 | | ns | | Т7 | Width of EOP Pulse (Note 1) | 70 | | ns | | Т8 | REQ True to ACK True | | 110 | ns | | Т9 | REQ False to DRQ True | | 110 | ns | | T10 | DACK False to ACK False | | 130 | ns | | T11 | WR False to Valid SCSI Data | | 100 | ns | | T12 | Data Hold from Write Enable | *0 | | ns | <sup>\*</sup>Write Enable is the occurrence of WR and DACK #### Note 1. EOP, WR, and DACK must be concurrently True for at least T7 for proper recognition of the EOP pulse. 12582C-085A Figure 51. DMA Write (Non-Block Mode) Initiator Send Cycle 3–66 Am85C80 # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) DMA Read (Non-Block Mode) Target Receive Cycle (see Figure 52) | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|------------------------------------|------|------|------| | . T1 | DRQ False from DACK True | | 100 | ns | | T2 | DACK False to DRQ True | 30 | | ns | | Т3 | DACK Hold Time from End of RD | 0 | | ns | | T4 | Data Access Time from Read Enable* | | 100 | ns | | T5 | Data Hold Time from End of RD | 0 | | ns | | T6 | Width of EOP Pulse (Note 1) | 70 | | ns | | <b>T</b> 7 | ACK True to DRQ True | | 110 | ns | | Т8 | DACK False to REQ True (ACK False) | | 120 | ns | | Т9 | ACK True to REQ False | | 125 | ns | | T10 | ACK False to REQ True (DACK False) | | 120 | ns | | T11 | Data Setup Time to ACK | 10 | | ns | | T12 | Data Hold Time from ACK | 65 | | ns | <sup>\*</sup>Read Enable is the occurrence of RD and DACK #### Note: <sup>1.</sup> EOP, RD, and DACK must be concurrently True for at least T6 for proper recognition of the EOP pulse. Figure 52. DMA Read (Non-Block Mode) Target Receive Cycle # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) DMA Read (Non-Block Mode) Initiator Receive Cycle (see Figure 53) | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|-------------------------------------|------|------|------| | Т1 | DRQ False from DACK True | | 100 | ns | | T2 | DACK False to DRQ True | 30 | | ns | | Т3 | DACK Hold Time from End of RD | 0 | | ns | | T4 | Data Access Time from Read Enable* | | 100 | ns | | T5 | Data Hold Time from End of RD | 0 | | ns | | T6 | Width of EOP Pulse (Note 1) | 70 | | ns | | T7 | REQ True to DRQ True | | 140 | ns | | T8 | DACK False to ACK False (REQ False) | | 100 | ns | | Т9 | REQ True to ACK True | | 110 | ns | | T10 | REQ False to ACK False (DACK False) | | 100 | ns | | T11 | Data Setup Time to REQ | 10 | | ns | | T12 | Data Hold Time from REQ | 65 | | ns | <sup>\*</sup>Read Enable is the occurrence of $\overline{\text{RD}}$ and $\overline{\text{DACK}}$ #### Note <sup>1.</sup> EOP, RD, and DACK must be concurrently True for at least T6 for proper recognition of the EOP pulse. Figure 53. DMA Read (Non-Block Mode) Initiator Receive Cycle # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) DMA Write (Block Mode) Target Send Cycle (see Figure 54) | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|------------------------------------|------|------|------| | T1 | DRQ False from DACK True | | 100 | ns | | T2 | Write Enable Width* | 70 | | ns | | T3 | Write Recovery Time | 120 | | ns | | T4 | Data Setup to End of Write Enable* | 30 | | ns | | T5 | Data Hold Time from End of WR | 40 | | ns | | T6 | Width of EOP Pulse (Note 1) | 70 | | ns | | <b>T</b> 7 | ACK True to REQ False | | 125 | ns | | T8 | REQ from End of WR (ACK False) | | 130 | ns | | Т9 | REQ from End of ACK (WR False) | | 110 | ns | | T13 | Data Hold from ACK True | 0 | | ns | | T14 | Data Setup to REQ True | 60 | | ns | <sup>\*</sup>Write Enable is the occurrence of WR and DACK #### Note: 1. EOP, WR, and DACK must be concurrently True for at least T6 for proper recognition of the EOP pulse. Figure 54. DMA Write (Block Mode) Target Send Cycle # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) DMA Read (Block Mode) Target Receive Cycle (see Figure 55) | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|------------------------------------|------|------|------| | T1 | DRQ False from DACK True | | 100 | ns | | T2 | RD Recovery Time | 120 | | ns | | ТЗ | Data Access Time from Read Enable* | | 100 | ns | | T4 | Data Hold Time from End of RD | 0 | | ns | | T5 | Width of EOP Pulse (Note 1) | 70 | | ns | | Т6 | RD False to REQ True (ACK False) | | 130 | ns | | T7 | ACK True to REQ False | | 125 | ns | | Т8 | ACK False to REQ True (RD False) | | 110 | ns | | T12 | Data Setup Time to ACK | *10 | | ns | | T13 | Data Hold Time from ACK | 65 | | ns | <sup>\*</sup>Read Enable is the occurrence of $\overline{\text{RD}}$ and $\overline{\text{DACK}}$ ## Note: 1. $\overline{\text{EOP}}$ , $\overline{\text{RD}}$ , and $\overline{\text{DACK}}$ must be concurrently True for at least T5 for proper recognition of the $\overline{\text{EOP}}$ pulse. Figure 55. DMA Read (Block Mode) Target Receive Cycle 3-70 Am85C80 # SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) Reset | 1 | | | | | | |---|-----------|------------------------|------|------|------| | | Parameter | Parameter | | | İ | | | Symbol | Description | Min. | Max. | Unit | | | T1 | Minimum Width of RESET | 100 | | ns | ## **Arbitration** | Parameter<br>Symbol | Parameter<br>Description | Min. | Max. | Unit | |---------------------|--------------------------------|------|------|------| | T1 | Bus Clear from SEL True | | 600 | ns | | T2 | Arbitrate Start from BSY False | 1200 | 2400 | ns | | Т3 | Bus Clear from BSY False | | 1100 | ns | SCSI SWITCHING CHARACTERISTICS/WAVEFORMS (Continued) CPU Write Cycle | Parameter<br>Symbol | Parameter Description | Min. | Max. | Unit | |---------------------|-------------------------------------|------|------|------| | T1 | Address Setup to Write Enable* | 10 | | ns | | T2 | Address Hold from End Write Enable* | 0 | | ns | | Т3 | Write Enable Width* | 40 | | ns | | T4 | Chip Select Hold from End of WR | 0 | | ns | | T5 | Data Setup to End of Write Enable* | 20 | | ns | | Т6 | Data Hold Time from End of WR | 30 | | ns | <sup>\*</sup>Write Enable is the occurrence of WR and CE2. ## **CPU Read Cycle** | Parameter | Parameter | | | | |-----------|------------------------------------|------|------|------| | Symbol | Description | Min. | Max. | Unit | | T1 | Address Setup to Read Enable* | 10 | | ns | | T2 | Address Hold from End Read Enable* | 0 | | ns | | ТЗ | Chip Select Hold from End of RD | . 0 | | ns | | T4 | Data Access Time from Read Enable* | | 100 | ns | | T5 | Data Hold Time from End of RD | 0 | | ns | <sup>\*</sup>Read Enable is the occurrence of RD and CE2. | Parameter<br>Symbol | Parameter<br>Description | Min. | Max. | Unit | |---------------------|--------------------------|------|------|------| | Т7 | CE1 to CE2 Recovery | 100 | | ns | | T8 | CE2 to CE2 Recovery | 100 | | ns | 12582C-093A Am85C80 #### SLEEP MODE The Am85C80 has a "sleep mode" feature which is extremely desirable in designing low power systems such as laptop, notebook and tablet PCs. Basically, the "sleep mode" feature saves power consumption by shutting down all the active circuitries when they are not in use, while keeping the necessary register values. While in "sleep mode," any incoming clock has to be stopped, all internal Voltage Controlled Oscillators and Ring Oscillators should be disabled, and to avoid driving any resistive load, the outputs have to be in tri-state. System designers should take necessary precautions to ensure no glitches occur when the system clock is being stopped or started. This is a key design issue for systems with clock stop/start capability. The Am85C80's sleep mode has been designed so that the two different portions of the device (SCSI and SCC) may be powered down separately or together, depending on user needs. For example, a SCSI disk can be shut down while serial communication is active, or the serial ports can be shut down while data is transferring to/from the disk. To utilize the least current (typical 80 µA), both the SCSI and SCC can be powered down, and this state is called "Deep Sleep." If a user exercises a shut down and wake up session into and out of "Deep Sleep," the Am85C80 will save all its SCC register values. On the other hand, its SCSI register values will be destroyed, and the user has to program the SCSI portion once the device is out of the "sleep mode." From the design point of view, the clock and host interface of the Am85C80 are crucial. The SCSI timing generator has an internal oscillator that is used for Arbitration and Selection timing defined in the ANSI X3.131-1986 standard. Because WR is synchronized with PCLK, the SCC writing registers are blocked when PCLK is stopped. However, any read and write to SCSI is unaffected by PCLK since it is still asynchronous. This feature enables SCSI and SCC portions of Am85C80 to be in "sleep mode" separately or together. Typically, only the SCSI or SCC portion of a Am85C80 will be active. The diagram below is a simplified block diagram of the Am85C80 drawn to address the power down mode. Simplified Block Diagram of the Am85C80 ## Guidelines for Designing Battery Powered Computers Using the Am85C80: - To save power, power-on reset (POR) circuitry is not implemented in the Am85C80. A user needs to do a soft reset, or assert both RD and WR simultaneously to cause a hard reset to the SCC portion. - In order to ensure the outputs (data lines) are inactive, either: - a) RD should be kept at logic 1, or - b) CE1 and CE2 should be kept at logic 1. - In order to <u>put the SCC portion into "sleep mode."</u> PCLK should be stopped at a logic 1 or 0 level. Users should ensure PCLK is stopped and started cleanly, with no double clocking or glitches. PCLK should be stopped a minimum of two cycles of PCLK before and after the access to the SCC. - 4. In order to <u>put the SCSI portion into "sleep mode."</u> RE SET should be asserted logic 0 to stop internal timing generator as shown on the diagram. RESET signal, which affects only the SCSI portion, can be asserted any time even in the middle of a CPU read or write. (Attention should be given to the software to first terminate any SCSI bus activity by going into bus free phase to avoid troubles on the SCSI bus when RESET is asserted.) - In order to put the Am85C80 into "Deep Sleep" mode, the user should put both the SCC and SCSI portion into their respective "sleep modes." This is done by both stopping PCLK and asserting RESET. The above guide lines are for designing the laptop computers using Am85C80. The following is a typical timing diagram the one could use. It is recommended that while the chip is in "Deep Sleep" mode, CE1, CE2, RD, and WR are at logic 1. SCC Power Down Mode (SCC PCLK Stopped) Am85C80