USER'S MANUAI

# **MC68605** X.25 PROTOCOL CONTROLLER

USER'S MANUAL

| Introduction                             | 1  |
|------------------------------------------|----|
| XPC Implementation of LAPB Procedure     | 2  |
| XPC Transparent Mode of Operation        | 3  |
| Internal Registers                       | 4  |
| Shared Memory Structures                 | 5  |
| Command Set                              | 6  |
| Signal Description                       | 7  |
| Bus Operation                            | 8  |
| <b>XPC/Host Processor Interface</b>      | 9  |
| Electrical Specifications                | 10 |
| Ordering Information and Mechanical Data | 11 |

# Introduction

1

2

3

4

5

6

7

8

- XPC Implementation of LAPB Procedure
- XPC Transparent Mode of Operation
  - Internal Registers
  - **Shared Memory Structures**
- Command Set
- Signal Description
- Bus Operation
- 9 XPC/Host Processor Interface
- **10** Electrical Specifications
- **11** Ordering Information and Mechanical Data

# MC68605

# X.25 PROTOCOL CONTROLLER (XPC) USER'S MANUAL

Motorola reserves the right to make changes without further notice to any products herein to improve reliability, function or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. Motorola products are not authorized for use as components in life support devices or systems intended for surgical implant into the body or intended to support or sustain life. Buyer agrees to notify Motorola of any such intended end use whereupon Motorola shall determine availability and suitability of its product or products for the use intended. Motorola and are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Employment Opportunity/Affirmative Action Employer.

# **TABLE OF CONTENTS**

Paragraph Number

#### Title

Page Number

#### Section 1 Introduction

| 1.1 | Key Features           | 1-1 |
|-----|------------------------|-----|
| 1.2 | General Description    | 1-2 |
| 1.3 | X.25 Frame Description | 1-4 |

## Section 2 XPC Implementation of LAPB Procedure

| 2.1   | Initialization Procedure             | 2-1  |
|-------|--------------------------------------|------|
| 2.2   | Link Setup Procedure                 | 2-2  |
| 2.3   | Collision of Unnumbered Commands     | 2-3  |
| 2.4   | Information Frame Transmission       | 2-3  |
| 2.4.1 | Receiving Acknowledgement            | 2-4  |
| 2.4.2 | Waiting Acknowledgement              | 2-4  |
| 2.4.3 | Receiving an REJ Frame               | 2-5  |
| 2.4.4 | Receiving an RNR Frame               | 2-6  |
| 2.5   | Information Frame Reception          | 2-6  |
| 2.5.1 | Invalid Frame Condition              | 2-7  |
| 2.5.2 | Receiving an Out-of-Sequence I Frame | 2-7  |
| 2.5.3 | Frame Reject Mode                    | 2-7  |
| 2.5.4 | Idle Channel Condition               | 2-9  |
| 2.5.5 | Busy Condition                       | 2-9  |
| 2.6   | Disconnect Mode                      | 2-9  |
| 2.7   | Link Disconnect Procedure            | 2-10 |
| 2.8   | State Table                          | 2-10 |

# Section 3

# **XPC Transparent Mode of Operation**

| 3.1 | Initialization Procedure       | 3-1 |
|-----|--------------------------------|-----|
| 3.2 | Entering Transparent Operation | 3-2 |

# ParagraphPageNumberTitle3.3Frame Transmission3.33.3

| 3.3 | Frame Transmission       | 3-3 |
|-----|--------------------------|-----|
| 3.4 | Frame Reception          | 3-4 |
| 3.5 | Exiting Transparent Mode | 3-5 |

# Section 4

## **Internal Registers**

| 4.1    | Command Register                       | 4-3  |
|--------|----------------------------------------|------|
| 4.2    | Semaphore Register                     | 4-4  |
| 4.3    | Interrupt Vector Register              | 4-4  |
| 4.4    | Data Register                          | 4-5  |
| 4.5    | Indirectly Accessible Registers        |      |
| 4.5.1  | Station Table Pointer Register         | 4-5  |
| 4.5.2  | Station Table Function Code Register   | 4-5  |
| 4.5.3  | Transmit Table Pointer Register        |      |
| 4.5.4  | Transmit Table Function Code Register  | 4-6  |
| 4.5.5  | Transmit Buffer Pointer Register       |      |
| 4.5.6  | Transmit Buffer Function Code Register | 4-7  |
| 4.5.7  | Transmit Buffer Count Register         |      |
| 4.5.8  | Receive Table Pointer Register         | 4-8  |
| 4.5.9  | Receive Table Function Code Register   | 4-8  |
| 4.5.10 | Receive Buffer Pointer Register        | 4-9  |
| 4.5.11 | Receive Buffer Function Code Register  | 4-9  |
| 4.5.12 | Receive Buffer Count Register          | 4-9  |
| 4.5.13 | Local Address Register                 | 4-10 |
| 4.5.14 | Remote Address Register                | 4-10 |
| 4.5.15 | Hardware Configuration Register        | 4-10 |
| 4.5.16 | Station Configuration Register         | 4-11 |
| 4.5.17 | Option Bits Register                   | 4-12 |
| 4.5.18 | Mode Descriptor Register               | 4-12 |
| 4.5.19 | Frame Reject Descriptor Register       | 4-15 |
| 4.5.20 | Rx/Host Status Register                | 4-16 |
| 4.5.21 | Tx/Link Status Register                | 4-19 |
| 4.5.22 | V(R) Register                          | 4-21 |
| 4.5.23 | V(S) Register                          | 4-21 |
| 4.5.24 | Time-Out Preset Register               | 4-21 |
| 4.5.25 | Retries Limit Register                 | 4-22 |

#### Paragraph Page Number Number Title 4.5.26 Time Scale Divider Register ..... 4-22 Outstanding Frames Limit Register...... 4-23 4.5.27 4.5.28 Pad Time Select Register 4-23 4.5.29 Retries Count Register...... 4-23 4.5.30 Last Receive (N(R)..... 4-24 Hardware or Software Reset ..... 4-24 4.6

#### Section 5 Shared Memory Structures

| 5.1    | Station Table                      | 5-2  |
|--------|------------------------------------|------|
| 5.1.1  | Option Bits                        | 5-2  |
| 5.1.2  | Time-Out Preset                    | 5-2  |
| 5.1.3  | Time Scale Divider                 | 5-4  |
| 5.1.4  | Pad Time Select                    | 5-4  |
| 5.1.5  | Outstanding Frames Limit           | 5-4  |
| 5.1.6  | Retries Limit                      | 5-5  |
| 5.1.7  | Rx/Host Mask                       | 5-5  |
| 5.1.8  | Tx/Link Mask                       | 5-6  |
| 5.1.9  | Rx/Host Status Clear               | 5-6  |
| 5.1.10 | Tx/Link Status Clear               | 5-7  |
| 5.1.11 | Local Address                      | 5-7  |
| 5.1.12 | Remote Address                     | 5-7  |
| 5.1.13 | Receive Table Function Code        | 5-7  |
| 5.1.14 | Receive Table Pointer              | 5-8  |
| 5.1.15 | Transmit Table Function Code       | 5-8  |
| 5.1.16 | Transmit Table Pointer             | 5-8  |
| 5.1.17 | Dump Area Function Code            | 5-9  |
| 5.1.18 | Dump Area Pointer                  | 5-9  |
| 5.1.19 | Rx/ Host Status                    | 5-9  |
| 5.1.20 | Tx/Link Status                     | 5-10 |
| 5.1.21 | Mode Descriptor                    | 5-10 |
| 5.1.22 | Frame Reject Descriptor            | 5-10 |
| 5.1.23 | V(R)                               | 5-11 |
| 5.1.24 | V(S)                               | 5-11 |
| 5.1.25 | First Unacknowledged Function Code | 5-11 |
| 5.1.26 | First Unacknowledged Pointer       | 5-11 |

| Paragrap |                                          | Page   |
|----------|------------------------------------------|--------|
| Number   | Title                                    | Number |
| 5.1.27   | Transmit Function Code                   | 5-11   |
| 5.1.28   | Transmit Table Pointer                   | 5-12   |
| 5.1.29   | Receive Function Code                    | 5-12   |
| 5.1.30   | Receive Table Pointer                    | 5-12   |
| 5.1.31   | Receive Bus/Address Error Function Code  | 5-12   |
| 5.1.32   | Receive Bus/Address Error Pointer        | 5-13   |
| 5.1.33   | Transmit Bus/Address Error Function Code | 5-13   |
| 5.1.34   | Transmit Bus/Address Error Pointer       |        |
| 5.1.35   | Received FRMR Information Field          | 5-13   |
| 5.2      | Transmit Frame Specification Table       | 5-14   |
| 5.2.1    | Transmit Table Status                    | 5-14   |
| 5.2.2    | Transmit Buffer Function Code            | 5-14   |
| 5.2.3    | Transmit Buffer Address                  | 5-15   |
| 5.2.4    | Transmit Buffer Length                   | 5-15   |
| 5.2.5    | Transmit Bus/Address Error               | 5-15   |
| 5.3      | Receive Frame Specification Table        | 5-16   |
| 5.3.1    | Receive Status                           | 5-16   |
| 5.3.2    | Receive Buffer Function Code             | 5-17   |
| 5.3.3    | Receive Buffer Address                   | 5-17   |
| 5.3.4    | Receive Buffer Length                    | 5-18   |
| 5.3.5    | Final Count                              |        |
| 5.3.6    | Receive Bus/Address Error                | 5-18   |

# Section 6

### **Command Set**

| 6.1   | Initialization Commands     | 6-1 |
|-------|-----------------------------|-----|
| 6.1.1 | Reset                       | 6-1 |
| 6.1.2 | Set Station Configuration   | 6-2 |
| 6.1.3 | Set Hardware Configuration  | 6-2 |
| 6.1.4 | Load Function Code          | 6-3 |
| 6.1.5 | Load Station Table Pointer  | 6-3 |
| 6.2   | Table Handling Commands     | 6-3 |
| 6.2.1 | Load Option Bits            | 6-4 |
| 6.2.2 | Load Preset Values          | 6-4 |
| 6.2.3 | Load Addresses              | 6-4 |
| 6.2.4 | Load Transmit Table Pointer | 6-4 |
|       |                             |     |

#### Paragraph Page Number Title Number 6.2.5 Continue Transmit 6-6 6.2.6 6.2.7 Load Station Parameters ..... 6-8 6.2.86.2.9 Clear Tx/Link Status 6-9 6.2.10 6.2.11 6.2.12 6.3 6.3.1 6.3.2 6.4 6.4.1 Dump Registers ...... 6-10 DMA Transfer...... 6-11 6.4.2 6.4.3 6.4.4 6.4.5 End Monitor 6-15

#### Section 7 Signal Description

|       | eigna beeenption                                 |     |
|-------|--------------------------------------------------|-----|
| 7.1   | Address Bus (A1–A3)                              | 7-1 |
| 7.2   | Data Bus (D0–D15)                                | 7-2 |
| 7.3   | Function Codes (FC0–FC3)                         | 7-2 |
| 7.4   | Bus Control                                      | 7-3 |
| 7.4.1 | Chip Select (CS)                                 | 7-3 |
| 7.4.2 | Address Strobe (AS)                              | 7-3 |
| 7.4.3 | Read/Write (R/W)                                 | 7-3 |
| 7.4.4 | Upper Data Strobe (UDS/A0) and Lower Data Strobe |     |
|       | (LDS/DS)                                         | 7-3 |
| 7.4.5 | Data Transfer Acknowledge (DTACK)                | 7-4 |
| 7.5   | Bus Arbitration                                  | 7-5 |
| 7.5.1 | Bus Request (BR)                                 | 7-5 |
| 7.5.2 | Bus Grant (BG)                                   | 7-5 |
| 7.5.3 | Bus Grant Acknowledge (BGACK)                    | 7-5 |
| 7.6   | Interrupt Control                                | 7-5 |
| 7.6.1 | Interrupt Request (IRQ)                          | 7-6 |
| 7.6.2 | Interrupt Acknowledge (IACK)                     |     |
|       |                                                  |     |

| Title                                |                                                                                                                                                                                                                                                                  |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bus Exception Conditions (BEC0-BEC2) | 7-6                                                                                                                                                                                                                                                              |
| Clock (CLK)                          |                                                                                                                                                                                                                                                                  |
|                                      |                                                                                                                                                                                                                                                                  |
| Carrier Detect (CD)                  | 7-6                                                                                                                                                                                                                                                              |
| Request-to-Send (RTS)                |                                                                                                                                                                                                                                                                  |
| Clear-to-Send (CTS)                  | 7-7                                                                                                                                                                                                                                                              |
| Transmit                             | 7-7                                                                                                                                                                                                                                                              |
| Transmit Clock (TCLK)                |                                                                                                                                                                                                                                                                  |
| Transmit Data (TxD)                  | 7-7                                                                                                                                                                                                                                                              |
| Receive                              | 7-8                                                                                                                                                                                                                                                              |
| Receive Clock (RCLK)                 |                                                                                                                                                                                                                                                                  |
| Receive Data (RxD)                   | 7-8                                                                                                                                                                                                                                                              |
| Signal Summary                       | 7-8                                                                                                                                                                                                                                                              |
|                                      | Bus Exception Conditions (BEC0-BEC2)<br>Clock (CLK)<br>Modem Control<br>Carrier Detect (CD)<br>Request-to-Send (RTS)<br>Clear-to-Send (CTS)<br>Transmit<br>Transmit Llock (TCLK)<br>Transmit Data (TxD)<br>Receive<br>Receive Clock (RCLK)<br>Receive Data (RxD) |

# Section 8

#### **Bus Operation**

| 8.1     | Slave Operation Mode              | 8-1  |
|---------|-----------------------------------|------|
| 8.1.1   | Host Processor Read Cycles        | 8-1  |
| 8.1.2   | Host Processor Write Cycles       | 8-2  |
| 8.1.3   | Interrupt Acknowledge Cycles      | 8-3  |
| 8.2     | Master Operation Mode             | 8-4  |
| 8.2.1   | XPC Read Cycles                   | 8-4  |
| 8.2.2   | XPC Write Cycles                  | 8-6  |
| 8.2.3   | XPC DMA Priority Scheme           | 8-6  |
| 8.2.4   | XPC Memory Bandwidth Requirements | 8-7  |
| 8.3     | Bus Exception Control             | 8-10 |
| 8.3.1   | BEC0–BEC2 Synchronization         | 8-11 |
| 8.3.2   | Bus Exception Functions           | 8-11 |
| 8.3.2.1 | Normal Termination                |      |
| 8.3.2.2 | Halt                              | 8-11 |
| 8.3.2.3 | Bus Error                         |      |
| 8.3.2.4 | Retry                             | 8-14 |
| 8.3.2.5 | Relinquish and Retry              |      |
| 8.3.2.6 | Reset                             |      |
| 8.3.2.7 | Undefined BEC Code                | 8-14 |

# **TABLE OF CONTENTS (Concluded)**

| Paragrap<br>Numbe |                               | Page<br>Number |
|-------------------|-------------------------------|----------------|
| 8.4               | Bus Arbitration               | 8-14           |
| 8.4.1             | Requesting the Bus            | 8-17           |
| 8.4.2             | Receiving the Bus Grant       | 8-20           |
| 8.4.3             | Acknowledgement of Mastership | 8-20           |
| 8.4.4             | Bus Arbitration State Machine | 8-20           |
| 8.5               | Reset Operation               | 8-21           |
| 8.6               | Bus Overhead Time             | 8-21           |
| 8.6.1             | Front-End Overhead            | 8-22           |
| 8.6.2             | Back-End Overhead             | 8-22           |

#### Section 9 XPC/Host Processor Interface

#### Section 10 Electrical Specifications

| 10.1 | Maximum Ratings               | 10-1 |
|------|-------------------------------|------|
| 10.2 | Thermal Characteristics       | 10-1 |
| 10.3 | Power Considerations          | 10-2 |
| 10.4 | DC Electrical Characteristics | 10-3 |
| 10.5 | AC Electrical Characteristics | 10-3 |

# Section 11

# **Ordering Information and Mechanical Data**

| 11.1 Package Types                 | 11-1 |
|------------------------------------|------|
| 11.2 Standard Ordering Information |      |
| 11.3 Pin Assignments               |      |
| 11.4 Package Dimensions            |      |

MC68605 USER'S MANUAL

MOTOROLA

# LIST OF ILLUSTRATIONS

| Figure<br>Number | Title                                 | Page<br>Number |
|------------------|---------------------------------------|----------------|
| 1-1              | XPC System Configuration              |                |
| 1-2              | MC68605 Block Diagram                 |                |
| 1-3              | X.25 Frame Formats                    |                |
| 1-4              | Basic Control Format                  |                |
| 1-5              | Extended Control Format               |                |
| 1-6              | Commands and Responses                |                |
| 1-7              | X.25 Frame Originate                  | 1-8            |
| 2-1              | XPC State Diagram                     | Foldout-1      |
| 4-1              | XPC Register Map                      | 4-2            |
| 4-2              | Transmit Registers                    | 4-6            |
| 4-3              | Receive Registers                     | 4-8            |
| 5-1              | Shared Memory Tables                  | 5-1            |
| 6-1              | DMA Configuration                     | 6-12           |
| 6-2              | Serial Loopback Configuration         | 6-13           |
| 7-1              | Input and Output Signals              | 7-2            |
| 8-1              | Host Processor Read Cycle             | 8-2            |
| 8-2              | Host Processor Write Cycle            | 8-3            |
| 8-3              | Interrupt Acknowledge Cycle           |                |
| 8-4              | Read Cycle and Slow Read Cycle        |                |
| 8-5              | Write Cycle and Slow Write Cycle      |                |
| 8-6              | Example BEC Signal Generation Circuit |                |
| 8-7              | Write Cycle with Halt                 |                |
| 8-8              | Read Cycle with Bus Error             |                |
| 8-9              | Write Cycle with Retry                |                |
| 8-10             | Read Cycle with Retry                 |                |
| 8-11             | Read Cycle with Relinquish and Retry  |                |
| 8-12             | Read Cycle with Undefined BEC0-BEC2   |                |
| 8-13             | Bus Arbitration                       | 8-19           |

# LIST OF ILLUSTRATIONS (Continued)

| Figure<br>Number | Title                                                    | Page<br>Number |
|------------------|----------------------------------------------------------|----------------|
| 8-14             | MC68605 Bus Arbitration Unit State Diagram               | 8-21           |
| 8-15             | Bus Timing Diagram                                       | 8-23           |
| 9-1              | XPC-to-Host-Processor Interface                          | 9-1            |
| 9-2              | XPC-to-MC68020 Interface                                 | 9-2            |
| 9-3              | Serial Interface Examples                                | 9-3            |
| 10-1             | Host Processor Read Cycle Timing Diagram                 | Foldout-2      |
| 10-2             | Host Processor Write Cycle Timing Diagram                | Foldout-2      |
| 10-3             | Interrupt Acknowledge Cycle Timing Diagram               | Foldout-2      |
| 10-4             | Bus Arbitration Timing Diagram                           |                |
| 10-5             | Read Cycle and Slow Read Cycle Timing Diagram            |                |
| 10-6             | Write Cycle Timing Diagram                               |                |
| 10-7             | XPC Read Cycle with Retry Timing Diagram                 |                |
| 10-8             | Read Cycle with Bus Error Timing Diagram                 |                |
| 10-9             | BR After Previous Exception Timing Diagram               |                |
| 10-10            | Short Exception Cycle Timing Diagram                     |                |
| 10-11            | Clock (CLK) Timing Diagram                               |                |
| 10-12            | XPC Serial Data RxD, TxD, and Serial Clocks (RCLK, TCLK) |                |
|                  | Timing Diagram                                           | Foldout-6      |

# LIST OF TABLES

#### Table Number

# Title

# Page Number

| 4-2<br>4-3 | XPC Register Set<br>Valid Commands<br>Relationship Between TBEN, CONN, and IFAK<br>Reset Impact on Registers | 4-3<br>4-15 |
|------------|--------------------------------------------------------------------------------------------------------------|-------------|
|            | Data Strobe Control of Data Bus in Master Mode<br>Signal Summary                                             |             |
| 8-1        | BEC Encoding Definitions                                                                                     | 8-10        |

MC68605 USER'S MANUAL

MOTOROLA

# SECTION 1 INTRODUCTION

The MC68605 X.25 Protocol Controller (XPC) is an intelligent HCMOS communications protocol controller that implements the 1984 International Telegraph and Telephone Consultative Committee (CCITT) X.25 Recommendation, data link access procedure (LAPB). It supports full-duplex point-to-point serial communication at up to 10 megabits per second (MBPS) and relieves the host processor of managing the communications link by providing sequencing using HDLC framing, error control, retransmission based upon a cyclic redundancy check (CRC), and flow control using the receive not ready supervisory frame. The XPC directly supports the physical level interfaces (Recommendation X.21 *bis* and V-series) and also provides an efficient interface to the packet level for information and control exchange.

# **1.1 KEY FEATURES**

Key features of the XPC include:

- Fully Implements X.25 Recommendation LAPB Procedure by Independently Generating Link Level Commands and Responses
- Option to Implement X.75 Recommendation
- Optional Transparent Operation (Monitor Mode) where XPC Provides HDLC/SDLC Framing Functions for User Generated Frames
- Performs DMA Transfer of Information Frames to and from Memory Using Two On-Chip 22-Byte FIFOs
- Primary Communication through Shared Memory Structures with a Powerful Command Set to Off-Load Data Link Management
- Flexible Rx/Tx Linked Memory Structures Minimize Host Intervention and Simplify Memory Management
- Basic (Modulo 8) and Extended (Modulo 128) Operation
- Automatic Comparison of the Programmable Local and Remote Addresses
- Detection of Programmable Timeout and Retries Limit Conditions

- 16- or 32-Bit CRC Generation and Checking
- Standard Modem Interface
- NRZ or NRZI Encoding/Decoding
- Vectored Interrupts and Status Reporting
- Built-In Diagnostics Provide Local Loopback and External Loopback Testing
- Up to 10-Mbps Synchronous Serial Data Rate
- 12.5- and 10-MHz System Clock Versions
- 8- and 16-Bit Data Bus Support
- 32-Bit Address Bus with Virtual Address Capability
- M68000 Family Asynchronous Bus Structure
- Programmable Byte Ordering of Data for Alternate Memory Organization Schemes

## **1.2 GENERAL DESCRIPTION**

The XPC supports high-speed X.25 communications between host computers, between host computers and remote units, and between remote units. The XPC also supports a transparent operation mode which does not apply the LAPB procedure. Data is passed between the XPC and the host processor through shared memory structures. This permits a minimum command set for host processor/XPC communication. Additionally, the XPC is a full MC68000 bus master, providing on-chip DMA capability for management of memory tables and frame buffers. Since the XPC data bus interface is configurable, the XPC can handle both 8-bit and 16-bit data transfers.

When the X.25 mode is selected by the user, the XPC is configured as a combined station for full-duplex point-to-point communication. The XPC supports a nonoperational mode and two operational modes as defined by the LAPB procedure. The nonoperational mode is asynchronous disconnect mode (ADM). In this balanced data link mode, the combined station is logically disconnected from the data link and is not permitted to transmit or accept information. Operational modes include asynchronous balanced data link and asynchronous balanced mode (ABM).

1

allows a combined station to send a command or initiate a response frame transmission without receiving explicit permission from the other station. In ABM/ABME the XPC performs the following operations:

- 1. Transmission of a chain of information (I) frames when instructed by the host,
- 2. Transmission of supervisory (S) frames as defined by the X.25 LAPB Recommendation,
- 3. Transmission of unnumbered (U) commands as required or when instructed by host, and
- 4. Transmission of unnumbered (U) responses as defined by the X.25 LAPB Recommendation.

When the transparent mode is selected, the XPC can be configured as a primary, a secondary, or a combined station for full-duplex operation. The XPC can support any HDLC/SDLC-defined operational mode. All frames are user-generated and are transmitted only when instructed by the host.

A typical system configuration using the XPC with a M68000 Family MPU is shown in Figure 1-1. A block diagram of the MC68605 is shown in Figure 1-2.



Figure 1-1. XPC System Configuration



Figure 1-2. MC68605 Block Diagram

## **1.3 X.25 FRAME DESCRIPTION**

Before looking in detail at the modes of operation, internal registers of the XPC, commands, and the shared memory structures, a quick review of the X.25 frame structure will be covered. There are three types of X.25 frame formats. These are the information (I) frame, supervisory (S) frame, and unnumbered (U) frame. Information frames transfer data between the network nodes. Supervisory frames pass data link supervisory and control information, such as information frame reception acknowledgement, retransmission of information frame requests, and temporary information frame transmission suspension requests. Unnumbered frames provide additional data link control functions. Although the unnumbered frame format contains no sequence numbers, the format does contain a poll/final bit to request a response frame.

The beginning and end of an X.25 frame is identified by a flag sequence of 01111110. The XPC transmits a minimum of two flags between frames.

The XPC permits sharing of the flag sequence for back-to-back frames.



The XPC also permits a shared zero within the two flag sequences for back-to-back frames.



The address field identifies a frame as either a command or a response. An XPC-generated command frame contains the remote address. An XPC-generated response frame contains the local station address.

| FRAME TYPE  | ADDRESS FIELD  |
|-------------|----------------|
| Rx Command  | Local Address  |
| Rx Response | Remote Address |
| Tx Command  | Remote Address |
| Tx Response | Local Address  |

X.25 defines an extended and basic frame format. These formats are shown in Figure 1-3. The difference between the extended and basic control format is the length of the control field. The basic control field contains eight bits and the extended control field contains 16 bits. Unnumbered frames always have 8-bit control fields. The extended control field format allows a maximum of 127 outstanding frames (Modulo 128) on the line; whereas, the basic control field format provides a limit of seven outstanding frames (Modulo 8). Figure 1-4 shows the basic control field format for X.25 I, S, and U frames, and Figure 1-5 shows the extended control field format for I, S, and U frames. Address, commands, responses, and sequence numbers are transmitted beginning with the low-order bit. For example, the sequence number bit with the weight 2° is transmitted first. Within the information field, the XPC transmits the low-order bit of the low-order data byte first, regardless of the organization of data in memory. The FCS is transmitted beginning with the coefficient of the highest order exponential term.

The various commands and responses defined for the three X.25 frame types are shown in Figure 1-6. Figure 1-7 illustrates which X.25 frame types are host generated.



NOTES:

1. XPC information field limited to 64K bytes.

2. XPC also provides optional 32-bit FCS.

3. Unnumbered frames have an 8-bit control field in extended mode.

#### Figure 1-3. X.25 Frame Formats

|            |   |       |      | BIT C | RDER |      |   |   |
|------------|---|-------|------|-------|------|------|---|---|
| FRAME TYPE | 1 | 2     | 3    | 4     | 5    | 6    | 7 | 8 |
| I FRAME    | 0 |       | N(S) |       | Р    | N(R) |   |   |
| S FRAME    | 1 | 0 S S |      |       | P/F  | N(R) |   |   |
| U FRAME    | 1 | 1     | М    | м     | P/F  | м    | М | М |

N(S) — Transmitting Station Send Sequence Number

N(R) — Transmitting Station Receive Sequence Number

S — Supervisory Function Bits

M — Modifier Function Bits

P/F — Poll/Final: Poll Bit for Command Frames Final Bit for Response Frames

#### **Figure 1-4. Basic Control Format**

