Making the leading edge work for you WD2511/WD2840 Technical Package April, 1984



# WD2511/WD2840 Technical Package April, 1984

TABLE OF CONTENTS

| WD2511 X.25 Packet Network Interface (LAPB)  | 1  |
|----------------------------------------------|----|
| Application Note Using The WD2511            | 33 |
| WD2840 Local Network Token Access Controller | 53 |
| WD2840 Application Note                      | 89 |

WESTERN DIGITAL



i

#### WESTERN DIGITAL 0 Ρ

Т

Δ

1 0

0

# WD2511 X.25 Packet Network Interface (LAPB)

#### FEATURES

 Packet switching controller, complies with CCITT Recommendation X.25, level 2, LAPB.

R

- Programmable primary timer (T1) and retransmission counter (N2).
- Programmable A-field which provides a wider range of applications than defined by X.25. These include: DTE-to-DTE connection, multipoint and loop-back testina.
- · Direct memory access (DMA) transfer: two channels: one for transmit and one for receive. Send/ receive data accessed by indirect addressing method. Sixteen output address lines.
- Zero bit insertion and deletion.
- Automatic appending and testing of FCS field.
- Computer bus interface structure: 8 bit bi-directional data bus. CS, WE, RE and four input address lines.
- DC to 1.1 MBPS data rate.
- TTL compatible. .
- 48 pin dual in-line packages.



N

A REFININA AV

WD2511

#### **PIN DESIGNATION**

#### DESCRIPTION

The WD2511 is a MOS/LSI device which handles bitoriented, full-duplex serial data communications with DMA, which conforms to CCITT X.25's LAPB with programmable enhancements.

The device is fabricated in N-Channel silicon gate MOS technology and is TTL compatible on all inputs and outputs.

#### APPLICATIONS

X.25 PACKET SWITCHING CONTROLLER PART OF DTE OR DCE PRIVATE PACKET NETWORKS LINK LEVEL CONTROLLER STORE AND FORWARD SYSTEM HIGH REL POINT TO POINT COMMUNICATIONS BIT ORIENTED PROTOCALS WITH BUILT IN DMA

# INTERFACE SIGNALS DESCRIPTION (All signals are TTL compatible.)

| 1       No Connection       Leave pin open.         2       REPLY       Reply       An active low output indicates the WD2511 either a CS•RE or a CS•WE input condition         3       WE       Write Enable       The data on the DAL are written into selected register when CS and WE are low.         4       CS       Chip Select       Active low chip select for CPU control of registers.         5       RE       Read Enable       The contents of the selected register is plat on DAL when CS and RE are low.         6       CLK       Clock       Clock input used for internal timing. Must square wave and should be greater than the KHz.         7       MR       Master Reset       Active low initializes the chip. All registers re to zero, except control bits MDISC and Ll which are set to 1. DACK must be stable hefore MR goes high.         8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ne<br>/O<br>ed<br>De<br>De<br>JK |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 3       WE       Write Enable       either a CS•RE or a CS•WE input condition         3       WE       Write Enable       The data on the DAL are written into selected register when CS and WE are low.         4       CS       Chip Select       Active low chip select for CPU control of registers.         5       RE       Read Enable       The contents of the selected register is play on DAL when CS and RE are low.         6       CLK       Clock       Clock input used for internal timing. Must square wave and should be greater than the KHz.         7       MR       Master Reset       Active low initializes the chip. All registers reto zero, except control bits MDISC and LI which are set to 1. DACK must be stable hefore MR goes high.         8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ne<br>/O<br>ed<br>De<br>De<br>JK |
| 4       CS       Chip Select       selected register when CS and WE are low.         5       RE       Read Enable       Active low chip select for CPU control of registers.         6       CLK       Clock       Clock input used for internal timing. Must square wave and should be greater than the KHz.         7       MR       Master Reset       Active low initializes the chip. All registers reto zero, except control bits MDISC and Ll which are set to 1. DACK must be stable here         8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | /O<br>ed<br>De<br>DO<br>et<br>IK |
| 5       RE       Read Enable       registers.         5       RE       Read Enable       The contents of the selected register is plat on DAL when CS and RE are low.         6       CLK       Clock       Clock input used for internal timing. Must square wave and should be greater than the KHz.         7       MR       Master Reset       Active low initializes the chip. All registers reto zero, except control bits MDISC and Liwhich are set to 1. DACK must be stable here of the selected register is plate.         8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ed<br>De<br>DO                   |
| 6       CLK       Clock       Clock input used for internal timing. Must square wave and should be greater than the square wave and should | oe<br>00<br>iet<br>IK            |
| 7       MR       Master Reset       square wave and should be greater than the KHz.         7       MR       Master Reset       Active low initializes the chip. All registers reto zero, except control bits MDISC and Ling which are set to 1. DACK must be stable in before MR goes high.         8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00<br>iet<br>IK                  |
| 8-15       DAL0-DAL7       Data Access Lines       An 8-bit bi-directional three-state data bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | IK                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                  |
| CPU and DMA controlled transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | or                               |
| 16 RD Receive Data Receive serial data input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                  |
| 17         RC         Receive Clock         This is a 1x clock input. RD is sampled on rising edge of RC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ıe                               |
| 18 VSS Ground Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                  |
| 19 TC Transmit Clock A 1x clock input. TD changes on the fall edge of TC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ıg                               |
| 20 TD Transmit Data Transmit serial data output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                  |
| 21 RTS Request-To-Send An open collector (drain) output which g<br>low when the WD2511 is ready to trans<br>either flags or data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                  |
| 22 CTS Clear-To-Send An active low input which signals the WD2 that transmission may begin. If high, the output is forced high. May be hard-wired ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | D                                |
| 23 DRQO DMA Request Out An active low output signal which initiates C bus request so the WD2511 can output d onto the bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                  |
| 24 DRQI DMA Request In An active low output signal which intitia CPU bus request so that data may be input the WD2511.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                  |
| 25 DACK DMA Acknowledge An active low input from the CPU in response<br>to DRQI or DRQO. DACK must not be low if<br>and RE are low or if CS and WE are low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | se<br>XS                         |
| 27, 26,<br>38-41,<br>28-37A0-A15Address Lines OutSixteen address outputs from the WD2511<br>DMA operation. If the control bit ADRV is 1;<br>outputs are TTL drives at all times. If ADRV is the outputs are three-state, and are HI-Z where the ver DACK is high. (ADRV is in Control Ret<br>ter #1.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | he<br>0,<br>•n-                  |
| 42 VDD Power Supply + 12VDC power supply input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                  |

WD2511

#### INTERFACE SIGNALS DESCRIPTION CONTINUED (All signals are TTL compatible.)

| PIN<br>NUMBER     | SYMBOL  | PIN NAME          | FUNCTION                                                                                                                                                                               |
|-------------------|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 43                | İNTR    | Interrupt Request | An active low interrupt service request output.<br>Returns to high when Status Register #1 is read.                                                                                    |
| 46, 47,<br>45, 44 | IA0-IA3 | Address Lines In  | Four address inputs for CPU controlled read/<br>write operation of the I/O registers in the<br>WD2511. If ADRV = 0, these may be tied to A0-<br>A3. (ADRV is in Control Register = 1.) |
| 48                | Vcc     | Power Supply      | + 5VDC power supply input.                                                                                                                                                             |

#### ORGANIZATION

Note: See appendix D for a glossary of terms used throughout this document.

A detailed block diagram of the WD2511 is shown in Figure 1.

Mode control and monitor of status by the user's CPU is performed through the Read/Write Control circuit which reads from or writes into I/O registers addressed by IA0-IA3.

Transmit and receive data are accessed through the DMA control. Serial data is generated and received by the bit-oriented controllers.

Internal Control of the WD2511 is by means of three internal microcontrollers; one for transmit, one for

receive, and one for overall control.

Parallel transmit data are entered into the Transmitter Holding Register (THR), and then presented to the Transmitter Register (TR) which converts the data to a serial bit stream. The Cyclic Redundancy Check (CRC) is computed in the 16-bit CRC register, and the result becomes the transmitted Frame Check Sequence (FCS).

Parallel receive data enters the Receiver Holding Register (RHR) from the 24-bit serial Receiver Register (RR). The 24-bit length of RR permits stripping of the FCS prior to transfer in to the RHR. The receiver CRC register is used to test the validity of the received FCS. A 3-stack FIFO is included in the receiver.



#### FRAME FORMAT

The WD2511 performs "bit-oriented" data communications control. According to the general format for bit-oriented procedures (HDLC, SDLC, ADCCP), each serial block of data is called a frame.

Each frame starts and ends with a Flag (0111110). A single flag may be used both as the closing flag of one frame and the opening flag of the next frame. In between flags, data transparency is provided by the insertion of a 0 bit after all sequences of 5 contiguous 1 bits. The receiver will strip the inserted 0 bits. The last 16-bits before the closing flag is in the Frame Check Sequence (FCS). Each frame also includes address and control fields (A and C fields).

The FCS calculation includes all data between the opening flag and the first bit of the FCS, except for 0's inserted for transparency. The 16-bit FCS has the following characteristics:

After the frame is received, if there were no errors then the remainder in the CRC register (internal in the WD2511) will be:

#### 1111000010111000 FOB8

The WD2511 generates and tests the Flag, FCS, A-Field, C-Field, and performs zero bit insertion and deletion.

According to the X.25 protocol, there are three types of frames: supervisory (S-frame), un-numbered (U-frame), and information (I-frame). The WD2511 performs frame level (level 2) link access control. All S- and U-frames are automatically generated and tested by the WD2511. The user need only be concerned with the I-frames, which are packets.

The WD2511 will transmit contiguous flags for interframe time fill (full duplex mode).



X.25 MUDI

NOTE: X.25 Level 1, is the Physical Interface





#### **II. PROGRAMMING THROUGH REGISTERS**

The WD2511 is controlled and monitored by sixteen I/O registers.

Control, status, and error bits will be referred to as CR, SR, or ER, respectively, along with two digits. For example, SR16 refers to status register #1 and bit 6, which is "XBA."

#### **REGISTER DEFINITION**

| REG<br># | IA3 | IA2 | IA1 | IA0 | REGISTER                  | REGISTER<br>GROUPING |
|----------|-----|-----|-----|-----|---------------------------|----------------------|
| 0        | 0   | 0   | 0   | 0   | CR0                       |                      |
| 1        | 0   | 0   | 0   | 1   | CR1                       |                      |
| 2        | 0   | 0   | · 1 | 0   | *SR0                      | OVERALL CONTROL      |
| 3        | 0   | 0   | 1   | 1   | *SR1                      | AND<br>MONITOR       |
| 4        | 0   | 1   | 0   | 0   | *SR2                      | MONITOR              |
| 5        | 0   | 1   | 0   | 1   | *ER0                      |                      |
| 6        | 0   | 1   | 1   | 0   | *CHAIN MONITOR            | RECEIVER             |
| 7        | 0   | 1   | 1   | 1   | *RECEIVED C-FIELD         | MONITOR              |
| 8        | 1   | 0   | 0   | 0   | T1                        | ТИГО                 |
| 9        | 1   | 0   | 0   | 1   | N2/T1                     | TIMER                |
| A        | 1   | 0   | 1   | 0   | TLOOK HI                  |                      |
| В        | 1   | 0   | 1   | 1   | TLOOK LO                  |                      |
| С        | 1   | 1   | 0   | 0   | CHAIN/BUFFER SIZE         | DMA SET-UP           |
| D        | 1   | 1   | 0   | 1   | NOT USED                  |                      |
| E        | 1   | 1   | 1   | 0   | XMT COMMAND "E"           | "A" FIELD            |
| F        | 1   | 1   | 1   | 1   | XMT RESPONSE "F" (Note 1) | A FIELD              |

\*CPU READ ONLY. (Write Not Possible)

#### NOTE:

1. Registers E and F should be set-up while MDISC = 1.

# CONTROL, STATUS, ERROR REGISTERS

|          |                  |                  |                    | BIT #              |              |      |      |       |
|----------|------------------|------------------|--------------------|--------------------|--------------|------|------|-------|
| REGISTER | 7                | 6                | 5                  | 4                  | 3            | 2    | 1    | 0     |
| CR0      | ADISC            | 0                | H/F                | ACTIVE/<br>PASSIVE | LOOP<br>TEST | RAMT | RECR | MDISC |
| CR1      | ТХМТ             | TRCV             | XI                 | ADRV               | 0            | 0    | 0    | SEND  |
| SR0      | NA2              | NA1              | NA0                | RNRR               | NB2          | NB1  | NB0  | RNRX  |
| SR1      | <sup>1</sup> PKR | <sup>1</sup> XBA | <sup>1</sup> ERROR | 0                  | NE2          | NE1  | NE0  | 0     |
| SR2      | T1OUT            | IRTS             | REC<br>IDLE        | 0                  | 0            | 0    | 0    | LINK  |
| ER0      | ER07             | ER06             | ER05               | ER04               | ER03         | ER02 | ER01 | ER00  |

1 Causes Interrupt (INTR Goes Low).

# **CONTROL REGISTER 0**

|          |       |                                                                                                                                                                                                                                                |                              | 001111021      | Laistenv     |             |                |            |
|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|----------------|--------------|-------------|----------------|------------|
| REGISTER | CR07  | CR06                                                                                                                                                                                                                                           | CR05                         | CR04           | CR03         | CR02        | CR01           | CR00       |
| CR0      | ADISC | 0 H/F ACTIVE/ LOOP RAMT RECR                                                                                                                                                                                                                   |                              |                |              |             |                |            |
| BIT      |       |                                                                                                                                                                                                                                                |                              | DE             | SCRIPTION    | •           |                |            |
| CR00     |       | MDISC (man<br>link. No DMA<br>Reset, MDIS<br>until MDISC                                                                                                                                                                                       | accessed d<br>C will be set. | ata will be tr | ansferred as | long as MD  | ISC = 1. Af    | ter Master |
| CR01     |       | RECR (Receiver Ready) indicates the CPU's is receiver buffer is Ready (CR01 = 1). If RECR = 1, the WD2511 may begin receiving I-frames. (See SR00)                                                                                             |                              |                |              |             |                |            |
| CR02     |       | RAMT — Internal Register Test when set. (See Self Tests)                                                                                                                                                                                       |                              |                |              |             |                |            |
| CR03     |       | The LOOP TEST bit will connect the transmit data output to the receive data input. The receiver input pins RD and RC are then logically disconnected from the internal circuitry. The "E" and "F" data registers of the A-field must be equal. |                              |                |              |             |                |            |
| CR04     |       | The Active/Passive bit when set, in conjunction with $MDISC = 0$ , will cause the $WD2511$ to initiate link set-up. When this bit is reset, the $WD2511$ will wait for a link setup from the remote station.                                   |                              |                |              |             |                |            |
| CR05     |       | H/F selects full duplex if CR05 = 0, and half duplex if CR05 = 1. (See Appendix A).                                                                                                                                                            |                              |                |              |             |                |            |
| CR06     |       | Unused conti                                                                                                                                                                                                                                   | rol bits shoul               | d remain at 0  |              |             |                |            |
| CR07     |       | ADISC (disco<br>ates link set-u<br>the SABM if (                                                                                                                                                                                               | up, a ÓISC w                 | ill be transmi | tted and ack | nówledged p | prior to trans |            |

|          |      |                                                                                                                                     |                                                                                                | CONTROL I                                                                                         | REGISTER 1                                                                                     |                                                                            |                                                                                     |                                                                       |
|----------|------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| REGISTER | CR17 | CR16                                                                                                                                | CR15                                                                                           | CR14                                                                                              | CR13                                                                                           | CR12                                                                       | CR11                                                                                | CR10                                                                  |
| CR1      | TXMT | TRCV XI ADRV 0 0 0 SE                                                                                                               |                                                                                                |                                                                                                   |                                                                                                |                                                                            |                                                                                     | SEND                                                                  |
| BIT      |      |                                                                                                                                     |                                                                                                | DE                                                                                                | SCRIPTION                                                                                      |                                                                            |                                                                                     |                                                                       |
| CR10     |      | The SEND bi<br>SEND = 1, t<br>transmission.<br>= 1, the WD2<br>buffer. After tr<br>reads BRDY c<br>is cleared, and<br>should set SE | he WD2511 v<br>If BRDY = 0<br>2511 will then<br>ansmission,<br>of the next se<br>d transmissio | will read fron<br>D, the WD251<br>read TSADF<br>the WD2511 of<br>gment. If 1, th<br>on of packets | n TLOOK the<br>1 will clear S<br>3 and TCNT, t<br>clears BRDY<br>ne next segm<br>is stopped. A | BRDY bit o<br>END and no<br>followed by t<br>of the segme<br>ent is transm | f the next se<br>action occur<br>he transmiss<br>nt just transr<br>itted. If 0, the | egment for<br>s. If BRDY<br>sion of that<br>nitted, and<br>e SEND bit |
| CR11-13  |      | Unused bits,                                                                                                                        | write in 0's.                                                                                  |                                                                                                   |                                                                                                |                                                                            |                                                                                     |                                                                       |
| CR14     |      | The ADRV (A<br>If ADRV = 0,<br>= 1, the outp<br>when DRQO,                                                                          | the outputs a<br>outs are alwa                                                                 | ire tri-state ar<br>ys low imped                                                                  | nd are in HI-Z<br>ance (TTL), a                                                                | , except whe                                                               | n DACK is lo                                                                        | w. If ADRV                                                            |
| CR15     |      |                                                                                                                                     | rame ≥ 3 byte                                                                                  | Used when T<br>es excluding<br>es excluding                                                       | FCS and Flag                                                                                   |                                                                            |                                                                                     |                                                                       |
| CR16     |      | TRCV — Tra                                                                                                                          | nsparent Re                                                                                    | ceive. Rece                                                                                       | ve all frame                                                                                   | s including                                                                | unknown fra                                                                         | ames. See                                                             |

#### STATUS REGISTER 0

|          |      |                                                                                                                               |      | • • • • • • • |      |      |      |      |
|----------|------|-------------------------------------------------------------------------------------------------------------------------------|------|---------------|------|------|------|------|
| REGISTER | SR07 | SR06                                                                                                                          | SR05 | SR04          | SR03 | SR02 | SR01 | SR00 |
| SR0      | NA2  | NA1                                                                                                                           | NA0  | RNRR          | NB2  | NB1  | NBO  | RNRX |
| BIT      | 1    | DESCRIPTION                                                                                                                   |      |               |      |      |      | •    |
| SR00     |      | RNRX. An RNR has been transmitted or will be at next opportunity. The CPU should set RECR when receive buffers are available. |      |               |      |      |      |      |
| SR03-SR0 | 1    | NB2-NB0. Next block to be transmitted.                                                                                        |      |               |      |      |      |      |
| SR04     |      | RNRR. This bit is set when an RNR frame is received. Once set, it is cleared when an RR, REJ, SABM, or UA is received.        |      |               |      |      |      |      |
| SR07-SR0 | 5    | NA2-NA0. Next block of transmitted data to be Acknowledged.                                                                   |      |               |      |      |      |      |

TXMT — Transparent transmit. See Appendix A.

Appendix A.

**CR17** 

WD2511

|          |      |                                                                                                                                                                                                                                                                               | STAT                                                | US REGISTI  | ER 1          |               |              |      |
|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------|---------------|---------------|--------------|------|
| REGISTER | SR17 | SR16                                                                                                                                                                                                                                                                          | SR15                                                | SR14        | SR13          | SR12          | SR11         | SR10 |
| SR1      | 1PKR | 1XBA                                                                                                                                                                                                                                                                          | 1ERROR                                              | 0           | NE2           | NE1           | NE0          | 0    |
| BIT      |      |                                                                                                                                                                                                                                                                               |                                                     | DE          | SCRIPTION     |               |              |      |
| SR10     |      | 0 (not used)                                                                                                                                                                                                                                                                  |                                                     |             |               |               |              |      |
| SR13-SR1 | 1    | NE2-NE0. Ne                                                                                                                                                                                                                                                                   | ext Expected                                        | oacket numb | er and next I | RLOOK segn    | nent number. |      |
| SR14     |      | 0 (not used)                                                                                                                                                                                                                                                                  |                                                     |             |               |               |              |      |
| SR151    |      | The ERROR bit indicates: 1) An error has occurred which is not recoverable by the WD2511 or 2) A significant event has occured.                                                                                                                                               |                                                     |             |               |               |              |      |
|          |      | For the specific reason for the ERROR bit being set, see error register (ER0) on next page.                                                                                                                                                                                   |                                                     |             |               |               |              |      |
| SR161    |      | The XBA (transmitted block acknowledgement) bit set, indicates that a previously trans-<br>mitted Block, or Blocks, have been acknowledged by the remote device. Upon acknowl-<br>edgement, the ACK'ED bit is set to "1" for each segment in TLOOK which was<br>acknowledged. |                                                     |             |               |               |              |      |
| SR171    |      | error-free and                                                                                                                                                                                                                                                                | stands for Pac<br>d in correct se<br>ced in the hos | quence acco | ording to the | received N (S |              |      |

#### NOTE 1:

WD2511

The three interrupt-causing bits are SR17, SR16, and <u>SR15</u>. Any of the three will cause an interrupt request (INTR goes low). After SR1 is read, all three bits are reset to 0, and INTR returns to high.

|          |            |                                                                                                                                                      | 3141          | US REGIST                   |                 |              |             |      |  |
|----------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------|-----------------|--------------|-------------|------|--|
| REGISTER | SR27       | SR26                                                                                                                                                 | SR25          | SR24                        | SR23            | SR22         | SR21        | SR20 |  |
| SR2      | T1OUT IRTS |                                                                                                                                                      | REC<br>IDLE   | 0                           | 0               | 0            | 0           | LINK |  |
| BIT      |            |                                                                                                                                                      | DESCRIPTION   |                             |                 |              |             |      |  |
| SR20     |            | If the link is ea                                                                                                                                    | stablished, L | $\overline{INK} = 0.$ If th | e link is logio | ally disconn | ected, LINK | = 1. |  |
| ST24-21  |            | Unused Bits — 0.                                                                                                                                     |               |                             |                 |              |             |      |  |
| SR25     |            | REC IDLE (Receiver Idle) indicates that the WD2511 has received at least 15 contiguous 1's.                                                          |               |                             |                 |              |             |      |  |
| SR26     |            | IRTS stands for the Internal Request-To-Send bit, and indicates that the transmitter is attempting (successful or not) to send either data or flags. |               |                             |                 |              |             |      |  |
| SR27     | ×          | T1OUT bit me<br>When T1OUT<br>in between in                                                                                                          | = 1, T1 is no | ot running. No              | OTE: This bit   | could be a 1 |             |      |  |

# STATUS REGISTER 2

8

#### ERROR REGISTER (ER0)

| HEX<br>VALUE | ERROR/EVENT                                                                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02           | Receiver overrun. The Receiver Register (RR) had a character to load into the FIFO but the FIFO was full. See note 2.                                                                            |
| 04           | Transmitter underrun. The Transmitter (TR) needed a character from the Transmitter Hold-<br>ing Register (THR) but the THR was not ready. The frame being transmitted is aborted. See<br>note 2. |
| 10           | RLOOK not ready. REC RDY bit of next segment is 0 but RECR = 1. This interrupt will not occur if RECR = 0.                                                                                       |
| 21           | Link is up. Was down.                                                                                                                                                                            |
| 22           | DISC sent. REC IDLE for time T1xN2.                                                                                                                                                              |
| 24           | DISC sent. SABM sent N2 times without receiving UA.                                                                                                                                              |
| 30           | Received DISC or DM while link was up.                                                                                                                                                           |
| 41           | Going to next chain segment.                                                                                                                                                                     |
| 42           | Next chain segment of the Receiver was not ready.                                                                                                                                                |
| 80           | Link reset (SABM) received.                                                                                                                                                                      |
| 88           | S-command sent N2 times without acknowledgement.                                                                                                                                                 |
| CO           | Frame Reject (FRMR) received. See note 1.                                                                                                                                                        |
| C1           | Frame Reject (FRMR) transmitted. See note 3. The received C-field (returned in the first<br>I-field byte of the FRMR frame) was invalid.                                                         |
| C3           | Frame Reject (FRMR) transmitted. See note 3. The received and rejected frame contained<br>an I-field which is not permitted with this frame type.                                                |
| C4           | Frame Reject (FRMR) transmitted. See note 3. Received I-field exceeded the total amount<br>of I-field data bytes established in Register C.                                                      |
| C8           | Frame Reject (FRMR) transmitted. See note 3. The received frame contained an invalid $N(R)$ .                                                                                                    |

#### NOTES:

- Whenever a Frame Reject (FRMR) is received, the I-field will have been placed in the appropriate memory location by the DMA. A link reset (SABM) will be transmitted. The NB is not advanced.
- Receiver overrun and Transmitter underrun are indication that the TC/RC clocks are either too fast for the WD2511, or the DACK response is too slow, or both.
- 3. As a result of FRMR transmitted, a SABM is received, causing link reset. In this case, only the Frame Reject interrupt is indicated.

#### W, X, Y, Z OF FRMR

A frame reject (FRMR) contains a three byte I-field. The first byte is the rejected frame control field. The second byte contains the current N(S) and N(R) counts of the station reporting the reject condition. The third byte contains W-X-Y-Z-0-0-0 where W is the LSB.

W set to 1 indicates that the control field received and returned in the first I-field byte was invalid.

X set to 1 indicates the rejected frame contained an I-field which is not permitted with this command.

W is also set to 1 in this case.

Y set to 1 indicates the received I-field exceeded the maximum I-field data byte count established (CHAIN/ BUFFER SIZE). Y is mutually exclusive with W.

Z set to 1 indicates the received control field contained an invalid N(R). Z is mutually exclusive with W.

Upon receiving a FRMR, the WD2511 will place the 3 byte l-field in memory by DMA, just as if the FRMR were a packet.

When the WD2511 transmits a FRMR, the frame reject condition is entered. Only a received SABM or DISC will clear this condition. If any other command is received, the WD2511 will re-transmit the FRMR. Also, the WD2511 will **not** transmit packets while in the frame reject condition.

In the FRMR I-field, bit #4 of the second byte is a "1" if the rejected frame was a response and a "0" if the frame was a command.

#### MEMORY ACCESS METHOD

The WD2511 memory access is accomplished by the use of DMA and two look-up tables. These tables are set-up to allow up to 7 l-frames to be outstanding in each direction of the communications link. The look-up tables are divided into a transmit and a receive area (TLOOK and RLOOK) and are located in memory external to the WD2511.

| TLOOK |
|-------|
| RLOOK |
|       |

These tables contain address and control information for individual Transmit/Receiver packets.

To provide the WD2511 access to TLOOK and RLOOK load only the starting address of TLOOK into the WD2511 registers A and B.

| REG A | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |
|-------|-----|-----|-----|-----|-----|-----|----|----|
| REG B | A7  | A6  | A5  | A4  | A3  | A2  | A1 | A0 |

A0-A15 16 bit TLOOK starting address

The TLOOK and RLOOK tables are each divided into 8 segments and each segment contains 8 bytes. Figure 3 illustrates the segmentation of TLOOK and RLOOK. Figure 5 and 6 illustrate the contents of a single TLOOK and RLOOK segment.

#### TRANSMIT

To transmit, the WD2511 will have read from TLOOK the starting address and length of the first packet to be transmitted. The WD2511 will automatically transmit

the flag, address, and control fields. Next, the information field data will be transmitted using DMA from the "SEND #0 PACKET" memory buffer. At the end of the information field, the WD2511 will automatically send the FCS and closing Flag. The WD2511 will then move on to the next packet.

If retransmission of one or more (up to seven) packets becomes necessary, the WD2511 will automatically retrace the previous transmissions through the TLOOK table. The user's CPU software does not become involved in the retransmission. However, an ERROR COUNTER is incremented. (See Error Counter Section.)

#### RECEIVE

When received, each frame is checked for correct address and FCS fields and for type of control field. If the frame is a packet, the information field is placed in the assigned memory location in a method similar to that used in transmit mode. If the packet is received error-free and in proper N(S) sequence count, an interrupt is generated and the WD2511 is ready for the next packet which will be placed in the next location.

Figure 4 shows a "store-and-forward" example that is useful in a network node.





WD251



# **TLOOK AND RLOOK**

Figures 5 and 6 detail the individual segments for TLOOK and RLOOK.

BRDY means that the transmit buffer is ready. The WD2511 will send the block only after the CPU sets BRDY = 1. (BRDY is used in conjunction with the SEND bit.) At the completion of the transmission, the WD2511 will set BRDY = 0 and then read the BRDY of the next seament.

After transmitting a packet, an acknowledgement must be received from the remote device. The acknowledgement is contained in the received N(R) count of an Iframe or S-frame. Upon acknowledgement, the WD2511 will set ACK'ED = 1, and generate a blockacknowledged interrupt. Before assigning a new block to a segment in TLOOK, the CPU must make sure that the previous block which used that segment number has been acknowledged.

REC RDY informs the WD2511 that the receive buffer is ready. The WD2511 will not receive a packet into a buffer referenced by a particular segment until REC RDY = 1. If the WD2511 progresses to a segment which has REC RDY = 0, an error interrupt will be generated.

After receiving an error-free packet with correct N(S), the WD2511 will, in order: 1) Set FRCML (Frame Complete), clear REC RDY and store received residual count. 2) Store the received length, in characters, of the I-field in RCNT HI and RCNT LO. 3) Advance the NE count and generate a packet received interrupt. 4) Acknowledge the received packet at the first opportunity.