|            |   | BIT ORDER |   |   |     |   |   |   |     |        |      |    |    |    |    |    |
|------------|---|-----------|---|---|-----|---|---|---|-----|--------|------|----|----|----|----|----|
| FRAME TYPE | 1 | 2         | 3 | 4 | 5   | 6 | 7 | 8 | 9   | 10     | 11   | 12 | 13 | 14 | 15 | 16 |
| I FRAME    | 0 | N(S)      |   |   |     |   | Р |   |     |        | N(R) |    |    |    |    |    |
| S FRAME    | 1 | 0         | S | S | Х   | Х | х | х | P/F | F N(R) |      |    |    |    |    |    |
| U FRAME    | 1 | 1         | М | м | P/F | м | М | м |     |        |      |    |    |    |    |    |

N(S) — Transmitting Station Send Sequence Number

N(R) — Transmitting Station Receive Sequence Number

S — Supervisory Function Bits

M — Modifier Function Bits

P/F --- Poll/Final: Poll Bit for Command Frames

Final Bit for Response Frames

X — Reserved and Set to Zero

### Figure 1-5. Extended Control Format

COMMANDS

RESPONSES

INFORMATION

T

## (a) Sequenced Information

|     | COMMANDS          |     | RESPONSES         |
|-----|-------------------|-----|-------------------|
| RR  | RECEIVE READY     | RR  | RECEIVE READY     |
| RNR | RECEIVE NOT READY | RNR | RECEIVE NOT READY |
| REJ | REJECT            | REJ | REJECT            |

# (b) Supervisory Format

|               | COMMANDS                                                                     |                  | RESPONSES                                                     |
|---------------|------------------------------------------------------------------------------|------------------|---------------------------------------------------------------|
| SABM<br>SABME | SET ASYNCHRONOUS BALANCED MODE<br>SET ASYNCHRONOUS BALANCED MODE<br>EXTENDED |                  |                                                               |
| DISC          | DISCONNECT                                                                   |                  |                                                               |
|               |                                                                              | UA<br>DM<br>FRMR | UNNUMBERED ACKNOWLEDGEMENT<br>DISCONNECT MODE<br>FRAME REJECT |

## (c) Unnumbered Format

Figure 1-6. Commands and Responses



Figure 1-7. X.25 Frame Originate

1

# SECTION 2 XPC IMPLEMENTATION OF LAPB PROCEDURE

This section describes the procedures used by the XPC in the X.25 mode to implement the LAPB procedure.

# 2.1 INITIALIZATION PROCEDURE

The XPC enters the initialization procedure as the result of a hardware or software reset. During this initialization, the station table address and function code (FC), system configuration information, and the XPC interrupt vector should be loaded by the XPC under the direction of the host, as shown in the sample program below. The internal XPC registers directly accessed during the initialization procedure are the command register (CR), data register (DR), interrupt vector register (IV), and semaphore register (SR).

RESET

| Repeat: Read Semaphore Register Until it is "FF" | Repeat: | Read | Semaphore | Register | Until | it is | s "FF" |
|--------------------------------------------------|---------|------|-----------|----------|-------|-------|--------|
|--------------------------------------------------|---------|------|-----------|----------|-------|-------|--------|

Write CR: Set Hardware Configuration

- Repeat: Read Semaphore Register Until it is "FF"
- Write CR: Set Station Configuration

Repeat: Read Semaphore Register Until it is "FF"

- Write DR: 4-Bit Function Code Value for Station Table Access
- Write CR: Load Function Code
  - Repeat: Read Semaphore Register Until it is "FF"
- Write DR: 32-Bit Address of Station Table
- Write CR: Load Station Table Pointer (STP)
  - Repeat: Read Semaphore Register Until it is "FF"
- Write IV: Interrupt Vector
- Write CR: Load Station Table Parameters

Repeat: Read Semaphore Register Until it is "FF"

Note that the XPC will not come out of hardware or software reset without the system clock and the transmit clock. The transmit clock is used to initialize the serial section of the chip.

When the XPC receives a SABM/SABME command frame from the remote station and the XPC can enter the information transfer phase, the XPC transmits an unnumbered acknowledge (UA) response frame, clears its internal V(R) and V(S) state variables in the V(R) and V(S) frame sequence registers respectively, and (re)enters operational mode. If a SABM/SABME command frame is received and the XPC cannot enter the information transfer phase, the XPC transmits a DM response and considers that the link is not set up.

When the link setup procedure is initiated as a result of a host processor command or link exception, the XPC begins by transmitting a SABM or SABME command frame, based on the value of the extended control (ECNT) bit in the station configuration register. The XPC also starts timer T1 to determine when the programmed time permitted for a reply to be received has elapsed and zeros the retries count register.

# 2.2 LINK SETUP PROCEDURE

Upon completion of the initialization routine, the XPC may be connected to the link. The XPC enters connect mode by executing a start link command from the host processor or by receiving a set asynchronous balanced mode/ set asynchronous balanced mode extended (SABM/SABME) command frame from the remote station. The XPC never transmits an unsolicited disconnect mode (DM) response frame to request the remote station to initiate link setup.

When the XPC receives a SABM/SABME command frame from the remote station and the XPC can enter the information transfer phase, the XPC transmits an unnumbered acknowledge (UA) response frame, clears its internal V(R) and V(S) state variables in the V(R) and V(S) frame sequence registers respectively, and (re)enters operational mode. If a SABM/SABME command frame is received and the XPC cannot enter the information transfer phase, the XPC transmits a DM response and considers that the link is not set up.

When the link setup procedure is initiated as a result of a host processor command or link exception, the XPC begins by transmitting a SABM or SABME command frame, based on the value of the extended control (ECNT) bit in the station configuration register. The XPC also starts timer T1 to determine when the programmed time permitted for a reply to be received has elapsed and zeros the retries count register.

Upon reception of a UA response frame, the XPC resets its frame sequence registers V(R) and V(S), stops timer T1, and enters operational mode. Alternately, upon reception of a DM response, the XPC will stop timer T1 and consider that the link is not set up. Frames other than UA, DM, SABM/SABME,

and disconnect (DISC) will be ignored. The reception of SABM/SABME or DISC is a collision on unnumbered command frames as discussed in **2.3 COLLISION OF UNNUMBERED COMMANDS**.

If timer T1 expires before reception of an UA response frame from the remote station, the XPC retransmits the SABM/SABME command frame, restarts timer T1, and increments the retries count register. If the retries count register becomes equal to the retries limit register, the XPC stops the link setup procedure and reports the status to the host processor.

# 2.3 COLLISION OF UNNUMBERED COMMANDS

If the sent and received unnumbered command frames are the same, the XPC and the remote station send a UA response at the earliest opportunity. The XPC then enters the indicated operational mode, after receiving the UA responses from the remote.

If the sent and received unnumbered command frames are different, the XPC and the remote station enter the asynchronous disconnect mode. A DM response frame is transmitted by both stations at the earliest opportunity.

# 2.4 INFORMATION FRAME TRANSMISSION

After the XPC enters asynchronous balanced mode (ABM) or asynchronous balanced mode extended (ABME), the host processor can instruct the XPC to transmit a chain of information frames by issuing the load transmit table pointer command. In response, the XPC loads the transmit table pointer and the transmit table function code from the station table into its internal registers. Next, the XPC loads the first transmit buffer pointer, transmit buffer function code, and transmit buffer count from the transmit frame specification table into the corresponding XPC registers. New the XPC is ready to build the first frame.

The remote address is copied from the remote address register into the XPC transmit FIFO. Next, the control field is generated internally and placed in the FIFO. The information field pointed to by the transmit buffer pointer register is then read from the memory buffer into the transmit FIFO until the transmit buffer count is satisfied. A frame check sequence is attached to complete the frame. Zero insertion is performed throughout the transmission. After frame transmission, V(S) is incremented and timer T1 is started (if it is not already running).

This transmission sequence repeats for each frame until the end of the transmit chain is reached or until the outstanding frames limit is reached. The XPC continues to transmit any available information frames even when the XPC receiver is in the busy condition. The XPC prematurely terminates frame transmission if a stop link command interrupts the information frame transmission or an error condition arises.

Transmission begins when six bytes are present in the transmit FIFO. Transmission can begin when less than six bytes are present in the FIFO, if the entire frame is less than six bytes in length. Between frames, the XPC transmits the user-selected number of pad flags. Additional pad flags are transmitted if the required number of bytes is not present in the transmit FIFO for transmission to begin. While transmitting an information frame, the XPC requests the bus when there are at least six empty bytes in the transmit FIFO.

# 2.4.1 Receiving Acknowledgement

When the XPC correctly receives an I frame or an S frame, the sequence number N(R) contained in the control field of this frame will acknowledge all I frames previously transmitted with sequence numbers up to and including the received N(R) – 1. The XPC stops timer T1 when it correctly receives an N(R) higher than the last received N(R), which acknowledges some I frames, or when the XPC receives a REJ frame with the N(R) equal to the last received N(R). If timer T1 is stopped by the reception of an I, RR, or RNR frame and there are outstanding I frames still unacknowledged, the XPC will restart timer T1.

# 2.4.2 Waiting Acknowledgement

Timer T1 is started after a frame has been transmitted to check that an acknowledgement for the frame is received before the programmed timeout value is reached. If timer T1 expires while waiting for acknowledgement from the remote station, the XPC will enter the timer recovery condition. The XPC will send a receive ready (RR) with the poll (P) bit set to one if receive buffers are available or receive not ready (RNR) with the P bit set to one if no receive buffers are available. The XPC then increments the retries count register and restarts timer T1.

If timer T1 expires while in the timer recovery condition, the XPC will increment the retries count register, restart timer T1, and transmit the appropriate supervisory command frame with the P bit set to one. If the retries count register becomes equal to the retries limit register, the XPC will initiate a link resetting procedure as described in **2.2 LINK SETUP PROCEDURE**.

If, while in the timer recovery condition, the XPC correctly receives a S frame with the P/F bit set to zero and with a valid N(R), the timer recovery condition is not cleared. The XPC will use the incoming N(R) to acknowledge previously transmitted I frames. If, while in the timer recovery condition, the XPC correctly receives a S frame with the P/F bit set to zero or an I or S frame with the P bit set to one and with the N(R) equal to the value of V(S) (acknowledging all transmitted I frames), the XPC will not clear the timer recovery condition nor stop timer T1.

Furthermore, if the received S frame is a REJ frame with the P/F bit set to zero and with a valid N(R), the XPC will ignore the retransmission request and wait for a supervisory frame with the F bit set to one. If the received S frame is a REJ frame with the P bit set to one and with a valid N(R), the XPC will immediately transmit an appropriate supervisory response frame with the F bit set to one. The request for retransmission is ignored until the XPC receives a S frame with the F bit set to one.

When the XPC receives a supervisory frame with the F bit set to one and with the N(R) within the range from the value of the last received N(R) to the current value of the send state variable V(S) inclusive, then the XPC stops timer T1, sets its send state variable to the value of the received N(R), updates the transmit table pointer register to point to the appropriate transmit table block, and exits timer recovery mode. The XPC will resume I frame transmission or retransmission, as appropriate.

# 2.4.3 Receiving an REJ Frame

When a REJ frame is received, the XPC compares its send state variable V(S) to the N(R) in the control field of the received REJ frame. If the N(R) in the received REJ frame is equal to V(S), the XPC transmits the corresponding I frame when it is available. If the received N(R) is less than V(S), the XPC will begin sequential retransmission of the specified frame(s), according to the X.25 Recommendation. If the REJ frame received from the remote station is a command frame with the P bit set to one, the XPC will transmit a RR, RNR, or REJ response with the F bit set to one before (re)transmitting the requested I frame(s).

## 2.4.4 Receiving an RNR Frame

When a RNR frame is received, the XPC waits for timer T1 to expire and then transmits a supervisory command frame with the P bit set to one. Timer T1 is then started to determine if there is any change in the receive status of the remote station. If the remote station responds with a RNR supervisory' response frame with the F bit set to one, indicating the continuance of the busy condition, the XPC repeats the above sequence the user-specified number of times (retries limit) and then initiates link reset. If the remote station responds with a RR or REJ frame, indicating the clearance of the busy condition, the XPC stops timer T1 and begins (re)transmission as appropriate.

# 2.5 INFORMATION FRAME RECEPTION

The host processor enables information reception by instructing the XPC to load receive table pointer. The XPC will load the receive table pointer and function code into its internal registers. Next, the receive buffer pointer and function code and the receive buffer count are loaded into the corresponding XPC registers. The XPC is now ready to receive information frames.

The address field of an incoming I frame is compared to the local address register and the remote address register. If the address does not match the local or remote address, the frame is ignored. If the address field matches the remote address, a frame reject (FRMR) is transmitted and the W (invalid or unimplemented control field) bit of the frame reject descriptor register (FRD) is set. If the address field matches the local address, the frame is accepted by the XPC, and the received N(R) acknowledges previously transmitted I frames.

Next, the send sequence number N(S) of the incoming frame is compared to the XPC internal receive state variable V(R). If the frame is in sequence, then the information field is transferred through the receive FIFO to the receive memory buffer. Out-of-sequence frames are rejected.

Lastly, the XPC performs a CRC check on the incoming information frame. If an error-free frame is received, the XPC acknowledges the frame reception with a supervisory frame (RR or RNR) or with an updated N(R) in the next information frame.

Zero deletion is performed throughout the reception process. The XPC requests the bus when there are six bytes in the receive FIFO. Only a single frame can reside in the receive FIFO. Frames are received in sequence as long as memory buffers are available.

2-6

# 2.5.1 Invalid Frame Condition

Invalid frames are discarded. An invalid frame is defined as a frame that:

- 1. Is not properly bounded by two flags,
- Contains fewer than 32/48 bits between flags in modulo 8 operation (basic) with 16-/32-bit CRC, contains fewer than 40/56 bits between flags for frames with sequence numbers in modulo 128 (extended) operation with 16-/32-bit CRC, or contains fewer than 32/48 bits between flags for frames without sequence numbers in modulo 128 operation with 16-/ 32-bit CRC,
- 3. Contains a FCS error, or
- 4. Contains an address other than the local or remote station address.

The XPC does provide a means to accept frames with CRC error test/diagnostic purposes. If the CRC bypass option (CRCNOA) bit in the option bits register is set to one, then a frame containing a CRC error will be accepted. If the CRCNOA bit is set to zero and a frame is received with a CRC error, the XPC ignores the frame, and receive buffer will be reused for the next frame.

## 2.5.2 Receiving an Out-of-Sequence | Frame

When the XPC receives a valid I frame whose send sequence number N(S) is not equal to the internal receive state variable V(R), the information field will be discarded. The XPC transmits an REJ frame with the N(R) field set equal to V(R) to initiate retransmission, beginning with the next expected frame. Only one REJ condition is established at a time. A REJ condition is cleared when the requested I frame is received.

# 2.5.3 Frame Reject Mode

The XPC enters the frame reject mode (FRMR) on reception of an error-free frame and the frame contains:

- 1. Unimplemented or illegal control field/unrecognized frame/nonzero "X" bits in the control field (extended control, S frame),
- 2. Supervisory frame or unnumbered frame with an information field which is not permitted,

- 3. Invalid N(R), or
- 4. Information field too long to fit the available memory buffer.

If the X.75 option is selected (bit 8 in the option bits register is set), then the XPC will also enter frame reject mode on reception of the following:

- A supervisory frame with the F bit set to one, except during a timer recovery condition or except as a reply to a command sent with the P bit set to one,
- 2. An unexpected UA or DM response, or
- 3. An information frame with an invalid N(S).

Once the XPC sends the FRMR response frame, no additional information or supervisory frames are accepted until the FRMR condition is cleared. The XPC stops all information frame transmission activities and updates status information held in the station table, which includes the reason for the FRMR response.

The XPC monitors the poll/final (P/F) bit of all incoming frames. When a frame is received with the P bit set to zero or when T1 expires, the XPC sends a FRMR response again with the F bit set to zero. If the received frame has a P bit set to one, the XPC responds with the FRMR frame with the F bit set to one. If the retries count register becomes equal to the retries limit register before the FRMR condition is cleared, the XPC will initiate the link resetting procedure described in **2.2 LINE SETUP PROCEDURE**. The XPC also initiates link reset when a FRMR response frame is received.

The FRMR condition is cleared when the XPC receives or transmits a SABM/ SABME or DISC command or a DM response. Upon receiving a SABM/SABME or DISC command frame, the XPC sends an UA response and enters the indicated operation mode. The XPC also clears both internal state variables and disables the transmit table pointer register, so that the host processor must reload this register to resume transmission. If a DM or FRMR response frame is received, the XPC initiates link setup by transmitting SABM/SABME. The XPC also writes the received FRMR information field to the station table and updates status. The XPC transmits a DISC command frame to clear the FRMR condition only as the result of a stop link command from the host.

2

# 2.5.4 Idle Channel Condition

When the XPC detects a channel idle condition of at least 15 consecutive ones, it reports the channel idle status to the host processor. The XPC does not implement timer T3 as described in 1984 CCITT X.25 Recommendation, which would allow the detection of excessive idle periods. This timer must be implemented by higher layer software, if desired.

# 2.5.5 Busy Condition

The XPC enters the busy condition when it is unable to continue to receive I frames due to internal constraints, such as receive buffer limitations. A RNR frame is transmitted at the earliest opportunity. I frames pending transmission by the XPC are transmitted prior to and following the RNR frame. The XPC clears the busy condition following a load RTP command from the host.

# 2.6 DISCONNECT MODE

The XPC enters asynchronous disconnect mode (ADM) when:

- 1. Initialization of the XPC is complete,
- 2. The XPC transmits an UA response after receiving a DISC command from the remote station,
- 3. The XPC receives a DM with F set to one or a UA response after transmitting a DISC command,
- 4. The XPC receives a DM with F set to one response after transmitting a SABM/SABME command,
- 5. The retries limit is reached during the link setup or link disconnect procedures, or
- 6. DISC and SABM/SABME command frames collide.

In disconnect mode, the XPC initiates link setup after receiving a start link command from the host processor. If the XPC receives a DISC command frame, it transmits a DM response and remains in disconnect mode. If the XPC receives a SABM/SABME command frame from the remote station, an UA response is transmitted. When any other command frame is received with the P bit set to a one, the XPC transmits a DM response with the F bit set to one. Other frames received while in disconnect mode are ignored.

# 2.7 LINK DISCONNECT PROCEDURE

The XPC initiates a link disconnect by transmitting a DISC command frame and starting timer T1. All received frames, except SABM/SABME or DISC commands and UA or DM responses, are ignored. Upon reception of a UA response frame, the XPC enters disconnect mode and reports its status to the host processor. Upon reception of a DM response with F set to one from the remote station, indicating that the remote station is already in the disconnect mode, the XPC stops timer T1 and enters the disconnect mode. The reception of an SABM/SABME or DISC command frame is considered a collision situation that is resolved as described in **2.3 COLLISION OF UNNUM-BERED COMMANDS**.

If timer T1 expires before reception of a UA or DM with F set to one response frame from the remote station, the XPC retransmits the DISC command frame, restarts timer T1, and adds one to the retries count register. If the retries count register becomes equal to the retries limit register, the XPC stops the link disconnect procedure, enters disconnect mode, and reports its status to the host processor.

#### 2.8 STATE TABLE

The state table (see Figure 2-1 found on a foldout page at the back of this document) defines the various XPC states based on command frames received (no errors), response frames received (no errors), and miscellaneous inputs received. For example, referring to Figure 2-1, if the command frame received was a RR with the P bit set to one while in the remote station busy condition (state 9), then the XPC responds with RR with F set to one and changes to information transfer (state 5).

# SECTION 3 XPC TRANSPARENT MODE OF OPERATION

The XPC transparent mode of operation can be used to implement a variety of bit oriented protocols. This section describes the XPC transparent mode of operation.

# 3.1 INITIALIZATION PROCEDURE

The XPC enters the initialization procedure as the result of a hardware or software reset. During initialization, the station table address and function code, system configuration information, and the XPC interrupt vector should be loaded by the XPC under the direction of the host, as shown in the following sample program:

#### RESET

Repeat: Read Semaphore Register Until it is "FF" Write CR: Set Hardware Configuration Repeat: Read Semaphore Register Until it is "FF" Write CR: Set Station Configuration Repeat: Read Semaphore Register Until it is "FF" Write DR: 4-bit Function Code Value for Station Table Access Write CR: Load Function Code Repeat: Read Semaphore Register Until it is "FF" Write DR: 32-bit Address of Station Table Write CR: Load Station Table Pointer (STP) Repeat: Read Semaphore Register Until it is "FF" Write IV: Interrupt Vector Write CR: Load Preset Values Repeat: Read Semaphore Register Until it is "FF"

Note that the XPC will not come out of hardware or software reset without the system clock and the transmit clock. The transmit clock is used to initialize the serial section of the chip.

When function codes are not implemented in the system, the host is not required to load the station table function code into the data register and then issue a load FC command. Function codes are usually found in virtual memory systems. Function codes divide memory into user data, user program, supervisor data, and supervisor program spaces. The XPC provides the user-specified function codes during XPC DMA cycles. However, the XPC performs no checking on the validity of the function code values.

During transparent operation, the following registers are not used and do not need to be initialized in the station table.

| Option Bits Register     | Word 0             |
|--------------------------|--------------------|
| Time Out Preset          | Word 1             |
| Time Scale Divider       | Word 2 — high byte |
| Outstanding Frames Limit | Word 3 — high byte |
| Retries Count            | Word 3 — low byte  |
| Local Address            | Word 8 — low byte  |
| Remote Address           | Word 9 — low byte  |

Once the initialization process is complete, the XPC is disconnected. The host can write commands to the XPC. However, it is always necessary to check the semaphore register for "FF" to ensure that the XPC is ready to accept the next command. The load addresses command should not be issued to the XPC, since, after the load addresses command, the XPC monitors the RxD line and could respond to a received SABM and enter X.25 operation.

### 3.2 ENTERING TRANSPARENT OPERATION

Transparent operation is entered when the host issues the monitor command. After the monitor command, the XPC asserts  $\overline{\text{RTS}}$ , transmits flags, and monitors RxD. Since handshaking between nodes is not possible before the monitor command is executed, the host processor at each node must issue the monitor command in order for the two nodes to communicate.

The V(S) and V(R) registers are zeroed upon entering transparent operation. During transmission and reception of frames, the V(S) and V(R) registers are incremented modulo 8 or modulo 128 depending on the ECNT (extended control) bit in the station configuration register. V(S) and V(R) are incremented regardless of frame type. User-generated control fields may be any length since the XPC does not analyze the address and control fields of transmitted and received frames.

The following eleven commands are valid during transparent operation:

Load RTP Load TTP Continue Transmit Clear Tx/Link Status Clear Rx/Host Status Clear Status Update Status Dump Parameters Dump Registers End Monitor Reset

After executing the dump parameters command or the dump registers command in transparent operation, the following locations in the station table and dump area are not valid:

| Frame Reject Descriptor         | Word 21 — low byte   | station table |
|---------------------------------|----------------------|---------------|
| First Unacknowledged Pointer    | Words 24 and 25      | station table |
| Received FRMR Information Field | Words 38, 39, and 40 | station table |
| Local Address                   | Word 14 — low byte   | dump area     |
| Remote Address                  | Word 15 — low byte   | dump area     |
| Frame Reject Descriptor         | Word 16 — low byte   | dump area     |
| Time Out Preset                 | Word 20              | dump area     |
| Outstanding Frames Limit        | Word 21 — high byte  | dump area     |
| Retries Limit                   | Word 21 — low byte   | dump area     |
| Last Received N(R)              | Word 22 — high byte  | dump area     |
| Retries Count                   | Word 22 — low byte   | dump area     |
|                                 |                      |               |

### 3.3 FRAME TRANSMISSION

After the monitor command is issued, the XPC begins transmission of frames only after receiving a load transmit table pointer command from the host. All frames are user-generated and may contain user-provided address, control, and data fields or may contain only a data field. After the host issues the load transmit table pointer command, the XPC loads the transmit table pointer and the transmit table function code from the station table into its internal registers. Next, the XPC loads the first transmit buffer pointer, transmit buffer function code, and transmit buffer count from the transmit frame specification table into the corresponding XPC registers. Now the XPC is ready to transmit the first frame.

The frame pointed to by the transmit buffer pointer register is read from the memory buffer into the transmit FIFO until the transmit buffer count is satisfied. An XPC-generated frame check sequence is then attached to complete the frame. After each frame transmission, the internal V(S) register is incremented without regard to the frame type. This transmission sequence repeats for each frame until the end of the transmit chain is reached. Zero insertion is performed throughout the transmission process.

In transparent operation, the XPC transmits frames until the end of the transmit specification table is reached. After the last byte of the last frame is loaded into the Tx FIFO, the XPC sets the IFAK (information frames acknowledged) bit in the Tx/link status register to indicate the end of the transmit table. The XPC also clears the TBEN (transmit buffer enable) and then sets the NEWMD (new mode) bit in the Tx/link status register. The XPC does not analyze any incoming frames for acknowledgments or link control information during transparent operation. The only errors reported in the Tx/link status register are address error, bus error, clear-to-send lost, and underrun.

Note that frames can be added to the transmit queue dynamically as the XPC is transmitting. After adding entries to the end of the transmit queue, the host must set the EOT bit in the last added entry and clear the EOT bit at the previous end of table. If the XPC has already read the EOT bit, then the added entries will not transmitted. In this case, the continue transmit command should be issued to XPC.

Transmission begins when six bytes are present in the transmit FIFO. Transmission can begin when less than six bytes are present in the FIFO if the entire frame is less than six bytes in length. Between frames, the XPC transmits the user-selected number of pad flags. Additional pad flags are transmitted if the required number of bytes are not present in the transmit FIFO for transmission to begin. While transmitting a frame, the XPC requests the bus when there are at least six empty bytes in the transmit FIFO.

### **3.4 FRAME RECEPTION**

The host processor enables frame reception by instructing the XPC to load receive table pointer. The XPC then loads the receive table pointer and function code into its internal registers. Next, the receive buffer pointer and function code and the receive buffer count are loaded into the corresponding XPC registers. The XPC is now ready to receive frames.

The XPC does not analyze the address and control fields of incoming frames, but does perform a CRC check on incoming frames. After the flags are stripped off, the entire frame, including CRC, is written into the current receive buffer, and the RXI (received information frame) bit is set in the Rx/host status register. If a frame is received that is nonoctet aligned or that has a CRC

3

error, the XPC sets the E bit in that frame's receive specification block. The shortest frame that can be received is two bits. Note that CRC checking cannot be performed on frames shorter than 16 bits, and no CRC error indication will be given.

To set the E bit, the XPC writes the receive status and receive buffer function code bytes. The L(link) bit is written as zero, regardless of its previous state. The EOT bit and FC bits are unchanged. Even though the link bit is cleared during the write cycle, the XPC has previously read its value, and the XPC will handle the linking operation normally. However, the user should not use the link bit value for his own routines. If no CRC error exists, the XPC does not write the receive status and receive buffer FC bytes. Therefore, the user must initialize the CRC error bit to zero. After a frame is received, the XPC increments V(R) without regard to frame type. Zero deletion is performed throughout the reception process.

In transparent operation, the XPC continues to receive frames until the end of the receive specification table is reached. The XPC then sets the RTE (receive table ended) bit in the Rx/host status register. The only errors reported in the Rx/host status register during transparent operation are buffer too short, no receive memory buffer available, undefined host command, illegal host command, address error, bus error, abort sequence, overrun, and receiver idle.

The XPC requests the bus when there are six bytes in the receive FIFO. Only a single frame can reside in the receive FIFO. Frames are received in sequence as long as memory buffers are available.

### 3.5 EXITING TRANSPARENT MODE

The transparent mode of operation is exited by issuing the end monitor command to the XPC. This will disable frame transmission and reception. There is no verification that the link is disconnected.

MOTOROLA

# SECTION 4 INTERNAL REGISTERS

The XPC has four functional blocks: serial, DMA, microcode controller, and register-file/ALU. Each section contains user-visible and nonvisible registers that define and control the operation of the XPC.

Because the XPC communicates with the host primarily through shared memory, a minimum number of host processor accessible registers are required. Registers in the XPC fall into two groups. One group is directly accessible by the user, and the other group is indirectly accessed through the station table. The directly accessible registers include the command register, semaphore register, interrupt vector register, and data register. The complete register set is shown in Table 4-1. A register map is shown in Figure 4-1.

| Register                      | Mnemonic | Mode         | Read By                           | Written By                  |  |  |  |  |  |  |
|-------------------------------|----------|--------------|-----------------------------------|-----------------------------|--|--|--|--|--|--|
| Directly Accessible           |          |              |                                   |                             |  |  |  |  |  |  |
| Command                       | CR       | Write        | Not Applicable                    | Host Processor              |  |  |  |  |  |  |
| Semaphore                     | SR       | Read         | Host Processor                    | Not Applicable              |  |  |  |  |  |  |
| Interrupt Vector              | IV       | Read/Write   | Host Processor (IACK)             | Host Processor              |  |  |  |  |  |  |
| Data                          | DR       | Write        | Not Applicable                    | Host Processor              |  |  |  |  |  |  |
|                               |          | Indirectly A | ccessible                         |                             |  |  |  |  |  |  |
| Station Table Pointer         | STP      | Write        | Not Applicable                    | Load Station Table Pointer  |  |  |  |  |  |  |
| Station Table Function Code   | STFC     | Write        | Not Applicable                    | Load Function Code          |  |  |  |  |  |  |
| Transmit Table Pointer        | ттр      | Read/Write   | Dump Registers<br>Dump Parameters | Load Transmit Table Pointer |  |  |  |  |  |  |
| Transmit Table Function Code  | TTFC     | Read/Write   | Dump Registers<br>Dump Parameters | Load Transmit Table Pointer |  |  |  |  |  |  |
| Transmit Buffer Pointer       | TBP      | Read/Write   | Dump Registers                    | Load Transmit Table Pointer |  |  |  |  |  |  |
| Transmit Buffer Function Code | TBFC     | Read/Write   | Dump Registers                    | Load Transmit Table Pointer |  |  |  |  |  |  |
| Transmit Buffer Count         | твс      | Read/Write   | Dump Registers                    | Load Transmit Table Pointer |  |  |  |  |  |  |
| Receive Table Pointer         | RTP      | Read/Write   | Dump Registers<br>Dump Parameters | Load Receive Table Pointer  |  |  |  |  |  |  |
| Receive Table Function Code   | RTFC     | Read/Write   | Dump Registers<br>Dump Parameters | Load Receive Table Pointer  |  |  |  |  |  |  |
| Receive Buffer Pointer        | RBP      | Read/Write   | Dump Registers                    | Load Receive Table Pointer  |  |  |  |  |  |  |
| Receive Buffer Function Code  | RBFC     | Read/Write   | Dump Registers                    | Load Receive Table Pointer  |  |  |  |  |  |  |
| Receive Buffer Count          | RBC      | Read/Write   | Dump Registers                    | Load Receive Table Pointer  |  |  |  |  |  |  |

Table 4-1. XPC Register Set (Sheet 1 of 2)

| Register                 | Mnemonic | Mode       | Read By                                            | Written By                                    |
|--------------------------|----------|------------|----------------------------------------------------|-----------------------------------------------|
|                          |          | Directly A | ccessible                                          |                                               |
| Local Address            | LA       | Read/Write | Dump Registers                                     | Load Addresses<br>Load Station Parameters     |
| Remote Address           | RA       | Read/Write | Dump Registers                                     | Load Addresses<br>Load Station Parameters     |
| Hardware Configuration   | нс       | Write      | Not Applicable                                     | Set Hardware Configuration                    |
| Station Configuration    | sc       | Write      | Not Applicable                                     | Set Station Configuration                     |
| Option Bits              | ОВ       | Write      | Not Applicable                                     | Load Station Parameters<br>Load Option Bits   |
| Mode Descriptor          | MD       | Read       | Dump Parameters<br>Dump Registers                  | Not Applicable                                |
| Frame Reject Descriptor  | FRD      | Read       | Dump Parameters<br>Dump Registers                  | Not Applicable                                |
| Rx/Host Status           | RHS      | Read/Write | Dump Parameters<br>Dump Registers<br>Update Status | Clear Rx/Host Status<br>Clear Status          |
| Tx/Link Status           | TLS      | Read/Write | Dump Parameters<br>Dump Registers<br>Update Status | Clear Tx/Link Status<br>Clear Status          |
| V(S)                     | V(S)     | Read       | Dump Parameters<br>Dump Registers                  | Not Applicable                                |
| V(R)                     | V(R)     | Read       | Dump Parameters<br>Dump Registers                  | Not Applicable                                |
| Time-Out Preset          | ТОР      | Read/Write | Dump Registers                                     | Load Preset Values<br>Load Station Parameters |
| Retries Limit            | RL       | Read/Write | Dump Registers                                     | Load Preset Values<br>Load Station Parameters |
| Outstanding Frames Limit | OFL      | Read/Write | Dump Registers                                     | Load Preset Values<br>Load Station Parameters |
| Time Scale Divider       | TSD      | Write      | Not Applicable                                     | Load Preset Values<br>Load Station Parameters |
| Pad Time Select          | PTS      | Write      | Not Applicable                                     | Load Preset Values<br>Load Station Parameters |
| Retries Count            | RC       | Read       | Dump Registers                                     | Not Applicable                                |
| Last Received N(R)       | LRN      | Read       | Dump Registers                                     | Not Applicable                                |

### Table 4-1. XPC Register Set (Sheet 2 of 2)

|          | D15 D           | 8         | D7    | D0 |  |  |
|----------|-----------------|-----------|-------|----|--|--|
| BASE     | UNUSED/RESERVED |           | CR/SR |    |  |  |
| BASE + 2 | UNUSED/RESERVED |           | IV    |    |  |  |
| BASE+4   | DR              | DR (HIGH) |       |    |  |  |
| BASE+6   | DR (LOW)        |           |       |    |  |  |
|          |                 |           |       |    |  |  |

### Figure 4-1. XPC Register Map

### 4.1 COMMAND REGISTER

The control interface between the XPC and the host processor is the command register (CR). This 8-bit register is written by the host processor to issue commands to the XPC. The 24 valid XPC commands are shown in Table 4-2. Each command is described in detail in **SECTION 6 COMMAND SET**.

Before the host processor writes to the XPC, the semaphore register must be checked to ensure that the XPC is ready to accept the next command. Passing the XPC an undefined command will set the undefined instruction bit (UDEF) in the Rx/host status register.

| Instruction                   |     | Bit |     |     |     |     |     |     | Hex   |
|-------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-------|
| instruction                   | IR7 | IR6 | IR5 | IR4 | IR3 | IR2 | IR1 | IR0 | Value |
| Load FC                       | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 80    |
| Load STP                      | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 81    |
| Load Option Bits              | 1   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 82    |
| Load Preset Values            | 1   | 0   | 0   | 0   | 0   | 0   | 1   | 1   | 83    |
| Load Addresses                | 1   | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 84    |
| Load Tx Table Pointer         | 1   | 0   | 0   | 0   | 0   | 1   | 0   | 1   | 85    |
| Load Rx Table Pointer         | 1   | 0   | 0   | 0   | 0   | 1   | 1   | 0   | 86    |
| Load Station Table Parameters | 1   | 0   | 0   | 0   | 0   | 1   | 1   | 1   | 87    |
| Update Status                 | 1   | 0   | 0   | 0   | 1   | 0   | 0   | 0   | 88    |
| Clear Tx/Link Status          | 1   | 0   | 0   | 0   | 1   | 0   | 0   | 1   | 89    |
| Clear Rx/Host Status          | 1   | 0   | 0   | 0   | 1   | 0   | 1   | 0   | 8A    |
| Clear Status                  | 1   | 0   | 0   | 0   | 1   | 0   | 1   | 1   | 8B    |
| Dump Parameters               | 1   | 0   | 0   | 0   | 1   | 1   | 0   | 0   | 8C    |
| Start Link                    | 1   | 0   | 0   | 0   | 1   | 1   | 0   | 1   | 8D    |
| Stop Link                     | 1   | 0   | 0   | 0   | 1   | 1   | 1   | 0   | 8E    |
| Dump Registers                | 1   | 0   | 0   | 0   | 1   | 1   | 1   | 1   | 8F    |
| DMA Transfer                  | 1   | 0   | 0   | 1   | 0   | 0   | 0   | 0   | 90    |
| Serial Loopback               | 1   | 0   | 0   | 1   | 0   | 0   | 0   | 1   | 91    |
| Monitor                       | 1   | 0   | 0   | 1   | 0   | 0   | 1   | 0   | 92    |
| End Monitor                   | 1   | 0   | 0   | 1   | 0   | 0   | 1   | 1   | 93    |
| Continue Tx                   | 1   | 0   | 0   | 1   | 0   | 1   | 0   | 1   | 95    |
| Reset                         | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | FF    |
| Set Station Configuation      | 1   | 0   | 1   | х   | м   | х   | М   | х   |       |
| Set Hardware Configuration    | 1   | 1   | 0   | М   | М   | х   | м   | м   |       |

Table 4-2. Valid Commands

 $X = Don't \ Care$ 

M = Modifier bits in the configuration commands:

Valid commands for set station configuration are hex A0-BF.

Valid commands for set hardware configuration are hex C0-DF.

All other command encodings are undefined/reserved.

#### MC68605 USER'S MANUAL

### 4.2 SEMAPHORE REGISTER

The 8-bit semaphore register (SR) is the mechanism by which the XPC indicates that it has completed the current processor command. The semaphore register is written by the XPC and read by the host processor. When a command is written to the XPC command register, the XPC indicates that it has accepted the command by setting the semaphore register to 'FE'. After the completion of the command, the XPC sets this register to 'FE'. The host processor must read the semaphore register to ensure that it is 'FF' before writing a new command to the XPC. The semaphore register also allows the XPC and the host processor to share external memory without conflict.

### **4.3 INTERRUPT VECTOR REGISTER**

The interrupt vector register (IV) contains the 8-bit interrupt vector number which is presented to the system during an interrupt acknowledge cycle. The upper six bits of the vector are user programmable. The least significant two bits are generated internally by the XPC to provide a unique interrupt vector number corresponding to the specific interrupt source. These encodings are shown in the following table.

| IV1 | IV0 | Interrupt Source                                                                    |  |  |  |  |  |  |
|-----|-----|-------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 0   | 0   | Transmitter and Receiver                                                            |  |  |  |  |  |  |
| 0   | 1   | Receiver                                                                            |  |  |  |  |  |  |
| 1   | 0   | Transmitter                                                                         |  |  |  |  |  |  |
| 1   | 1   | BERR or AERR During a Station Table Ac-<br>cess or Default Vector Number ('0F' Hex) |  |  |  |  |  |  |

During reset the interrupt vector register is initialized to '0F' Hex by the XPC. If the interrupt vector register is not written by the host processor to specify a different interrupt vector prior to an interrupting condition, the XPC will pass a '0F' regardless of the interrupt source.

Three sources of internal interrupts are recognized by the XPC. These sources are the transmitter, the receiver, or both the transmitter and receiver. A fourth interrupt condition indicates that the XPC had a bus error (BERR) or address error (AERR) while accessing the station table.

Except when a BERR or AERR has occurred during a station table access, the XPC interrupt indicates to the host processor that the appropriate status word in the station table contains additional information about the specific interrupt condition. As part of the interrupt service routine to handle the XPC interrupt request, the host should set the appropriate bit(s) in the Rx/host and/or Tx/

link status clear locations in the station table. The host should then issue a clear Rx/host, clear Tx/link, or clear status command to cause the XPC to clear the corresponding internal status register bit(s) and the station table status bit(s).

A bus or address error during a station table access is a fatal condition, and the XPC will continue to generate an interrupt until a hardware or software reset is received.

### 4.4 DATA REGISTER

The 32-bit data register (DR) is accessed during initialization to load the station table pointer register and the station table function code register using a load STP or load FC command, respectively.

### 4.5 INDIRECTLY ACCESSIBLE REGISTERS

The remaining XPC registers are visible to the user but are not directly accessible. Commands issued to the XPC cause the XPC to load these registers from the station table or write these registers to the station table. Internal registers can also be written to a dump area in memory using the dump registers command.

### 4.5.1 Station Table Pointer Register

The 32-bit station table address is stored in the station table pointer register (STP). The STP is initialized as the result of a load STP command during initialization. A hardware or software reset clears this register.

### 4.5.2 Station Table Function Code Register

The station table function code register (STFC) holds the 4-bit function code value which may be required by the system to access the station table. This register is initialized after reset by the load FC command. A hardware or software reset clears this register.

### 4.5.3 Transmit Table Pointer Register

The 32-bit transmit frame specification table address is stored in the transmit table pointer register (TTP) (refer to Figure 4-2). Execution of the load TTP command loads the transmit table pointer, words 14 and 15 of the station table, into the transmit table pointer register. The TTP register is incremented as frames are transmitted to point to the current transmit frame specification block. The transmit table pointer location in the station table is not updated. After the entire information chain has been transmitted, the TTP register points to the first memory location following the end of the transmit frame specification table.

To allow the host to determine which frame the XPC is currently transmitting and which frames have been acknowledged, the host can issue a dump parameters command. The transmit pointer and the first unacknowledged pointer are written to the station table. The transmit pointer contains the current value of the transmit table pointer register, and the first unacknowledged pointer is based on the current value of the transmit table pointer register and the value of the last received N(R). The transmit table pointer register is written to the dump area by the dump registers command. The TTP is cleared by a hardware or software reset.



Figure 4-2. Transmit Registers

### 4.5.4 Transmit Table Function Code Register

The transmit table function code register (TTFC) contains the 4-bit function code value that may be required by the system to access the transmit table pointed to by the transmit table pointer register. The TTFC is loaded with the transmit table function code, word 13 in the station table, using the load TTP command. The TTFC register is written to the dump area by executing the dump registers command. A hardware or software reset clears this register.

### 4.5.5 Transmit Buffer Pointer Register

The transmit buffer pointer register (TBP) contains the 32-bit address of the current transmit buffer. The transmit buffer pointer register is autoincremented as the data in the buffer is transmitted until the count in the buffer length location of the current transmit frame specification block is reached. The TBP register is first loaded from the buffer address location of the transmit frame specification block using the load TTP command. The TBP register is then loaded automatically by the XPC to access each frame buffer until the end of the transmit frame specification table is reached. This register is written to the dump area by executing the dump registers command. The TBP is not cleared by a hardware or software reset.

### 4.5.6 Transmit Buffer Function Code Register

The transmit buffer function code register (TBFC) contains the 4-bit function code value that may be required to access the transmit buffer pointed to by the transmit buffer pointer register. The TBFC is loaded from the buffer function code location of the transmit frame specification block pointed to by the transmit table pointer register. This register is first loaded by the load TTP command. The TBFC is then loaded automatically by the XPC to access each frame buffer until the end of the transmit frame specification table is reached. The TBFC is written to the dump area by the dump registers command. The TBFC is not cleared by a hardware or software reset.

### 4.5.7 Transmit Buffer Count Register

The transmit buffer count register (TBC) is a 16-bit register that contains the number of bytes to be transmitted from the transmit buffer pointed to by the transmit buffer pointer register. As the information is transmitted, the XPC autodecrements the TBC until the count is zero. The TBC is loaded from the buffer length location in the transmit frame specification block pointed to by the transmit table pointer register. The TBC is first loaded by executing the load TTP command. This register is then loaded automatically by the XPC for each frame buffer until the end of the transmit frame specification table is reached. The dump registers command causes the TBC to be written to the dump area. The TBC is not cleared by a hardware or software reset.

### 4.5.8 Receive Table Pointer Register

The receive table pointer register (RTP) contains the 32-bit address of the receive frame specification table (refer to Figure 4-3). The value in the receive table pointer location, words 11 and 12 in the station table, is loaded into the RTP by executing the load RTP command. The receive table pointer register is incremented as frames are received to point to the current receive frame specification block. The receive table pointer location in the station table is not updated as frames are received. However, the host can determine the next receive pointer by issuing a dump parameters command. The XPC writes the current value of the receive table pointer register to the next receive table pointer location in the station table to allow the host to determine which receive buffers contain information. After the end of the receive frame specification table has been reached, the RTP points to the first memory location following the end of the receive frame specification table.

The receive pointer is written to the station table by a dump parameters command. The dump registers command causes the RTP to be written to the dump area. A hardware or software reset clears the RTP register.



Figure 4-3. Receive Registers

### 4.5.9 Receive Table Function Code Register

The receive table function code register (RTFC) contains the 4-bit function code that may be required by the system to access the receive table pointed. to by the receive table pointer register. This register is loaded by execution of the load RTP command from the receive table function code entry in word 10 of the station table. This register is written to the dump area by the dump registers command. A hardware or software reset clears the receive table function code register.

### 4.5.10 Receive Buffer Pointer Register

The current receive buffer address is stored in the 32-bit receive buffer pointer register (RBP). As the data is received, the RBP is autoincremented until the count in the buffer length location of the current receive frame specification block is reached or until the frame is completed. The RBP is first loaded from the buffer address location of the receive frame specification block by the execution of the load RTP command. This register is then loaded automatically by the XPC to access each receive frame buffer until the end of the receive frame specification table is reached. The RBP is written to the dump area by execution of the dump registers command. A hardware or software reset does not clear this register.

### 4.5.11 Receive Buffer Function Code Register

The receive buffer function code register (RBFC) contains the 4-bit function code value that may be required to access the receive buffer pointed to by the receive buffer pointer register. This register is first loaded from the receive buffer function code location in the current receive frame specification block by the execution of the load RTP command. This register is then loaded automatically by the XPC to access each receive frame buffer until the end of the receive frame specification table is reached. This register is written to the dump area by the dump registers command. A hardware or software reset does not clear the RBFC register.

### 4.5.12 Receive Buffer Count Register

The receive buffer count register (RBC) is a 16-bit register that contains the number of bytes available in the current receive buffer that is pointed to by the RBP register. This register is first loaded from the receive buffer length location in the receive frame specification block by the load RTP command. Thereafter, the RBC is loaded automatically by the XPC as each receive frame buffer is accessed.

The XPC autodecrements the RBC as information is received into the corresponding receive buffer until the count is exhausted or until the entire frame is received. After the frame is received, this register contains the number of bytes remaining in the current receive buffer. This value is written to the final count location of the receive frame specification block. In transparent operation, if the length of the incoming frame exceeds the buffer length available, the XPC sets the BTS (buffer too short) bit in the Rx/ host status register.

In X.25 operation, if the length of the incoming frame exceeds the buffer length available, the XPC enters frame reject mode and reports its status to the host.

The RBC is written to the dump area by executing the dump registers command. A hardware or software reset does not clear the RBC.

### 4.5.13 Local Address Register

The local address register (LA) is an 8-bit register that stores the station address of the XPC. Execution of the load addresses or load station parameters command loads the LA from the local address location, the low-order byte of word 8 in the station table. This register is written to the dump area by executing the dump registers command. A software or hardware reset clears this register. This register is not used in transparent operation.

### 4.5.14 Remote Address Register

The remote address register (RA) is an 8-bit register that stores the address of the remote station that communicates with the XPC. Execution of the load addresses or load station parameters command loads the RA from the remote address location, the low-order byte of word 9 in the station table. This register is written to the dump area by executing the dump registers command. A hardware or software reset clears this register. This register is not used in transparent operation.

### 4.5.15 Hardware Configuration Register

The hardware configuration register (HC) is an 8-bit register that contains system operating parameters. The operating parameters define the data encoding and decoding scheme, DMA burst control, data organization in memory, and data bus width. Execution of the set hardware configuration command during initialization loads this register. The valid operation parameters are shown below. This register is cleared by a hardware or software reset.

| 7 | 6 | 5 | 4    | 3    | 2 | 1     | 0    |
|---|---|---|------|------|---|-------|------|
| 0 | 0 | 0 | NRZI | BRSC | 0 | DORGM | BUSW |

- NRZI -Nonreturn to Zero Invert
  - 0 = NRZ Decoding and Encoding
  - 1 = NRZI Decoding and Encoding
- BRSC Burst Control
  - 0 = XPC DMA Burst Is Unlimited
  - 1 = XPC DMA Is Limited to Eight Successive Memory Cycles

DORGM — Data Organization in Memory (16-Bit Bus Only)

- 0=Data in Memory Buffers Organized with High-Order Byte in Lower Address (Motorola, IBM Convention)
- 1=Data in Memory Buffers Organized with High-Order Byte in Higher Address (Digital, Intel Convention)

BUSW - Bus Width

0=8-Bit Data Bus

1=16-Bit Data Bus

### 4.5.16 Station Configuration Register

The station configuration register (SC) is an 8-bit register that contains the station operating parameters. Execution of the set station configuration command during initialization loads this register. The SC register format is shown below. A hardware or software reset clears this register.

| 7 | 6 | 5 | 4 | 3    | 2 | 1    | 0 |
|---|---|---|---|------|---|------|---|
| 1 | 0 | 1 | 0 | ECRC | 0 | ECNT | 0 |

 $\begin{array}{l} \mbox{ECRC} \mbox{$--$ Extended CRC$} \\ \mbox{$0=16$-Bit CRC$ (CRC CCITT)$} \\ \mbox{$1=32$-Bit CRC$} \end{array}$ 

ECNT — Extended Control

0 = Basic Control Field Format (Modulo 8)

1 = Extended Control Field Format (Modulo 128)

### 4.5.17 Option Bits Register

The option bits register (OB) is a 16-bit register that contains operation options. Execution of the load option bits or load station parameters command loads the OB register from the option bits location in word 0 of the station table. The register format is shown below. This register is cleared by a hardware of software reset. This register is not used in transparent operation.

| F | E | D | С  | В | А | 9 | 8      |
|---|---|---|----|---|---|---|--------|
| 0 | 0 | 0 | 0. | 0 | 0 | 0 | X.75   |
| 7 | 6 | 5 | 4  | 3 | 2 | 1 | 0      |
| 0 | 0 | 0 | 0  | 0 | 0 | 0 | CRCNOA |

X.75 — X.75 Option

0 = X.25 Operation

1 = X.75 Operation

#### CRCNOA — CRC Bypass Option

- 0=Nonoctet Aligned Frames or Frames with a CRC Error Are Not Accepted
- 1 = Nonoctet Aligned Frames or Frames with a CRC Error Are Accepted

All other bits are reserved for future use.

If the X.75 option is selected, then, in addition to the frame reject conditions for X.25, the XPC will enter frame reject mode on reception of the following:

- A supervisory frame with the F bit set to one, except during a timer recovery condition or except as a reply to a command sent with the P bit set to one,
- 2. An unexpected UA or DM response, or
- 3. An information frame with an invalid N(S).

#### 4.5.18 Mode Descriptor Register

The 8-bit mode descriptor register (MD) contains the current operation mode information. The MD register is updated when the XPC operation mode changes. If the new mode bit in the Tx/link status register is not set when an operation mode change occurs, the XPC sets this bit and writes the MD register to the mode descriptor location in the high-order byte of word 21 in the station table (except for the TBEN bit and WACK bit discussed later). If the new mode bit is set when a mode change occurs, the XPC updates the

MD register but does not write the register to the station table location. As part of a new mode status condition service routine, the host should read the MD station table location and then issue a dump parameters command to get the latest new mode information that is stored in the MD register. Execution of the dump registers command causes the MD to be written to the dump area. The dump parameters command causes this register to be written to the station table. A hardware or software reset clears the mode descriptor register.

The TBEN (transmit buffer enable) bit is set internally after the load transmit table pointer command has been executed by the XPC. In order to prevent unnecessary interruptions to the host, the XPC will not dump the MD register into the station table or set the new mode bit in the Tx/link status register. The completion of the load transmit table pointer command is an indication that TBEN has been set internally. Similarly, the MD register is not written to the station table when TBEN is cleared due to the acknowledgement of all transmitted information frames, since the IFAK status bit in the Tx/link status register will be set and an interrupt generated to the host.

The WACK bit is set after the Start Link command is executed by the XPC or after a SABM or SABME is sent by the XPC to initiate link reset. When the WACK bit is set and the new mode bit is not currently set internally, the XPC will write the MD to the station table and generate a new mode interrupt. When the WACK bit is cleared, the XPC will not generate a separate new mode interrupt. Instead, the clearing of the WACK bit is indicated by either the CONN bit set (generating a new mode interrupt) or by the RTRYL bit set in the Tx/Link status register.



TBEN — Transmit Buffer Enable

X.25

0 = Transmission of I Frames is Disabled

1 = Station Is Connected and Transmission of I Frames Is Enabled Transparent

0 = Transmission of Frames Is Disabled

1 = Transmission of Frames Is Enabled

ECNT — Extended Control

0 = Basic Control Field Format (Modulo 8)

1 = Extended Control Field Format (Modulo 128)

CONN — Connected

X.25

0 = Station Is Disconnected

1 = Station Is Connected

Transparent — Not Used

WACK — Waiting for Acknowledgement X.25

0 = Station Is Not Waiting for an UA Response 1 = Station Is Waiting for an UA Response Transparent — Not Used

FRMR — Frame Reject Mode

X.25

0 = Station Not in FRMR Mode

1 = Station in FRMR Mode

Transparent — Not Used

#### RCVR — Recovery Mode

X.25

0 = Station Not in Timer Recovery Mode

1 = Station in Timer Recovery Mode

Transparent — Not Used

RBSY — Remote Station Busy

X.25

0 = Remote Station Is Not in Busy Condition

1 = Remote Station Is in Busy Condition

Transparent — Not Used

Table 4-3 shows the relationship between the TBEN, CONN, and IFAK (information frames acknowledged bit in the Tx/link status register).

| Event                                                                                                                      | TBEN | CONN | IFAK |
|----------------------------------------------------------------------------------------------------------------------------|------|------|------|
| Chip Reset (Hardware or Software)                                                                                          | 0    | 0    | 0    |
| Enter Connect State (S5) due to SABM/UA Exchange <sup>1</sup>                                                              | 0    | 1    | 0    |
| Load Transmit Table Pointer Command                                                                                        | 1    | 1    | 0    |
| All Information Frames have been Transmitted and Acknowledged                                                              | 0    | 1    | 1    |
| Receive Response with F = 1 after Transmitting Frame with P = 1<br>(Enter S5 from S7), All Information Frames Acknowledged | 0    | 1    | 1    |
| Receive Response with $P-1$ after Transmitted Frame with $P=1$ (Enter S5 from S7), Some Information Frames Unacknowledged  | 1    | 1    | 0    |
| Receive DISC (Enter S1 from S5) Information Frame Transmission was Not Enabled                                             | 0    | 0    | 0    |
| Receive DISC (Enter S1 from S5) Some Information Frames Unacknowledged <sup>2</sup>                                        | 1    | 0    | 0    |
| Receive DISC (Enter S1 from S5) All Information Frames<br>Acknowledged                                                     | 0    | 0    | 1    |

#### Table 4-3. Relationship Between TBEN, CONN, and IFAK

NOTES:

 The XPC clears TBEN upon entering S5 due to a SABM/UA exchange, this is done in order to let upper layer software distinguish between normal return to S5 (from S6 and above, i.e., clear busy condition) and a link reset situation (from S6 and above where SABM/UA are exchanged). The software may instruct the XPC to dump parameters, analyze the transmit and receive pointers and recover without any information loss.

 TBEN = 1 at DISC does not mean that the XPC is going to transmit I frames. However, it may be used as an indication that not all information frames were transmitted and acknowledged before entering the DISC mode. The XPC does not update TBEN and IFAK upon entering DISC from the connect states (S5 and above).

### 4.5.19 Frame Reject Descriptor Register