The addresses (TSADR and RSADR) are 16-bit binary addresses. HI represents the upper 8-bits and LO represents the lower 8-bits. The counts (TCNT and RCNT) are 12-bit binary numbers for the number of characters in the I-field.

TSADR is the starting address of the buffer to transmit and TCNT is the binary count of the number of bytes to transmit. (4087 is the maximum value allowed in TCNT.)

RSADR is the starting address of the receive buffer. After successfully receiving the packets, the WD2511 will write the value of RCNT which is the binary length of the received packet.

Whether the WD2511 accesses a look-up table or a memory block, a DMA Cycle is required for each access.

|                      | BIT #         |                           |    |    |    |    |    |      |  |  |
|----------------------|---------------|---------------------------|----|----|----|----|----|------|--|--|
| BYTE # IN<br>SEGMENT | 7             | 6                         | 5  | 4  | 3  | 2  | 1  | 0    |  |  |
| 1                    | ACK'ED        | NU                        | NU | NU | NU | NU | NU | BRDY |  |  |
| 2                    |               | TSADR HI                  |    |    |    |    |    |      |  |  |
| 3                    | TSADR LO      |                           |    |    |    |    |    |      |  |  |
| 4                    | SPARE TCNT HI |                           |    |    |    |    |    |      |  |  |
| 5                    |               | TCNT LO                   |    |    |    |    |    |      |  |  |
| 6                    |               | SPARE FOR USER DEFINITION |    |    |    |    |    |      |  |  |
| 7                    |               | SPARE                     |    |    |    |    |    |      |  |  |
| 8                    |               | SPARE                     |    |    |    |    |    |      |  |  |

NU = Not Used

# FIGURE 5. TLOOK SEGMENT