The 8-bit frame reject descriptor register (FRD) contains information about the cause of the current frame reject condition when the FRMR bit in the mode descriptor register is set. The FRD register is updated when the frame reject mode is entered and cleared when the frame reject mode is exited. If the new mode bit in the Tx/link status register is not set when the FRD is updated or cleared, the XPC will also write this register to the corresponding station table location. If the new mode bit is set, the XPC only updates the internal FRD register. This register is written to the dump area by executing the dump registers command. The dump parameters command causes this register to be written to the station table. A hardware or software reset clears this register. This register is not used in transparent operation.

| 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|---|---|---|---|---|---|---|
| C/R | 0 | 0 | 0 | Z | Y | Х | w |

#### C/R — Command/Response

0 = The Cause of FRMR Mode was a Command Frame

1 = The Cause of FRMR Mode was a Response Frame

Z — Invalid N(R)

Set if received I or S frame contained an invalid N(R).

#### Y — Receive Memory Buffer Too Short

Set if received information field is longer than the receive memory buffer, while in normal operation. Not used during monitor test.

#### X — Illegal I Field

Set if received frame has nonzero length information field and the control field does not permit an I field. The W bit must also be set.

W — Invalid or Not Implemented Control Field Set if a correct frame with invalid or unimplemented control field is received.

### 4.5.20 Rx/Host Status Register

The Rx/host status register (RHS) is a 16-bit register that contains XPC status information relating to the condition of the receiver and host interface. These status bits have the same meaning for both X.25 and transparent operation unless otherwise specified. If a status bit is already set internally when the corresponding event occurs, the XPC takes no action. If the internal status bit is clear, the XPC sets the bit and checks its internal interrupt pending flag, which is a copy of the  $\overline{IRQ}$  signal. If no interrupt is pending, the RHS is written to word 19 in the station table. This event can then cause a interrupt to occur if the corresponding bit in the Rx/host interrupt mask location is set. If an interrupt request is already pending when the event occurs, the RHS is not written to the station table. When the current interrupt request is cleared, the internal RHS is immediately written to the station table location. Any set status bits can then cause an interrupt.

Individual bits in the Rx/host status register are cleared by executing the clear Rx/host status or a clear status command. A hardware or software reset clears the Rx/host status register. The dump registers command causes this register

to be written to the dump area. The update status or dump parameters command causes this register to be written to the station table.

| F    | E    | D      | С    | В      | А    | 9     | 8   |
|------|------|--------|------|--------|------|-------|-----|
| BTS  | NBA  | CRCERR | 0    | RREJ   | ETST | UDEF  | ILL |
| 7    | 6    | 5      | 4    | 3      | 2    | 1     | 0   |
| AERR | BERR | ABORT  | OVRN | RXIDLE | RXI  | RFRMR | RTE |

#### BTS — Receive Buffer is Too Short

The current buffer is used for the next frame received.

X.25

Not used. Instead, the FRMR mode is entered and the Y bit in the FRD register is set.

Transparent

Set when the received frame is longer than the receive buffer

#### NBA — No Receive Memory Buffer Available

The current buffer will be used for the next frame received.

X.25

Set when an I frame is received and no memory buffer is available.

Transparent

Set when a frame is received and no memory buffer is available.

#### CRCERR — CRC Error or Nonoctet Aligned Frame Received

A CRC check can not be performed on a frame which is less than 16 bits long; thus, this bit will not be set for those frames.

X.25

Set when a frame with local or remote address is nonoctet aligned or received with a CRC error.

Transparent — Not Used

RREJ — Received REJ Frame

X.25

Set when a REJ frame is received.

Transparent — Not Used

ETST — End of Test Command

Set upon the successful completion of DMA transfer or serial loopback commands.

4

UDEF — Undefined Host Command

Set when an unimplemented command from one of the following ranges is received from the host:

- '20' '7F' hex
- '94' hex
- '96' '9F' hex
- 'E0' 'FE' hex

If the XPC receives an unimplemented command in the range '00' — '1F' hex, the XPC will set the semaphore register to 'FE' and ignore the command. The semaphore register will remain at 'FE' until the next command is issued to the XPC.

#### ILL — Illegal Host Command

Set when a command is received from the host which conflicts with the current state of the XPC.

#### AERR — Address Error

Set when an address presented to the bus by the XPC to access the receive frame specification table or a receive buffer produces an XPC chip select or an XPC interrupt acknowledge input signal.

#### BERR — Bus Error

Set when the BERR encoding is asserted on the BEC input pins during a XPC access to the receive frame specification table or a receive buffer.

#### ABORT — Abort Sequence

Set when a minimum of seven consecutive ones are received (abort) during frame reception or when the carrier detect input signal is negated for 1 Tx clock cycle during frame reception. The current buffer will be used for the next frame received.

#### OVRN — Overrun

Set when a receive FIFO overrun occurs during frame reception.

#### RXIDLE — Receiver Idle

Set when more than 15 consecutive ones are received between frames.

#### **RXI** — Received Information Frame

X.25

Set when an information frame is received.

#### Transparent

Set when a frame is received.

RFRMR — Received FRMR Frame

X.25

Set when a FRMR frame is received. The FRMR I field is written to the station table.

Transparent — Not Used.

RTE — Receive Frame Specification Table Ended

X.25

Set after filling the last buffer specified by the receive frame specification table — RNR frame or RR frame is sent to acknowledge the reception of the previous frame(s) depending on whether the link bit in the receive status location of the last receive specification block is set.

Transparent

Set after filling the last buffer specified by the receive frame specification table.

### 4.5.21 Tx/Link Status Register

The Tx/link status register (TLS) is a 16-bit register containing the status information relating to the transmitter and communication link. These status bits have the same meaning for both X.25 and transparent operation unless otherwise specified. If a status bit is already set internally when the corresponding event occurs, the XPC takes no action. If the internal status bit is clear, the XPC sets the bit and checks its internal interrupt pending flag, which is a copy of the IRQ signal. If no interrupt is pending, the TLS is written to word 20 in the station table. This event can then cause an interrupt to occur if the corresponding bit in the Tx/link interrupt mask location is set. If an interrupt request is already pending when the event occurs, the TLS is not written to the station table. When the current interrupt request is cleared, the internal TLS is immediately written to the station table location. Any set status bits can then cause an interrupt.

Individual bits in the Tx/link status register are cleared by executing the clear Tx/link status or a clear status command. A hardware or software reset clears the Tx/link status register. The dump registers command causes this register to be written to the dump area. The update status or dump parameters command causes this register to be written to the station table.

|   | F    | Е    | D    | С    | В | А | 9     | 8     |
|---|------|------|------|------|---|---|-------|-------|
|   | 0    | 0    | 0    | 0    | 0 | 0 | NEWMD | RTRYL |
|   | 7    | 6    | 5    | ٨    | 2 | 2 | 1     | 0     |
| , | /    |      | 5    | 4    | 3 |   |       |       |
| l | AERR | BERR | CTSL | URUN | 0 | 0 | 0     | IFAK  |

#### NEWMD — New Mode

Set when the XPC operation mode changes. The mode descriptor register and the FRMR descriptor register give information about the mode change.

RTRYL — Retry Limit

#### X.25

Set when the retransmission limit specified in the retries limit register is exceeded.

Transparent — Not Used

#### AERR — Address Error

Set when an address presented to the bus by the XPC to access the transmit frame specification table or a transmit buffer produces an XPC chip select or an XPC interrupt acknowledge input signal.

#### BERR — Bus Error

Set when the BERR encoding is asserted on the BEC input pins during an XPC access to the receive frame specification table or a receive buffer.

#### CTSL — Clear to Send Lost

Set when CTS is not asserted within 68 Tx clock cycles after RTS was asserted or when CTS is negated for 1 Tx clock cycle during frame transmission.

#### URUN — Underrun

Set when a transmit FIFO underrun occurs during frame transmission. The XPC transmits an abort sequence and then retransmits the frame.

#### IFAK — Information Frames Acknowledged

X.25

Set when the current transmit frame specification table has ended and all information frames have been acknowledged.

#### Transparent

Set when the last byte of the last frame is loaded into the Tx FIFO.

## 4.5.22 V(R) Register

During transparent operation, the 8-bit V(R) register counts the number of frames received regardless of frame type. After a frame is received, V(R) is incremented Modulo 8 or Modulo 128 depending on the ECNT bit in the station configuration register.

During X.25 operation, the 8-bit V(R) register contains the sequence number N(S) of the last received I frame incremented by one. Therefore, V(R) is equal to the sequence number of the next expected I frame.

This register is stored in the V(R) location, the low-order byte of word 22, in the station table as the result of a dump parameters command. Execution of the dump registers command causes the V(R) register to be written to the dump area. A hardware or software reset clears this register.

### 4.5.23 V(S) Register

During transparent operation, the 8-bit V(S) register counts the number of frames transmitted regardless of frame type. After a frame is transmitted, V(S) is incremented Modulo 8 or Modulo 128 depending on the ECNT bit in the station configuration register.

During X.25 operation, the 8-bit V(S) register contains the send sequence N(S) of the next information frame to be transmitted by the XPC.

This register is stored in the V(S) location, the high-order byte of word 22, in the station table as the result of a dump parameters command. Execution of the dump registers command causes the V(R) register to be written to the dump area. A hardware or software reset clears this register.

### 4.5.24 Time-Out Preset Register

The time-out preset register (TOP) is a 16-bit register that contains the user specified time-out counter preset. The time-out period range is from 0 to  $2^{16}-1$  clock cycles. The clock frequency is determined by the time scale divider register. The TOP is loaded from the time-out preset location, word 1 in the station table, using the load preset values or load station parameters command. The dump registers command dumps the TOP to the dump area. A hardware or software reset clears this register. This register is not used in transparent operation.

### 4.5.25 Retries Limit Register

The retries limit register (RL) is an 8-bit register that contains the user-specified number of retransmissions permitted. The retries limit register contains the value of the LAPB N2 parameter (maximum number of attempts to complete transmission) minus 1. The retries limit is loaded from the retries limit station table location, the lower byte of word 3, by a load preset values or load station parameters command. The RL is written to the dump area by the dump registers command. A hardware or software reset clears this register. This register is not used in transparent operation.



RL7-RL0

Contain the Binary Number of Retries (0 to 255)

### 4.5.26 Time Scale Divider Register

The time scale divider register (TSD) is an 8-bit register which contains the user specified system clock divider for generating the lower frequency clock used by the time-out counter. Valid divisors are 512, 1024, 2048, 4096, and 8192. This register is loaded from the time scale location, the high-order byte of word 2, in the station table by executing the load preset values or load station parameters command. This register is cleared by a hardware or software reset. This register is not used in transparent operation.

| 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|---|---|---|---|-----|-----|-----|-----|
| 0 | 0 | 0 | 0 | TS3 | TS2 | TS1 | TSO |

**TS3-TS0** 

Determine the System Clock Divisor

| TS3 | TS2 | TS1 | TS0 | Divisor |
|-----|-----|-----|-----|---------|
| 0   | 0   | 0   | 0   | 512     |
| 0   | 0   | 0   | 1   | 1,024   |
| 0   | 0   | 1   | 0   | 2,048   |
| 0   | 1   | 0   | 0   | 4,096   |
| 1   | 0   | 0   | 0   | 8,192   |

Encodings other than those specified are undefined.

4

### 4.5.27 Outstanding Frames Limit Register

The outstanding frames limit register (OFL) is an 8-bit register that contains the user-specified number of outstanding frames permitted. The number of outstanding frames may be zero to seven in the basic control field mode and zero to 127 in the extended control field mode of operation. This register is loaded from the outstanding frames limit location, the high-order byte of word 3, in the station table by executing the load preset values or load station parameters command. This register is cleared by a hardware or software reset. The OFL register is written to the dump area by executing the dump registers command. This register is not used in transparent operation.

| 7 | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|---|------|------|------|------|------|------|------|
| 0 | OFL6 | OFL5 | OFL4 | OFL3 | OFL2 | OFL1 | OFLO |

#### OLF6-OLF0

These bits are the binary number of outstanding frames allowed in extended control field operation.

#### OFL2-OFL0

These bits are the binary number of outstanding frames allowed in basic control field operation.

### 4.5.28 Pad Time Select Register

The pad time select register (PTS) is an 8-bit register that contains the userspecified minimum number of flags to be transmitted between frames. This register is loaded from the low-order byte of word 2 in the station table by executing the load preset values or load station parameters command. The PTS register is initialized to zero during a hardware or software reset.

### 4.5.29 Retries Count Register

The retries count register (RC) is an 8-bit register that contains the current number of retransmission attempts. This register is initialized to zero when a frame is transmitted. The RC register is incremented for each retransmission of the frame, until the value in the retries limit register (RL) is reached. No further transmission of the frame is attempted, and the XPC reports its status to the host. The RC register is written to the dump area by executing the dump registers command. The RC register is cleared when the XPC receives a UA or RNR frame or when the XPC receives information or supervisory frames with the N(R) higher than the last received N(R). The RC register is also cleared when the XPC enters a new mode (i.e., ABM, ABME, or ADM) and after transmitting a FRMR command or UA response. This register is also cleared on reset. This register is not used during transparent operation.

### 4.5.30 Last Received N(R)

The last received N(R) register (LRN) is an 8-bit register that contains the receive sequence number N(R) contained in the last received frame. This register is written to the dump area by executing the dump registers command. The LRN register is cleared by hardware or software reset and when the XPC (re)enters connect mode. This register is not used in transparent operation.

### 4.6 HARDWARE OR SOFTWARE RESET

Table 4-4 summarizes the effect of a hardware or software reset on the internal XPC registers.

| Register                      | Cleared by Hardware<br>or Software Reset |
|-------------------------------|------------------------------------------|
| Station Table Pointer         | Yes                                      |
| Station Table Function Code   | Yes                                      |
| Transmit Table Pointer        | Yes                                      |
| Transmit Table Function Code  | Yes                                      |
| Transmit Buffer Pointer       | No                                       |
| Transmit Buffer Function Code | No                                       |
| Transmit Buffer Count         | No                                       |
| Receive Table Pointer         | Yes                                      |
| Receive Table Function Code   | Yes                                      |
| Receive Buffer Pointer        | No                                       |
| Receive Buffer Function Code  | No                                       |
| Receive Buffer Count          | No                                       |
| Local Address                 | Yes                                      |
| Remote Address                | Yes                                      |
| Hardware Configuration        | Yes                                      |

#### Table 4-4. Reset Impact on Registers

| Register                 | Cleared by Hardware<br>or Software Reset |
|--------------------------|------------------------------------------|
| Station Configuration    | Yes                                      |
| Option Bits              | Yes                                      |
| Mode Descriptor          | Yes                                      |
| Frame Reject Descriptor  | Yes                                      |
| Rx/Host Status           | Yes                                      |
| Tx/Link Status           | Yes                                      |
| V(S)                     | Yes                                      |
| V(R)                     | Yes                                      |
| Time-Out Preset          | Yes                                      |
| Retries Limit            | Yes                                      |
| Outstanding Frames Limit | Yes                                      |
| Time Scale Divider       | Yes                                      |
| Pad Time Select          | Yes                                      |
| Retries Count            | Yes                                      |
| Last Received N (R)      | Yes                                      |

# SECTION 5 SHARED MEMORY STRUCTURES

The host processor communicates with the XPC using three tables located in shared memory (see Figure 5-1). The station table allows the host processor to initialize and update the XPC operating parameters and table pointers and to receive status and error information. The transmit frame specification table queues frames to be transmitted by the XPC, and the receive frame specification table queues available receive buffers for the XPC to store received information frames. The XPC is given a pointer to the station table during initialization. The transmit frame specification table and receive frame specification table pointers are contained in the station table.



Figure 5-1. Shared Memory Tables

### **5.1 STATION TABLE**

The station table format is shown in Table 5-1. The first 19 words of the station table are written by the host processor and are read by the XPC. This portion of the table contains the XPC operating information. The XPC accesses this table area as the result of a host processor command. The next 22 words of the table are written by the XPC and read by the host processor. Some of these entries are written by the XPC as the result of a command; other entries are updated by the XPC when a change occurs. When the XPC accesses the table as the result of a host processor command, it sets the semaphore register to hex 'FF' upon completion of the access. While the XPC is processing a command, the semaphore register is hex 'FE'.

### 5.1.1 Option Bits

Word zero of the station table contains the option bits. This word is loaded into the option bits register by executing a load option bits or load station parameters command. For more details see **4.5.17 Option Bits Register**.

| F | E | D | С | В | А | 9 | 8      |
|---|---|---|---|---|---|---|--------|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | X.75   |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | CRCNOA |

### 5.1.2 Time-Out Preset

Word 1 of the station table contains the user-specified time-out counter preset. This value is loaded into the time-out preset register as a result of a load preset values or load station parameters command. The value can range from 0 to  $2^{16}-1$  clock cycles. For more details see **4.5.24 Time-Out Preset Register**. The location is not used in transparent operation.

| WORD | 15 12       | 11 8             | 7 4            | 3              | 0              |
|------|-------------|------------------|----------------|----------------|----------------|
| 0    |             | OPTIO            | N BITS         |                |                |
| 1    |             | TIME-OU          | T PRESET       |                |                |
| 2    | TIME SCA    | E DIVIDER        | PAD TIM        | e select       |                |
| 3    | OUTSTANDING | FRAMES LIMIT     | RETRIES        | s limit        |                |
| 4    |             | Rx/HOST M        | ASK BITS       |                |                |
| 5    |             | Tx/LINK N        | ASK BITS       |                |                |
| 6    |             | Rx/HOST STAT     | US CLEAR BITS  |                |                |
| 7    |             | Tx/LINK STATU    | JS CLEAR BITS  |                |                |
| 8    | 0000        | 0000             | LOCAL A        |                |                |
| 9    | 0000        | 0000             | REMOTE         | HOST PROCESSOR |                |
| 10   | 0000        | 0000             | 0000           | RTFC           | XPC WRITTEN BY |
| 11   | REC         | EIVE TABLE POI   | NTER — HIGH WO | )RD            | HOST PROCESSOR |
| 12   | RE          | CEIVE TABLE POII | NTER — LOW WC  | IRD            |                |
| 13   | 0000        | 0000             | 0000           | TTFC           |                |
| 14   | TRA         | NSMIT TABLE PO   | INTER — HIGH W | /ORD           |                |
| 15   | TRA         |                  |                |                |                |
| 16   | 0000        | 0000             | 0000           | DAFC           |                |
| 17   | D           | UMP AREA POIN    | rer — High Wof | łD             |                |
| 18   | D           | UMP AREA POIN    | ter — Low Wor  | D              |                |

### Table 5-1. Station Table Structure

| 19 | [                                              | Rx/HOST        | STATUS           |           | ]        |  |  |
|----|------------------------------------------------|----------------|------------------|-----------|----------|--|--|
| 20 |                                                | Tx/LINK        | STATUS           |           | 1        |  |  |
| 21 | MODE DESCRIPTOR FRAME REJECT DESCRIPTOR        |                |                  |           |          |  |  |
| 22 | V(                                             | S)             | V(               | R)        | 1        |  |  |
| 23 | 0000                                           | 0000           | 0000             | FUFC      |          |  |  |
| 24 | FIRST UN                                       | ACKNOWLEDGE    | ) POINTER — HIG  | H WORD    |          |  |  |
| 25 | FIRST UN                                       | ACKNOWLEDGE    | ) POINTER — LO   | W WORD    | ]        |  |  |
| 26 | 0000                                           | 0000           | 0000             | TFC       |          |  |  |
| 27 | Т                                              | RANSMIT POINT  | er — High wor    | D         |          |  |  |
| 28 | 1                                              | RANSMIT POINT  | er — Low Wori    | D         | ]        |  |  |
| 29 | 0000                                           | 0000           | 0000             | RTFC      | XPC ARE  |  |  |
| 30 |                                                | RECEIVE POINTE | r — High Word    |           | PROCESS  |  |  |
| 31 |                                                | RECEIVE POINTE | R — LOW WORD     |           | BY THE 3 |  |  |
| 32 | 0000                                           | 0000           | 0000             | REFC      | ]        |  |  |
| 33 | RECEIVE BU                                     | JS/ADDRESS ERR | or pointer — H   | IIGH WORD |          |  |  |
| 34 | RECEIVE B                                      | US/ADDRESS ERF | IOR POINTER — L  | .OW WORD  | ].       |  |  |
| 35 | 0000                                           | 0000           | 0000             | TEFC      |          |  |  |
| 36 | TRANSMIT BUS/ADDRESS ERROR POINTER — HIGH WORD |                |                  |           |          |  |  |
| 37 | TRANSMIT                                       | BUS/ADDRESS ER | ROR POINTER      | LOW WORD  | ]        |  |  |
| 38 | RECEIVE                                        | ED FRMR INFORM | iation field     | WORD 1    |          |  |  |
| 39 | RECEIVE                                        | ed FRMR INFORM | iation field — ' | WORD 2    | ]        |  |  |
| 40 | RECEIVE                                        | ed FRMR INFORM | iation field —   | WORD 3    | ]        |  |  |

KPC AREA READ BY THE HOST PROCESSOR WRITTEN BY THE XPC

### 5.1.3 Time Scale Divider

The high-order byte of station table word 2 contains the time scale divider. This is a user-defined parameter for generating the lower frequency clock used by the time-out counter. The valid divider values are 512, 1024, 2048, 4096, and 8192. The time scale divider is loaded into the time scale divider register as the result of a load preset values or load station parameters command. For more details see **4.5.26 Time Scale Divider Register**. This location is not used in transparent operation.



### 5.1.4 Pad Time Select

The lower order byte of station table word 2 contains the user-specified minimum number of pad flags to be transmitted between frames. This parameter is loaded into the pad time select register by executing the load preset values or load station parameters command. This value can range from 0 to 255. When the pad time select value is zero, the XPC transmits a closing flag immediately followed by the opening flag of the next frame. Then, if six bytes are present in the transmit FIFO, the XPC will begin to transmit the frame address, etc. If the required number of bytes are not present in the FIFO, the XPC will transmit additional flags. This requirement for a minimum number of bytes to be available in the FIFO decreases the occurrence of a transmit underrun condition. Of course, transmission can begin when less than six bytes are present if the entire frame is less than six bytes.

### 5.1.5 Outstanding Frames Limit

The upper byte of station table word 3 contains the outstanding frames limit. This user-defined parameter is the number of frames which can be sent before an acknowledgement is required. The format of this table entry is shown below. The outstanding frames limit is loaded into the outstanding frames limit register by a load preset values or load station parameters command. The maximum number of outstanding frames is 127 for extended control mode and 7 for basic control mode. For more details see **4.5.27 Outstanding Frames Limit Register**. This location is not used in transparent operation.

5-4

| 7         | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----------|------|------|------|------|------|------|------|
| *         | OFL6 | OFL5 | OFL4 | OFL3 | OFL2 | OFL1 | OFLO |
| *Not Used |      |      |      |      |      |      |      |

### 5.1.6 Retries Limit

The lower byte of station table word 3 holds the retries limit. This 8-bit userspecified parameter is the permitted number of attempts to successfully retransmit a frame. The maximum number of retransmission attempts is 255. The retries limit is loaded into the retries limit register by the load preset values or load station parameters command. This location is not used in transparent operation.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| RL7 | RL6 | RL5 | RL4 | RL3 | RL2 | RL1 | RLO |

### 5.1.7 Rx/Host Mask

Word 4 of the station table contains the Rx/host mask. This mask allows the user to selectively disable interrupts caused by receiver or host status conditions. Interrupt conditions are individually masked by clearing the appropriate bit in the mask entry. Even though an interrupting condition is masked, the corresponding status bit in the Rx/host status register and the Rx/host status entry in the station table will be updated. If a masked interrupt condition is later enabled and the corresponding bit in the Rx/host status register is set, an interrupt request will be issued. There is no internal copy of the Rx/host mask. Each time the Rx/host status changes, the XPC reads the current mask residing in the station table to determine whether to issue an interrupt. The format is identical to the Rx/host status entry in the station table and to the Rx/host status register. For more details see **4.5.20 Rx/Host Status Register**.

| F    | E    | D      | С    | В    | А    | 9     | 8   |
|------|------|--------|------|------|------|-------|-----|
| BTS  | NBA  | CRCERR | *    | RREJ | ETST | UDEF  | ILL |
|      |      |        |      |      |      |       |     |
| 7    | 6    | 5      | 4    | 3    | 2    | 1     | 0   |
| AERR | BERR | ABORT  | OVRN | IDLE | RXI  | RFRMR | RTE |
|      | ргор |        | OVBN | IDLE | BXI  | RERMR | RTE |

\*Not Used

### 5.1.8 Tx/Link Mask

Word 5 of the station table contains the Tx/link mask. This mask allows the user to selectively disable interrupts caused by transmitter or link status conditions. Interrupt conditions are individually masked by clearing the appropriate bit in the mask. Even though an interrupting condition is masked, the corresponding status bit in the Tx/link status register and the Tx/link status entry in the station table will be updated. If a masked interrupt condition is later enabled and the corresponding bit in the Tx/link status register is set, an interrupt request will be issued. There is no internal copy of the Tx/link mask. Each time the Tx/link status changes, the XPC reads the current mask residing in the station table to determine whether to issue an interrupt. The format of the mask is identical to the Tx/link status entry in the station table and to the Tx/link status register. For more details see **4.5.21 Tx/Link Status Register**.

| _ | F    | E    | D    | C    | В | Α | 9     | 8     |
|---|------|------|------|------|---|---|-------|-------|
|   | *    | *    | *    | *    | * | * | NEWMD | RTRYL |
|   | 7    | 6    | 5    | 4    | 3 | 2 | 1     | 0     |
|   | AERR | BERR | CTSL | URUN | * | * | *     | IFAK  |

<sup>\*</sup>Not Used

### 5.1.9 Rx/Host Status Clear

The Rx/host status clear bits in word 6 of the station table allow the host to selectively clear status bits relating to receiver or host interface conditions. These bits are individually cleared by setting the appropriate bit in the Rx/ host status clear entry in the station table and then instructing the XPC to clear Rx/host status or to clear status. The XPC clears the corresponding bit in the Rx/host status register and writes the register to the Rx/host status register. For more details see **4.5.20 Rx/Host Status Register**.

| _ | F    | E    | D      | С    | В    | А    | 9     | 8   |
|---|------|------|--------|------|------|------|-------|-----|
|   | BTS  | NBA  | CRCERR | *    | RREJ | ETST | UDEF  | ILL |
| - | 7    | 6    | 5      | 4    | 3    | 2    | 1     | 0   |
|   | AERR | BERR | ABORT  | OVRN | IDLE | RXI  | RFRMR | RTE |

\*Not Used

### 5.1.10 Tx/Link Status Clear

Tx/link status clear bits in word 7 of the station table allow the host to selectively clear status bits relating to transmitter or link conditions. These bits are individually cleared by setting the appropriate bit in the Tx/link status clear entry in the station table and then instructing the XPC to clear Tx/link status or to clear status. The XPC clears the corresponding bit in the Tx/link status register and writes the register to the Tx/link status entry in the station table. The format is identical to the Tx/link status register. For more details see **4.5.21 Tx/Link Status Register**.



\*Not Used

### 5.1.11 Local Address

The lower order byte of station table word 8 contains the XPC's station address. The 8-bit address is loaded into the local address register by the load addresses or load station parameters command. This location is not used in transparent operation.

### 5.1.12 Remote Address

The lower order byte of station table word 9 contains the address of the remote station that communicates with the XPC. The 8-bit remote address is loaded into the remote address register by the load addresses or load station parameters command. This location is not used in transparent operation.

### 5.1.13 Receive Table Function Code

Bits 0–3 of station table word 10 contains the function code value that may be required by the system to access the receive frame specification table, which starts at the address contained in the receive table pointer location of the station table. The function code value is stored in the receive table function code register by executing a load RTP command. The function codes are defined by the user, and the XPC does not perform any checking on these values

#### 5.1.14 Receive Table Pointer

The 32-bit receive table pointer is stored in words 11 and 12 of the station table. This pointer is the address of the receive frame specification table which specifies free memory buffers for storage of received information frames. The XPC presents this address and the receive table function code when first accessing the receive frame specification table. This pointer is stored in the receive table pointer register by executing a load receive table pointer command. For more details see 5.3 RECEIVE FRAME SPECIFICATION TABLE.

#### NOTE

The XPC does not check for an "odd pointer" value and does not generate an address error for the odd word boundary access. In an 8-bit data bus system, an "odd pointer" is proper. In a 16-bit data bus system, the XPC zeros the least significant address bit of the pointer and therefore presents an even word address to the bus. The system designer must ensure that the XPC is not given an odd pointer in a 16-bit data bus configuration.

# 5.1.15 Transmit Table Function Code

Bits 0–3 of station table word 13 contain the function code value that may be required by the system to access the transmit frame specification table, which starts at the address contained in the transmit table pointer location of the station table. The function code value is stored in the transmit table function code register by executing a load TTP command. The function codes are defined by the user, and the XPC does not perform any checking on these values.

#### 5.1.16 Transmit Table Pointer

Station table words 14 and 15 contain the 32-bit transmit table pointer. This pointer is the address of the transmit frame specification table. The XPC presents this pointer and the transmit table function code to the system when

5

first accessing the transmit frame specification table. This pointer is stored in the transmit table pointer register by executing a load TTP command. For more details see **5.2 TRANSMIT FRAME SPECIFICATION TABLE**.

## 5.1.17 Dump Area Function Code

Bits 0–3 in station table word 16 contain the function code value that may be required by the system to access the dump area, which starts at the address contained in the dump area pointer entry in the station table. The dump area function code is loaded by the XPC during the execution of the dump registers command.

## 5.1.18 Dump Area Pointer

Words 17 and 18 in the station table contain the address of the dump area in memory. This 32-bit address is loaded into the XPC during the execution of the dump registers command. This command writes internal registers into this dump area in memory for diagnostic purposes.

#### 5.1.19 Rx/Host Status

The Rx/host status entry in station table word 19 contains XPC status information which relates to the condition of the receiver and host interface. Rx/ host status bits are individually cleared by the clear Rx/host status or clear status commands. For more details see **4.5.20 Rx/Host Status Register**.

| F    | E    | D      | С    | В    | А    | 9     | 8   |
|------|------|--------|------|------|------|-------|-----|
| BTS  | NBA  | CRCERR | *    | RREJ | ETST | UDEF  | ILL |
| 7    | 6    | 5      | 4    | 3    | 2    | 1     | 0   |
| AERR | BERR | ABORT  | OVRN | IDLE | RXI  | RFRMR | RTE |

\*Not Used

#### 5.1.20 Tx/Link Status

Word 20 of the station table, Tx/link status, contains the XPC status information relating to the condition of the transmitter and communications link. Tx/link status bits are individually cleared by the clear Tx/link status or clear status commands. For more details see **4.5.21 Tx/Link Status Register**.



\*Not Used

#### 5.1.21 Mode Descriptor

The mode descriptor, in the high-order byte of station table word 21, contains information about the XPC operation mode. The mode descriptor register and the mode descriptor in the station table are updated to reflect the current XPC operation mode as changes occur. The mode descriptor format is shown below. For more details see **4.5.18 Mode Descriptor Register**.

| 7 | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|---|------|------|------|------|------|------|------|
| * | TBEN | ECNT | CONN | WACK | FRMR | RCVR | RBSY |

\*Not Used

#### 5.1.22 Frame Reject Descriptor

The frame reject descriptor, in the low-order byte of station table word 21, contains information about the cause of the current FRMR mode. The frame reject descriptor is a copy of the frame reject descriptor register. Both the register and the station table entry are updated whenever the XPC enters or exits the FRMR mode. The format of the frame reject descriptor is shown below. For more details refer to **4.5.19 Frame Reject Descriptor Register**. In transparent operation, zero is written to this location.



## 5.1.23 V(R)

The V(R) register is stored in the low-order byte of station table word 22 as the result of a dump parameters command. The maximum value of the V(R) register is seven in basic operation mode and 127 in extended operation mode.

## 5.1.24 V(S)

The V(S) register is stored in the high-order byte of station table word 22 as the result of a dump parameters command. The maximum value of the V(S) register is seven in basic operation mode and 127 in extended operation.

## 5.1.25 First Unacknowledged Function Code

Bits 0–3 of word 23 in the station table contain the function code value that may be required by the system to access the contents of the address stored in the first unacknowledged pointer location in the station table. A dump parameters command updates this station table entry. This function code is the same as the transmit table function code. This location is undefined in transparent operation.

#### 5.1.26 First Unacknowledged Pointer

Words 24 and 25 in the station table contain the first unacknowledged pointer. This pointer is the 32-bit address of the first transmit frame specification block whose corresponding transmit buffer has not been acknowledged. All transmit frame specification blocks up to this block identify transmit buffers that have been transmitted and acknowledged. The host can use this information to manage the transmit queue and frame buffers. This entry is updated by the XPC when a dump parameters command is executed. If all transmitted frames have been acknowledged, then this station table entry points to the first memory location following the end of the transmit frame specification table. This location is undefined in transparent operation.

#### 5.1.27 Transmit Function Code

Bits 0–3 of station table word 26 contain the function code value that may be required by the system to access the contents of the address stored in the transmit pointer location in the station table. Execution of the dump parameters command updates this station table entry. The transmit function code is the same as the transmit table function code.

#### 5.1.28 Transmit Table Pointer

Words 27 and 28 in the station table contain the transmit table pointer. This pointer is the 32-bit address of the transmit frame specification block which points to the next transmit buffer to be transmitted or to the transmit buffer that is currently being transmitted. All transmit frame specification blocks up to this block identify transmit buffers that have been transmitted by the XPC. Execution of the dump parameters command updates the transmit pointer entry. When the XPC executes a dump parameters command after all frames have been transmitted, this entry is updated to point to the first memory location following the end of the transmit frame specification table.

## 5.1.29 Receive Function Code

Bits 0–3 of station table word 29 contain the function code value that may be required by the system to access the contents of the address stored in the receive pointer location in the station table. The dump parameters command updates this entry. The receive pointer function code is the same as the receive table function code.

# 5.1.30 Receive Table Pointer

Words 30 and 31 of the station table contain the receive table pointer. This pointer is the 32-bit address of the receive frame specification block, which points to the first empty receive buffer or to the receive buffer that is currently being filled. The host may use this information for receive queue and frame buffer management. The receive pointer is updated when a dump parameters command is executed. When the XPC executes a dump parameters command and the receive frame specification table has ended, this entry points to the first memory location following the end of the table.

#### 5.1.31 Receive Bus/Address Error Function Code

Bits 0–3 of station table word 32 contain the receive bus/address error function code. This function code was presented to the system by the XPC when a bus or address error occurred while accessing the receive frame specification table or a receive memory buffer.

5-12

5

## 5.1.32 Receive Bus/Address Error Pointer

Words 33 and 34 of the station table contain the receive bus/address error pointer. This address was presented to the system bus by the XPC when a bus/address error occurred while accessing the receive frame specification table or a receive memory buffer. An address error is generated by an address presented to the bus by the XPC which produces a XPC  $\overline{CS}$  or IACK. A bus error is generated when the BERR encoding is asserted on the  $\overline{BEC}$  input pins during a XPC bus master cycle. Following an error, the XPC reaccesses the bus to write the receive bus/address error pointer entry in the station table.

#### 5.1.33 Transmit Bus/Address Error Function Code

Bits 0–3 of station table word 35 contain the transmit bus/address error function code. This function code was presented to the system by the XPC when a bus/address error occurred while accessing the transmit frame specification table or a transmit memory buffer.

#### 5.1.34 Transmit Bus/Address Error Pointer

Words 36 and 37 of the station table contain the transmit bus/address error pointer. This 32-bit address was presented to the system by the XPC when a bus/address error occurred while accessing the transmit frame specification table or a transmit memory buffer. An address error is generated by an address presented to the bus by the XPC which produces a XPC  $\overline{\text{CS}}$  or  $\overline{\text{IACK}}$ . A bus error is generated when the BERR encoding is asserted on the  $\overline{\text{BEC}}$  pins during a XPC bus master cycle. When a transmit bus/address error occurs, the XPC reaccesses the system bus to write the transmit bus/address error pointer entry in the station table.

## 5.1.35 Received FRMR Information Field

Words 38, 39, and 40 of the station table contain the information field of the received frame reject. When operating in basic mode (modulo 8), the XPC dumps the 24-bit information field into words 38 and 39. The low byte of word 39 is the same as the high byte of word 39. When operating in extended mode (modulo 128), the 40-bit information field is dumped into words 38, 39, and 40. The low byte of word 40 is the same as the high byte of word 40. This location is not updated in transparent operation.

## 5.2 TRANSMIT FRAME SPECIFICATION TABLE

The transmit frame specification table queues transmit frames for the XPC. These frames are stored in memory buffers located throughout memory. The transmit frame specification table contains a sequential list of transmit frame specification blocks. The transmit frame specification blocks describe the location of transmit buffers and provide information about the transmit queue. The transmit table pointer location in the station table points to the first transmit frame specification block. Each transmit frame specification block has the format shown below.

| WORD | 15 8                  | 7                                  | 0 |  |  |  |  |
|------|-----------------------|------------------------------------|---|--|--|--|--|
| 0    | TRANSMIT TABLE STATUS | TRANSMIT BUFFER FC                 |   |  |  |  |  |
| 1    | TRANSMIT BUFFER AD    | DRESS — HIGH WORD                  |   |  |  |  |  |
| 2    | TRANSMIT BUFFER AD    | TRANSMIT BUFFER ADDRESS — LOW WORD |   |  |  |  |  |
| 3    | TRANSMIT BL           | IFFER LENGTH                       |   |  |  |  |  |

#### 5.2.1 Transmit Table Status

The high-order byte in word zero of a transmit frame specification block contains the queue status. The format of the status byte is shown below.

| F   | E | D | С | В | А | 9 | 8 |
|-----|---|---|---|---|---|---|---|
| EOT | * | * | * | * | * | * | * |

\*Not Used

EOT — End of Table

0 = Another Transmit Frame Specification Block Follows

1 = This Block Is the Last Block in the Table

#### 5.2.2 Transmit Buffer Function Code

The low-order byte of word zero is the transmit buffer function code. This function code value may be required by the system to access the transmit buffer identified by the transmit buffer address. The transmit buffer function code register is loaded from this location by executing a load TTP command to begin a new transmit frame specification table. This register is then automatically loaded by the XPC from each block's transmit buffer function code entry to access each frame buffer until the end of the transmit frame specification table is reached.

| 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|---|---|---|---|-----|-----|-----|-----|
| 0 | 0 | 0 | 0 | FC3 | FC2 | FC1 | FC0 |

## 5.2.3 Transmit Buffer Address

Words 1 and 2 of the transmit frame specification block contain the 32-bit address of the transmit buffer. The transmit buffer pointer register is loaded with this 32-bit address by executing the load TTP command to begin a new transmit frame specification table. This register is then loaded automatically by the XPC from each block's buffer address entry to access each transmit buffer until the end of the transmit frame specification table is reached.

Note that the XPC does not check for an "odd pointer" value and does not generate an address error for the odd word boundary access. In an 8-bit data bus system, an "odd pointer" is proper. In a 16-bit data bus system, the XPC zeros the least significant address bit of the pointer and therefore produces an even word address to the bus. The system designer must ensure that the XPC is not given an "odd pointer" in 16-bit data bus configuration.

## 5.2.4 Transmit Buffer Length

Word 3 of the transmit frame specification block contains the number of bytes to be transmitted from the transmit buffer pointed to by the transmit buffer address. The transmit buffer count register is loaded with this count by executing a load TTP command to begin a new transmit frame specification table. This register is then loaded automatically by the XPC from each block's transmit buffer length entry before transmitting each buffer until the end of the transmit frame specification table is reached.

## 5.2.5 Transmit Bus/Address Error

If a bus error or address error occurs during a transmit frame specification table access or transmit buffer access, the XPC aborts any frame being transmitted and disables the transmit frame specification table as if the end of the table had been reached. Next, the XPC writes the function code and the address that caused the error into the transmit bus/address error entry and updates the Tx/link status entry in the station table. Before I frame transmission may resume, the host processor must instruct the XPC to load TTP.

## 5.3 RECEIVE FRAME SPECIFICATION TABLE

The receive frame specification table queues receive buffers for the XPC. These buffers are stored throughout memory. The receive frame specification table contains a sequential list of receive frame specification blocks. The receive frame specification blocks describe the location of the receive buffers and provide information about the queue. The receive table pointer in the station table points to the first receive frame specification block. Each receive frame specification block has the format shown below.

| WORD | 15 | 8                                  | 7    | 6                 | 0 |  |  |
|------|----|------------------------------------|------|-------------------|---|--|--|
| 0    |    | RECEIVE STATUS                     | L    | RECEIVE BUFFER FC |   |  |  |
| 1    |    | RECEIVE BUFFER ADDRESS — HIGH WORD |      |                   |   |  |  |
| 2    |    | RECEIVE BUFFER ADD                 | DRES | SS — LOW WORD     |   |  |  |
| 3    |    | RECEIVE BUFFER LENGTH              |      |                   |   |  |  |
| 4    |    | RECEIVE FINAL COUNT                |      |                   |   |  |  |

#### 5.3.1 Receive Status

The high-order byte in word zero of the receive frame specification block contains status information. The format is shown below.

| F   | E | D | С | В | А | 9 | 8 |
|-----|---|---|---|---|---|---|---|
| EOT | * | * | * | * | * | * | E |

\*Not Used

#### EOT — End of Table

0 = Another Receive Frame Specification Block Follows

1 = This Block Is the Last Block in the Table

#### E — CRC Error or Nonoctet Aligned Frame Received

Set during transparent operation when the XPC receives a frame which is nonoctet aligned or receives a frame which contains a CRC error. The entire frame, including the received CRC, is written in the corresponding receive buffer. Since a CRC check cannot be performed on a frame which is less than 16 bits long, this bit will not be set for frames shorter than 16 bits.

## 5.3.2 Receive Buffer Function Code

The low-order byte of word zero contains the receive buffer function code and the link bit. This function code may be required by the system to access the receive buffer identified by the receive buffer address. The link bit provides a means to link receive tables.



- L Link
  - 0 = This receive frame specification table is not linked to another receive table.
  - 1 = This receive frame specification table is linked to another receive table. When this bit is set in the last receive frame specification block in the receive table, a valid receive table pointer and FC are stored in the corresponding station table locations.

FC3-FC0

These bits are the function code value associated with the receive memory buffer.

#### 5.3.3 Receive Buffer Address

Words 1 and 2 of the receive frame specification block contain the 32-bit receive buffer address. The receive buffer pointer register is loaded with this 32-bit address by executing the load RTP command to begin a new receive frame specification table. The RBP is then loaded automatically by the XPC from each block's receive buffer address entry as information frames are received until the end of the receive frame specification table is reached.

Note that the XPC does not check for an "odd pointer" value and does not generate an address error for the odd word boundary access. In an 8-bit data bus system, an "odd pointer" is proper. In a 16-bit data bus system, the XPC zeros the least significant address bit of the pointer and therefore presents an even word address to the bus. The system designer must ensure that the XPC is not given an "odd pointer" in a 16-bit data bus configuration.

#### 5.3.4 Receive Buffer Length

Word 3 of the receive frame specification table block contains the number of bytes available in the receive buffer pointed to by the receive buffer address. The receive buffer count register is loaded with this count by a load RTP command to begin a new receive frame specification table. This register is then loaded automatically by the XPC from each block's receive buffer length entry as information frames are received until the end of the receive frame specification table is reached.

#### 5.3.5 Final Count

Word 4 of the receive frame specification block contains the final count. This count is the number of unused bytes in the memory buffer pointed to by the receive buffer address after the XPC has stored a received frame in the buffer. The receive buffer count register is loaded with the number of available bytes in the memory buffer from the receive buffer length entry. As a frame is received, the RBC is decremented. When the entire frame is stored in the receive buffer, the count in the receive buffer count register is written in the final count location in the current receive frame specification block.

#### 5.3.6 Receive Bus/Address Error

If a bus error or address error occurs during a receive frame specification table access or a receive buffer access, XPC disables the receive frame specification table and stops receiving information frames. Next, the XPC writes the function code and the address that caused the error into the receive bus/ address error entry and updates the Rx/host status entry in the station table. The host processor must instruct the XPC to load RTP to resume reception of information frames.

# SECTION 6 COMMAND SET

The host processor issues commands to the XPC to perform various functions by writing to the XPC command register. There are 24 commands that fall in the following four categories:

- 1. Initialization
- 2. Table Handling
- 3. Link Handling
- 4. Test/Diagnostics

When the XPC receives a command from the host processor, the XPC sets the semaphore register to 'FE' hex. The XPC sets the semaphore register to 'FF' after completing the command to indicate to the host processor that it is ready for the next command. The host processor must read the semaphore register before writing the next command to ensure that the last command has been completed by the XPC.

## 6.1 INITIALIZATION COMMANDS

Initialization commands configure the XPC for operation after a hardware or software reset. The four initialization commands specify various system attributes, communication protocol options, and the location of the station table in memory. These commands should only be issued as part of an initialization procedure following reset.

#### 6.1.1 Reset

The reset command (hex 'FF') and hardware reset cause the following actions:

Reset the Receive Channel and Isolate RxD Reset the Transmit Channel, Negate RTS, and Transmit Ones Immediately Relinquish the System Bus Set the Interrupt Vector Register to 'OF' Hex Disable Transmit and Receive Memory Buffers Clear All Rx/Host and Tx/Link Status Bits Clear All Hardware and Station Configuration Bits **Clear All Option Bits** 

Clear All Mode Descriptor and Frame Reject Descriptor Bits Zero Station Table Pointer and Station Table FC Registers Zero Transmit Table Pointer and Transmit Table FC Registers Zero Receive Table Pointer and Receive Table FC Registers Zero Remote Address and Local Address Registers Zero V(R), V(S), and Last Received N(R) Registers Zero Preset Values and Retries Count Register

The transmit clock is required to execute the reset command.

## 6.1.2 Set Station Configuration

The set station configuration command specifies protocol parameters. The command has the following format.



ECRC — Extended CRC

0 = 16-Bit CRC

CRC CCITT  $(X^{16} + X^{12} + X^5 + 1)$ 

1 = 32-Bit CRC

 $(X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X^1 + 1)$ 

ECNT — Extended Control

0 = Basic Control Field Format (Modulo 8)

1 = Extended Control Field Format (Modulo 128)

X — Don't Care

Valid commands are A0-BF.

#### 6.1.3 Set Hardware Configuration

The set hardware configuration command defines the data decoding/encoding scheme, DMA burst control, data organization in memory, and data bus size. The format of the command is shown below.

| 7 | 6 | 5 | 4    | 3    | 2 | 1     | 0    |
|---|---|---|------|------|---|-------|------|
| 1 | 1 | 0 | NRZI | BRSC | Х | DORGM | BUSW |

NRZI — Nonreturned to Zero Invert

- 0 = NRZ Decoding/Encoding
- 1 = NRZI Decoding/Encoding
- BRSC Burst Control
  - 0 = DMA Burst is Unlimited
  - 1 = DMA Burst is Limited to Eight Successive Memory Cycles
- DORGM Data Organization in Memory for a 16-Bit Data Bus System
  - 0 = Data in Memory is Organized with High-Order Byte in Lower Memory Address (Motorola and IBM Convention)
  - 1 = Data in Memory is Organized with Low-Order Byte in Lower Memory Address (DEC and Intel Convention)

(This capability is available only for I frame buffers and not for parameters or tables.)

BUSW — Bus Width 0=8-Bit Data Bus 1=16-Bit Data Bus

X — Don't Care Valid commands include C0–DF.

6.1.4 Load Function Code

The load FC command (hex '80') writes the function code value in the data register into the station table FC register. This command is issued after the host processor has written the function code to the data register.

#### 6.1.5 Load Station Table Pointer

The load station table pointer command (hex '8I') writes the initial station table address from the data register into the station table pointer register. This command is issued after the host processor has written the station table pointer to the data register.

#### 6.2 TABLE HANDLING COMMANDS

The 12 table handling commands cause the XPC to access the station table, transmit table, or receive table.

# 6.2.1 Load Option Bits

The load option bits command (hex '82') loads the option set from the station table into the option bits register. This command is issued as part of the initialization routine or whenever options need to be changed.

#### 6.2.2 Load Preset Values

The load preset values command (hex '83') loads the time-out preset value, time scale divider, pad time select, outstanding frames limit, and retries limit from the station table into the respective XPC internal registers. This command should only be issued following reset or when the XPC is in asynchronous disconnect mode (ADM).

#### 6.2.3 Load Addresses

The load addresses command (hex '84') loads the local and remote addresses from the station table into the internal XPC registers. After these registers are loaded, the XPC is ready to establish the link. The XPC monitors the receive line, asserts RTS, and transmits continuous flags. This command should only be issued following reset or when the XPC is in asynchronous disconnect mode (ADM).

## 6.2.4 Load Transmit Table Pointer

The load transmit table pointer (hex '85') loads the transmit table pointer and the transmit table FC from the station table into the corresponding XPC registers and enables the transmission of a chain of information frames. If the load TTP command is received when the XPC has transmit buffers not yet transmitted, not yet acknowledged in X.25 information transfer, or not yet transmitted in transparent operation, the illegal (ILL) bit in the Rx/host status register is set.

The load TTP command is accepted by the XPC after:

- 1. The last transmit buffer specified by the current transmit frame specification is transmitted in transparent operation or is transmitted and acknowledged in X.25 operation,
- 2. An address or bus error occurs while accessing the transmit frame specification table or a transmit memory buffer,

6-4

- 3. Executing the monitor or end monitor command, or
- 4. The XPC (re)enters the X.25 information transfer mode (ABM/ABME).

When the host processor instructs the XPC to load TTP, the XPC loads the transmit table pointer and transmit table function code registers from the corresponding station table entries. The transmit table pointer register then has the address of the first transmit frame specification block. Before the transmission of each frame, the XPC accesses the current transmit frame specification block to load the transmit buffer function code, transmit buffer address, and transmit buffer length into the corresponding internal registers. The XPC presents the transmit buffer address and function code to the system to load the information contained in the transmit buffer.

During transparent operation, the XPC accesses the next transmit frame specification block and transmits the corresponding frame buffer until the end of the transmit frame specification table is reached. The XPC updates its internal V(S) register after the transmission of each frame. When all frames have been transmitted, the XPC sets the IFAK bit in the Tx/link status register.

During X.25 operation, the XPC accesses the next transmit frame specification block and transmits the corresponding frame buffer according to the X.25 Recommendation until either the outstanding frames limit or the end of the transmit frame specification table is reached. The XPC updates its internal V(S) register after the transmission of an information frame. The XPC monitors the N(R) of incoming frames for reception acknowledgement. When all information frames queued in the transmit frame specification table have been transmitted, the XPC continues to monitor the N(R) of incoming frames have been acknowledged. After all frames have been acknowledged, the XPC sets the IFAK bit in the Tx/link status register.

Note that frames can be added to the transmit queue dynamically as the XPC is transmitting. After adding entries to the end of the transmit queue, the host must set the EOT bit in the last added entry and clear the EOT bit at the previous end of table. If the XPC has already read the EOT bit, then the added entries will not be transmitted. In this case, the continue transmit command (described in **6.2.5 Continue Transmission**) should be issued to the XPC.

The following events cause the XPC to abort the transmission of a frame:

- 1. Transmit or severe BERR/AERR
- 2. Transmit FIFO underrun
- 3. CTS is negated for 1 Tx clock cycle.
- 4. During X.25 operation, if a start link or stop link command is received from the host.
- 5. During X.25 operation, if the XPC receives a frame which causes the XPC to enter FRMR mode. The XPC transmits an ABORT and then transmits the FRMR.
- 6. During X.25 operation, if the XPC receives a REJ, SABM, DISC, DM, UA, FRMR, or an unexpected final bit.

#### 6.2.5 Continue Transmit

The continue transmit command (hex '95') is used to extend the transmit queue after adding entries to the transmit frame specification table. The user should set the EOT bit in the transmit status location of the last added entry and then clear the EOT bit at the previous end of table. Finally, the user should instruct the XPC to "Continue Transmit". This command is useful in the case where the XPC has already detected the previous EOT and will not read a new table entry. Instead, it is waiting for all transmitted frames to be acknowledged, and, during this period, it will not accept a new load transmit table pointer command.

The XPC action after receiving the continue transmit command is:

- 1. In the case where the XPC has not yet reached the previous EOT, no action is taken. The XPC will continue transmission normally with the extended transmit specification table.
- In the case during X.25 operation where the XPC has transmitted the whole table and is now waiting for acknowledgement, the XPC will continue transmission with the extended table when the number of outstanding frames permits it.
- 3. In the case where the whole table has been transmitted and the IFAK status bit has been set, the XPC will continue transmission similar to number 2 above. Note that, in this case, the load transmit table pointer command could be given instead of the continue transmit command.

6-6

#### MOTOROLA

## 6.2.6 Load Receive Table Pointer

The load receive table pointer command (hex '86') loads the receive table pointer and the receive table FC from the station table into the corresponding XPC registers and enables the reception of frames into the Rx FIFO. If the load RTP command is received when the XPC has receive buffers available, the illegal (ILL) bit in the Rx/host status register is set.

This command is accepted by the XPC after:

- 1. Hardware or software reset,
- 2. The last free receive memory buffer specified by the current receive frame specification table is filled,
- 3. An address or bus error occurs while accessing the receive frame specification table or a receive memory buffer, or
- 4. Executing a monitor or end monitor command.

When the host processor instructs the XPC to load RTP, the XPC loads the receive table function code and receive table pointer registers from the corresponding station table entries. The receive table pointer register then contains the address of the first receive frame specification block. The XPC accesses the receive frame specification block to load the receive buffer function code, receive buffer address, and the receive buffer length into its internal registers. The XPC then presents the receive buffer address and function code to the system to store the received information field in the memory buffer. After reception of a frame, the XPC writes the number of unused bytes in the final count entry in the current receive frame specification block and updates its internal V(R) register. Next, the XPC sets the received frame specification block to store incoming frames until the end of the receive frame specification table is reached.

To decrease the possibility of a receiver not ready condition due to a lack of available receive buffers, a method is provided for linking receive frame specification tables. When the EOT (end of table) bit is set in a receive frame specification block, the XPC inspects the link bit value. If the link bit is set, then the XPC loads the receive table pointer and FC registers from the corresponding station table locations. The XPC then sets the RTE (receive table ended) bit in the Rx/host status register and issues an interrupt if enabled. The link operation can be used to implement a cyclical queue by using the original RTP and FC values in the station table. However, the user must read filled receive buffers expediently to ensure that the XPC does not overwrite the buffers with incoming frames.

During transparent operation, if the link bit is not set in the last receive frame specificaton block, the XPC sets the RTE bit in the Rx/host status register. If a frame is received before another receive table is assigned via a load RTP command, the XPC sets the NBA (no receive buffer available) bit in the Rx/ host status register.

During X.25 operation, if the link bit is set in the last receive frame specification block, the XPC transmits an RR frame, and then the XPC is ready to receive additional I frames into memory buffers using the new receive frame specification table. If the link bit is not set in the last receive frame specification block, the XPC sets the RTE bit in the Rx/host status register. If an I frame is received before another receive table is assigned via a load RTP command, the XPC sets the NBA (no receive buffer available) bit in the Rx/ host status register and transmits an RNR frame.