The control bits in TLOOK (BRDY and ACK'ED) and in RLOOK (FRCML and REC RDY) define various states for each segment. These states are shown below:

#### **TLOOK STATES**

| ACK'ED | BRDY | STATE                                                        |
|--------|------|--------------------------------------------------------------|
| 0      | 1    | Ready To Transmit (CPU set BRDY, cleared ACK'ED)             |
| 0      | 0    | * Transmitted and Awaiting Acknowledge (WD2511 cleared BRDY) |
| 1      | 0    | Received Acknowledge (WD2511 set ACK'ED)                     |
| 1      | 1    | This state not allowed                                       |

\*State 0-0 could also occur whenever there is no data ready to send.

|                      | 1                |                           |    | BI | Τ#   | i    |       | 1          |
|----------------------|------------------|---------------------------|----|----|------|------|-------|------------|
| BYTE # IN<br>SEGMENT | 7                | 6                         | 5  | 4  | 3    | 2    | 1     | 0          |
| 1                    | FRCML*           | NU                        | NU | NU | RES2 | RES1 | RES0  | REC<br>RDY |
| 2                    | RSADR HI         |                           |    |    |      |      |       |            |
| 3                    | RSADR LO         |                           |    |    |      |      |       |            |
| 4                    | NOT USED RCNT HI |                           |    |    |      |      | IT HI |            |
| 5                    |                  | RCNT LO                   |    |    |      |      |       |            |
| 6                    |                  | SPARE FOR USER DEFINITION |    |    |      |      |       |            |
| 7                    | SPARE            |                           |    |    |      |      |       |            |
| 8                    | SPARE            |                           |    |    |      |      |       |            |

NU = Not Used (NOTE: The "not used" bits may be either 1 or 0).

\*FRCML = Frame Complete

#### FIGURE 6. RLOOK SEGMENT





Notice that in a TLOOK segment, the 0-0 state could have two meanings. Due to control internal to the WD2511, this will not pose an ambiguity to the WD2511. However, if it is a difficulty to the CPU, the CPU could at start-up, set all ACK'ED bits. Since this would only be a

start-up procedure, this would not violate the "deadly embrace" rule.

In the "WAITING FOR ACKNOWLEDGE" state, one or more re-transmissions could occur.

#### **RLOOK STATES**

| FRCML | REC RDY | STATE                                               |  |
|-------|---------|-----------------------------------------------------|--|
| 0     | 1       | Ready To Receive (CPU set REC RDY, cleared FRCML)   |  |
| 1     | 0       | Received Packet (WD2511 set FRCML, cleared REC RDY) |  |
| 0     | 0       | Not Ready (CPU cleared FRCML)                       |  |
| 1     | 1       | This state not allowed                              |  |



RLOOK SEGMENT STATE FLOW

| [ | REGISTER | ER CHAIN BUFFER SIZE |          |          |          |          |          |          |          |
|---|----------|----------------------|----------|----------|----------|----------|----------|----------|----------|
|   | С        | Bit<br>7             | Bit<br>6 | Bit<br>5 | Bit<br>4 | Bit<br>3 | Bit<br>2 | Bit<br>1 | Bit<br>0 |

#### **CHAINING/BUFFER SIZE**

The WD2511 includes a chained-block feature which allows the user more efficient use of memory particularly in situations where the maximum packet size is much larger than the average packet size.

Register C is used to program the chaining feature. The upper 4 bits define CHAIN which is the number of chain

segments allowed in addition to the first segment. (If this feature is not used, make CHAIN all 0's.)

The lower 4 bits of Register C define the buffer size, which is the size of the buffer in multiples of 64 bytes including the transfer address (XFR ADR). If buffer size is 0000, the size is 64. For 0001, the size is 128, and so on.

The maximum amount of I-field data bytes that can be contained in this buffer is the buffer size minus 2 bytes (XFR ADR) for all transmitter and receiver chaining blocks, except for the last receiver chaining block. For this block, the maximum amount of I-field data bytes is the buffer size minus 3.

For example, suppose that the buffer size defines a segment size of 128 and that CHAIN defines 8 additional segments in addition to the first. (Register C would be hex 81 in this example.) When 126 bytes of I-field data have been received, the WD2511 will read the next two buffer bytes as a transfer address (XFR ADR) pointing to another segment. At the end of that segment is another XFR ADR, and so on, up to a maximum of 9 total segments, (in this example).

For the receiver, a XFR ADR of all 0's will mean that the next segment is not ready. If the WD2511 reaches a XFR ADR on the receiver with all 0s, there will be an Error Interrupt code 42. Otherwise, there will be an Interrupt code 41 which is a status indication that the WD2511 is going to the next segment. I/O Register 6 upper 4 bits gives a status of which chain segment is currently being used.

The transmitter chaining works like the receiver with the following exceptions:

- 1. XFR ADR = all 0's will not indicate next segment not ready.
- 2. There is no interrupt when going from one segment to another.
- 3. There is no status of the current segment being used.
- 4. Last chaining block is allowed to contain one more I-field data byte.

Total amount of I-field data bytes in receiver =  $(64 \times (1 + BUFFER SIZE) - 2) \times (1 + CHAIN) - 1$ .

The total amount of I-field data bytes in transmitter =  $(64 \times (1 + BUFFER SIZE) - 2) \times (1 + CHAIN).$ 

Also, note that the transmitter and receiver counts are modified by 2 for each time a chain boundary is crossed. For example, if BUFFER SIZE = 0001 (segment size = 128 bytes including XFR ADR), and if an l-field of 270 bytes is to be transmitted, then there will be two times that a chain boundary is crossed. The TCNT must be made 274 to send 270 bytes. The same is true for RCNT. Note that the largest block of data that can be sent without chaining is 1021 bytes.

#### "DEADLY EMBRACE" PREVENTION

A "deadly embrace" can occur when two processors reach a state where each is waiting for the other. In this case, the two processors are the user's CPU and the micro-controller inside the WD2511. Therefore, to prevent the "deadly embrace," the following rule is obeyed by the WD2511 and should also be obeyed by the user's CPU. This rule applies to TLOOK, RLOOK and to the I/O registers. The Error Counters do not apply to this rule.

| RULE: | If a bit is set by the CPU, it will not be set |
|-------|------------------------------------------------|
|       | by the WD2511, and vice versa. If a bit is     |
|       | cleared by the WD2511, it will not be          |
|       | cleared by the CPU, and vice versa.            |

As an example, the BRDY bit in the TLOOK segments is only set by the CPU and only cleared by the WD2511.

#### SEND BIT CONTENTION

The WD2511 may be clearing the Send bit when the host is setting it. To insure that the bit is set the host should read the status of the Send bit after it is set. If the Send bit is cleared the host should set it again.

#### **TLOOK AND RLOOK POINTERS**

There are three 3-bit counters for the status of the segments in TLOOK and RLOOK. Status Register #0 (SR0) contains counters NA and NB which are used in conjunction with TLOOK. NB is the segment number of the next block to be transmitted and is advanced at the end of each block transmission. NA is the value of the segment of the next block to be acknowledged. If all transmitted blocks have been acknowledged, then NA = NB.

In SR1 is a 3-bit counter, NE, used in conjunction with RLOOK. NE is the value of the segment number where the next received packet will be placed.

- NA = Next to be Acknowledged
- NB = Next Block to be Transmitted
- NE = Next Expected to be Received

#### VARIABLE BIT LENGTH AND RESIDUAL BITS

The WD2511 will only send 8 bits per character and all transmitted frames will have an integral number of bytes.

The WD2511 may receive a packet with, or without, an integral number of bytes. The "RES" bits in the RLOOK tables indicate the number of received residual bits. The residual bits occupy the lower portion of the last received character.

| RES 2 | RES 1 | RES 0 | <b>Received Residual Bits</b> |
|-------|-------|-------|-------------------------------|
| 0     | 0     | 0     | 0                             |
| 0     | 0     | 1     | 7                             |
| 0     | 1     | 0     | 6                             |
| 0     | 1     | 1     | 5                             |
| 1     | 0     | 0     | 4                             |
| 1     | 0     | 1     | 3                             |
| 1     | 1     | 0     | 2                             |
| 1     | 1     | 1     | 1                             |

# WD2511

#### **ERROR COUNTERS**

Following contiguously after RLOOK are six 8-bit error counters. The WD2511 will increment each counter at the occurrence of the defined event. However, the WD2511 will not increment past 255 (all 1's). The CPU has the responsibility of clearing each counter. The first counter past RLOOK is #1, etc.

| ERROR<br>COUNTER | TYPE OF ERROR                                                                   |
|------------------|---------------------------------------------------------------------------------|
| 1                | *Received Frames with FCS Error<br>(includes frames ABORTed in the<br>I-field). |
| 2                | Received Short Frames (less than 32-bits)                                       |
| 3                | **Number of times T1 ran-out<br>(completed)                                     |
| 4                | Not used                                                                        |
| 5                | *REJ Frames Received                                                            |
| 6                | <b>REJ Frames Transmitted</b>                                                   |

\*These counters are incremented only if the received A-field is equal to either Register E or F.

\*\*Incremented only when attempting to transmit a command.

The Error Counters are accessed by the WD2511 transmitter DMA channel. Therefore, if multiple errors are received while the WD2511 is transmitting a long frame, only the last error will be counted. The only Counters which could miss counts because of this are Counters #1, #2, and #5. The error Counters are incremented only when the link is up (LINK = 0).

#### OTHER I/O REGISTERS RECEIVED C-FIELD

Register 7 is the C-field of the last received frame, provided the A-field of the frame was equal to either register E or F, the FCS was good, the frame contained 32 or more bits, and the WD2511 is not waiting for a SABM or DISC in response to a transmitted FRMR.

#### TIMER

Registers 8 and 9 define a 10-bit timer (T1), and a 6-bit Maximum Number of Transmissions and Retransmissions counter (N2).

|          |     | BIT # |    |    |   |     |     |     |
|----------|-----|-------|----|----|---|-----|-----|-----|
| REGISTER | 7   | 6     | 5  | 4  | 3 | 2   | 1   | 0   |
| 8        |     |       |    | T1 | • |     |     | LSB |
| 9        |     |       | N2 |    |   |     |     |     |
|          | MSB |       |    |    |   | LSB | MSE | 3   |

MSB = Most Significant Bit

LSB = Least Significant Bit

T1 provides the value of a delay in waiting for a response and/or acknowledgement. The delay is the binary count multiplied by time CT where:

$$CT = \frac{16384}{CLK} sec$$

Thus, if CLK = 1 MHz, then T1 may be set in increments 16.384 milliseconds, to a maximum delay of 16.78 seconds. All ones in T1 is maximum delay.

Once the CPU establishes T1 and N2, there is no need to write into T1 and N2 again unless a master reset  $(\overline{MR})$  has occurred, there is a power loss, or the CPU needs to change T1 or N2. If a time-out occurs, the WD2511 will still retain T1 and N2.

The conditions for starting, stopping, or restarting T1 are shown below: ("Re-start" means starting T1 before it ran-out).

| START T1                                                                                           | RE-START T1                                               | STOP T1                                    |
|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------|
| <ol> <li>*I-frame sent and T1 not already<br/>in progress due to previous I-<br/>frame.</li> </ol> | *Acknowledgement received to some, but not all, I-frames. | Acknowledgement received for all I-frames. |
| 2. —                                                                                               | *RNR received while link up.                              |                                            |
| <ol> <li>*SABM or DISC sent. (N2 restarted at first occurrence)</li> </ol>                         | -                                                         | UA or DM Received                          |
| 4. Receiver Idle (REC IDLE = 1)                                                                    | *Frame sent, while REC IDLE<br>= 1                        | Detected REC IDLE = 0                      |
| 5. S — command sent                                                                                |                                                           | _                                          |

\*N2 is restarted.

#### "A" FIELD REGISTERS

Registers E and F provide a programmable A-field. This allows the WD2511 to be a super-set of the X.25 document. That is, the WD2511 can handle a wider range of application than the DTE-DCE links defined in X.25. These wider ranges include: DTE-to-DTE connection, multipoint, and loop-back testing. If the WD2511 is strictly in an X.25 DTE-DCE link, use the values shown below:

| DTE | Register $E = 01$<br>Register $F = 03$ |
|-----|----------------------------------------|
| DCE | Register E = $03$<br>Register F = $01$ |

If performing a loop-back test, either internal (CR03 = 1) or external (CR03 = 0), registers E and F should be the same.

# V. LAPB PROCEDURE

The Link Access Procedure Balanced (LAPB) is described in CCITT Recommendation X.25 as the Level 2 protocol for the Asynchronous Balanced Mode (ABM).

Zero bit insertion/deletion, use of flags, and FCS are part of Level 2, and have been discussed in this document.

The DTE is the Data Terminal Equipment and the DCE is the Data Circuit Termination Equipment (the network side of the DTE-DCE connection).

The DTE and DCE are each "combined" stations in .

Only the FRMR and I-frame contain I-fields.

LAPB Commands and Responses (Bit 0 is transmitted first).

that each can transmit and receive commands and responses. Whether a particular frame is to be taken as a command or a Response is determined by the contents of the address field. Commands from the DCE and the associated responses from the DTE use address A (hex 03).

Commands from the DTE and the associated responses from the DCE use address B (hex 01).

The individual commands and responses are shown in Figure 7.

#### USE OF POLL BIT

One use of the Poll bit (P) is in conjunction with Time-Out Recovery. Timer T1 is started at the beginning of a transmitted command provided it has not been previously started. If T1 runs out, the command will be retransmitted with P = 1. If T1 runs out again, the command will again be retransmitted, with P = 1 up to N2 times. At N2 + 1, an error interrupt will occur. If the command was an S-frame (originally an I-frame), the WD2511 will reset the link by transmitting a SABM. If the command was a SABM, the WD2511 will send a DISC. If a DISC, the WD2511 will continue to send a DISC indefinitely.

| FRAME TYPE  | COMMAND             | RESPONSE |   | BIT # |   |     |      |   |   |   |
|-------------|---------------------|----------|---|-------|---|-----|------|---|---|---|
|             |                     |          | 7 | 6     | 5 | 4   | 3    | 2 | 1 | 0 |
| INFORMATION | I-FRAME<br>(PACKET) |          | N | (R)   |   | Р   | N(S) |   |   | 0 |
| UNNUMBERED  | SABM                |          | 0 | 0     | 1 | Р   | 1    | 1 | 1 | 1 |
| (U)         | DISC                |          | 0 | 1     | 0 | Р   | 0    | 0 | 1 | 1 |
|             |                     | UA       | 0 | 1     | 1 | F   | 0    | 0 | 1 | 1 |
|             |                     | FRMR     | 1 | 0     | 0 | F   | 0    | 1 | 1 | 1 |
|             |                     | DM       | 0 | 0     | 0 | F   | 1    | 1 | 1 | 1 |
| SUPERVISORY | RR                  | RR       | N | (R)   |   | P/F | 0    | 0 | 0 | 1 |
| (S)         | RNR                 | RNR      | N | (R)   |   | P/F | 0    | 1 | 0 | 1 |
|             | *REJ                | REJ      | N | (R)   |   | P/F | 1    | 0 | 0 | 1 |

\*The WD2511 will not send a REJ command (will send REJ response, only), but may receive either a REJ command or REJ response.

#### FIGURE 7.

#### TRANSMISSION OF ABORT

An ABORT (seven contiguous 1's) is transmitted to terminate a frame in such a manner that the receiving station will ignore the frame. There are two conditions which will cause the WD2511 to transmit an ABORT:

- 1. Transmitter Under-Run
- 2. While transmitting a packet, a REJ is received.

#### LOOP-BACK TEST

The loop-back may be internal (CR03 = 1) or external (CR03 = 0). Of course, if external, RD and TD must be tied together either directly or remotely.

If CR03 = 1, TD is internally tied to RD, and the RD signal (pin 16) is internally disconnected. Also, TC is internally tied to RC and the pin at  $\overrightarrow{RC}$  (pin 17) is internally disconnected. CTS must be connected externally to GND or  $\overrightarrow{RTS}$ .

#### WD2511 ELECTRICAL SPECIFICATIONS:

ABSOLUTE MAXIMUM RATINGS:

Voltages referenced to VSS

| High Supply Voltage (VDD) 0.3 to + 15V      |
|---------------------------------------------|
| Voltage at any Pin 0.3 to + 15V             |
| Operating Temperature Range0°C to +70°C     |
| Storage Temperature Range – 55°C to + 125°C |

#### NOTE:

Maximum limits indicate where permanent device damage occurs. Continuous operation at these limits is not intended and should be limited to those conditions specified in the DC Electrical characteristics.

|        | •••                                |      |     |      |      |                       |
|--------|------------------------------------|------|-----|------|------|-----------------------|
| SYMBOL | PARAMETER                          | MIN  | TYP | MAX  | UNIT | CONDITIONS            |
| IDD    | VDD Supply Current                 |      | 20  | 70   | mA   |                       |
| ICC    | V <sub>CC</sub> Supply Current     |      | 200 | 280  | mA   |                       |
| VDD    | High Voltage Supply                | 11.4 | 12  | 12.6 | V    |                       |
| Vcc    | Low Voltage Supply                 | 4.75 | 5   | 5.25 | V    |                       |
| VIH    | Input High Voltage                 | 2.4  |     |      | V    |                       |
| VIL    | Input Low Voltage                  | 1    |     | 0.8  | V    |                       |
| Voh    | Output High Voltage                | 2.8  |     |      | V    | $I_O = -0.1 mA$       |
| VOL    | Output Low Voltage                 |      |     | 0.4  | V    | IO = 1.6mA            |
| ΙLΗ    | Input Source Current               |      |     | 10   | μA   | Vin = VCC             |
| ILL    | Input Sink Current                 |      |     | 10   | μA   | Vin = +0.4V           |
| IOZH   | Output Leakage (High<br>Impedance) |      |     | 50   | μΑ   | Vin = V <sub>CC</sub> |
| IOZL   | Output Leakage (High<br>Impedance) |      |     | 50   | μΑ   | Vin = +0.4V           |

| Operating DC Characteristics: VSS = | 0V.VCC = | +5.0V + 0.25.Vss = | + 12.0V + 0.6V TA = | = 0° to + 70°C |
|-------------------------------------|----------|--------------------|---------------------|----------------|
|                                     |          |                    |                     |                |

| SYMBOL          | PARAMETER                                                                      | MIN | ТҮР | MAX  | UNIT | CONDITIONS |
|-----------------|--------------------------------------------------------------------------------|-----|-----|------|------|------------|
| CLK             | Clock Frequency                                                                | 0.5 |     | 2.05 | MHz  | Note 1     |
| RC              | Receive Clock Range                                                            | 0   |     |      | MHz  | Note 4     |
| TC              | Transmit Clock Range                                                           | 0   |     |      | MHz  | Note 4     |
| MR              | Master Reset Pulse Width                                                       | 10  |     |      | mS   |            |
| TAR             | Input Address Valid to RE                                                      | 0   |     |      | nS   |            |
| TRD             | Read Strobe (or DACK<br>Read) to Data Valid                                    | 2   | f   | 375  | nS   | Note 5, 2  |
| THD             | Data Hold Time from Read to Strobe                                             | 20  |     | 100  | nS   |            |
| ТНА             | Address Hold Time from<br>Read Strobe                                          | 0   |     |      | nS   |            |
| TAW             | Input Address Valid to<br>Trailing Edge of WE                                  | 100 |     |      | nS   |            |
| Tww             | Minimum WE Pulse Width                                                         | 200 |     |      | nS   |            |
| TDW             | Data Valid to Trailing Edge<br>of WE or Trailing Edge of<br>DACK for DMA Write | 100 |     |      | nS   | Note 2, 3  |
| TWRR            | CS High between Writes                                                         | 300 |     |      | nS   |            |
| TRDR            | CS High between RE                                                             | 300 |     |      | nS   |            |
| T <sub>RR</sub> | RE Pulse Width                                                                 | 375 |     |      | nS   |            |
| TDAK            | DACK Pulse Width                                                               | 375 |     |      |      |            |
| TAHW            | Address Hold Time after<br>WE                                                  | 80  |     |      | nS   |            |
| TDHW            | Data Hold Time after WE or<br>after DACK for DMA Write                         | 100 |     |      |      |            |
| TDA1            | Time from DRQO (or DRQI)<br>to Output Address Valid if<br>ADRV = 1             |     |     | 80   | nS   | Note 3     |
| TDA0            | Time from $\overrightarrow{DACK}$ to Output<br>Address Valid if ADRV = 0       |     |     | 375  | nS   | Note 5     |
| T <sub>DD</sub> | Time from Leading Edge of<br>DACK to Trailing Edge of<br>DRQO (or DRQI)        |     |     | 375  | nS   | Note 5     |
| TDAH            | Outp <u>ut Add</u> ress Hold Time<br>from DACK                                 | 20  |     | 100  | nS   |            |
| TDMW            | Data Hold Time from DACK<br>for DMA Out                                        | 20  |     | 100  | nS   | Note 2     |
| TTDV            | TD Valid                                                                       | 100 |     |      | nS   |            |
| TSRD            | RD Setup                                                                       | 0   |     |      | nS   |            |
| THRD            | RD Hold                                                                        | 320 |     |      | nS   |            |

# AC Timing Characteristics (AC):

#### NOTES:

1. Clock must have 50% duty cycle.

2. There must not be a CPU read or write (CS-RE or CS-WE) within 500 nanoseconds after the trailing (rising) edge of DACK.

3. There must not be the leading (falling) edge of DACK allowed within 500 nanoseconds after the completion of a CPU write (CS-WE).

4. See "Ordering Information" for maximum serial rates.

5. C(load) = 100pf

6. Measured by discharging a 100pf capacitor to each pin through a 1K ohm resistor.

WD2511



CPU READ (CS IS LOW)

CPU WRITE (CS IS LOW)



DMA OUT

DMA IN



Information furnished by Western Digital Corporation is believed to be accurate and reliable. However, no responsibility is assumed by Western Digital Corporation for its use; nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Western Digital Corporation. Western Digital Corporation reserves the right to change specifications at anytime without notice.

#### **APPENDIX A**

#### TRANSPARENT MODES

The WD2511 was originally intended to be a link level controller meeting the requirements of X.25 LAPB and this has been accomplished. However, there has been an increasing demand from potential WD2511 users for additional frame types not included in the LAPB frame type repertoire.

For example, the Bell System standard, BX.25, calls for the use of XID (exchange identification) in LAPB connections of DTE-to-DTE and in Dial access. (Of course, DTE-to-DTE and Dial access are not X.25 in the strictest sense.) Also, Western Digital has received several requests for the use of a SIM (set initialization mode). Also, there has been one request to allow "unknown" frames to pass thru the chip for the purpose of teleloading.

Therefore, we have added two selectable modes to the WD2511: transparent transmit and transparent receive. Basically, these two modes allow the user the option to pass certain non-LAPB frames thru the chip without controlling these frames according to the LAPB protocol.

#### FEATURES OF THE TRANSPARENT MODES

- May transmit any A and C field under transparent control.
- May receive any U-frame not part of the LAPB repertoire if transparent-receive enabled.
- Transparent modes are link state independent.

#### **1.0 HOW THE TRANSPARENT MODES WORK**

Two control bits have been added. TXMT (CR17) is the bit to enable the Transparent Transmit and TRCV (CR16) will enable the Transparent Receive.

#### **1.1 TRANSPARENT TRANSMIT**

When TXMT = 1, the WD2511 will transmit the frame in the next TLOOK segment provided SEND (CR10) = 1 and BRDY of that TLOOK segment is 1. The link may be either UP or DOWN. The WD2511 will not add the A and C fields to the Transparent Transmitted frame. The user's CPU must add these fields as the first two bytes in the transmit buffer. Thus, the significance of the transmit count (TCNT) is different from normal packet transmission. In packet transmission, TCNT is the count of the I-field. In transparent transmission, TCNT is the I-field plus the A and C fields (I-field plus two bytes).

The timer, T1, will be disabled in transparent transmission. Therefore, if using this feature while the link is UP, it is advised that TXMT be set only when there are no outstanding (unacknowledged) packets which is indicated whenever NA = NB.

At the end of the transparent transmission, there will be an interrupt with XBA = 1. The SEND bit will be cleared, but the BRDY bit will not be cleared. The NB pointer will not be incremented. To send another transparent frame, set SEND. To resume packet transmission, clear TXMT and set SEND. (Of course, the TLOOK segment must be set-up prior to setting SEND.)

If SEND is set while the link is down, a transmission will occur even if TXMT = 0. Under this condition, a packet will be transmitted from current TLOOK segment, NB and V(S) will be incremented, and the chip will go on to the next TLOOK segment just as if the link were UP. However, the WD2511 will expect no acknowledgment to the packet(s). If the link is brought UP later, NB and V(S) are cleared to 0 at the time the link comes UP.

The bit  $\overline{XI}$  (CR15) is used only when TXMT = 1.  $\overline{XI}$  stands for Transmit I-field. If the frame contains three, or more bytes, not counting FCS, set  $\overline{XI} = 0$ . If the frame contains two bytes not counting FCS, set  $\overline{XI} = 1$ . When  $\overline{XI} = 1$ , only two frame bytes will be transmitted regardless of TCNT. DO NOT attempt to transmit a frame with TXMT = 1 and  $\overline{XI} = 0$  if TCNT is 2, 1, or 0.

#### **1.2 TRANSPARENT RECEIVE**

For the purposes of this discussion, it is necessary to define an "unknown frame." That is, a frame which is "unknown" to the WD2511.

Unknown Frame: A U-frame (unnumbered) frame which is not part of the LAPB repertoire. The U-frame repertoire in LAPB is SABM, DISC, DM, UA, and FRMR. For the purposes of this discussion, "UF" will refer to an unknown frame without an I-field, and "UFI" will refer to an unknown frame with a I-field.

A received SREJ (Selective REJect), which is an Sframe, is not considered an unknown frame by the WD2511. If the link is DOWN and an SREJ command is received, a DM response will be sent. If the link is DOWN and a SREJ response is received, the SREJ is disregarded. If the link is UP and a SREJ command or response is received, a FRMR will be sent with W = 1. The WD2511 will treat a received SREJ the same whether TRCV is 0 or 1.

A received packet (I-frame) response is not considered an unknown frame by the WD2511. If the link is DOWN, the frame is disregarded. If the link is UP, a FRMR will be sent with W = 1 and X = 1. The received packet response is treated the same whether TRCV is 0 or 1.

Whether TRCV is 0 or 1, the WD2511 will check all received frames to insure that the A-field equals either Register E or F, that the FCS is correct, and that the frame contains 32 bits or more. If TRCV = 0, and if a UF or UFI is received, and if the link is UP, the WD2511 will send a FRMR with W = 1 (W and X are 1 in the case of a UFI). See "States of the WD2511."

When TRCV = 1, the WD2511 will be enabled to receive all frames. If the frame is "known" by the WD2511, it will be treated according to the protocol just as if TRCV = 0. However, if the frame is a UF or UFI, it will be passed on to the user's CPU.

WD2511

When an unknown frame is received while TRCV = 1, there will be an interrupt with ERROR = 1 and the Error Register (ER0) will contain one of the following hexidecimal values:

| ER0 | FRAME RECEIVED |
|-----|----------------|
| 60  | UFI Response   |
| 61  | UFI Command    |
| 62  | UF Response    |
| 63  | UF Command     |

The C-field of the received frame is contained in Register #7. If the frame had an I-field, the frame will be placed in the next RLOOK segment and the value of RCNT will represent the count of bytes in the I-field (not including the A and C fields). The RLOOK pointer, NE, will be incremented. Therefore, the relationship between NE and V(R) will not be guaranteed if transparent receive is used while the link is UP. However, this will not cause a sequence problem in the protocol since the actual V(R) is maintained in an internal register in the WD2511. Note that NE is cleared when the link is brought UP. Thus, if transparent receive is used only when the link is DOWN, then NE will be equal to V(R).

A word of caution. If the next RLOOK segment is not ready when a UFI is received, the Error Register (60 or 61) will be overwritten almost immediately with an error code 10 (RLNR) and the user will not know if the received UFI was a command or response.

If RECR is set while the link is DOWN, the WD2511 will prepare to receive I-fields, whether TRCV is 0 or 1. If a packet command is received, there will be a PKR interrupt, and the NE and V(R) will be incremented. Of course, NE and V(R) are cleared once the link is brought up.

The following tables show what action the WD2511 will take when various frames are received.

| TABLE 1. | PACKET | RECEIVED | (command, not response) |
|----------|--------|----------|-------------------------|
|----------|--------|----------|-------------------------|

| LINK    | RLOOK READY | TRCV   | ACTION BY WD2511                                                                                                                                |
|---------|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| DOWN    | NO          | 0 or 1 | DISREGARD                                                                                                                                       |
| DOWN    | YES         | 0 or 1 | If $N(S) = V(R)$ , PKR interrupt, V(R) and NE incremented. No ack transmitted. If $N(S)$ not = V(R), DISREGARD.                                 |
| UP      | NO          | 0 or 1 | If N(S) = V(RT), RNR sent, Else, REJ condi-<br>tion entered.                                                                                    |
| UP<br>• | YES         | 0 or 1 | If $N(S) = V(R)$ , PKR interrupt, V(R) and NE incremented. Acknowledgement sent at next opportunity. If $N(S)$ not = V(R), enter REJ condition. |

#### TABLE II. UFI RECEIVED

| LINK | RLOOK READY | TRCV   | ACTION BY WD2511                          |
|------|-------------|--------|-------------------------------------------|
| DOWN | NO          | 0 or 1 | DISREGARD                                 |
| DOWN | YES         | 0      | DISREGARD                                 |
| DOWN | YES         | 1      | Error interrupt 60 or 61. NE incremented. |
| UP   | NO          | 0      | FRMR sent. $W = 1 X = 1$                  |
| UP   | NO          | 1      | DISREGARD                                 |
| UP   | YES         | 0      | FRMR sent. $W = 1 X = 1$                  |
| UP   | YES         | 1      | Error interrupt 60 or 61. NE incremented. |

If TRCV = 1 and UF (no I-field) is received, there will be an Error interrupt 62 or 63, independent of the link state or the readiness of RLOOK.

Of course, the received C-field of any frame will be in Register #7 provided the A-field matched either Register E or F, the FCS was good, and the frame contained 32, or more, bits.

#### **APPENDIX B**

#### HALF DUPLEX OPTION

The WD2511 is basically a full duplex device. The receiver is maintained in an "always ready" condition even if the receive buffer is not ready. Thus, whether the received frame came from a full or half duplex system is of no consequence to the WD2511.

Therefore, the half duplex option affects only the WD2511 transmitter. Half duplex is enabled when  $H/\bar{F}$  (CR05) = 1.

The WD2511 will transmit one frame at a time according to the following procedure:

- A. Enable RTS (RTS goes low).
- B. Wait for CTS (CTS input goes low).
- C. Transmit frame (when CTS is active).
- D. Remove RTS (RTS goes high 21/2 bits of time after the last 0 of the trailing flag.)

#### NOTES:

The leading flag will be transmitted somewhere between 5 and 13 bits after CTS goes low.

Interframe fill will be all 1's (IDLE).

If T1 is internally activated it is started when  $\overline{\text{RTS}}$  goes low.

After RTS goes low, the frame will not begin transmission until CTS goes low. After the frame has started, the transmission of that frame is completed even if CTS returns high during the frame.

#### APPENDIX C STATE DESCRIPTIONS





CONDITION FOR RESET OR DISCONNECT LINK IS UP



WD2511

# STATE TABLE I LINK DOWN, BUT GOING UP

(Column 2 also applies to link reset)

# ACTION BY WD2511

| STIMULUS:                                           | COLUMN 1:<br>DISC sent. Waiting for UA or DM. | COLUMN 2:<br>SABM sent. Waiting for UA.                      |
|-----------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------|
| T1 runs out                                         | Re-send DISC. P = 1.                          | Re-send SABM. P = 1.                                         |
| T1 and N2 run out                                   | Re-send DISC. P = 1.                          | Send DISC. Interrupt ER0 = 24. Go to column 1                |
| Received UA                                         | Send SABM. Go to column 2                     | Clear NA, NB, NE, V(R), V(S). Go to link up flow.            |
| Received DISC                                       | Send DM.                                      | Send DM.                                                     |
| Received SABM                                       | Disregards                                    | Send UA. Clear NA, NB, NE, V(R), V(S). Keep waitiing for UA. |
| Received DM                                         | Send SABM. Go to column 2.                    | Send DISC. Go to column 1.                                   |
| Received something other than UA, DM, DISC, or SABM | Disregard.                                    | Disregard.                                                   |

# STATE TABLE II LINK GOING DOWN (WAS UP)

User sets MDISC, Chip sends DISC.

#### ACTION BY WD2511

| STIMULUS                                                  | DISC sent. Waiting for UA.       |
|-----------------------------------------------------------|----------------------------------|
| T1 runs out                                               | Re-send DISC. P = 1.             |
| Received UA or DM                                         | Go to Link Down Flow             |
| Received SABM                                             | Disregard                        |
| Received DISC                                             | Send DM. Go to Link<br>Down Flow |
| Received something<br>other than DISC,<br>SABM, UA, or DM | Disregard.                       |

# **USE OF FLAGS BY THE WD2511**

Once MDISC has been reset the WD2511 will send interframe flags (hex 7E) if full duplex is selected (CR05 = 0) (point ST of the Link Down Flow point has been entered). If half duplex is selected, (CR05 = 1), interframe fill will be all 1's (IDLE).

The WD2511 does not require the interframe time fill flags. Either idle or flags will be accepted. However, if the receiver detects idle for time T1 X N2, the WD2511 will send a DISC.

When sending continuous flags, the WD2511 will send:

011111100111111001111110011...

The WD2511 will accept either the above sequence as continuous flags, or the "shared zero" pattern:

01111110111110111111011111011111...

# DEFINITIONS OF COMMAND AND RESPONSE

A transmitted or received command or response is a frame with the A-field defined below:

| FRAME                | A-FIELD =  |
|----------------------|------------|
| Transmitted Command  | Register E |
| Received Command     | Register F |
| Transmitted Response | Register F |
| Received Response    | Register E |

For non-transparent transmitted frames, only commands or responses are transmitted. A transparent transmitted frame (TXMT = 1) may have any A-field the user chooses.

All received frames must be either commands or responses or the frame is disregarded ("thrown away"), even if transparent receive is enabled (TRCV = 1).

#### STATE TABLE III SENDING I-FRAMES (PACKETS) AND S-COMMANDS

#### NOTES:

In all subsequent pages, the link is considered Up (LINK = 0) unless otherwise stated. X = don't care. TXMT = 0 for Table III.

| SEND | BRDY | NA AND NB | RNRR | T1 EXPIRES | RCVD REJ | ACTION BY WD2511                                                                                                                                                               |
|------|------|-----------|------|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | 0    | X         | 0    | No         | No       | Clear SEND (CR10)                                                                                                                                                              |
| 1    | 1    | X         | 0    | No         | No       | Send next packet with $N(S) = NB$ . After trans-<br>mission complete. Incre-<br>ment NB. Exception: If $NB + 1 = NA$ , do not send<br>next packet. There are 7<br>outstanding. |
| Х    | X    | X         | 1    | Yes        | No       | Send S-command, P = 1.                                                                                                                                                         |
| X    | X    | not =     | Х    | Yes        | No       | Send S-command, P = 1.                                                                                                                                                         |
| x    | X    | not =     | X    | No         | Yes      | Make NA = received N(R).<br>Start sequential retransmis-<br>sion of packets beginning<br>with N(S) = NA. See Note 3.                                                           |

#### NOTES ON STATE TABLE III

- 1. Received S-frames in Table III are assumed to have valid N(R)'s.
- 2. When an acknowledgement of one or more previously transmitted packets is received, NA is set equal to the received N(R). All TLOOK segments from the old value of NA up to N(R) 1 are acknowledged and the appropriate ACKED bits in the TLOOK segments will be set. After setting the ACKED bits, an XBA interrupt is generated.
- 3. Assuming appropriate TLOOK segments are ready, packets are transmitted sequentially without waiting for an acknowledgement, with three exceptions:
  - a. There are already seven outstanding (unacknowledged) packets (NB + 1 = NA).
  - b. The remote station has indicated a busy condition by sending an RNR frame (RNRR). T1 is started and an S-command will be transmitted with P = 1 when T1 expires.
  - c. T1 expired and there are one or more outstanding packets. An S-command will be transmitted with P = 1.
- 4. If an S-frame command is received, the WD2511 will transmit an S-frame response at the next opportunity.
- 5. If SEND = and TXMT = 1, a frame will be transmitted from the next TLOOK segment if BRDY = 1. After transmission, SEND is cleared by the WD2511.

# RECEIVING AND TRANSMITTING A NULL PACKET

If an error-free (FCS good) packet is received with a correct N(S), but has no I-field, that packet will be treated the same as a packet with an I-field. The fact that there was no I-field is shown by RCNT equal to all 0's.

The WD2511 will not transmit a null packet. TCNT must not be allowed to be all 0's.

#### **SENDING A REJ (RESPONSE)**

- 1. The REJ condition is entered any time an error-free packet is received with an out-of-sequence N(S). Exception: If the received N(S) + 1 = V(R), then the received N(S) has been acknowledged, and either an RR or RNR is transmitted.
- 2. When the REJ condition is entered, the REJ frame with N(R) = V(R) is transmitted immediately if a packet is not being transmitted, or, at the completion of the current packet. There are two exceptions, as noted in 3 and 4 below.
- 3. If a link resetting SABM needs to be transmitted, the SABM is sent. When the UA is received for the SABM, the REJ condition is cleared.
- 4. If the receiver is not ready (RNRX = 1), the REJ is not sent.
- 5. Once the REJ condition is entered, only one REJ will be transmitted. Another REJ is not transmitted unless the REJ condition is cleared and re-entered. The REJ condition is cleared if a packet is with correct N(S) if a SABM is received, or if a SABM is transmitted and a UA received.
- 6. When the REJ is transmitted, error counter #6 is incremented.

#### RECEIVING A REJ (RESPONSE OR COMMAND)

Suppose a REJ has been received error-free with no I-field, then:

1. If the N(R) is not valid, an interrupt is generated with ER0 = C8, and a FRMR is transmitted.

- WD2511
- If the N(R) is valid, and greater than NA, at least one transmitted packet is acknowledged. The appropriate ACKED bits in TLOOK are set and an XBA interrupt is generated.
- If the N(R) is valid and less than NB, the WD2511 will begin sequential retransmission starting with V(S) = received N(R). If a packet is being transmitted when the REJ was received, that packet is aborted. If the N(R) is valid and equal to NB and a packet is being transmitted, that packet (which will be #NB) is aborted and retransmission will begin.
- 4. If the N(R) is valid and equal to NB and there is no packet being transmitted, there is no retransmission initiated. In this case the REJ has the same effect as an RR.
- 5. If in 2, 3, or 4 above, the received REJ is a command, the WD2511 will transmit a RR or RNR response at the next respond opportunity.

#### **DEFINITION OF VALID RECEIVED N(R)**

#### Reference

CCITT Recommendation X.25 paragraphs 2.4.10 and 2.3.4.10.

#### Definition

A valid received N(R) is greater than or equal to NA, and less than or equal to NB.

- 1. The "greater than" and "less than" relationships must be understood in a circular sense. 0 could be greater than 7 depending on the values of NA and NB.
- 2. If NA = NB, there is only one possible valid received N(R), N(R) = NA.
- If NB + 1 = NA, there are seven outstanding packets and any received N(R) will be valid: N(R) = NB ACK's all of the outstanding frames, N(R) = NA ACK's none of them, and an N(R) in between ACK's some of the packets.
- Basically, a received N(R) which is not valid is one which acknowledges a packet, or packets, never transmitted.

| LINK  | RECR  | REC RDY | ACTION                                                                                                                                        |
|-------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | Х     | X       | No S-frame transmitted when link down.                                                                                                        |
| 1 → 0 | 1     | 1       | RLOOK ready. No RNR frame sent.                                                                                                               |
| 1→0   | 1     | 0       | RNR response sent immediately after link<br>Up. RNRX set. RLNR Interrupt                                                                      |
| 1→0   | 0     | x       | RNR response sent immediately after link<br>Up, RNRX set. No RLNR interrupt                                                                   |
| 0     | 1     | 1       | Receiver ready to accept packets.                                                                                                             |
| 0     | 1→0   | 1       | Receiver ready to accept packets.                                                                                                             |
| 0     | 1     | 0       | RNR response sent. RNRX set. RLNR Inter-<br>rupt.                                                                                             |
| 0     | 0 → 1 | 1       | If RNRX was set, then RNRX will be cleared<br>after the next received packet or S-com-<br>mand. After that, an RR or REJ response is<br>sent. |
| 0     | 0     | 0       | RNR response sent. RNRX set. There is no RLNR interrupt.                                                                                      |

#### NOTES ON STATE TABLE IV

STATE TABLE IV

- 1. The arrows (→) indicate a change in state from the value on the left to the value on the right.
- 2. The RNRX status bit is set at the time the receivernot-ready condition was established. The RNR frame will be sent immediately if no packet is being sent or after the end of the current packet.
- 3. When a received packet is brought into memory with RNRX = 0, the packet will be accepted provided the FCS and N(S) are correct and the I-field is not too long. The N(R) may or may not be correct but is checked separately. If N(R) is not valid, a FRMR is transmitted.
- 4. Whenever RNRX = 1, the I-field of a received frame is not brought into memory. For received packets, the N(S) and N(R) are checked as usual. If the N(S) is out-of-sequence, the REJ will not be transmitted.
- 5. If a link resetting SABM is transmitted when RNRX = 1, RNRX will be cleared when the UA is received. If the condition which caused receiver-not-ready still exists, an RNR is sent and RNRX is set. However, if the receiver instead is ready, I-field data may be brought into memory.

The same also applies when a link resetting SABM is received.

WD251<sup>-</sup>

# STATE TABLE V REMOTE STATION BUSY (RECEIVED RNR: RNRR = 1)

| SEND  | NA AND NB | RECVD<br>ACK? | RECVD<br>RNR | RECVD RR,<br>REJ OR UA | T1 EXPIRES | ACTION                                                                                                 |
|-------|-----------|---------------|--------------|------------------------|------------|--------------------------------------------------------------------------------------------------------|
| Х     | not =     | Yes           | Yes          | No                     | No         | Set RNRR. Restart T1 and N2. Update NA.                                                                |
| 0     | Equal     | No            | Yes          | No                     | No         | Set RNRR. Start T1.                                                                                    |
| х     | not =     | No            | No           | No                     | Yes        | Send S-command (P = 1). If<br>RNR subsequently received<br>restart T1 and N2.                          |
| х     | not =     | Yes           | No           | Yes, but not UA        | No         | Clear RNRR. Restart T1 and N2. Update NA.                                                              |
| Х     | x         | X             | No           | Yes                    | No         | Clear RNRR.                                                                                            |
| 0 → 1 | Equal     | No            | No           | No                     | No         | Send next packet. Increment<br>NB after transmission. (Then,<br>NB does not = NA). Start T1<br>and N2. |

#### 2. NOTES OF TABLE V

- 1. If SEND = 1, it is assumed for this table that BRDY of the next TLOOK segment is set.
- 2. If RNRR = 1, an RR or RNR command is transmitted at T1 intervals.

# SENDING S-FRAME COMMANDS

When an S-frame command is to be transmitted, an RR command is transmitted if RNRX = 0 or an RNR command is transmitted if RNRX = 1. If RNRX = 0, and a REJ is waiting to be transmitted, a REJ command is transmitted.

For all transmitted S-commands, the P bit is set to 1.

An S-command will be transmitted at T1 intervals if an RNR is received (RNRR = 1) or if T1 has expired due to waiting for an acknowledgement to previouusly transmitted packets.

# CONDITIONS FOR SENDING SABM (LINK RESET)

- 1. FRMR received.
- 2. Have sent an S-command N2 times with P = 1 (at T1 intervals) without receiving an S-response with F = 1.

#### UNSOLICITED UA OR UNSOLICITED F BIT

If an unsolicited UA or an unsolicited F bit is received with the link up, a FRMR will be transmitted with W = 1.

#### SENDING AN FRMR

An FRMR may be transmitted for any of the reasons indicated in X.25 (W, X, Y, Z). An FRMR is transmitted only if the link is up.

Upon sending a FRMR, the WD2511 will not send a packet until the FRMR condition is cleared. The WD2511 will also discard any received I-fields. The FRMR condition is cleared when either a SABM or DISC is received.

If an S or I-frame is received which acknowledges a previously transmitted packet(s), the acknowledgement(s) is accepted, the appropriate ACKED bits in TLOOK are set, and there is an XBA interrupt.

While in the FRMR condition, the WD2511 will act as shown below:

| FRAME RECEIVED                                  | ACTION BY WD2511                                                      |
|-------------------------------------------------|-----------------------------------------------------------------------|
| SABM                                            | Send UA. Clear FRMR condition. Enter infor-<br>mation transfer phase. |
| DISC                                            | Send UA. Clear FRMR<br>condition. Enter logical<br>disconnect state.  |
| Packet with good N(R)                           | Retransmit FRMR                                                       |
| S-frame with good N(R)<br>(command or response) | Retransmit FRMR                                                       |
| Packet or S-frame with<br>bad N(R)              | Transmit new FRMR (Z<br>= 1)                                          |
| Any frame with violation<br>W, X, Y             | Transmit new FRMR                                                     |

#### **RECEIVING AN FRMR**

After a FRMR has been received:

- 1. The FRMR I-field will bee in the memory referenced by the current NE segment, provided the receiver was ready.
- 2. The SEND bit is cleared.
- No more I-field data is allowed to come into memory until the user makes the receiver memory ready.
- 4. A link resetting SABM is transmitted and an error interrupt, ER0 = C0 is generated.
- 5. After the UA is received for the SABM, the NA, NB, NE, V(R), and V(S) are cleared to 0.

#### PROTOCOL SIGNIFICANCE OF TLOOK/RLOOK POINTERS

The NE, NA, and NB pointers have a relationship with the sequence counters used in the LAPB protocol.

The RLOOK pointer NE is equal to V(R) at all times if TRCV = 0. However TRCV = 1 and the link is UP, there is no guaranteed relationship between NE and V(R).

TLOOK pointer NB is the Next Block to be transmitted. If the chip is not in packet retransmission, NB is equal to the V(S) of the next new packet to be transmitted.

TLOOK pointer NA is the Next packet to be Acknowledged. It represents the V(S) number for the oldest packet in the retransmission buffer.

#### USE OF THE RECR BIT

The RECR (CR01) bit should be understood as an instruction to the WD2511 to enable the receiver function. The WD2511 will test RECR as soon as MDISC is cleared, and will retest RECR after each link set-up and each link reset. Once the receiver is ready, the WD2511 will not test RECR again unless there is a link set-up or a link reset.

The receiver-not-ready condition is indicated by RNRX = 1. This condition is cleared after the user makes RECR = 1 with RECRDY = 1 (in RLOOK #0) and after either a packet or an S-frame is received from the remote station.

If RECRDY of the next RLOOK is 0 but RECR = 0, there will not be an RLNR interrupt, but RNRX will be set. If RECR = 1 but the RECRDY bit of the next RLOOK segment is 0, there will be an RLNR interrupt (error code 10) and RNRX will be set.

#### HOST PROCEDURE FOR LINK RESET

The host should keep its own set of variables to determine the index of the Next Packet to be Received and the Next Packet to be Acknowledged because if a Link Reset occurs, the chip resets its NA, NB, and NE counters. After a Link Reset the host should look for unprocessed received packets (FRCML = 1) in the RLOOK table beginning at its Next Packet to be Received segment and proceeding in order until it finds FRCML = 0. Furthermore, if RLOOK0 has RECRDY = 1 and RECR is set to 1, a packet can be stored into RLOOK0 immediately after a Link Reset. Therefore, the host should also look for received packets beginning at RLOOK0 after a Link Reset.

The chip resets the SEND bit after a Link Reset so no new TLOOK buffers will be sent until the host sets SEND again. After a Link Reset the host should look for any unprocessed acknowledged packets (ACKED = 1) in the TLOOK table beginning at its Next Packet to be Acknowledged segment and proceeding in order until it finds a segment with ACKED = 0. Then the host must set up the TLOOK segments again so that the oldest unacknowledged packet is in TLOOK0, the next in TLOOK1, and so on, setting the BRDY = 1 in each occupied segment. (New packets may be added to the TLOOK at the next available segment.) When the host has finished setting up the TLOOK segments, it should set the SEND bit to 1. At this point packet transmission will resume if the remote station is up and is not in a receiver not ready (RNRR = 1) condition.

When presenting packets to the chip for transmission, the host should implement a timer. The value of the timer is system dependent and varies with packet size and line speed but should be in the order of seconds. If a packet has not been acknowledged by the time the timer expires, the host should check the SEND bit. If it is reset, set it to 1 again and restart the timer. If it was still set, the link must be reset. Do this by setting the MDISC bit (CR00 = 1), waiting for the link to go down (LINK = 1), then resetting MDISC (CR00 = 0), and waiting for the link to come back up (ER0 = 21 or, if RLOOK0 was not ready, 11 and LINK = 0).

For more software information refer to the WD2511 Application Note.

# WD2511

# APPENDIX D

**GLOSSARY OF DATA COMMUNICATIONS TERMS** 

| The following i | s a list of industry-accepted data communications terms that are applicable to this specification.                                                        |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ABM             | Asynchronous Balanced Mode                                                                                                                                |  |  |  |
| ADCCP           | Advanced Data Communications Control Procedure (ANSI BSR X3.66)                                                                                           |  |  |  |
| ANSI            | American National Standards Institute                                                                                                                     |  |  |  |
| ARM             | Asynchronous Response Mode                                                                                                                                |  |  |  |
| CCITT           | International Consultative Committee for Telegraphy and Telephony                                                                                         |  |  |  |
| CMDR            | Command Reject. A U-Frame                                                                                                                                 |  |  |  |
| DCE             | Data Circuit Termination Equipment (the network side of the DTE/DCE link)                                                                                 |  |  |  |
| DISC            | Disconnect. A U-Frame                                                                                                                                     |  |  |  |
| DTE             | Data Terminal Equipment                                                                                                                                   |  |  |  |
| DM              | Disconnect Mode. A U-Frame (LAPB, only)                                                                                                                   |  |  |  |
| ECMA            | European Computer Manufacturers Association                                                                                                               |  |  |  |
| FCS             | Frame Check Sequence                                                                                                                                      |  |  |  |
| FDX             | Full Duplex (also called "two way simultaneous")                                                                                                          |  |  |  |
| FRAME           | Basic serial block of bit-oriented data. Includes leading and trailing flags, address field, control field, FCS field, and an optional information field. |  |  |  |
| FRMR            | Frame Reject. A U-Frame (LAPB, only)                                                                                                                      |  |  |  |
| HDLC            | High-Level Data Link Control (ISO 3309)                                                                                                                   |  |  |  |
| HDX             | Half Duplex (also called "two way alternate")                                                                                                             |  |  |  |
| HOST            | Another name for a DTE                                                                                                                                    |  |  |  |
| I-Frame         | Information Frame. Control field bit 0 is 0. In X.25 an I-frame is a packet.                                                                              |  |  |  |
| ISO             | International Standards Organization                                                                                                                      |  |  |  |
| LINK            | The logical and physical connection between two data terminals                                                                                            |  |  |  |
| LAP             | Link Access Procedure                                                                                                                                     |  |  |  |
| LAPB            | Link Access Procedure Balanced                                                                                                                            |  |  |  |
| N2              | Maximum number of retransmissions of a frame. (Also called retransmission count variable.)                                                                |  |  |  |
| NODE            | Another name for a DCE or DTE.                                                                                                                            |  |  |  |
| N(R)            | Sequence number of next frame expected to be received.                                                                                                    |  |  |  |
| N(S)            | Sequence number of current frame being transmitted.                                                                                                       |  |  |  |
| OCTET           | An 8-bit byte                                                                                                                                             |  |  |  |
| PACKET          | An I-Frame in X.25                                                                                                                                        |  |  |  |
| PAD             | Packet Assembly/Disassembly facility                                                                                                                      |  |  |  |
| ŘEJ*            | Reject. An S-Frame                                                                                                                                        |  |  |  |
| RNR*            | Receiver Not Ready. An S-Frame                                                                                                                            |  |  |  |
| RR*             | Receiver Ready. An S-Frame                                                                                                                                |  |  |  |
| S-Frame         | Supervisory Frame. Control field bit $0 = 1$ and bit $1 = 0$                                                                                              |  |  |  |
| SARM            | Set Asynchronous Response Mode. (LAP, only)                                                                                                               |  |  |  |
| SABM            | Set Asynchronous Balanced Mode. (LAPB, only)                                                                                                              |  |  |  |
| SDLC            | Synchronous Data Link Control (IBM document GA27-3093)                                                                                                    |  |  |  |
| T1              | A Primary Timer for a delay in waiting for a response to a frame                                                                                          |  |  |  |
| U-Frame         | Unnumbered Frame. Control Field bit $0 = 1$ and bit $1 = 1$                                                                                               |  |  |  |
| UA              | Unnumbered Acknowledge. A U-Frame                                                                                                                         |  |  |  |
| X.25            | Recommendation by CCITT on Interfacing to Public Packet Switching Networks                                                                                |  |  |  |

X.3, X.28, X.29 Recommendations by CCITT involving PAD facilities

\*There are also RR, RNR, and REJ packets which are not the same as the S-frame RR, RNR and REJ discussed in this document.

#### **ORDERING INFORMATION**

| Order Number | Maximum Data Rate |
|--------------|-------------------|
| WD2511AN-01  | 100 Kbps          |
| WD2511AN-05  | 500 Kbps          |
| WD2511AN-11  | 1.1 Mbps*         |

\* Higher speeds available on special order.



# Package Diagram

48 LEAD CERAMIC "T" or "AN"

# WESTERN DIGITAL

O R P O R A T / O Application Note Using The WD2511



This application note provides an introduction to the X.25 communication protocol and introduces the ISO reference model. The link layer of X.25 is highlighted as it can today be implemented with a single LSI device, the WD2511.

С

The bulk of this document provides details of the hardware and software interfaces that a user typically encounters when using the WD2511. Schematic and timing diagrams for a typical Z80 interface along with high level flowcharts for initialization and operation are given. This circuitry is applicable for applications where the TC/RC speed is 64 Kbps and below.

#### CONTENTS

1.0 The WD2511 General Description

2.0 The WD2511 and the ISO Model

3.0 Hardware

4.0 Software

Appendix A Glossary

Appendix B LAP vs LAPB

#### 1.0 THE WD2511 GENERAL DESCRIPTION

The WD2511 is an LSI device that fully handles the link level (level 2) of the CCITT X.25 communications protocol.

In addition to the traditional parallel/serial converters and FCS logic, the WD2511 incorporates a highly efficient micro-programmed processor that fully handles the required link set-up and frame sequencing operations conventionally delegated to a "user defined" processor. The WD2511 also contains an intelligent two-channel DMA controller to further simplify its integration into a user's system.

# 2.0 THE WD2511 AND THE ISO MODEL

The CCITT X.25 recommendation comprises three levels of protocols (Level 1 to 3). See Figure 1.

Level 1 is the physical level, which concerns the actual means of bit transmission across a physical medium.

Level 2 is the link level which includes frame formatting, error control and link control.

Level 3 is the packet (network) level which controls the traffic of the different virtual calls and multiplexes these

for passage over the physical line.

These three levels are completely independent of each other, which allows changes to be made to one level without disrupting the operation of any other level. An adjacent level is affected only if the changes affect the interface to that level.

N

Each level performs one well defined set of functions, using only a well defined set of services provided by the level below. These functions implement a set of services that can be accessed only from the level above. Each level is strictly controlled by the systems engineer according to formal functional and interface specifications.

The WD2511 implements level 2. Without additional logic, it generates the frame, performs error checking, performs link management (set up/disconnect) and ensures reliable data transmission by evaluating the sequence number associated with each l-frame. The device automatically acknowledges received l-frames and fully supports up to 7 outstanding (unacknowledge) frames, including retransmission if required.

# 3.0 HARDWARE

The WD2511 must be connected to the Physical Level (Level 1). This generally amounts to simple line drivers/ receivers.

A typical X.25 DTE/DCE station block diagram is shown in Figure 2. Figure 3 shows a circuit diagram of the actual X.25 hardware interface of this same station. Table 1 is a description of signal functions for this circuit diagram. This is to be connected directly to a Z80 microprocessor on one side and an EIA RS-422 interface on the other side.

Figures 4 and 5 are DMA cycle timing diagrams for this particular station.

General notes to this interface:

- A modem would be needed for long-distance communication lines.
- The hardware interface in Figure 3 includes all hardware options. Simpler interfacing is possible.
- The function of the CPU Bus Driver Control Circuit (CBDCC) is to control the direction and/or timing of the data-line transceivers and the two address latches.
- If the CPU clock frequency is not higher than the WD2511 CLK maximum frequency, the High Speed Control Circuit (HSCC) is not needed. The function of the HSCC circuit is to divide a high speed CPU





The only real physical connection between the two stations (DTE and DTE/DCE) is the Physical Link between the two physical layers. The other connections shown between two of the same layers (peer to peer interface) is not a physical but rather a logical connection made

clock signal (0) down to half the frequency (01A). It also delays the reset of BUSRQ with one additional 01 clock cycle when a high speed CPU clock is used. These functions are needed to establish a time window of at least 500ns between DACK being active and a CPU Write/Read function.

- When a high speed CPU clock is used, connect 01A signal to 01 signal and BUSRQA signal to BUSRQ signal. When a low speed CPU clock is used, connect CPU clock (0) direct to 01 signal and BUSRQ2 signal to BUSRQ signal.
- The DMA I/O circuit matches the timing between the Z80 and the WD2511.
- The RTS open collector output needs a pull-up resistor.
- In this particular example, line drivers/receivers are of type EIA RS-422. However, RS-232C or RS-423 can also easily be used.
- Port A of a PIO in this example is programmed to be an output. In this case, the CPU controls the DTR output to the modem. Port B of the PIO is

up by the respective protocols for that particular level.

Each level n "interfaces" to the corresponding level n on the other side of the Data Communication Link through the level n-1, then n-2 etc., via the physical link and up through the levels to n-2, n-1 and to level n.

programmed to be interrupt controlled inputs; the CPU can be interrupted by DSR and/or INTR as programmed.

- MRW (Memory Read/Write) signal enables the output of the memory address decoder for the computer system memory chips. As an example, if a PROM type 28S42 is used as the memory address decoder, MRW is connected direct to E (Pin 15) input.
- The WD2511 CS input is to be connected to a port address decoder (or memory address decoder). MWE is connected to all WE inputs, and MOE is connected to all OE inputs of the system memory chips.
- REPLY output is not used in this application.

#### 3.1 READ/WRITE CONTROL OF I/O REGISTERS

The sixteen I/O registers are directly accessible from the CPU data bus (DAL0-DAL7) by a read and/or write operation by the CPU. The CPU must activate the WD2511 register address (IA0-IA3). Chip Select (CS). Write Enable (WE) or Read Enable (RE) before each data bus transfer operation. The read/write operation is completed when  $\overline{CS}$  or  $\overline{RE/WE}$  is brought high. During a write operation, the falling edge of  $\overline{WE}$  will initiate a WD2511 write cycle. The addressed register will then be loaded with the content of the Data Bus. The rising edge of  $\overline{WE}$  will latch that data into the addressed register.

During a read operation, the falling edge of RE will initiate a WD2511 read cycle. The addressed register will then place its content onto the Data Bus.

The CPU must set-up all transmit data, TSADR HI and LO, TCNT HI and LO, and residual bits before setting BRDY in the applicable TLOOK segment.

The CPU must set aside receiver memory (at least one chain segment with transfer address), and set-up RSADR HI and LO before setting REC RDY in the applicable RLOOK segment.

# 3.2 DMA IN/OUT OPERATION

The Direct Memory Access (DMA) operation is completely controlled by the WD2511. During a DMA cycle, the CPU sets its address bus, data bus and three-state control signals to their high impedance states.

(See DMA In/Out timing diagrams, Figures 4 and 5.)

In this application example, the data bus transceivers are permanently enabled (low impedance state). When the CPU has control, the direction of these transceivers is pointing from the CPU bus towards the WD2511. During a DMA In cycle, this is not changed. During a DMA Out cycle however, the direction is reversed (WD2511 towards the CPU bus).

The address bus latches are in high impedance state while the CPU has control of the bus. When the WD2511 has control of the CPU bus, the address latches are in the low impedance state. During the DMA Out cycle, these latches function as regular bus drivers. During the DMA In cycle however, the address gets latched to assure enough data hold time for the WD2511.

# 3.2.1 DMA IN

During a DMA In cycle, the task of transferring one byte of I-field data from memory into the WD2511 is performed. The CPU time (in the example described in this paragraph to execute this task) is five T-states for a low speed CPU clock system and ten T-states for a high speed CPU clock system.

The DMA In function starts when the WD2511 is ready to receive a byte from memory to be transmitted out to the remote station. This condition causes the DRQI signal to go LO, which in turn activates the BUSRQ (Bus Request) signal. Also at this time (ADRV bit = 1), the WD2511 presents the address (on A0-A15) of the data byte to be retrieved from memory.

The BUSRQ signal is sampled by the CPU with the rising edge of the last CPU clock (0) period of any machine cycle. In this case, because the BUSRQ signal is active, the CPU goes into high impedance state with the rising edge of the next CPU clock pulse. At this time, the CPU also switches the control over to the WD2511 by activating the BUSAK signal. This causes DACK to go LO at the following rising edge of 01 clock. This is the actual indication for the WD2511 to start the DMA In cycle. DACK also causes DRQI to return to the HI state.

At the next rising edge of the 01 clock,  $\overline{\text{MOE}}$  (Memory Output Enable) is activated. This causes the memory to output the addressed data byte onto the Data Bus. Also, the address is now latched into the address bus latches (74LS373) at this time.

At the next falling edge of the 01 clock,  $\overrightarrow{DACK}$  gets deactivated, causing the WD2511 to latch the data byte (DAL0-DAL7) and to set its address lines (A0-A15) to logical HI state (ADRV bit = 1). The address bus latches hold the address active until  $\overrightarrow{DMOE}$  signal is deactivated.

At the next rising edge of the 01 clock (low speed CPU clock), BUSRQ gets deactivated. When high speed CPU clock is used, BUSRQ is deactivated after an additional 01 clock cycle.

At the next following rising edge of 01 clock, BUSRQ is sampled by the CPU. This causes BUSAK and MOE to become deactivated, but not until the next falling edge of the CPU (0) clock. This is the end of the DMA In cycle. At the next rising edge of the CPU clock, the CPU again controls the CPU bus.

# 3.2.2 DMA OUT

This operation is very similar to the DMA In function. During this cycle, one byte of I-field data is transferred from the WD2511 to the memory. The CPU-time in this example described to perform this task is the same as for the DMA In cycle.

The DMA Out function starts when the WD2511 is holding a received I-field byte and is ready to transfer this to the memory. This condition activates the DRQO signal, which in turn sets the BUSRQ to LO. Also at this time (ADRV bit = 1), the WD2511 presents the address to the memory location to where the respective data byte is to be loaded.

The BUSRQ signal is sampled by the CPU with the rising edge of the last CPU clock period of any machine cycle. Since the BUSRQ signal is active, the CPU goes into high impedance state with the rising edge of the following CPU clock pulse. Now the CPU also switches the control over to the WD2511 by activating the BUSAK signal. This causes DACK to go LO at the next rising edge of 01 clock, which indicates to the WD2511 to start the DMA Out cycle. This causes DRQO to reset back to HI state and to load the data byte to be transferred onto the data-bus.

At the next rising edge of the 01 clock,  $\overline{\text{MWE}}$  (Memory Write Enable) is activated. This causes the memory to input the addressed data byte.

At the following rising edge of the 01 clock,  $\overline{\text{MWE}}$  goes HI, latching the data into the memory. Also at this time

| TABLE 1. | SIGNAL NAMES FOR THE HARDWARE INTERFACE (See Note | ) |
|----------|---------------------------------------------------|---|
|----------|---------------------------------------------------|---|

| NAME                     | SYMBOL  | FUNCTION                                                                                                                                                                                                                                                                              |
|--------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RECEIVE                  | RCV     | When activated (LO), sets the direction of the data<br>bus transceivers from WD2511 towards the CPU<br>bus. This is done only during CPU Read or DMA<br>Out cycle.                                                                                                                    |
| DRM TRANSFER             | DTFR    | When activated (LO), enables the output of the<br>address bus latches. This is done during a DMA<br>In/Out cycle.                                                                                                                                                                     |
| DMA MEMORY OUTPUT ENABLE | DMOE    | Is activated during a DMA In cycle. Generates the MOE signal and latches the DMA In addresses.                                                                                                                                                                                        |
| MEMORY OUTPUT ENABLE     | MOE     | Is activated during a DMA In or a CPU Read cycle. Enables the memory outputs. Is to be connected to the $\overline{OE}$ pin of the memory circuits.                                                                                                                                   |
| MEMORY WRITE ENABLE      | MWE     | Is activated during a DMA Out or a CPU Write<br>Cycle. Enables the memory write function. Is to<br>be connected to the WE input of the memory<br>circuits.                                                                                                                            |
| MEMORY READ/WRITE        | MRW     | Is activated during a DMA In/Out function or a<br>Memory Read/Write cycle by the CPU. Enables<br>the output of the Memory Address decoder.                                                                                                                                            |
| DMA OUT                  | DMA OUT | Is activated during a DMA Out function.                                                                                                                                                                                                                                               |
| DMA IN                   | DMA IN  | Is activated during a DMA In function.                                                                                                                                                                                                                                                |
| INTERNAL LOOP            | ILOOP   | Is activated during an internal loop-back test.<br>Keeps the RTS signal to the modem in off condi-<br>tion and logically connects RTS to CTS.                                                                                                                                         |
| BUS ACKNOWLEDGE 1        | BUSAK1  | When active, indicates that the CPU has switched<br>bus control over to the WD2511. Compared to<br>BUSAK signal, this is delayed one 01 clock cycle<br>when going LO to allow a time window of at least<br>500 ns before DACK becomes activated.                                      |
| BUS REQUEST 1            | BUSRQ1  | When active, requests the CPU via BUSRQ2 and BUSRQ (low speed CPU clock) to switch control over to the WD2511.                                                                                                                                                                        |
| BUS REQUEST 2            | BUSRQ2  | Same function as $\overline{\text{BUSRQ1}}$ , except that $\overline{\text{BUSRQ2}}$ is delayed one 01 cycle when going HI. The delay allows a time window of at least 500 ns between DACK being active and a CPU Read/Write function.                                                |
| BUS REQUEST A            | BUSRQA  | Same function as BUSRQ2, except is delayed an additional 01 cycle when going HI. This delay allows the necessary 500 ns time window between DACK being active and a CPU Read/<br>Write function when an high speed CPU clock is used. This is then directly driving the BUSRQ signal. |

(low speed CPU clock), BUSRQ signal gets deactivated. When high speed CPU clock is used, BUSRQ is deactivated after an additional 01 clock cycle.

At the next rising edge of 01 clock, the BUSRQ signal is sampled by the CPU.

DACK goes HI half a 01 clock cycle after MWE goes HI. This ends the DMA Out cycle by the WD2511 setting its data-lines in high impedance state and the address-lines (A0-A15) to logical HI state (ADRV bit = 1).

After CPU has sampled and detected BUSRQ being deactivated, it resets BUSAK to HI at the next falling edge of the CPU clock.

At the next rising edge of the CPU clock, the CPU again controls the bus.

| NAME         | SYMBOL | FUNCTION                                                                                                                                                                                                                                                                                                                           |
|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 01           | 01     | Clock used for timing of this hardware interface.<br>The 01 frequency is not allowed to be higher than<br>the CLK maximum frequency of the WD2511.<br>When a low speed CPU clock is used, 01 signal is<br>connected directly to the CPU clock (0). When a<br>high speed CPU clock is used, this is connected<br>to the 01A signal. |
| 01A          | 01A    | Clock signal with half the CPU clock frequency.<br>This is driving the 01 clock when a high speed<br>CPU clock is used.                                                                                                                                                                                                            |
| +5 RESISTIVE | + 5R   | + 5V through a resistor.                                                                                                                                                                                                                                                                                                           |
|              |        |                                                                                                                                                                                                                                                                                                                                    |

# TABLE 1. (Continued) SIGNAL NAMES FOR THE HARDWARE INTERFACE (See Note)

NOTE: Signals described in this paragraph are signals generated by this circuitry only. Other signals are described in either the WD2511 device specification or in the Z80 CPU data sheets.







GND RCV

DRQ1 - DRQ1

DALO

DAL7

TA0

таз

A0 Δ1

۵7

A15

WE

RE

MR

MTR ČS

REPLY

WD2501/ 2511

A2

A3

A4

A5

A6

A7

**A**8 A8

A9 A10

A11

A12

A13 A14

A15

DACK

DRQO DROO

PORT ADDRESS TO MEMORY ADDRESS - MRW







EIA RS-422 LINE DRIVERS/RECEIVERS

IN a

FM D

D MC

GND

: M D

**RTS** 

8 DTR

CTS

RD

DSR

- 0

TO MODEM (DCE)

100g (5ML)

1 mg

-w-

MC

• MC

MC.

MC.

MC

GND

+ 5V

RTS

TD

CTS

RC

Vcc

vss

CLK

VDD

CLK

DTR

**DSB** 

MC

MC

MC.

+ 5V

GND

. 01

(≤2 MHz)

+ 12

HSCC + 5B BUSRQ2 74LS 74 74LS 74 BUSRQA (NOTE) 01A (NOTE)

#### NOTE:

Connect 0 to 01 and BUSRQ2 to BUSRQ if following conditions are true:

1. WD2511 CLK max. frequency ≥ CPU frequency.
 2. CPU frequency≤ 2.0 MHz

If above conditions are not true, connect 01A to 01 and BUSRQA to BUSRQ.



 Data would become non-valid after the address becomes non-valid if address latches were not used.





Figure 5. DMA OUT TIMING

### 3.3 SERIAL INTERFACE

The receiver and transmitter sub-systems are completely independent of each other, the CPU Read/Write functions and the DMA In/Out functions.

The serial data is synchronized by the externally supplied  $\overline{TC}$  clock and  $\overline{RC}$  clock. The falling edge of  $\overline{TC}$  generates new transmitted data and the rising edge of  $\overline{RC}$  is used to sample the received data.

After initilization and before the first frame is sent, the TD output sends Idles (continuous 1s).

After the first frame is sent or the ACTIVE/PASSIVE bit is set, continuous flags are sent in between frames.

For detailed information on what type of frames are sent for certain conditions, see the WD2511 specifications.

### 4.0 SOFTWARE

Initialization of the WD2511 and I-field data processing (level 3) is accomplished by user written software. This software need not be realtime, since the WD2511 responds to link exceptions and overhead functions on its own.

Configuring the WD2511 for certain test functions, modes, timer values, location of initial memory pointers, chain buffer lengths and link level addresses is performed via the sixteen I/O registers.

All buffer management support, buffer chaining and free/busy flags occur in user memory. Here two look-up tables (TLOOK/RLOOK), located in the user memory,

contain pointers/counters for up to eight outstanding transmit/receive packets. The WD2511 contains only one address pointer which is the starting address of Segment #0 in the TLOOK table. Segment #0 in the RLOOK table always begins 40(Hex) bytes after TLOOK, Segment #0, byte #0. See section "Memory Access Scheme" in the WD2511 specifications.

Link monitoring is done by use of the I/O registers and the memory buffers. The WD2511 indicates to the system CPU that a certain event has occurred by setting a bit in status register 1 and setting the interrupt flag. This indicates whether a packet has been received, a transmitted packet has been acknowledged, a nonrecoverable error condition or some other condition needs the attention of the CPU.

In this section a flow-chart is given to show the user how to program the WD2511. For more details refer to the data sheets.

The flow for programming/monitoring the WD2511 for transmitting or receiving a packet(s) or for a loop-back test is shown in the flowchart below. The flow starts at START1 if a power-up was just done and/or if no data communication environment programming (initialization) has been done.

If initialization is complete, the flow starts at START2 when the WD2511 is to be enabled to receive a packet(s).

If a packet is to be transmitted and initialization is complete, the flow starts at START3.

### WD2511 PROGRAMMING FLOWCHART





ENABLE RECEPTION OF PACKET(S)

1











### 4.1 INTERNAL LOOP-BACK TEST (Example 1)

The loop-back test feature is an internal programmable loop-back of data, enabling the user to make an almost complete test of the WD2511. It allows diagnostic testing of the WD2511 and the interfacing circuitry. In this mode, transmitted data to the TD pin is internally routed to the received data input circuitry, thus allowing this WD2511 to set-up a link, send a number of packets to itself and then reset the link.

The RC clock is internally connected to TC clock. CTS input however, must be connected externally to GND or the RTS output.

The loop-back test allows the verifying of proper operation of practically all the various functions of the WD2511. The features tested here, the addresses and values of the variables chosen are only used as examples and are as follows:

TLOOK segments starting address = 0800HTransmit Data buffer #0 starting address = 1000HReceived Data buffer #0 starting address = 1800HNumber of packets transferred = 1Number of l-field bytes per packet = 1024Number of residual bits = 0T1 = 101HN2 = 20H Chaining is used in this example. The 1024 bytes are divided into 256 byte chain segments. Five segments are needed for this operation with 256 bytes of I-field data and two XFR ADR bytes per segment in the first four chain-segments. The rest of the I-field data (8 bytes) are located in the fifth chain-segment.

Programming:

CHAIN = 4 = number of CHAIN segments -1LIMIT = 3 = (number of bytes per segment divided by 64) -1

For buffer management programming, see memory access scheme in Figure 7.

XMIT Command Address and XMIT Response Address (REG. E and F) must be the same value.

In some applications it is necessary to keep the RTS signal to the modem in the Off condition during internal loop-back test. Also, to accomplish the most complete test, RTS output should be connected to CTS input externally (not done internally). Figure 6 shows one example of how to implement these two functions. The ILOOP signal is connected directly to a PIO output.

In the loop-back test example shown in this section, the logic in Figure 6 is used and contains the Z80 CPU, programmable I/O (PIO) etc., as shown in Figure 3.







Figure 7. MEMORY ACCESS SCHEME FOR LOOP-BACK TEST (Example 1)

# APPENDIX A

## GLOSSARY OF DATA COMMUNICATIONS TERMS

|                   | s a list of industry-accepted data communications terms that are applicable to this specification.                                                        |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| ABM               | Asynchronous Balanced Mode                                                                                                                                |
| ADCCP             | Advanced Data Communications Control Procedure (ANSI BSR X3.66)                                                                                           |
| ANSI              | American National Standards Institute                                                                                                                     |
| ARM               | Asynchronous Response Mode                                                                                                                                |
| CCITT             | International Consultative Committee for Telegraphy and Telephony                                                                                         |
| CMDR              | Command Reject. A U-Frame                                                                                                                                 |
| DCE               | Data Circuit Termination Equipment (the network side of the DTE/DCE link)                                                                                 |
| DISC              | Disconnect. A U-Frame                                                                                                                                     |
| DTE               | Data Terminal Equipment                                                                                                                                   |
| DM                | Disconnect Mode. A U-Frame (LAPB, only)                                                                                                                   |
| ECMA              | European Computer Manufacturers Association                                                                                                               |
| FCS               | Frame Check Sequence                                                                                                                                      |
| FDX               | Full Duplex (also called "two way simultaneous")                                                                                                          |
| FRAME             | Basic serial block of bit-oriented data. Includes leading and trailing flags, address field, control field, FCS field, and an optional information field. |
| FRMR              | Frame Reject. A U-Frame (LAPB, only)                                                                                                                      |
| HDLC              | High-Level Data Link Control (ISO 3309)                                                                                                                   |
| HDX               | Half Duplex (also called "two way alternate")                                                                                                             |
| HOST              | Another name for a DTE                                                                                                                                    |
| I-Frame           | Information Frame. Control field bit 0 is 0. In X.25 an I-frame is a packet.                                                                              |
| ISO               | International Standards Organization                                                                                                                      |
| LINK              | The logical and physical connection between two data terminals                                                                                            |
| LAP               | Link Access Procedure                                                                                                                                     |
| LAPB              | Link Access Procedure Balanced                                                                                                                            |
| N2                | Maximum number of retransmissions of a frame. (Also called retransmission count variable.)                                                                |
| NODE              | Another name for a DCE or DTE.                                                                                                                            |
| N(R)              | Sequence number of next frame expected to be received.                                                                                                    |
| N(S)              | Sequence number of current frame being transmitted.                                                                                                       |
| OCTET             | An 8-bit byte                                                                                                                                             |
| PACKET            | An I-Frame in X.25                                                                                                                                        |
| PAD               | Packet Assembly/Disassembly facility                                                                                                                      |
| REJ*              | Reject. An S-Frame                                                                                                                                        |
| RNR*              | Receiver Not Ready. An S-Frame                                                                                                                            |
| RR*               | Receiver Ready. An S-Frame                                                                                                                                |
| S-Frame           | Supervisory Frame. Control field bit $0 = 1$ and bit $1 = 0$                                                                                              |
| SARM              | Set Asynchronous Response Mode. (LAP, only)                                                                                                               |
| SABM              | Set Asynchronous Balanced Mode. (LAPB, only)                                                                                                              |
| SDLC              | Synchronous Data Link Control (IBM document GA27-3093)                                                                                                    |
| T1                | A Primary Timer for a delay in waiting for a response to a frame                                                                                          |
| U-Frame           | Unnumbered Frame. Control Field bit $0 = 1$ and bit $1 = 1$                                                                                               |
| UA                | Unnumbered Acknowledge. A U-Frame                                                                                                                         |
| X.25              | Recommendation by CCITT on Interfacing to Public Packet Switching Networks                                                                                |
|                   | Recommendations by CCITT involving PAD facilities                                                                                                         |
| *There are also I | RR, RNR, and REJ packets which are not the same as the S-frame RR, RNR and REJ discussed in this document.                                                |

### **APPENDIX B**

# THE DIFFERENCE BETWEEN LAP AND LAPB

In March 1976, the CCITT adopted Recommendation X.25 as an interface standard for public packet-switching networks. The link level procedure adopted was called Link Access Procedure (LAP) and used the HDLC Asynchronous Response Mode (ARM). However, ARM was not designed for peer-to-peer communications so LAP had some subtle problems. Therefore, in 1977, when Provisional Recommendation X.25 was adopted, a procedure called LAPB was added. LAPB is Link Access Procedure-Balanced and operates under the HDLC Asynchronous Balanced Mode (ABM). Unfortunately, the 1977 LAPB lacked good symmetry between the DTE and DCE, and was unworkable.

In the April 1979 CCITT meeting, the LAPB was greatly enhanced, especially in the DTE/DCE symmetry. This enhanced version was approved in the February 1980 Plenary meeting of the CCITT. We now have a good, workable LAPB standard. LAPB is a superior procedure and the usage of LAP is being replaced with LAPB.

|            |         |          | CO    | NTRO | OL FIELD |   | ]                                         |
|------------|---------|----------|-------|------|----------|---|-------------------------------------------|
| FRAME TYPE | COMMAND | RESPONSE |       | BI   | Т#       |   |                                           |
|            |         | ļ        | 765   | 4    | 321      | 0 |                                           |
| I-FRAME    | I-FRAME |          | N(R)  | Р    | N(S)     | 0 |                                           |
|            | RR      | RR       | N(R)  | P/F  | 000      | 1 | RECEIVER<br>READY                         |
| S-FRAME    | RNR     | RNR      | N(R)  | P/F  | 010      | 1 | RECEIVER<br>NOT<br>READY                  |
|            | REJ     | REJ      | N(R)  | P/F  | 100      | 1 | REJECT                                    |
|            | SABM    |          | 001   | Р    | 1 1 1    | 1 | SET ASYN-<br>CHRONOUS<br>BALANCED<br>MODE |
| U-FRAME    | DISC    |          | 0 1 0 | Р    | 001      | 1 | DISCONNECT                                |
|            |         | DM       | 000   | F    | 111      | 1 | DISCONNECT<br>MODE                        |
|            |         | UA       | 0 1 1 | F    | 001      | 1 | UNNUMBERED<br>ACKNOWL-<br>EDGE            |
|            |         | FRMR     | 100   | F    | 011      | 1 | FRAME<br>REJECT                           |

## LAPB COMMANDS AND RESPONSES

Only the FRMR and I-frame contain I-fields P = Pole Bit F = Final Bit

' = Pole Bit F = Final Bit



# WESTERN DIGITAL

T

 $\overline{n}$ 

N



#### FEATURES

 Broadcast Medium Independent (Coax, RF, CATV, IR, etc.)

0

R

D

- · Up to 254 nodes
- Dual DMA/Highly efficient Memory Block Chaining
- · Token based protocol
- · Acknowledge option on each datagram
- · Adjustable fairness, stations may be prioritized
- Frame format similar to industry standard HDLC
- Supports Global Addressing
- Diagnostic Support: Self-Tests, System and Network
- TTL Compatible



#### **PIN DESIGNATION**

#### DESCRIPTION

The WD2840 is a MOS/LSI device intended for local network applications, where reliable data communications over a shared medium is required. The device uses a buffer chaining scheme to allow efficient memory utilization. This scheme minimizes the host CPU time requirements for handling packets of data. The WD2840 frees the host CPU from extensive overhead by performing network initialization, addressing, coordination, data transmission, acknowledgements and diagnostics.

#### **APPLICATIONS**

The WD2840 is a general purpose Local Network Token Controller applicable to virtually all types of multi-point communications applications. The token protocol allows the sharing of one bus by up to 254 nodes. WD2840's will be designed into process control equipment, micro-computers, mini-computers, personal computers, proprietary micro-processor based applications, intelligent terminals, front-end processors, and similar equipment.

The great advantage for the design engineer is the ease with which he can implement a local network function. The WD2840 handles autonomously all major communications tasks as they relate to the local network function.

# 1.1 PIN DEFINITIONS

| PIN NUMBER | SYMBOL   | PIN NAME          | FUNCTION                                                                                                                                                                                                                                                            |
|------------|----------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | DNC      | DO NOT CONNECT    | Leave pin open.                                                                                                                                                                                                                                                     |
| 2          | SQ       | SIGNAL QUALITY    | An active low input which signals the WD2840<br>that a frame may be received. The modern may<br>negate this signal if its receive signal quality is<br>below a reliability threshold, ensuring that the<br>WD2840 will not accept the frame.                        |
| 3          | WE       | WRITE ENABLE      | The data on the DAL are written into the selected register when CS and WE are low. RE and WE must not be low at the same time.                                                                                                                                      |
| 4          | CS       | CHIP SELECT       | Active low chip select for CPU control of I/O registers.                                                                                                                                                                                                            |
| 5          | RE       | READ ENABLE       | The content of the selected register is placed on DAL when CS and RE are low.                                                                                                                                                                                       |
| 6          | CLK      | CLOCK             | Clock input used for internal timing.                                                                                                                                                                                                                               |
| 7          | MR       | MASTER RESET      | Initialize on active low. All registers reset to zero,<br>except control bit ISOL is set to 1. DACK must be<br>stable high before MR goes high. Status Register<br>0 is not defined at power-up (this register will be<br>set-up upon entry into the Network mode). |
| 8-15       | DAL0-7   | DATA ACCESS LINES | An 8-bit bi-directional three-state bus for CPU and DMA controlled data transfers.                                                                                                                                                                                  |
| 16         | RD       | RECEIVE DATA      | Receive serial data input.                                                                                                                                                                                                                                          |
| 17         | RC       | RECEIVE CLOCK     | This is a 1X clock input, and RD is sampled on the rising edge of RC.                                                                                                                                                                                               |
| 18         | VSS      | GROUND            | Ground.                                                                                                                                                                                                                                                             |
| 19         | TC       | TRANSMIT CLOCK    | A 1X clock input. TD changes on the falling edge of TC.                                                                                                                                                                                                             |
| 20         | TD       | TRANSMIT DATA     | Transmitted serial data output.                                                                                                                                                                                                                                     |
| 21         | RTS      | REQUEST-TO-SEND   | An open collector output which goes low when<br>the WD2840 is ready to transmit either data or<br>flags.                                                                                                                                                            |
| 22         | CTS      | CLEAR-TO-SEND     | An active low input which signals the WD2840 that transmission may begin.                                                                                                                                                                                           |
| 23         | DRQO     | DMA REQUEST OUT   | An active low output signal to initiate CPU bus request so that the WD2840 can output onto the bus.                                                                                                                                                                 |
| 24         | DRQI     | DMA REQUEST IN    | An active low output signal to initiate CPU bus requests so that data may be input to the WD2840.                                                                                                                                                                   |
| 25         | DACK     | DMA ACKNOWLEDGE   | An active low input from the CPU in response to DRQO or DRQI. DACK must not be low if CS and RE are low or if CS and WE are low.                                                                                                                                    |
| 26-41      | A0-A15*  | ADDRESS LINES OUT | Sixteen address outputs from the WD2840 for DMA operation.                                                                                                                                                                                                          |
| 42         | VDD      | POWER SUPPLY      | + 12VDC power supply input.                                                                                                                                                                                                                                         |
| 43         | INTR     | INTERRUPT REQUEST | An active low interrupt service request output.<br>Returns high when Interrupt Register is read.                                                                                                                                                                    |
| 44-47      | IA0-IA3* | ADDRESS LINES IN  | Four address inputs to the WD2840 for CPU controlled read/write operations with registers in the WD2840. If $ADRV = 0$ , these may be tied to A0-A3.                                                                                                                |
| 48         | Vcc      | POWER SUPPLY      | + 5VDC power supply input.                                                                                                                                                                                                                                          |
|            |          |                   |                                                                                                                                                                                                                                                                     |

### WD2840 LOCAL NETWORK TOKEN ACCESS CONTROLLER

# INTRODUCTION

The WD2840 is a single LSI device which gives systems designers the ability to include networking capabilities into their unique products simply and economically.

A general and fundamental advantage to the use of complex LSI in a given system is the partitioning of required technical expertise. A successful user of the WD2840 need not be a data-communications expert, and further, he need not be at all concerned with low level network details (though these details are documented and available to him if he is interested). The potential user of the WD2840 must simply evaluate the communications facilities provided by the device to determine its suitability for the intended use. The WD2840 is designed to logically interconnect 2 to 254 user devices over a shared communications medium. Examples of typical mediums include coax cable, twisted pair bus, RF, and CATV. All network control functions, such as data framing and error checking, destination filtering, fair and adjustable transmission scheduling, and network initialization and fault recovery (caused by noise for example) are handled completely by the WD2840.

The protocol implemented allows guaranteed station access intervals allowing applications in factory automation and other critical communications environments where "statistical delays" are not acceptable. The WD2840 token protocol also allows the addition and/or removal of stations to a network at anytime, including while operating.



Serious attention has also been given to the user's interface to the device. The interface is a combination of conventional I/O registers and an elaborate DMA buffer chaining interface. This chaining feature allows the user much more efficient use of his system memory, particularly in situations where the maximum message sent over the network is much longer than the average size. This feature also allows the automatic queueing of messages independently of the user's consumption rate, in effect, speed decoupling the user's CPU and processing requirements from the network.

The WD2840 has several parameters (registers) that allow tailoring to the user's requirements. In this way, network priority and access ordering, to name two, can be manually set if desired.

Using an integrated version of these network algorithms saves not only the development costs already mentioned, but further, the total processing power required for the user's application is not increased. In other words, a CPU upgrade can likely be avoided by "distributing" the network processing task into LSI devices such as the WD2840.

### SCOPE

This document differs from traditional LSI data sheets in that it details not only the LSI implementation of a function, but also defines the overall function in detail. Specifically, this document includes details of the communications protocol implemented by the WD2840 Token Access Controller.

The document is organized into three main sections:

SECTION ONE is much like a traditional data sheet including register descriptions, pin definitions, and hardware architecture.

SECTION TWO describes the interfaces to the WD2840. The network side is conventional, the host side consists of an elaborate DMA interface with control blocks and WD2840/host handshaking.

SECTION THREE details the network protocol implemented by the device. Normal operation, initialization, and the handling of error conditions are described.



# **1.2 DEVICE ARCHITECTURE**

A detailed block diagram of the WD2840 is shown in Figure 1.1.

Mode control and monitor of status by the user's CPU is performed through the Read/Write Control circuit, which reads from or writes into registers addressed by IA0-IA3.

Transmit and receive data are accessed through DMA control. Serial data is generated and received by the bit-oriented controllers.

Internal control of the WD2840 is by means of three internal micro-controllers; one for transmit, one for receive, and one for overall control.

Parallel transmit data is entered into the Transmitter Holding Register (THR), and then presented to the Transmitter Register (TR) which converts the data to a serial bit stream. The Frame Check Sequence (FCS) is computed in the sixteen bit CRC register, and the results become the transmitted FCS.

Parallel receive data enters the Receiver Holding Register (RHR) from the 24 bit serial Receive Register (RR). The 24-bit length of RR prevents received FCS data from entering the RHR. The receiver CRC register is used to test the validity of the received FCS. A three level FIFO is included in the receiver.

The WD2840 sends all information, network control and user data, in blocks called frames. Each frame starts and ends with a single flag (binary pattern 0111110). In between flags, data transparency is provided by the insertion of a zero bit after all sequences of five contiguous one bits. The receiver will strip the inserted zero bits. (See section on frame format for location of address, control, and FCS fields.)

### **1.3 REGISTER DEFINITION**

The WD2840 is controlled and monitored by sixteen 8 bit registers. This set of registers consists of two Control Registers, three Status Registers, an In-

terrupt Event Register, a Counter Register and a variety of Parameter Registers. In general the host is responsible for defining these registers (except certain host read-only registers: SR0-2, IR0, CTR0 and NA) to contain proper and meaningful values prior to entering Network Mode from Isolate State. Furthermore, while the WD2840 is in Network Mode, the CBP (H,L) and MA registers must not be changed by the host. Register NAR may be changed arbitrarily but will only be considered by the WD2840 in response to the NEWNA (CR10) control bit being set. The two Control Registers and the TA, TD, AHOLT, TXLT registers may change dynamically to control the behavior of the WD2840.

| REG  |       |                             |
|------|-------|-----------------------------|
| [1]  | NAME  | DESCRIPTION                 |
| 0    | CR0   | Control Register 0          |
| 1    | CR1   | Control Register 1          |
| 2[2] | SR0   | Status Register 0           |
| 3[2] | IR0   | Interrupt Event Register    |
| 4[2] | SR1   | Status Register 1           |
| 5[2] | SR2   | Status Register 2           |
| 6[2] | CTR0  | Counter Register 0          |
| 7[2] | NA    | Next Address                |
| 8    | TA    | ACK Timer                   |
| 9    | TD    | Net Dead Timer              |
| Α    | CBPH  | Control Block Pointer       |
|      |       | (MSB)                       |
| В    | CBPL  | Control Block Pointer (LSB) |
| С    | NAR   | Next Address, Request       |
| D    | AHOLT | Access Hold-off Limit       |
| E    | TXLT  | Transmit Limit              |
| F    | MA    | My Address                  |

[1] = Hexadecimal representation of IA0-IA3.

[2] = CPU read only, write not possible.

Control, status, and interrupt bits will be referred to as CR, SR, or IR, respectively, along with two digits. For example, SR21 refers to status register #2 and bit 1, which is "STATE."

# SUMMARY - CONTROL, STATUS, INTERRUPT REGISTERS

|                  | BIT #          |           |           |              |                |             |              |                                         |  |  |
|------------------|----------------|-----------|-----------|--------------|----------------|-------------|--------------|-----------------------------------------|--|--|
| REGISTER         | 7              | 6         | 5         | 4            | 3              | 2           | 1            | 0                                       |  |  |
| CR0              | TXDEN          | TXEN      | RXEN      | ITOKON       | ILOOP          | COPY        | NOINT        | ISOL[1]                                 |  |  |
| CR1[2]<br>CR1[4] | DIAGC<br>DIAGC | PIGT<br>0 | INIT<br>0 | ADRV<br>ADRV | GIRING<br>DMAT | 0<br>LOOPT  | TOFF<br>RAMT | NEWNA<br>NUDIAG                         |  |  |
| SR0              | LASTF          | SENDACK   | L2        | 0            | BSZ3 .         | . BSZ2 .    | . BSZ1 .     | . BSZO                                  |  |  |
| IR0 [3]          | ITERR          | IROR      | INS       | ITRAN        | IREC           | ΙΤΟΚ        | ITA          | ITD/M                                   |  |  |
| SR1              | TAOUT          | IRTS      | RECIDL    | 1            | 1              | 1           | 1            | 1                                       |  |  |
| SR2              | NXTT0          | NXTR0     | TR        | ACKRQ        | RETRY          | TSENT       | STATE        | INRING                                  |  |  |
| NOTE: ZER        | O BITS (0) SI  | HOWN ABOV | E ARE RES | ERVED AND    | SHOULD NO      | DT BE USED. |              | • • • • • • • • • • • • • • • • • • • • |  |  |

NOTES:

- [1] = Set to 1 on power-up or master reset.
- [2] = Non diagnostic mode only (CR17-DIAGC cleared).
- [3] = Any bit set causes host interrupt (INTR goes true) when Master Interrupt Suppress (CR01) is clear. All bits are cleared when register is read by the host.
- [4] = Diagnostic State only (CR17-DIAGC set). See diagnostic section for register usage in diagnostic mode.

# **CR0** — CONTROL REGISTER 0 DEFINITION

| R | EGISTER | CR07  | CR06 | CR05 | CR04   | CR03  | CR02 | CR01  | CR00 |
|---|---------|-------|------|------|--------|-------|------|-------|------|
|   | CR0     | TXDEN | TXEN | RXEN | ITOKON | ILOOP | COPY | NOINT | ISOL |

| BIT  | NAME   | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CR00 | ISOL   | Isolate. Set true on power up or master reset. Host clears this bit after the host memory based WD2840 control block and other WD2840 registers have been set up. May be set by the host at any time (will be ignored if WD2840 is in diagnostic state). There is some delay for the WD2840 to respond to any state change request. A state change to network mode is acknowledged by the state confirmation status bit (SR21-STATE) being cleared. Setting ISOL while the WD2840 is in Network State will cause a state change to Isolate State, confirmed by an interrupt event (IR00-ITM) and the STATE status bit (SR21) being set. This transaction will be delayed until the node does not possess the token. Any in-progress frame transmission will be completed normally (at the current frame, regardless of queue length), followed by a normal token pass sequence. |
| CR01 | NOINT  | Master Interrupt Suppress. When clear, the WD2840 will generate host interrupt requests (INTR low) if any bit in the WD2840 interrupt request register (IR0) is set. When set, only the interrupt request is suppressed, not the setting of bits in IR0. Note that any interrupt request will be dropped by the WD2840 when IR0 is read since this will clear IR0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CR02 | COPY   | Enables COPY mode. When set causes all received data frames to be accepted<br>and DMA'ed into memory regardless of destination address. (See description in<br>Diagnostics Section.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CR03 | ILOOP  | Instructs the WD2840 to loop data internally from transmitter to receiver. Used with the LOOP diagnostic. Must NOT be set while in network mode (CR00-ISOL clear).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CR04 | ITOKON | Enable Token received interrupts. When clear no Token received interrupts are gener-<br>ated. When set the WD2840 generates an Itok interrupt when a token is received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| NAME  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXEN  | Receive Data Enable. When clear, the WD2840 still makes normal responses to supervisory frames (scan, token pass), but will not DMA any data frames into memory and ignores the receiver buffer chain. However any data frame which is addressed to this node and for which an ACK is requested, will be NAK'ed with a "receiver not enable" Nak code. When RXEN is set, it allows the receiver to DMA appropriate data frames into memory. RXEN may be arbitrarily set and reset while in Network State but changes will not affect any frames in progress. |
|       | NOTE: Even when RXEN is clear, the WD2840 is "following" the receiver buffer chain with an internal register pointing either to the next available buffer (NXTR0 set) or, if the chain is exhausted, to a link field of zero (NXTR0 clear). The constraints on host manipulation of the receiver buffer chain are the same regardless of the state of RXEN. See the subsequent section on Receiver Memory Interface for more details.                                                                                                                        |
| TXEN  | Master Transmit Enable. When clear no transmissions will occur and the transmit buffer chain will be ignored. When set, transmission activity is further dependent upon TXDEN (CR07).                                                                                                                                                                                                                                                                                                                                                                        |
|       | NOTE: Even when TXEN is clear, the WD2840 is "following" the transmitter buffer chain with an internal register pointing either to the next frame to transmit (NXTT0 set) or, if the chain is exhausted, to a link field of zero (NXTT0 clear). The constraints on host manipulation of the transmitter buffer chain are the same regardless of the state of TXEN. See the subsequent section on Transmitter Memory Interface for more details.                                                                                                              |
| TXDEN | Data Transmit Enable. Has no meaning unless TXEN is set. When set in con-<br>junction with TXEN, normal WD2840 transmission of data and supervisory frames<br>will occur. When clear and with TXEN set, only data frame transmission will be<br>suppressed. That is, token pass and Ack/Nak supervisory frames will still be<br>transmitted when appropriate.<br>NOTE: The note above for TXEN applies.                                                                                                                                                      |
|       | RXEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# **CR1 — CONTROL REGISTER 1 DEFINITION**

| REGISTER | CR17  | CR16 | CR15 | CR14 | CR13   | CR12  | CR11 | CR10   |
|----------|-------|------|------|------|--------|-------|------|--------|
| CR1      | DIAGC | PIGT | INIT | ADRV | GIRING | 0     | TOFF | NEWNA  |
| CR1      | DIAGC | 0    | 0    | ADRV | DMAT   | LOOPT | RAMT | NUDIAG |

| BIT  | NAME   | DESCRIPTION (CR17 = 0, Network mode)                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CR10 | NEWNA  | Update NA register. When set causes WD2840 to copy the contents of register NAR into register NA. The WD2840 clears this bit after the function is complete. This mechanism allows the host to define the WD2840's successor in the logical ring. The node's next token pass will be to the new NA node.                                                                                                                                                 |
|      |        | NOTE: The normal token pass recovery applies. If the token pass to the new NA is<br>not successful, a normal scan sequence will occur where the WD2840 attempts a<br>single token pass to each node address in numerical sequence until a successful<br>pass occurs or the node's address itself is reached.                                                                                                                                             |
| CR11 | TOFF   | When set causes WD2840 to ignore timers. (This is NOT intended to be used in an operational network, but is provided to support network diagnosis.) CAUTION: This control bit disables all automatic network error recovery.                                                                                                                                                                                                                             |
| CR12 |        | (Not used, Reserved.)                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CR13 | GIRING | Get in logical ring. Instructs the WD2840 to gain entry into the logical ring at the next opportunity (i.e. respond to a token pass). The INRING status bit (SR20) is confirmation; when INRING is set, it indicates that the WD2840 is participating in a logical ring of at least two nodes. If the host clears GIRING while INRING is set, the WD2840 will not accept the next token pass to it at which time INRING will be cleared as confirmation. |

WD2840

| T    |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIT  | NAME  | DESCRIPTION (CR17 = 0, Network mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CR14 | ADRV  | Address Driver Enable. Enables the sixteen output address (A0-A15). If ADRV = 0, the outputs are tri-state and are in HI-Z, except when $\overline{DACK}$ goes low. If ADRV = 1, the outputs are always TTL levels.                                                                                                                                                                                                                                                                                                                                                                                           |
| CR15 | INIT  | Network Initialization Enable. When clear, the WD2840 will not attempt to (re)initialize the network if the net dead timer (TD) expires. When set, TD timer expiration causes the WD2840 to enter Scan Mode. In this mode it transmits a token pass frame to each node numerically higher in address, one after another, until either network activity occurs (another node responds) or until the node's own address is reached. When Scan Mode begins, the first node address used is the then current NA (Next Address) node address. This value is derived from and is affected by the following actions: |
|      |       | <ol> <li>At transition into Network State it defaults to MA + 1.</li> <li>It may be set by the host using the NAR register and the NEWNA (CR10) control flag.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ,    |       | 3. Upon receipt of a Scan Mode frame, NA is redefined to MA + 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      |       | The successful initialization of the network by Scan Mode causes NA to be defined as the first responding node (hence, this node's successor).                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |       | All node address computations are ascending and circular within the valid node address range of 1-254.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |       | NOTE: Since this network initialization activity comes about because of a timer expiration, TOFF (CR11) must be clear.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CR16 | PIGT  | If set, instructs WD2840 to piggy back token on last data frame transmitted. This request is honored if the last frame is determined as a result of limit TXLT or the LAST bit set in the TX-FCB, but not if transmission ends due to the reaching of the end of the chain.                                                                                                                                                                                                                                                                                                                                   |
| CR17 | DIAGC | Enables diagnostic mode. In network mode this bit must be zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# **CR1 — CONTROL REGISTER 1 DEFINITIONS**

| BIT  | NAME   | DESCRIPTION (CR17 = 1, Diagnostic mode)                                                                                                                                                                                                                                                                                                                 |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CR10 | NUDIAG | Perform a new diagnostic. When set causes WD2840 to perform the selected diagnostics. The host initializes the appropriate registers for the particular diagnostic and by setting this bit can initiate the test. The WD2840 clears this bit after completion of the diagnostic.                                                                        |
| CR11 | RAMT   | Selects internal RAM test if in diagnostic mode.                                                                                                                                                                                                                                                                                                        |
| CR12 | LOOPT  | Selects Loop Test if in diagnostic mode.                                                                                                                                                                                                                                                                                                                |
| CR13 | DMAT   | Selects DMA Test if in diagnostic mode.                                                                                                                                                                                                                                                                                                                 |
| CR14 | ADRV   | Address Driver Enable. Enables the sixteen output address (A0-A15). If ADRV = 0, the outputs are tri-state and are in HI-Z, except when DACK goes low. If ADRV = 1, the outputs are always TTL levels.                                                                                                                                                  |
| CR15 | _      | (Not used, Reserved.)                                                                                                                                                                                                                                                                                                                                   |
| CR16 | —      | (Not used, Reserved.)                                                                                                                                                                                                                                                                                                                                   |
| CR17 | DIAGC  | Enables diagnostic mode. Confirmation of diagnostic mode is via status bit STATE (SR21). When DIAGC and STATE are both set, diagnostic functions of CR1 apply. When DIAGC is cleared, after the selected set of diagnostics in progress complete, the WD2840 will transition to the Isolate state. This transition will cause an interrupt event (ITM). |

# SR0 — STATUS REGISTER 0 DEFINITION

| REGISTER | SR07  | SR06    | SR05 | SR04 | SR03 | SR02 | SR01 | SR00 |
|----------|-------|---------|------|------|------|------|------|------|
| SR0      | LASTF | SENDACK | L2   | 0    | BSZ3 | BSZ2 | BSZ1 | BSZ0 |
| SR0      | LASTF | SENDACK | L2   | 0    | BSZ3 | BSZ2 | BSZ1 | BSZ  |

| BIT          | NAME    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR00         | BSIZ    | BSIZ0 — BSIZ3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <br><br>SR03 |         | Buffer size, defines the buffer size in multiples of 64 bytes (the value ranges from 0 to $15_{\rm H}$ . Corresponding to a buffer size of 64 to 1024 bytes in 64 byte increments). This value is used internally to define buffer boundaries to allow the chip to link buffers. A maximum of 16 buffers may be used for a single frame.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| SR04         | —       | Not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| SR05         | L2      | An internal flag set during frame transmission if the length value of the current frame is equal to eight. For normal data frame transmission this means the frame has no data field and for transparent frame transmission this means the frame is an access control frame. (SCAN FRAME)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| SR06         | SENDACK | An internal flag set during data frame reception to indicate that the incoming frame should be acknowledged (send ack/nak frame). This flag is cleared when the acknowledgement has been transmitted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| SR07         | LASTF   | An internal flag set during data frame transmission to indicate that the current frame will be the last to be transmitted with this token. Five situations can cause this to occur: 1) ISOL (CR00) becoming set, 2) TXDEN (CR07) becomes clear, 3) current frame flagged (via FCB) to be "last frame," 4) the current token frame count reaching the TXLT limit, 5) transmitter under-run detection. Note in particular that the last frame in the transmit queue will not cause LASTF to set since it's being last is not known until frame end. Also if a piggy-back token is permitted (CR16 set) and no acknowledge is requested (via FCXB), the token will be piggybacked on the current (last) data frame. LASTF is not cleared until the next data frame transmission begins. |

# **IR0** — INTERRUPT REGISTER DEFINITION

| REGISTER | IR07  | IR06 | IR05 | IR04  | IR03 | IR02 | IR01 | IR00  |
|----------|-------|------|------|-------|------|------|------|-------|
| IR0      | ITERR | IROR | INS  | ITRAN | IREC | ΙΤΟΚ | ITA  | ITD/M |

The setting of any bit in this register by the WD2840 causes an interrupt request ( $\overline{INTR} = Iow$ ) if NOINT (CR01) is clear. The reading of this register by the host clears all bits (and any interrupt request).

| BIT  | NAME  | DESCRIPTION (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IR00 | ITD/M | Network dead or mode change (dual use). When in Network mode, timer TD ex-<br>piring (with TOFF clear) causes this bit to be set to indicate no network activity has<br>occurred within the timeout period. Also INRING (SR20) is cleared and, if INIT (CR15)<br>is set, the WD2840 will enter Scan Mode (see INIT - CR15 for details). Transition from<br>Network or Diagnostic State to the Isolate State will be confirmed by this interrupt. The<br>choice between the ITD and ITM interpretations is easily made based on the ISOL<br>(CR00) bit. |
| IR01 | ITA   | Date Frame Transmission Unsuccessful. This interrupt indicates that a transmitted data frame with an acknowledge request was not successfully acknowledged. Either a NAK or no response after two transmissions will cause this. The exact cause can be determined by inspecting the appropriate FSB.                                                                                                                                                                                                                                                  |
| IR02 | ΙΤΟΚ  | The token has been received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

WD2840

| BIT  | NAME  | DESCRIPTION (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IR03 | IREC  | Data Frame Received. This interrupt signifies that a good data frame has been properly received and DMA'ed into the buffer chain. Frames that have been received can be identified by following the buffer chain noting the WD2840 frame status bytes (FSB). A non-zero FSB (host must clear when queuing free buffers) indicates a properly received frame. The host may freely remove all received frames from the chain up to but NOT necessarily including the last one posted. The last one posted may only be removed if the WD2840 NXTR0 (SR26) is set. For more details see the explanation for NXTR0. |
| IR04 | ITRAN | Indicates that at least one data frame has been transmitted. The number of frames transmitted and the status of each (i.e. ACK/NAK, retry count) is determined by following the transmit chain and inspecting frame status bytes (FSB). All transmitted frames up to but NOT including the last posted may be freely removed. The last one posted may only be removed if the WD2840 NXTT0 (SR27) is set. For more details see the explanation for NXTT0.                                                                                                                                                       |
| IR05 | INS   | New successor. The WD2840 has identified a new successor in the logical ring.<br>This happens when the prior successor either failed to respond to a token pass or<br>as instigated by a network scan frame.                                                                                                                                                                                                                                                                                                                                                                                                   |
| IR06 | IROR  | Receiver over-run. The WD2840 ran out of buffers or access to the DMA channel was delayed by the host so long as to cause loss of received data.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| IR07 | ITERR | Transmitter error. Three abnormal frame transmission cases can cause the ITERR interrupt. The causes are "transmitter underrun," "premature end of chain," and "exceeded 16 buffers." The frame transmission will repeat once per token until the host removes the WD2840 from the network, or the cause of the error is fixed.                                                                                                                                                                                                                                                                                |

(1) = Non diagnostic mode only. See diagnostic section for register usage for diagnostics.

# SR1 — STATUS REGISTER 1 DEFINITION

| REGISTER | SR17  | SR16 | SR15   | SR14 | SR13 | SR12 | SR11 | SR00 |
|----------|-------|------|--------|------|------|------|------|------|
| SR1      | TAOUT | IRTS | RECIDL | 1    | 1    | 1    | 1    | 1    |

| BIT                | NAME   | DESCRIPTION                                                                                                                                                                                                                                                             |
|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SR10<br>::<br>SR14 |        | (Not used, reserved.)                                                                                                                                                                                                                                                   |
| SR15               | RECIDL | Receiver Idle. Indicates the WD2840 has received at least 15 contiguous ones.                                                                                                                                                                                           |
| SR16               | IRTS   | Internal Request To Send. Indicates the transmitter is attempting (successful or not) to send either data or flags. If the $\overline{\text{RTS}}$ pin is not tied to ground or WIRE-OR'ED with another signal, then $\overline{\text{IRTS}} = \overline{\text{RTS}}$ . |
| SR17               | TAOUT  | Timer TA expired.                                                                                                                                                                                                                                                       |

| REGISTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R SR27 | SR26                                                                                                                                                                          | SR25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SR24                                                                              | SR23                         | SR22                                                                                              | SR21                                                                     | SR20                                  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|---------------------------------------|--|--|
| SR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NXTTO  | NXTRO                                                                                                                                                                         | TR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ACKRQ                                                                             | RETRY                        | TSENT                                                                                             | STATE                                                                    | INRING                                |  |  |
| BIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NAME   |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | D                                                                                 | ESCRIPTION                   | 8                                                                                                 |                                                                          | · · · · · · · · · · · · · · · · · · · |  |  |
| SR20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | INRING | at least on                                                                                                                                                                   | logical ring. Indicates the node has had the token and has successfully passed it<br>least once (therefore it is included in a logical ring of at least two nodes). See<br>RING (CR13) for other comments.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                   |                              |                                                                                                   |                                                                          |                                       |  |  |
| SR21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | STATE  | Diagnostic<br>in Network                                                                                                                                                      | ode confirmation. Depending on DIAGC (CR17), the WD2840 is either in Isolate or<br>agnostic state. When ISOL (CR00) is set, STATE set confirms the WD2840 is not<br>Network State. When ISOL is clear, STATE clear confirms Network State. Note<br>y state transition into Isolate State causes an interrupt event to occur (ITM).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                   |                              |                                                                                                   |                                                                          |                                       |  |  |
| SR22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TSENT  | been eithe                                                                                                                                                                    | n internal flag. TSENT is set when the WD2840 passes the token. It may have<br>sen either a piggyback or explicit token pass frame. TSENT is cleared when the<br>ext frame is received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                   |                              |                                                                                                   |                                                                          |                                       |  |  |
| SR23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RETRY  | be retransi<br>request ar<br>retransmit                                                                                                                                       | mitted. Data<br>nd no respor<br>ted if no net                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | is set when e<br>frames are o<br>nse at all oc<br>twork activity<br>a TA timeout. | nly retransm<br>curred. Toke | itted if they<br>on pass fram                                                                     | have an ackr<br>nes (except \$                                           | nowledge<br>Scan) are                 |  |  |
| SR24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ACKRQ  | requested<br>the ACK/N<br>retry will o                                                                                                                                        | for the spec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | uring data fra<br>ific frame. If<br>e frame; if the<br>TRY-SR23). A<br>ission.    | this is the c<br>TA timer ex | ase, the WE<br>pires before                                                                       | 2840 pauses<br>the response                                              | to await<br>, a single                |  |  |
| SR25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TR     | when the t                                                                                                                                                                    | oken is pass<br>a bad data fi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | en the WD28<br>ed (or if it is ig<br>rame, TXEN                                   | gnored for ar                | ny reason. Fo                                                                                     | or example, p                                                            | iggyback                              |  |  |
| SR26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | NXTR0  | the buffer<br>pointing to<br>chain (prio<br>that it has<br>encounterre<br>the chain w<br>the WD284<br>field expect<br>available b<br>set it indic<br>frames (de<br>frame proc | Internal Receive Buffer Pointer State. Because of the linked list approach used in the buffer chains, the WD2840 internal register used to follow the list is either pointing to the next buffer in the chain or at the address of the next buffer in the chain (prior buffer's link field). The WD2840 will always advance along the chain so that it has the address of the next buffer to be used. However, when a zero link is encountered, the WD2840 retains the link field address expecting eventually that the chain will be extended by the host making the link some non-zero value. When the WD2840 actually needs the next buffer, it looks again at the contents of the link field expecting it to have been changed (chain extended) to the address of an available buffer. The NXTR0 bit differentiates between these two situations. When set it indicates the WD2840 has the address of the next buffer and that all prior frames (denoted by posted FSB's) can be removed from the chain for received has advanced to a zero link (end of chain). |                                                                                   |                              |                                                                                                   |                                                                          |                                       |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | for process<br>extend the                                                                                                                                                     | sing since it i<br>receiver buff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                   | d of his last                | buffer that r                                                                                     | nust be set ir                                                           | n order to                            |  |  |
| SR27 NXTT0 Internal Transmit Buffer Pointer State. The comments for NXTR0 (SR2<br>analogous manner) to NXTT0 since the transmit buffer chain is ha<br>WD2840 using an identical scheme. When NXTT0 is set it indic<br>WD2840 has the address of the next frame to transmit in its int<br>However when clear, it indicates that the transmit chain internal regi<br>the link field of the last buffer of the last transmitted frame. This<br>tained zero when first read. For the transmit case, this is a nor<br>corresponding to no data frames to transmit. |        |                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                   |                              | ain is handle<br>it indicates<br>n its internal<br>rmal register<br>e. This link f<br>is a normal | d by the<br>that the<br>register.<br>points to<br>ield con-<br>situation |                                       |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | (denoted b<br>when NXT                                                                                                                                                        | by posted FS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | e case, when<br>SB's) can be<br>indicates that<br>he very last fra                | removed fro<br>at the transm | om the chain<br>hit chain mu                                                                      | n for reuse.<br>st be extende                                            | However,<br>ed by the                 |  |  |

SR2 - STATUS REGISTER 2 DEFINITION

### **OTHER REGISTER DEFINITIONS**

NAME DESCRIPTION Running Limit Counter. Used by the WD2840 for Access Hold-Off Limit (AHOLT) checking and CTR0 Transmit Limit (TXLT) checking. When transmitting data frames CTR0 is used for TXLT counting; otherwise it is used for AHOLT counting. The counter runs from zero to the 8-bit limit value. NA Next Address. This register shows the current (instantaneous) successor node in the network logical ring. For validity, the WD2840 should be "in the ring" (see GIRING - CR13 and INRING -SR20 for more details). The successor node may be changed for a variety of reasons: 1. Any attempted token pass that fails twice will cause the WD2840 to attempt to locate a new successor by sequentially trying token passes to successively higher node addresses beginning with NA + 1. 2. A received Scan frame will cause NA to be set to MA<sup>s</sup> 1. If the next token pass fails case 1 applies. The host may arbitrarily redefine NA by using the NAR register and the NEWNA (CR10) control bit. At a convenient point the WD2840 recognizes NEWNA, copies NAR into NA, then clears NEWNA as confirmation. If the next token pass fails case 1 applies. TA Acknowledgement Timer. Value of maximum allowed time between frame transmission and ACK/NAK (if requested), or between token sent and network activity. The delay is in increments of 64 times the period of the clock CLK. Thus, if CLK = 2 MHz, then TA may be set in increments of 32 microseconds (range of 32 µs to 8.2 ms). TD Network Dead Timer. Value of maximum time interval between received valid frames on the network. 32X range of TA. Control Block Pointer. A sixteen bit pointer to the WD2840 control block in the user's memory. CBP (H,L) Must not be modified while the WD2840 is in network mode. NAR Next Address, Request. Used in conjunction with the NEWNA (CR10) control bit to cause the WD2840 to update the NA register. This redefines the node's successor in the network logical ring. It MUST be an address in the range 1-254. The acceptance of this update is confirmed when the NEWNA control bit is cleared. On the next token pass, if the redefined successor fails to accept the token, this WD2840 enters Scan mode where it sequentially attempts a token pass to successively higher nodes. AHOLT Access Hold-off Limit. This register is set at a value indicating the number of access cycles (tokens received) that must be skipped before the data frame may be transmitted. (A token pass frame will be sent even if a data frame may not be sent at a given access cycle.) Initialized to zero at power up. TXLT Transmit Limit. This register is set at the maximum number of consecutive data frames the WD2840 may transmit during one access cycle. A value of zero allows the WD2840 to transmit all frames queued up to 256. Initialized to zero at power up. MA My Address. The WD2840 receives only frames with this destination address (along with the broadcast address) and inserts this address into the SA field of any transmitted frame. Must be set by the host (range is 1 to 254).

# **1.4 DIAGNOSTIC AIDS**

There are three levels of diagnostics supported by the WD2840; those that are associated with the network as a whole, those associated with the in-

|              | AGNOST<br>DE CONT | · · •         |                                                                         |
|--------------|-------------------|---------------|-------------------------------------------------------------------------|
| CR00<br>ISOL |                   | SR21<br>STATE | DEFINITION                                                              |
| 1            | 0                 | 0             | WD2840 "Isolated." Power-<br>up condition or isolate<br>request.        |
| 0            | 0                 | 0             | WD2840 active.                                                          |
| 1            | 0                 | 1             | Isolate request function confirmed.                                     |
| 1            | 1                 | 0             | Host request to enter diagnostic mode.                                  |
| 1            | 1                 | 1             | Diagnostic mode con-<br>firmed. Diagnostic func-<br>tions of CR1 apply. |
| 0            | 0                 | 1             | Illegal.                                                                |
| 0            | 1                 | 0             | Illegal.                                                                |
| 0            | 1                 | 1             | Illegal.                                                                |

dividual node, and those that are limited to the WD2840 as a device. These tests are Network Diagnostics, System Diagnostics and Self Diagnostics respectively. The Network Diagnostics can be performed while the WD2840 is in the logical ring, but the System Diagnostics and the Self Diagnostics may be used only while the WD2840 is in the diagnostic mode.

Diagnostic mode may be entered after power-up or from the network mode by manipulation of the mode control bits. The mode transition is confirmed by the WD2840 via the STATE status bit.

Once in diagnostic mode, the desired test is selected via CR1. Because most of registers 8 through F are interpreted differently for each test, only one of the diagnostic test bits should be set at a time. In conjunction with setting the diagnostic bits, the NUDIAG (CR10) bit must be set to perform the diagnostic test requested.

At the completion of the selected test NUDIAG is cleared by the WD2840. Therefore the host can initiate a diagnostic by entering the diagnostic mode, initializing the proper registers, setting the desired diagnostic bit, and setting NUDIAG. The host then moniters CR1 for NUDIAG going to zero, indicating the completion of the requested diagnostic.

# **DIAGNOSTIC STATE FLOW CHART**



WD2840



# 1.4.1 SELF DIAGNOSTICS

# Internal Ram and Interrupt Test

There are nine eight bit registers in the WD2840 which are not directly accessable by the users CPU. This test provides a means to check those registers and the interrupt register. The contents of register A are placed into the interrupt register and five even internal registers, and the contents of register B in four odd internal registers. The nine registers are then added together without carry and the result is placed in registers 2, 5, 6, 7.

Use the following procedure to initiate the RAM test:

- 1. Enter diagnostic mode.
- 2. Set up registers A and B
- 3. Set RAMT.
- 4. Set NUDIAG (can be set with RAMT bit together).
- 5. Wait for NUDIAG to be cleared.
- 6. Read registers 2, 5, 6, 7. Clear RAMT.

Note that the setting of any bit in the interrupt register while <u>NOINT</u> is clear will generate a hardware interrupt (INTR, pin 43 goes true).

# **1.4.2 SYSTEM DIAGNOSTICS**

# **DMA** Test

This test verifies proper operation of the DMA subsystem by reading the value from a register and writing it into the user memory. The test continues by reading the value from the same location in memory and writing it into another register.

The value is read from register C. Using the transmitter DMA sub-system, it is written into memory location addressed by register A and B (location N; register A is the MSB). The receiver DMA sub-system is used and contents of the same address is read and it is stored into the register 7. Next the receiver dma is used and the contents from register D is written into location N + 1. The transmitter dma reads the value from location N + 1 and stores it into register 6.

It is the host's responsibility to check if the contents of registers C and register 7 and memory location N

match. The same is true for registers D and 6 and memory location  $N+1. \label{eq:register}$ 

### Loop-Back Test

The host can test the WD2840 transmitter and receiver logic by using the Loop Test.

There are two Loop Tests available for diagnostic purposes — internal and external.

| (CR12)<br>LOOPT | (CR03)<br>1LOOP | DEFINITION                 |
|-----------------|-----------------|----------------------------|
| 0               | 0               | Not in Loop Test           |
| 0               | 1               | Do not use in network mode |
| 1               | 0               | External loop              |
| 1               | 1               | Internal loop              |

When using the external loop the interface or modem must have the necessary logic to tie TD to RD and  $\overline{TC}$  to  $\overline{RC}$ .

Use the following procedure to run the loop test.

- 1. Set up a 256 byte transmit buffer with the data pattern to be transmitted.
- 2. Initialize a 256 byte receive buffer with all "00s" or "FFs."
- 3. Load register A (MSB) and B (LSB) with the address of the transmit buffer.
- 4. Load register C (MSB) and D (LSB) with the address of the receive buffer.
- 5. Load register 0 for Internal or External Loop.
- 6. Load register 1 for diagnostic & loop. (85H)
- 7. Refer to Diagnostic State Flow Chart.

### NOTE:

If this test frame is allowed onto the network, transmission collisions may occur. Further, the first three bytes of the transmit buffers will be interpreted as TC, DA and SA, respectively, by the other stations. Therefore in case this test is initiated while this node is in the logical ring, care should be taken for choosing these three values for external loop-back test.

For proper operation of the internal loop-back test the CTS and SQ pins of the WD2840 should be either tied to ground or tied to RTS pin of the WD2840.

### 1.4.3 NETWORK DIAGNOSTICS

### **Duplicate Station Detection**

Duplicate stations (more than one station with the same address) can result from the faulty programming of internal register MA (due to wrong address switch settings on the user's device, for example). This is expected to occur often enough to warrant the addition of a detection algorithm in the users WD2840 initialization procedure.

After initialization, the user should place the WD2840 in the network mode with TXEN off and ITOKON on. This will cause the WD2840 to generate an ITOK interrupt each time a token is passed to its address (MA). The host must provide the timeout algorithm which should be greater than the maximum time for the network to pass the token around the ring twice. Checking twice eliminates the possibility that the Network is in the scan mode and sending tokens to non-existing stations.

It is useful to note that this constraint requiring each node which is participating in the network logical ring to have a unique address does not extend to nodes which are "listening" but not "in the ring." It might be useful to a network designer to have groups of receive only nodes which have the same node address but do not participate in the network token passing (see GIRING - CR13). Data frames transmitted to such clusters must not request acknowledgement since all nodes in the cluster would simultaneously respond.

### Copy Mode

The COPY Mode is selected by setting the COPY control bit (CR02). Normally the WD2840 receives (DMA's into the receive buffer chain) data frames only if they contain the general broadcast destination address or if they are specifically addressed to the WD2840. This occurs when the frame's destination address (DA) matches the WD2840 my address (MA, set by the host).

However, when COPY mode is selected data frames which are specifically addressed to other nodes will be treated as broadcast frames by this node. The COPY mode allows a specific node to "eavesdrop" on data frame traffic on the network.

### **Nak Response**

The WD2840 sends negative acknowledgements (NAK's) on response to received frames under

several circumstances. The NAK prevents the transmitting node from wasting bandwidth retrying indiscriminately, and further, lends visibility to individual network node problems. The NAK includes a reason code which is available to the transmitter's software (via the TFSB).

Each data frame to be transmitted can be specifically marked (via the FCB) by the host to require an ACK/NAK response from the receiving WD2840. In the absence of errors, an acknowledge (ACK) frame will be returned to the transmitter as confirmation. However, several circumstances cause a Negative Acknowledge (NAK) to be returned:

- 1. Insufficient buffer space
- 2. Receiver not enabled (RXEN CR05 cleared)
- 3. Receiver overrun
- 4. Frame exceeded 16 buffers in length

This information is placed in the transmitted frames's FSB. See section 2.1.2 for more details on the Transmit Frame Status Byte (TFSB).

### 2.0 INTERFACES

There are two interfaces to the WD2840: the host computer side, and the network side. The network side is conventional from an electrical point of view, the WD2840 performs all logical functions required to ensure communications capability on broadcast media (such as coax or RF).

The host interface involves two separate functional interfaces: the status/control registers described in section one, and a DMA interface that is described in the following subsection.

### 2.1 HOST

The WD2840 uses a complex memory buffer architecture allowing it to respond in real time to its network obligations (e.g., to meet network data rate and processing delay requirements). These memory structures are managed cooperatively by the host and the WD2840.

Memory management functions requiring real time response (e.g., traversing chains) are completely handled by the WD2840. Other important, but not time critical operations are the responsibility of the host software (such as removing used buffers from the transmit chain).

All memory references by the WD2840 are pointed to by memory locations (and internal registers) initially defined and set up by the host software. Initial values and memory based registers are grouped together and called the WD2840 Control Block. WD2840

The location of this control block is written into the registers CBPH and CBPL anytime the WD2840 is in Isolate State. This control block has the following structure:

|                | · · · · · · · · · |                                |
|----------------|-------------------|--------------------------------|
| CBP→ +0        | NXTR (H)          | Receive Buffer Chain           |
|                |                   | (MSByte)                       |
| +1             | NXTR (L)          | Receive Buffer Chain           |
|                |                   | (LSByte)                       |
| +2             | NXTT (H)          | Transmit Buffer Chain          |
|                |                   | (MSByte)                       |
| +3             | NXTT (L)          | Transmit Buffer Chain          |
| 1 10           | · • · · · · (L)   | (LSByte)                       |
| +4             | BSIZE             | Buffer Size / 16 (0-F = $64$ - |
| <b>– – – –</b> | DOILL             |                                |
|                |                   | 1024 bytes)                    |
| +5             |                   |                                |
| +6             | EVT1              | Eleven separate Event          |
| 1              |                   | Counters, see section          |
|                |                   | 2.1.1 for details              |
| ) +F           | EVT10             |                                |
|                |                   |                                |

As the WD2840 transitions to Network State, it reads and uses the first five bytes of the control block. The remaining eleven bytes of event counters are accessed by the WD2840 only when each specific event condition occurs.

Either the Receive (NXTR) or Transmit (NXTT) chain entries in the control block may initially be zero; in such a case the WD2840 expects the chain to be extended by the host's changing the zero link field in the control block. Thereafter any such zero link would be in a buffer.

The WD2840 uses constant size buffers; their length is set by the value in location BSIZE. The buffer size is indicated by a 4-bit count in the least significant 4 bits of the BSIZE byte in the WD2840 control block. The buffer sizes available are multiples of 64; (BSIZE +1) 64 is the buffer size used by the WD2840. Thus a BSIZE range of 0-15 corresponds to actual buffer sizes of 64 through 1024 bytes. This buffer length is inclusive of control bytes and buffer link pointers.

The WD2840 includes a chained-block feature which allows the user more efficient use of memory, particularly in situations where the maximum packet size is much larger than the average packet size. One or up to 16 buffers may make up a frame but a buffer may not contain more than one frame.

Byte counters are associated with each frame (at the memory interface, not actually transmitted within the frame) so that frames on the network need not be integer multiples of buffers. The byte counters include all buffer management overhead. Therefore, a frame consisting of 100 transmitted data bytes, occupying two 64-byte buffers, would have a byte count of 110 (six bytes per frame + 2 bytes per buffer).

Since the WD2840 receive and transmit buffer chains are linked lists (see section 2.1.2 and 2.1.3) and are "followed" by the WD2840 but managed by the host;

it is expected that the host will maintain both a FIRST and a LAST address for each chain. On transition into Network State, the chain origin information in the WD2840 control block is the same as FIRST. In fact, since the WD2840 does not change these control block entries, they can be maintained directly as FIRST by the host. An explicit LAST could be placed in an extended control block section.

The WD2840 "follows" the linked buffer chains by maintaining a NEXT address internally for each chain. This NEXT address can be in one of two states: 1) it can be the address of the next buffer in the chain, or 2) at the chain end (zero link), it can be the address of the buffer containing the zero link. The WD2840 uses a status bit for each chain, NXTR0 (receive) and NXTTO (transmit), to differentiate the two states. When set they indicate the WD2840 chain NEXT address is in state 1 above; when clear they indicate state 2 above. This is an important distinction since it indicates whether the last buffer posted in a chain can be removed by the host (because the WD2840 has advanced to the buffer beyond) or must be left until the chain can be extended so the WD2840 can advance.

The host software monitors the progress of the NEXT pointer, and updates FIRST and LAST as it adds (and removes) buffers to (from) the chains as required. The WD2840 provides interrupt Events (see IR0) and NXTR0, NXTT0 status bits to indicate when it advances along the two chains and exactly what state its NEXT address registers are in. The operation of these chains will be explained by example in later sections.

# "Deadly Embrace" Prevention

A "Deadly Embrace" can occur when two processors reach a state where each is waiting for the other. In this case, the two processors are the user's CPU and the micro-controller inside the WD2840. Therefore, to prevent the "deadly embrace," the following rule is obeyed by the WD2840 and should also be obeyed by the user's CPU. This rule applies to the WD2840 memory registers and to the I/O registers. The Event Counters are an exception to this rule.

# Rule:

If a bit is set by the CPU, it will not be set by the WD2840, and vice versa. If a bit is cleared by the WD2840, it will not be cleared by the CPU, and vice versa.

As an example, the NEWNA (CR10) control bit is only set by the host and is only cleared by the WD2840.

# Dual DMA

The WD2840 may, for efficiency, interleave frame data fetch/store operations with fetches and stores of pointers and flags in memory. In all cases, operation sequencing is such as to prevent deadlocks and ambiguities between the WD2840 and software.

# 2.1.1 EVENT COUNTERS

Several non-fatal logical events are tabulated by the WD2840 and made visible to the host via memory based event counters (see WD2840 control block organization for specific locations). The WD2840 will

increment each counter at the occurance of the specified event. Note that the WD2840 will not increment past 255. The host has the responsibility of initializing each counter.

| COUNTER | DESCRIPTION                                                                                                                                                                                                                                                                                                     |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EVT0    | "Set scan mode" frame received from the network. The NA register was redefined to $MA + 1$ at the time.                                                                                                                                                                                                         |
| EVT1    | Transmission error first attempt, second try successful. Can only occur for frames requiring an acknowledgement. It indicates no response was received for the first transmission; however, the second transmission was either ACK'ed or NAK'ed.                                                                |
| EVT2    | Transmission error. Attempt aborted due to either transmitter underrun or frame length exceeding 16 buffers.                                                                                                                                                                                                    |
| EVT3    | Timer TD (network dead) expired.                                                                                                                                                                                                                                                                                |
| EVT4    | Access Control Frame Reception Error. A one or two byte supervisory frame (ACK/NAK, Token Pass, Scan Mode) has been received in error. This may be due to an FCS error, frame abort, or carrier loss detection.                                                                                                 |
| EVT5    | Data Frame Reception Error. An incoming data frame was incorrectly received due to<br>an FCS error, frame abort, carrier loss detection, or receiving a data frame when ex-<br>pecting an ACK/NAK frame.                                                                                                        |
| EVT6    | <ul> <li>NAK sent. Can occur for any of the following reasons:</li> <li>1. Insufficient buffers in chain</li> <li>2. Receiver not enabled (RXEN clear)</li> <li>3. Receiver overrun</li> <li>4. Frame length exceeded 16 buffers</li> </ul>                                                                     |
| EVT7    | Invalid frame received. Caused by the detection of certain abnormal network con-<br>ditions such as receiving an ACK/NAK frame when not expecting one, receiving a<br>Scan mode frame when expecting an ACK/NAK frame, or receiving an invalid<br>supervisory frame.                                            |
| EVT8    | Duplicate token detected. This counter will be incremented when the WD2840 determines that more than one token exists in the logical ring. This happens if a token pass is received when the WD2840 already has the token, or a data frame is received when the WD2840 is waiting for an acknowledgement frame. |
| EVT9    | Not used.                                                                                                                                                                                                                                                                                                       |
| EVT10   | Duplicate node address. This counter will be incremented when a data frame being DMA'd into memory has a source address (SA) equal to the WD2840 node address (MA). This counter when used with COPY mode (CR02) is one way for detecting other nodes with the same node number (MA).                           |

# 2.1.2 TRANSMIT MEMORY INTERFACE

When the token is received, data transmission is enabled (TXEN - CR06 and TXDEN - CR07 both set), and if the access hold-off counter has reached its limit, the WD2840 will determine whether any data frames are pending in the transmit chain. If so, it will transmit the first data frame in the chain. Otherwise the token will be passed. A given data frame will be the last frame transmitted for this token if any of several conditions occur.

- 1. ISOL (CR00) is set indicating the host has requested a transition to Isolate State.
- 2. TXDEN (CR07) is clear indicating the host has changed data frame transmission rights.
- 3. The frame FSB indicates this frame should be the last transmitted for this token.

- 4. The running frame counter has reached its limit (TXLT).
- 5. No further frames are pending in the transmit chain.

If any of the first four reasons above are true a token pass will occur. If the last frame does not require an acknowledgement, the WD2840 will piggyback the token pass if that is permitted (CR16). If the token cannot be piggybacked or if the last frame transmitted is the last frame pending (condition #5 above), an explicit token pass will occur. A piggyback token will not occur for the last pending frame because, for the general multiple buffer case, it is not known to be the last pending frame until after the transmission is complete. The WD2840 will read and evaluate the address of the next frame at two specific points in time:

- 1. At the end of the prior frame, even if the prior frame is the last to be transmitted for this token.
- 2. When the token is received and data frame transmission is permitted.

If a non-zero frame address is found at time 1 above, it is kept and used without being re-read at time 2 above. However, if no pending frame is found at time 1, this is noted with the NXTTO flag clear and the chain re-inspected on each occurrence of time 2 above.

As frame transmission commences, the WD2840 reads the address of the next buffer, the frame control byte, (FCB) and the frame length. It then starts reading bytes from the buffer and sending them until the frame length count or the end of the buffer is reached. The new buffer is read and data transmitted as before. (See Figure 2.1)

The frame length provided in the LENGTH field must be the sum of the overhead bytes and number of data bytes (see Fig. 2.1).

Simplified formula for LENGTH:

LENGTH = # of data bytes + 2 link bytes per buffer + 6 overhead constants per frame.

### Example #1

LENGTH = 8 (0010<sub>H</sub> in LENGTH field)

implies one buffer is used for this frame (64 bytes) two link + six overhead, no data.

### Example #2

LENGTH = # of data bytes + 2 link bytes per buffer + 6 overhead constants per frame.

Programmed buffer size = 64 bytes per buffer. Two buffers are used in this frame for a total of four link bytes (2 per buffer), six overhead, and 57 data bytes.

The General Formula for LENGTH

### WHERE

 $N_D = # of data bytes (max 4095)$ 

- 6 = Overhead Constant per frame (FSB, FCB, LENGTH (H), LENGTH (L), DA, SA)
- BK = B SIZE in bytes (64, 128, etc.) a constant preprogrammed into the WD2840 on 64 byte boundaries to a max of 1024 bytes.

GIVEN ND  

$$L = ND + 8 + 2^{*} TRUNC \frac{ND + 5}{B_{K} - 2}$$
GIVEN L  
#B's = 1 + TRUNC  $\frac{L - 1}{B_{K}}$   
ND = L - 6 - 2 (#B's)

### NOTE:

The expression for N<sub>D</sub> fails for values of L =  $B_{K}$  + 1. This is okay since the 2840 doesn't generate such values.

|                      | ND  | <u> </u> |         |
|----------------------|-----|----------|---------|
|                      | 0   | 8        |         |
|                      | 1   | 9        | 1 bufr  |
|                      | 56  | 64       |         |
| BK = 64              | 57  | 67       | 2 bufrs |
|                      | 118 | 128      |         |
|                      | 119 | 131      | 3 bufrs |
|                      | 120 | 128      | 1 bufr  |
| B <sub>K</sub> = 128 | 121 | 131      | 2 bufrs |
|                      | 246 | 256      |         |
|                      | 247 | 259      | 3 bufrs |

Find #B's, ND given L

|                      | L    | #B's        | ND  |
|----------------------|------|-------------|-----|
|                      | 8    | 1           | 0   |
|                      | 9    | 1           | 1   |
| BK = 64              | 64   | 1           | 56  |
|                      | 67   | 2           | 57  |
|                      | 128  | 2           | 118 |
|                      | 131  | 3           | 119 |
|                      | L    | #B's        | ND  |
| B <sub>K</sub> = 128 | 128  | 1           | 120 |
|                      | 131  | 2           | 121 |
|                      | 256  | 2           | 246 |
|                      | 258* | 2<br>3<br>3 | 246 |
|                      | 259  | 3           | 247 |

#### \*NOTE:

Case corresponds to buffer end and frame end on same byte . . . extra buffer consumed.

When the frame length is finally reached, the WD2840 pauses if an acknowledgement has been requested. The frame status byte (FSB) is updated when the frame is completed; its posting indicates frame completion and gives information about the success or failure of the frame transmission. At frame completion, the WD2840 attempts to advance along the transmission chain to identify the next frame regardless of whether it will be transmitted with this token or later.

The host may add frames to the end of the transmit chain at any time by changing the zero link in the last buffer. Also buffers of all posted frames up to but NOT including the last buffer of the most recently posted, may be arbitrarily removed from the chain. The last posted frame (more specifically, the last buffer of the last frame) may only be removed and reused if NXTTO is set. This indicates that the WD2840 has advanced its NEXT address to the next frame but that its transmission has not been completed (in fact, perhaps not even started).

### NOTE:

The WD2840 checks only the most significant byte of the link field for zero link detection. This has the following implications:

1. When writing into a zero link field, the host must write the LSB of the new link field first, followed by the corresponding MSB.

2. All buffers must have a starting address greater than or equal to Hex '0100'.

# **TRANSMIT FRAME STATUS BYTE (WRITTEN BY WD2840)**

| BIT # | 7      | 6                                                                   | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4           | 3              | 2          | 1    | 0    |  |  |
|-------|--------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|------------|------|------|--|--|
| Name  | DONE   | WIRING                                                              | Х                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | X           | SELF           | VAL2 —     | VAL1 | VALO |  |  |
| BIT   | NAME   |                                                                     | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |                |            |      |      |  |  |
| 7     | DONE   | Set to gu                                                           | uarantee a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | non-zero va | alue for the p | osted FSB. |      |      |  |  |
| 6     | WIRING | Value of                                                            | the corres                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | sponding bi | t in received  | ACK frame. |      |      |  |  |
| 5-4   |        | Reserve                                                             | d.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |                |            |      |      |  |  |
| 3     | SELF   | FSB is a                                                            | When set, indicates the ACK/NAK code appears in the value field (bit 2-0) of this FSB is assigned by the WD2840 transmitter routine. When clear, indicates value resulted from ACK/NAK code from receiving station.                                                                                                                                                                                                                                                                                                                                            |             |                |            |      |      |  |  |
| 2-0   | VAL    | FSB.<br>a. SE<br>0<br>0<br>0<br>0<br>1<br>b. SE<br>0<br>0<br>0<br>0 | An encoded field whose interpretation depends upon the SELF flag (bit 3) in this<br>FSB.<br>a. SELF clear<br>0 0 0 - No receive error (= ACK when DONE is set).<br>0 1 - Insufficent buffers for frame.<br>0 1 0 - Receiver not enabled at frame start.<br>0 1 1 - Receiver over-run.<br>1 0 0 - Frame exceeded 16 receive buffers.<br>b. SELF set<br>0 0 0 - No transmit error.<br>0 0 1 - Transmission failed after retry.<br>0 1 0 - Transmission failed after retry.<br>0 1 1 - Premature end of chain.<br>1 0 0 - Transmission frame exceeded 16 buffers. |             |                |            |      |      |  |  |

# **Transmit Frame Status and Control Bytes**

Each frame has two bytes reserved, one for host control information needed by the WD2840, the other for status information posted by the WD2840 at frame transmission completion. The frame control byte (FCB) is only read by the WD2840, never changed; the frame status byte (FSB), is written (posted) by the WD2840 with no regard for its prior contents. On completion, the FSB value will always be non-zero; it is important that the host zero the FSB byte in order to be able to recognize a posted frame.

# NOTE:

Specifically note in Figure 2.1 that the first buffer of each frame has a different structure than any overflow buffers for that frame. In particular, each frame has only one set of FSB, FCB, and LENGTH fields regardless of the number of buffers required by the frame.

| BIT # | 7      | 6                                                                                                                                                                                                                                                                                                                                                                                                                          | 5                                                                                                                                                                   | 4       | 3    | 2       | 1                                      | 0 |  |
|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|---------|----------------------------------------|---|--|
| Name  | WACK   | FCBLF                                                                                                                                                                                                                                                                                                                                                                                                                      | TRANSP                                                                                                                                                              | Х       | X    | Х       | Х                                      | Х |  |
| BIT   | NAME   |                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                     | ······· | DESC | RIPTION | ······································ |   |  |
| 7     | WACK   | Wait for Acknowledgement. Instructs the WD2840 to wait for an ACK/NAK response from the receiver for this particular frame only. The token control (TC) byte in the frame is automatically set to cause the destination node to respond. This bit must NOT be set if the frame uses the broadcast destination address. Inadvertently doing so will cause the frame to be posted "Transmission failed, due to max retries." |                                                                                                                                                                     |         |      |         |                                        |   |  |
| 6     | FCBLF  |                                                                                                                                                                                                                                                                                                                                                                                                                            | Last Frame. This bit will cause the WD2840 to pass the token either piggybacked with this frame (if possible) or explicitly after the frame transmission completes. |         |      |         |                                        |   |  |
| 5     | TRANSP | Transparent Frame. This bit will cause the WD2840 to interpret the buffer contents to be the exact sequence of bytes to be transmitted. The normal token control (TC) byte and source address (SA) byte generation is suppressed. Note that for a non-transparent data frame the TC byte must NOT appear in the buffer.                                                                                                    |                                                                                                                                                                     |         |      |         |                                        |   |  |
| 4-0   | _      | Reserve                                                                                                                                                                                                                                                                                                                                                                                                                    | h                                                                                                                                                                   |         |      |         |                                        |   |  |





# 2.1.3 Receive Memory Interface

After the third byte of an incoming data frame is detected, the WD2840 will begin to place frame data into memory if several conditions are satisfied:

- 1. Receiver Enabled (RXEN-CR05 set).
- 2. There is an available buffer in the receive buffer chain.
- 3. The frame is addressed to this node specifically. it is a broadcast frame, or COPY mode has been selected by the host.

As the frame continues, it may completely fill its buffer. If this happens the WD2840 reads and inspects the link field of the current buffer. If this link is zero, an error occurs and the receive chain is reset to reuse from the first buffer used by the dropped frame. However, if another buffer is available, the incoming frame is continued beginning in the third byte of that buffer. This continues until one of several things happen:

1. Receiver overrun. The WD2840 has a four byte FIFO to buffer incoming frame data; however, if the host DMA responds too slowly a receiver overrun will occur. If this happens an event counter is incremented, the frame is dropped, and the receiver buffer chain is reset to reuse buffers of the dropped frame.

- 2. Current buffer capacity exhausted. If 16 buffers have been used for the current frame, an event occurs with the frame being dropped and the chain reset. Otherwise the WD2840 attempts to advance to the next buffer in the receiver buffer chain. The frame data will be continued in this subsequent buffer. If the end of the receiver buffer chain is reached an event counter is incremented, the frame is dropped, and the chain reset.
- 3. Frame ends. If the FCS is not correct an event counter is incremented, the frame is dropped. and the chain is reset. If correct however, the frame length is placed in the LENGTH field and the Frame Status Byte (FSB) is posted "done, no error"

If the frame is addressed to this node and indicates an acknowledgement is required (TC = 255), whether or not an error occurs, the WD2840 responds with an ACK/NAK supervisory frame indicating either success or failure. In case of receiver over-run, bad FCS, and SA = MA acknowledgement request will be ignored. (See section 1.4.3 for details)

It is the host's responsibility to ensure that buffers are available, initialized (FSB zero'ed), and attached to the end of the receive buffer chain.

# **RECEIVE FRAME STATUS BYTE (WRITTEN BY WD2840)**

| BIT # | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------|---|---|---|---|---|---|---|
| Name  | DONE | х | х | Х | Х | х | х | х |

| BIT | NAME | DESCRIPTION                                      |
|-----|------|--------------------------------------------------|
| 7   | DONE | Set to indicate the frame reception is complete. |
| 6-0 | _    | Reserved.                                        |

### **RECEIVE FRAME CONTROL BYTE (WRITTEN BY HOST)**

|       |   | •   |             |   |   |   |   |   |
|-------|---|-----|-------------|---|---|---|---|---|
| BIT # | 7 | 6   | 5           | 4 | 3 | 2 | 1 | 0 |
| Name  | Х | Х   | Х           | Х | X | X | х | X |
| BIT   | N | AME | DESCRIPTION |   |   |   |   |   |
| 7-0   |   | _   | Reserved.   |   |   |   |   |   |

# **2.2 MODEM INTERFACE**

The modem interface is the conventional half duplex NRZ type with separate data and clock (Figure 2.3). When the WD2840 desires to transmit, it asserts RTS and awaits CTS. RTS is generally used to enable the modem transmitter. After a system dependent preamble is generated, the modem asserts CTS which allows the WD2840 to begin the actual transmission of the frame. (Note: CTS may be asserted permanently if the transmission system does not need to generate a preamble).

The  $\overline{SQ}$  input is used on receive to indicate a valid carrier. If this term is negated anytime during a receive message, the WD2840 will presume the message is in error and treat it as an abort. This signal is used to augment message integrity beyond that of the CRC by allowing a modem to detect and report low level faults (such as out-of-frequency carrier or missing clock).





# 3.0 NETWORK PROTOCOL

To enable operation on a broadcast medium without the need for a central controller performing device polling, the WD2840 implements a media access protocol. The particular access protocol designed into the WD2840 prevents self-induced transmission collisions and ensures a fair and guaranteed distribution of transmission time among attached controllers. (See Appendix A for Protocol flowcharts.)

This design-out of collisions allows the WD2840 a greatly expanded selection of transmission media, since no physical characteristics of a particular medium are relied upon for proper network operation. Another benefit of this lack of collisions is the visibility of network faults. If a collision is detected, it is treated consistently in a error recovery mode by the WD2840 and is also unambiguously visible to service personnel as a fault.

Secondly, the WD2840 can ensure that a transmitted message was correctly received and buffered by requiring acknowledgement of its receipt. This is sometimes called "acknowledging datagrams" where the sender awaits a predefined period after a frame is sent for a reply from its destination. With this method, no sequence counters nor multi-frame retransmission buffering is required. The scheme is efficient since local network applications such as the WD2840 address do not encounter extremely long transmission delays (such as satellite links) as in conventional data networks (such as X.25).

Both functions are parameterized, allowing tuning and optimization by the user to his unique application. These parameters may be adjusted in real time by the user's software, allowing a dynamic network, responsive to constantly changing requirements.

The two functions, access control and data transmission, function simultaneously though independently. Thus they are described separately as subprotocols for clarity.

# 3.1 Data Transmission

The data transmission cycle is entered after the token has been received and data transmission rights validated (see section 3.2 "access method"). The WD2840 determines if there is a frame to be sent and, if not, simply sends the token to the next station.

If something is queued for transmit, the WD2840 DMA's it from memory and sends it. After the complete frame has been sent, the WACK (Wait for ACK) bit is tested in the TFSB (Transmit Frame Status Byte). If set, the WD2840 waits for, and expects, an acknowledgement from the frames recipient. A timer (TA) is started. In the normal case, the ACK is received before TA expires which causes the WD2840 to send the next frame queued, repeating this procedure. Thus, the WD2840 sends multiple frames to various destinations until the transmit queue is emptied or a programmed limit (register TXLT) is exceeded.



In the event TA expires, the frame is re-transmitted once. (Note: it is the responsibility of higher level protocol operating in the host to protect against the possibility of duplicate frame reception.) If TA expires again, usually indicating the destination node is offline, the FSB is updated to reflect the unsuccessful transmission, interrupt bit ITA is set, and the frame is skipped.

A frame is also skipped and tagged if the destination station sends a NAK, indicating it cannot presently process the frame.

# TRANSMISSION OF ABORT

An ABORT is transmitted by the WD2840 to terminate a frame in such a manner that the receiving station will ignore the frame. An ABORT is sent when there is a Transmitter Under-Run. The abort sequence is a zero, followed by seven ones, after which RTS is set false.

# 3.2 ACCESS METHOD

The WD2840 network access method is based on the use of tokens, the specific granting of transmission rights passed from station to station. At any given time, exactly one station has the right to transmit (this right is called the token) and is obligated to pass it on when finished with it.

This can be clarified by referring to Figure 3.1. We assume in this figure that the network has already been initialized (meaning that the linkages in the access ring have already been established) and the token is held at this instant by station 4 (the station whose MA register = 4).

When station 4 is ready to pass his access right on, he sends a message to the station number called out in his internal register NA, in this case 11. The message, and thus the token, are received by station 11 who can now transmit its message(s). When station 11 is ready to pass the token, it sends a message to station 19, as directed by its internal register NA and the cycle continues, in a circular fashion, from station 4 to 11 to 19 to 54 to 4...

Notice that the station numbers need not be contiguous. This relatively arbitrary station numbering (in the example) poses no inefficiency to the access method. The value of this is the ability to add and remove stations (re-configure) on the network without re-arranging everyone elses addresses. (See section 3.2.2 for an example).

In this way, the token is passed from one station to the next in a logical ring.

# 3.2.1 ACCESS INITIALIZATION/ERROR RECOVERY

When the WD2840 is commanded into Network State, the Next Address Request (NAR) register and the NEWNA (CR10) flag must be used to define the Next Address (NA) register. When it is necessary to pass the token, it is passed to the current node number in register NA. If station NA is not on-line, determined by its lack of response, station NA + 1 is tried. This process continues until a station is found which does respond. The responding station number is written into register NA so that this scanning procedure need not be repeated on subsequent access cycles.

- NOTE: 1. Node numbers 0 and 255 are reserved and cannot be used. Consequently scanning occurs circularly in the range 1-254.
  - 2. During Scan mode token passing to each node is only tried once.

Anytime a station cannot successfully pass a token within two attempts, register NA is updated to NA + 1, and a new "next" station is searched for. The result is the removal of non-responding station(s) from the access ring. An interrupt (INS) is generated indicating a network exception caused a change to NA.

The above description covers network recovery from station failure and purposeful removal of stations during on-line network operation. Setting stations in the scan mode can also be accomplished by sending control frames (a Scan frame redefines NA = MA + 1) over the network. The control frame may be directed to a single station, or all stations simultaneously (using the broadcast address). It is this scanning for new stations that permits on line addition to the access ring.

#### NOTE:

The policy of the SCAN frame is redefined by the user software as required by the application. For example: in a process control environment where stations are not often added while the network is in use, this procedure would be initiated rarely if at all.

# 3.2.2 REMOVING A STATION

There are two ways a station can be removed from the access ring: non-response due to station failure and non-response due to host commanded transition to the Isolate State. Both are treated identically from a network point of view.

Referring to Figure 3.1, assume that station 19 is removed from the network (either physically or logically). In this example, station 11 would detect a network fault when trying to pass the token to 19 (time TA would expire since station 19 will not respond). Station 11 detects this and finds the next station in the access ring by using the "scan" function (similar to initialization). The next attempt at passing the token would be to station 20, register NA+1.

By starting the token ring recovery procedure at the intended station plus one (station 20) rather than MA + 1 (station 12) as is done in initialization, recovery delays are minimized (since fewer stations are tested for presence, 8 less in this example).

The next station found would be number 54 in the example which station 11 writes into his register NA (now "patching out" dead station 19). The next time station 11 is finished with the token, it directly sends it to 54, making the sequence now 11 to 54 to 4 to 11 to 54...

# 3.2.3 ADDING STATIONS

There are three primary methods by which a station can be added to a network. The first is a distributed method, in which each station in the network can poll for new stations in the gap between its address and the next address (between MA and NA). Second is a centralized method, in which an individual station designated by the network architect can interrogate the entire address space seeking a new station desiring INRING. The third — central scan — is a simpler (from the host point of view), centralized method in which a station can send a global frame causing all the on-line TACs to reset their next address space at its next tokenpass attempt. Each method has advantages and disadvantages.

# **Distributed Method**

The distributed method does not rely on a specific station. Thus, there are no problems or efforts spent selecting the administrator, nor is there any concern about backup administrators. In the distributive method, each station has the same responsibility to allow new access members as other stations. This method is the most host intensive and requires each station to maintain a timer (that can be configuration set as to its value) as to how often it should poll its gap for new stations.

For example, assume the timer in each station is 5 sec. and that station 4's timer has expired (Fig. 3.2.3.1). The host attached to station 4 notes that the next address register (NA in the TAC) is set to 11, which indicates that a new station might be added to the network as station number 5, 6, 7, 8, 9, or 10.

The host queues a frame into the TAC transmit chain, polling station 5. This frame will be sent by 4 with an acknowledgement requested from 5. If 5 is present it responds; otherwise, the TAC aborts its attempt after time TA. The TAC marks the result on the frame in the host memory space and proceeds with other tasks.

After this exchange, the host, at its leisure, checks the transmit status of the frame. The host sees that the frame acknowledgement timed out, meaning that station 5 has not been added to the network, or that station 5 is on the network and whether the request INRING is set in the network code field. In either case, the host takes appropriate action. If the desired INRING bit is set, station 4 changes its NA register to 5, allowing its next token to be passed to 5. This action puts station 5 in the ring.

Depending on an application's sophistication, a control message can be sent to station 5. That message says, "Your successor is X." In this case, X = 11, so that 5 is not forced to poll for its successor. In any case, 4 updates its next address register to 5 and does not need to go through this distributive polling cycle again because there is no gap between 5's address and the next address; there is no possibility that a new station can be inserted between addresses 4 and 5. If 5 didn't respond to 4's poll, station 4 updates its poll counter so that the next time that the poll timer times out, station 6 will be tried.



**Fig. 3.2.3.1 Distributed polling.** Each host polls the gap in its address space for the possible addition of new stations. The host internal poll timer and poll counter set the polling rate and range as desired.

If node 6 responds, its desired INRING bit is tested as above. If 6 does not respond, the host will queue a poll to station 7 the next time its poll timer expires. This continues until the host completes 10, when the cycle goes back to 5 and repeats. In this example, with a gap of 6 stations (between 4 and 11), and with a 5-sec. clock, a new node can be added within 30 sec.

In the centralized station-addition method, a single station can poll the entire address space, seeking a new station that desires INRING. One reason for centralizing this function might be the more careful control that can be placed in a network. There can also be optimizations. For example, the central polling station can keep track of the stations that already exist and, therefore, bypass some address ranges. A polling station may know the network will never have more than, say, 75 stations, In the example of Fig. 3.2.3.2, when station 4 starts polling, it polls only to address 75 before resetting to zero. This works like the distributed method except that a single station does all the work.



Fig. 3.2.3.2 Central polling. A single station — in this case, station 4 — dubbed "the administrator," can be charged with all polling tasks. This simplifies the software in the other stations and centralizes network control.

When the polling station determines that a station has been added, it must place the new station in the access ring. For example, station 4 is the centralized station doing all the polling (Fig. 3.2.3.2), and it discovers that station 27 has recently been added. Station 4 knows this because station 27 now responds to a first-time poll, and because its status bit is set, indicating that it wants to be added to the ring. (Some stations may be receive only, never desiring the right to initiate transmissions.) Station 4 sends a high-level message to the software in station 19, telling it to change its next address register to 27. This message can also prompt station 19 to tell 27 its next address register should be 54. This gets confusing, but it is all done with high-level software. These tasks are not real time and are guite efficient from the network point of view.

Station 4, the administrator, need not create and maintain a table of active stations on the network because the poll response returns three pieces of information. As node 4 polls the stations on the network, it finds out (a) that the polled station does not respond at all, as it would if it polled station 12 in Fig. 3.2.3.2 (b) that the station is already part of the network an is already in the ring or is receive only, as it would if station 4 happened to poll station 11 or 19; and (c) whether the station is attached to the network, is alive and wants to be in the ring, as is the case with a poll to 27. These indications are conveyed by a combination of status bits sent back by the acknowledge frame. This acknowledge frame and status information are transferred at a TAC device level, so a host is not concerned with whether its station wants to be in the ring. The host simply sets up the proper bits in the control registers; the bits are relayed automatically by the TAC. Thus, with a simple algorithm, an administrative station can poll the entire network address range and know the network's exact membership and status.

#### **Central Scan**

Central scan is the simplest method of adding stations to a network. It involves sending a global frame to all



FIG. 3.2.3.3 Central scan request. A special command can be sent by any station causing all attached TACs to set their NA register to the address of the next possible node. This causes each TAC to poll without the help of the host.

stations on the network, which forces each to update its own next address register to its station address plus one (NA = MA + 1). Assume station 4 is the centralized station and sends the scan command frame (Fig. 3.2.3.3). Station 11, upon receiving it, automatically sets its next address register to 12 (the TAC does this; the host is not involved but is notified of the situation). Also, station 19 sets its next address register to 20, and station 54 sets its NA register to 55.

The result of this is a round of polling at the TAC level. Station 11, on completing its use of the token, tries to send it to 12. The token to station 12 times out because 12 is not present. Station 11 reclaims the token trying to send it to 13 and so on, causing 11 to poll for station addition. The drawback of this is the huge time disruption incurred by the simultaneous polling.

It is not required that station 4 send this scan control frame to all stations at the same time. If it is known that station 11 exists in the network and that a station may be trying to add into the network after station 11 in the address space, a command can be sent to 11 telling it to set its next address register to 11 + 1. Now 11 will go through scanning station 12, 13, 14... again without intervention from station 11's host software. This directed scanning has the effect of smoothing the polling disturbance over a greater time.

The trade-off of all these methods is the software complexity distribution. If a TAC user assumes more responsibility, providing more intelligence distributed in the software, the system can be more sophisticated in handling new stations. If a user wants the TAC to handle this task itself, saving host software development, he pays only slightly in inefficiency. TAC gives the user an option.

# 3.2.4 INTERACTION OF THE SUB-PROTOCOLS

After a station is given the token, it will send an information frame, a token frame, or a combination of both. It is this combination frame, referred to as a "piggy back" token, that causes the sub-protocols to interact slightly.

In the normal case (no time-out), the SOURCE may transmit a combination frame to the DATASINK when his access period is over. All stations on the network observe this; after the reception of the current frame is complete, the one whose MA register matches the token address in the frame (TC) knows it has the token.

In the case of a combination frame, the SENDer resets his timer TA on transmission complete and waits for the NA station to transmit something valid,

| TC  | The token control byte has the dual purpose of transferring access control between stations and conveying a request for immediate acknowledgement of the frame by its intended receiver.                                                                                                                                           |                                                                                                                              |  |  |  |  |  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|     | There is no interaction between the TC field and the DA or SA fields. Thus the token may be transferred to one station and data sent to the same or a different station, with one single frame. The value entered into the TC field is determined by the WD2840 and does not appear in the buffer (except for transparent frames). |                                                                                                                              |  |  |  |  |  |
|     | TC Value                                                                                                                                                                                                                                                                                                                           | Meaning                                                                                                                      |  |  |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                  | Token not affected at this time.                                                                                             |  |  |  |  |  |
|     | 1-254 After current frame, the token belongs to station TC.<br>(The sending station has recovery responsibility).                                                                                                                                                                                                                  |                                                                                                                              |  |  |  |  |  |
|     | 255                                                                                                                                                                                                                                                                                                                                | Immediate ACK requested. Token not affected.                                                                                 |  |  |  |  |  |
|     | NOTE:<br>The sharing of this field prevents the passing of the token with data (piggy-back) and<br>acknowledgement requests on the same frame. This combination is specifically<br>disallowed because of its undesirable characteristics in network error situations                                                               |                                                                                                                              |  |  |  |  |  |
| DA  |                                                                                                                                                                                                                                                                                                                                    | ess. Value of zero is reserved, 1 to 254 indicates the destination ne. The value 255 is the global (or broadcast) address.   |  |  |  |  |  |
| SA  | Source address. The values of 0 and 255 are reserved. A value of 1 thru 254 is the address of the sender of the frame.                                                                                                                                                                                                             |                                                                                                                              |  |  |  |  |  |
|     | Information Field.                                                                                                                                                                                                                                                                                                                 | User defines format and content.                                                                                             |  |  |  |  |  |
| FCS | Frame Check Sequence. The FCS calculation includes all data between the opening flag and the first bit of the FCS, except for 0's inserted for transparency. The sixteen bit FCS is compatible with the standard HDLC FCS.                                                                                                         |                                                                                                                              |  |  |  |  |  |
| AC  |                                                                                                                                                                                                                                                                                                                                    | conveys supervisory information. May be sent as a command using or received in response to an ACK/NAK request. Its format is |  |  |  |  |  |

# FIELD DESCRIPTIONS AND ENCODING

# ACCESS CONTROL FIELD

| BIT # | 7     | 6      | 5 | 4 | 3 | 2     | 1         | 0       |
|-------|-------|--------|---|---|---|-------|-----------|---------|
| Name  | SCANF | WIRING | 0 | 0 | 0 | NVAL2 | — NVAL1 — | - NVAL0 |

| BIT | NAME   | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                       |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SCANF  | Scan Mode (Command). Indicates that the addressed node(s) must redefine NA = $MA + 1$ for use on its next token pass.                                                                                                                                                                                                                                             |
| 6   | WIRING | Wants in ring (Response). This bit when set informs the node requesting the ACK frame that this node is not in the logical ring, but is requesting entry. It is the logical function of the transmitting node's GIRING .AND. INRING. (see CR13 and SR20) The WD2840 does not act on this information but merely passes it to the host via the ACK'ed frame's FSB. |
| 5-3 | _      | Reserved.                                                                                                                                                                                                                                                                                                                                                         |
| 2-0 | NVAL   | An encoded NAK/ACK value (Response). The receiving node will set one of the following codes depending upon the state of the last received frame:                                                                                                                                                                                                                  |
|     |        | <ul> <li>0 0 0 — No error</li> <li>0 1 — Insufficient buffers for frame</li> <li>0 1 0 — Receiver not enabled at frame start</li> <li>0 1 1 — Receiver overrun</li> <li>1 0 0 — Frame exceeded 16 receive buffers</li> </ul>                                                                                                                                      |

to verify his reception of the piggy back token. If the timer expires, the sender sends an explicit token (the data from the combination frame is assumed to have been accepted) and enters the normal token subprotocol.

The user is prevented from sending a combination frame and requesting an acknowledgement at the same time to prevent possible network state conflict under time-out conditions.

# 3.3 FRAME FORMAT

The frame format the WD2840 uses to transmit all data and control frames is similar to the industry standard HDLC. A 16 bit CRC is implemented and standard zero insertion (CRC16-CCITT) is used for framing. This framing method allows the use of standard network monitoring and diagnostic equipment such as data scopes and logic analyzers.

Additional address fields and control points are defined as required to support the protocol.

# Normal Frame Format:

F-TC-DA-SA-I-FCS-F

- F = Flag, binary pattern 01111110
- TC = Token Control (8 bit)
- DA = Destination Address (8 bit)
- SA = Source Address (8 bit)
- I = Information Field (0 to 4095 bytes or 16 buffers, whichever is less).
- FCS = Frame Check Sequence (16 bit)

# Access Control Format:

F-DA-AC-FCS-F

- F = Flag, binary pattern 01111110
- DA = Destination Address (8 bit)
- AC = Access Control Field (8 bit)
- FCS = Frame Check Sequence (16 bit)

### Token Pass Format:

F-TC-FCS-F

- F = Flag, binary pattern 01111110
- TC = Token Control (8 bit)
- FCS = Frame Check Sequence (16 bit)

### 3.4 SENDING A TRANSPARENT OR ACCESS FRAME

Two types of frames are transmitted under the transparent mode under user control. A scan access frame or a transparent frame. The format of the frames are described under 3.3 Frame Format with the transparent format the same as Normal Frame Format.

# ACCESS FRAME COMMANDS

There is only one Access Frame type permitted under user control — Scan Frame. The node that is addressed must redefine NA = MA + 1 for use on its next token pass. The format for sending this frame is:

| LINK (H)<br>LINK (L) | Pointer to next frame.                        |
|----------------------|-----------------------------------------------|
| 00 (FŠB)             | Transportent from a no                        |
| 20h (FCB)            | Transparent frame, no<br>acknowledge allowed. |
| 00 LENGTH (H)        | Access Control frame<br>size (H, L).          |
| 08 LENGTH (L)        |                                               |
| DA                   | Destination Address or                        |
| 80h                  | 255 broadcast.<br>Set Scan Mode.              |

The FCB can be set for last frame, the acknowledge bit has no effect and no acknowledgements will be given to access frames nor will they be expected by the transmitting WD2840.

The node receiving the access frame will only recognize a scan access frame as a command. Event count #0 will increment and the receiving node will set its NA to MA + 1. Any other access code will increment Event Counter #7.

# **OPERATING CHARACTERISTICS (DC):**

Operating Temperature Range ..... 0°C to + 70°C

# TRANSPARENT FRAME

| st. |
|-----|
|     |
|     |
|     |
|     |
|     |

The Transparent Data Frame allows a user to control the token pass, or TC field of a frame by using the first byte after length rather than the FCB. The frame transmitted will look like the User Info part of the buffer without the WD2840 firmware generating anything else but the flags and FCS.

# **4.0 ELECTRICAL SPECIFICATIONS**

# **ABSOLUTE MAXIMUM RATINGS:**

| Voltages referenced to VSS                      |
|-------------------------------------------------|
| High Supply Voltage (VDD) 0.3 to 15V            |
| Voltage at any Pin – .03 to 15V                 |
| Storage Temperature Range – 55°C to + 125°C     |
| Electro-static voltage at any pin 400V (Note 6) |

# NOTE:

Absolute maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended and should be limited to those conditions specified under DC Electrical Characteristics.

| SYMBOL | PARAMETER           | MIN. | TYP. | MAX. | UNIT | CONDITIONS        |
|--------|---------------------|------|------|------|------|-------------------|
| IDD    | VDD Supply Current  |      | 18   | 30   | mA   |                   |
| ICC    | VCC Supply Current  |      | 160  | 220  | mA   |                   |
| VDD    | High Voltage Supply | 11.4 | 12   | 12.6 | v    |                   |
| Vcc    | Low Voltage Supply  | 4.75 | 5    | 5.25 | v    |                   |
| VIH    | Input High Voltage  | 2.4  |      |      | v    |                   |
| VIL    | Input Low Voltage   |      |      | 0.8  | v    |                   |
| Vон    | Output High Voltage | 2.8  |      |      | V    | $I_{O} = -0.1 mA$ |
| VOL    | Output Low Voltage  |      |      | 0.4  | V    | $I_0 = 1.6 mA$    |
| lozн   | Three-State Leakage |      |      | 50   | μA   | $V_{IN} = V_{CC}$ |
| IOZL   | Three-State Leakage |      |      | 50   | μA   | $V_{IN} = 0.4V$   |
| Чн     | Input Current       |      |      | 10   | μA   | VIN = VCC         |
| ΙL     | Input Current       |      |      | 10   | μA   | $V_{IN} = 0.4V$   |

| SYMBOL | PARAMETER                                                                         | MIN. | TYP. | MAX. | UNIT | CONDITIONS |
|--------|-----------------------------------------------------------------------------------|------|------|------|------|------------|
| CLK    | Clock Frequency                                                                   | 0.5  |      | 2.05 | MHz  | Note 1, 7  |
| RC     | Receive Clock Range                                                               | 0    |      |      | MHz  | Note 4, 7  |
| тс     | Transmit Clock Range                                                              | 0    |      |      | MHz  | Note 4, 7  |
| MR     | Master Reset Pulse Width                                                          | 10   |      |      | mS   |            |
| TAR    | Input Address Valid to RE                                                         | 0    |      |      | nS   |            |
| TRD    | Read Strobe (or DACK<br>Read) to Data Valid                                       | 2    |      | 375  | nS   | Note 5, 2  |
| THD    | Data Hold Time From<br>Read to Strobe                                             | 20   |      | 100  | nS   |            |
| ТНА    | Address Hold Time<br>From Read Strobe                                             | 0    |      |      | nS   |            |
| TAW    | Input Address Valid<br>to Trailing Edge of WE                                     | 100  |      |      | nS   |            |
| Tww    | Minimum WE Pulse Width                                                            | 200  |      |      | nS   |            |
| TDW    | Data Valid to Trailing<br>Edge of WE or Trailing<br>Edge of DACK for DMA<br>Write | 100  |      |      | nS   | Note 2, 3  |
| TWRR   | CS High Between<br>Writes                                                         | 300  |      |      | nS   |            |
| TRDR   | CS High Between RE                                                                | 300  |      |      | nS   |            |
| TRR    | RE Pulse Width                                                                    | 375  |      |      | nS   |            |
| TDAK   | DACK Pulse Width                                                                  | 375  |      |      |      |            |
| TAHW   | Address Hold Time<br>After WE                                                     | 80   |      |      | nS   |            |
| TDHW   | Data Hold Time After WE<br>or After DACK for DMA<br>Write                         | 100  |      |      |      |            |
| TDA1   | Time From DRQO (or<br>DRQI) to Output<br>Address Valid if<br>ADRV = 1             |      |      | 80   | nS   |            |
| TDA0   | Time From DACK to<br>Output Address Valid if<br>ADRV = 0                          |      |      | 375  | nS   | Note 5     |
| TDD    | Time From Leading Edge<br>of DACK to Trailing<br>Edge of DRQO<br>(or DRQI)        |      |      | 375  | nS   | Note 5     |
| TDAH   | Output Address Hold<br>Time From DACK                                             | 20   |      | 100  | nS   |            |
| TDMW   | Data Hold Time From<br>DACK For DMA Read                                          | 20   |      | 100  | nS   | Note 2     |
| TTDV   | TD Valid                                                                          | 100  |      |      | nS   |            |
| TSRD   | RD Setup                                                                          | 0    |      |      | nS   |            |
| THRD   | RD Hold                                                                           | 320  |      |      | nS   |            |

# 5.0 TIMING CHARACTERISTICS (AC):

# NOTES:

1. Clock must have 50% duty cycle.

2. There must not be a CPU read or write ( $\overline{CS}$ - $\overline{RE}$  or  $\overline{CS}$ - $\overline{WE}$ ) within 500 nanoseconds after the trailing (rising) edge of  $\overline{DACK}$ .

3. There must not be the leading (falling) edge of DACK allowed within 500 nanoseconds after the completion of a CPU write (CS-WE).

4. See "Ordering Information" for maximum serial rates.

5. C(load) = 100pf

6. Measured by discharging a 100pf capacitor to each pin through a 1K ohm resistor.

7. TC/RC must be <43% of CLK when transmitting multiple buffers.

81



CPU READ (CS IS LOW)

CPU WRITE (CS IS LOW)



DMA OUT

DMA IN

# 6.0 ORDERING INFORMATION

| DEVICE NUMBER | MAXIMUM RATE |  |  |
|---------------|--------------|--|--|
| WD2840-01     | 100 Kbps     |  |  |
| WD2840-05     | 500 Kbps     |  |  |
| WD2840-11     | 1.0 Mbps     |  |  |

Package Diagram





**TD-RD TIMING** 







2840 REVISION 4.0 ROMID=5 MARCH 3, 83









# WESTERN DIGITAL

CORPORATION

# WD2840 Application Note

# INTERFACING THE WD2840 TO A VERSABUS SYSTEM USING A DUAL PORT MEMORY

This application note describes one possible method of interfacing the WD2840 Token Access Controller with a general purpose microprocessor based system. This is intended to be an example design only, no effort has been made to minimize the logic required to perform these functions as would be done in a production design. Rather, the design has been kept "clean" to promote readability.

This implementation is designed with a dual-port memory concept allowing its use in systems that either do not support DMA at all, as well as systems that are unable to guarantee reasonable DMA response to a request (Figure 1). Examples of these systems are low end personal computers that allow their disk controllers to "hog" the DMA channel for an entire sector transfer. Very high end systems are also candidates for the dual-port memory technique. Here, the system bus may be shared by multiple hosts and be of such extreme bandwidth that the internal WD2840 DMA controller may be inefficient.

In most applications, the WD2840, can simply self-DMA its data directly to/from the host system's working memory. In the applications described above, the WD2840 must DMA its messages to/from the network into a local RAM allowing the host to access it at its leisure.

# REFERENCES

- WD2840 Token Access Controller Specification, Western Digital Corporation, 1983.
- "Token Passing Cashes in with Controller Chip" Electronic Design, October 14, 1982.
- Versabus Technical Reference Manual Motorola,
- RS-422 Technical Specification

This design is described in six sections:

- Host dependent logic, here designed for the Motorola Versabus system, including all required bus interface drivers and timing.
- Local two-port buffer memory which is shared by the host and the WD2840.
- Arbitration logic to fairly share the buffer memory, especially when both the host and WD2840 demand access at the same time.
- WD2840 Token Access Controller and associated timing
- Media interface consisting of a manchester encoder/decoder and liner drivers
- Generalized initialization flowchart



Figure 1. Versabus Application of WD2840 Using Dual Port Memory





# HOST INTERFACE

The host interface (Figure 2) utilizes common threestate bus drivers buffering the Versabus from the internal data bus. They are enabled low-Z onto the host bus whenever the host "reads" from the local memory (or WD2840 registers) and are enabled to drive the internal bus whenever the host writes to the internal memory (or registers). All other times these are hi-Z allowing other modules on the Versabus side to use that bus, as well as allowing the WD2840 to use the internal bus. Only an eight bit internal data bus is used mapping all host memory accesses into the lower byte. (Bus drivers A10 and A11 are not used)

Sixteen address bits are buffered and driven onto the internal address bus when the host has access to the RAMs (otherwise the WD2840 drives the internal address bus). The additional address lines of the Versabus are "anded" with the I/O Data Strobe signals DS0 and DS1 and address modifier bits creating a device select signal (DEVSEL) when all are active simultaneously indicating the host actually wants to access this module.

The Host Interrupt and Driver control logic (Figure 3) supplies the host interrupt vector (0FFH) when acknowledged (C10). Acknowledgement occurs when the Versabus ACKIN is received in conjunction with the proper priority level (set at 4 in this design), the proper address modifier (AMIACK), a short deskew delay (DSA3), and a signal indicating an

interrupt was indeed generated by this module (IROQ).

The logic on this sheet also controls the direction of the data buffers previously described (with signals EN and NEN), presuming the host has active control of the local bus (HOST = 1). The host requests control of the bus for access to the on-board RAM and during interrupt acknowledgement.

#### **CLOCK/ARBITRATION**

This logic (Figure 4) generates the synchronous timing used in the rest of the sections. A 16MHz signal derived from a crystal oscillator (part of the manchester logic, described later) is buffered (by C9 and then called FC). This high speed clock is also divided down for the WD2840 system clock CLK at 2 MHz (other slower rates are not used in this design).

This high speed clock clocks a simple latch (B7) until either the host or the WD2840 request local bus access. If the host desires access to this module, HOST is made true, the on-board WD2840 DMA request generated TACDRQ. When either (or both) of these signals occur, IDLE goes false (B5 pin4) freezing the state of latch B7.

IDLE going false starts the timing chain (B1, C1) that generates general timing pulses used later.

When the local memory sequence is complete, at time T10 for the TAC (B8 pin 6) or at time T7 for the



Figure 3. Host Interrupt and Driver Control

host (B2 pin 6) a special end of cycle delay is initiated (via shift register E7). This delay ensures that at least 500ns is maintained between WD2840 DMAs and possible host I/O accesses. At the end of this delay, flip-flop B6 generates a one clock "DONE" pulse resetting the arbitration logic.

# **MEMORY ARRAY**

The memory (Figure 5) uses simple static memories configured as 8K by 8 bits. The RAM data lines are buffered onto the local data bus due to loading considerations. The RAM array is enabled during all I/O operations except those to the first sixteen locations, which are used for accessing the sixteen internal WD2840 registers (REG).

# WD2840 SUPPORT

The WD2840 interface logic is given in Figure 6. The system clock (CLK) is derived from the timing generator (Figure 4). (This clock may be asynchronous with the transmit and receive data clocks if desired.) Address latches are used in this design to provide additional signal drive and to improve memory access timing (the WD2840 does have internal address latches that are useful in less stringent applications).

Host Write (HWRITE) is used to control the direction of I/O operations with the WD2840. When true, the WD2840 expects its internal registers to be written into. This occurs when both WE (pin 3) and CS (pin 4) are both low. Gate C7 1,2,3 ensures that the WE\* signal goes false prior to the data changing (ensures hold time). Chip select logic (D10, 1,2,13,12) enables reads or writes only when the host has access to the internal bus, the internal address bus holds a value in the range of 0-15 (REG true), and a short set-up timer has expired (T1).

Gate F10 (11,12,13) "ands" the WD2840s DMA input and output requests and presents them to the arbitration logic described earlier (via TACDRQ). The sense of the WD2840 DMA request (input or output) is latched (with E10). The DMA output signal is delayed for RAM setup (T2) and turned off before the data is removed to meet RAM hold timing (T7) and presented to the RAM control logic to generate the write pulse.

# MANCHESTER ENCODER/DECODER

The manchester encoder/decoder used here is a Harris HD-6409 (Figure 7). This device is ideal for use with the WD2840 in that its "invalid manchester output," that detects missing clocks, etc., can be directly connected to the WD2840's SQ input. A 16 Mhz crystal controls the internal digital phase locked loop used for clock recovery and generated the 16 Mhz master clock (FC) used for general timing in this design.

The "modem" consists of a simple RS-422 balanced driver and receiver. More elaborate media interfaces are possible, including FSK and broadband, depending on speed / distance / number of taps / cost requirements.

# INITIALIZATION

Figure 10 "flow chart" gives a generalized method of initializing a WD2840 based communications subsystem. First the WD2840 internal diagnostic are preferred, followed by loading of station parameters. Next the network is tested for activity and potential duplicate addresses. Finally the WD2840 TXEN is set allowing normal network generation. The Host now simply monitors TX and RX chains to sent/receive network data.

# SUMMARY

This application note details a simple WD2840 subsystem designed around the VERSAbus form factor. The on-board RAM makes removes any DMA/host bus access questions from the system design. A very simple line driver allows a number of these modules to communicate at speeds of 1 Mbps.

Note that this application note is intended for illustration only; simpler and more elaborate interfaces are possible.

B9 3 C8M -NC 9 C4M 8 TACGNT -NC 393 в 2 TACS B8 B7 10 C2M TACDRQ NC D 4 IDLE 3 TACS Q C1M 175 7 HOSTS B5 -NC LS08 6 5 FROM HOST D 12 C500K MANCHESTER C9 A NC D LS02 C250K 10 7 IDLE B<sub>1</sub> 12 13 FC NC g ۱D 11 HOSTGNT FC 9 C125K B8 Ci 13 LS240 HOSTS 2 B8 LS08 FC LS08 C9 0 LS240 **B**8 T10 CLOCK LS08 D7 10 13 2 R1 B5 273 9 5 R2 R1 4 LS240 R2 7 6 R3 9 R4 LS02 E7 HOST 4 B2 R3 8 Τ7 5 R4 13 R5 14 R6 17 R7 18 FC 11 12 R5 LS11 IDLE 3 D0 273 Q0 2 T9 Τ8 T1 3 15 R6 273 16 R7 <sup>B1</sup> Q1 T2 Т9 C1 5 T10 T1 RESET TAC/HOST ARBITRATION D1 19 R8 6 T11 тз Τ2 T10 7 D2 Q2 R8 2 D 74 R T3 T4 9 T12 T11 8 D3 Q3 B6 FC T12 13 12 T13 T4 13 T5 3 DONE D7 6 D4 Q4 0 T6 15 T14 Т6 21 T5 14 T6 T13 14 18 Q5 D5 LS240 T14 17 16 T15 Τ6 T7 17 Q6 **T**7 16 T7 + 5V T7 Τ8 T15 18 19 T16 18 Qī FC 11 FC 11 R **T**8 Т8 14 DONÉ 1119 STATE GENERATOR

Figure 4. Clock and Arbitration

A0 8 4118 4118 7 F1 D1 6 HRAMON 2 4 RAMOE 4118 5 СЗ DRQIL 3 D2 4118 157 **HWRITE 13** F2 C4 Τ4 12 4118 A7 TACW D4 LS32 Е s RAMWE 21 6 WE OE CS 5 D12 RAMOE 20 4118 15 TACS F4 RCS0 18 LS32 RCS4 18 CS 12 241 12 + 5 4118 15 Τ1 9 RDT0 D5 RDT1 10 RCS1 4118 RDT2 RDT3 F11 LS240 11 RCS5 18 18 F5 13 RDT4 14 TACGNT RCS2 18 RDT5 15 RDT6 3 В5 16 23 REG T1 A8 17 RDT7 18 RCS6 12 LS02 22 B2 A9 HOSTGNT 13 19 N/C 18 LS11 RCS3 RAMCE RCS7 18 RDT0 RDT1 RDT0 RDT1 D0 D1 D2 D0 D1 D2 D3 D4 D5 D6 D7 18 2 18 16 16 14 244 C11 16 244 C12 4 A10 RCS0 0 15 4 A RDT2 RDT2 RDT3 RDT4 A11 RCS1 6 14 2 6 B C8 12 D3 13 RCS2 12 RDT3 8 A12 8 с RDT4 D4 12 RCS3 11 9 11 9 -0-RDT5 RDT5 13 -∕-13 D5 11 RCS4 6 138 RDT6 RDT7 RDT6 RDT7 15 17 10 RCS5 <u>15</u> 17 D6 4 5 D7 3 3 5 9 RCS6 RCS7 ÷ 7 19 RAMOE RAMOE 17 LS240 D7

Figure 5. Memory Array



Figure 6. WD2840 Support



Figure 7. Manchester Encoder/Driver



Figure 8. Host Timing







Information furnished by Western Digital Corporation is believed to be accurate and reliable. However, no responsibility is assumed by Western Digital Corporation for its use; nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Western Digital Corporation. Western Digital Corporation reserves the right to change specifications at anytime without notice.



2445 McCABE WAY IRVINE, CALIFORNIA 92714

(714) 863-0102, TWX 910-595-1139



2445 McCabe Way • Irvine, CA 92714 (714) 863-0102 • TWX 910-595-1139