Note that the XPC reads the next receive frame specification block immediately after completing the reception of a frame. The XPC does not reread the block when a new frame is received. So there is a period when the RTE bit is not yet set, but the last block has been read. During this time a modification of the link bit by the user is not detected by the XPC. Following an RTE status indication, the user may wish to verify that the linking operation was performed by the XPC or the user can wait for an NBA status condition which indicates that the link operation was not successful.

#### 6.2.7 Load Station Parameters

The load station parameters command (hex '87') loads the station parameters from the station table into the XPC registers. This command should only be issued following reset or when the XPC is in asynchronous disconnect mode (ADM). This command combines the load option bits, load preset values, and load addresses commands. The XPC will behave as if each of these commands was issued sequentially to the XPC. The XPC will release the bus and rearbitrate for the bus between each command execution.

#### 6.2.8 Update Status

6-8

The update status command (hex '88') allows the host to request current XPC status information. When the XPC receives this command, the XPC will negate the  $\overline{IRQ}$  line (if it was asserted) and write both the Rx/host and Tx/ link status registers to the station table. If the Rx/host or Tx/link status register does not equal zero, the XPC reads the station table mask entries and asserts

IRQ if necessary. Note that the same function is achieved by a clear status command when both station table status clear entries contain all zeros.

#### 6.2.9 Clear Tx/Link Status

The clear Tx/link status command (hex '89') clears the status bits in the Tx/link status register as specified by the Tx/link status clear bits in the station table. When the XPC receives this command, it negates the  $\overline{IRQ}$  line (if it is asserted), reads the Tx/link status clear bits, clears the corresponding status register bits and writes both Tx/link and Rx/host status registers into the station table. If the Tx/link status register does not equal zero, the XPC reads the station table mask entries and asserts  $\overline{IRQ}$  if necessary.

#### 6.2.10 Clear Rx/Host Status

The clear Rx/host status command (hex '8A') clears the Rx/host status bits in the Rx/host status register as specified by the Rx/host status clear bits in the station table. When the XPC receives this command, it negates the IRQ line (if it is asserted), reads the Rx/host status clear bits, clears the corresponding status register bits, and writes both Tx/link and Rx/host status registers into the station table. If the Rx/host status does not equal zero, the XPC reads the station table mask entries and asserts IRQ if necessary.

#### 6.2.11 Clear Status

The clear status command (hex '8B') clears both the Tx/link and Rx/host status bits in the respective XPC registers as specified by the Tx/link status clear bits and the Rx/host status clear bits in the station table. This command combines the clear Tx/link status and clear Rx/host status commands. The XPC will behave as if each of these commands was issued sequentially to the XPC. The XPC will release the bus and rearbitrate for the bus between each command execution.

## 6.2.12 Dump Parameters

The dump parameters command (hex '8C') writes the following XPC parameters into the corresponding station table locations in the order given: Rx/ host status, Tx/link status, mode descriptor, frame reject descriptor, V(R), V(S), first unacknowledged FC and pointer, transmit FC and pointer, and receive FC and pointer.

#### 6.3 LINK HANDLING COMMANDS

The two link handling commands cause the XPC to set the link to a new mode and to automatically handle communication on both channels according to the predefined configuration and option bits.

#### 6.3.1 Start Link

The start link command (hex '8D') initiates the link setup procedure as described in **2.2 LINK SETUP PROCEDURE**. If this command is issued while the waiting acknowledgement (WACK) bit in the mode descriptor register is set, the illegal command (ILL) bit in the Rx/host status register is set.

## 6.3.2 Stop Link

The stop link command (hex '8E') initiates the link disconnect procedure as described in **2.7 LINK DISCONNECT PROCEDURE**. If this command is issued while the waiting acknowledgement (WACK) bit in the mode descriptor register is set, the illegal command (ILL) bit in the Rx/host status register is set.

# 6.4 TEST/DIAGNOSTIC COMMANDS

The five commands in the test/diagnostic category test the XPC circuit and run diagnostics on the link. Upon completion of the serial loopback, DMA transfer, or end monitor, the XPC requires a load addresses command. Until this command is received, the XPC is isolated from the serial link.

## 6.4.1 Dump Registers

The dump registers command (hex '8F') writes the XPC registers listed below to a user specified dump area in external memory. The XPC loads the dump area pointer and FC from the station table. This command should not be executed during X.25 operation while the XPC is in connect mode. When the dump registers command is executed, the T1 timer is reset.

| WORD | 15 12       | 11 8                               | 7 4             | 3 0          |  |  |  |
|------|-------------|------------------------------------|-----------------|--------------|--|--|--|
| 0    | 0000        | 0000                               | 0000            | TTFC         |  |  |  |
| 1    | TRA         | NSMIT TABLE PO                     | INTER — HIGH W  | /ORD         |  |  |  |
| 2    | TRAI        | NSMIT TABLE PO                     | INTER - LOW W   | /ORD         |  |  |  |
| 3    | 0000        | 0000                               | 0000            | RTFC         |  |  |  |
| 4    | REC         | EIVE TABLE POI                     | NTER — HIGH WO  | ORD          |  |  |  |
| 5    | REC         | CEIVE TABLE POIL                   | NTER - LOW WO   | )RD          |  |  |  |
| 6    | 0000        | 0000                               | 0000            | TBFC         |  |  |  |
| 7    | TRAN        | ISMIT BUFFER PO                    | DINTER — HIGH V | VORD         |  |  |  |
| 8    | TRAN        | ISMIT BUFFER PO                    | DINTER — LOW V  | VORD         |  |  |  |
| 9    | 0000        | 0000                               | 0000            | RBFC         |  |  |  |
| 10   | REC         | RECEIVE BUFFER POINTER — HIGH WORD |                 |              |  |  |  |
| 11   | REC         | RECEIVE BUFFER POINTER — LOW WORD  |                 |              |  |  |  |
| 12   |             | TRANSMIT B                         | UFFER COUNT     |              |  |  |  |
| 13   |             | RECEIVE BU                         | FFER COUNT      |              |  |  |  |
| 14   | 0000        | 0000                               | LOCAL A         | DDRESS       |  |  |  |
| 15   | 0000        | 0000                               | REMOTE          | ADDRESS      |  |  |  |
| 16   | MODE DE     | SCRIPTOR                           | FRAME REJEC     | T DESCRIPTOR |  |  |  |
| 17   |             | Rx/HOST                            | STATUS          |              |  |  |  |
| 18   |             | Tx/LINK                            | STATUS          |              |  |  |  |
| 19   | V(          | S)                                 | V(R)            |              |  |  |  |
| 20   | ł           | TIME-0U                            | T PRESET        |              |  |  |  |
| 21   | OUTSTANDING | FRAMES LIMIT                       | RETRIE          | S LIMIT      |  |  |  |
| 22   | LAST RECI   | EIVED N(R)                         | RETRIES         | COUNT        |  |  |  |

# 6.4.2 DMA Transfer

The DMA transfer command (hex '90') tests the handling of parallel data in the logical configuration shown in Figure 6-1. The XPC reads the data from a transmit memory buffer and writes it to a receive memory buffer. Only one memory buffer is read and written each time this command is executed. The XPC transfers data from the transmit buffer to the receive buffer via the data register without using the internal transmit or received FIFOs. The serial link is not affected by this operation.



Figure 6-1. DMA Configuration

The XPC first loads the transmit table function code and pointer and the receive table function code and pointer from the station table. Next, the XPC loads the transmit buffer function code and pointer and the transmit buffer length from the transmit frame specification table. Finally, the XPC loads the receive buffer function code and pointer from the receive frame specification table and begins to transfer the data. The number of bytes to be transferred is specified by the transmit buffer length. The receive buffer final count is not updated.

When the DMA transfer test is completed, the XPC sets the ETST (end of test) bit in the Rx/host status register. The XPC may terminate the DMA transfer test prematurely due to an error condition (BERR, AERR, etc.). In this case, the appropriate status bit is set and the ETST bit is not set. The XPC only accepts this command while in disconnect mode. In connect mode, the XPC sets the ILL (illegal command) bit in the Rx/host status register.

#### 6.4.3 Serial Loopback

The serial loopback command (hex '91') tests the handling of parallel and serial data in the logical configuration shown in Figure 6-2. The XPC reads data from the transmit memory buffer into the transmit FIFO. The data is then serialized and shifted internally into the receive FIFO and onto the TxD line. Finally, the data is stored in the receive memory buffer. Only one memory buffer is read and written each time this command is executed.



Figure 6-2. Serial Loopback Configuration

The XPC first loads the transmit table function code and pointer and the receive table function code and pointer from the station table. Next, the XPC loads the receive buffer function code and pointer from the receive frame specification table. Finally, the XPC loads the transmit buffer function code and pointer and transmit buffer length from the transmit frame specification table and begins to transfer the data. The number of bytes of data to be transmitted is specified by the transmit buffer length. The receive clock (RCLK) is used to synchronize both the receive and transmit channels. RTS is not active during serial loopback.

Following the transmit data, the XPC calculates and writes the CRC to the receive buffer. The CRC is 16 or 32 bits, depending on the CRC option selected. Then following the CRC, the XPC writes one word to indicate whether the XPC receiver determined a CRC error. If no CRC error occurred, all zeros are written in this word. If a CRC error has occurred, all ones are written in this word. Two or three extra words should be reserved in the receive memory buffer for CRC and CRC error indication. The receive buffer final count is not updated.

When the serial loopback test is completed, the XPC sets the ETST (end of test) bit in the Rx/host status register. The XPC may terminate the serial loopback test prematurely due to an error condition (BERR, AERR, etc.). In this case, the appropriate status bit is set and the ETST bit is not set. The XPC only accepts this command while in disconnect mode. In connect mode, the XPC sets the ILL (illegal command) bit in the Rx/host status register.

#### 6.4.4 Monitor

The monitor command (hex '92') allows the XPC to check the communication channel by reading/writing the entire frame from/to memory. The monitor command may be used to perform an external loopback test of the system or to implement any HDLC/SDLC operation mode where all frames are user generated. The XPC transmits and/or receives multiple information frames until an end monitor command is received. The monitor command is only accepted by the XPC in disconnect mode. In connect mode, the XPC sets the ILL (illegal command) bit in the Rx/host status register.

After receiving the monitor command, the XPC monitors the receive line, asserts RTS, and transmits continuous flags. The XPC then requires a load receive table pointer and/or load transmit table pointer command(s). Thereafter, the XPC transmits and/or receives frames using the transmit and/or receive frame specification table(s) pointed to by the TTP and/or RTP respectively.

In each transmit buffer, the user places the address, control, and data (if any) fields. For each frame buffer, the XPC transmits the user-specified number of pad flags, the opening flag, the user-specified address, control and data fields, the XPC-generated CRC, and the closing flag. Zero insertion is performed throughout.

On the receive side, the XPC strips off pad flags and the opening flag for each frame. The address, control, data (if any), and CRC fields are written into the current receive buffer. Zero deletion is performed throughout.

If a receive CRC error is detected by the XPC, the E (CRC error) bit of the receive status byte is set in the corresponding receive frame specification block. To set this bit, the XPC writes the receive status and receive buffer function code bytes. The L (link) bit is written as zero, regardless of its previous state. The EOT (end of table) bit and FC bits are unchanged. Even though the link bit is cleared during the write cycle, the XPC has previously read its value and will handle the linking operation normally. However, the user should not use the link bit value for its own routines.

If no CRC error exists, the XPC does not write the receive status and receive buffer FC bytes. Therefore, the user must initialize the CRC error bit to zero.

The V(S) and V(R) registers are zeroed upon entering the monitor mode. V(S) is incremented with each frame transmission, and V(R) is incremented upon receiving a frame.

The following 11 commands are valid during monitor mode: Load RTP Load TTP Continue Transmit Clear Tx/Link Status Clear Rx/Host Status Clear Status Update Status Dump Parameters Dump Registers End Monitor Test Reset

## 6.4.5 End Monitor

The end monitor command (hex '93') terminates the monitor or transparent operation. After receiving the end monitor command, the XPC quits monitoring the receive line, negates  $\overline{\text{RTS}}$ , and quits transmitting flags. This command is only accepted by the XPC when the CONN bit in the mode descriptor register is not set. If the CONN bit is set, the XPC sets the ILL bit in the Rx/ host status register.

١

MOTOROLA

# SECTION 7 SIGNAL DESCRIPTION

This section contains a brief description of the input and output signals of the XPC. Reference is given (if applicable) to other paragraphs that contain more information about the function being performed.

#### NOTE

The terms **assertion** and **negation** will be used extensively. This is done to avoid confusion when dealing with a mixture of "active low" and "active high" signals. The terms assert and assertion are used to indicate that a signal is active or true, independent of whether that level is represented by a high or low voltage. The terms negate and negation are used to indicate that a signal is inactive or false.

The XPC has two system bus operation modes: master mode and slave mode. The XPC enters slave mode whenever  $\overline{\text{CS}}$  or  $\overline{\text{IACK}}$  is asserted. In this mode, the XPC accepts data from or places data on the data bus according to the level on the R/W pin. When in master mode, the XPC is the bus master and is performing memory reads and writes.

The input and output signals can be functionally organized into the groups shown in Figure 7-1. Each of these groups is discussed in the following paragraphs.

# 7.1 ADDRESS BUS (A1-A31)

This is a 32-bit (when combined with the UDS/A0 signal), unidirectional (with the exception of A1 and A2), three-state bus capable of addressing up to 4 gigabytes of memory. A1 and A2 are bidirectional three-state lines that address internal XPC registers in the slave mode and that provide the lower two address outputs in the master mode.



Figure 7-1. Input and Output Signals

## 7.2 DATA BUS (D0-D15)

The XPC has a 16-bit, bidirectional, three-state bus for the general-purpose data transfer. The XPC can transmit and receive data using an 8-bit or 16-bit data bus. The data bus is used for data input during a host processor write or XPC read cycle and for data output during a host processor read or XPC write cycle.

# 7.3 FUNCTION CODES (FC0-FC3)

These three-state output pins can be used in the master mode to further qualify the value on the address bus by providing 16 separate address spaces that may be defined by the user. The value placed on these lines by the XPC is taken from one of the internal function code registers, depending on the source register for the address used during the DMA cycle. The XPC performs no checking on the function code value.

# 7.4 BUS CONTROL

The following paragraphs describe the bus control signals.

# 7.4.1 Chip Select ( $\overline{CS}$ )

This input pin selects the XPC for a host processor bus cycle. When  $\overline{CS}$  is asserted, the address on A1, A2, and the data strobes select the internal XPC register that will be involved in the transfer.  $\overline{CS}$  should be generated by qualifying an address decode signal with address strobe.

## 7.4.2 Address Strobe (AS)

This bidirectional three-state signal is an output in the master mode which indicates that a valid address is present on the address bus. In the slave mode,  $\overline{AS}$  is an input that is monitored to determine when the XPC can take control of the bus (after the XPC has requested and been granted use of the bus).

## 7.4.3 Read/Write (R/W)

This bidirectional three-state signal indicates the direction of the data transfer during a bus cycle. The  $R/\overline{W}$  pin is an input in the slave mode. A high level indicates that the transfer is from the XPC onto the data bus, and a low level indicates that the transfer is from the data bus into the XPC. The  $R/\overline{W}$  pin is an output in the master mode. A high level indicates that the transfer is from the data bus into the transfer is from the data bus into the transfer is from the data bus into the XPC. The R/W pin is an output in the master mode. A high level indicates that the transfer is from the data bus into the XPC, and a low level indicates that the transfer is from the XPC onto the data bus.

## 7.4.4 Upper Data Strobe (UDS/A0) and Lower Data Strobe (LDS/DS)

These bidirectional three-state signals control the flow of data on the data bus. When using a 16-bit data bus, these pins function as  $\overline{\text{UDS}}$  and  $\overline{\text{LDS}}$ . During any bus cycle,  $\overline{\text{UDS}}$  is asserted if data is to be transferred over data lines D8–D15 and  $\overline{\text{LDS}}$  is asserted if data is to be transferred over data lines D0–D7.  $\overline{\text{UDS}}$  and  $\overline{\text{LDS}}$  are controlled by the XPC when operating in the master mode and by the host when operating in slave mode (see Table 7-1).

When using an 8-bit data bus, these pins function as A0 and  $\overline{DS}$ . A0 is an extension to the lower address lines to provide the address of a byte in the address map and is valid when A1–A31 are valid.  $\overline{DS}$  is a data strobe that enables external data buffers and indicates that valid data is on the bus during a write cycle (see Table 7-1).

| UDS/A0                                    | LDS/DS                                    | R/W                                  | D8-D15                                                                        | D0-D7                                                                         |  |  |  |  |  |
|-------------------------------------------|-------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--|--|--|--|--|
| 16-Bit Transfer                           |                                           |                                      |                                                                               |                                                                               |  |  |  |  |  |
| High<br>Low<br>High<br>High<br>Low<br>Low | High<br>Low<br>Low<br>Low<br>High<br>High | X<br>X<br>Low<br>High<br>Low<br>High | No Valid Data<br>Valid Data<br>No Valid Data<br>X<br>Valid Data<br>Valid Data | No Valid Data<br>Valid Data<br>Valid Data<br>Valid Data<br>No Valid Data<br>X |  |  |  |  |  |
|                                           |                                           | 8-Bit                                | Fransfer                                                                      |                                                                               |  |  |  |  |  |
| X<br>X<br>X                               | Low<br>Low<br>High                        | Low<br>High<br>X                     | No Valid Data<br>X<br>No Valid Data                                           | Valid Data<br>Valid Data<br>No Valid Data                                     |  |  |  |  |  |

#### Table 7-1. Data Strobe Control of Data Bus in Master Mode

X — Don't Care Condition

# 7.4.5 Data Transfer Acknowledge (DTACK)

This bidirectional three-state line signals that the asynchronous bus cycle may be terminated. In the slave processor mode, this output indicates that the XPC has accepted data from the host or placed data on the bus for the host. In the master mode, this input is monitored by the XPC to determine when to terminate a bus cycle. As long as DTACK remains negated, the XPC will insert wait cycles into the bus cycle. When DTACK is asserted, the bus cycle will be terminated.

# 7.5 BUS ARBITRATION

The three signals discussed in the following paragraphs form a bus arbitration circuit that determines which device in a system will be the current bus master.

#### 7.5.1 Bus Request (BR)

This open-drain output pin is asserted by the XPC to request control of the bus.  $\overline{BR}$  is wire-ORed with all other devices that may be bus masters.

## 7.5.2 Bus Grant (BG)

This input is asserted by an external bus arbiter to inform the XPC that it may assume bus mastership as soon as the current bus cycle is completed. The XPC will not take control of the bus until  $\overline{AS}$  and  $\overline{BGACK}$  are negated and the  $\overline{BEC}$  lines are encoded as normal mode.

## 7.5.3 Bus Grant Acknowledge (BGACK)

This bidirectional three-state signal is asserted by the XPC to indicate that it is the current bus master.  $\overrightarrow{BGACK}$  is monitored as an input to determine when the XPC can become bus master.  $\overrightarrow{BGACK}$  is not asserted as an output until the following conditions are met:

- 1. BR is asserted,
- 2. BG is asserted,
- 3.  $\overline{AS}$  is inactive, indicating that the current bus cycle has ended,
- 4. BGACK is inactive, indicating that no other device is claiming bus mastership, and
- 5. BEC lines are encoded as normal mode.

## 7.6 INTERRUPT CONTROL

The two signals discussed in the following paragraphs form an interrupt request/acknowledge handshake circuit with a host processor.

## 7.6.1 Interrupt Request (IRQ)

This open-drain output is asserted by the XPC to request service from the host.

## 7.6.2 Interrupt Acknowledge (IACK)

This input is asserted by the host to acknowledge that it has received an interrupt from the XPC. In response to the assertion of  $\overline{IACK}$ , the XPC will place a vector on D0–D7 that is used by the host to fetch the address of the proper XPC interrupt handler routine.

# 7.7 BUS EXCEPTION CONDITIONS (BEC0-BEC2)

These input lines provide an encoded signal that indicates an abnormal bus condition such as a bus error or reset. For more detailed information refer to **8.3 BUS EXCEPTION CONTROL**.

## 7.8 CLOCK (CLK)

This input signal is the XPC parallel clock. This signal can range from 4 to 16 MHz. The XPC can operate with a CLK input, which is synchronous or asynchronous with respect to the host clock, as long as the bus requirements are satisfied.

# 7.9 MODEM CONTROL

The following paragraphs describe the modem control signals.

## 7.9.1 Carrier Detect (CD)

The XPC considers the data on the RxD pin to be valid only if the  $\overline{CD}$  input pin is asserted. If the  $\overline{CD}$  pin is negated for one Tx clock cycle during frame reception, the XPC sets the abort bit in the Rx/host status register.

## 7.9.2 Request-to-Send (RTS)

The XPC asserts the RTS output pin upon executing the load addresses or monitor test commands. At this point, the XPC starts transmitting continuous flags. The XPC negates the RTS pin upon hardware or software reset or upon executing the end monitor or serial loopback command.

#### 7.9.3 Clear-to-Send (CTS)

If the  $\overline{\text{CTS}}$  input pin is not asserted within 68 cycles of the Tx clock following the assertion of  $\overline{\text{RTS}}$  or if the  $\overline{\text{CTS}}$  pin is negated for more than one cycle while transmitting interframe flags, the XPC sets the clear to send lost (CTSL) bit in the Tx/link status register. If the  $\overline{\text{CTS}}$  pin is negated for more than one cycle during a frame transmission, the XPC sets the CTSL bit in the Tx/link status register and aborts the current frame.

#### 7.10 TRANSMIT

The following paragraphs describe the transmit signals.

#### 7.10.1 Transmit Clock (TCLK)

This input signal can range from dc to 10 MHz. The XPC synchronizes the transmit data to this clock. Ten transmit clock cycles are required during reset to initialize the serial logic. The TCLK must be a clean signal which meets the specified electrical characteristics. Any noise in the TCLK signal will cause the XPC to behave erratically.

#### 7.10.2 Transmit Data (TxD)

This output pin is used to send the serial bit stream.

# 7.11 RECEIVE

The following paragraphs describe the receive signals.

#### 7.11.1 Receive Clock (RCLK)

This input signal can range from dc to 10 MHz. The receive data is synchronized to this clock. The RCLK must be a clean signal which meets the specified electrical characteristics. Any noise in the RCLK signal will cause the XPC to behave erratically.

## 7.11.2 Receive Data (RxD)

This input line receives the serial bit stream from the communications link synchronized to the receive clock.

#### 7.12 SIGNAL SUMMARY

Table 7-2 is a summary of all the signals discussed in the previous paragraphs.

| Signal Name               | Mnemonic  | Input/Output | Active State | Driver Type              |
|---------------------------|-----------|--------------|--------------|--------------------------|
| Address Bus               | A1-A2     | Input/Output |              | Three-State              |
| Address Bus               | A3-A31    | Output       |              | Three-State              |
| Data Bus                  | D0-D15    | Input/Output |              | Three-State              |
| Function Codes            | FC0-FC3   | Output       |              | Three-State              |
| Bus Exception Codes       | BEC0-BEC2 | Input        | Low          |                          |
| Upper Data Strobe         | UDS/A0    | Input/Output | Low          | Three-State <sup>1</sup> |
| Lower Data Strobe         | LDS/DS    | Input/Output | Low          | Three-State <sup>1</sup> |
| Address Strobe            | ĀS        | Input/Output | Low          | Three-State <sup>1</sup> |
| Read/Write                | R/W       | Input/Output | High/Low     | Three-State <sup>1</sup> |
| Chip Select               | CS        | Input        | Low          |                          |
| Data Transfer Acknowledge | DTACK     | Input/Output | Low          | Three-State <sup>1</sup> |
| Bus Request               | BR        | Output       | Low          | Open-Drain <sup>2</sup>  |
| Bus Grant                 | BG        | Input        | Low          |                          |
| Bus Grant Acknowledge     | BGACK     | Input/Output | Low          | Three-State              |
| Carrier Detect            | CD        | Input        | Low          |                          |
| Request-to-Send           | RTS       | Output       | Low          | Normal                   |
| Clear-to-Send             | CTS       | Input        | Low          |                          |
| Transmit Clock            | TCLK      | Input        |              |                          |
| Transmit Data             | TxD       | Output       |              | Normal                   |
| Receive Clock             | RCLK      | Input        |              |                          |
| Receive Data              | RxD       | Input        |              |                          |
| Interrupt Request         | ĪRQ       | Output       | Low          | Open-Drain <sup>2</sup>  |
| Interrupt Acknowledge     | IACK      | Input        | Low          |                          |
| Clock                     | CLK       | Input        |              |                          |

#### Table 7-2. Signal Summary

<sup>1</sup>These signals require a pullup resistor to maintain a high voltage when in the high-impedance or negated state. However, when these signals go to the high-impedance state, they will first drive the pin high momentarily to reduce the signal rise time.

<sup>2</sup>These signals are wire-ORed and require a pullup resistor to maintain a high voltage when not driven.

A second secon

## SECTION 8 BUS OPERATION

The following section describes the bus signal operation of the XPC during bus arbitration, bus exception conditions, slave operations, master operations, and the reset operation. Functional timing diagrams are included to assist in the definition of signal timing; however, these diagrams are not intended as parametric timing definitions. For detailed relationships, refer to **SECTION 10 ELECTRICAL SPECIFICATIONS**.

## 8.1 SLAVE OPERATION MODE

In the slave operation mode, the XPC is a peripheral slave to the bus master. The XPC enters the slave operation mode when chip select or interrupt acknowledge is asserted. During slave mode operations, the XPC accepts data from, or places data on the data bus according to the level on the R/W pin. The data transferred will either be loaded into or read from the internal register that is selected by the encoding of A1 and A2 and the data strobes (refer to Figure 4-1). This mode of operation is used during XPC initialization to load system configuration information and the initial station table pointer and function code into the XPC. After initialization, the slave mode of operation is used by the host processor to place commands into the XPC command register.

In slave mode, the XPC can operate with a CLK input, which is synchronous or asynchronous with respect to the host clock, as long as the bus requirements are satisfied. In the functional diagrams showing host operations, the bus master is assumed to be an M68000 Family processor with a clock signal identical to the XPC CLK signal. The state numbers (S0, S1, etc.) refer to the numbering convention for those processors.

### 8.1.1 Host Processor Read Cycles

During host processor read cycles, the XPC places data on the data bus and asserts DTACK to indicate to the bus master that the data is valid. Figure 8-1 shows the functional timing for a word read cycle on a 16-bit data bus. The timing for even- and odd-byte host reads on a 16-bit data bus or any

host read on an 8-bit bus are identical, with the encoding of  $\overline{\text{UDS}}/\text{A0}$  and  $\overline{\text{LDS}/\text{DS}}$  selecting the proper byte. The 8-bit semaphore register is always selected during a host processor read cycle, regardless of the A1, A2 encoding, as this is the only XPC register that is directly readable by the host processor. When the upper data bus is selected during a host read cycle, the XPC drives D8–D15 to 'FF'.



Figure 8-1. Host Processor Read Cycle

The XPC begins a host read cycle when  $\overline{CS}$  is asserted and the R/W line is high. The XPC responds to  $\overline{CS}$  by decoding  $\overline{UDS}/A0$  and  $\overline{LDS}/\overline{DS}$ , driving the appropriate data lines, and asserting  $\overline{DTACK}$ . The XPC then waits until both  $\overline{UDS}/A0$  and  $\overline{LDS}/\overline{DS}$  or  $\overline{CS}$  is negated, three-states the data lines, negates and three-states  $\overline{DTACK}$ . The content of the semaphore register is always hex 'FE' or hex 'FF'.

#### 8.1.2 Host Processor Write Cycles

During host processor write cycles, the XPC accepts data from the data bus and asserts DTACK to indicate to the bus master that the data has been loaded into the selected register. The only XPC registers that are directly writable by the host processor are the command register (CR), interrupt vector register (IV), and the data register (DR). The timing is identical for even- and odd-byte host processor writes to a 16-bit data bus or any host processor write to an 8-bit data bus. The proper byte is selected by the encodings of  $\overline{\text{UDS}}/\text{A0}$  and  $\overline{\text{LDS}}/\overline{\text{DS}}$  signals.

A host processor write cycle begins when  $\overline{CS}$  is asserted and  $R/\overline{W}$  is low. The XPC responds by decoding A1, A2,  $\overline{UDS}/A0$ , and  $\overline{LDS}/\overline{DS}$  signals. When a valid register (CR, IV, or DR) is selected, the XPC accepts the data from the data bus, places the data into the selected register, and asserts  $\overline{DTACK}$ . Next, the XPC waits for both  $\overline{LDS}/\overline{DS}$  and  $\overline{UDS}/A0$  or  $\overline{CS}$  to be negated and then negates and three-states  $\overline{DTACK}$ . The timing for this operation is shown in Figure 8-2.



Figure 8-2. Host Processor Write Cycle

## 8.1.3 Interrupt Acknowledge Cycles

During interrupt acknowledge cycles, the host processor is responding to an interrupt request from the XPC. The timing of an interrupt acknowledge cycle is identical to an odd-byte read cycle, except that it is started by the assertion of an IACK signal rather than  $\overline{CS}$ .  $\overline{CS}$  and  $\overline{IACK}$  are mutually exclusive signals and should not be asserted at the same time. If  $\overline{IACK}$  is asserted when the XPC is bus master, an address error is generated.

The interrupt acknowledge operation is started by the XPC when  $\overline{IACK}$  is asserted and  $\overline{LDS/DS}$  is asserted. The XPC responds to  $\overline{IACK}$  by placing a vector number on D0–D7 and asserting  $\overline{DTACK}$ . The vector number remains valid on the data bus until  $\overline{IACK}$  or  $\overline{LDS}$  is negated by the host processor, at which time the XPC will three-state the data lines, negate and three-state  $\overline{DTACK}$ . The timing for this operation is shown in Figure 8-3.



Figure 8-3. Interrupt Acknowledge Cycle

#### 8.2 MASTER OPERATION MODE

In the master operation mode, the XPC is the bus master and performs memory read and write operations. The XPC can operate in either an 8-bit or a 16-bit bus configuration.

#### 8.2.1 XPC Read Cycles

During a DMA read operation, the XPC controls the transfer of data from memory into the XPC. The functional timing for a DMA read operation is shown in Figure 8-4. The timing for an even- or odd-byte read on a 16-bit data bus or any read on an 8-bit data bus is identical, with the encoding of UDS/A0 and LDS/DS selecting the proper byte.



MC68605 USER'S MANUAL



Figure 8-4. Read Cycle and Slow Read Cycle

The XPC drives FC0–FC3 and A1–A31 pins with the address of the memory location that the XPC wants to read. Then  $R/\overline{W}$  is driven high,  $\overline{AS}$ ,  $\overline{UDS}/A0$ , and/or  $\overline{LDS}/\overline{DS}$  are asserted.  $\overline{DTACK}$  is asserted by memory when valid data from memory is on lines D0–D15. If using an 8-bit bus, only the data on lines D0–D7 is assumed to be valid. When  $\overline{DTACK}$  is asserted, the data is latched by the XPC from the data lines, and the bus cycle is terminated.

#### 8.2.2 XPC Write Cycles

During a DMA write operation, the XPC controls the transfer of data to memory from the XPC. The functional timing for this operation is shown in Figure 8-5. The timing for an even- or odd-byte write on a 16-bit data bus or any write to an 8-bit data bus is identical, with encoding of UDS/A0 and LDS/DS selecting the proper byte.

The XPC drives FC0–FC3 and A1–A31 pins with the address of the memory location to be written. Then R/W is driven low,  $\overline{AS}$  is asserted, and, depending on data size,  $\overline{UDS}/A0$  and/or  $\overline{LDS}/\overline{DS}$  are asserted. Data to be written to memory is placed on the bus and, when  $\overline{DTACK}$  is asserted, the cycle is terminated. On a slow write, as shown in Figure 8-5, the bus cycle is extended because  $\overline{DTACK}$  is not asserted by the end of S4.

#### 8.2.3 XPC DMA Priority Scheme

The XPC has four DMA channels which are used to access the receive specification table, the receive memory buffers, the transmit specification table, and the transmit memory buffers. During one DMA burst, the XPC can access one or more of the following: the station table, the dump area, the receive specification table, the receive memory buffers, the transmit specification table, and/or the transmit memory buffers. Commands from the host that are received between DMA bursts are handled by the XPC microcode and have a higher priority than the receiver and transmitter. For each memory access, an internal arbiter determines which section of the XPC requires priority: the microcode controller, the receiver, or the transmitter. The following priority scheme is used for memory accesses:

- 1. microcode controller, if execution of microcode requires a memory access
- 2. receiver, if Rx FIFO  $\geq$ 7 full words
- 3. transmitter, if Tx FIFO  $\geq$ 7 empty words
- 4. receiver, if Rx FIFO  $\geq$ 3 full words

- 5. transmitter, if Tx FIFO  $\geq$ 3 empty words
- 6. receiver, if Rx FIFO < 3 full words and end of receive frame
- 7. transmitter, if Tx FIFO < 3 empty words and end of transmit frame

where Rx FIFO counts the number of full words and Tx FIFO counts the number of empty words.

For example, the Rx FIFO has 6 full words, the Tx FIFO has 8 empty words, and no commands have been received from the host. The sequential memory cycles are: Tx, Tx, Rx, Rx, Rx, Rx, Tx, Tx, Tx, Tx, Rx, Rx, Tx, and Tx. As the state of the Rx FIFO and Tx FIFO changes, the priority of the required memory accesses for each changes.

#### 8.2.4 XPC Memory Bandwidth Requirements

The serial bit rate and system clock frequency determine the percent of memory bandwidth required by the XPC. The serial bit rate determines how often the XPC has to request the bus, and the system clock frequency and memory access time affect how long the XPC will control the bus during each DMA burst. If the memory is slow and/or there are other bus masters in the system, then Tx FIFO underruns and Rx FIFO overruns are more likely to occur.

The following equation can be used to estimate the average percent of memory bandwidth used by the XPC during transmit and receive operations:

% of memory bandwidth = 
$$\begin{bmatrix} \text{Term 1} & \text{Term 2} & \text{Term 3} \\ \hline (4+W) \cdot \text{T}_{\text{Sys}} \\ BUSW \cdot \text{T}_{\text{ser}} \end{bmatrix} \cdot \begin{bmatrix} 1 + \left(\frac{8+10}{2 \cdot F}\right) \end{bmatrix} \cdot \begin{bmatrix} \frac{F}{F+H+N} \end{bmatrix} \cdot Q$$

where

- $T_{SVS}$  = period of the system clock
  - $T_{ser}$  = period of the serial clock
    - W = number of memory wait states
    - 4 = number of system clocks per memory cycle
- BUSW = the data bus width, either 8 or 16 bits
- $(4+W) \cdot T_{SVS} =$  the memory cycle time
- $BUSW \cdot T_{ser}$  = the time to receive or transmit the data which can be accessed in one memory cycle
  - **Term 1** = the ratio of the time to access the receive or transmit data in memory to the time it takes to receive or transmit the data on the serial line
    - 8 = the number of bytes accessed in the transmit frame descriptor in order to transmit a frame (frame overhead)
    - 10 = the number of bytes accessed in the receive frame descriptor in order to receive a frame (frame overhead)
    - F = the average number of bytes of data in the information field of transmit and receive frames
    - 2 = required because the XPC is full duplex
  - **Term 2** = factor necessary to account for frame overhead on receive and transmit
    - H = 4 for basic mode (1 byte address, 1 byte control, and 2 bytes CRC)

5 for extended mode (1 byte address, 2 bytes control, and 2 bytes CRC)

**Note:** if extended CRC is used, 2 more bytes must be added

- N = the number of pad flags between frames
- **Term 3** = percent of the serial line used for transmission and reception of data
  - Q = overhead for bus arbitrations
    - 1.33 for  $F_{ser}$  < 4 MHz, 16-bit bus
    - 1.2 for  $F_{ser} > 4$  MHz, 16-bit bus
    - 1.16 for  $F_{ser}$  < 4 MHz, 8-bit bus
    - 1.1 for  $F_{ser} > 4$  MHz, 8-bit bus





## 8.3 BUS EXCEPTION CONTROL

To fully support the M68000 bus architecture, the XPC has three encoded inputs, BECO–BEC2, that indicate abnormal bus cycle termination conditions. These three lines function in a similar manner to the RESET, HALT, and BERR signals on an M68000 processor, but have different definitions than the processor counterparts. Except for RESET, bus exception encodings are ignored if the XPC is not the bus master. Table 8-1 shows the definition of each encoding of the BECO–BEC2 pins. Figure 8-6 illustrates how the three inputs may be generated from signals normally present in an M68000 system.

| BEC2 | BEC1 | BEC0 | Definition           | XPC Action                                                                                                                          |
|------|------|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| High | High | High | No Exception         | No Affect                                                                                                                           |
| High | High | Low  | Halt (Release Bus)   | Halt after DTACK and Release the Bus                                                                                                |
| High | Low  | High | Bus Error            | Terminate the Current Cycle and Release the Bus                                                                                     |
| High | Low  | Low  | Retry                | Terminate the Current Cycle and Rerun the Same Cycle Again After the Exception Disappears                                           |
| Low  | High | High | Relinquish and Retry | Terminate the Current Cycle, Release the Bus —<br>Rerun Last Cycle after Rearbitration                                              |
| Low  | High | Low  | Undefined, Reserved  | Current Cycle Terminated with $\overline{\text{DTACK}}$ , but No Bus Cycles Run until $\overline{\text{BEC}}$ = No Exception        |
| Low  | Low  | High | Undefined, Reserved  | Current Cycle Terminated with $\overline{\text{DTACK}}$ , but No Bus Cycles Run until $\overline{\text{BEC}} = \text{No Exception}$ |
| Low  | Low  | Low  | Reset                | Reset XPC Registers and Logic                                                                                                       |

Table 8-1. BEC Encoding Definitions



Figure 8-6. Example **BEC** Signal Generation Circuit

### 8.3.1 BEC0–BEC2 Synchronization

The bus exception signals are synchronized as are all asynchronous inputs. The particular clock cycle in which the BEC lines become synchronized internally affects the length of the current bus cycle. In the first case, a very early bus exception occurs in which the bus exception signal is asserted more than one clock cycle before DTACK is asserted. This bus exception causes no delay in the termination of the bus cycle. In case two, which is the typical case, the bus exception occurs in the same clock cycles as DTACK. This bus exception causes one clock cycle delay in the termination of the current bus cycle. In the third case, the bus exception occurs in the clock cycle after DTACK was asserted. This bus exception causes one clock delay in the termination of the current bus cycle.

A late bus exception which does not meet electrical specification (58) may cause improper behavior of the XPC, including bus lockup.

#### 8.3.2 Bus Exception Functions

The 3-bit bus exception control code allows eight different bus termination conditions.  $\overline{\text{BEC0}}$  is the least significant bit and  $\overline{\text{BEC2}}$  is the most significant bit.

- **8.3.2.1 NORMAL TERMINATION.** When HHH is encoded on the BEC pins, the XPC operates in normal mode and DTACK is used to terminate bus cycles.
- **8.3.2.2 HALT**. HHL encoded on the BEC pins halts the XPC after the current bus cycle is terminated by the assertion of DTACK. The XPC releases ownership of the bus and enters the idle state until the BEC pins return to normal mode (all zeros). At this time, the XPC will rearbitrate for the bus and continue DMA operations if necessary. The halt timing diagram is shown in Figure 8-7.
- **8.3.2.3 BUS ERROR**. When HLH is encoded on the BEC pins, the XPC aborts the current bus cycle and releases bus mastership. After the BEC lines return to normal, the XPC reports the bus error to the host processor by writing the address and function code that caused the error into the station table. The XPC also sets the bus/address error bit in the appropriate status register and interrupts the host. The channel in which the bus error occurred is disabled





MC68605 USER'S MANUAL



Figure 8-8. Read Cycle with Bus Error

until the host clears the status bit. After the  $\overline{\text{BEC}}$  lines return to normal, the XPC may rearbitrate for the bus and continue DMA operations if necessary. A bus error condition is shown in the timing diagram in Figure 8-8.

- **8.3.2.4 RETRY**. When HLL is encoded on the BEC pins, the XPC terminates the current bus cycle and enters a waiting mode. BGACK remains asserted, so the XPC retains bus mastership. When the BEC pins return to normal (all zeros), the XPC reruns the same bus cycle, using the same address and function code. Figures 8-9 and 8-10 show the timing diagram for a retry operation.
- **8.3.2.5 RELINQUISH AND RETRY**. When the BEC pins are encoded with LHH, the XPC terminates the current bus cycle and relinquishes bus mastership. One debounce delay after the BEC pins have returned to normal, the XPC will rearbitrate for the bus and rerun the same bus cycle as shown in Figure 8-11.
- **8.3.2.6 RESET.** When LLL is encoded on the BEC pins, the XPC executes an internal reset sequence. After completion of the reset, the XPC enters the idle mode.
- **8.3.2.7 UNDEFINED BEC CODE.** When LHL or LLH is encoded on the BEC pins, the XPC takes no action as shown in Figure 8-12. However, the cycle may be extended one more clock cycle due to the debouncing of the BEC lines. The XPC terminates the current cycle after DTACK is asserted. No further bus cycles run until BEC = No Exception.

### 8.4 BUS ARBITRATION

Once the host has initialized the XPC and the XPC enters connect mode, the XPC uses the M68000 bus arbitration protocol to request bus mastership before entering the master mode of operation. Bus arbitration is a technique used by bus master devices to request, be granted, and acknowledge bus mastership. The bus arbitration timing diagram is shown in Figure 8-13.



NOTE: Two alternatives of DTACK and retry are drawn in the first one. The second cycle is postponed for one additional cycle due to BEC synchronization.

Figure 8-9. Write Cycle with Retry



8-16



Figure 8-10. Read Cycle with Retry



Figure 8-11. Read Cycle with Relinquish and Retry

## 8.4.1 Requesting the Bus

External devices capable of becoming bus masters request the bus by asserting the  $\overline{BR}$  signal. This is a wire-ORed signal that indicates to the external bus arbiter that some external device requires control of the external bus. The XPC requests the bus when a command is issued that requires a DMA operation or when data needs to be moved to or from the internal FIFOs.







Figure 8-12. Read Cycle with Undefined BEC0-BEC2





Figure 8-13. Bus Arbitration

#### 8.4.2 Receiving the Bus Grant

The external bus arbiter, which may be a separate unit such as the MC68452 Bus Arbitration Module or the arbiter built into an M68000 processor, will then assert  $\overline{BG}$  to indicate that bus mastership will belong to the XPC as soon as the current bus master has released the bus.  $\overline{BG}$  may be routed through a daisy-chained network or through a specific priority-encoded network. The bus arbiter is not affected by the external method of arbitration as long as the protocol is obeyed.

#### 8.4.3 Acknowledgement of Mastership

Upon receiving a bus grant, the XPC waits until  $\overline{AS}$  and  $\overline{BGACK}$  are negated before asserting  $\overline{BGACK}$ . The negation of  $\overline{AS}$  indicates that the previous master has completed its cycle; negation of  $\overline{BGACK}$  indicates that the previous master has released control of the bus. When these conditions are met, the XPC asserts  $\overline{BGACK}$ . After  $\overline{BGACK}$  is asserted,  $\overline{BR}$  is negated to allow the external arbiter to begin arbitration for the next bus master. The XPC maintains control of the bus for up to eight bus cycles or until all data transfers have been serviced, based upon the value in the burst control (BRSC) bit of the hardware configuration register.  $\overline{BGACK}$  is negated after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of  $\overline{BGACK}$ .

#### 8.4.4 Bus Arbitration State Machine

The bus arbitration control unit in the XPC is implemented with a finite state machine. The state diagram is shown in Figure 8-14. All asynchronous signals to the XPC are synchronized before they are used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time has been met. The input signal is sampled on the falling edge of the clock and is valid internally after the next rising edge.



Figure 8-14. MC68605 Bus Arbitration Unit State Diagram

## 8.5 RESET OPERATION

The XPC is reset by a host processor command (hex 'FF') or by a hardware reset encoded on the  $\overline{\text{BEC0}}$ ,  $\overline{\text{BEC2}}$  lines. A reset encoding on the  $\overline{\text{BEC}}$  lines should be asserted for at least 10 clock cycles. Normally the XPC requires 32 system clock cycles and ten TCLK cycles before it is ready to accept a command after reset.

## 8.6 BUS OVERHEAD TIME

In asynchronous bus systems, such as those defined for the M68000 Family, a certain amount of time is used to synchronize incoming signals and is thus "wasted time" since no data transfer activity can take place during those periods. In many applications, the synchronization overhead time required to switch bus masters must be known to predict system behavior. For the

XPC there are two types of overhead: overhead for the XPC to take control of the bus and overhead that occurs when the XPC releases control of the bus. The timing diagram for the front-end and back-end overhead for the XPC is shown in Figure 8-15.

#### 8.6.1 Front-End Overhead

This overhead is the delay that occurs from the time that the host processor terminates a bus cycle by negating  $\overline{AS}$  to when the XPC starts the bus cycle by placing the function codes and address on the bus. It is assumed that  $\overline{BG}$  is asserted and  $\overline{BGACK}$  is negated prior to negation of  $\overline{AS}$  by the host processor so that no additional synchronization delays are introduced by those signals. After one synchronization delay plus 1 1/2 clock cycles, the XPC asserts  $\overline{BGACK}$  to assume control of the bus and begins the DMA cycle. The front-end overhead is between 2 1/2 and 3 1/2 clock cycles.

#### 8.6.2 Back-End Overhead

This overhead is the delay between when the XPC has completed all operations and negated  $\overline{AS}$  and the start of the next bus cycle, which is controlled by another bus master. The XPC negates the  $\overline{BGACK}$  signal one cycle after the last bus cycle. One synchronization delay plus one-half clock cycle later, the new bus master begins the next bus cycle.





MOTOROLA

# SECTION 9 XPC/HOST PROCESSOR INTERFACE

Figure 9-1 shows the connections between the XPC and a host processor with the XPC having local memory. The configuration for the XPC and the MC68020 microprocessor is shown in Figure 9-2. A typical modem interface is shown in Figure 9-3.



Figure 9-1. XPC-to-Host-Processor Interface



Figure 9-2. XPC-to-MC68020 Interface

9-2



Figure 9-3. Serial Interface Examples

.

# SECTION 10 ELECTRICAL SPECIFICATIONS

This section contains the electrical specifications and associated timing information for the MC68605. Refer to the timing diagrams (Figures 10-1– 10-12) found on foldout pages at the back of this document.

#### **10.1 MAXIMUM RATINGS**

| Rating                | Symbol          | Value          | Unit |
|-----------------------|-----------------|----------------|------|
| Supply Voltage        | V <sub>DD</sub> | -0.3 to $+7.0$ | V    |
| Input Voltage         | Vin             | -0.3 to $+7.0$ | V    |
| Operating Temperature | Τ <sub>Α</sub>  | 0 to 70        | °C   |
| Storage Temperature   | Tstg            | – 55 to 150    | °C   |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either GND or V<sub>DD</sub>).

## **10.2 THERMAL CHARACTERISTICS**

| Characteristic            | Symbol | Value | Unit |
|---------------------------|--------|-------|------|
| Thermal Resistance<br>PGA | θJΑ    | 33    | °C/W |

 $T_{J} = T_{A} + (P_{D} \cdot \theta_{JA})$ 

 $P_D = (V_{DD} \bullet I_{DD}) + P_{I/O}$ 

where:

PI/O is the lower dissipation on pins (user determined) which can be neglected in most cases.

For TA = 70°C and PD = 0.55 W (a) 12.5 MHz TJ = 88°C



#### **10.3 POWER CONSIDERATIONS**

The average chip-junction temperature, TJ, in °C can be obtained from:  $T_J = T_A + (P_D \bullet \theta_J A) \eqno(1)$ 

where:

| = Ambient Temperature, °C                                  |
|------------------------------------------------------------|
| = Package Thermal Resistance, Junction-to-Ambient, °C/W    |
| = PINT + PI/O                                              |
| = IDD × VDD, Watts — Chip Internal Power                   |
| = Power Dissipation on Input and Output Pins, Watts — User |
| Determined                                                 |
|                                                            |

For most applications PI/O<PINT and can be neglected.

The following is an approximate relationship between PD and TJ (if PI/O is neglected):

$$P_D = K \div (T_J + 273^{\circ}C)$$
 (2)

Solving equations (1) and (2) for K gives:

$$K = P_D \bullet (T_A + 273^{\circ}C) + \theta_{JA} \bullet P_D^2$$
(3)

where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring P<sub>D</sub> (at equilibrium) for a known T<sub>A</sub>. Using this value of K, the values of P<sub>D</sub> and T<sub>J</sub> can be obtained by solving equations (1) and (2) iteratively for any value of T<sub>A</sub>.

## **10.4 DC ELECTRICAL CHARACTERISTICS**

All specifications are valid under the following conditions:  $V_{DD}$  = 4.75 V to 5.25 V,  $V_{SS}$  = 0 V,  $T_A$  =  $T_L$  to  $T_H$  and 130 pF total capacitance on output pins.

| Characteristic                                                         | Symbol          | Min                  | Max                  | Unit |
|------------------------------------------------------------------------|-----------------|----------------------|----------------------|------|
| Input High Voltage (Except System Clock)                               | VIH             | 2.0                  | V <sub>DD</sub>      | V    |
| Input Low Voltge (Except System Clock)                                 | VIL             | V <sub>SS</sub> -0.3 | 0.8                  | V    |
| Input High Voltage (System Clock)                                      | VCIH            | 2.4                  | V <sub>DD</sub>      | v    |
| Input Low Voltage (System Clock)                                       | VCIL            | V <sub>SS</sub> -0.3 | 0.5                  | V    |
| Input Leakage Current                                                  | lin             | _                    | 20                   | μA   |
| Input Capacitance                                                      | C <sub>in</sub> |                      | 13                   | pF   |
| Three-State Leakage Current (2.4/0.5 V)                                | ITSI            |                      | 20                   | μΑ   |
| Open-Drain Leakage Current (2.4 V)                                     | lod             |                      | 20                   | μA   |
| Output High Voltage (I <sub>OH</sub> =400 μA)                          | VOH             | 2.4                  |                      | v    |
|                                                                        | V <sub>OL</sub> |                      | 0.5<br>0.5<br>0.5    | V    |
| Power Dissipation @ 10 MHz, 0°C<br>@ 12.5 MHz, 0°C<br>@ 16.67 MHz, 0°C | PD              |                      | 0.50<br>0.55<br>0.65 | W    |

## **10.5 AC ELECTRICAL CHARACTERISTICS**

High and low outputs are measured at 2.0 V minimum and 0.8 V maximum, respectively. High and low inputs are driven to 2.4 V and 0.5 V, respectively, for AC test purposes. However, input specifications are still measured from 2.0 V to 0.8 V. All specifications are valid under the following conditions:  $V_{DD}$ =4.75 V to 5.25 V,  $V_{SS}$ =0 V,  $T_A$ = $T_L$  to  $T_H$ , output load = 130 pF, and output current as specified in **DC ELECTRICAL CHARACTERISTICS**. See Figures 10-1–10-12.

| Num. | Ohannatariatia                                                                                   | 10 1 | MHz          | 12.5 | 12.5 MHz     |     | 16.67       |                 |
|------|--------------------------------------------------------------------------------------------------|------|--------------|------|--------------|-----|-------------|-----------------|
| Num. | Characteristic                                                                                   | Min  | Max          | Min  | Max          | Min | Max         | Unit            |
| 1    | Asynchronous Input Setup Time                                                                    | 20   | —            | 20   | _            | 10  |             | ns              |
| 2    | UDS, LDS Inactive to CS, IACK Inactive                                                           | —    | 100          |      | 80           | _   | 60          | ns              |
| 3    | CLK Low (On Which UDS or LDS and CS or<br>IACK are Recognized) to Data-Out Valid<br>(see Note 5) | _    | 1/2<br>+ 150 | _    | 1/2<br>+ 120 |     | 1/2<br>+ 90 | Clk. Per.<br>ns |
| 4    | CS or IACK High to Data-Out High Impedance                                                       |      | 60           | _    | 50           | _   | 35          | ns              |
| 5    | LDS/DS High to Data-Out Hold Time (see Note 6)                                                   | 0    | —            | 0    |              | 0   |             | ns              |
| 6    | IACK or CS Low to DTACK High<br>(Driving Three-State DTACK High)                                 |      | 80           |      | 70           |     | 60          | ns              |
| 7    | CLK Low (On Which UDS or LDS and CS or<br>IACK are Recognized) to DTACK Low<br>(see Note 5)      |      | 2<br>+ 90    | _    | 2<br>+ 80    |     | 2<br>+ 50   | Clk. Per.<br>ns |
| 8    | CLK Low to DTACK Low                                                                             |      | 90           | _    | 80           | _   | 50          | ns              |
| 9    | Data-Out Valid to DTACK Low                                                                      | 20   | —            | 20   | _            | 20  |             | ns              |
| 10   | DTACK Low to UDS, LDS, CS, IACK High<br>(Earliest)                                               | 100  |              | 80   |              | 60  | —           | ns              |

|      | AC ELECTRICAL CHARACT                                                                                                                                                                                         |           |           |           |           |           | ·         |                |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|----------------|--|
| Num. | Characteristic                                                                                                                                                                                                | 10        | MHz       | 12.5      | MHz 16.0  |           | MHz       | Unit           |  |
|      |                                                                                                                                                                                                               | Min       | Max       | Min       | Max       | Min       | Max       |                |  |
| 11   | CS or IACK or Data Strobes (The Earliest) High<br>to DTACK High (see Note 7)                                                                                                                                  |           | 60        | _         | 50        | _         | 40        | ns             |  |
| 12   | DTACK High to DTACK High Impedance<br>(At End of Bus Cycle)                                                                                                                                                   |           | 50        | _         | 50        |           | 40        | ns             |  |
| 13   | UDS, LDS Inactive Time                                                                                                                                                                                        | 1         |           | 1         |           | 1         |           | Clk. Per.      |  |
| 14   | CS, IACK Inactive Time                                                                                                                                                                                        | 0         |           | 0         |           | 0         | ·         | ns             |  |
| 15   | A1–A2 Valid to UDS, UDS, CS (The Latest One)<br>Low (Write)                                                                                                                                                   | 30        | —         | 20        |           | 20        |           | ns             |  |
| 16   | DTACK Low to Data and A1–A2 Hold Time                                                                                                                                                                         | 100       | _         | 80        | —         | 60        | —         | ns             |  |
| 17   | UDS or LDS, CS or IACK (The Latest One)<br>Low to Data-In Valid                                                                                                                                               |           | 80        | _         | 70        | —         | 60        | ns             |  |
| 18   | $R/\overline{W}$ Valid to $\overline{UDS}$ or $\overline{LDS}$ , $\overline{CS}$ or $\overline{IACK}$<br>(The Latest One) Low                                                                                 | 20        | —         | 20        |           | 10        | _         | ns             |  |
| 19   | $\overline{\text{UDS}}$ , $\overline{\text{LDS}}$ High to R/ $\overline{\text{W}}$ High                                                                                                                       | 0         |           | 0         | _         | 0         | —         | ns             |  |
| 20   | CLK High to IRQ Low                                                                                                                                                                                           |           | 100       | _         | 80        |           | 60        | ns             |  |
| 21   | Reserved                                                                                                                                                                                                      |           |           |           |           |           |           |                |  |
| 22   | Reserved                                                                                                                                                                                                      |           |           |           |           |           |           |                |  |
| 23   | CLK High to BR Low                                                                                                                                                                                            |           | 60        | —         | 55        | _         | 40        | ns             |  |
| 24   | CLK High to BR High Impedance                                                                                                                                                                                 |           | 55        | _         | 50        |           | 40        | ns             |  |
| 25   | BGACK Low to BR High Impedance                                                                                                                                                                                | 20        |           | 20        | _         | 10        | —         | ns             |  |
| 26   | BG Active/Inactive to CLK Low Setup Time                                                                                                                                                                      | 20        |           | 20        |           | 10        |           | ns             |  |
| 27   | CLK Low to BGACK Low                                                                                                                                                                                          |           | 60        | _         | 55        | _         | 40        | ns             |  |
| 28   | CLK High to BGACK High Impedance                                                                                                                                                                              |           | 45        | _         | 40        |           | 40        | ns             |  |
| 29   | $\overline{\text{AS}}$ and $\overline{\text{BGACK}}$ High (The Latest One) to $\overline{\text{BGACK}}$<br>Low (When $\overline{\text{BG}}$ is Previously Asserted)                                           | 2<br>+ 20 | 3<br>+ 80 | 2<br>+ 20 | 3<br>+ 70 | 2<br>+ 10 | 3<br>+ 50 | Clk. Per<br>ns |  |
| 30   | BG Low to BGACK Low (No Other Bus Master)                                                                                                                                                                     | 2<br>+ 20 | 3<br>+ 80 | 2<br>+ 20 | 3<br>+ 70 | 2<br>+ 10 | 3<br>+ 50 | Clk. Per<br>ns |  |
| 31   | BR High Impedance to BG High                                                                                                                                                                                  | 0         |           | 0         | —         | 0         |           | ns             |  |
| 32   | Clock on which $\overline{\text{BGACK}}$ Low to Clock on which $\overline{\text{AS}}$ Low                                                                                                                     | 1.5       | 1.5       | 1.5       | 1.5       | 1.5       | 1.5       | Clk. Per       |  |
| 33   | Clock Low to BGACK High                                                                                                                                                                                       |           | 55        | —         | 50        |           | 40        | ns             |  |
| 34   | CLK on which $\overline{BR}$ Low to CLK on which $\overline{BGACK}$<br>Low (Assuming that $\overline{BG}$ is Active and $\overline{BGACK}$<br>and $\overline{AS}$ are Inactive for at Least 2 CLK<br>Periods) | 1.5       | 1.5       | 1.5       | 1.5       | 1.5       | 1.5       | Clk. Per       |  |
| 35   | CLK on which $\overline{\text{AS}}$ is High to CLK on which $\overline{\text{BGACK}}$ is High                                                                                                                 | —         | 1         | -         | 1         | _         | 1         | Clk. Per       |  |
| 36   | CLK High to Address Valid                                                                                                                                                                                     |           | 100       | _         | 80        |           | 60        | ns             |  |
| 37   | CLK High to Address/FC High Impedance                                                                                                                                                                         | _         | 70        |           | 60        |           | 50        | ns             |  |
| 38   | CLK High to FC Valid                                                                                                                                                                                          |           | 60        |           | 55        |           | 50        | ns             |  |
| 39   | Address Valid to AS Valid                                                                                                                                                                                     | 20        |           | 15        |           | 10        | _         | ns             |  |
| 40   | CLK High to $\overline{AS}$ , $\overline{UDS}$ , $\overline{LDS}$ Low                                                                                                                                         |           | 50        | _         | 40        |           | 40        | ns             |  |
| 41   | CLK to AS, UDS, LDS High                                                                                                                                                                                      |           | 55        | _         | 50        |           | 40        | ns             |  |

## **10.5 AC ELECTRICAL CHARACTERISTICS (Continued)**

| Num. | Characteristic                                                                                                                      |             | ИНz         | 12.5 MHz    |             | 16.67 MHz   |             | Unit            |
|------|-------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-----------------|
|      |                                                                                                                                     | Min         | Max         | Min         | Max         | Min         | Max         |                 |
| 42   | AS High to Address/FC Invalid                                                                                                       | 20          |             | 10          |             | 0           |             | ns              |
| 43   | CLK High to AS, UDS, LDS High Impedance                                                                                             |             | 70          |             | 60          |             | 45          | ns              |
| 44   | CLK to R/W High (see Note 4)                                                                                                        |             | 55          | <u> </u>    | 50          |             | 45          | ns              |
| 45   | CLK Low to R/W High Impedance                                                                                                       |             | 70          |             | 60          |             | 45          | ns              |
| 46   | UDS, LDS High to Data-In Invalid                                                                                                    | 0           |             | 0           |             | 0           |             | ns              |
| 47   | AS, UDS, LDS High to DTACK High<br>(Earliest of AS, UDS, or LDS)                                                                    | 0           | 100         | 0           | 90          | 0           | 60          | ns              |
| 48   | Data-In to CLK Low Setup Time Required when<br>DTACK Satisfies (1) (see Note 1)                                                     | 10          | _           | 10          | _           | 5           | _           | ns              |
| 49   | DTACK Low to Data-In Valid Required when<br>DTACK does not Satisfy (1) (see Note 2)                                                 |             | 65          |             | 50          |             | 40          | ns              |
| 50   | CLK High to R/W Low                                                                                                                 |             | 60          | _           | 55          |             | 40          | ns              |
| 51   | AS Low to Data-Out Valid (Write)                                                                                                    |             | 90          |             | 80          |             | 60          | ns              |
| 52   | CLK Low to Data-Out Valid                                                                                                           |             | 55          |             | 55          |             | 40          | ns              |
| 53   | Data-Out Valid to UDS, LDS Low                                                                                                      | 20          |             | 15          |             | 10          |             | ns              |
| 54   | UDS, LDS High to Data-Out Invalid                                                                                                   | 20          | _           | 15          | _           | 0           | _           | ns              |
| 55   | CLK High to Data-Out Hold Time                                                                                                      | 0           | 100         | 0           | 100         | 0           | 60          | ns              |
| 56   | No Exception to BR (DTACK Active)                                                                                                   | 1.5<br>+ 20 | 2.5<br>+ 80 | 1.5<br>+ 20 | 2.5<br>+ 70 | 1.5<br>+ 10 | 2.5<br>+ 50 | Clk. Per.<br>ns |
| 57   | DTACK Low to Asynchronous Exception Active<br>Required When DTACK Does Not Satisfy (1)<br>(see Note 2)                              |             | 55          |             | 35          |             | 30          | ns              |
| 58   | Exception Active to CLK Low Setup Time<br>Synchronous Input ("Late Exception")<br>Required when DTACK Satisfies (1)<br>(see Note 1) | 45          |             | 45          |             | 20          | —           | ns              |
| 59   | Exception Active to CLK Low Setup Time<br>Asynchronous Input (Required when DTACK<br>is Absent) (see Note 3)                        | 20          | _           | 20          | —           | 10          | —           | ns              |
| 60   | AS, UDS, LDS High to Exception Inactive                                                                                             | 0           | —           | 0           | —           | 0           |             | ns              |
| 61   | Exception Inactive to CLK Low Setup Time<br>(for Identification of No Exception)                                                    | 20          | _           | 20          | —           | 10          |             | ns              |
| 62   | No Exception to $\overline{\text{BR}}$ (DTACK Inactive)                                                                             | 2.5<br>+ 20 | 3.5<br>+ 80 | 2.5<br>+ 20 | 3.5<br>+ 70 | 2.5<br>+ 10 | 3.5<br>+ 50 | Clk. Per.<br>ns |
| 63   | RESET (on BEC0-BEC2) Width                                                                                                          | 10          | —           | 10          | —           | 10          |             | Clk. Per.       |
| 64   | CLK Frequency                                                                                                                       | 4           | 10          | 4           | 12.5        | 4           | 16.67       | MHz             |
| 65   | CLK Period                                                                                                                          | 100         | 250         | 80          | 250         | 60          | 250         | ns              |
| 66   | CLK Width High (see Note 8)                                                                                                         | 45          | 125         | 35          | 125         | 25          | 125         | ns              |
| 67   | CLK Rise/Fall Time (see Note 8)                                                                                                     |             | 10          | _           | 5           | _           | 5           | ns              |
| 68   | CLK Width Low (see Note 8)                                                                                                          | 45          | 125         | 35          | 125         | 25          | 125         | ns              |
| 69   | RCLK, TCLK Frequency                                                                                                                | 0           | 10          | 0           | 12.5        | 0           | 16.67       | MHz             |
| 70   | RxD to RCLK High Setup Time                                                                                                         | 35          | _           | 35          | _           | 25          |             | ns              |
| 71   | RCLK High to RxD Hold Time                                                                                                          | 5           |             | 5           |             | 5           |             | ns              |

## **10.5 AC ELECTRICAL CHARACTERISTICS (Continued)**

| Num. | Characteristic                  | Characteristic 10 MHz |     | 12.5 MHz |     | 16.67 MHz |     | Unit |
|------|---------------------------------|-----------------------|-----|----------|-----|-----------|-----|------|
| Num. | Mir                             |                       | Мах | Min      | Max | Min       | Max | Unit |
| 72   | RCLK, TCLK Rise/Fall Time       | _                     | 10  | _        | 10  |           | 5   | ņs   |
| 73   | RCLK, TCLK Width Low            | 45                    | _   | 35       | -   | 25        |     | ns   |
| 74   | RCLK, TCLK Width High           | 45                    | _   | 35       | _   | 25        | _   | ns   |
| 75   | RCLK, TCLK Period               | 100                   | _   | 80       | —   | 60        | _   | ns   |
| 76   | TCLK Low to TxD Valid           | 10                    | 80  | 10       | 60  | 10        | 45  | ns   |
| 77   | Reserved                        |                       |     |          |     |           |     |      |
| 78   | CD Low to RCLK Low Setup Time   | 25                    |     | 25       |     | 25        | _   | ns   |
| 79   | CTS Low to TCLK High Setup Time | 25                    | _   | 25       | —   | 25        | _   | ns   |

## 10.5 AC<sub>\*</sub>ELECTRICAL CHARACTERISTICS (Concluded)

NOTES:

1. If DTACK satisfies the asynchronous setup time (1), then (48) is required for the data-in setup time and (58) for the synchronous exception setup time. Erroneous behavior may occur if (58) is not satisfied.

2. If DTACK does not satisfy (1), then (49) is required for data-in and (57) for the exception. Erroneous behavior may occur if (57) is not satisfied.

3. Active exception when DTACK is absent must satisfy the asynchronous setup time (59). Erroneous behavior may occur if (59) is not satisfied.

4. R/W rises on the end of a write cycle (i.e., on the phase following S7). If the XPC relinquishes the bus, then R/W is three-stated one phase later. When the XPC takes the bus, R/W is three-stated until S2 and changes on that phase.

5. Data (3) and DTACK (7) will be timed from the latest of CS and either data strobe during an MPU cycle. Data (3) and DTACK will be timed from the latest of IACK and either data strobe during an IACK cycle.

6. If CS or IACK is negated before UDS/LDS, the data bus will be three-stated (4), possibly before UDS/LDS negation.

7. If an 8-bit bus is used, only LDS need be considered. If a 16-bit bus is used, both UDS and LDS must negate to apply to this specification.

8. The clock signal during test has 5 ns of rise time and 5 ns of fall time. For system implementations that have less clock rise and fall time, the clock pulse minimum should be commensurately wider such that:

1. System (TCL + (TCR + TCF) ÷ 2)  $\ge$  (minimum t<sub>cyc</sub>) ÷ 2 2. System (TCH + (TCR + TCF) ÷ 2)  $\ge$  (minimum t<sub>cyc</sub>) ÷ 2

where:

TCL is CLK width low (see electrical specification #68)

TCH is CLK width high (see electrical specification #66)

TCR is CLK rise time

TCF is CLK fall time

t<sub>cvc</sub> is CLK period (see electrical specification #65)

# SECTION 11 ORDERING INFORMATION AND MECHANICAL DATA

This section contains the pin assignments and package dimensions for the PGA (pin grid array) for the MC68605RC. In addition, detailed information is provided to be used as a guide when ordering.

## **11.1 PACKAGE TYPES**

| Suffix | Package Type                    | Comments                                                      |
|--------|---------------------------------|---------------------------------------------------------------|
| R      | Pin Grid Array (PGA)<br>Ceramic | Depopulated Center Pins<br>Solder Lead Finish<br>No Standoffs |
| RC     | Pin Grid Array (PGA)<br>Ceramic | Depopulated Center Pins<br>Gold Lead Finish<br>No Standoffs   |
| FN     | Plastic Leaded Chip<br>Carrier  | Suitable for Socketing or<br>Surface Mounting                 |

MOTOROLA

## **11.2 PIN ASSIGNMENTS**



# **11.3 PACKAGE DIMENSIONS**



- 3. DIMENSIONING AND TOLERANCING PER Y14.5M, 1982.
- 4. CONTROLLING DIMENSION: INCH.

MC68605 USER'S MANUAL

D

G

K

0.43

3.56

2.54 BSC

0.61

4.95

0.017

0.024

0.100 BSC

0.140 0.195

MOTOROLA

ţ

| 1  | Introduction                             |
|----|------------------------------------------|
| 2  | XPC Implementation of LAPB Procedure     |
| 3  | XPC Transparent Mode of Operation        |
| 4  | Internal Registers                       |
| 5  | Shared Memory Structures                 |
| 6  | Command Set                              |
| 7  | Signal Description                       |
| 8  | Bus Operation                            |
| 9  | <b>XPC/Host Processor Interface</b>      |
| 10 | Electrical Specifications                |
| 11 | Ordering Information and Mechanical Data |



| STATE                                                                          | I FRAME<br>WITH<br>POLL | I FRAME<br>W/O POLL | RR<br>WITH<br>POLL  | RR<br>W/O POLL       | REJ<br>WITH<br>POLL  | REJ<br>W/O POLL      | RNR<br>WITH<br>POLL  | RNR<br>W/O POLL      | SABM<br>WITH OR<br>W/O POLL | DISC.<br>WITH OR<br>W/O POLL | RR<br>WITH<br>FINAL     | RR<br>W/O<br>FINAL | REJ<br>WITH<br>FINAL    | REJ<br>W/O<br>FINAL | RNR<br>WITH<br>FINAL    | RNR<br>W/O<br>FINAL | UA WITH<br>OR W/O<br>FINAL | DM<br>WITH<br>FINAL | DM<br>W/O<br>FINAL | FRMR<br>WITH OR<br>W/O FINAL | LOCAL<br>START<br>COMMAND | LOCAL<br>STOP<br>COMMAND | STATION<br>BECOMES<br>BUSY | BUSY<br>CONDITION<br>CLEAR | T1<br>EXPIRES        | N2 × T1<br>IS<br>EXCEEDED | NS<br>SEQUENCE<br>ERROR  | INVALID<br>NR<br>RECEIVED | UNRECOGNIZED<br>FRAME<br>RECEIVED |
|--------------------------------------------------------------------------------|-------------------------|---------------------|---------------------|----------------------|----------------------|----------------------|----------------------|----------------------|-----------------------------|------------------------------|-------------------------|--------------------|-------------------------|---------------------|-------------------------|---------------------|----------------------------|---------------------|--------------------|------------------------------|---------------------------|--------------------------|----------------------------|----------------------------|----------------------|---------------------------|--------------------------|---------------------------|-----------------------------------|
| S1<br>DISCONNECTED                                                             | DM, F=1                 | -                   | DM, F = 1           | make                 | DM, F=1              |                      | DM, F = 1            |                      | UA, F P<br>TO S5            | DM, F = P                    | _                       | _                  | _                       |                     | _                       | _                   | _                          | SABM<br>TO S2       | SABM<br>TO S2      | _                            | SABM<br>TO S2             | DISC<br>TO S4            | Х                          | _                          | Х                    | х                         | *DM                      | *DM                       | *DM                               |
| S2<br>LINK SETUP                                                               | _                       |                     |                     | -                    |                      | _                    | _                    |                      | UA, F P                     | DM, F – P<br>TO S1           |                         |                    | -14°88                  |                     | _                       |                     | TO \$5                     | T0 S1               |                    | -                            | x                         | x                        | Х                          |                            | SABM                 | T0 S1                     | -                        |                           | _                                 |
| S3<br>FRAME REJECT                                                             | FRMR,<br>F 1            | FRMR,<br>F 0        | FRMR,<br>F =- 1     | FRMR,<br>F 0         | FRMR,<br>F 1         | FRMR,<br>F = 0       | FRMR,<br>F = 1       | FRMR,<br>F 0         | UA, F – P<br>TO S5          | UA, F -= P<br>TO S1          |                         |                    |                         | -                   |                         | _                   | Markan.                    | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | Х                          | _                          | FRMR<br>F = 0        | SABM<br>TO S2             | *FR                      | *FR                       | *FR                               |
| S4<br>DISCONNECT<br>REQUEST                                                    | _                       |                     | _                   | _                    | _                    | _                    | _                    |                      | DM, F = P<br>TO S1          | UA, F P                      |                         |                    |                         | _                   | No. 1990                | nation .            | TO \$1                     | TO S1               | _                  |                              | х                         | x                        | Х                          | _                          | DISC                 | TO S1                     |                          | _                         | _                                 |
| S5<br>INFORMATION<br>TRANSFER                                                  | RR, F 1                 | **                  | RR, F - 1           | **                   | RR, F = 1            | **                   | RR, F=1<br>TO S9     | RR, F = 0<br>10 S9   | UA, F – P                   | UA, F P<br>TO S1             | (UNXF)<br>SABM<br>TO S2 | ***                | (UNXF)<br>SABM<br>TO S2 | ***                 | (UNXF)<br>SABM<br>TO S2 | TO \$9              | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F = P<br>TO S8        | х                          | RR, P = 1<br>TO S7   | SABM<br>TO S2             | *J<br>TO S6              | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S6<br>REJ FRAME<br>SENT                                                        | RR, F 1<br>TO S5        | **<br>TO S5         | RR, F 1             | **                   | RR, F 1              | **                   | RR, F = 1<br>TO S14  | 88, F 0<br>10 \$14   | UA, F – P<br>TO S5          | UA, F · P<br>TO S1           | (UNXF)<br>SABM<br>TO S2 | ***                | (UNXF)<br>SABM<br>TO S2 | ***                 | (UNXF)<br>SABM<br>TO S2 | TO S14              | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F = P<br>TO S8        | x                          | RR, P – 1<br>TO S7   | SABM<br>TO S2             | IF P = 1<br>Tx RR, F = 1 | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S7<br>WAITING I FRAME<br>ACKNOWLEDGE-<br>MENT                                  | RR, F = 1               | RR, F – 0           | RR, F – 1           | RR, F - 0            | RR, F – 1            | RR, F – 0            | RR, F = 1<br>TO S12  | RR, F 0<br>TO \$12   | UA, F = P<br>TO S5          | UA, F – P<br>TO S1           | ***<br>TO S5            | —                  | ***<br>TO S5            | _                   | TO S9                   | T0 S12              | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F=P<br>TO S11         | х                          | RR, P = 1            | SABM<br>TO S2             | *J                       | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S8<br>STATION<br>BUSY                                                          | RNR, F = 1              | RNR, F = 0          | RNR, F = 1          | *N                   | RNR, F == 1          | *N                   | RNR, F = 1<br>TO S10 | RNR, F 0<br>10 S10   | UA, F = P                   | UA, F – P<br>TO S1           | (UNXF)<br>SABM<br>TO S2 | ***                | (UNXF)<br>SABM<br>TO S2 | ***                 | (UNXF)<br>SABM<br>TO S2 | T0 S10              | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | Х                          | **J<br>TO \$5              | RNR, P = 1<br>TO S11 | SABM<br>TO S2             | RNR, F == P              | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S9<br>REMOTE<br>STATION BUSY                                                   | RR, F 1                 | RR, F = 0           | RR, F = 1<br>TO S5  | **<br>T0 S5          | RR, F = 1<br>TO S5   | **<br>TO S5          | RR, F = 1            | RR, F → O            | UA, F = P<br>TO S5          | UA, F P<br>TO S1             | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S5       | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S5        | (UNXF)<br>SABM<br>TO S2 | _                   | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F = P<br>TO S10       | х                          | RR, P = 1<br>TO S12  | SABM<br>TO S2             | *J<br>TO S14             | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S10<br>BOTH STATIONS<br>BUSY                                                   | RNR, F = 1              | RNR, F = 0          | RNR, F - 1<br>TO S8 | *N<br>TO S8          | RNR, F 1<br>TO S8    | *N<br>TO S8          | RNR, F = 1           | RNR, F - 0           | UA, F = P<br>TO S8          | UA, F = P<br>TO S1           | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S8       | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S8        | (UNXF)<br>SABM<br>TO S2 | -                   | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | Х                          | **J<br>TO S9               | RNR, P = 1<br>TO S13 | SABM<br>TO S2             | RNR, F = P               | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S11<br>WAITING I FRAME<br>ACKNOWLEDGE-<br>MENT AND STA-<br>TION BUSY           |                         | RNR, F = 0          | RNR, F = 1          | RNR, F = 0           | RNR, F = 1           | RNR, F = 0           | RNR, F = 1<br>TO S13 | RNR, F - 0<br>10 S13 |                             | UA, F – P<br>TO S1           | ***<br>TO S8            | _                  | ****<br>TO S8           |                     | TO \$10                 | TO \$13             | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | Х                          | **J<br>TO S7               | RNR, P = 1           | SABM<br>TO S2             | RNR, F = P               | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S12<br>WAITING I FRAME<br>ACKNOWLEDGE-<br>MENT AND RE-<br>MOTE STATION<br>BUSY | RR, F = 1               | RR, F = 0           | RR, F 1<br>TO S7    | RR, F = 0<br>T0 S7   | RR, F - 1<br>TO S7   | RR, F=0<br>T0 S7     | RR, F = 1            | BR, F O              | UA, F P<br>TO S5            | UA, F=P<br>TO S1             | ***<br>TO S5            | TO \$7             | ***<br>TO S5            | T0 S7               | TO S9                   |                     | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F = P<br>TO S13       | x                          | RR, P = 1            | SABM<br>TO S2             | *J                       | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S13<br>WAITING I FRAME<br>ACKNOWLEDGE-<br>MENT AND BOTH<br>STATIONS BUSY       | RNR, F=1                | RNR, F = 0          | RNR, F=1<br>T0 S11  | RNR, F = 0<br>TO S11 | RNR, F = 1<br>TO S11 | RNR, F = 0<br>TO S11 | RNR, F=1             | RNR, E O             | UA, F = P<br>TO S8          | UA, F = P<br>TO S1           | ***<br>TO S8            | T0 S11             | ****<br>TO S8           | T0 S11              | TO S10                  | _                   | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | х                          | **J<br>TO S12              | RNR, P = 1           | SABM<br>TO S2             | RNR, F = P               | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |
| S14<br>REJ FRAME SENT<br>AND REMOTE<br>STATION BUSY                            | RR, F = 1<br>TO S9      | RR, F = 0<br>TO S9  | RR, F = 1<br>TO S6  | **<br>TO S6          | RR, F = 1<br>TO S6   | **<br>TO S6          | RR, F = 1            | BB, F O              | UA, F = P<br>TO S5          | UA, F = P<br>TO S1           | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S6       | (UNXF)<br>SABM<br>TO S2 | ***<br>TO S6        | (UNXF)<br>SABM<br>TO S2 | _                   | SABM<br>TO S2              | SABM<br>TO S2       | SABM<br>TO S2      | SABM<br>TO S2                | SABM<br>TO S2             | DISC<br>TO S4            | RNR, F=P<br>TO S10         | х                          | RR, P = 1<br>TO S12  | SABM<br>TO S2             | IF P = 1<br>Tx RR, F = 1 | FRMR(Z)<br>TO S3          | FRMR(W)<br>TO S3                  |

\*\* If I available then Tx I frame else Tx RR, F = 0
\*\*\* If I available then Tx I frame else do nothing
\*N If I available then Tx I frame else Tx RNR, F = 0
\*\*N If P = 1 then Tx RNR, F = 1 else if I available then Tx I frame else Tx RNR, F = 0
\*FR If P = 1 then Tx FRMR, F = 1 else if P = 0 then Tx FRMR, F = 0 else do nothing
\*DM If P = 1 then Tx DM, F = 1 else do nothing
\*I if no PE I EPAME is outcoding the transmitter I. E = P else if P = 1 then Tx PR

\*J If no REJ FRAME is outstanding then transmit REJ, F=P else if P=1 then Tx RR, F=1 else do nothing
\*J If the I field of a correctly received frame has been discarded (due to the busy condition) then Tx REJ, F=0 else Tx RR, F=0

Do nothing
 X This event never occurs in this state

UNXF Unexpected final bit

.

Figure 2-1. XPC State Diagram



Figure 10-1. Host Processor Read Cycle Timing Diagram







Figure 10-3. Interrupt Acknowledge Cycle Timing Diagram

.



Figure 10-4. Bus Arbitration Timing Diagram





The solid lines assume that the communication controller was bus master on the last cycle. The dotted lines assume that there was a different bus master

Figure 10-5. Read Cycle and Slow Read Cycle Timing Diagram

Figure 10-4. Bus Arbitration Timing Diagram

Figure 10-5. Read Cycle and Slow Read Cycle Timing Diagram







CASE 1: If DTACK satisfies (1), then (48) and (58) are required; if DTACK is active but does not satisfy (1), then (49) and (57) are required. CASE 2: If DTACK is not active, then (59) is required for the exception active setup time. Parameter (61) is always required for the exception inactive setup time.

## Figure 10-7. XPC Read Cycle with Retry Timing Diagram

Figure 10-6. Write Cycle Timing Diagram

Figure 10-7. XPC Read Cycle with Retry Timing Diagram



Figure 10-8. Read Cycle with Bus Error Timing Diagram



The above occurs when the XPC requires the bus cycle after a previous exception.





Two alternatives of  $\overrightarrow{\text{DTACK}}$  and exception. Case one has  $\overrightarrow{\text{DTACK}}$  occur after exception and case two has exception occur after  $\overrightarrow{\text{DTACK}}$ . Note that a HALT cycle can be terminated only by  $\overrightarrow{\text{DTACK}}$ .

#### Figure 10-10. Short Exception Cycle Timing Diagram

MOTOROLA Foldout-5

Figure 10-8. Read Cycle with Bus Error Timing Diagram Figure 10-9. BR After Previous Exception Timing Diagram Figure 10-10. Short Exception Cycle Timing Diagram







Figure 10-12. XPC Serial Data RxD, TxD, and Serial Clocks (RCLK, TCLK) Timing Diagram

Figure 10-11. Clock (CLK) Timing Diagram

Figure 10-12. XPC Serial Data RxD, TxD, and Serial Clocks (RCLK, TCLK) Timing Diagram



#### Literature Distribution Centers:

USA: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036. EUROPE: Motorola Ltd.; European Literature Center; 88 Tanners Drive, Blakelands, Milton Keynes, MK14 5BP, England. ASIA PACIFIC: Motorola Semiconductors H.K. Ltd.; P.O. Box 80300; Cheung Sha Wan Post Office; Kowloon Hong Kong. JAPAN: Nippon Motorola Ltd.; 3-20-1 Minamiazabu, Minato-ku, Tokyo 106 Japan.