| Index |
|-------|
|-------|

# 1 Introduction

2 Installation

3 Hardware User's Manual

4 Appendices to the Hardware User's Manual

5 Copies of Data Sheets

6 Eagle Module

7 Introduction to VMEPROM

8 Appendices to the VMEPROM Introduction

9 Bios Source Code Listing

10 User Notes

11 Options/Applications/ Modifications

н. 1

# SYS68K/CPU-40/41 USER'S MANUAL

Revision No. 2 February 1992

FORCE COMPUTERS Inc./GmbH All Rights Reserved

> This document shall not be duplicated, nor its contents used for any purpose, unless express permission has been granted.

Copyright by FORCE COMPUTERS®

•

# **INTRODUCTION**

This page intentionally left blank

## ΝΟΤΕ

The information in this document has been carefully checked and is believed to be entirely reliable. FORCE COMPUTERS makes no warranty of any kind with regard to the material in this document, and assumes no responsibility for any errors that may appear in this document. FORCE COMPUTERS reserves the right to make changes without notice to this, or any of its products, to improve reliability, performance or design.

FORCE COMPUTERS assumes no responsibility for the use of any circuitry other than circuitry which is part of a product of FORCE COMPUTERS GmbH/Inc.

FORCE COMPUTERS does not convey to the purchaser of the product described herein any license under the patent rights of FORCE COMPUTERS GmbH/Inc. nor the rights of others.

#### FORCE COMPUTERS Inc.

3165 Winchester Blvd. Campbell, CA 95008-6557 U.S.A.

Phone : (408) 370-6300 FAX : (408) 374-1146

#### FORCE COMPUTERS GmbH

Prof.-Messerschmitt-Str. 1 D-8014 Neubiberg/Munich West Germany

Phone : (089) 608 14-0 Telex : 524190 forc-d FAX : (089) 609 77 93

#### FORCE COMPUTERS FRANCE Sarl 11, rue Casteja 92100 Boulogne

France

Phone : (1) 4620 37 37 Telex : 206 304 forc-f FAX : (1) 4621 35 19 FORCE Computers UK Ltd. No. 1 Holly Court 3 Tring Road Wendover Buckinghamshire HP England

Phone : (0296) 625456 Telex : 838033 FAX : (0296) 624027 This page was intentionally left blank

# TABLE OF CONTENTS

| 1.                                      | GENERAL INFORMATION                                                                                                                    | 1-1                             |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| 1.1                                     | Features of the CPU Board                                                                                                              | 1-4                             |
| 2.                                      | THE PROCESSOR                                                                                                                          | 2-1                             |
| 2.1                                     | The CPU 68040                                                                                                                          | 2-1                             |
| 2.2<br>2.2.1<br>2.2.2<br>2.2.3<br>2.2.4 | The Shared RAM                                                                                                                         | 2-3<br>2-3<br>2-4<br>2-5<br>2-6 |
| 2.3                                     | The System EPROM                                                                                                                       | 2-7                             |
| 2.4                                     | The Local SRAM                                                                                                                         | 2-7                             |
| 2.5                                     | The Local FLASH EPROM                                                                                                                  | 2-7                             |
| 2.6                                     | The Boot EPROM                                                                                                                         | 2-7                             |
| 2.7                                     | The FGA-002                                                                                                                            | 2-8                             |
| 2.8<br>2.8.1<br>2.8.2                   | The PI/T 68230The I/O Configuration of PI/T1The I/O Configuration of PI/T2The I/O Configuration of PI/T2The I/O Configuration of PI/T2 | 2-9<br>2-10<br>2-10             |
| 2.9                                     | The Real Time Clock 72423                                                                                                              | 2-11                            |
| 2.10<br>2.10.1                          | The DUSCC 68562                                                                                                                        | 2-12<br>2-13                    |
| 2.11                                    | The EAGLE Modules                                                                                                                      | 2-15                            |
| 2.12                                    | The VMEbus Interface                                                                                                                   | 2-15                            |
| 2.13                                    | The Monitor of the CPU board                                                                                                           | 2-17                            |
| 2.14                                    | Default Jumper Settings on the CPU Board                                                                                               | 2-18                            |
| 3.                                      | SPECIFICATIONS OF THE CPU BOARD                                                                                                        | 3-1                             |
| 4.                                      | ORDERING INFORMATION                                                                                                                   | 4-1                             |
| 5.                                      | HISTORY OF MANUAL REVISIONS                                                                                                            | 5-1                             |

## LIST OF FIGURES

| Figure 1-1: | Photo of the CPU Board                | 1-2  |
|-------------|---------------------------------------|------|
| Figure 1-2: | Block Diagram of the CPU Board        | 1-3  |
| Figure 2-1: | Location Diagram for All Jumperfields | 2-20 |
| Figure 2-2: | The Front Panel of the CPU Board      | 2-21 |

# LIST OF TABLES

| Table 1-1: | The Memory Map                              | 1-6 |
|------------|---------------------------------------------|-----|
| Table 1-2: | The Base Addresses of the Local I/O Devices | 1-7 |

## 1. GENERAL INFORMATION

This CPU board is a high performance single board computer based on the 68040 microprocessor and the VMEbus. The board incorporates a modular I/O subsystem which provides a high degree of flexibility for a wide variety of applications. The CPU board can be used with or without an I/O subsystem, called an "EAGLE" module.

The board is able to hold a RAM Module which can be DRAM (CPU-40) or SRAM (CPU-41) based.

The CPU-40/41 family design utilizes all of the features of the powerful FORCE Gate Array (FGA-002). Among its features is a 32-bit DMA controller which supports local (shared) memory, VMEbus and I/O data transfers for maximum performance, parallel real time operation and responsiveness.

The EAGLE modules are installed on the CPU board via the FLXi (FORCE Local eXpansion interface). This provides a full 32-bit interface between the base board and the EAGLE module I/O subsystem, providing a range of I/O options.

Four multiprotocol serial I/O channels, a parallel I/O channel and a Real Time Clock with on-board battery backup are installed on the base board which, in combination with EAGLE modules, make the CPU board a true single board computer system.

A broad range of operating systems and kernels is available for the CPU board. However, as with all FORCE COMPUTERS' CPU cards, VMEPROM firmware is provided with the board at no extra cost. VMEPROM is a Real Time Kernel and is installed on the CPU board in the two 16-bit wide EPROM sockets, which results in a 32-bit wide System EPROM area. This ensures that the board is supplied ready to use.

# Figure 1-1: Photo of the CPU Board







#### **1.1 Features of the CPU Board**

- 68040 microprocessor: 25.0 MHz on CPU-40B/41B/x
- 68040 microprocessor: 33.0 MHz on CPU-40D/41D/x
- Shared DRAM Module: 4 Mbyte DRAM with Burst Read/Write and Parity Generation and Checking (DRM-01/4)

16 Mbyte DRAM with Burst Read/Write and Parity Generation and Checking (DRM-01/16)

• Shared SRAM Module: 4 Mbyte SRAM with Burst Read/Write (SRM-01/4)

8 Mbyte SRAM with Burst Read/Write (SRM-01/8)

- 32-bit high speed DMA controller for data transfers to/from the shared RAM, VMEbus memory and EAGLE modules; DMA controller is installed in the FGA-002.
- Two system EPROM devices supporting 40-pin devices. Access from the 68040 using a 32bit data path
- One boot EPROM for local booting, initialization of the I/O chips and configuration of the FGA-002
- 128 Kbyte SRAM with on-board battery backup
- 128 Kbyte FLASH EPROM
- FLXi interface for installation of one EAGLE module
- Four Serial I/O interfaces, configurable as RS232/RS422/RS485, available on the front panel
- 8-bit parallel interface with 4-bit handshake
- Two 24-bit timers with 5-bit prescaler
- One 8-bit timer
- Real Time Clock with calendar and on-board battery backup
- Full 32-bit VMEbus master/slave interface, supporting the following data transfer types:
  - A32, A24, A16 : D8, D16, D32 Master
  - A32, A24 : D8, D16, D32 Slave
  - UAT, RMW, ADO

# Features of the CPU Board (cont'd)

- Four-level VMEbus arbiter
- SYSCLK driver
- VMEbus interrupter (IR 1-7)
- VMEbus interrupt handler (IH 1-7)
- Support for ACFAIL\* and SYSFAIL
- Bus timeout counters for local and VMEbus access (15  $\mu$ sec)
- VMEPROM, Real Time Multitasking Kernel with monitor, file manager and debugger

The following table summarizes the memory map of the CPU board.

## Table 1-1: The Memory Map

| Start<br>Address                 | End<br>Address                   | Туре                                                                              |
|----------------------------------|----------------------------------|-----------------------------------------------------------------------------------|
| 00000000<br>00000000<br>00000000 | 003FFFFF<br>007FFFFF<br>00FFFFFF | Shared Memory (4 Mbyte)<br>Shared Memory (8 Mbyte) or<br>Shared Memory (16 Mbyte) |
| 00400000                         | F9FFFFF                          | VMEbus Addresses (4 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8                |
| 00800000                         | F9FFFFF                          | VMEbus Addresses (8 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8                |
| 01000000                         | F9FFFFF                          | VMEbus Addresses (16 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8               |
| FA000000                         | FAFFFFF                          | Message Broadcast Area                                                            |
| FB000000                         | FBFEFFFF                         | VMEbus<br>A24: D32, D24, D16, D8                                                  |
| FBFF0000                         | FBFFFFF                          | VMEbus<br>A16: D32, D24, D16, D8                                                  |
| FC000000                         | FCFEFFFF                         | VMEbus<br>A24: D16, D8                                                            |
| FCFF0000                         | FCFFFFF                          | VMEbus<br>A16: D16, D8                                                            |
| FD000000                         | FEFFFFF                          | Reserved                                                                          |
| FF000000                         | FF7FFFF                          | SYSTEM EPROM                                                                      |
| FF800000                         | FFBFFFFF                         | Local I/O                                                                         |
| FFC00000                         | FFC7FFFF                         | LOCAL SRAM                                                                        |
| FFC80000                         | FFCFFFFF Local FLASH EPROM       |                                                                                   |
| FFD00000                         | FFDFFFF                          | Registers of FGA-002                                                              |
| FFE00000                         | FFEFFFF                          | BOOT EPROM                                                                        |
| FF803E00                         | FF803FFF                         | VMEbus Arbiter                                                                    |
| FFF00000                         | FFFFFFF                          | Reserved                                                                          |

This table gives a brief overview of the local I/O devices and the equivalent base address.

# Table 1-2: The Base Addresses of the Local I/O Devices

| BASE ADDRESS | DEVICE       |
|--------------|--------------|
| \$FF803000   | RTC 72423    |
| \$FF802000   | DUSCC1 68562 |
| \$FF802200   | DUSCC2 68562 |
| \$FF800C00   | PI/T1 68230  |
| \$FF800E00   | PI/T2 68230  |

This page was intentionally left blank

# 2. THE PROCESSOR

## 2.1 The CPU 68040

The 68040 is a third generation full 32 bit enhanced microprocessor. The 68040 is upward object code compatible with the 68030, 68020, 68010 and 68000 line of microprocessors.

The 68040 combines a central processing unit core, an instruction cache, a data cache, a memory management unit, and an enhanced bus controller.

This virtual memory processor utilizes multiple, concurrent execution units and a highly integrated architecture providing a high level of performance.

The 68040 processor combines a 68030 compatible integer unit, a 68881/68882 compatible floating point unit (FPU), memory management units (MMUs), and a 4 Kbyte instruction and data cache. Cache functionality is strengthened by the built-in on-chip bus snooping logic which instantly supports cache logic during multimaster applications.

Instruction administration is routed through both the integer unit and FPU, which link to the fully independent data and instruction memory units. Each memory unit consists of an MMU, an address translation cache (ATC), a main cache, and a snoop controller.

The internal blocks are designed to operate in parallel, allowing instruction execution to be overlapped. In addition, the internal caches, the on-chip memory management unit, and the enhanced bus controller operate parallel to one another.

The 68040 contains an enhanced bus controller that supports both synchronous/ asynchronous bus cycles and burst data transfers. It contains a nonmultiplexed address bus and data bus and supports 32 bits of address and data.

#### Features of the 68040

- Nonmultiplexed 32 bit address and data buses
- 16 general purpose address and data registers (32 bit wide)
- 8 floating point data registers (80 bit wide)
- Two supervisor stack pointers (32 bit wide)
- 19 special purpose control registers
- 4 Kbyte instruction and 4 Kbyte data cache
- On-chip paged memory management unit
- Pipelined architecture with parallelism allowing accesses to internal caches, bus transfers, and instruction execution in parallel
- Synchronous bus cycles and burst read and write data transfers
- Complete floating point support given to the 68882 FPCP subset and software emulation
- 68030 compatible
- Low latency bus accesses to reduce cache miss penalty
- Maximized throughput from the integer unit, FPU, MMU and bus controller
- 4 Gbyte direct addressing range

## 2.2 The Shared RAM

On this CPU board the shared RAM is placed on a module to allow the adaption of DRAM or SRAM to the base board.

All signals which are needed to control the shared RAM are available on the RAM module connector. Therefore RAM devices with different access times can also be used on this CPU board to take advantage of the 68040 with higher frequency if it becomes available.

#### 2.2.1 The DRM-01/4

The DRM-01/4 is a 4 Mbyte RAM module which is used on the CPU-40B/4.

#### Features of the DRM-01/4

- 4 Mbyte DRAM
- Burst READ and Burst WRITE capability
- Parity Generation and Checking
- Asynchronous refresh is provided every 14µs
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$003FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

The DRAM module includes byte parity check for local and VMEbus accesses. If a parity error is detected on a VMEbus cycle, a BERR is forced to the VMEbus informing the requestor that a parity error has occurred. On local accesses, a Transfer Error Acknowledge (TEA) is forced to the processor if a parity error was detected.

The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-40/B      | 25 MHz                   | 4                                                                        | 1                                              | 3                                          | 0                                         |

#### 2.2.2 The DRM-01/16

The DRM-01/16 is a 16 Mbyte RAM module which is used on the CPU-40B/16.

#### Features of the DRM-01/16

- 16 Mbyte DRAM
- Burst READ and Burst WRITE capability
- Parity Generation and Checking
- Asynchronous refresh is provided every 14µs
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$00FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

The DRAM module includes byte parity check for local and VMEbus accesses. If a parity error is detected on a VMEbus cycle, a BERR is forced to the VMEbus informing the requestor that a parity error has occurred. On local accesses, a Transfer Error Acknowledge (TEA) is forced to the processor if a parity error was detected.

The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040-B Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|----------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-40/B      | 25 MHz                     | 4                                                                        | 1                                              | 3                                          | 0                                         |

#### 2.2.3 The SRM-01/4

The SRM-01/4 is a 4 Mbyte RAM module which is used on the CPU-41B/4.

#### Features of the SRM-01/4

- 4 Mbyte SRAM
- Burst READ and Burst WRITE capability
- Battery Backup via VMEbus
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$003FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

Parity check is not necessary for SRAM devices, because these components are protected against soft errors owing alpha emission. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-41/B      | 25 MHz                   | 3                                                                        | 1                                              | 2                                          | 0                                         |

#### 2.2.4 The SRM-01/8

The SRM-01/8 is an 8 Mbyte RAM module which is used on the CPU-41B/8.

#### Features of the SRM-01/8

- 8 Mbyte SRAM
- Burst READ and Burst WRITE capability
- Battery Backup via VMEbus
- Accessible via VMEbus

The access address for the 68040 is \$0000000 to \$007FFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes.

For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

Parity check is not necessary for SRAM devices, because these components are protected against soft errors owing alpha emission. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-41/B      | 25 MHz                   | 3                                                                        | 1                                              | 2                                          | 0                                         |

## 2.3 The System EPROM

The CPU board offers two 40-pin EPROM sockets for the installation of two 16-bit wide EPROM devices. The EPROMs present a full 32-bit data path to the processor enabling maximum performance. The following devices are supported in the system EPROM area:

| Organization | Total Memory Capacity |
|--------------|-----------------------|
| 64K x 16     | 256 Kbytes            |
| 128K x 16    | 512 Kbytes            |
| 256K x 16    | 1 Mbyte               |
| 512K x 16    | 2 Mbytes              |

#### Supported Device Types in the System EPROM Area:

#### 2.4 The Local SRAM

The CPU board contains a 128K \* 8 bit SRAM. Battery backup is provided via the on-board battery or the VMEbus + 5VSTDBY line.

# 2.5 The Local FLASH EPROM

A 128 Kbyte FLASH EPROM is included on the base board of the CPU-40 which can be used as additional data backup under conditions of power down for long periods. FLASH EPROM is ideal to hold details of the board status, such as software revision or user data which is to be kept permanently.

# 2.6 The Boot EPROM

The CPU board contains, in addition to the two system EPROMs, a single boot EPROM to boot the local microprocessor, initialize all I/O devices and program the board-dependent functions of the FGA-002. All basic initialization of the I/O devices and the FGA-002 are made through the boot EPROM.

In addition, the boot EPROM contains user utility routines, which may be called out of the user's application program. These routines provide easy software access to the functionality of the FGA-002 (DMA controller, FORCE Message Broadcast, Interrupt Management, etc.).

## 2.7 The FGA-002

One of the main features on this CPU board is the FGA-002 Gate Array with 24,000 gates and 281 pins. The FGA-002 controls the local bus and builds the VMEbus interface. It also includes a DMA controller, a complete interrupt handler, message broadcast interface (FMB), timer functions, mailbox locations, and a VMEbus interrupter. This gate array monitors the local bus, which in turn signifies that if any local I/O device is to be accessed, the gate array overrules all control signals, used address signals, and data signals.

The FGA-002 serves as a VMEbus manager. All VMEbus address and data lines are connected to the gate array through the buffers. Additional functions such as the VMEbus interrupt handler are also installed on the FGA-002. The on-chip DMA controller can access the local memory, VMEbus memory, and on-board devices which are able to function in a DMA mode. The start address of the FGA-002 registers is \$FFD00000. All registers of the gate array and associated functions are described in detail in the FGA-002 Users Manual. On the following page you will find a list of features for the FGA-002.

#### Features of the FGA-002

- 32 bit DMA Controller
- 2 Message Broadcast Channels (FMB)
- 8 Mailbox Interrupt Channels
- One 8 bit timer
- Complete Interrupt Management for VMEbus interrupts, ACFAIL, SYSFAIL, Onboard Interrupts and FGA-002 internal interrupts
- VMEbus interface including a single level arbiter
- Decoding logic for accesses to the Shared Memory of the CPU board

A complete functional description of the FGA-002 may be found in the FGA-002 Users Manual.

## 2.8 The PI/T 68230

The MC68230 Parallel Interface/Timer (PI/T) provides versatile double buffered parallel interfaces and an operating system oriented timer for MC68000 systems. The parallel interfaces operate in unidirectional or bidirectional modes, 8 or 16 bits wide. The PI/T timer contains a 24 bit wide counter and a 5 bit prescaler.

## Features of the PI/T

- MC68000 Bus Compatible
- Port Modes Include: Bit I/O Unidirectional 8 bit and 16 bit Bidirectional 8 bit and 16 bit
- Selectable Handshaking Options
- 24 bit Programmable Timer
- Software Programmable Timer Modes
- Contains Interrupt Vector Generation Logic
- Separate Port and Timer Interrupt Service Requests
- Registers are Read/Write and Directly Addressable

# 2.8.1 The I/O Configuration of PI/T1

Port A is connected to the two 4 bit HEX rotary switches provided on the front panel for application dependent settings.

Port B is used for programming the local base address for A24 accesses from the VMEbus.

Port C is used for port and timer interrupts and to control the RMC behavior of the board.

# 2.8.2 The I/O Configuration of PI/T2

Port A and the handshake lines are routed to a 24-pin header which allows the connection of a flat cable. 8 bits are connected to port A of the PI/T and can be used as inputs or outputs, with the remaining 4 bits being connected to the handshake pins of the PI/T. This port can be used to establish a "Centronics type" interface.

Port B allows the memory capacity of the Shared RAM to be read. Each CPU board of this type contains three readable status bits describing the memory capacity. In addition, the CPU board type can be read through the remaining 5 bits.

Port C grants the RAM type (DRAM/SRAM) burst and parity capability of the Shared RAM to be read.

A "Powerup Reset" can be initiated by software.

#### 2.9 The Real Time Clock 72423

There is a Real Time Clock (RTC) 72423 installed on the CPU board. The CPU board contains a self supportive battery to sustain the RTC during power down.

## Features of the RTC

- Built-in quartz oscillator makes regulation unnecessary and allows easy design
- Direct bus compatibility (120 ns access time)
- Incorporated built-in time (hour, minute, second), and date (year, month, week, day) counters
- 12 hour and 24 hour clock switchover functions and automatic leap year setting
- Interrupt masking
- An error adjustment time function of 30 seconds
- READ, WRITE, HOLD, STOP, RESET, and CHIP SELECT inputs
- The C-MOS IC boasts low current consumption and features a backup function
- A 24-pin *so* package

#### 2.10 The DUSCC 68562

The Dual Universal Serial Communications Controller (DUSCC) 68562 is installed to communicate with terminals, computers, or other equipment.

The DUSCC is a single chip MOS-LSI communications device providing two independent, multiprotocol, full duplex receiver/transmitter channels in a single package. Each channel consists of a receiver, transmitter, 16-bit multifunction counter/timer, digital phaselocked loop (DPLL), parity/CRC generator and checker, and associated control circuits.

#### Features of the DUSCC

- Dual full duplex synchronous/asynchronous receiver and transmitter
- Multiprotocol operation consisting of:

BOP:HDLC/ADCCP, SDLC, SDLC Loop, X.25 or X.75 link levelCOP:BISYNC, DDCMP, X.21ASYNC:5-8 bit plus optional parity

- Programmable data encoding formats: NRZ, NRZI, FMO, FM1, Manchester
- 4 character receiver and transmitter FIFOs
- Individual programmable baud rate for each receiver and transmitter
- Digital phase locked loop
- User programmable counter/timer
- Programmable channel modes full/half duplex, auto echo, local loopback
- Modem control signals for each channel: RTS, CTS, DCD
- CTS and DCD programmable autoenables for Receiver (RX) and Transmitter (TX)
- Programmable interrupt on change of CTS or DCD

# 2.10.1 The I/O Configuration of DUSCC1 and DUSCC2

The four channels may be configured to function as a RS232 or RS422/RS485 compatible interface. Termination resistors can be installed to adapt various cable lengths and reduce reflections upon the selection of the RS422/RS485 compatible interface. The DUSCC can interrupt the local CPU at a specified programmable IRQ level.

# I/O Signals for DUSCC1:

The I/O signal assignment of channel 1 to 2 is listed as follows:

| Signal | Input | Output | 9 Pin Micro<br>D-Sub Connector | Description         |
|--------|-------|--------|--------------------------------|---------------------|
| DCD    | Х     |        | 1                              | Data Carrier Detect |
| RXD    | Х     |        | 2                              | Receive Data        |
| TXD    |       | Х      | 3                              | Transmit Data       |
| DTR    |       | Х      | 4                              | Data Terminal Ready |
| GND    |       |        | 5                              | Signal GND          |
| DSR    | X     | X      | 6                              | Data Set Ready      |
| RTS    |       | X      | 7                              | Request to Send     |
| CTS    | Х     |        | 8                              | Clear to Send       |
| GND    |       |        | 9                              | Signal GND          |

The I/O signals of channel 1 can be connected to the VME connector P2 in parallel to the 9-pin Micro D-Sub connector as follows:

| Signal | Input | Output | VME Connector<br>P2 | Description         |
|--------|-------|--------|---------------------|---------------------|
| DCD    | Х     |        | c29                 | Data Carrier Detect |
| RXD    | Х     |        | c30                 | Receive Data        |
| TXD    |       | X      | c31                 | Transmit Data       |
| DTR    |       | X      | c32                 | Data Terminal Ready |
| DSR    | X     | X      | a29                 | Data Set Ready      |
| RTS    |       | X      | a30                 | Request to Send     |
| CTS    | X     |        | a31                 | Clear to Send       |
| GND    |       |        | a32                 | Signal GND          |

#### NOTE

This is only possible if these VMEbus P2 lines are not used by an EAGLE module.

#### I/O Signals for DUSCC2:

The I/O signal assignment of channels 3 and 4 is listed as follows:

| Signal | Input | Output | 9 Pin Micro<br>D-Sub Connector | Description         |
|--------|-------|--------|--------------------------------|---------------------|
| DCD    | Х     |        | 1                              | Data Carrier Detect |
| RXD    | Х     |        | 2                              | Receive Data        |
| TXD    |       | Х      | 3                              | Transmit Data       |
| DTR    |       | Х      | 4                              | Data Terminal Ready |
| GND    |       |        | 5                              | Signal GND          |
| DSR    | Х     | Х      | 6                              | Data Set Ready      |
| RTS    |       | Х      | 7                              | Request to Send     |
| CTS    | Х     |        | 8                              | Clear to Send       |
| GND    |       |        | 9                              | Signal GND          |

#### 2.11 The EAGLE Modules

EAGLE modules are I/O subsystems designed not only to increase the functionality of the board but to add the exact I/O features to fit the application requirement. EAGLE modules connect directly onto the FLXi of the base board. FLXi and EAGLE modules will be a feature on future FORCE board generations to ensure continued flexibility.

If your CPU board is assembled with an EAGLE module please refer to the "EAGLE Module" manual which is shipped with this board and should be placed in Section 6 of this manual.

#### 2.12 The VMEbus Interface

The CPU board has a full 32-bit VMEbus interface. The address modifier codes for A16, A24 and A32 addressing are fully supported in master mode. In slave mode, the address modifiers for A32 and A24 are fully supported.

Read-Modify-Write cycles are fully supported to allow multiple CPU boards to be synchronized via the shared RAM. The FGA-002 determines whether or not an access to the shared RAM is allowed and, if allowed, controls the access cycle.

The CPU board provides an interrupt handler capability (IH 1-7) which can be enabled/disabled by programming the FGA-002. The CPU board also provides an interrupter function which enables the board to send interrupts to the VMEbus on seven programmable levels with a software-programmable vector.

The following bus release modes are supported:

| RWD   | = | Release When Done     |
|-------|---|-----------------------|
| ROR   | = | Release On Request    |
| RBCLR | = | Release On Bus Clear  |
| RAT   | = | Release After Timeout |
| REC   | = | Release Every Cycle   |
| ROACF | = | Release On ACFAIL*    |

Each of the listed modes is software programmable inside the gate array. The bus request level of the CPU board is jumper or software selectable (BRO-3).

The DMA controller installed in the FGA-002 on the CPU board is able to access the VMEbus interface independently from the microprocessor, enabling VMEbus communication to take place without impacting the processing capabilities of the rest of the board for number crunching or servicing on-board I/O.

A four level arbiter with round robin and prioritized round robin arbitration modes, a power monitor, a SYSRESET\* generator, IACK\* daisy chain driver and support for ACFAIL\*, SYSFAIL\* and SYSCLK complete the VMEbus interface.

#### 2.13 The Monitor of the CPU board

Every CPU board contains VMEPROM, a real time multitasking monitor debugger. It consists of a powerful real time kernel, file manager and monitor/debugger with 68040 line assembler/disassembler.

The monitor/debugger includes all functions to control the real time kernel and file manager as well as all tools required for program debugging such as breakpoints, tracing, memory display, memory modify and host communication.

VMEPROM supports several memory and I/O boards on the VMEbus to take full advantage of the file manager and kernel functions.

A built-in selftest checks all on-board devices and memory. This allows detection of any failures on the board.

Memory initialization and test commands offer easy installation of global memory in the environment on the local RAM and/or the VMEbus.

The one line assembler/disassembler is 68040 compatible and supports all 68040 commands in the original mnemonic described in the MC 68040 User's Manual.

# 2.14 Default Jumper Settings on the CPU Board

The following are the default jumper settings and a location diagram displaying all jumpers.

#### Default Jumper Settings for the CPU

| Jumperfield | Description                                          | Default<br>Connection | Schematics |
|-------------|------------------------------------------------------|-----------------------|------------|
| B2          | Reset Voltage Sensor                                 |                       | SH4<br>B4  |
| B20         | Backup Supply for Local SRAM and<br>RTC via +5VSTDBY |                       | SH4<br>B2  |
| B1          | Backup Supply for Local SRAM and RTC via Bat 1       | 1-2                   | SH4<br>B2  |

#### Default Jumper Settings for System EPROMs and SRAM/EEPROM

| Jumperfield | Description                   | Default<br>Connection | Schematics |
|-------------|-------------------------------|-----------------------|------------|
| B11         | System EPROM device select    | 1-6                   | SH5<br>A4  |
| B16         | FLASH EPROM write dis-/enable | 1-2                   | SH4<br>C2  |

#### Default Jumper Settings for Serial I/O (RS232)

| Jumperfield | Description                               | Default<br>Connection | Schematics |
|-------------|-------------------------------------------|-----------------------|------------|
| В3          | Connector 1, PD1<br>(DUSCC1 Port #1)      | 2-15<br>8-9           | SH6<br>B2  |
| В4          | Connector 2, PD2<br>(DUSCC1 Port #2)      | 2-15<br>8-9           | SH6<br>B3  |
| В5          | Connector 1, PD1<br>(DUSCC1 Port #1)      |                       | SH6<br>C2  |
| B6          | Connector 2, PD2<br>(DUSCC Port #2)       |                       | SH6<br>C3  |
| В7          | Connector 3, PD3<br>(DUSCC2 Port #3)      | 2-15<br>8-9           | SH7<br>B2  |
| B8          | Connector 4, PD4<br>(DUSCC2 Port #4)      | 2-15<br>8-9           | SH7<br>B3  |
| В9          | Connector 3, PD3<br>(DUSCC2 Port #3), PD3 |                       | SH7<br>C2  |
| B10         | Connector 4, PD4<br>(DUSCC Port #4), PD4  |                       | SH7<br>C3  |

## **Default Jumper Settings for VMEbus**

| Jumperfield | Description                                                     | Default<br>Connection    | Schematics |
|-------------|-----------------------------------------------------------------|--------------------------|------------|
| B19         | Four level Arbiter Request Level                                | 1-6<br>2-5<br>3-4        | SH9<br>B4  |
| B13         | SYSCLK<br>SYSFAIL<br>Receive VMEbus RESET<br>Drive VMEbus RESET | 1-8<br>2-7<br>3-6<br>4-5 | SH10<br>C2 |

## Default Jumper Settings for Test

| Jumperfield | Description         | Default<br>Connection | Schematics |
|-------------|---------------------|-----------------------|------------|
| B17         | Clock Signal to CPU | 1-2                   | SH16<br>A1 |

#### Headers for 12 Bit I/O and 8 Bit I/O

| Jumperfield | Description | Default<br>Connection | Schematics |
|-------------|-------------|-----------------------|------------|
| B12         | User I/O    |                       | SH8<br>D1  |







# Figure 2-2: The Front Panel of the CPU Board

This page intentionally left blank

## 3. SPECIFICATIONS OF THE CPU BOARD

| СРИ Туре                                                                                                                                           |                                               | 68040                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------|
| CPU Clock Frequency                                                                                                                                | CPU-40B/x<br>CPU-40D/x                        | 25.0 MHz<br>33.0 MHz                                               |
| Shared DRAM Capacity with Parity                                                                                                                   | CPU-40X/4<br>CPU-40X/16                       | 4 Mbytes<br>16 Mbytes                                              |
| Shared SRAM Capacity                                                                                                                               | CPU-41X/4<br>CPU-41X/8                        | 4 Mbytes<br>8 Mbytes                                               |
| SRAM Capacity with On-board Battery Backup<br>FLASH EPROM                                                                                          |                                               | 128 Kbytes<br>128 Kbytes                                           |
| Number of System EPROM Sockets<br>Data Path                                                                                                        |                                               | 2<br>32-Bits                                                       |
| Serial I/O Interfaces (68562)<br>RS232/RS422/RS485 Compatible                                                                                      |                                               | 4<br>4 of 4                                                        |
| 24-bit Timer with 5-bit Prescaler<br>8-bit Timer                                                                                                   |                                               | 2<br>1                                                             |
| Parallel I/O Interface (68230)                                                                                                                     |                                               | 12 Lines                                                           |
| Real Time Clock with On-board Battery Backup                                                                                                       |                                               | 72423                                                              |
| VMEbus Interface A32, A24, A16:D8, D16, D32, UAT, RMW<br>A32, A24:D8, D16, D32, RMW                                                                |                                               | Master<br>Slave                                                    |
| Four Level Arbiter<br>SYSCLK Driver<br>Mailbox Interrupts                                                                                          |                                               | Yes<br>Yes<br>8                                                    |
| FORCE Message Broadcast                                                                                                                            | FMB FIFO 0<br>FMB FIFO 1                      | 8 Bytes<br>1 Byte                                                  |
| VMEbus Interrupter/VMEbus and Local Interrupt Handler<br>All Sources can be Routed to a Software Programmable IRQ Level                            |                                               | 1 to 7<br>Yes                                                      |
| RESET/ABORT Switch                                                                                                                                 | ······································        | Yes                                                                |
| VMEPROM Firmware Installed on All Board Versions                                                                                                   |                                               | 256 Kbytes                                                         |
| Power Requirements                                                                                                                                 | + 5V min/max<br>+ 12V min/max<br>-12V min/max | 5.2A/6.0A<br>0.1A/0.3A<br>0.1A/0.3A                                |
| Operating Temperature with Forced Air Cooling<br>Storage Temperature<br>Relative Humidity (noncondensing)<br>Board Dimensions<br>No. of Slots Used |                                               | 0 to +50°C<br>-40 to +85°C<br>0 to 95%<br>234x160mm/9.2x6.3in<br>1 |

This page intentionally left blank

## 4. ORDERING INFORMATION

| SYS68K/CPU-40B/4-00  | 25.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared DRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYS68K/CPU-40B/4-01  | 25.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared DRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included.  |
| SYS68K/CPU-40B/16-00 | 25.0 MHz 68040 based CPU board with DMA, 16 Mbyte shared DRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                 |
| SYS68K/CPU-40B/16-01 | 25.0 MHz 68040 based CPU board with DMA, 16 Mbyte shared DRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included. |
| SYS68K/CPU-40D/4-00  | 33.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared DRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |
| SYS68K/CPU-40D/4-01  | 33.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared DRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included.  |
| SYS68K/CPU-40D/16-00 | 33.0 MHz 68040 based CPU board with DMA, 16 Mbyte shared DRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                 |
| SYS68K/CPU-40D/16-01 | 33.0 MHz 68040 based CPU board with DMA, 16 Mbyte shared DRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included. |
| SYS68K/CPU-41B/4-00  | 25.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared SRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |
| SYS68K/CPU-41B/4-01  | 25.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared SRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included.  |
| SYS68K/CPU-41B/8-00  | 25.0 MHz 68040 based CPU board with DMA, 8 Mbyte shared SRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |
| SYS68K/CPU-41B/8-01  | 25.0 MHz 68040 based CPU board with DMA, 8 Mbyte shared SRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included.  |
| SYS68K/CPU-41D/4-00  | 33.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared SRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |
| SYS68K/CPU-41D/4-01  | 33.0 MHz 68040 based CPU board with DMA, 4 Mbyte shared SRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included.  |
| SYS68K/CPU-41D/8-00  | 33.0 MHz 68040 based CPU board with DMA, 8 Mbyte shared SRAM, 4 serial I/O channels, FLXi, VMEPROM. Documentation included.                                                  |

| SYS68K/CPU-41D/8-01        | 33.0 MHz 68040 based CPU board with DMA, 8 Mbyte shared SRAM, 4 serial I/O channels, EAGLE-01C (SCSI, floppy disk and Ethernet Interface), VMEPROM. Documentation included. |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYS68K/IOBP-1              | Backpanel for single board computers providing SCSI and floppy disk drive connectors.                                                                                       |
| SYS68K/CABLE MICRO-9 SET 1 | Set of three adapter cables 9-pin micro D-Sub male connector to 9-pin D-Sub female connector, length 2 m.                                                                   |
| SYS68K/CABLE MICRO-9 SET 2 | Set of four adapter cables 9-pin micro D-Sub male connector to 25-pin D-Sub female connector, length 2 m.                                                                   |
| SYS68K/VMEPROM/40/UP       | VMEPROM update service for the SYS68K/CPU-40 series.                                                                                                                        |
| SYS68K/VMEPROM/UM          | VMEPROM User's Manual excluding the SYS68K/CPU-40 description.                                                                                                              |
| SYS68K/CPU-40/UM           | User's Manual for the SYS68K/CPU-40 product, including VMEPROM User's<br>Manual and EAGLE-01C User's Manual (separately available as<br>EAGLE-01C/UM).                      |
| SYS68K/FGA-002/UM          | User's Manual for the FGA-002 Gate Array.                                                                                                                                   |

## 6.8 **RESET Generation**

There is an IEEE 1014 compatible SYSRESET\* driver installed on the CPU board. The RESET generator circuitry is operable if the power supply VCC is at least 3 volts. The RESET signal can be asserted (low) on any one of the following conditions:

- Front Panel RESET switch toggled
- Voltage Sensor detects VCC below limit (4.8V)
- Execution of the RESET instruction by the microprocessor on the board

The asserted RESET signal will be held low for at least 200 milliseconds after removing all the above conditions.

When the Reset Switch is toggled twice a Powerup equivalent Reset can be generated. The time lapse immediately after the Reset Switch is released must be 0,2 seconds or less.

## 6.8.1 The Front Panel RESET Switch

The upper switch on the front panel of the CPU board is the RESET switch. Toggling it provides a reset of all on-board devices, independent from the jumper options. With the jumper B13 3-6 connection inserted, the SYSRESET\* signal of the VMEbus backplane will be asserted. When the RUN LED is red, the processor is in the HALT state. For example, this state will be entered if a double bus fault occurs. A reset of the board must be performed by toggling the RESET switch or by asserting the SYSRESET\* backplane signal. The light of the RUN LED is also red while the RESET generator drives the reset. After reset, the red light must change to green.

## 6.8.2 The Voltage Sensor Module FH001

The voltage sensor module FH001 is included with the RESET generator. Power up reset is provided by this sensor, as soon as the supply voltage VCC has reached 3 volts. RESET will be asserted if VCC is less than 4.8 volts on the board, once the jumper B2 pin 1-2 is removed (B). This jumper is removed upon delivery. When the jumper at B2 1-2 is inserted (A), RESET will be asserted if VCC is less than 4.6 volts. RESET will stay asserted at least 200 milliseconds after the supply voltage has passed the threshold. Jumperfield B2 pin 1-2 must be removed for normal operation, and may be inserted for test purposes.

## Figure 6-7: Jumper Settings for Jumperfield B2







## 6.8.3 VMEbus RESET Conditions

## 6.8.3.1 Receive RESET from VMEbus

In order to receive a RESET from the VMEbus on the CPU board, jumper B13, 4-5 must be inserted. If removed, the SYSRESET signal from the VMEbus is not monitored on the CPU board.

B13

| 8 | 7 | 6 | 5     |  |
|---|---|---|-------|--|
| o | 0 | 0 | 0<br> |  |
| Ö | 0 | 0 | 0     |  |
| 1 | 2 | 3 | 4     |  |

## 6.8.3.2 Drive RESET to VMEbus

To drive the RESET signal on the VMEbus, jumper B13, 3-6 must be inserted on the CPU board. When inserted, the RESET from the front panel switch and voltage monitor are driven to the VMEbus. If not inserted, SYSRESET is not VMEbus driven.

B13

| 8 | 7 | 6 | 5 |
|---|---|---|---|
| 0 | 0 | 0 | ο |
| Ö | 0 | 0 | 0 |
| 1 | 2 | 3 | 4 |

## 6.8.3.3 Default Configuration of Jumperfield B13

By default, SYSCLK and SYSRESET are driven to the VMEbus; SYSRESET and SYSFAIL are monitored by the CPU board.

| B13 |
|-----|
|-----|

| 8 | 7 | 6 | 5 |
|---|---|---|---|
| 0 | 0 | 0 | ο |
|   |   |   |   |
| 0 | 0 | 0 | 0 |
| 1 | 2 | 3 | 4 |



## Figure 6-9: Location Diagram of Jumperfield B13

## 6.8.4 The RESET Instruction

The RESET instruction of the microprocessor is designed to reset peripherals under program control, without resetting the processor itself. This instruction is fully supported by the CPU board. The RESET instruction triggers the RESET generator and resets all peripherals on the board driving RESET to low. At this point the processor on the CPU itself will not be reset. Therefore, program execution will go on with the next operation code. If another board asserts SYSRESET \* before this instruction triggered reset is ended, then the processor will still not be reset because of a lockout logic.

This page was intentionally left blank

•

-

# APPENDIX TO THE HARDWARE USER'S MANUAL

This page was intentionally left blank

- A. SPECIFICATION OF THE CPU BOARD
- B. MEMORY MAP OF THE CPU BOARD
- C. ADDRESS ASSIGNMENT AND REGISTER LAYOUT OF THE I/O DEVICES
- D. PIN ASSIGNMENTS OF THE EPROM SOCKETS D.1 Pin Assignment for EPROM Area
- E. CIRCUIT SCHEMATICS OF CPU BOARD E.1 Circuit Schematics of DRM-01 E.2 Circuit Schematics of SRM-01
- F. DEFAULT JUMPER SETTINGS ON THE CPU BOARD
- G. CONNECTOR PIN ASSIGNMENT G.1 J1/P1 Pin Assignments G.2 J2/P2 Pin Assignments
- H. COMPONENT PART LIST
- I. GLOSSARY OF VME/1014 TERMS
- J. LITERATURE REFERENCE
- K. PRODUCT ERROR REPORT

This page is intentionally left blank.

## APPENDIX A

#### SPECIFICATIONS OF THE CPU BOARD

| СРИ Туре                                                                                                                |                                                                                                                 | 68040                    |
|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------|
| CPU Clock Frequency                                                                                                     | CPU-40B/x<br>CPU-40D/x                                                                                          | 25.0 MHz<br>33.0 MHz     |
| Shared DRAM Capacity with Parity                                                                                        | CPU-40X/4<br>CPU-40X/16                                                                                         | 4 Mbytes<br>16 Mbytes    |
| CPU Clock Frequency                                                                                                     | CPU-41B/x<br>CPU-41D/x                                                                                          | 25.0 Mhz<br>33.0 MHZ     |
| Shared SRAM Capacity                                                                                                    | CPU-41X/4<br>CPU-41X/8                                                                                          | 4 Mbytes<br>8 Mbytes     |
| SRAM capacity with On-board Battery Backup<br>FLASH EPROM                                                               |                                                                                                                 | 128 Kbytes<br>128 Kbytes |
| Number of System EPROM Sockets<br>Data Path                                                                             |                                                                                                                 | 2<br>32-bits             |
| Serial I/O Interfaces (68562)<br>RS232/RS422/RS485 Compatible                                                           |                                                                                                                 | 4<br>4 of 4              |
| 24-bit Timer with 5-bit Prescaler<br>8-bit Timer                                                                        |                                                                                                                 | 2<br>1                   |
| Parallel I/O Interface (68230)                                                                                          |                                                                                                                 | 12 lines                 |
| Real Time Clock with On-board Battery Backu                                                                             | p                                                                                                               | 72423                    |
| -                                                                                                                       | 4, A16:D8, D16, D32, UAT, RMW<br>4:D8, D16, D32, RMW                                                            | Master<br>Slave          |
| Four Level Arbiter<br>SYSCLK Driver<br>Mailbox Interrupts                                                               |                                                                                                                 | Yes<br>Yes<br>8          |
| FORCE Message Broadcast                                                                                                 | FMB FIFO 0<br>FMB FIFO 1                                                                                        | 8 bytes<br>1 byte        |
| VMEbus Interrupter/VMEbus and Local Interrupt Handler<br>All Sources can be Routed to a Software Programmable IRQ Level |                                                                                                                 | 1 to 7<br>Yes            |
| RESET/ABORT Switch                                                                                                      | ingeneral and an an and an an and an and an and an and an and an and an an and an an and an an an an an an an a | Yes                      |
| VMEPROM Firmware Installed on All Board Ve                                                                              | ersions                                                                                                         | 256 Kbytes               |

#### TO BE CONTINUED

## SPECIFICATIONS OF THE CPU BOARD CONTINUED

| + 5V min/min<br>+ 12V min/max<br>-12V min/max | 5.2A/6.0A<br>0.1A/0.3A<br>1.0A/0.3A |
|-----------------------------------------------|-------------------------------------|
|                                               | 0 to +50°C                          |
|                                               | -40 to +85C<br>0 to 95%             |
|                                               | 234x160mm/9.2x6.3in                 |
|                                               | 1                                   |
|                                               | +12V min/max                        |

## 5. HISTORY OF MANUAL REVISIONS

| Revision No. | Description                                                                                                               | Date of Last Change |
|--------------|---------------------------------------------------------------------------------------------------------------------------|---------------------|
| 0            | First Print.                                                                                                              | FEB/05/1991         |
| 1            | The following sections/pages have been changed:                                                                           | APR/16/1991         |
|              | Section 1:                                                                                                                |                     |
|              | Page 2-16 (EPROM Description)                                                                                             |                     |
|              | Section 3:                                                                                                                |                     |
|              | Pages 3-11, 3-12, 3-14, 3-15 (EPROM Description)                                                                          |                     |
|              | Section 4:                                                                                                                |                     |
|              | Page F-1 (EPROM Description)                                                                                              |                     |
|              | Sections 7, 8, and 9:                                                                                                     |                     |
|              | These have been changed to adapt to VMEPROM Version 2.74                                                                  |                     |
|              | Section 1:                                                                                                                | AUG/23/1991         |
|              | Chapter 3: Power Requirements for + 12V changed from 0.1A/0.5A to 0.1A/0.3A                                               |                     |
|              | Section 3:                                                                                                                |                     |
|              | Chapter 3.9.4 has been eliminated.<br>Chapter 3.9.12: New Board Identification.<br>Chapter 3.9.16: 1 and 0 were switched. |                     |
| 2            | Rework for PCB Revision 2                                                                                                 | FEB/03/1992         |

This page was intentionally left blank

# **INSTALLATION**

This page was intentionally left blank

## WARNING

TO AVOID MALFUNCTIONS AND COMPONENT DAMAGES, PLEASE READ THE COMPLETE INSTALLATION PROCEDURE BEFORE THE BOARD IS INSTALLED IN A VMEBUS ENVIRONMENT. This page was intentionally left blank

.

.

## TABLE OF CONTENTS

| 1.  | GENERAL OVERVIEW              | 1-1 |
|-----|-------------------------------|-----|
| 1.1 | The Rotary Switches           | 1-1 |
| 1.2 | The Function Switch Positions | 1-1 |
| 1.3 | Connection of the Terminal    | 1-3 |
| 1.4 | The Default Hardware Setup    | 1-4 |
| 2.  | INSTALLATION IN THE RACK      | 2-1 |
| 2.1 | Power ON                      | 2-1 |
| 2.2 | Correct Operation             | 2-2 |
| 3.  | ENVIRONMENTAL REQUIREMENTS    | 3-1 |

## LIST OF FIGURES

| Figure 1-1: | Front Panel of CPU Board and the Rotary Switch Positions | 1-2 |
|-------------|----------------------------------------------------------|-----|
| Figure 1-2: | Pinout of the Micro D-Sub and D-Sub Connector for RS232  | 1-4 |

This page was intentionally left blank

#### 1. GENERAL OVERVIEW

Easy installation of the CPU board is provided since the memory map, the I/O devices, and the interfaces are configured to communicate with a standard terminal containing RS232 interface.

The monitor (VMEPROM) boots up automatically with the setup of the rotary switches on the front panel.

## **1.1 The Rotary Switches**

Two rotary switches are installed on the CPU board to configure the startup of the VMEPROM or a user program.

The following lists the default configuration for bootup.

| Switch | Hex Code |
|--------|----------|
| 2      | \$F      |
| 1      | \$F      |

The different functions of the rotary switches are described in detail in the *Introduction to VMEPROM* as well as in the *Hardware User's Manual* of this particular CPU board.

#### **1.2 The Function Switch Positions**

The CPU board contains two function switches. These two switches are defined as **RESET** and **ABORT**. The **RESET** switch is located in the first and upper position, and the **ABORT** switch is located directly underneath in the second and lower position.

The two moveable positions of these switches are defined as "Up" and "Down".

All function switches must be set to the position "Down" upon performing initial installation.

Please toggle each of the switches before installing the board in the rack in order to detect mechanical damages to the switches during transport.





## **1.3** Connection of the Terminal

The terminal must be connected to the 9-pin Micro D-Sub connector 1 on the CPU board.

The board is delivered with a 9-pin Micro D-Sub to 9-pin D-Sub adapter cable.

The following communication setup is used for interfacing the terminal. Please configure the terminal to this setup.

No Parity 8 Bits per character 1 Stop Bit 9600 Baud Asynchronous Protocol

The hardware interface is RS232 compatible. The following signals are supported on the 9-pin Micro D-sub connector on the front panel:

| Signal | Input    | Output | Required | 9 Pin Micro<br>D-Sub Connector | Description         | 9 Pin D-Sub of the<br>Adapter Cable |
|--------|----------|--------|----------|--------------------------------|---------------------|-------------------------------------|
| DCD    | x        |        |          | 1                              | Data Carrier Detect | 1                                   |
| RXD    | Х        |        | Х        | 2                              | Receive Data        | 2                                   |
| TXD    |          | X      | Х        | 3                              | Transmit Data       | 3                                   |
| DTR    |          | Х      |          | 4                              | Data Terminal Ready | 4                                   |
| GND    |          |        |          | 5                              | Signal GND          | 5                                   |
| DSR    | X        | Х      |          | 6                              | Data Set Ready      | 6                                   |
| RTS    |          | Х      | Х        | 7                              | Request to Send     | 7                                   |
| CTS    | X        |        | X        | 8                              | Clear to Send       | 8                                   |
| GND    | <u> </u> |        | X        | 9                              | Signal GND          | 9                                   |

## CAUTION

- 1) The terminal used must not drive a signal line which is marked to be an output of CPU board.
- 2) All signals marked as "Required" must be supported from the terminal to enable the transmission.
- 3) If the terminal is configured to the listed setup, please connect the 9-pin Micro D-Sub connector to the terminal with a cable which supports all of the required signals.



12



#### 1-4

## 1.4 The Default Hardware Setup

The VMEbus interface is configured to be used immediately, without any changes.

This results in a default hardware setup which may conflict with other boards installed in the rack.

The following signals are driven/received from the CPU board:

| Signal     | Driven | Received | From               |
|------------|--------|----------|--------------------|
| SYSCLK     | x      |          | FGA-002 Gate Array |
| BR3*       | Х      |          | FGA-002 Gate Array |
| BR[30]*    |        | X        | 4 Level Arbiter    |
| BG[30]OUT* | X      |          | 4 Level Arbiter    |
| ACFAIL*    |        | X        | FGA-002 Gate Array |
| SYSFAIL*   |        | X        | FGA-002 Gate Array |
| SYSRESET*  | Х      | X        | FGA-002 Gate Array |

## CAUTION

1) The on-board four level arbiter is enabled and reacts on every Bus Request\*.

2) The CPU board is configured as a slot 1 controller.

This page intentionally left blank

## 2. INSTALLATION IN THE RACK

The CPU board can immediately be mounted into a VME rack at slot 1.

## CAUTION

- 1) Switch off power before installing the board to avoid electrical damage to the components.
- 2) The CPU board contains a special ejector (the handles). The board must be plugged in, and the screws on the front panel tightened up to guarantee proper installation.
- 3) Unplug every other VMEbus board to avoid conflicts.

## 2.1 Power ON

Power to the VMEbus rack may be switched on when the board is correctly installed, the switches are in the correct positions, and the terminal is correctly configured and under power.

Initially, the green RUN LED will light up, and after one to three seconds the message "Wait until hard disk is up to speed" will be displayed. A few seconds later the VMEPROM banner should appear.

The terminal is now at the user's discretion. At this point, it is advised to make a few carriage returns, to obtain the question mark (?\_) prompt.

## 2.2 Correct Operation

To test the correct operation of the CPU board, the following command must be typed in:

? SELFTEST < cr>

It is a matter of a few seconds until all tests are completed. Once all tests are completed, the following messages will appear on the screen:

#### VMEPROM Hardware Selftest

I/O test .....passed

Memory test .....passed

Clock test . . . . . . . . . passed

Any errors will be reported as they occur.

If an error message is displayed, please refer to *Section 7, "Introduction to VMEPROM*" containing the command description "*SELFTEST*".

#### 3. ENVIRONMENTAL REQUIREMENTS

This board was specified and tested for reliable operation under certain environmental conditions. Based on our performance tests, this board is capable of operating within the temperature range of 0°C to 50°C when used inside of a FORCE TARGET-32 chassis. The following chart details the calculated rate of forced air cooling.

| Rate | of | Forced | Air | Cooling |
|------|----|--------|-----|---------|
|------|----|--------|-----|---------|

| Air Cooling per Board                                         | Total Air Cooling - Target-32   |  |  |  |
|---------------------------------------------------------------|---------------------------------|--|--|--|
| 5.5 CFM* = 0.0026 cubic meter/sec                             | 131 CFM = 0.062 cubic meter/sec |  |  |  |
| 275 LFM** = 1.4 meter/sec                                     | 275 LFM = 1.4 meter/sec         |  |  |  |
| * CFM = Cubic Feet per Minute ** LFM = Linear Feet per Minute |                                 |  |  |  |

The TARGET-32 chassis performs forced air cooling using four axial fans. The amount of airflow needed for cooling and normal operation is reflected by certain factors such as ambient temperature, number and location of boards in the system, and outside heat sources. Sufficient air cooling is normally obtained when 5.5 CFM and 275 LFM is circulating around each board at an ambient temperature between 0°C and 50°C. Allowable storage temperatures may range between -40°C and 85°C. The rate of relative humidity (non-condensing) should not be less than 5%, and should not exceed 95%. The following illustration is a pictorial view of the fan placement in the chassis.



20 SLOTS AVAILABLE FOR 20 BOARDS

This page was intentionally left blank

## HARDWARE USER'S MANUAL

.

This page was intentionally left blank

## TABLE OF CONTENTS

| 1.                                                                                                                                               | GENERAL INFORMATION                                                                                                                                                                                                                                                                                                                                                                                              | 1-1                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| 2.                                                                                                                                               | THE PROCESSOR                                                                                                                                                                                                                                                                                                                                                                                                    | 2-1                                                                                               |
| 2.1<br>2.1.1<br>2.1.1.1                                                                                                                          | The CPU 68040Hardware Interface of the 68040General Operation                                                                                                                                                                                                                                                                                                                                                    | 2-1<br>2-1<br>2-1                                                                                 |
| 2.2                                                                                                                                              | The Instruction Set                                                                                                                                                                                                                                                                                                                                                                                              | 2-1                                                                                               |
| 2.3                                                                                                                                              | Vector Table of the 68040                                                                                                                                                                                                                                                                                                                                                                                        | 2-2                                                                                               |
| 3.                                                                                                                                               | THE LOCAL BUS                                                                                                                                                                                                                                                                                                                                                                                                    | 3-1                                                                                               |
| 3.1                                                                                                                                              | The FGA-002 Gate Array                                                                                                                                                                                                                                                                                                                                                                                           | 3-1                                                                                               |
| 3.2<br>3.2.1<br>3.2.2<br>3.2.3<br>3.2.4<br>3.2.5<br>3.2.6<br>3.2.7<br>3.2.8<br>3.2.9<br>3.2.10<br>3.2.11<br>3.2.12<br>3.2.12<br>3.2.13<br>3.2.14 | The Shared RAM<br>General Operation<br>Shared RAM Information<br>The DRM-01/4<br>RAM Type Information for the DRM-01/4<br>Summary of the DRM-01/4<br>The DRM-01/16<br>RAM Type Information for the DRM-01/16<br>Summary of the DRM-01/16<br>The SRM-01/4<br>RAM Type Information for the SRM-01/4<br>Summary of the SRM-01/4<br>The SRM-01/8<br>RAM Type Information for the SRM-01/8<br>Summary of the SRM-01/8 | 3-2<br>3-2<br>3-4<br>3-5<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-9<br>3-9<br>3-10<br>3-11<br>3-11 |
| 3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.4                                                                                          | The System EPROM Area                                                                                                                                                                                                                                                                                                                                                                                            | 3-12<br>3-15<br>3-18<br>3-18<br>3-18<br>3-18<br>3-19                                              |
| 3.4.1<br>3.5<br>3.5.1                                                                                                                            | Introduction to the FLXibus         The Local FLASH EPROM         Memory Organization of the FLASH EPROM                                                                                                                                                                                                                                                                                                         | 3-19<br>3-20<br>3-20                                                                              |
| 3.5.2<br>3.5.3<br>3.5.4<br>3.5.5<br>3.5.6                                                                                                        | Programming the FLASH EPROM                                                                                                                                                                                                                                                                                                                                                                                      | 3-21<br>3-21<br>3-21<br>3-21<br>3-22                                                              |

| 3.6    | The Local SRAM                                        | 3-23 |
|--------|-------------------------------------------------------|------|
| 3.6.1  | Memory Organization of the User SRAM                  | 3-23 |
| 3.6.2  | The Address Map of the SRAM Area                      | 3-26 |
| 3.6.3  | Summary of the SRAM Area                              | 3-26 |
| 3.7    | The Boot EPROM                                        | 3-27 |
| 3.7.1  | Summary of the Boot EPROM Area                        | 3-27 |
| 0.7.1  |                                                       | 0 27 |
| 3.8    | The DUSCC 68562                                       | 3-29 |
| 3.8.1  | Address Map of the DUSCC1 Registers                   | 3-30 |
| 3.8.2  | RS232 Hardware Configuration of Port #1 and #2        | 3-32 |
| 3.8.3  | Cable for the Micro D-Sub Connector                   | 3-38 |
| 3.8.4  | RS422/RS485 Hardware Configuration of Ports #1 and #2 | 3-38 |
| 3.8.5  | RS232 and RS422/RS485 Driver Modules FH002 and FH003  | 3-45 |
| 3.8.6  | Summary of DUSCC1                                     | 3-45 |
| 3.8.7  | Address Map of the DUSCC2 Registers                   | 3-46 |
| 3.8.8  | RS232 Hardware Configuration of Ports #3 and #4       | 3-48 |
| 3.8.9  | Cable for the Micro D-Sub Connector                   | 3-52 |
| 3.8.10 | RS422/RS485 Hardware Configuration of Port #3 and #4  | 3-52 |
| 3.8.11 | RS232 and RS422/RS485 Driver Modules FH002 and FH003  | 3-58 |
| 3.8.12 | Summary of DUSCC2                                     | 3-58 |
| ~ ~    |                                                       |      |
| 3.9    | The PI/T 68230                                        | 3-59 |
| 3.9.1  | Address Map of the PI/T1 Registers                    | 3-60 |
| 3.9.2  | I/O Configuration of PI/T1                            | 3-61 |
| 3.9.3  | Rotary Switches                                       | 3-62 |
| 3.9.4  | Lock Cycles                                           | 3-64 |
| 3.9.5  | Interrupt Request Signal                              | 3-65 |
| 3.9.6  | A24 Slave Mode                                        | 3-65 |
| 3.9.7  | Reserved Lines                                        | 3-65 |
| 3.9.8  | Summary of PI/T1                                      | 3-66 |
| 3.9.9  | Address Map of the PI/T2 Registers                    | 3-67 |
| 3.9.10 | I/O Configuration of PI/T2                            | 3-68 |
| 3.9.11 | Memory Size Recognition                               | 3-69 |
| 3.9.12 | Board Identification                                  | 3-69 |
| 3.9.13 | Interrupt Request Signal                              | 3-69 |
| 3.9.14 | 12 Bit I/O Port                                       | 3-09 |
| 3.9.14 |                                                       |      |
|        | MODLOW                                                | 3-72 |
| 3.9.16 | RAM Module Configuration Signals                      | 3-72 |
| 3.9.17 | Timer IRQ/Reset                                       | 3-73 |
| 3.9.18 | PIRQ                                                  | 3-73 |
| 3.9.19 | Enable A24 Slave Mode                                 | 3-73 |
| 3.9.20 | Reserved Line                                         | 3-74 |
| 3.9.21 | Summary of PI/T2                                      | 3-74 |
| 3.10   | The Real Time Clock (RTC) 72423                       | 3-75 |
| 3.10.1 | Address Map of the RTC Registers                      | 3-75 |
| 3.10.2 | RTC Programming                                       | 3-75 |
| 3.10.2 | Summary of the RTC                                    | 3-79 |
| 5.10.5 |                                                       | 3-13 |

| 4.                                                                                                          | FUNCTION SWITCHES AND INDICATION LEDs                                                                                                                                                                                                                                                                                             | 4-1                                                                          |
|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 4.1                                                                                                         | RESET Function Switch                                                                                                                                                                                                                                                                                                             | 4-1                                                                          |
| 4.2                                                                                                         | ABORT Function Switch                                                                                                                                                                                                                                                                                                             | 4-1                                                                          |
| 4.3                                                                                                         | "RUN" LED                                                                                                                                                                                                                                                                                                                         | 4-2                                                                          |
| 4.4                                                                                                         | "BM" LED                                                                                                                                                                                                                                                                                                                          | 4-2                                                                          |
| 4.5                                                                                                         | Rotary Switches                                                                                                                                                                                                                                                                                                                   | 4-2                                                                          |
| 5.                                                                                                          | THE CPU BOARD INTERRUPT STRUCTURE                                                                                                                                                                                                                                                                                                 | 5-1                                                                          |
| 6.                                                                                                          | VMEBUS INTERFACE                                                                                                                                                                                                                                                                                                                  | 6-1                                                                          |
| 6.1<br>6.1.1<br>6.1.2                                                                                       | VMEbus Master Interface       Data Transfer Size of the VMEbus Interface         Address Modifier Implementation       Data Transfer Size of the VMEbus Interface                                                                                                                                                                 | 6-1<br>6-1<br>6-4                                                            |
| 6.2<br>6.2.1<br>6.2.2<br>6.2.3                                                                              | VMEbus Slave InterfaceThe Access AddressData Transfer Size of the Shared RAMAddress Modifier Decoding and A24 Slave Mode                                                                                                                                                                                                          | 6-8<br>6-8<br>6-8<br>6-8                                                     |
| 6.3                                                                                                         | The VMEbus Interrupt Handler                                                                                                                                                                                                                                                                                                      | 6-11                                                                         |
| 6.4<br>6.4.1<br>6.4.2<br>6.4.3<br>6.4.3.1<br>6.4.3.2<br>6.4.3.3<br>6.4.3.4<br>6.4.3.5<br>6.4.3.6<br>6.4.3.7 | VMEbus Arbitration<br>Four Available VMEbus Arbiters<br>The On-Board Four Level Arbiter<br>The VMEbus Release Function<br>Release Every Cycle (REC)<br>Release on Request (ROR)<br>Release After Timeout (RAT)<br>Release on Bus Clear (RBCLR)<br>Release When Done (RWD)<br>Release Voluntary (RV)<br>Release on ACFAIL (ACFAIL) | 6-12<br>6-12<br>6-18<br>6-18<br>6-18<br>6-18<br>6-19<br>6-19<br>6-19<br>6-19 |
| 6.5<br>6.5.1<br>6.5.2                                                                                       | The VMEbus Interrupter                                                                                                                                                                                                                                                                                                            | 6-21<br>6-21<br>6-22                                                         |
| 6.6                                                                                                         | The SYSCLK Driver                                                                                                                                                                                                                                                                                                                 | 6-23                                                                         |
| 6.7                                                                                                         | Exception Signals                                                                                                                                                                                                                                                                                                                 | 6-25                                                                         |
| 6.8<br>6.8.1<br>6.8.2<br>6.8.3<br>6.8.3.1                                                                   | RESET GenerationThe Front Panel RESET SwitchThe Voltage Sensor Module FH001VMEbus RESET ConditionsReceive RESET from VMEbus                                                                                                                                                                                                       | 6-27<br>6-27<br>6-27<br>6-29<br>6-29                                         |

| 6.8.3.2 | Drive RESET to VMEbus                    | 6-29 |
|---------|------------------------------------------|------|
| 6.8.3.3 | Default Configuration of Jumperfield B13 | 6-29 |
| 6.8.4   | The RESET Instruction                    | 6-31 |

## LIST OF FIGURES

| Figure 2-1:  | Jumper Setting for B17                                                     | 2-3  |
|--------------|----------------------------------------------------------------------------|------|
| Figure 2-2:  | Location Diagram of Jumperfields B17                                       | 2-4  |
| Figure 3-1:  | Memory Organization of the System EPROM Area                               | 3-12 |
| Figure 3-2:  | Location Diagram of the System EPROM Area                                  | 3-13 |
| Figure 3-3:  | Configuration Jumper Settings of System EPROM Area Jumperfield B11         | 3-16 |
| Figure 3-4:  | Location Diagram of Jumperfield B11 Configuration of the System EPROM      |      |
|              | Area                                                                       | 3-17 |
| Figure 3-5:  | Location Diagram of the Backup Supply Jumperfield B1 and B20               | 3-25 |
| Figure 3-6:  | Location Diagram of the Boot EPROM                                         | 3-28 |
| Figure 3-7:  | Location Diagram of the $0\Omega$ Resistors R563 to R569                   | 3-34 |
| Figure 3-8:  | RS232 Connection Between DUSCC1 and VMEbus Connector P2                    | 3-35 |
| Figure 3-9:  | RS232 Connection Between DUSCC1 and Micro D-Sub Connector                  | 3-35 |
| Figure 3-10: | Pinout of the Micro D-Sub and D-Sub Connector for RS232                    | 3-35 |
| Figure 3-11: | Location Diagram of RS232 Configuration Jumperfields B3, B4, B5, and B6    | 3-37 |
| Figure 3-12: | Location Diagram of the $0\Omega$ Resistors R563 to R569                   | 3-40 |
| Figure 3-13: | RS422/RS485 Connection between DUSCC1 and VMEbus Connector P2              | 3-41 |
| Figure 3-14: | RS422/RS485 Pinout of the Micro D-Sub and D-Sub Connectors                 | 3-42 |
| Figure 3-15: | Location Diagram of RS422/RS485 Configuration Jumperfields B3, B4, B5, and |      |
|              | Β6                                                                         | 3-43 |
| Figure 3-16: | Location Diagram of RS232/RS422/RS485 Driver/Receivers J20 and J21 plus    |      |
|              | Resistor Arrays J22 and J23                                                | 3-44 |
|              | Connection Between DUSCC2 and D-Sub Connector for RS232                    | 3-49 |
|              | Location Diagram of RS232 Configuration Jumperfields B7 through B10        | 3-50 |
| -            | RS232 Pinout of the Micro D-Sub and D-Sub Connectors                       | 3-51 |
| -            | Connection between DUSCC2 and Micro D-Sub Connector for RS422/RS485        | 3-53 |
| Figure 3-21: | Location Diagram of RS422/RS485 Configuration Jumperfields B7 through      |      |
|              | B10                                                                        | 3-54 |
| -            | RS422/RS485 Pinout of the Micro D-Sub and D-Sub Connectors                 | 3-55 |
| Figure 3-23: | Location Diagram of RS232/RS422/RS485 Driver/Receiver J25/J26 and          |      |
|              | Resistor Arrays J27/J28                                                    | 3-57 |
| -            | CPU Board Front Panel and Rotary Switch Positions                          | 3-63 |
| -            | Location Diagram of Header B12                                             | 3-71 |
| -            | RTC Programming Example                                                    | 3-76 |
|              | Location Diagram of the Backup Supply Jumperfield B1 and B20               | 3-78 |
| -            | Front Panel of the CPU Board                                               | 4-3  |
| Figure 6-1:  | Requester/Arbiter Jumperfield B19                                          | 6-16 |
| Figure 6-2:  | Location Diagram of Jumperfield B19                                        | 6-17 |
| Figure 6-3:  | Usage of Jumperfield B13                                                   | 6-23 |
| Figure 6-4:  | Location Diagram of B13                                                    | 6-24 |
| Figure 6-5:  | Usage of Jumperfield B13                                                   | 6-25 |
| Figure 6-6:  | Location Diagram of Jumperfield B13                                        | 6-26 |
| Figure 6-7:  | Jumper Settings for Jumperfield B2                                         | 6-27 |
| Figure 6-8:  | Location Diagram of Jumperfield B2                                         | 6-28 |
| Figure 6-9:  | Location Diagram of Jumperfield B13                                        | 6-30 |

## LIST OF TABLES

| Table 2-1:  | Exception Vector Assignments                            | 2-2  |
|-------------|---------------------------------------------------------|------|
| Table 3-1:  | Address Map of the EPROM Area                           | 3-18 |
| Table 3-2:  | Serial I/O Port #1 (DUSCC1) Register Address Map        | 3-30 |
| Table 3-3:  | Serial I/O Port #2 (DUSCC1) Register Address Map        | 3-31 |
| Table 3-4:  | Ports #1 and #2 (DUSCC1) Common Register Address Map    | 3-31 |
| Table 3-5:  | Default Setting of RS232 Configuration Jumperfields     | 3-38 |
| Table 3-6:  | RS422/RS485 Configuration Jumperfield Settings          | 3-41 |
| Table 3-7:  | PCB Locations for the RS232/RS422/RS485 Configuration   | 3-42 |
| Table 3-8:  | Serial I/O Port #3 (DUSCC2) Register Address Map        | 3-46 |
| Table 3-9:  | Serial I/O Port #4 (DUSCC2) Register Address Map        | 3-47 |
| Table 3-10: | Ports #3 and #4 (DUSCC2) Common Registers Address Map   | 3-48 |
| Table 3-11: | Default Setting of the RS232 Configuration Jumperfields | 3-51 |
| Table 3-12: | RS422/RS485 Configuration Jumperfield Setting           | 3-55 |
| Table 3-13: | PCB Locations for RS232/RS422/RS485 Configuration       | 3-56 |
| Table 3-14: | PI/T1 Register Layout                                   | 3-60 |
| Table 3-15: | PI/T1 Interface Signals                                 | 3-61 |
| Table 3-16: | PI/T2 Register Layout                                   | 3-67 |
| Table 3-18: | PI/T2 Interface Signals                                 | 3-68 |
| Table 3-17: | RTC Register Layout                                     | 3-75 |
| Table 6-1:  | Data Bus Size of the VMEbus                             | 6-2  |
| Table 6-2:  | Defined VMEbus Transfer Cycles (D32 Mode)               | 6-3  |
| Table 6-3:  | Defined VMEbus Transfer Cycles (D16 Mode)               | 6-3  |
| Table 6-4:  | Address Ranges                                          | 6-4  |
| Table 6-5:  | Address Modifier Codes                                  | 6-5  |
| Table 6-6:  | Address Modifier Codes Used on the CPU Board            | 6-7  |
| Table 6-7:  | VMEbus Slave AM Codes                                   | 6-10 |
| Table 6-8:  | VMEbus Arbiter/Requester Register Layout                | 6-13 |
| Table 6-9:  | Description of Arbiter/Requester Register Bits          | 6-13 |
| Table 6-10: | Bit Settings for VMEbus Request Level                   | 6-14 |
| Table 6-11: | Bit Settings for VMEbus Arbiter Mode                    | 6-15 |
| Table 6-12: | Bus Release Functions                                   | 6-20 |
| Table 6-13: | VMEbus Interrupter Registers                            | 6-21 |
| Table 6-14: | Description of the IRQ Generation Register              | 6-22 |

#### 1. GENERAL INFORMATION

This CPU board is a high performance single board computer based on the 68040 microprocessor and the VMEbus. The board incorporates a modular I/O subsystem which provides a high degree of flexibility for a wide variety of applications. The CPU board can be used with or without an I/O subsystem, called an "EAGLE" module.

The board is able to hold a RAM Module which can be DRAM (CPU-40) or SRAM (CPU-41) based.

The CPU-40/41 family design utilizes all of the features of the powerful FORCE Gate Array (FGA-002). Among its features is a 32-bit DMA controller which supports local (shared) memory, VMEbus and I/O data transfers for maximum performance, parallel real time operation and responsiveness.

The EAGLE modules are installed on the CPU board via the FLXi (FORCE Local eXpansion interface). This provides a full 32-bit interface between the base board and the EAGLE module I/O subsystem, providing a range of I/O options.

Four multiprotocol serial I/O channels, a parallel I/O channel and a Real Time Clock with on-board battery backup are installed on the base board which, in combination with EAGLE modules, make the CPU board a true single board computer system.

A broad range of operating systems and kernels is available for the CPU board. However, as with all FORCE COMPUTERS' CPU cards, VMEPROM firmware is provided with the board at no extra cost. VMEPROM is a Real Time Kernel and is installed on the CPU board in the 16-bit wide EPROM sockets, which results in a 32-bit wide System EPROM area. This ensures that the board is supplied ready to use.

This page intentionally left blank

## 2. THE PROCESSOR

#### 2.1 The CPU 68040

#### 2.1.1 Hardware Interface of the 68040

The 68040 uses a nonmultiplexed 32-bit address and 32-bit data bus. The 68040 does not support the dynamic bus sizing like the 68020 or 68030. On this CPU board the dynamic bus sizing is built in external hardware (two programmable gate arrays). This means if the 68040 does a long word read from a byte device, the external hardware will fetch 4 bytes from this byte wide device, from a long word and acknowledge the access cycle to the 68040. Therefore all device drives within the 68020 or 68030 can be used on this CPU board. Please note that the 68040 has a 4 Kbyte instruction and a 4 Kbyte data cache which may cause problems.

#### 2.1.1.1 General Operation

The CPU drives the address lines (A0-A31), the size lines (SIZ0, SIZ1) the transfer type (TT0-TT1) on every cycle, and modifier (TM0-2) signals independent of a cache hit or miss. These signals are used to decode the memory map of the CPU board.

The transfer start (TS) signals the hardware on the CPU board that the current cycle is not a cache cycle, and that the decoding outputs are valid.

The 32 data lines (D0-D31) are also driven from the processor on write cycles and sensed on read cycles.

The size of the data transfer is defined by the SIZE output signals (always driven from the CPU when master). The transfer acknowledge or the transfer error acknowledge signal (TA, TEA) or both terminate the transfer cycle. CPU 68040 cycles only allow a port width of 32 bits.

If an access error occurs (TEA sensed from the CPU), exception handling starts because the current cycle has been aborted (illegal transfer or wrong data).

During local bus operation, an access error will be generated if a device does not respond correctly.

VMEbus transfers may also be aborted via a TEA (VMEbus : BERR\*).

The TA and TEA signal asserted simultaneously initiate a retry cycle.

#### 2.2 The Instruction Set

For the 68040 instruction set and further information relative to programming, please refer to the 68040 User's Manual.

## **2.3 Vector Table of the 68040**

The following table lists all vectors defined and used by the 68040 CPU.

## Table 2-1: Exception Vector Assignments

| Vector<br>Number(s) | Vector Offset<br>(Hex) | Assignment                                       |  |
|---------------------|------------------------|--------------------------------------------------|--|
| 0                   | 000                    | Reset Initial Interrupt Stack Pointer            |  |
| 1                   | 004                    | Reset Initial Program Counter                    |  |
| 2                   | 008                    | Access Fault (Bus Error)                         |  |
| 3                   | 00C                    | Address Error                                    |  |
| 4                   | 010                    | Illegal Instruction                              |  |
| 5                   | 014                    | Integer Divide by Zero                           |  |
| 6                   | 018                    | CHK, CHK2 Instruction                            |  |
| 7                   | 01C                    | FTRAPcc, TRAPcc, TRAPV Instructions              |  |
| 8                   | 020                    | Privilege Violation                              |  |
| 9                   | 024                    | Trace                                            |  |
| 10                  | 028                    | Line 1010 Emulator (Unimplemented A-Line Opcode) |  |
| 11                  | 020                    | Line 1111 Emulator (Unimplemented F-Line Opcode) |  |
| 12                  | 030                    | (Unassigned, Reserved)                           |  |
| 13                  | 034                    | Defined for MC68020/MC68030, not for MC68040     |  |
| 14                  | 038                    | Format Error                                     |  |
| 15                  | 030                    | Uninitialized Interrupt                          |  |
| 16-23               | 040-05C                | (Unassigned, Reserved)                           |  |
| 24                  | 060                    | Spurious Interrupt                               |  |
| 25                  | 064                    | Level 1 Interrupt Autovector                     |  |
| 26                  | 068                    | Level 2 Interrupt Autovector                     |  |
| 27                  | 06C                    | Level 3 Interrupt Autovector                     |  |
| 28                  | 070                    | Level 4 Interrupt Autovector                     |  |
| 29                  | 074                    | Level 5 Interrupt Autovector                     |  |
| 30                  | 078                    | Level 6 Interrupt Autovector                     |  |
| 31                  | 07C                    | Level 7 Interrupt Autovector                     |  |
| 32-47               | 080-0BC                | TRAP #0-15 Instruction Vectors                   |  |
| 48                  | 0C0                    | FP Branch or Set on Unordered Condition          |  |
| 49                  | 0C4                    | FP Inexact Result                                |  |
| 50                  | 0C8                    | FP Divide by Zero                                |  |
| 51                  | occ                    | FP Underflow                                     |  |
| 52                  | ODO                    | FP Operand Error                                 |  |
| 53                  | OD4                    | FP Overflow                                      |  |
| 54                  | 0D8                    | FP Signaling NAN                                 |  |
| 55                  | ODC                    | FP Unimplemented Data Type                       |  |
| 56                  | OEO                    | Defined for MC68030 and MC68851, not for MC68040 |  |
| 57                  | 0E4                    | Defined for MC68851, not for MC68040             |  |
| 58                  | 0E8                    | Defined for MC68851, not for MC68040             |  |
| 59-63               | 0EC-0FC                | (Unassigned, Reserved)                           |  |
| 64-255              | 100-3FC                | User Defined Vectors (192)                       |  |

For test purposes the clock signal for the microprocessor is connected via jumper B17 to the devices. When using the CPU board, this jumper must be inserted according to the following figure.

## CAUTION

If jumper B17 is removed, damage may be caused to the devices on the CPU board.

Figure 2-1: Jumper Setting for B17







## 3. THE LOCAL BUS

#### 3.1 The FGA-002 Gate Array

The FGA-002 Gate Array featured on this CPU board has 24,000 gates and 281 pins.

The FGA-002 Gate Array controls the local bus and builds the interface to the VMEbus. It also includes a DMA controller, complete interrupt management, a message broadcast interface (FMB), timer functions, and mailbox locations.

This gate array monitors the local bus. This in turn signifies that if any local device is to be accessed, the gate array takes charge of all control signals in addition to used address and data signals.

The FGA-002 Gate Array serves as a manager for the VMEbus. All VMEbus address and data lines are connected to the gate array through the buffers. Additional functions such as the VMEbus interrupt handler are also installed on the FGA-002 Gate Array. The SGL VMEbus arbiter in the FGA/002 must remain disabled because the 4 level VME arbiter of the CPU board is designed in a separate device and connected with the VME bus (please refer to *chapter 6.4* VMEbus Arbitration in *this section*).

The start address of the FGA-002 Gate Array registers is \$FFD00000. All registers of the gate array and associated functions are described in detail in the FGA-002 Gate Array Users Manual.

#### 3.2 The Shared RAM

On this CPU board the shared RAM is placed on a module to allow the adaption of DRAM or SRAM to the base board.

All signals which are needed to control the shared RAM are available on the RAM module connector. Therefore RAM devices with different access times can also be used on this CPU board to take advantage of the 68040 with higher frequency if it becomes available.

#### **3.2.1 General Operation**

The Shared RAM is accessible from the 68040 and from the VMEbus. The access address for the 68040 starts at \$00000000. The access address for the VMEbus is software programmable in 4 Kbyte steps. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

If an access from the VMEbus takes place the onboard logic requests the local bus mastership from the local arbiter via the FGA-002 Gate Array. After the arbiter has granted local bus mastership to the FGA-002 Gate Array, the access cycle is executed. A read cycle is terminated by latching all data from the memory; a write cycle is ended by storing the data in the memory cells. Both read and write cycles are terminated on the local bus side and the FGA-002 Gate Array immediately releases bus mastership to the CPU while completing the fully asynchronous VMEbus access cycle.

#### 3.2.2 Shared RAM Information

The RAM module connector holds several signals which are software readable and inform the user concerning RAM type and functionality.

These pins are readable via the PI/T2 device which is installed on the CPU board. For base address and register address information please refer to the chapter "Address Map of the PI/T2 Registers".

The following table shows the information which can be read and the corresponding PI/T bit. The RAM modules which are accessible are described in the following chapters which also contain the "RAM Type Information" description.

| RAM Type Information on PI/T2   |                      |             |                                                                                     |  |  |
|---------------------------------|----------------------|-------------|-------------------------------------------------------------------------------------|--|--|
| PI/T Bit Name Value Description |                      |             |                                                                                     |  |  |
| PBO<br>PB1<br>PB2               | MCD0<br>MCD1<br>MCD2 | *<br>*<br>* | Describes the memory size of the module.<br>Please refer to the following chapters. |  |  |
| PC2                             | RAMTYP               | 0<br>1      | SRAM<br>DRAM                                                                        |  |  |
| PC4                             | BURST                | 0           | Not available<br>Available                                                          |  |  |
| PC6                             | PARITY               | 0<br>1      | Not available<br>Available                                                          |  |  |

#### 3.2.3 The DRM-01/4

The following CPU boards are assembled with the DRM-01/4.

| CPU Board                                                                    | RAM Module |  |  |
|------------------------------------------------------------------------------|------------|--|--|
| CPU-40B/4/xx                                                                 | DRM-01/4   |  |  |
| "xx" contains the EAGLE module number and is independent for the RAM module. |            |  |  |

The DRM-01/4 is a 4 Mbyte RAM module using Dynamic Random Access Memory devices. The RAM module has the following features.

#### Features of the DRM-01/4

- 4 Mbyte DRAM
- Burst READ and Burst WRITE capability
- Parity Generation and Checking
- Asynchronous refresh is provided every 14µs
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$003FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

The DRAM module includes byte parity check for local and VMEbus accesses. If a parity error is detected on a VMEbus cycle, a BERR is forced to the VMEbus informing the requestor that a parity error has occurred. On local accesses, a Transfer Error Acknowledge (TEA) is forced to the processor if a parity error was detected. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-40/B      | 25 MHz                   | 4                                                                        | 1                                              | 3                                          | 0                                         |

## 3.2.4 RAM Type Information for the DRM-01/4

The following information can be read from the PI/T2.

| RAM Type Information |        |   |  |  |
|----------------------|--------|---|--|--|
| PI/T Bit             | Value  |   |  |  |
| PB0                  | MCD4   | 1 |  |  |
| PB1                  | MCD1   | 1 |  |  |
| PB2                  | MCD2   | 0 |  |  |
| PC2                  | RAMTYP | 1 |  |  |
| PC4                  | BURST  | 1 |  |  |
| PC6                  | PARITY | 1 |  |  |

## 3.2.5 Summary of the DRM-01/4

| Capacity            | 4 Mbytes                                     |
|---------------------|----------------------------------------------|
| Address Range       | \$00000000 to \$003FFFFF                     |
| Port Data Width     | 32 bits                                      |
| Local Data Width    | 32 bits                                      |
| Burst Mode          | Supported                                    |
| Parity Mode         | Supported                                    |
| Device              | 1M x 1 Nibble Mode                           |
| Supported Transfers | Byte, Word, Long word, Cache Line (16 bytes) |

#### 3.2.6 The DRM-01/16

The following CPU boards are assembled with the DRM-01/16.

| CPU Board                                                                    | RAM Module |  |  |
|------------------------------------------------------------------------------|------------|--|--|
| CPU-40B/16/xx                                                                | DRM-01/16  |  |  |
| "xx" contains the EAGLE module number and is independent for the RAM module. |            |  |  |

The DRM-01/16 is a 16 Mbyte RAM module which is used on the CPU-40B/16.

#### Features of the DRM-01/16

- 16 Mbyte DRAM
- Burst READ and Burst WRITE capability
- Parity Generation and Checking
- Asynchronous refresh is provided every 14µs
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$00FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes.

For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

The DRAM module includes byte parity check for local and VMEbus accesses. If a parity error is detected on a VMEbus cycle, a BERR is forced to the VMEbus informing the requestor that a parity error has occurred. On local accesses, a Transfer Error Acknowledge (TEA) is forced to the processor if a parity error was detected. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-40/B      | 25 MHz                   | 4                                                                        | 1                                              | 3                                          | 0                                         |

## 3.2.7 RAM Type Information for the DRM-01/16

The following information can be read from the PI/T2.

| RAM Type Information |                      |             |  |
|----------------------|----------------------|-------------|--|
| PI/T Bit             | Value                |             |  |
| PBO<br>PB1<br>PB2    | MCD4<br>MCD1<br>MCD2 | 1<br>0<br>0 |  |
| PC2                  | RAMTYP               | 1           |  |
| PC4                  | BURST                | 1           |  |
| PC6 PARITY           |                      |             |  |

#### 3.2.8 Summary of the DRM-01/16

| Capacity            | 16 Mbytes                                    |
|---------------------|----------------------------------------------|
| Address Range       | \$00000000 to \$00FFFFF                      |
| Port Data Width     | 32 bits                                      |
| Local Data Width    | 32 bits                                      |
| Burst Mode          | Supported                                    |
| Parity Mode         | Supported                                    |
| Device              | 4M x 1 Nibble Mode                           |
| Supported Transfers | Byte, Word, Long word, Cache Line (16 bytes) |

#### 3.2.9 The SRM-01/4

The following CPU boards are assembled with the SRM-01/4.

| CPU Board                                                                    | RAM Module |  |  |
|------------------------------------------------------------------------------|------------|--|--|
| CPU-41B/4/xx                                                                 | SRM-01/4   |  |  |
| "xx" contains the EAGLE module number and is independent for the RAM module. |            |  |  |

The SRM-01/4 is a 4 Mbyte RAM module using Static Memory devices. The RAM module has the following features.

#### Features of the SRM-01/4

- 4 Mbyte SRAM
- Burst READ and Burst WRITE capability
- Battery Backup via VMEbus
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$003FFFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes. For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

Parity check is not necessary for SRAM devices, because these components are protected against soft errors owing alpha emission. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-41/B      | 25 MHz                   | 3                                                                        | 1                                              | 2                                          | 0                                         |

## 3.2.10 RAM Type Information for the SRM-01/4

The following information can be read from the PI/T2.

| RAM Type Information |                      |             |  |  |
|----------------------|----------------------|-------------|--|--|
| PI/T Bit             | Value                |             |  |  |
| PBO<br>PB1<br>PB2    | MCD4<br>MCD1<br>MCD2 | 1<br>1<br>0 |  |  |
| PC2                  | RAMTYP               | 0           |  |  |
| PC4                  | BURST                | 1           |  |  |
| PC6                  | PARITY               | 0           |  |  |

#### 3.2.11 Summary of the SRM-01/4

| Capacity            | 4 Mbytes                                     |
|---------------------|----------------------------------------------|
| Address Range       | \$00000000 to \$003FFFFF                     |
| Port Data Width     | 32 bits                                      |
| Local Data Width    | 128 bits                                     |
| Burst Mode          | Supported                                    |
| Parity Mode         | Not necessary                                |
| Device              | 128K x 8 Static RAM                          |
| Supported Transfers | Byte, Word, Long word, Cache Line (16 bytes) |

#### 3.2.12 The SRM-01/8

The following CPU boards are assembled with the SRM-01/8.

| CPU Board                                                                    | RAM Module |  |  |
|------------------------------------------------------------------------------|------------|--|--|
| CPU-41B/8/xx                                                                 | SRM-01/8   |  |  |
| "xx" contains the EAGLE module number and is independent for the RAM module. |            |  |  |

The SRM-01/8 is an 8 Mbyte RAM module which is used on the CPU-41B/8.

#### Features of the SRM-01/8

- 8 Mbyte SRAM
- Burst READ and Burst WRITE capability
- Battery Backup via VMEbus
- Accessible via VMEbus

The access address for the 68040 is \$00000000 to \$007FFFF.

The access address for the VMEbus is programmable in 4 Kbyte steps through the FGA-002. The defined memory range can be write protected in coordination with the address modifier codes.

For example, in supervisor mode the memory can be read and written, in user mode memory can only be read.

Parity check is not necessary for SRAM devices, because these components are protected against soft errors owing alpha emission. The following chart lists the required CPU clock cycles and wait states for accessing the shared RAM.

| Board<br>Type | 68040 Clock<br>Frequency | No. of CPU Clock<br>Cycles Counted<br>From TS to TA<br>for Normal Cycles | No. of CPU Clock<br>Cycles for<br>Burst Cycles | No. of Wait<br>States for<br>Normal Cycles | No. of Wait<br>States for<br>Burst Cycles |
|---------------|--------------------------|--------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------|-------------------------------------------|
| CPU-41/B      | 25 MHz                   | 3                                                                        | 1                                              | 2                                          | 0                                         |

## 3.2.13 RAM Type Information for the SRM-01/8

The following information can be read from the PI/T2.

| RAM Type Information |                      |             |  |  |  |  |
|----------------------|----------------------|-------------|--|--|--|--|
| PI/T Bit             | Value                |             |  |  |  |  |
| PBO<br>PB1<br>PB2    | MCD4<br>MCD1<br>MCD2 | 0<br>1<br>0 |  |  |  |  |
| PC2                  | 0                    |             |  |  |  |  |
| PC4 BURST            |                      | 1           |  |  |  |  |
| PC6                  | PARITY               | 0           |  |  |  |  |

## 3.2.14 Summary of the SRM-01/8

| Capacity            | 8 Mbytes                                     |
|---------------------|----------------------------------------------|
| Address Range       | \$00000000 to \$007FFFF                      |
| Port Data Width     | 32 bits                                      |
| Local Data Width    | 128 bits                                     |
| Burst Mode          | Supported                                    |
| Parity Mode         | Not necessary                                |
| Device              | 128K x 8 Static RAM                          |
| Supported Transfers | Byte, Word, Long word, Cache Line (16 bytes) |

#### 3.3 The System EPROM Area

The first two read cycles after RESET of the microprocessor are fetches of the Initial Interrupt Stack Pointer and the Initial Program Counter. These cycles are executed under addresses \$0 and \$4 respectively. A special control logic maps the System EPROM Area down to this address to start the CPU from the installed EPROMs. As a result of this downmapping, the first two long words in the EPROM must contain the following data:

\$0 in EPROM Initial Interrupt Stack Pointer \$4 in EPROM Initial Program Counter

The data path of the System EPROM Area is 32 bits wide. The system EPROM consists of two 16 bit wide EPROM devices.

#### 3.3.1 Memory Organization of the System EPROM Area

The memory organization of the System EPROM and the location number of the sockets are outlined in the following figure. The one after that shows the location diagram of the sockets.

| Figure 3-1: | Memory | Organization   | of the S | ystem EPROM Area |
|-------------|--------|----------------|----------|------------------|
|             |        | ••• 3••••••••• | •••••    |                  |

| Long Word Address                                             | D31 D24     | D23 D16     | D15 D8      | D7 D0       |
|---------------------------------------------------------------|-------------|-------------|-------------|-------------|
| \$FF00 0000                                                   | Byte O      | Byte 1      | Byte 2      | Byte 3      |
| \$FF00 0000                                                   | \$FF00 0000 | \$FF00 0001 | \$FF00 0002 | \$FF00 0003 |
|                                                               | Byte 4      | Byte 5      | Byte 6      | Byte 7      |
| \$FF00 0004                                                   | \$FF00 0004 | \$FF00 0005 | \$FF00 0006 | \$FF00 0007 |
|                                                               |             |             |             |             |
|                                                               | UU<br>J30   | UM<br>J30   | LM<br>J29   | LL<br>J29   |
| UU = Upper Upper Byte in J30<br>UM = Upper Middle Byte in J30 |             |             |             |             |

UM = Upper Middle Byte in J30 / LM = Lower Middle Byte in J29 2

LL = Lower Lower Byte in J29 /



Figure 3-2: Location Diagram of the System EPROM Area

The following read only cycles can be forced to the System EPROM Area:

Byte: 8 Bits | Word: 16 Bits | Long Word: 32 Bits

The processor supports long word read instructions odd addresses, resulting in byte and word accesses which meet the 68040 boundary requirements. If a user program must be burned into EPROMs for CPU board usage, the data bytes must be burned into the different chips as shown below.

| Device Locations       | Add                          | lress                        |
|------------------------|------------------------------|------------------------------|
| UU, UM:<br>J30 (UPPER) | XXXO<br>XXX4<br>XXX8<br>XXXC | XXX1<br>XXX5<br>XXX9<br>XXXD |
| LM, LL:<br>J29 (LOWER) | XXX2<br>XXX6<br>XXXA<br>XXXE | XXX3<br>XXX7<br>XXXB<br>XXXF |

#### CAUTION

- 1) The bus size of the System EPROM Area cannot be changed. Two EPROMs must always be used for proper operation.
- Microprocessor interactive fetches can only be on addresses (\$0,2,4,6, 8..). An Address Trap Error occurs if a program is started/executed on odd addresses (\$1,3,5,7...).
- Data can be read from any address; odd, even or unaligned in byte, word, or long word format.
- 4) Write cycles to the EPROM Area are forbidden.
- 5) All chips must be the same device type and access time for usage in System EPROM Area.

#### Example for Data Transfers:

The following instruction is fully supported from the System EPROM Area:

```
MOVE.X ($FF00 000Y), D0
```

| Х | = | W | = | Byte<br>Word<br>Long Word | 1 Byte<br>2 Bytes<br>4 Bytes |
|---|---|---|---|---------------------------|------------------------------|
| Y |   |   |   |                           |                              |

All combinations of the listed instructions are allowed and possible.

#### 3.3.2 Usable Device Types for the EPROM Area

The following device types or equivalent are supported by the System EPROM Area:

| Device    | Device Capacity | Total Capacity | Default Configuration |
|-----------|-----------------|----------------|-----------------------|
| 27210     | 64K x 16        | 256 Kbytes     | х                     |
| 272048    | 128K x 16       | 512 Kbytes     |                       |
| UNDEFINED | 256K x 16       | 1 Mbyte        |                       |
| UNDEFINED | 512K x 16       | 2 Mbytes       |                       |

The default configuration, using 27210 devices, is provided for the installation of VMEPROM. The following figure outlines the different jumper settings for the listed device types and the one to follow shows the location diagram of Jumperfield B11 for device dependent configuration. The Appendix of this Hardware User's Manual lists a table of the usable pinouts for the System EPROM Area if other devices than those listed must be used.

|            | Jumpersetting:                    | Device:   | Organization:          |
|------------|-----------------------------------|-----------|------------------------|
| -          | B11<br>1 0<br>0 0<br>0 0<br>0 0   | 27C210    | 64K x 16               |
| MN177-3693 | B11<br>1 0 0<br>0 0<br>0 0<br>B11 | 27C2048   | 128K x 16<br>(DEFAULT) |
| W          | 1<br>0-0<br>0 0                   | UNDEFINED | 256K x 16              |
|            | B11<br>1 0-0<br>0-0<br>0-0        | UNDEFINED | 512K x 16              |

# Figure 3-3: Configuration Jumper Settings of System EPROM Area Jumperfield B11

## Figure 3-4: Location Diagram of Jumperfield B11 Configuration of the System EPROM Area



#### **3.3.3 Access Time Selection of the System EPROM Area**

The access time of the System EPROM Area is software programmable in the FGA-002 Gate Array. It can be adapted to various access speeds of the EPROM devices. A complete description of the FGA-002 Gate Array can be found in the related manual.

#### **3.3.4** Address Map of the System EPROM Area

The start address of the System EPROM Area is mapped via the FGA-002 Gate Array and cannot be changed. The size of this memory area depends on the memory capacity of the used devices. The following table lists the address map of the EPROM area.

Table 3-1: Address Map of the EPROM Area

| Start Address | End Address | Used Device | Total Capacity | Default<br>Configuration |
|---------------|-------------|-------------|----------------|--------------------------|
| FF00 0000     | FF03 FFFF   | 27210       | 256 KBYTES     | x                        |
| FF00 0000     | FF07 FFFF   | 272048      | 512 KBYTES     |                          |
| FF00 0000     | FF0F FFFF   | UNDEFINED   | 1 MBYTE        |                          |
| FF00 0000     | FF1F FFFF   | UNDEFINED   | 2 MBYTES       |                          |

#### 3.3.5 Summary of the EPROM Area

| Not Allowed Access with Function Code                                          | 111                                  |
|--------------------------------------------------------------------------------|--------------------------------------|
| Usable Data Bits                                                               | D00 - D31                            |
| Supported Port Size                                                            | Long Word                            |
| No. of Devices to be Installed                                                 | 2                                    |
| Upper Upper Byte<br>Upper Middle Byte<br>Lower Middle Byte<br>Lower Lower Byte | J30<br>J30<br>J29<br>J29             |
| Maximum Capacity                                                               | 2 Mbytes                             |
| Default Configuration for                                                      | 128K * 16 Devices                    |
| Default Access Time                                                            | 200ns                                |
| Access Address Range                                                           | \$FF00 0000 START<br>\$FF03 FFFF END |

#### 3.4 The FLXibus

The CPU board can be used with or without an I/O subsystem, called an "EAGLE" Module.

The EAGLE module increases the functionality of the board and adds extra I/O features to fit the application requirement. EAGLE modules connect directly to the FLXi (FORCE Local eXpansion interface) of the base board.

If your CPU board is assembled with an EAGLE module please refer to the "EAGLE Module" manual which is shipped with this board and should be placed in **Section 6** of this manual.

#### **3.4.1** Introduction to the FLXibus

The FLXi (FORCE Local eXpansion interface) is a 32 bit interface with non-multiplexed data and address lines.

An EAGLE module holds a FLXibus interface and an I/O interface (64 pins), which is directly connected to row a and row c of the VMEbus P2 connector.

The aim of the EAGLE module concept is to be more flexible in the I/O part of the board. This avoids the complete redesign of a board if new I/O devices or customer specific solutions must be implemented. When having several modules available we can take advantage of a basis contingent for the design of new boards.

The EAGLE module has the ability to become master of the FLXi and therefore the devices on the EAGLE module are able to transfer data to the "main memory" on the base board if they have DMA capability.

#### Features of the FLXibus

- One or more identical or different EAGLE modules can be used on a base board. This CPU board is capable of holding one EAGLE module.
- The EAGLE modules contain all necessary software which is stored in the on-board EPROMs.
- The EAGLE module can become bus master (e.g. for DMA transfers) on the base board.
- Interrupts to the base boards are supported.
- FLXibus definition is based on the 68020 asynchronous interface and supports frequencies up to 50 MHz.

#### 3.5 The Local FLASH EPROM

The CPU board holds a 128K x 8 FLASH EPROM which allows data storage without the need of a battery or supply via the +5VSTDBY VMEbus line.

#### 3.5.1 Memory Organization of the FLASH EPROM

The FLASH EPROM is connected with the data lines D24 to D31. This device features a byte port. The cycle control chip (CCC) between the 68040 processor and the FGA-002 simulates the dynamic bus sizing, so that succeeding bytes seen by the microprocessor are handled in the same manner as succeeding bytes for the FLASH EPROM. Byte, word, and long word accesses are managed by the dynamic bus sizing of the microprocessor. For further details, please refer to the CCC description.

Data can be read from any address; odd, even or unaligned in byte, word, or long word format, and written to any address in byte format.

#### Example for Data Transfers:

The following instruction is fully supported from the FLASH EPROM Area:

MOVE.X (\$FFC8 000Y), D0

| X      | = | W      | = | Byte<br>Word<br>Long | Word | 2 | Byte<br>Bytes<br>Bytes |
|--------|---|--------|---|----------------------|------|---|------------------------|
| Y<br>Y |   | 1<br>2 |   |                      |      |   |                        |
|        |   |        |   |                      |      |   |                        |

#### 3.5.2 Programming the FLASH EPROM

The software and hardware to erase and program the FLASH EPROM is installed on the CPU board. For detailed information on how to program the FLASH EPROM, please refer to the CPU-40 VMEPROM description which is located in *Section 7* and *Section 8* of this manual.

Before programming the FLASH EPROM the write protection jumper on jumperfield B16 must be set from 1-2 to 2-3. The following page shows the location of jumperfield B16.

#### 3.5.3 Address Map of the FLASH EPROM

The address range of the FLASH EPROM Area is mapped via the FGA-002 and a PAL and is unchangeable.

#### 3.5.4 Summary of the Local FLASH Memory

| Not Allowed Access with Function Code | 111                    |
|---------------------------------------|------------------------|
| Supported Port Size                   | Byte                   |
| Capacity                              | 128 Kbytes             |
| Chip Organization                     | 128K x 8               |
| Access Time                           | 200ns                  |
| Access Address                        | \$FFC80000 to FFC9FFFF |

#### 3.5.5 Jumper Settings for B16



### **3.5.6** Location Diagram of Jumperfield B16



#### 3.6 The Local SRAM

The SRAM allows the user to retain data even when the power supply is switched off. A battery provides the voltage for the SRAM standby mode. With Jumper B20, it is possible to select either the on board battery or the +5VSTDBY of the VMEbus for backup supply.

#### 3.6.1 Memory Organization of the User SRAM

This device features a byte port. External hardware simulates the dynamic bus sizing, so that succeeding bytes seen by the microprocessor are handled in the same manner as succeeding bytes for the Local SRAM. Byte, word, and long word accesses are managed by the dynamic bus sizing of the external hardware.

Data can be read from and written to any address; odd, even or unaligned in byte, word, or long word format.

#### Example for Data Transfers:

The following instruction is fully supported from the SRAM Area:

```
MOVE.X ($FFC0 000Y), DO
```

| X | = | W | = | Byte<br>Word<br>Long | Word | 2 | Byte<br>Bytes<br>Bytes |
|---|---|---|---|----------------------|------|---|------------------------|
| Y | = | 0 |   |                      |      |   |                        |
| Y | = | 1 |   |                      |      |   |                        |
| Y | = | 2 |   |                      |      |   |                        |
| Y | Ξ | 3 |   |                      |      |   |                        |
|   | • |   |   |                      |      |   |                        |
|   | ٠ |   |   |                      |      |   |                        |
|   | ٠ |   |   |                      |      |   |                        |
|   |   |   |   |                      |      |   |                        |

All combinations of the listed instructions are allowed and possible.

This SRAM can be used to save special settings of the FGA-002 as described in *Section 7*, "*Introduction to VMEPROM*" of this manual.

The following figure shows the location diagram of Jumperfield B20 for the backup supply. The default configuration uses the on board battery.

Please note that the Real Time Clock on the CPU board is supplied via the same jumperfield.



#### NOTE

The battery is not installed on the CPU board to avoid damage during shipment.





## Figure 3-5: Location Diagram of the Backup Supply Jumperfield B1 and B20

#### 3.6.2 The Address Map of the SRAM Area

The address range of the SRAM Area is mapped via the FGA-002 and a PAL and is unchangeable. The SRAM is used by the boot software and therefore not fully available to the user. Please refer to the *FGA-002 User's Manual, Section 10, Boot Software*.

#### 3.6.3 Summary of the SRAM Area

| Not Allowed Access with Function Code | 111                       |
|---------------------------------------|---------------------------|
| Supported Port Size                   | Byte                      |
| Capacity                              | 128 Kbytes                |
| Chip Organization                     | 128K * 8 Devices          |
| Access Time                           | 100ns                     |
| Access Address                        | \$FFC0 0000 - \$FFC1 FFFF |

#### 3.7 The Boot EPROM

The CPU board contains one 28-pin EPROM which is used to boot up the processor and run a program to initialize register contents of the FGA-002 Gate Array. This program finishes in such a manner that the System EPROM appears to have booted the CPU Board. The device type of the Boot EPROM is 27512 with the total memory capacity of 64 Kbytes. The location is J15.

For more detailed information over the Boot EPROM, please refer to *Section 10, "Boot Software Description*" of the FGA-002 Users Manual.

The figure on the page to follow displays the location of the Boot EPROM on the CPU board.

#### **3.7.1** Summary of the Boot EPROM Area

| Access Not Allowed with Function Code | 111                       |
|---------------------------------------|---------------------------|
| Supported Port Size                   | Byte                      |
| No. of Devices to be installed        | 1                         |
| Maximum Capacity                      | 64 Kbytes                 |
| Default Access Time                   | 200ns                     |
| Access Address                        | \$FFE0 0000 - \$FFE0 FFFF |





#### 3.8 The DUSCC 68562

The Dual Universal Serial Communications Controller 68562 (DUSCC) is a single-chip MOS-LSI communications device that provides two independent, multiprotocol, full duplex receiver/ transmitter channels in a single package. Each channel consists of a receiver, a transmitter, a 16 bit multifunction counter/timer, a digital phaselocked loop (DPLL), a parity/CRC generator and checker, and associated control circuits.

#### Features of the DUSCC

- Dual full-duplex synchronous/asynchronous receiver and transmitter
- Multiprotocol operation consisting of:

| BOP:   | HDLC/ADCCP, SDLC, SDLC Loop, X.25 or X.75 link level |
|--------|------------------------------------------------------|
| COP:   | BISYNC, DDCMP, X.21                                  |
| ASYNC: | 5-8 bit plus optional parity                         |

- Programmable data encoding formats: NRZ, NRZI, FMO, FM1, Manchester
- 4 character receiver and transmitter FIFOs
- Individual programmable baud rate for each receiver and transmitter
- Digital phase locked loop
- User programmable counter/timer
- Programmable channel modes full/half duplex, auto echo, local loopback
- Modem control signals for each channel: RTS, CTS, DCD
- CTS and DCD programmable auto enables for Receiver (RX) and Transmitter (TX)
- Programmable interrupt on change of CTS or DCD

#### 3.8.1 Address Map of the DUSCC1 Registers

The following tables contain the complete register map of the DUSCC1.

### Table 3-2: Serial I/O Port #1 (DUSCC1) Register Address Map

| Port Base Address: \$FF802000 |                                  |    |     |          |                                |  |  |  |
|-------------------------------|----------------------------------|----|-----|----------|--------------------------------|--|--|--|
| Address<br>HEX                | HEX Value Mode Label Description |    |     |          | Description                    |  |  |  |
| \$FF802000                    | 00                               | 00 | R/W | DUSCMR1  | Channel Mode Reg 1             |  |  |  |
| \$FF802001                    | 01                               | 00 | R/W | DUSCMR2  | Channel Mode Reg 2             |  |  |  |
| \$FF802002                    | 02                               |    | R/W | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |
| \$FF802003                    | 03                               |    | R/W | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |
| \$FF802004                    | 04                               | 00 | R/W | DUSTPR   | Transmitter Parameter Reg      |  |  |  |
| \$FF802005                    | 05                               |    | R/W | DUSTTR   | Transmitter Timing Reg         |  |  |  |
| \$FF802006                    | 06                               | 00 | R/W | DUSRPR   | Receiver Parameter Reg         |  |  |  |
| \$FF802007                    | 07                               |    | R/W | DUSRTR   | Receiver Timing Reg            |  |  |  |
| \$FF802008                    | 08                               |    | R/W | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |
| \$FF802009                    | 09                               |    | R/W | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |
| \$FF80200A                    | 0A                               |    | R/W | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |
| \$FF80200B                    | OB                               | 00 | R/W | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |
| \$FF80200C                    | 0C                               |    | R   | DUSCTH   | Counter/Timer High             |  |  |  |
| \$FF80200D                    | 0D                               |    | R   | DUSCTL   | Counter/Timer Low              |  |  |  |
| \$FF80200E                    | OE                               | 00 | R/W | DUSPCR   | Pin Configuration Reg          |  |  |  |
| \$FF80200F                    | OF                               |    | R/W | DUSCCR   | Channel Command Reg            |  |  |  |
| \$FF802010                    | 10                               |    |     |          |                                |  |  |  |
| \$FF802011                    | 11                               |    |     |          |                                |  |  |  |
| \$FF802012                    | 12                               |    | w   | DUSTFIFO | Transmitter FIFO               |  |  |  |
| \$FF802013                    | 13                               |    |     |          |                                |  |  |  |
| \$FF802014                    | 14                               |    |     |          |                                |  |  |  |
| \$FF802015                    | 15                               |    |     |          |                                |  |  |  |
| \$FF802016                    | 16                               |    | R   | DUSRFIFO | Receiver FIFO                  |  |  |  |
| \$FF802017                    | 17                               |    |     |          |                                |  |  |  |
| \$FF802018                    | 18                               | 00 | R/W | DUSRSR   | Receiver Status Reg            |  |  |  |
| \$FF802019                    | 19                               | 00 | R/W | DUSTRSR  | Transmitter/Receiver Stat Reg  |  |  |  |
| \$FF80201A                    | 1A                               |    | R/W | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |
| \$FF80201C                    | 1C                               | 00 | R/W | DUSIER   | Interrupt Enable Reg           |  |  |  |

| Port Base Address: \$FF802000 |                  |                |      |          |                                |  |  |  |  |
|-------------------------------|------------------|----------------|------|----------|--------------------------------|--|--|--|--|
| Address<br>HEX                | Offset<br>HEX    | Reset<br>Value | Mode | Label    | Description                    |  |  |  |  |
| \$FF802020                    | 00               | 00             | R/W  | DUSCMR1  | Channel Mode Reg 1             |  |  |  |  |
| \$FF802021                    | 01               | 00             | R/W  | DUSCMR2  | Channel Mode Reg 2             |  |  |  |  |
| \$FF802022                    | 02               |                | R/W  | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |  |
| \$FF802023                    | 03               |                | R/W  | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |  |
| \$FF802024                    | 04               | 00             | R/W  | DUSTPR   | Transmitter Parameter Reg      |  |  |  |  |
| \$FF802025                    | 05               |                | R/W  | DUSTTR   | Transmitter Timing Reg         |  |  |  |  |
| \$FF802026                    | 06               | 00             | R/W  | DUSRPR   | Receiver Parameter Reg         |  |  |  |  |
| \$FF802027                    | 07               |                | R/W  | DUSRTR   | Receiver Timing Reg            |  |  |  |  |
| \$FF802028                    | 08               |                | R/W  | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |  |
| \$FF802029                    | 09               |                | R/W  | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |  |
| \$FF80202A                    | 0A               |                | R/W  | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |  |
| \$FF80202B                    | OB               | 00             | R/W  | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |  |
| \$FF80202C                    | 0C               |                | R    | DUSCTH   | Counter/Timer High             |  |  |  |  |
| \$FF80202D                    | OD               |                | R    | DUSCTL   | Counter/Timer Low              |  |  |  |  |
| \$FF80202E                    | 0E               | 00             | R/W  | DUSPCR   | Pin Configuration Reg          |  |  |  |  |
| \$FF80202F                    | OF               |                | R/W  | DUSCCR   | Channel Command Reg            |  |  |  |  |
| \$FF802030                    | 10- <sub>7</sub> |                |      |          |                                |  |  |  |  |
| \$FF802031                    | 11               |                |      |          |                                |  |  |  |  |
| \$FF802032                    | 12               |                | W    | DUSTFIFO | Transmitter FIFO               |  |  |  |  |
| \$FF802033                    | 13-              |                |      |          |                                |  |  |  |  |
| \$FF802034                    | 14- <sub>7</sub> |                |      |          |                                |  |  |  |  |
| \$FF802035                    | 15               |                |      |          |                                |  |  |  |  |
| \$FF802036                    | 16               |                | R    | DUSRFIFO | Receiver FIFO                  |  |  |  |  |
| \$FF802037                    | 17-1             |                |      |          |                                |  |  |  |  |
| \$FF802038                    | 18               | 00             | R/W  | DUSRSR   | Receiver Status Reg            |  |  |  |  |
| \$FF802039                    | 19               | 00             | R/W  | DUSTRSR  | Transmitter/Receiver Stat Reg  |  |  |  |  |
| \$FF80203A                    | 1A               |                | R/W  | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |  |
| \$FF80203C                    | 1C               | 00             | R/W  | DUSIER   | Interrupt Enable Reg           |  |  |  |  |

Table 3-4: Ports #1 and #2 (DUSCC1) Common Register Address Map

| Port Base Address: \$FF802000                                                       |                      |                      |                        |                                       |                                                                                                                     |  |  |  |  |
|-------------------------------------------------------------------------------------|----------------------|----------------------|------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Address     Offset     Reset       HEX     HEX     Mode       Label     Description |                      |                      |                        |                                       |                                                                                                                     |  |  |  |  |
| \$FF80201B<br>\$FF80201E<br>\$FF80201F<br>\$FF80203E                                | 1B<br>1E<br>1F<br>3E | 00<br>0F<br>00<br>0F | R/W<br>R/W<br>R/W<br>R | DUSGSR<br>DUSIVR<br>DUSICR<br>DUSIVRM | General Status Register<br>Interrupt Vec Reg Unmodified<br>Interrupt Control Register<br>Interrupt Vec Reg Modified |  |  |  |  |

#### 3.8.2 RS232 Hardware Configuration of Port #1 and #2

Ports #1 and #2 are built around the DUSCC (J19). The DUSCC is connected to the local 8 bit data bus.

The RS232 interfaces of port #1 and #2 are identical except that port #1 is additionally wired to a  $O\Omega$  resistor field which allows connection to the VMEbus P2 connector. The  $O\Omega$  resistors are not installed in the default configuration because it may conflict with the EAGLE module. All RS232 driver and receivers are installed in the default configuration. The I/O signals of port #1 are connected to the VME connector P2 as follows:

| Signal | Input | Output | VME Connector P2 | Description         |
|--------|-------|--------|------------------|---------------------|
| DCD    | х     |        | c29              | Data Carrier Detect |
| RXD    | Х     |        | c30              | Receive Data        |
| TXD    |       | Х      | c31              | Transmit Data       |
| DTR    |       | Х      | c32              | Data Terminal Ready |
| DSR    | Х     | Х      | a29              | Data Set Ready      |
| RTS    |       | Х      | a30              | Request to Send     |
| CTS    | Х     |        | a31              | Clear to Send       |
| GND    |       |        | a32              | Signal GND          |

The individual I/O signal assignment of ports #1 and #2 are listed as follows:

| Signal | Input | Output | 9 Pin D-Sub Connector | Description         |
|--------|-------|--------|-----------------------|---------------------|
| DCD    | х     |        | 1                     | Data Carrier Detect |
| RXD    | х     |        | 2                     | Receive Data        |
| TXD    |       | Х      | 3                     | Transmit Data       |
| DTR    |       | X      | 4                     | Data Terminal Ready |
| GND    |       |        | 5                     | Signal GND          |
| DSR    | Х     | Х      | 6                     | Data Set Ready      |
| RTS    |       | Х      | 7                     | Request to Send     |
| CTS    | Х     |        | 8                     | Clear to Send       |
| GND    |       |        | 9                     | Signal GND          |

The following figure shows the location diagram of the  $0\Omega$  resistor fields R563 to R569 and the figure afterwards displays the connection between the DUSCC and the VMEbus Connector P2, and the Micro D-Sub connector.

#### CAUTION

Before installing the  $O\Omega$  resistors to generate the port #1 availability on the VMEbus P2 Connector, please make sure that the EAGLE module which is being used does not occupy the VMEbus P2 signals c29 to c32 and a29 to a32. Otherwise the board will be damaged.





### Figure 3-8: RS232 Connection Between DUSCC1 and VMEbus Connector P2







3-35

The devices are labeled as shown in the following chart.

| Port# | Channel | Ba | Bb | Pa  | Connector |
|-------|---------|----|----|-----|-----------|
| 1     | a       | ВЗ | B5 | PD1 | 1/VME P2  |
| 2     | b       | В4 | B6 | PD2 | 2         |

The next figure shows the pinout of the Micro D-Sub connector for RS232. The figure on the next page displays the location of the RS232 configuration jumperfields. The default setting of the RS232 configuration jumperfield is shown in the next table.





# Figure 3-11: Location Diagram of RS232 Configuration Jumperfields B3, B4, B5, and B6



#### Table 3-5: Default Setting of RS232 Configuration Jumperfields



#### **3.8.3** Cable for the Micro D-Sub Connector

The CPU board is delivered with one 9-pin Micro D-Sub to 9-pin D-Sub Adapter Cable. Additional cables or a 9-pin Micro D-Sub to 25-pin D-Sub Adapter Cable are available from FORCE COMPUTERS.

#### 3.8.4 RS422/RS485 Hardware Configuration of Ports #1 and #2

The CPU board is delivered with RS232 compatible interface buffers installed on all serial I/O ports. It is possible to reconfigure I/O ports #1 and #2 to be RS422/RS485 compatible. Termination resistors can be installed to adapt various cable lengths and reduce reflections. The resistor value is user application dependent. A recommended value for all resistors is 1 KOHM. The RS422/RS485 interfaces of ports #1 and #2 are identical except that port #1 is additionally wired to a 0 $\Omega$  resistor field which allows connection to the VMEbus P2 connector.

The  $0\Omega$  resistors are not installed in the default configuration because it may conflict with the EAGLE module.

| Signal | Input | Output | VME Connector P2 | Description     |
|--------|-------|--------|------------------|-----------------|
| TXD-   |       | Х      | c29              | Transmit Data   |
| RTS-   |       | X      | c30              | Request to Send |
| CTS+   | Х     |        | c31              | Clear to Send   |
| RXD+   | Х     |        | c32              | Receive Data    |
| TXD+   |       | X      | a29              | Transmit Data   |
| RTS+   |       | X      | a30              | Request to Send |
| CTS-   | X     |        | a31              | Clear to Send   |
| RXD-   | X     |        | a32              | Receive Data    |

The next figure shows the location diagram of the  $0\Omega$  resistors R563 to R569 and the figure afterwards displays the connection between the DUSCC1 and the VMEbus connector.

#### CAUTION

Before installing the  $0\Omega$  resistors to generate the port #1 availability on the VMEbus P2 Connector, please make sure that the EAGLE module which is being used does not occupy the VMEbus P2 signals c29 to c32 and a29 to a32. Otherwise the board will be damaged.

The devices are labeled according to the following chart.

| Port# | Channel | Ba | Bb | Pa  | Connector   | Resistor Array |
|-------|---------|----|----|-----|-------------|----------------|
| 1     | а       | B3 | B5 | PD1 | 1/VMEbus P2 | J22            |
| 2     | b       | B4 | B6 | PD2 | 2           | J23            |





3-40





B3, B4

B5, B6





#### Figure 3-14: RS422/RS485 Pinout of the Micro D-Sub and D-Sub Connectors



The following table shows the PCB locations and devices that have to be inserted according to the RS232/RS422/RS485 configuration.

#### Table 3-7: PCB Locations for the RS232/RS422/RS485 Configuration

|        | RS232 Devices             | RS422/RS485 Devices                                 |            |  |  |
|--------|---------------------------|-----------------------------------------------------|------------|--|--|
| Port # | Driver and Receiver FH002 | Driver and Receiver FH002 Driver and Receiver FH003 |            |  |  |
| 1<br>2 | J20<br>J21                | J20<br>J21                                          | J22<br>J23 |  |  |

The RS422/RS485 compatible interface supports TXD, RXD, RTS, CTS with differential outputs and inputs. The port occupies the same eight pins of the P2 connector as in the RS232 compatible configuration, but with a different signal association. The following figure displays the location diagram for the RS232/RS422/RS485 driver/receiver J22 and resistor array J23.

# Figure 3-15: Location Diagram of RS422/RS485 Configuration Jumperfields B3, B4, B5, and B6



### Figure 3-16: Location Diagram of RS232/RS422/RS485 Driver/Receivers J20 and J21 plus Resistor Arrays J22 and J23



#### WARNING

- 1) Please make sure that the jumper setting is adapted to the user driver module.
- 2) Any mistakes could ruin the inserted component upon board powerup.

#### 3.8.5 RS232 and RS422/RS485 Driver Modules FH002 and FH003

To save space and to be able to vary the interface, FORCE COMPUTERS has developed the RS232 and RS422/RS485 modules with the FH002 and FH003. These 21-pin SIL modules are installed with sockets so that they may be easily changed. The default jumper setting on the CPU board for the RS232 module is as shown below:



#### 3.8.6 Summary of DUSCC1

| Device                  | 68562 DUSCC           |
|-------------------------|-----------------------|
| Access Address          | \$FF802000            |
| Port Width              | Byte                  |
| Interrupt Request Level | Software programmable |
| FGA-002 Interrupt Level | Local IRQ #4          |

### 3.8.7 Address Map of the DUSCC2 Registers

The following tables contain the complete register map of DUSCC2.

#### Table 3-8: Serial I/O Port #3 (DUSCC2) Register Address Map

|                |                  | Port           | Base | Address : \$FF8 | 02200                          |
|----------------|------------------|----------------|------|-----------------|--------------------------------|
| Address<br>HEX | Offset<br>HEX    | Reset<br>Value | Mode | Label           | Description                    |
| \$FF802200     | 00               | 00             | R/W  | DUSCMR1         | Channel Mode Reg 1             |
| \$FF802201     | 01               | 00             | R/W  |                 | Channel Mode Reg 2             |
| \$FF802202     | 02               |                | R/W  | DUSSS1R         | SYN1/Secondary Adr Reg 1       |
| \$FF802203     | 03               |                | R/W  | DUSS2R          | SYN2/Secondary Adr Reg 2       |
| \$FF802204     | 04               | 00             | R/W  | DUSTPR          | Transmitter Parameter Reg      |
| \$FF802205     | 05               |                | R/W  | DUSTTR          | Transmitter Timing Reg         |
| \$FF802206     | 06               | 00             | R/W  | DUSRPR          | Receiver Parameter Reg         |
| \$FF802207     | 07               |                | R/W  | DUSRTR          | Receiver Timing Reg            |
| \$FF802208     | 08               |                | R/W  | DUSCTPRH        | Counter/Timer Preset Reg H     |
| \$FF802209     | 09               |                | R/W  | DUSCTPRL        | Counter/Timer Preset Reg L     |
| \$FF80220A     | 0A               |                | R/W  | DUSCTCR         | Counter/Timer Control Reg      |
| \$FF80220B     | OB               | 00             | R/W  | DUSOMR          | Output and Miscellaneous Reg   |
| \$FF80220C     | 0C               |                | R    | DUSCTH          | Counter/Timer High             |
| \$FF80220D     | 0D               |                | R    | DUSCTL          | Counter/Timer Low              |
| \$FF80220E     | OE               | 00             | R/W  | DUSPCR          | Pin Configuration Reg          |
| \$FF80220F     | OF               |                | R/W  | DUSCCR          | Channel Command Reg            |
| \$FF802210     | 10 <sub>7</sub>  |                |      |                 |                                |
| \$FF802211     | 11               |                |      |                 |                                |
| \$FF802212     | 12               |                | W    | DUSTFIFO        | Transmitter FIFO               |
| \$FF802213     | 13-1             |                |      |                 |                                |
| \$FF802214     | 14-7             |                |      |                 |                                |
| \$FF802215     | 15               |                |      |                 |                                |
| \$FF802216     | 16               |                |      |                 |                                |
| \$FF802217     | 17- <sup>j</sup> |                | R    | DUSRFIFO        | Receiver FIFO                  |
| \$FF802218     | 18               | 00             | R/W  | DUSRSR          | Receiver Status Reg            |
| \$FF802219     | 19               | 00             | R/W  | DUSTRSR         | Transmitter/Receiver Stat Reg  |
| \$FF80221A     | 1A               |                | R/W  | DUSICTSR        | Input + Counter/Timer Stat Reg |
| \$FF80221C     | 1C               | 00             | R/W  | DUSIER          | Interrupt Enable Reg           |

|                | Port Base Address : \$FF802220 |                |      |          |                                |  |  |  |  |
|----------------|--------------------------------|----------------|------|----------|--------------------------------|--|--|--|--|
| Address<br>HEX | Offset<br>HEX                  | Reset<br>Value | Mode | Label    | Description                    |  |  |  |  |
| \$FF802220     | 00                             | 00             | R/W  | DUSCMR1  | Channel Mode Reg 1             |  |  |  |  |
| \$FF802221     | 01                             | 00             | R/W  | DUSCMR2  | Channel Mode Reg 2             |  |  |  |  |
| \$FF802222     | 02                             |                | R/W  | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |  |
| \$FF802223     | 03                             |                | R/W  | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |  |
| \$FF802224     | 04                             | 00             | R/W  | DUSTPR   | Transmitter Parameter Reg      |  |  |  |  |
| \$FF802225     | 05                             |                | R/W  | DUSTTR   | Transmitter Timing Reg         |  |  |  |  |
| \$FF802226     | 06                             | 00             | R/W  | DUSRPR   | Receiver Parameter Reg         |  |  |  |  |
| \$FF802227     | 07                             |                | R/W  | DUSRTR   | Receiver Timing Reg            |  |  |  |  |
| \$FF802228     | 08                             |                | R/W  | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |  |
| \$FF802229     | 09                             |                | R/W  | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |  |
| \$FF80222A     | 0A                             |                | R/W  | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |  |
| \$FF80222B     | OB                             | 00             | R/W  | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |  |
| \$FF80222C     | 0C                             |                | R    | DUSCTH   | Counter/Timer High             |  |  |  |  |
| \$FF80222D     | 0D                             |                | R    |          | Counter/Timer Low              |  |  |  |  |
| \$FF80222E     | OE                             | 00             | R/W  |          | Pin Configuration Reg          |  |  |  |  |
| \$FF80222F     | OF                             |                | R/W  | DUSCCR   | Channel Command Reg            |  |  |  |  |
| \$FF802230     | 10 <sub>7</sub>                |                |      |          |                                |  |  |  |  |
| \$FF802231     | 11                             |                |      |          |                                |  |  |  |  |
| \$FF802232     | 12                             |                | w    | DUSTFIFO | Transmitter FIFO               |  |  |  |  |
| \$FF802233     | 13-                            |                |      |          |                                |  |  |  |  |
| \$FF802234     | 14-                            |                |      |          |                                |  |  |  |  |
| \$FF802235     | 15                             |                |      |          |                                |  |  |  |  |
| \$FF802236     | 16                             |                |      |          |                                |  |  |  |  |
| \$FF802237     | 17-                            |                | R    |          | Receiver FIFO                  |  |  |  |  |
| \$FF802238     | 18                             | 00             | R/W  |          | Receiver Status Reg            |  |  |  |  |
| \$FF802239     | 19                             | 00             | R/W  |          | Transmitter/Receiver Stat Reg  |  |  |  |  |
| \$FF80223A     | 1A                             |                | R/W  |          | Input + Counter/Timer Stat Reg |  |  |  |  |
| \$FF80223C     | 1C                             | 00             | R/W  | DUSIER   | Interrupt Enable Reg           |  |  |  |  |

#### Table 3-10: Ports #3 and #4 (DUSCC2) Common Registers Address Map

| Port Base Address : \$FF802200                               |                      |                      |                        |                    |                                                                                                  |  |  |
|--------------------------------------------------------------|----------------------|----------------------|------------------------|--------------------|--------------------------------------------------------------------------------------------------|--|--|
| Address Offset Reset Mode Label Description<br>HEX HEX Value |                      |                      |                        |                    |                                                                                                  |  |  |
| \$FF80221B<br>\$FF80221E<br>\$FF80221F<br>\$FF80223E         | 1B<br>1E<br>1F<br>3E | 00<br>0F<br>00<br>0F | R/W<br>R/W<br>R/W<br>R | DUSCMR2<br>DUSSS1R | Channel Mode Reg 1<br>Channel Mode Reg 2<br>SYN1/Secondary Adr Reg 1<br>SYN2/Secondary Adr Reg 2 |  |  |

#### **3.8.8 RS232 Hardware Configuration of Ports #3 and #4**

Ports #3 and #4 are built around the DUSCC (J24). DUSCC2 is connected to the local 8 bit data bus and is accessible in the byte mode. The RS232 interfaces of port #3 and #4 which are wired to the two 9-pin Micro D-Sub connectors (named "3" and "4") on the front panel are identical. All RS232 driver and receivers are installed in the default configuration. The individual I/O signal assignment of the two channels is listed as follows:

| Signal | Input | Output | 9 Pin D-Sub Connector | Description         |
|--------|-------|--------|-----------------------|---------------------|
| DCD    | Х     |        | 1                     | Data Carrier Detect |
| RXD    | Х     |        | 2                     | Receive Data        |
| TXD    |       | Х      | 3                     | Transmit Data       |
| DTR    |       | X      | 4                     | Data Terminal Ready |
| GND    |       |        | 5                     | Signal GND          |
| DSR    | Х     | Х      | 6                     | Data Set Ready      |
| RTS    |       | X      | 7                     | Request to Send     |
| CTS    | Х     |        | 8                     | Clear to Send       |
| GND    |       |        | 9                     | Signal GND          |

The following figure displays the connection between DUSCC2 and the D-Sub connectors.



#### Figure 3-17: Connection Between DUSCC2 and D-Sub Connector for RS232

The devices are labeled as shown in the following chart.

| Port # | Channel | Ba | Bb  | Pa  | Connector |
|--------|---------|----|-----|-----|-----------|
| 3      | a       | B7 | B9  | PD3 | 3         |
| 4      | b       | B8 | B10 | PD4 | 4         |

"Location Diagram of the RS232 Configuration Jumperfields" is found in the figure on the next page. The default setting of the RS232 configuration jumperfield is shown in the next table.





The following is the displayed pinout of the D-Sub connector for RS232 Configuration.

### Figure 3-19: RS232 Pinout of the Micro D-Sub and D-Sub Connectors





| I | 37, | B8 |    |   | I | 39, B10 |
|---|-----|----|----|---|---|---------|
|   |     |    | ]  |   |   |         |
| 1 | 0   | 0  | 16 | 1 | L | Ö       |
| 2 | o-  | -o | 15 | 2 | 2 | o       |
| 3 | ο   | ο  | 14 |   | 3 | ο       |
| 4 | 0   | ο  | 13 |   |   |         |
| 5 | 0   | ο  | 12 |   |   |         |
| 6 | 0   | ο  | 11 |   |   |         |
| 7 | ο   | ο  | 10 |   |   |         |
| 8 | o   | 0  | 9  |   |   |         |
|   |     |    | ]  |   |   |         |

#### **3.8.9** Cable for the Micro D-Sub Connector

The CPU board is delivered with one 9-pin Micro D-Sub to 9-pin D-Sub Adapter Cable. Additional cables or a 9-pin Micro D-Sub to 25-pin D-Sub Adapter Cable are available by order from FORCE COMPUTERS.

#### 3.8.10 RS422/RS485 Hardware Configuration of Port #3 and #4

The CPU board is delivered with RS232 compatible interface buffers installed on all serial I/O ports. It is possible to reconfigure I/O ports #3 and #4 so that they are RS422/RS485 compatible. Termination resistors can be installed to adapt various cable lengths and reduce reflections. The resistor value is user application dependent. A recommended value for all resistors is 1 KOHM. The I/O signal assignment of each of the channels is listed as follows:

| Signal | Input | Output | 9 Pin D-Sub Connector | Description     |
|--------|-------|--------|-----------------------|-----------------|
| TXD-   |       | Х      | 1                     | Transmit Data   |
| RTS-   |       | X      | 2                     | Request to Send |
| CTS+   | Х     |        | 3                     | Clear to Send   |
| RXD+   | Х     |        | 4                     | Receive Data    |
| RXD-   | Х     |        | 5                     | Receive Data    |
| TXD+   |       | X      | 6                     | Transmit Data   |
| RTS+   |       | X      | 7                     | Request to Send |
| CTS-   | Х     |        | 8                     | Clear to Send   |
| RXD-   | Х     |        | 9                     | Receive Data    |

The next figure displays the connection between DUSCC2 and D-Sub connectors.

# Figure 3-20: Connection between DUSCC2 and Micro D-Sub Connector for RS422/RS485



The devices are labeled according to the following chart.

| Port # | Channel | Ва | Bb  | Pa  | Connector |
|--------|---------|----|-----|-----|-----------|
| 3      | a       | B7 | B9  | PD3 | 3         |
| 4      | b       | B8 | B10 | PD4 | 4         |

# Figure 3-21:Location Diagram of RS422/RS485 Configuration Jumperfields B7<br/>through B10







### Figure 3-22: RS422/RS485 Pinout of the Micro D-Sub and D-Sub Connectors



B7, B8

B9, B10





1

2

3

The following table shows the PCB locations and devices that have to be inserted according to the RS232/RS422/RS485 configuration.

#### Table 3-13: PCB Locations for RS232/RS422/RS485 Configuration

|        | RS232 Devices             | RS422/RS485 Devices       |                   |  |
|--------|---------------------------|---------------------------|-------------------|--|
| Port # | Driver and Receiver FH002 | Driver and Receiver FH003 | Resistor Array Ja |  |
| 3<br>4 | J25<br>J26                | J25<br>J26                | J27<br>J28        |  |

The RS422/RS485 compatible interface supports TXD, RXD, RTS, CTS with differential outputs and inputs. Each port occupies the same nine pins of the D-Sub connector as in the RS232 compatible configuration, but with a different signal association. The following figure displays the location diagram for the RS232 RS422/RS485 driver/receiver J25/J26 and resistor arrays J27/J28.

#### WARNING

1) Please make sure that the jumper settings are adapted to the user driver module.

2) Any mistakes could ruin the inserted component upon board powerup.

# Figure 3-23: Location Diagram of RS232/RS422/RS485 Driver/Receiver J25/J26 and Resistor Arrays J27/J28



## 3.8.11 RS232 and RS422/RS485 Driver Modules FH002 and FH003

To save space and to be able to vary the interface, FORCE COMPUTERS has developed the RS232 and RS422/RS485 modules with the FH002 and FH003. These 21-pin SIL modules are installed with sockets so that they may be easily changed. The default jumper setting on the CPU board for the RS232 module is as shown below:



#### 3.8.12 Summary of DUSCC2

| Device                    | 68562 DUSCC           |
|---------------------------|-----------------------|
| Access Address            | \$FF802200            |
| Port Width                | Byte                  |
| Interrupt Request Level   | Software programmable |
| FGA-002 Interrupt Channel | Local IRQ #5          |

# 3.9 The PI/T 68230

The MC68230 Parallel Interface/Timer provides versatile double buffered parallel interfaces and an operating system oriented timer. The parallel interfaces operate in unidirectional or bidirectional modes, either 8 or 16 bits wide. The PI/T contains a 24 bit wide counter and a 5 bit prescaler.

#### Features of the PI/T

- MC68000 Bus Compatible
- Port Modes Include: Bit I/O Unidirectional 8 bit and 16 bit 8 bit and 16 bit
- Selectable Handshaking Options
- 24 bit Programmable Timer
- Software Programmable Timer Modes
- Contains Interrupt Vector Generation Logic
- Separate Port and Timer Interrupt Service Requests
- Registers are Read/Write and Directly Addressable

## **3.9.1** Address Map of the PI/T1 Registers

PI/T1 is accessible via the 8 bit local I/O bus (byte mode). The following table shows the register layout of the PI/T1.

# Table 3-14: PI/T1 Register Layout

| Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 0C00<br>Default Name: PI_T1 |               |                |            |                                 |
|---------------------------------------------------------------------------------------------|---------------|----------------|------------|---------------------------------|
| Address<br>HEX                                                                              | Offset<br>HEX | Reset<br>Value | Label      | Description                     |
| FF800C00                                                                                    | 00            | 00             | PIT1 PGCR  | Port General Control Register   |
| FF800C01                                                                                    | 01            | 00             | PIT1 PSRR  | Port Service Request Register   |
| FF800C02                                                                                    | 02            | 00             | PIT1 PADDR | Port A Data Direction Register  |
| FF800C03                                                                                    | 03            | 00             | PIT1 PBDDR | Port B Data Direction Register  |
| FF800C04                                                                                    | 04            | 00             | PIT1 PCDDR | Port C Data Direction Register  |
| FF800C05                                                                                    | 05            | 00             | PIT1 PIVR  | Port Interrupt Vector Register  |
| FF800C06                                                                                    | 06            | 00             | PIT1 PACR  | Port A Control Register         |
| FF800C07                                                                                    | 07            | 00             | PIT1 PBCR  | Port B Control Register         |
| FF800C08                                                                                    | 08            |                | PIT1 PADR  | Port A Data Register            |
| FF800C09                                                                                    | 09            |                | PIT1 PBDR  | Port B Data Register            |
| FF800C0A                                                                                    | 0A            |                | PIT1 PAAR  | Port A Alternate Register       |
| FF800C0B                                                                                    | OB            |                | PIT1 PBAR  | Port B Alternate Register       |
| FF800C0C                                                                                    | 00            |                | PIT1 PCDR  | Port C Data Register            |
| FF800C0D                                                                                    | 0D            |                | PIT1 PSR   | Port Status Register            |
| FF800C10                                                                                    | 10            | 00             | PIT1 TCR   | Timer Control Register          |
| FF800C11                                                                                    | 11            | OF             | PIT1 TIVR  | Timer Interrupt Vector Register |
| FF800C12                                                                                    | 12            |                | PIT1 CPR   | Counter Preload Register        |
| FF800C13                                                                                    | 13            |                | "          | "                               |
| FF800C14                                                                                    | 14            |                |            | 11                              |
| FF800C15                                                                                    | 15            |                | 19         | и                               |
| FF800C16                                                                                    | 16            |                | PIT1 CNTR  | Count Register                  |
| FF800C17                                                                                    | 17            |                | "          | n n                             |
| FF800C18                                                                                    | 18            |                | "          | 1                               |
| FF800C19                                                                                    | 19            |                | 17         | п                               |
| FF800C1A                                                                                    | 1A            | 00             | PIT1 TSR   | Timer Status Register           |

# 3.9.2 I/O Configuration of PI/T1

The following table lists all I/O signals connected to PI/T1. The functions of these signals are described in the corresponding chapter. Additional information is provided in the PI/T data sheet, included in *Section No. 5, "COPIES OF DATA SHEETS"*.

## Table 3-15: PI/T1 Interface Signals

| PI/T1 I/O Pin | PI/T Signal Name | Connected Signal                         | Input/Output |
|---------------|------------------|------------------------------------------|--------------|
| 4             | PAO              | Rotary Switch 1                          | 1            |
| 5             | PA1              | "                                        |              |
| 6             | PA2              | n                                        | 1            |
| 7             | PA3              | n en |              |
| 9             | PA4              | Rotary Switch 2                          | 1            |
| 10            | PA5              | 11                                       | 1            |
| 11            | PA6              | 11                                       | 1            |
| 12            | PA7              | 11                                       | l            |
| 14            | H1               | Reserved                                 | -            |
| 15            | H2               | Reserved                                 | -            |
| 16            | H3               | Reserved                                 | -            |
| 17            | H4               | Reserved                                 | -            |
| 18            | PBO              |                                          | 0            |
| 19            | PB1              |                                          | 0            |
| 22            | PB2              | A31A24                                   | 0            |
| 23            | PB3              | Control                                  | 0            |
| 24            | PB4              | for                                      | Q            |
| 25            | PB5              | Accesses in                              | 0            |
| 26            | PB6              | Slave Mode                               | 0            |
| 27            | PB7              |                                          | 0            |
| 34            | PC0              | Reserved                                 | -            |
| 35            | PC1              | Reserved                                 | -            |
| 36            | PC2              | Reserved                                 | -            |
| 37            | PC3              | Timer IRQ                                | 0            |
| 38            | PC4              | Lock Cycles                              | 0            |
| 39            | PC5              | Reserved                                 | -            |
| 40            | PC6              | Reserved                                 | -            |
| 41            | PC7              | Reserved                                 | -            |

#### 3.9.3 Rotary Switches

There are two rotary switches installed on the front panel of the CPU board. The position of each switch can be read in via port A of the PI/T1. The next figure outlines the front panel and the position of the rotary switches. Each rotary switch covers four bits. Therefore, each switch holds 16 positions and the code shown on the switch (i.e., 0-9 and A-F) can be read from the line PA0-PA3 (SW1) and PA4-PA7 (SW2) of PI/T1. The following lists the input signals of PI/T1 in relation to the rotary switch signals.

| PI/T1 Signal | Rotary Switch | Bit | Data Bit of PI/T Port A |
|--------------|---------------|-----|-------------------------|
| PAO          | SW1/1         | 0   | 0                       |
| PA1          | SW1/2         | 1   | 1                       |
| PA2          | SW1/3         | 2   | 2                       |
| PA3          | SW1/4         | 3   | 3                       |
| PA4          | SW2/1         | 4   | 4                       |
| PA5          | SW2/2         | 5   | 5                       |
| PA6          | SW2/3         | 6   | 6                       |
| PA7          | SW2/4         | 7   | 7                       |

#### **Rotary Switch Signals Assignment**

For application programs, the rotary switches can be used as a general purpose input channel for diagnostics, configuration selection, or automatic system boot with different configurations. VMEPROM uses the rotary switches for automatic configuration.

NOTE: The rotary switches serve a special function in conjunction with the RESET and ABORT switches. This functionality is built into the BOOT EPROM and is described in detail in the BOOT Software description of the FGA-002 User's Manual.





## 3.9.4 Lock Cycles

On the initial cycle of a line access, a retry causes the MC68040 processor to retry the bus cycle. A retry signaled during the second, third, or fourth cycle of a line transfer is recognized by the processor as a bus error, and causes the processor to abort the line transfer and start an access fault exception subroutine.

When the local MC68040 wants to access a slave on the VMEbus and has already been granted the local bus, and a master on the VMEbus wants to access the MC68040's Shared Memory and has already been granted the VMEbus, a bus collision occurs. In this case the FGA-003 signals a retry to the MC68040 to resolve the collision on hardware level. It is not necessary that software observes this event.

When a bus collision occurs during the second, third, or fourth cycle of a line transfer, where the processor is not able to retry the cycle, the MC68040 initiates a bus error. So the collision appears on the software level and can be resolved there with considerable time expense.

To prevent the software from being concerned, the following feature is implemented on the CPU-40/41 Rev. 2 and succeeding revisions.

The signal ENARMC 16 can be activated by software via PI/T1 Pin *PC4*. With this signal driven low a line transfer from the MC68040 is defined as a locked RMC transfer. So the FGA-002, when being granted the VMEbus, doesn't release the VMEbus until all four long cycles of the line tranfer are successfully completed or an actual bus error occurred.

When using this feature the FGA-002 must be programmed to drive ASVME high between the locked RMC similar cycles and not to support real VMEbus compatible Read Modify Cycles. Actual RMC transfers from the MC68040 are treated the same way. As a result, on a slave board which is accessible from the VME bus as well as from the VSB, this kind of arbitration locked read modify cycle can be broken.

#### PC4:

To enable the feature that line transfers are defined as locked cycles, this bit must be programmed to low. Be sure to program the FGA-002 so that ASVME is driven high between RMC transfers.

To disable this feature, this bit must be programmed to high. VMEPROM programs this bit to low by default.

#### 3.9.5 Interrupt Request Signal

#### TOUT:

The PI/T1 pin 37 is used as an interrupt request line. The 24 bit timer can generate interrupt requests at a software programmable level. This interrupt request line is connected to the IRQ #2 of the FGA-002.

#### PIRQ:

The PI/T pin 33 is used to generate an interrupt depending on the handshake lines of the PI/T. The PIRQ is connected to the TOUT pin but is not able to generate an interrupt because the handshake lines are not used and are reserved.

#### 3.9.6 A24 Slave Mode

In order to allow an A24 slave mode as described in the chapter "*Address Modifier Decoding and A24 Slave Mode*", the A31 to A24 address lines are programmable for this mode as described in the following table displaying the PI/T bit and the coordinating address line.

| Address Line |
|--------------|
| A24          |
| A25          |
| A26          |
| A27          |
| A28          |
| A29          |
| A30          |
| A31          |
|              |

#### 3.9.7 Reserved Lines

#### H1, H2, H3, H4, PC0, PC1, PC2, PC5, PC6, PC7:

These lines are not used. In order to retain compatibility to following versions, these lines should not be used in any applications.

# 3.9.8 Summary of PI/T1

.

| Device                                | 68230 PI/T            |
|---------------------------------------|-----------------------|
| Access Address                        | \$FF800C00            |
| Port Width                            | Byte                  |
| Interrupt Request Level               | Software programmable |
| FGA-002 Interrupt Channel (Timer IRQ) | Local IRQ #2          |

## 3.9.9 Address Map of the PI/T2 Registers

The PI/T2 is accessible via the 8 bit local I/O bus (byte mode). The following table shows the register layout of PI/T2.

# Table 3-16: PI/T2 Register Layout

| Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 0E00<br>Default Name: PI_T2 |               |                |            |                                 |
|---------------------------------------------------------------------------------------------|---------------|----------------|------------|---------------------------------|
| Address<br>HEX                                                                              | Offset<br>HEX | Reset<br>Value | Label      | Description                     |
| FF800E00                                                                                    | 00            | 00             | PIT2 PGCR  | Port General Control Register   |
| FF800E01                                                                                    | 01            | 00             | PIT2 PSRR  | Port Service Request Register   |
| FF800E02                                                                                    | 02            | 00             | PIT2 PADDR | Port A Data Direction Register  |
| FF800E03                                                                                    | 03            | 00             | PIT2 PBDDR | Port B Data Direction Register  |
| FF800E04                                                                                    | 04            | 00             | PIT2 PCDDR | Port C Data Direction Register  |
| FF800E05                                                                                    | 05            | 00             | PIT2 PIVR  | Port Interrupt Vector Register  |
| FF800E06                                                                                    | 06            | 00             | PIT2 PACR  | Port A Control Register         |
| FF800E07                                                                                    | 07            | 00             | PIT2 PBCR  | Port B Control Register         |
| FF800E08                                                                                    | 08            |                | PIT2 PADR  | Port A Data Register            |
| FF800E09                                                                                    | 09            |                | PIT2 PBDR  | Port B Data Register            |
| FF800E0A                                                                                    | 0A            |                | PIT2 PAAR  | Port A Alternate Register       |
| FF800E0B                                                                                    | OB            |                | PIT2 PBAR  | Port B Alternate Register       |
| FF800E0C                                                                                    | 00            |                | PIT2 PCDR  | Port C Data Register            |
| FF800E0D                                                                                    | OD            |                | PIT2 PSR   | Port Status Register            |
| FF800E10                                                                                    | 10            | 00             | PIT2 TCR   | Timer Control Register          |
| FF800E11                                                                                    | 11            | OF             | PIT2 TIVR  | Timer Interrupt Vector Register |
| FF800E12                                                                                    | 12            |                | PIT2 CPR   | Counter Preload Register        |
| FF800E13                                                                                    | 13            | •              | 11         | u                               |
| FF800E14                                                                                    | 14            |                | 11         | 11                              |
| FF800E15                                                                                    | 15            |                | 11         | п                               |
| FF800E16                                                                                    | 16            |                | PIT2 CNTR  | Count Register                  |
| FF800E17                                                                                    | 17            |                | 11         | u u                             |
| FF800E18                                                                                    | 18            |                | н          | · u                             |
| FF800E19                                                                                    | 19            |                | 11         | и .                             |
| FF800E1A                                                                                    | 1A            | 00             | PIT2 TSR   | Timer Status Register           |

## 3.9.10 I/O Configuration of PI/T2

The following table lists all I/O signals connected to PI/T2. The functions of these signals are described in the corresponding chapter. Additional information is provided in the PI/T data sheet, included in *Section No. 5, "COPIES OF DATA SHEETS"*.

## Table 3-18: PI/T2 Interface Signals

| PI/T I/O Pin | PI/T Signal Name | Connected Signal | Input/Output |
|--------------|------------------|------------------|--------------|
| 4            | PAO              |                  | 1/0          |
| 5            | PA1              |                  | 1/0          |
| · 6          | PA2              |                  | I/O          |
| 7            | PA3              |                  | I/O          |
| 9            | PA4              |                  | 1/0          |
| 10           | PA5              | I/O Port via     | 1/0          |
| 11           | PA6              | B12              | I/O          |
| 12           | PA7              |                  | I/O          |
| 14           | H1               |                  | . I          |
| 15           | H2               |                  | I/O          |
| 16           | H3               |                  | 1            |
| 17           | H4               |                  | I/O          |
| 18           | PB0              | Memory Size      | 1            |
| 19           | PB1              | 11               | l            |
| 22           | PB2              | "                | 1            |
| 23           | PB3              | Board ID         | I            |
| 24           | PB4              | Π                | l            |
| 25           | PB5              | 11               | · • • •      |
| 26           | PB6              | Π                | I            |
| 27           | PB7              | 11               |              |
| 34           | PC0              | MODLOW           | I            |
| 35           | PC1              | Reserved         | -            |
| 36           | PC2              | RAMTYP           | I            |
| 37           | PC3              | Timer IRQ/Reset  | 0            |
| 38           | PC4              | BURST            | 1            |
| 39           | PC5              | PORT IRQ         | 0            |
| 40           | PC6              | PARITY           |              |
| 41           | PC7              | ENA24            | 0            |

# 3.9.11 Memory Size Recognition

## PBO-PB2:

From these lines, the on-board memory capacity can be read in by software. Please refer to the chapter "*The Shared RAM*" for detailed information.

## **3.9.12** Board Identification

#### PB3-PB7:

From these lines, the CPU board identification number can be read in by software. Every CPU board has its own number. Different versions of one CPU board (i.e. different speeds, capacity of memory, or modules) contain the same identification number. In the case of the CPU-40/41, the number is ten ("\$20").

## 3.9.13 Interrupt Request Signal

#### TOUT:

PI/T2 pin 37 is used as an interrupt request line. The 24 bit timer can generate interrupt requests on a software programmable level. Together with the Port Interrupt Request line, the timer interrupt request line is connected to the local IRQ #3 of the FGA-002. Therefore the software has to check whether the interrupt request was generated by the timer or by the port handshake lines.

#### PIRQ:

PI/T2 pin 39 is used as an interrupt request line. The port handshake lines can generate interrupts on a software programmable level. Together with the Timer Interrupt Request line, the port interrupt request line is connected to the local IRQ #3 of the FGA-002. Therefore the software has to check whether the interrupt request was generated by the timer or by the port handshake lines.

#### 3.9.14 12 Bit I/O Port

#### PA0-PA7, H1-H4:

This 12 bit I/O port is routed to a 24-pin header B12 allowing flat cable connection. Eight bits are connected to PI/T2 port A and are used as inputs or outputs; the remaining four bits are connected to the PI/T2 handshake pins. This port can be used to build a Centronics type interface.

| PI/T   |     | Header B12 |
|--------|-----|------------|
| Signal | Pin | Pin        |
| PAO    | 4   | 1          |
| PA1    | 5   | 2          |
| PA2    | 6   | 3          |
| PA3    | 7   | 4          |
| PA4    | 9   | 5          |
| PA5    | 10  | 6          |
| PA6    | 11  | 7          |
| PA7    | 12  | 8          |
| H1     | 14  | 9          |
| H2     | 15  | 10         |
| Н3     | 16  | 11         |
| H4     | 17  | 12         |

The figure on the next page shows the location diagram of Jumperfield B12.





#### 3.9.15 MODLOW

#### PC0

This line is driven low by an Eagle Module if there is one inserted. Be sure to leave this pin undriven by the PI/T. If no Eagle Module is inserted and this signal is driven low the local IACK daisy chain is not closed!

## 3.9.16 RAM Module Configuration Signals

#### PC2, PC4, PC6:

From PC2, RAMTYP of the RAM module can be read as shown in the following chart.

| PC2 | <b>RAM</b> Туре |
|-----|-----------------|
| 1   | DRAM            |
| 0   | SRAM            |

For more information please refer to the chapter "The Shared RAM".

From PC4, BURST capability of the RAM module can be read as shown in the following chart.

| PC4 | Burst Mode |
|-----|------------|
| 1   | Yes        |
| 0   | No         |

From PC6, PARITY capability of the RAM module can be read as shown in the following chart.

| PC6 | Parity |
|-----|--------|
| 1   | Yes    |
| 0   | No     |

For more information please refer to the chapter "The Shared RAM".

# 3.9.17 Timer IRQ/Reset

## PC3:

This line can be connected to FGA-002 LIRQ 3 or to the RESET operation via jumperfield B18. An interrupt can be requested by the PI/T timer or directly by programming this line to low, when the jumper is inserted in 2-3. With a jumper inserted in 1-2, this bit can generate a RESET which is equivalent to a Powerup RESET so that the contents of a RAM disk in DRAM area can be destroyed.

## 3.9.18 PIRQ

#### PC5:

Interrupts from the PI/Ts handshake lines are routed to this FGA-002 LIRQ3 line.

## 3.9.19 Enable A24 Slave Mode

#### PC7:

The A24 slave mode can be enabled via the PC7 bit as described in the chapter "Address Modifier Decoding and A24 Slave Mode".

| PC7 | Enabled VMEbus Slave Mode |
|-----|---------------------------|
| 1   | A32                       |
| 0   | A32/A24                   |

#### 3.9.20 Reserved Line

PC1:

This line is not used. In order to retain compatibility to following versions, this line should not be used in any applications.

# 3.9.21 Summary of PI/T2

| Device                                  | 68230 PI/T            |
|-----------------------------------------|-----------------------|
| Access Address                          | \$FF800E00            |
| Port Width                              | Byte                  |
| Interrupt Request Level                 | Software programmable |
| FGA-002 Interrupt Channel<br>Timer IRO: | Local IRQ #3          |

# 3.10 The Real Time Clock (RTC) 72423

There is an RTC 72423 installed on the CPU board, containing its own battery to maintain the RTC function during power down.

## 3.10.1 Address Map of the RTC Registers

The RTC 72423 is a four bit device. It must be accessed in byte mode and the upper four bits are "don't care" during read and write accesses. The base address of the RTC is \$FF803000. The following table shows the register layout of the RTC 72423.

## Table 3-17: RTC Register Layout

| Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 3000<br>Default Name: RTC |        |          |                                  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------|--------|----------|----------------------------------|--|--|--|--|--|--|--|
| Address HEX                                                                               | Offset | Label    | Description                      |  |  |  |  |  |  |  |
| FF803000                                                                                  | 00     | RTC1SEC  | 1 Second Digit Register          |  |  |  |  |  |  |  |
| FF803001                                                                                  | 01     | RTC10SEC | 10 Second Digit Register         |  |  |  |  |  |  |  |
| FF803002                                                                                  | 02     | RTC1MIN  | 1 Minute Digit Register          |  |  |  |  |  |  |  |
| FF803003                                                                                  | 03     | RTC10MIN | 10 Minute Digit Register         |  |  |  |  |  |  |  |
| FF803004                                                                                  | 04     | RTC1HR   | 1 Hour Digit Register            |  |  |  |  |  |  |  |
| FF803005                                                                                  | 05     | RTC10HR  | PM/AM and 10 Hour Digit Register |  |  |  |  |  |  |  |
| FF803006                                                                                  | 06     | RTC1DAY  | 1 Day Digit Register             |  |  |  |  |  |  |  |
| FF803007                                                                                  | 07     | RTC10DAY | 10 Day Digit Register            |  |  |  |  |  |  |  |
| FF803008                                                                                  | 08     | RTC1MON  | 1 Month Digit Register           |  |  |  |  |  |  |  |
| FF803009                                                                                  | 09     | RTC10MON | 10 Month Digit Register          |  |  |  |  |  |  |  |
| FF80300A                                                                                  | 0A     | RTC1YR   | 1 Year Digit Register            |  |  |  |  |  |  |  |
| FF80300B                                                                                  | OB     | RTC10YR  | 10 Year Digit Register           |  |  |  |  |  |  |  |
| FF80300C                                                                                  | 0C     | RTCWEEK  | Week Register                    |  |  |  |  |  |  |  |
| FF80300D                                                                                  | 0D     | RTCCOND  | Control Register D               |  |  |  |  |  |  |  |
| FF80300E                                                                                  | 0E     | RTCCONE  | Control Register E               |  |  |  |  |  |  |  |
| FF80300F                                                                                  | OF     | RTCCONF  | Control Register F               |  |  |  |  |  |  |  |

## **3.10.2 RTC Programming**

The following programming example shows how to read from or write to the RTC. Please note that the RTC must be stopped prior to reading the date and time registers. For further details, please refer to the RTC 72423 Data Sheet in *Section 5, "COPIES OF DATA SHEETS"* in this manual.

#### Figure 3-26: RTC Programming Example

```
** read RTC 72421 and load to RAM
                                                    **
         30-Oct-87 M.S. **
**
                                                    **
*******
setclock(sy)
register struct SYRAM *sy;
₹
register struct rtc7242 *rtc = RTC2;
register long count=100000l;
                                                    /* hold clock */
rtc->dcontrol = 1;
while(count--)
     if(rtc->dcontrol&0x02)
            break;
if(!count)
    ( printf("\nCannot read Realtime Clock");
      rtc -> dcontrol = 0;
      return; }
sy-> ssec[0] = (unsigned char)((rtc->sec10reg&0x07)*10 + (rtc->sec1reg&0x0f));
sy->_smin = (unsigned char)((rtc->min10reg&0x07)*10 + (rtc->min1reg&0x0f));
sy->_shrs = (unsigned char)((rtc->hou10reg&0x03)*10 + (rtc->hou1reg&0x0f));
sy->_syrs[0] = (unsigned char)((rtc->yr10reg&0x0f)*10 + (rtc->yr1reg&0x0f));
sy->_sday = (unsigned char)((rtc->day10reg&0x03)*10 + (rtc->day1reg&0x0f));
sy->_smon = (unsigned char)((rtc->mon10reg&0x01)*10 + (rtc->mon1reg&0x0f));
                                                    /* start clock */
rtc->dcontrol = 0;
3
**
         write RTC 72421 from RAM
                                                  **
**
                                                    **
writeclock(sy)
register struct SYRAM *sy;
{
register struct rtc7242 *rtc = RTC2;
register long count=100000l;
rtc->dcontrol = 1;
                                                    /* hold clock */
while(count--)
    if(rtc->dcontrol&0x02)
             break;
if(!count)
    { printf("\nCannot read Realtime Clock");
      rtc -> dcontrol = 0;
      return; }
rtc->fcontrol = 5;
rtc \rightarrow fcontrol = 4;
                                                     /* 24-hour clock */
rtc->sec10reg = sy->_ssec[0]/10;
rtc->sec1reg = sy->_ssec[0]%10;
rtc->min10reg = (char)(sy->_smin/10);
rtc->min1reg = (char)(sy->_smin%10);
rtc->hou10reg = (char)(sy->_smin%10);
rtc->hou10reg = (char)(sy->_shrs/10);
rtc->yr10reg = (char)(sy->_shrs%10);
rtc->yr10reg = sy->_syrs[0]/10;
rtc->yr1reg = sy->_syrs[0]%10;
rtc->day10reg = sy->_sday/10;
rtc->day1reg = sy->_sday/10;
rtc->mon10reg = sy->_smon/10;
rtc->mon1reg = sy->_smon%10;
rtc->dcontrol = 0;
                                                    /* start clock */
3
```

The following figure shows the location diagram of jumperfield B20 for backup supply. The default configuration uses the onboard battery. Please note that the SRAM on this CPU board is also supplied via this jumperfield.



NOTE

The battery is not installed on the CPU board to avoid damage during shipment.

## CAUTION

Before altering jumperfield B1 or disassembling the battery, please consult *Chapter 3.6, "The Local SRAM"*.

•



#### Figure 3-27: Location Diagram of the Backup Supply Jumperfield B1 and B20

# 3.10.3 Summary of the RTC

| Device                            | 72423 RTC                                                                 |
|-----------------------------------|---------------------------------------------------------------------------|
| Access Address                    | \$FF80 3000                                                               |
| Access Mode                       | Byte only                                                                 |
| Supported Transfers               | Byte only, the upper 4 bits are to be ignored for read and write accesses |
| Battery Type                      | Varta CR 1/3 or equivalent                                                |
| Interrupt Request Level           | Software programmable                                                     |
| FGA-002 Interrupt Request Channel | Local IRQ #0                                                              |

This page was intentionally left blank

# 4. FUNCTION SWITCHES AND INDICATION LEDs

The following paragraphs describe all switches and indicator LEDs. Figure 4-1 shows the front panel of the CPU board.

# 4.1 RESET Function Switch

A reset of all on-board I/O devices and the CPU is performed if the RESET switch is pushed to the "UP" position. RESET is held active until the switch is in "DOWN" position. In addition, a local timer guarantees a minimum reset time of two to three seconds. Power fail and power up also force a RESET (2-3 seconds), to start the board if the supply voltage is out of range (below 4.8 Volts).

#### Normal switch position: "DOWN"

If enabled, the reset is also driven to the VMEbus. For more information, please refer to the chapter "VMEbus RESET Conditions".

In combination with the ABORT switch, the RESET switch has a special function which is described in the BOOT Software description of the FGA-002 User's Manual.

When the Reset Switch is toggled twice a Powerup equivalent Reset can be generated. The time lapse immediately after the Reset Switch is released must be 0,2 seconds or less.

# 4.2 ABORT Function Switch

An interrupt on a software programmable level is provided on the board to allow an abort of the current program, to trigger a self-test or to start a maintenance program. ABORT is activated in "UP" position and deactivated in "DOWN" position.

#### Normal switch position: "DOWN"

In combination with the RESET switch, the ABORT switch has a special function which is described in the BOOT Software description of the FGA-002 User's Manual.

## 4.3 "RUN" LED

The first LED below the RESET and ABORT switch is the RUN LED. This bicolor LED is green if the processor is not in HALT state. It is red during the RESET phase, and when the processor is in HALT state.

#### 4.4 "BM" LED

If the CPU board is the current bus master, the BM LED is lit. Optical control is provided through this LED whether or not the board is working on VME.

#### 4.5 Rotary Switches

There are two rotary switches (SW1 and SW2) which are four bit, hexadecimal encoded. These switches are completely under software control. The default setting is \$FF. For a detailed description of the use of these switches under VMEPROM, please refer to the *Section No. 7*, *"Introduction to VMEPROM"*.

In combination with the RESET and ABORT switches, the rotary switches have a special function which is described in the BOOT Software description of the FGA-002 User's Manual.

# Figure 4-1: Front Panel of the CPU Board



This page was intentionally left blank

## 5. THE CPU BOARD INTERRUPT STRUCTURE

All interrupts on the CPU board are handled via the FGA-002 or the hardware which is controlling the FLXibus.

The interrupts of the FLXibus and the interrupts handled by the FGA-002 are daisy chained. If an interrupt occurs on the FLXibus with the same priority as an interrupt occurring through the FGA-002, the priority is as follows:

#### **Priority of the Onboard Interrupts**

**Highest Priority** 

FLXibus

FGA-002

Lowest Priority

The interrupts which are caused by the EAGLE module are described in the *Section 6*, "*EAGLE Module*". Interrupts handled by the FGA-002 are described in the following paragraphs.

The Gate Array installed on the CPU board handles all local and VMEbus interrupts. Each interrupt request from the local bus through the two DUSCCs, RTC, the two timers, as well as the Gate Array specific interrupt requests, are combined with seven VMEbus interrupt requests.

Each IRQ source including VMEbus IRQs can be programmed to interrupt the CPU on an individual programmable level (1 to 7).

The Gate Array supports the vector, or initiates an interrupt vector fetch from the I/O device or from the VMEbus.

In addition to local interrupts, the ACFAIL and SYSFAIL signals can be used to interrupt the CPU on a software programmable level.

Gate Array supplied interrupt vectors have basic vector and fixed increments for each source. The basic vector is software programmable.

For a complete description of interrupt handling, please refer to the FGA-002 Users Manual.

The chart below shows the connection between local devices and the local interrupt request of the FGA-002.

| Device                                                                                                                                                                        | Base Address | Function  | Local Interrupt<br>Request Number | FGA-002 Pin<br>Number |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------|-----------------------------------|-----------------------|--|--|--|
| RTC                                                                                                                                                                           | \$FF803000   | *         | 0                                 | C07                   |  |  |  |
| PI/T1                                                                                                                                                                         | \$FF800C00   | Timer IRQ | 2                                 | E07                   |  |  |  |
| PI/T2                                                                                                                                                                         | \$FF800E00   | *         | 3                                 | A06                   |  |  |  |
| DUSCC1                                                                                                                                                                        | \$FF802000   | *         | 4                                 | B06                   |  |  |  |
| DUSCC2                                                                                                                                                                        | \$FF802200   | *         | 5                                 | B05                   |  |  |  |
| * More than one function is available. Please refer to the data sheet of the coinciding device in <i>Section No. 5, "COPIES OF DATA SHEETS"</i> , for a complete description. |              |           |                                   |                       |  |  |  |

## 6. VMEBUS INTERFACE

The CPU board contains a VMEbus interface which is compatible with the following standards:

#### **IEEE 1014**

The VMEbus interface supports 8, 16, 32 bit, and unaligned data transfers. The extended, standard, and short I/O address modifier codes are implemented to interface to all existing VMEbus products.

Read-Modify-Write cycles on the VMEbus are handled as described in the VMEbus Standard (see above). The address strobe signal is held low during this cycle while the data strobe signals are driven low twice, once for the read cycle and once for the write cycle, and high between the both of them.

All seven interrupt request signals are connected to the FGA-002 which can optionally map every level and then interrupt the local CPU. A four level bus arbiter together with several release functions are implemented with all slot 1 functions such as SYSRESET driver and receiver and SYSCLOCK driver.

The following chapters describe the functions of the interface parts in detail.

#### 6.1 VMEbus Master Interface

#### 6.1.1 Data Transfer Size of the VMEbus Interface

The VMEbus interface contains memory areas where the transfer size is software programmable to be 16 or 32 bits wide.

The memory areas which contain the software programmable data bus size are fixed mapped and can't be modified.

The hardware on the CPU board adjusts the transfer size of the data bus automatically, so that no additional overhead in the programs is necessary.

The table on the next page lists the VMEbus memory areas and their data bus sizes in detail.

## Table 6-1: Data Bus Size of the VMEbus

| Start Address | End Address | Туре    | Transfer Size |
|---------------|-------------|---------|---------------|
| XXXX XXXX*    | F9FF FFFF   | VME:A32 | PROGRAMMABLE  |
| FB00 0000     | FBFE FFFF   | VME:A24 | PROGRAMMABLE  |
| FBFF 0000     | FBFF FFFF   | VME:A16 |               |
| FC00 0000     | FCFE FFFF   | VME:A24 | FIXED, 16 BIT |
| FCFF 0000     | FCFF FFFF   | VME:A16 | FIXED, 16 BIT |

\* XXXX XXXX = 0040 0000 for CPU-40x/4 or 0100 0000 for CPU-40x/16

\* XXXX XXXX = 0040 0000 for CPU-41x/4 or 0080 0000 for CPU-41x/8

#### NOTE

- 1) The data bus transfer size of the areas marked "FIXED" cannot be modified.
- 2) The data bus transfer size of the areas marked as "PROGRAMMABLE" can be set to 16 or 32 bits. The default setup after RESET through the hardware is 32 bits.

VMEPROM contains a command (MEM) to set up the data bus transfer size of the software programmable areas.

- MEM displays the current data bus transfer size
- MEM 16 sets the size to 16 data bus transfer bits only
- MEM 32 sets the size to 32 data bus transfer bits
- (8 and 16 bit transfers are also allowed)

In addition, VMEPROM uses one bit of the rotary switches available on the front panel to select the data bus size of the VMEbus after RESET or power up.

This default configuration is useful if a user program or an operating system is started, and additional memory boards with known data sizes are installed.

For details on the usage of the rotary switches, please refer to Section 7, "Introduction to VMEPROM".

| Transfer Type                                                          | D31-D24                 | D23-D16     | D14-D8      | D7-D0       | Supported        |  |  |  |
|------------------------------------------------------------------------|-------------------------|-------------|-------------|-------------|------------------|--|--|--|
| Byte<br>Byte                                                           |                         |             | x           | x           | y<br>y           |  |  |  |
| Word                                                                   |                         |             | x           | x           | y                |  |  |  |
| Long Word                                                              | x                       | x           | ×           | x           | У                |  |  |  |
| Unaligned Word<br>Unaligned<br>Long Word A<br>Unaligned<br>Long Word B | x                       | x<br>x<br>x | x<br>x<br>x | ×           | y<br>y<br>y      |  |  |  |
| RMW Byte<br>RMW Byte<br>RMW Word<br>RMW Long Word                      | x                       | x           | x<br>x<br>x | x<br>x<br>x | y<br>y<br>y<br>y |  |  |  |
|                                                                        | RMW = Read Modify Write |             |             |             |                  |  |  |  |

# Table 6-2: Defined VMEbus Transfer Cycles (D32 Mode)

# Table 6-3: Defined VMEbus Transfer Cycles (D16 Mode)

| Transfer Type           | D31-D24 | D23-D16 | D14-D8 | D7-D0 | Supported |  |
|-------------------------|---------|---------|--------|-------|-----------|--|
| Byte<br>Byte            |         |         | x      | x     | y<br>y    |  |
| Word                    |         |         | x      | x     | у         |  |
| RMW Byte<br>RMW Byte    |         |         | x      | x     | y<br>y    |  |
| RMW Word                |         |         | x      | x     | у         |  |
| RMW = Read Modify Write |         |         |        |       |           |  |

## 6.1.2 Address Modifier Implementation

The VMEbus defines three different Address Modifier Ranges as shown in the following table:

#### Table 6-4: Address Ranges

| Mode                | Used Address Lines | Short Form |
|---------------------|--------------------|------------|
| Extended Addressing | A1-A31             | A32        |
| Standard Addressing | A1-A24             | A24        |
| Short I/O           | A1-A15             | A16        |

All allowed and defined Address Modifier (AM) Codes are listed in the next table. The supported AM codes are marked with an asterisk (\*).

The address range of the microprocessor (4 Gigabyte) is split into several areas to support all of the listed AM codes. The table to follow lists the address ranges and the supported AM codes for this range.

All I/O and Memory Boards on the VMEbus which will be addressed in the listed address ranges must use one or a combination of the AM codes to guarantee proper operation.

|                                                | Address Modifier |                 |                 |                            |                                 |                                      |                                                                                                                                                                                                                                                       |
|------------------------------------------------|------------------|-----------------|-----------------|----------------------------|---------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HEX<br>Code                                    | 5                | 4               | 3               | 2                          | 1                               | 0                                    | Function                                                                                                                                                                                                                                              |
| 3F<br>*3E<br>*3D<br>3C<br>3B<br>3A<br>39<br>38 | <b>エエエエエエ</b>    | <b>エエエエエエ</b> エ | <b>エ</b> エエエエエエ |                            |                                 | H<br>L<br>H<br>L<br>H<br>L<br>L      | Standard Supervisory Block Transfer<br>Standard Supervisory Program Access<br>Standard Supervisory Data Access<br>Reserved<br>Standard Privileged Block Transfer<br>Standard Previleged Program Access<br>Standard Previleged Data Access<br>Reserved |
| 37<br>36<br>35<br>34<br>33<br>32<br>31<br>30   |                  | ΙΙΙΙΙΙ          |                 |                            | H                               | H<br>L<br>H<br>L<br>H<br>L<br>H<br>L | Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved                                                                                                                                                                      |
| 2F<br>2E<br>*2D<br>2C<br>2B<br>2A<br>*29<br>28 | * * * * * * *    |                 | нтнтнт          |                            |                                 |                                      | Reserved<br>Reserved<br>Short Supervisory Access<br>Reserved<br>Reserved<br>Reserved<br>Short Previleged Access<br>Reserved                                                                                                                           |
| 27<br>26<br>25<br>24<br>23<br>22<br>21<br>20   | нннннн           |                 |                 | H<br>H<br>H<br>L<br>L<br>L | H<br>H<br>L<br>H<br>H<br>L<br>L | H<br>L<br>H<br>L<br>H<br>L           | Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved                                                                                                                                                          |
|                                                |                  | L               | = lo            | w sig                      | nal le                          | H = high signal level                |                                                                                                                                                                                                                                                       |

# Table 6-5: Address Modifier Codes

# The Address Modifier Codes (cont'd)

|                                                  | Address Modifier                           |                      |                      |                            | fier                            |                                      |                                                                                                                                                                                                                                                       |  |  |  |
|--------------------------------------------------|--------------------------------------------|----------------------|----------------------|----------------------------|---------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| HEX<br>Code                                      | 5                                          | 4                    | 3                    | 2                          | 1                               | 0                                    | Function                                                                                                                                                                                                                                              |  |  |  |
| 1F<br>1E<br>1D<br>1C<br>1B<br>1A<br>19<br>18     |                                            | <b>X X X X X X X</b> | <b>X X X X X X X</b> | H H H L L L                |                                 | H<br>L<br>H<br>L<br>H<br>L<br>L      | Standard Supervisory Block Transfer<br>Standard Supervisory Program Access<br>Standard Supervisory Data Access<br>Reserved<br>Standard Previleged Block Transfer<br>Standard Previleged Program Access<br>Standard Previleged Data Access<br>Reserved |  |  |  |
| 17<br>16<br>15<br>14<br>13<br>12<br>11<br>10     |                                            |                      |                      |                            | H<br>H<br>L<br>H<br>H<br>L<br>L | H<br>L<br>H<br>L<br>H<br>L<br>H<br>L | Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved                                                                                                                                                          |  |  |  |
| 0F<br>*0E<br>*0D<br>0C<br>0B<br>*0A<br>*09<br>08 |                                            |                      |                      | H<br>H<br>H<br>L<br>L<br>L |                                 |                                      | Reserved<br>Reserved<br>Short Supervisory Access<br>Reserved<br>Reserved<br>Reserved<br>Short Previleged Access<br>Reserved                                                                                                                           |  |  |  |
| 07<br>06<br>05<br>04<br>03<br>02<br>01<br>00     |                                            |                      |                      | H<br>H<br>L<br>L<br>L<br>L | H<br>L<br>L<br>H<br>L<br>L      | H<br>L<br>H<br>L<br>H<br>L           | Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved                                                                                                                                                          |  |  |  |
|                                                  | L = low signal level H = high signal level |                      |                      |                            |                                 |                                      |                                                                                                                                                                                                                                                       |  |  |  |

| Address                                                                                                                                                         | Range                                                | Address Modifier Code                                |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|--|--|
| XXXX XXXX*<br>1000:<br>:<br>F9FF FFFF                                                                                                                           | VMEbus (Extended Access)<br>A32 : D32, D24, D16, D8  | 001110 SPA<br>001101 SDA<br>001010 NPA<br>001001 NDA |  |  |
| FBFF 0000<br>00 :<br>:<br>FBFE FFFF                                                                                                                             | VMEbus (Standard Access)<br>A24 : D32, D24, D16, D8  | 111110 SPA<br>111101 SDA<br>111010 NPA<br>111001 NDA |  |  |
| FBFF 0000<br>:<br>:<br>FBFF FFFF                                                                                                                                | VMEbus (Short I/O Access)<br>A16 : D32, D24, D16, D8 | 101101 SDA<br>101001 NDA                             |  |  |
| FC00 0000<br>:<br>:<br>FCFE FFFF                                                                                                                                | VMEbus (Standard Access)<br>A24 : D16, D8            | 111110 SPA<br>111101 SDA<br>111010 NPA<br>111001 NDA |  |  |
| FCFF 0000<br>:<br>:<br>FCFF FFFF                                                                                                                                | VMEbus (Short I/O Access)<br>A16 : D16, D8           | 101101 SDA<br>101001 NDA                             |  |  |
| SPA = Supervisor Program Access<br>SDA = Supervisor Data Access<br>NPA = Nonpreviliged Program Access<br>NDA = Nonpreviliged Data Access                        |                                                      |                                                      |  |  |
| <ul> <li>* XXXX XXXX = 0040 0000 for CPU-40x/4 or 0100 0000 for CPU-40x/16</li> <li>* XXXX XXXX = 0040 0000 for CPU-41x/4 or 0080 0000 for CPU-41x/8</li> </ul> |                                                      |                                                      |  |  |

# Table 6-6: Address Modifier Codes Used on the CPU Board

### 6.2 VMEbus Slave Interface

#### 6.2.1 The Access Address

The onboard shared RAM of the CPU board is also accessible from the VMEbus side. Both the begin and end address are programmable in 4 Kbyte increments inside the FGA-002. The complete address decoding for the shared RAM logic is performed inside the FGA-002 Gate Array. For details on the programming of the access address, please refer to the BOOT Software description in the FGA-002 User's Manual.

### 6.2.2 Data Transfer Size of the Shared RAM

The VMEbus interface of the shared RAM is 32 bits wide. It supports 32 bit, 16 bit, and 8 bit as well as unaligned (UAT) and read-modify-write (RMW) transfers.

#### 6.2.3 Address Modifier Decoding and A24 Slave Mode

For access to the shared RAM from the VMEbus side, extended (A32) and standard (A24) accesses are allowed.

The FGA-002 only recognizes A32 accesses. The access address for an A32 access can be programmed as described above.

If an A24 access takes place additional onboard hardware translates this A24 access to an A32 access to the FGA-002. This means that the standard address modifier code from the VMEbus is modified to extended address modifier to the FGA-002. In A24 mode the address lines A31 to A24 of the VMEbus must not be used for address decoding. Therefore these address lines are driven to the FGA-002 via an additional driver. The value of these address bits are programmable via the PI/T1 Port B. For detailed information about the address map and register layout of the PI/T1 please refer to the chapter "Address Map of the PI/T1 Registers".

The following table shows which PI/T bit belongs to which address line.

| PI/T1 Port B Bit | Address Line |
|------------------|--------------|
| 0                | A24          |
| 1                | A25          |
| 2                | A26          |
| 3                | A27          |
| 4                | A28          |
| 5                | A29          |
| 6                | A30          |
| 7                | A31          |

The value of these bits must be programmed according to the access address inside the FGA-002.

For example if the shared RAM access address for VMEbus is programmed to:

#### Start Address \$1000000 End Address \$1040000

the PI/T bits must be programmed to:

PI/T1 Port B Bit 7 6 5 4 3 2 1 0 0 0 0 1 0 0 0 0

to allow A24 accesses.

If an A24 master now accesses the address \$005000, it reaches the same address as an A32 master accessing the address \$10005000.

A32 mode is always enabled and A24 mode can be enabled in addition via the PI/T2 Port C Bit 7. For detailed information about the address map and register layout of the PI/T2, please refer to the chapter "Address Map of the PI/T2 Registers".

The following table shows the function of the PI/T2 Port C bit 7.

| Enable VMEbus Slave Accesses |
|------------------------------|
| A32                          |
| A32/A24                      |
|                              |

The following table shows the allowed AM Codes for VMEbus accesses to the Shared RAM.

### Table 6-7: VMEbus Slave AM Codes

| HEX                  |                                                                                                                                                                                                                                             | Address Modifier |     |             |             |                  |                                                                                                                                                                             |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----|-------------|-------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code                 | 5                                                                                                                                                                                                                                           | 4                | 3   | 2           | 1           | 0                | Function                                                                                                                                                                    |
| 3E<br>3D<br>3A<br>39 | H<br>H<br>H<br>H<br>H                                                                                                                                                                                                                       | тттт             | ттт | H<br>H<br>L | HLHL        | L<br>H<br>L<br>H | Standard Supervisory Program Access<br>Standard Supervisory Data Access<br>Standard Previleged Program Access<br>Standard Previleged Data Access                            |
| 0E<br>0D<br>0A<br>09 | OE       L       L       H       H       H       L         OD       L       L       H       H       L       H         OA       L       L       H       L       H       L       H         O9       L       L       H       L       L       H |                  |     |             | L<br>H<br>L | L<br>H           | Extended Supervisory Program Access<br>Extended Supervisory Data Access<br>Extended Previleged Program Access<br>Extended Previleged Data Access<br>I H = high signal level |

# 6.3 The VMEbus Interrupt Handler

All seven VMEbus interrupt request (IRQ) signals are connected to the interrupt handling logic on the FGA-002 Gate Array. Each of the VMEbus IRQ signals can be separately enabled or disabled. The FGA-002 Gate Array allows high end multiprocessor environment board usage with distributed interrupt handling.

The FGA-002 Gate Array uses the interrupt as a D08(0) interrupt handler in accordance with the VMEbus Standard.

In addition every VMEbus interrupt level can be mapped to cause an interrupt on a different level to the processor. So for example a VMEbus interrupt request on level 2 can be mapped to cause an interrupt request on level 5 to the processor.

#### CAUTION

The CPU board only supports the byte interrupt vectoring.

The byte interrupt vector is implemented on most of the existing boards because the VMEbus Specification Rev. A and B do not include a word or long word interrupt vector. Therefore, older VMEbus boards can be used together with this CPU board if they are compatible to the current timing specification.

The complete VMEbus interrupt handling is done inside the FGA-002. Therefore please refer to the FGA-002 User's Manual for a detailed description of the programming of the interrupt management functions.

#### **6.4 VMEbus Arbitration**

Each transfer to/from an area marked in Table 6-6 causes a VMEbus access cycle. The VMEbus defines an arbitration scheme to arbitrate the bus mastership. Four request levels are defined as 0, 1, 2, and 3.

#### 6.4.1 Four Available VMEbus Arbiters

A VMEbus Arbiter may operate in one of the following modes:

- a) Single Level Arbiter
- b) Prioritized 4-Level Arbiter
- c) Round Robin 4-Level Arbiter
- d) Prioritized Round Robin 4-Level Arbiter

The arbiter modes a, b, and c above are defined in the VMEbus standard and mode d has been developed by FORCE COMPUTERS and implemented on the CPU board. The arbiter mode used is application dependent.

#### 6.4.2 The On-Board Four Level Arbiter

The CPU board contains a four level arbiter which can be enabled/disabled through hardware. The four level arbiter together with the VMEbus request level control and the VMEbus interrupter is built in an LCA which is a programmable gate array.

- If the four level arbiter is enabled, the board must be plugged into slot 1 of the VMEbus rack, as defined in the VMEbus standard.
   All other boards must force bus requests at level 0...3 if the on-board arbiter is enabled.
   No other arbiter can be used if the on-board arbiter is enabled.
   If an external arbiter is used, the on-board arbiter must be disabled.
   By default, the four level arbiter is enabled.
- 6) The SGL VMEbus arbiter in the FGA-002 must remain disabled in all cases.

The arbiter can work in the Prioritized 4-level, Round Robin 4-level or Prioritized Round Robin 4-level mode.

The VMEbus Arbiter/Requester/Interrupter LCA has three internal registers which are one byte wide. One of the registers is used to control the VMEbus Requester and the VMEbus Arbiter. It can be accessed on address \$FF803E02.

#### Table 6-8: VMEbus Arbiter/Requester Register Layout

| Default I/O Base Address: \$FF800000<br>Default Offset: \$00003E02 |    |     |    |            |                            |  |
|--------------------------------------------------------------------|----|-----|----|------------|----------------------------|--|
| AddressOffsetModeDefaultLabelHEXHEXValue                           |    |     |    |            | Description                |  |
| FF803E0<br>2                                                       | 00 | R/W | 73 | ARBRE<br>G | Arbiter/Requester Register |  |

### Table 6-9: Description of Arbiter/Requester Register Bits

| Bit      | Value                                                                                                     | Mode | Description                                                                                                    |  |  |  |
|----------|-----------------------------------------------------------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------------|--|--|--|
| 0        | 1*                                                                                                        | R/W  | Request level: low bit                                                                                         |  |  |  |
| 1        | 1*                                                                                                        | R/W  | Request level: high bit                                                                                        |  |  |  |
| 2        | 2*                                                                                                        | R/W  | Arbiter mode: low bit                                                                                          |  |  |  |
| 3        | 2*                                                                                                        | R/W  | Arbiter mode: high bit                                                                                         |  |  |  |
| 4        |                                                                                                           | R    | No function                                                                                                    |  |  |  |
| 5        |                                                                                                           | R    | No function                                                                                                    |  |  |  |
| 6        | 1<br>0                                                                                                    | R    | Setting of arbiter jumperfield:<br>Arbiter enabled (Jumper inserted)<br>Arbiter disabled (Jumper not inserted) |  |  |  |
| 7        | 1<br>0                                                                                                    | R/W  | Control of request level:<br>Done by software<br>Done by hardware                                              |  |  |  |
| 1*<br>2* | <ul> <li>1* See the description "Request Level"</li> <li>2* See the description "Arbiter Mode"</li> </ul> |      |                                                                                                                |  |  |  |

#### **Request Level**

The control of the request level on VMEbus can be done either by software (bit 7 is set to one) or by hardware (bit 7 is set to zero).

If the control of the request level is done by hardware the request level is selected via jumperfield B19. The jumpersettings for the VMEbus request levels 0 to 3 are shown in figure 6-1: Requester/Arbiter Jumperfield B19.

If the control of the request level is done by software the request level is selected via bit 0 and bit 1 of the register. The bit settings for the VMEbus request levels 0 to 3 are shown in the next table.

#### Table 6-10: Bit Settings for VMEbus Request Level

| Bit 1 | Bit O    | VMEbus Request Level | Default |
|-------|----------|----------------------|---------|
| 0     | 0        | 0                    |         |
| 0     | 1        | 1                    |         |
| 1     | 0        | 2                    |         |
| 1     | 1        | 3                    | ¥       |
|       | <u> </u> | L                    |         |

#### NOTE

If the user wants to select the request level by software (bit 7 set to one) the two jumpers in jumperfield B19 for the request level (see Figure 6-1: Requester/Arbiter Jumperfield B19) must be removed before. Otherwise bit 7 can't be set to one.

#### Arbiter Enable/Disable

The onboard VMEbus arbiter can enabled or disabled via the third jumper of jumperfield B19 (see Figure 6-1: Requester/Arbiter Jumperfield B19). The setting of the jumper can be read by software via bit 6 of the requester/arbiter register (see Table 6-9: Description of Requester/Arbiter Register Bits).

#### Arbiter Mode

The arbiter mode of the onboard VMEbus arbiter can be selected by software via bit 2 and bit 3 of the requester/arbiter register. The bit settings for the three arbiter modes are shown in Table 6-11: Bit Settings for VMEbus Arbiter Mode.

#### Table 6-11: Bit Settings for VMEbus Arbiter Mode

| Bit 3 | Bit 2 | Default | Arbiter Mode                 |
|-------|-------|---------|------------------------------|
| 0     | 0     | *       | prioritized mode             |
| 0     | 1     |         | round robin mode             |
| 1     | 0     |         | prioritized round robin mode |
| 1     | 1     |         | prioritized round robin mode |

# Figure 6-1: Requester/Arbiter Jumperfield B19

|                     | Arbiter Enabled | Arbiter Disabled |  |  |
|---------------------|-----------------|------------------|--|--|
|                     | B19 (default)   | B19              |  |  |
|                     | 1 0 6           | 1 0 6            |  |  |
| Bus Request Level 3 | 2 0-0 5         | 2 <b>o—o</b> 5   |  |  |
|                     | 3 0-0 4         | 3 0 0 4          |  |  |
|                     | B19             | B19              |  |  |
|                     | 1 0 6           | 1 <b>o</b> —o 6  |  |  |
| Bus Request Level 2 | 2 0 0 5         | 2 • • 5          |  |  |
|                     | 3 0-0 4         | 3 • • 4          |  |  |
|                     | B19             | B19              |  |  |
|                     | 1 0 0 6         | 1 0 0 6          |  |  |
| Bus Request Level 1 | 2 <b>o—o</b> 5  | 2 <b>o—o</b> 5   |  |  |
|                     | 3 0-0 4         | 3 • • 4          |  |  |
|                     | B19             | B19              |  |  |
|                     | 1 0 0 6         | 1 0 0 6          |  |  |
| Bus Request Level 0 | 2 0 0 5         | 2 0 0 5          |  |  |
|                     | 3 0-0 4         | 3 0 0 4          |  |  |
|                     |                 |                  |  |  |



# Figure 6-2: Location Diagram of Jumperfield B19

# 6.4.3 The VMEbus Release Function

The CPU board contains several different software selectable bus release functions to relinquish VMEbus mastership. The Bus Release Operation is independent of whether or not the on-board arbiter is enabled and independent of the Bus Request level. Easy handling and usage of the bus release functions is provided through the FGA-002 Gate Array. RMW Cycles are always completed before the bus is released. VMEPROM allows the user to change the release function through the ARB command. Please refer to the *Introduction to VMEPROM* for details. The modes are defined in the following chapters.

# 6.4.3.1 Release Every Cycle (REC)

The REC mode causes a release of VMEbus mastership after the initiated transfer cycle has been completed. A normal read or write cycle is terminated after the address and data strobes are driven high (inactive state). A Read Modify Write cycle (RMW) is terminated after the write cycle is completed by the CPU, through deactivation of the address and data strobes. If the REC mode is enabled, all other bus release functions have no impact ("don't care"). The REC mode is only for CPU cycles to the VMEbus, and not for DMA cycles. The programming of the REC mode is described in the FGA-002 Gate Array User's Manual.

### 6.4.3.2 Release on Request (ROR)

The ROR Mode is defined as a release of bus mastership if another bus requester has requested bus mastership and the CPU board is the current bus master. The Gate Array contained DMA controller can also be the requestor causing such a bus release. The ROR mode is only for CPU cycles to the VMEbus, and not for DMA cycles. The ROR mode cannot be disabled, it is programmable how long the CPU stays VMEbus master despite of a Bus Request pending. The programming of the ROR mode is described in the FGA-002 Gate Array Manual.

# 6.4.3.3 Release After Timeout (RAT)

A timer with a fixed clock rate is installed in the FGA-002 providing a bus mastership release after 100 microseconds of no CPU cycles to the VMEbus. This release function is active only after the ROR mode timeout. This function cannot be disabled. The RAT Mode is only for CPU cycles to the VMEbus and not for DMA cycles. The programming of the RAT mode is described in the FGA-002 Gate Array Manual.

# 6.4.3.4 Release on Bus Clear (RBCLR)

The RBCLR function allows the bus mastership release if an external arbiter asserts the BCLR \* signal of the VMEbus. This function then overrides the ROR function timing limitations. The RBCLR Mode is only for CPU cycles to the VMEbus and not for DMA cycles. The programming of the RBCLR mode is described in the FGA-002 Gate Array User's Manual.

# 6.4.3.5 Release When Done (RWD)

The DMA Controller installed in the FGA-002 Gate Array can also be VMEbus master. It always operates in transfer rounds (maximum 32 transfers). The bus is always released after completion of such a transfer round. The other Bus Release Functions are for CPU mastership to the VMEbus. The VMEbus board mastership is always a CPU or DMA Controller mastership. Gaining mastership is always a VMEbus arbitration sequence.

# 6.4.3.6 Release Voluntary (RV)

If the local processor is VMEbus bus master, the release on request counter inhibits the gate array from releasing the bus for the specified time (See ROR function). After this time elapses, the gate array may release the bus voluntary if the local CPU does not perform accesses to the VMEbus within a 100 microsecond time period. After each new access to VME, this 100 us time period must pass until the bus is released voluntary.

# 6.4.3.7 Release on ACFAIL (ACFAIL)

If the board is programmed by the Gate Array to be the ACFAILHANDLER in the VMEbus Rack, and if the ACFAIL\* signal of the VMEbus is asserted, the CPU will not release the VMEbus if it is the bus master. That is, REC, ROR, RAT, and RBCLR do not operate in this case. If the board is not ACFAILHANDLER and the ACFAIL\* signal is asserted, the board will release the VMEbus immediately.

# Table 6-12: Bus Release Functions

| Function                   | Enabled                               | Release                                    |  |  |  |
|----------------------------|---------------------------------------|--------------------------------------------|--|--|--|
| REC<br>ROR<br>RAT<br>RBCLR | Yes<br>Y<br>Y<br>X                    | Every Cycle                                |  |  |  |
| REC<br>ROR<br>RAT<br>RBCLR | NO<br>Y<br>Y<br>NO                    | BR(0,1,2) = 0<br>or<br>Timeout             |  |  |  |
| REC<br>ROR<br>RAT<br>RBCLR | NO<br>Y<br>Y<br>YES                   | BR(0,1,2) = 0  or<br>Timeout or $BCLR = 0$ |  |  |  |
| X =                        | X = don't care Y = cannot be disabled |                                            |  |  |  |

### 6.5 The VMEbus Interrupter

The VMEbus Interrupter on the CPU board can generate interrupts on the VMEbus interrupt levels IRQ1 to IRQ7. The interrupts can be generated by software. The interrupter can generate a byte wide interrupt vector which is software programmable.

The VMEbus Interrupter on the CPU board together with the VMEbus Arbiter/Requester is built in an LCA which is a programmable gate array. This LCA has three internal registers which are byte wide. Two of these registers are used to control the VMEbus Interrupter. They are accessed on addresses \$FF803E00 and \$FF803E01.

| Default I/O B<br>Default Offse |               | s:         | \$FF80000<br>\$00003EC |                       |                                                            |
|--------------------------------|---------------|------------|------------------------|-----------------------|------------------------------------------------------------|
| Address<br>HEX                 | Offset<br>HEX | Mode       | Default<br>Value       | Label                 | Description                                                |
| FF803E00<br>FF803E01           | 00<br>01      | R/W<br>R/W | 01<br>00               | IRQREG<br>VECTRE<br>G | Interrupt generation register<br>Interrupt vector register |

#### Table 6-13: VMEbus Interrupter Registers

#### 6.5.1 The Interrupt Generation Register

The VMEbus Interrupts on levels IRQ1 to IRQ7 can be generated by software via bit 1 to bit 7 of the IRQ generation register. Bit 0 of the register has no function (see Table 6-14: Description of the IRQ Generation Register). An interrupt is generated by setting the corresponding register bit to one. When the interrupt is acknowledged by the VMEbus Interrupt Handler the bit is automatically set to zero again.

| Bit | Value  | Mode | Description                                                                   |
|-----|--------|------|-------------------------------------------------------------------------------|
| 0   |        |      | No function                                                                   |
| 1   | 1<br>0 | R/W  | VMEbus interrupt IRQ1<br>Active<br>Inactive (automatically set to zero again) |
| 2   | 1<br>0 | R/W  | VMEbus interrupt IRQ2<br>Active<br>Inactive (automatically set to zero again) |
| 3   | 1<br>0 | R/W  | VMEbus interrupt IRQ3<br>Active<br>Inactive (automatically set to zero again) |
| 4   | 1<br>0 | R/W  | VMEbus interrupt IRQ4<br>Active<br>Inactive (automatically set to zero again) |
| 5   | 1<br>0 | R/W  | VMEbus interrupt IRQ5<br>Active<br>Inactive (automatically set to zero again) |
| 6   | 1<br>0 | R/W  | VMEbus interrupt IRQ6<br>Active<br>Inactive (automatically set to zero again) |
| 7   | 1<br>0 | R/W  | VMEbus interrupt IRQ7<br>Active<br>Inactive (automatically set to zero again) |

# Table 6-14: Description of the IRQ Generation Register

# 6.5.2 The Interrupt Vector Register

The interrupt vector register holds the byte wide interrupt vector for the VMEbus interrupts. It can be read and written and must be set to the right value before an interrupt is activated. It must not be changed as long as a VMEbus Interrupt from the board is pending.

#### 6.6 The SYSCLK Driver

The CPU board contains all circuities to support the SYSCLK signal. The output signal is a stable 16 MHz signal with a 50/50 high/low cycle.

The driver circuitry for the SYSCLK signal has a current driver capacity of 64mA.

The SYSCLK signal can be enabled and disabled via a jumper setting at B13.

Jumper 1-8 insertedSYSCLK driven (default)Jumper 1-8 removedSYSCLK not driven

The usage of jumperfield B13 is shown in Figure 6-3 and the location diagram of the SYSCLK jumperfield is outlined in Figure 6-4.

# CAUTION

Only one board (located in slot 1) in the VMEbus environment must drive the SYSCLK signal.

#### Figure 6-3: Usage of Jumperfield B13

"SYSCLK driven if jumper 1-8 is inserted"

B13

| 8 | 7 | 6 | 5 |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | о |
| 1 | 2 | 3 | 4 |

# Figure 6-4: Location Diagram of B13



6-24

#### 6.7 Exception Signals

The VMEbus defines the signals ACFAIL, SYSFAIL, and RESET for signaling exceptions or status.

The ACFAIL and the SYSFAIL signals of the VMEbus are connected to the FGA-002 Gate Array.

The FGA-002 may be programmed to generate interrupts on SYSFAIL and ACFAIL. For detailed information please refer to the FGA-002 User's Manual.

VMEPROM monitors the SYSFAIL line during the initialization of external intelligent I/O boards. The ACFAIL line is ignored by VMEPROM.

The FGA-002 drives the SYSFAIL line after Reset until initialization of the board is completed.

To remain compatible to older boards this signal can be enabled and disabled via a jumper setting at B13.

Jumper 2-7 insertedSYSFAIL driven (default)Jumper 2-7 removedSYSFAIL not driven

The usage of jumperfield B13 is shown in the following figure, and the location diagram of the SYSFAIL jumperfield is outlined in the figure on the next page.

#### Figure 6-5: Usage of Jumperfield B13

"SYSFAIL driven if jumper 2-7 is inserted"

B13

| 8 | 7     | 6 | 5 |
|---|-------|---|---|
| 0 | 0<br> | 0 | ο |
| Ö | Ö     | 0 | 0 |
| 1 | 2     | 3 | 4 |





# APPENDIX B

#### MEMORY MAP OF THE CPU BOARD

| Start<br>Address                 | End<br>Address                   | Туре                                                                              |
|----------------------------------|----------------------------------|-----------------------------------------------------------------------------------|
| 00000000<br>00000000<br>00000000 | 003FFFFF<br>007FFFFF<br>00FFFFFF | Shared Memory (4 Mbyte)<br>Shared Memory (8 Mbyte) or<br>Shared Memory (16 Mbyte) |
| 0040000                          | F9FFFFF                          | VMEbus Addresses (4 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8                |
| 0000000                          | F9FFFFF                          | VMEbus Addresses (8 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8                |
| 01000000<br>for 16 meg bood      | F9FFFFF                          | VMEbus Addresses (16 Mbyte Shared Memory)<br>A32: D32, D24, D16, D8               |
| FA000000                         | FAFFFFF                          | Message Broadcast Area                                                            |
| FB000000                         | FBFEFFFF                         | VMEbus<br>A24: D32, D24, D16, D8                                                  |
| FBFF0000                         | FBFFFFF                          | VMEbus<br>A16: D32, D24, D16, D8                                                  |
| FC000000                         | FCFEFFFF                         | VMEbus<br>A24: D16, D8                                                            |
| FCFF0000                         | FCFFFFF                          | VMEbus<br>A16: D16, D8                                                            |
| FD000000                         | FEFFFFF                          | Reserved                                                                          |
| FF000000                         | FF7FFFF                          | SYSTEM EPROM                                                                      |
| FF800000                         | FFBFFFFF                         | Local I/O                                                                         |
| FFC00000                         | FFC7FFFF                         | LOCAL SRAM                                                                        |
| FFC80000                         | FFCFFFFF                         | Local FLASH EPROM                                                                 |
| FFD00000                         | FFDFFFFF                         | Registers of FGA-002                                                              |
| FFE00000                         | FFEFFFFF                         | BOOT EPROM                                                                        |
| FF803E00                         | FF803FFF                         | VMEbus Arbiter                                                                    |
| FFF00000                         | FFFFFFF                          | Reserved                                                                          |

This page was intentionally left blank

# APPENDIX C

### ADDRESS ASSIGNMENT AND REGISTER LAYOUT OF THE I/O DEVICES

#### Serial I/O Port #1 (DUSCC1) Register Layout

|                | Port Base Address: \$FF802000 |                |      |          |                                |  |  |  |  |  |  |
|----------------|-------------------------------|----------------|------|----------|--------------------------------|--|--|--|--|--|--|
| Address<br>HEX | Offset<br>HEX                 | Reset<br>Value | Mode | Label    | Description                    |  |  |  |  |  |  |
| \$FF802000     | 00                            | 00             | R/W  | DUSCMR1  | Channel Mode Reg 1             |  |  |  |  |  |  |
| \$FF802001     | 01                            | 00             | R/W  | DUSCMR2  | Channel Mode Reg 2             |  |  |  |  |  |  |
| \$FF802002     | 02                            |                | R/W  | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |  |  |  |
| \$FF802003     | 03                            |                | R/W  | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |  |  |  |
| \$FF802004     | 04                            | 00             | R/W  | DUSTPR   | Transmitter Parameter Reg      |  |  |  |  |  |  |
| \$FF802005     | 05                            |                | R/W  | DUSTTR   | Transmitter Timing Reg         |  |  |  |  |  |  |
| \$FF802006     | 06                            | 00             | R/W  | DUSRPR   | Receiver Parameter Reg         |  |  |  |  |  |  |
| \$FF802007     | 07                            |                | R/W  | DUSRTR   | Receiver Timing Reg            |  |  |  |  |  |  |
| \$FF802008     | 08                            |                | R/W  | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |  |  |  |
| \$FF802009     | 09                            |                | R/W  | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |  |  |  |
| \$FF80200A     | 0A                            |                | R/W  | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |  |  |  |
| \$FF80200B     | OB                            | 00             | R/W  | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |  |  |  |
| \$FF80200C     | 0C                            |                | R    | DUSCTH   | Counter/Timer High             |  |  |  |  |  |  |
| \$FF80200D     | 0D                            |                | R    | DUSCTL   | Counter/Timer Low              |  |  |  |  |  |  |
| \$FF80200E     | 0E                            | 00             | R/W  | DUSPCR   | Pin Configuration Reg          |  |  |  |  |  |  |
| \$FF80200F     | OF                            |                | R/W  | DUSCCR   | Channel Command Reg            |  |  |  |  |  |  |
| \$FF802010     | 10                            |                |      |          | -                              |  |  |  |  |  |  |
| \$FF802011     | 11                            |                |      |          |                                |  |  |  |  |  |  |
| \$FF802012     | 12                            |                | W    | DUSTFIFO | Transmitter FIFO               |  |  |  |  |  |  |
| \$FF802013     | 13                            |                |      |          |                                |  |  |  |  |  |  |
| \$FF802014     | 14                            |                |      |          |                                |  |  |  |  |  |  |
| \$FF802015     | 15                            |                |      |          |                                |  |  |  |  |  |  |
| \$FF802016     | 16                            |                | R    | DUSRFIFO | Receiver FIFO                  |  |  |  |  |  |  |
| \$FF802017     | 17                            |                |      |          |                                |  |  |  |  |  |  |
| \$FF802018     | 18                            | 00             | R/W  | DUSRSR   | Receiver Status Reg            |  |  |  |  |  |  |
| \$FF802019     | 19                            | 00             | R/W  | DUSTRSR  | Transmitter/Receiver Stat Reg  |  |  |  |  |  |  |
| \$FF80201A     | 1A                            |                | R/W  | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |  |  |  |
| \$FF80201C     | 1C                            | 00             | R/W  | DUSIER   | Interrupt Enable Reg           |  |  |  |  |  |  |

.

| Serial I/O | Port # | #2 (D | USCC1) | Register | Layout |
|------------|--------|-------|--------|----------|--------|
|------------|--------|-------|--------|----------|--------|

| Port Base Address: \$FF802000 |               |                |      |          |                                |  |  |  |  |
|-------------------------------|---------------|----------------|------|----------|--------------------------------|--|--|--|--|
| Address<br>HEX                | Offset<br>HEX | Reset<br>Value | Mode | Label    | Description                    |  |  |  |  |
| \$FF802020                    | 00            | 00             | R/W  | DUSCMR1  | Channel Mode Reg 1             |  |  |  |  |
| \$FF802021                    | 01            | 00             | R/W  | DUSCMR2  | Channel Mode Reg 2             |  |  |  |  |
| \$FF802022                    | 02            |                | R/W  | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |  |
| \$FF802023                    | 03            |                | R/W  | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |  |
| \$FF802024                    | 04            | 00             | R/W  | DUSTPR   | Transmitter Parameter Reg      |  |  |  |  |
| \$FF802025                    | 05            |                | R/W  | DUSTTR   | Transmitter Timing Reg         |  |  |  |  |
| \$FF802026                    | 06            | 00             | R/W  | DUSRPR   | Receiver Parameter Reg         |  |  |  |  |
| \$FF802027                    | 07            |                | R/W  | DUSRTR   | Receiver Timing Reg            |  |  |  |  |
| \$FF802028                    | 08            |                | R/W  | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |  |
| \$FF802029                    | 09            |                | R/W  | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |  |
| \$FF80202A                    | 0A            |                | R/W  | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |  |
| \$FF80202B                    | OB            | 00             | R/W  | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |  |
| \$FF80202C                    | 00            |                | R    | DUSCTH   | Counter/Timer High             |  |  |  |  |
| \$FF80202D                    | 0D            |                | R    | DUSCTL   | Counter/Timer Low              |  |  |  |  |
| \$FF80202E                    | OE            | 00             | R/W  | DUSPCR   | Pin Configuration Reg          |  |  |  |  |
| \$FF80202F                    | OF            |                | R/W  | DUSCCR   | Channel Command Reg            |  |  |  |  |
| \$FF802030                    | 10-7          |                |      |          |                                |  |  |  |  |
| \$FF802031                    | 11            |                |      |          |                                |  |  |  |  |
| \$FF802032                    | 12            |                | w    | DUSTFIFO | Transmitter FIFO               |  |  |  |  |
| \$FF802033                    | 13-           |                |      |          |                                |  |  |  |  |
| \$FF802034                    | 14-           |                |      |          |                                |  |  |  |  |
| \$FF802035                    | 15            |                |      |          |                                |  |  |  |  |
| \$FF802036                    | 16            |                | R    | DUSRFIFO | Receiver FIFO                  |  |  |  |  |
| \$FF802037                    | 17-           |                |      |          |                                |  |  |  |  |
| \$FF802038                    | 18            | 00             | R/W  | DUSRSR   | Receiver Status Reg            |  |  |  |  |
| \$FF802039                    | 19            | 00             | R/W  | DUSTRSR  | Transmitter/Receiver Stat Reg  |  |  |  |  |
| \$FF80203A                    | 1A            |                | R/W  | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |  |
| \$FF80203C                    | 1C            | 00             | R/W  | DUSIER   | Interrupt Enable Reg           |  |  |  |  |

Ports #1 and #2 (DUSCC1) Common Register Address Map

| Port Base Address: \$FF802000 |               |                |      |         |                              |  |  |  |
|-------------------------------|---------------|----------------|------|---------|------------------------------|--|--|--|
| Address<br>HEX                | Offset<br>HEX | Reset<br>Value | Mode | Label   | Description                  |  |  |  |
| \$FF80201B                    | 1B            | 00             | R/W  | DUSGSR  | General Status Register      |  |  |  |
| \$FF80201E                    | 1E            | OF             | R/W  | DUSIVR  | Interrupt Vec Reg Unmodified |  |  |  |
| \$FF80201F                    | 1F            | 00             | R/W  | DUSICR  | Interrupt Control Register   |  |  |  |
| \$FF80203E                    | 3E            | OF             | R    | DUSIVRM | Interrupt Vec Reg Modified   |  |  |  |

| Port Base Address : \$FF802200 |                 |                |      |          |                                |  |  |  |
|--------------------------------|-----------------|----------------|------|----------|--------------------------------|--|--|--|
| Address<br>HEX                 | Offset<br>HEX   | Reset<br>Value | Mode | Label    | Description                    |  |  |  |
| \$FF802200                     | 00              | 00             | R/W  | DUSCMR1  | Channel Mode Reg 1             |  |  |  |
| \$FF802201                     | 01              | 00             | R/W  | DUSCMR2  | Channel Mode Reg 2             |  |  |  |
| \$FF802202                     | 02              |                | R/W  | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |
| \$FF802203                     | 03              |                | R/W  | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |
| \$FF802204                     | 04              | 00             | R/W  | DUSTPR   | Transmitter Parameter Reg      |  |  |  |
| \$FF802205                     | 05              |                | R/W  | DUSTTR   | Transmitter Timing Reg         |  |  |  |
| \$FF802206                     | 06              | 00             | R/W  | DUSRPR   | Receiver Parameter Reg         |  |  |  |
| \$FF802207                     | 07              |                | R/W  | DUSRTR   | Receiver Timing Reg            |  |  |  |
| \$FF802208                     | 08              |                | R/W  | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |
| \$FF802209                     | 09              |                | R/W  | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |
| \$FF80220A                     | 0A              |                | R/W  | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |
| \$FF80220B                     | OB              | 00             | R/W  | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |
| \$FF80220C                     | 00              |                | R    | DUSCTH   | Counter/Timer High             |  |  |  |
| \$FF80220D                     | 0D              |                | R    | DUSCTL   | Counter/Timer Low              |  |  |  |
| \$FF80220E                     | OE              | 00             | R/W  | DUSPCR   | Pin Configuration Reg          |  |  |  |
| \$FF80220F                     | OF              |                | R/W  | DUSCCR   | Channel Command Reg            |  |  |  |
| \$FF802210                     | 10 <sub>7</sub> |                |      |          |                                |  |  |  |
| \$FF802211                     | 11              |                |      |          |                                |  |  |  |
| \$FF802212                     | 12              |                | W    | DUSTFIFO | Transmitter FIFO               |  |  |  |
| \$FF802213                     | 13-             |                |      |          |                                |  |  |  |
| \$FF802214                     | 14-             |                |      |          |                                |  |  |  |
| \$FF802215                     | 15              |                |      |          |                                |  |  |  |
| \$FF802216                     | 16              |                |      |          |                                |  |  |  |
| \$FF802217                     | 17-             |                | R    | DUSRFIFO | Receiver FIFO                  |  |  |  |
| \$FF802218                     | 18              | 00             | R/W  | DUSRSR   | Receiver Status Reg            |  |  |  |
| \$FF802219                     | 19              | 00             | R/W  | DUSTRSR  | Transmitter/Receiver Stat Reg  |  |  |  |
| \$FF80221A                     | 1A              |                | R/W  | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |
| \$FF80221C                     | 1C              | 00             | R/W  | DUSIER   | Interrupt Enable Reg           |  |  |  |

# Serial I/O Port #3 (DUSCC2) Register Address Map

#### Serial I/O Port #4 (DUSCC2) Register Address Map

|                | Port Base Address : \$FF802220 |                |     |          |                                |  |  |  |  |  |
|----------------|--------------------------------|----------------|-----|----------|--------------------------------|--|--|--|--|--|
| Address<br>HEX | Offset<br>HEX                  | Reset<br>Value |     | Label    | Description                    |  |  |  |  |  |
| \$FF802220     | 00                             | 00             | R/W | DUSCMR1  | Channel Mode Reg 1             |  |  |  |  |  |
| \$FF802221     | 01                             | 00             | R/W | DUSCMR2  | Channel Mode Reg 2             |  |  |  |  |  |
| \$FF802222     | 02                             |                | R/W | DUSSS1R  | SYN1/Secondary Adr Reg 1       |  |  |  |  |  |
| \$FF802223     | 03                             |                | R/W | DUSS2R   | SYN2/Secondary Adr Reg 2       |  |  |  |  |  |
| \$FF802224     | 04                             | 00             | R/W | DUSTPR   | Transmitter Parameter Reg      |  |  |  |  |  |
| \$FF802225     | 05                             |                | R/W | DUSTTR   | Transmitter Timing Reg         |  |  |  |  |  |
| \$FF802226     | 06                             | 00             | R/W | DUSRPR   | Receiver Parameter Reg         |  |  |  |  |  |
| \$FF802227     | 07                             |                | R/W | DUSRTR   | Receiver Timing Reg            |  |  |  |  |  |
| \$FF802228     | 08                             |                | R/W | DUSCTPRH | Counter/Timer Preset Reg H     |  |  |  |  |  |
| \$FF802229     | 09                             |                | R/W | DUSCTPRL | Counter/Timer Preset Reg L     |  |  |  |  |  |
| \$FF80222A     | 0A                             |                | R/W | DUSCTCR  | Counter/Timer Control Reg      |  |  |  |  |  |
| \$FF80222B     | OB                             | 00             | R/W | DUSOMR   | Output and Miscellaneous Reg   |  |  |  |  |  |
| \$FF80222C     | 00                             |                | R   | DUSCTH   | Counter/Timer High             |  |  |  |  |  |
| \$FF80222D     | 0D                             |                | R   | DUSCTL   | Counter/Timer Low              |  |  |  |  |  |
| \$FF80222E     | OE                             | 00             | R/W | DUSPCR   | Pin Configuration Reg          |  |  |  |  |  |
| \$FF80222F     | 0,F                            |                | R/W | DUSCCR   | Channel Command Reg            |  |  |  |  |  |
| \$FF802230     | 10 <sub>7</sub>                |                |     |          |                                |  |  |  |  |  |
| \$FF802231     | 11                             |                |     |          |                                |  |  |  |  |  |
| \$FF802232     | 12                             |                | w   | DUSTFIFO | Transmitter FIFO               |  |  |  |  |  |
| \$FF802233     | 13-                            |                |     |          |                                |  |  |  |  |  |
| \$FF802234     | 14 <sub>7</sub>                |                |     |          |                                |  |  |  |  |  |
| \$FF802235     | 15                             |                |     |          |                                |  |  |  |  |  |
| \$FF802236     | 16                             |                |     |          |                                |  |  |  |  |  |
| \$FF802237     | 17-1                           |                | R   |          | Receiver FIFO                  |  |  |  |  |  |
| \$FF802238     | 18                             | 00             | R/W |          | Receiver Status Reg            |  |  |  |  |  |
| \$FF802239     | 19                             | 00             | R/W |          | Transmitter/Receiver Stat Reg  |  |  |  |  |  |
| \$FF80223A     | 1A                             |                | R/W | DUSICTSR | Input + Counter/Timer Stat Reg |  |  |  |  |  |
| \$FF80223C     | 1C                             | 00             | R/W | DUSIER   | Interrupt Enable Reg           |  |  |  |  |  |

Ports #3 and #4 (DUSCC2) Common Registers Address Map

|                                                      | Port Base Address : \$FF802200 |                      |                        |                    |                                                                                                  |  |  |  |  |  |
|------------------------------------------------------|--------------------------------|----------------------|------------------------|--------------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Address<br>HEX                                       | Offset<br>HEX                  | Reset<br>Value       |                        | Label              | Description                                                                                      |  |  |  |  |  |
| \$FF80221B<br>\$FF80221E<br>\$FF80221F<br>\$FF80223E | 1E<br>1F                       | 00<br>0F<br>00<br>0F | R/W<br>R/W<br>R/W<br>R | DUSCMR2<br>DUSSS1R | Channel Mode Reg 1<br>Channel Mode Reg 2<br>SYN1/Secondary Adr Reg 1<br>SYN2/Secondary Adr Reg 2 |  |  |  |  |  |

#### PI/T1 Register Layout

| Default Offse  | Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 0C00<br>Default Name: PI_T1 |                |            |                                 |  |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------|----------------|------------|---------------------------------|--|--|--|--|--|
| Address<br>HEX | Offset<br>HEX                                                                               | Reset<br>Value | Label      | Description                     |  |  |  |  |  |
| FF800C00       | 00                                                                                          | 00             | PIT1 PGCR  | Port General Control Register   |  |  |  |  |  |
| FF800C01       | 01                                                                                          | 00             | PIT1 PSRR  | Port Service Request Register   |  |  |  |  |  |
| FF800C02       | 02                                                                                          | 00             | PIT1 PADDR | Port A Data Direction Register  |  |  |  |  |  |
| FF800C03       | 03                                                                                          | 00             | PIT1 PBDDR | Port B Data Direction Register  |  |  |  |  |  |
| FF800C04       | 04                                                                                          | 00             | PIT1 PCDDR | Port C Data Direction Register  |  |  |  |  |  |
| FF800C05       | 05                                                                                          | 00             | PIT1 PIVR  | Port Interrupt Vector Register  |  |  |  |  |  |
| FF800C06       | 06                                                                                          | 00             | PIT1 PACR  | Port A Control Register         |  |  |  |  |  |
| FF800C07       | 07                                                                                          | 00             | PIT1 PBCR  | Port B Control Register         |  |  |  |  |  |
| FF800C08       | 08                                                                                          |                | PIT1 PADR  | Port A Data Register            |  |  |  |  |  |
| FF800C09       | 09                                                                                          |                | PIT1 PBDR  | Port B Data Register            |  |  |  |  |  |
| FF800C0A       | 0A                                                                                          |                | PIT1 PAAR  | Port A Alternate Register       |  |  |  |  |  |
| FF800C0B       | OB                                                                                          |                | PIT1 PBAR  | Port B Alternate Register       |  |  |  |  |  |
| FF800C0C       | 00                                                                                          |                | PIT1 PCDR  | Port C Data Register            |  |  |  |  |  |
| FF800C0D       | 0D                                                                                          |                | PIT1 PSR   | Port Status Register            |  |  |  |  |  |
| FF800C10       | 10                                                                                          | 00             | PIT1 TCR   | Timer Control Register          |  |  |  |  |  |
| FF800C11       | 11                                                                                          | OF             | PIT1 TIVR  | Timer Interrupt Vector Register |  |  |  |  |  |
| FF800C12       | 12                                                                                          |                | PIT1 CPR   | Counter Preload Register        |  |  |  |  |  |
| FF800C13       | 13                                                                                          |                | 11         | n                               |  |  |  |  |  |
| FF800C14       | 14                                                                                          |                | 18         | n .                             |  |  |  |  |  |
| FF800C15       | 15                                                                                          |                | **         | n                               |  |  |  |  |  |
| FF800C16       | 16                                                                                          |                | PIT1 CNTR  | Count Register                  |  |  |  |  |  |
| FF800C17       | 17                                                                                          |                | 17         | u                               |  |  |  |  |  |
| FF800C18       | 18                                                                                          |                | 98         | n                               |  |  |  |  |  |
| FF800C19       | 19                                                                                          |                | 11         | 11                              |  |  |  |  |  |
| FF800C1A       | 1A                                                                                          | 00             | PIT1 TSR   | Timer Status Register           |  |  |  |  |  |

#### PI/T2 Register Layout

| Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 0E00<br>Default Name: PI_T2 |               |                |            |                                 |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|---------------|----------------|------------|---------------------------------|--|--|--|--|--|
| Address<br>HEX                                                                              | Offset<br>HEX | Reset<br>Value | Label      | Description                     |  |  |  |  |  |
| FF800E00                                                                                    | 00            | 00             | PIT2 PGCR  | Port General Control Register   |  |  |  |  |  |
| FF800E01                                                                                    | 01            | 00             | PIT2 PSRR  | Port Service Request Register   |  |  |  |  |  |
| FF800E02                                                                                    | 02            | 00             | PIT2 PADDR | Port A Data Direction Register  |  |  |  |  |  |
| FF800E03                                                                                    | 03            | 00             | PIT2 PBDDR | Port B Data Direction Register  |  |  |  |  |  |
| FF800E04                                                                                    | 04            | 00             | PIT2 PCDDR | Port C Data Direction Register  |  |  |  |  |  |
| FF800E05                                                                                    | 05            | 00             | PIT2 PIVR  | Port Interrupt Vector Register  |  |  |  |  |  |
| FF800E06                                                                                    | 06            | 00             | PIT2 PACR  | Port A Control Register         |  |  |  |  |  |
| FF800E07                                                                                    | 07            | 00             | PIT2 PBCR  | Port B Control Register         |  |  |  |  |  |
| FF800E08                                                                                    | 08            |                | PIT2 PADR  | Port A Data Register            |  |  |  |  |  |
| FF800E09                                                                                    | 09            |                | PIT2 PBDR  | Port B Data Register            |  |  |  |  |  |
| FF800E0A                                                                                    | 0A            |                | PIT2 PAAR  | Port A Alternate Register       |  |  |  |  |  |
| FF800E0B                                                                                    | 0B            |                | PIT2 PBAR  | Port B Alternate Register       |  |  |  |  |  |
| FF800E0C                                                                                    | OC            |                | PIT2 PCDR  | Port C Data Register            |  |  |  |  |  |
| FF800E0D                                                                                    | 0D            |                | PIT2 PSR   | Port Status Register            |  |  |  |  |  |
| FF800E10                                                                                    | 10            | 00             | PIT2 TCR   | Timer Control Register          |  |  |  |  |  |
| FF800E11                                                                                    | 11            | OF             | PIT2 TIVR  | Timer Interrupt Vector Register |  |  |  |  |  |
| FF800E12                                                                                    | 12            |                | PIT2 CPR   | Counter Preload Register        |  |  |  |  |  |
| FF800E13                                                                                    | 13            |                | "          | "                               |  |  |  |  |  |
| FF800E14                                                                                    | 14            |                | "          | "                               |  |  |  |  |  |
| FF800E15                                                                                    | 15            |                | н          | п                               |  |  |  |  |  |
| FF800E16                                                                                    | 16            |                | PIT2 CNTR  | Count Register                  |  |  |  |  |  |
| FF800E17                                                                                    | 17            |                | "          |                                 |  |  |  |  |  |
| FF800E18                                                                                    | 18            |                | "          | "                               |  |  |  |  |  |
| FF800E19                                                                                    | 19            |                | "          |                                 |  |  |  |  |  |
| FF800E1A                                                                                    | 1A            | 00             | PIT2 TSR   | Timer Status Register           |  |  |  |  |  |

### **RTC Register Layout**

| Default I/O Base Address: \$FF80 0000<br>Default Offset: \$0000 3000<br>Default Name: RTC |        |          |                                  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------|--------|----------|----------------------------------|--|--|--|--|--|
| Address HEX                                                                               | Offset | Label    | Description                      |  |  |  |  |  |
| FF803000                                                                                  | 00     | RTC1SEC  | 1 Second Digit Register          |  |  |  |  |  |
| FF803001                                                                                  | 01     | RTC10SEC | 10 Second Digit Register         |  |  |  |  |  |
| FF803002                                                                                  | 02     | RTC1MIN  | 1 Minute Digit Register          |  |  |  |  |  |
| FF803003                                                                                  | 03     | RTC10MIN | 10 Minute Digit Register         |  |  |  |  |  |
| FF803004                                                                                  | 04     | RTC1HR   | 1 Hour Digit Register            |  |  |  |  |  |
| FF803005                                                                                  | 05     | RTC10HR  | PM/AM and 10 Hour Digit Register |  |  |  |  |  |
| FF803006                                                                                  | 06     | RTC1DAY  | 1 Day Digit Register             |  |  |  |  |  |
| FF803007                                                                                  | 07     | RTC10DAY | 10 Day Digit Register            |  |  |  |  |  |
| FF803008                                                                                  | 08     | RTC1MON  | 1 Month Digit Register           |  |  |  |  |  |
| FF803009                                                                                  | 09     | RTC10MON | 10 Month Digit Register          |  |  |  |  |  |
| FF80300A                                                                                  | 0A     | RTC1YR   | 1 Year Digit Register            |  |  |  |  |  |
| FF80300B                                                                                  | OB     | RTC10YR  | 10 Year Digit Register           |  |  |  |  |  |
| FF80300C                                                                                  | 00     | RTCWEEK  | Week Register                    |  |  |  |  |  |
| FF80300D                                                                                  | 0D     | RTCCOND  | Control Register D               |  |  |  |  |  |
| FF80300E                                                                                  | OE     | RTCCONE  | Control Register E               |  |  |  |  |  |
| FF80300F                                                                                  | OF     | RTCCONF  | Control Register F               |  |  |  |  |  |

This page was intentionally left blank

# **APPENDIX D**

#### PIN ASSIGNMENTS OF THE EPROM SOCKETS

#### Pin Assignment for EPROM Area

| ·   |       |      |
|-----|-------|------|
| 2   |       | 2    |
| 7   |       | 7    |
| 1   |       | 1    |
| D   |       | D    |
| VPP | 1 40  | vcc  |
| CE  | 2 39  | PGM  |
| D15 | 3 38  | NC   |
| D14 | 4 37  | A15  |
| D13 | 5 36  | A14  |
| D12 | 6 35  | A13  |
| D11 | 7 34  | A12  |
| D10 | 8 33  | A11  |
| D9  | 9 32  | A 10 |
| D8  |       | A9   |
| GND | 11 30 | GND  |
| D7  | 12 29 | A8   |
| D6  | 13 28 | Α7   |
| D5  | 14 27 | A6   |
| D4  | 15 26 | A5   |
| DЗ  | 16 25 | A4   |
| D2  | 17 24 | EΑ   |
| D1  | 18 23 | A2   |
| DO  | 19 22 | A1   |
| OE  | 20 21 | AD   |

This page was intentionally left blank

# APPENDIX E

#### CIRCUIT SCHEMATICS OF CPU BOARD

This page was intentionally left blank







.

















| <u>}</u> | Α                      | В                        | I                                |            | С             |                                  | D                        | {        |
|----------|------------------------|--------------------------|----------------------------------|------------|---------------|----------------------------------|--------------------------|----------|
|          | 6,15 WDP2C(1:32)       |                          |                                  |            |               |                                  |                          |          |
|          | DVWE(0: 31)<br>9, 11   | DVWE(0:31)               | DI                               | MEL 0: 311 |               |                                  | ļ                        |          |
|          | AVWE(1:31)             | AVUE(1: 31)              |                                  | AVHE[1:31] |               |                                  | 1                        |          |
|          | 6,15 HDP2A(1: 32)      |                          |                                  |            |               |                                  |                          |          |
|          | 9 BRVWE( 0: 3)         |                          | <b>-</b>                         |            |               |                                  |                          |          |
| 1        |                        |                          |                                  |            |               |                                  |                          | 1        |
|          |                        |                          |                                  |            |               |                                  |                          |          |
|          |                        |                          |                                  | 1          |               |                                  |                          |          |
|          |                        |                          |                                  | 1          |               | 11                               |                          |          |
|          |                        |                          |                                  | 1          |               |                                  |                          |          |
|          |                        |                          |                                  |            |               |                                  |                          |          |
| 1        | 9 ACFLYVE              |                          |                                  | 1          |               | 11                               |                          |          |
|          | P1                     |                          |                                  |            | P2            | 11                               |                          | F        |
|          | CAL DYNED              | BBSYYWE DB1              | GCI DYWEB                        |            | CHA1 NOP2A1   |                                  | C1 MDP2C1                |          |
| 1        | A2 DYWE1               | BCLRVWE EB2              | C2 DYMER                         | 1          | A2 NDP2A2     | G-82                             | GC2 NDP2C2               |          |
|          | GA3 DYWE2              | ACELYME 03               | GC3 DYMEIO                       | 1          | AJ NOP2AJ     | 083                              | C3 NOP2C3                | 1        |
|          | G A4 DVWE3             | GB+ BGINO                | GG DYNEI1                        | 1          | GA4NDP2A4     | B4 AVWE24                        | GC4 NDP2C4               |          |
|          | □ <u>A5</u> D¥₩E4      | BS BGOUTO                | GC5 DYNE12                       | 1          | A5 NDP2A5     | B5 AVWE 25                       | C5 NDP2C5                |          |
|          | G Å¢D∀₩E.5             | B6 BGINI                 | C6 DYMEL3                        |            | A6 NDP 2 A6   | B6 AVWE 26                       | G6 MDP2C6                |          |
|          | G <sup>A7</sup> DY₩€6  |                          | G <sup>C7</sup> DYNE14           |            |               | B7 AVWE 27                       | C7 NOP2C7                |          |
|          | G <u>A8</u> D¥WE7      | Be BGIN2                 | C8 DYNE15                        |            | A8            |                                  | C8 MDP2C8                |          |
|          | - 49 10                | DB9 BGOUT2               |                                  |            | 13-10 NOP2AS  | B9 AVWE 29                       |                          |          |
|          |                        |                          |                                  |            |               |                                  | GC10 WDP2C10             |          |
|          |                        | B10 BGIN3                |                                  |            |               |                                  |                          |          |
|          |                        | BIL BOUTS                | CIA DERRYWE                      |            | C-A11 NDP2A11 | ⊷ .                              | G11 WDP2C11              |          |
|          |                        | B12 BRVWEO               | GC12 RESETVINE                   |            | ALZ NOP2ALZ   | G <sup>B12</sup>                 | C12 MDP2C12              | -        |
|          |                        | BIJ BRVWEI               | CI3 LWDVWE                       | <b></b>    | A13           | G <mark>813</mark> ► ≩           | GC13 MDP2C13             |          |
| 1        |                        | BRVWE2                   | CI 4 ANYWES                      | <b>1</b>   | CALA NOP2ALA  | BI4 DYNEIB                       | GC14 NDP2C14             |          |
|          |                        | DB15 BRVWEJ              | CI 5 AYME 23                     | 1          | A15 NDP2A15   | CHIS DYMEIZ                      | C15 MDP2C15              |          |
|          | 9, 10 DTACKYME A16     | BIG ANYMED               | C18AVME22                        | -          | GALS MOPZALS  | C-816DYME18                      | GC16 MDP2C16             |          |
|          |                        | [] <sup>017</sup> ANYWE1 | C1 7 AVME 21                     | 4          | GA17WDP2A17   | C-017 DYME19                     | GC17 NDP2C17             |          |
|          |                        | GB18 AWYWE2              |                                  |            | A18 MOP2ALB   | G818 DYME20                      | CI8 MDP2C18              |          |
|          |                        | DELO AMYMES              | CI9 AVWE19                       |            | CALS NDP2ALS  | B19 DYME21                       | C19 WDP2C19              |          |
|          | 10AXYWEA20             | ⊡ <sup>820</sup>         | GC20 AYME18                      | -4         | A20 NDP2A20   | DYME 22                          | GC20 MDP2C20             |          |
| 1        |                        |                          | C21 AVWE17                       |            | A21 MDP2A21   | B21 DYME23                       | G <sup>C21</sup> MDP2C21 |          |
|          |                        | □ 822                    | GC22 AVME16                      | 4          | A22 MDP2A22   | G <sup>\$22</sup>                | G22 KOP2C22              |          |
|          | 10 AMVME4 A23          | [ <del>] 823  </del> ह   | GC23 AVME15                      |            | A23 MDP2A23   | DYME24                           | C23 NDP2C23              |          |
|          | AVNE7                  | B24 IRQVMET              | GC24 AYNE14                      |            | A24 NDP2A24   | B24 DYME25                       | GC24 NDP2C24             |          |
|          | A25 AYMES              |                          | GC23 AVME1 3                     |            | A25 NDP 2A25  | 325 DYME26                       | G C25 MDP 2C25           | 1        |
| ٦        | A26AYNE5               |                          | C26 AVME12                       |            | A26 WDP2A26   | DYME 27                          | GC28 MDP2C26             | t        |
|          | G-A27 AYME 4           |                          | GC27 AYNE11                      |            | A27 NDP 2A27  | 327 DYME 28                      | GC27 MDP2C27             | ļ        |
| 1        | CJA28 AYMEJ            |                          | C2B AYMELD                       |            | A28 NDP2A28   | B28DYME29                        | C28 MDP2C28              |          |
|          | G <sup>A29</sup> AYME2 |                          | C29 AVMER                        |            | A29 NDP2A29   | B29 DYME30                       | GC29 MDP2C29             |          |
| 1        | G-A30 AVME1            | B30 IRQVME1              | GC30 AVMER                       |            | A30 NDP2A30   | B30 DAME 21                      | GC30 WDP2C30             |          |
|          | G_A31                  |                          | <del>] [] []</del> []]           |            | G A31NDP2A31  | <u>عامل الاه</u>                 |                          |          |
|          | G-412                  | - B32                    | G-C32                            |            | A32 HOP2A32   | G-A32 → Ž                        | G G32 MDP2G32            |          |
|          | <b>₩</b>               |                          |                                  |            | G             | 4                                | <u>L</u>                 |          |
|          | +5V 2                  | +5V IS                   | CC                               |            |               |                                  |                          |          |
|          | 1 IRQVWE(1:7)          |                          |                                  | V SER      |               | DATE MADE                        |                          | <b>T</b> |
|          | Ļ                      | $\downarrow$             |                                  |            |               | DATE NAME<br>APR. 24. 91 SK. AS. | SYS68K/CPU-40            | REV. 2   |
|          |                        |                          |                                  |            |               |                                  | 31300K/0F0-40            | 1        |
|          | - 1<br>- 15            | 51.4<br>1.4              | 10<br>10<br>10<br>10<br>10<br>10 | 21000      |               | EOBOE                            |                          | SHEET 1  |
|          | e -                    |                          |                                  |            |               | FORCE<br>COMPUTERS               | VME CONNECTORs           | FROM 18  |
|          | <u>A</u>               | B                        |                                  |            | C             | CUMPUTERS                        |                          | SHEETS   |





| GA25M0P2A28     G25M0P2C28     G223M0P2C27       GA26M0P2C30     G26M0P2A30     G27M0P2A31       GA27M0P2C31     G28M0P2C32     G27M0P2C32       GA28M0P2C31     G28M0P2C32     G28G22       GA28M0P2C31     G28G23     G28G23       GA30     G28G23     G28G23       GA30     G28G30     G28G23       GA00     G28G30     G28G30       GA10     G10     G28       GA10     G10     G10 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| APR. 24. 91 SK. AS. SYS68K/CPU-40 REV.                                                                                                                                                                                                                                                                                                                                                  |





.

·



.

E.1 Circuit Schematics of DRM-01

This page was intentionally left blank



.











| <u>۲</u> | Α            |   | В              |     | C                |   |                                | D             |                  |
|----------|--------------|---|----------------|-----|------------------|---|--------------------------------|---------------|------------------|
|          |              |   |                |     |                  |   |                                |               |                  |
|          |              |   |                |     |                  |   |                                |               |                  |
|          | BCLD( 0: 7)  | T | CLKCY          | ٨   | DPIUU            | 8 | RAMTP                          | C             |                  |
|          | PCLD( 0: 3)  | т | CLKRP          | ٨   | DPIUM            | B | BURST                          | C             |                  |
|          | RASUU        | т | CYC[ 00: 05]   | ٨   | DPILM            | 8 | PARIT                          | C             |                  |
|          | RASUM        | T | TSCPU          | ٨   | DPILL            | В | MCDOO                          | С             |                  |
|          | RASLM        | T | T AR AM        | A   | DPOUU            | В | MCD01                          | c             |                  |
|          | RASLL        | T | TEARM          | A   | DPOUM            | B | MCD02                          | C             |                  |
|          | ARME 00: 12] | T | RARUU          | ٨   | DPOLM            | В | POWRU                          | C             |                  |
|          | RDSUU        | Т | RARUM          | ٨   | DPOLL            | B | TBIRM                          | C             |                  |
|          | RDSLL        | Т | RARLM          | A   | ACP[ 00: 31 ]    | B | TAECP                          | C             |                  |
| 4        | CASUU        | T | RARLL          | A   | DCP[ 00: 31 ]    | B | REFPL                          | С             |                  |
|          | CASUM        | T | ADDSL          | ٨   | SICPO            | B | WUUCL                          | C             |                  |
|          | CASLM        | Т | KIRAS          | ٨   | SICPI            | B | WUNCL                          | C             |                  |
| 1        | CASLL        | т | SERAS          | A . | RDINV            | 8 | WL MCL                         | C             |                  |
| ļ        |              |   | KICAS          | A . | RDBUF            | B | WLLCL                          | C             |                  |
|          |              |   | ENCAS          | A   | MICPU            | 8 | ELWUL                          | C             |                  |
| 1        |              |   | SECAS          | *   | 1 ABOT           | 8 | KIREF                          | C             |                  |
|          |              |   | ARC02          | A . | RESCY            | B | REFEN                          | C             |                  |
|          |              |   | ARCO5<br>Arco7 | A A | R A MSL<br>REFSL | 8 | ELRUU                          | C             |                  |
| }        |              |   | ARC09          | A A | RAMSD            | B | ELRUM                          | C             |                  |
|          |              |   | ARCI 1         | A . | REFSD            | B | ELRLM<br>Elrll                 | C<br>C        |                  |
|          |              |   | ARC1 3         | A . | CBREN            | B | BEREN                          | c             |                  |
|          |              |   | ARC1 5         | ^   | SEDAL            | 8 | RESCF                          | C             |                  |
|          |              |   | ARC17          | Å   | TAREN            | 8 | RESLO                          | C             |                  |
|          |              |   | ARC19          | Å   | SEADD            | B | GA2RM                          | C             |                  |
|          |              |   | ARC21          | Å   | REFRQ            | 8 | UN2NM                          | U             |                  |
|          |              |   | ARC23          | A   | REFFF            | B |                                |               |                  |
|          |              |   | ARC25          | Α   | DALEN            | B |                                |               |                  |
|          |              |   | ARR03          | Å   | DRME 00: 31 ]    | B |                                |               |                  |
|          |              |   | ARR04          | ٨   | DPGUU            | B |                                |               |                  |
|          |              |   | ARR06          | ٨   | DPGUM            | B |                                |               |                  |
|          |              |   | ARROB          | ٨   | DPGLM            | B |                                |               |                  |
|          |              |   | ARR1 0         | ٨   | DPGLL            | 8 |                                |               |                  |
|          |              |   | ARR12          | ٨   | RDLAT            | 8 |                                |               |                  |
|          |              |   | ARR1 4         | *   |                  |   |                                |               |                  |
|          |              |   | ARR16          | A   |                  |   |                                |               |                  |
|          |              |   | ARR1 8         | ٨   |                  |   |                                |               |                  |
|          |              |   | ARR 20         | A   |                  |   |                                |               |                  |
|          |              |   | ARR22          | A   |                  |   |                                |               |                  |
|          |              |   | ARR24          | ٨   |                  |   |                                |               |                  |
|          |              |   | RDRUU          | Å   |                  |   |                                |               |                  |
|          |              |   | RDRLL          | ٨   |                  |   |                                |               |                  |
|          |              |   | RDPUU          | A   |                  |   |                                |               |                  |
|          |              |   | RDPLL          | A   |                  |   |                                |               |                  |
|          |              |   | ARXNN          | ٨   |                  |   |                                |               |                  |
|          |              |   | ARX09          | ٨   |                  |   | DATE NAME<br>NOV. 13. 90 S. K. | SYS68K/DRM-01 | REV.             |
|          |              |   | ARX1 0         | A   |                  |   |                                | 51500K/DKM-01 |                  |
|          |              |   | LACTA          | A   |                  |   | FORCE                          |               | SHEET 7          |
| J        | Α            |   | В              |     | C                |   | FORCE<br>COMPUTERS             | LAYOUT LEVEL  | FROM B<br>SHEETS |



.

.

E.2 Circuit Schematics of SRM-01

This page was intentionally left blank



a a construction of the construction of

| \       | Α                                                     | В С                                    | D                                                                 |
|---------|-------------------------------------------------------|----------------------------------------|-------------------------------------------------------------------|
|         | M2 A                                                  | 1.3.5 CADR(00:31) M2B                  | M2C                                                               |
|         | ۵۱ مرب الم                                            |                                        | (3 <mark>°1</mark>                                                |
|         | □^^2                                                  | E]B2                                   | G <sup>C2</sup>                                                   |
| 1       | ۸3 کې مېر کې د کې | CADR23                                 | ç₄E c3                                                            |
|         | 3, 5 RDBUF                                            | CADR24 B4                              | ž 🚽 — — — 🗗 C (                                                   |
|         | ₹ <b></b> ^۸5                                         | CADR25 EB5                             | G <sup>C5</sup>                                                   |
|         | 5 RESPDW                                              | CADROO E B6                            | G <sup>C6</sup>                                                   |
|         | □ <sup>k7</sup>                                       | CADR01E]B7                             | <sup>‡</sup> ∢€ <sup>C7</sup>                                     |
|         | 3.5 RESCOF                                            | CADR26 E BB                            | ž 🚽 ———————————————————————————————————                           |
|         | Å9                                                    | CADR27 EB9                             | G.c., IB                                                          |
|         | 3 TBIRNE A10                                          | CADR28EB10                             | ⊡ <sup>€10</sup>                                                  |
|         | 2 A1 1                                                | CADR29 E) BI 1                         | چ <b>⊣</b> Ð с1 1                                                 |
| 2       | 3 TSCPU                                               | CADR30B1 2                             | ً<br>≹ <b>⊣</b> ∃ <sup>сı 2</sup>                                 |
|         | A 1 3                                                 | CADR31 EBI 3                           | G <sup>C13</sup>                                                  |
|         | 3, 5 SIZOCPU                                          | 3, 5 BUREQ B1 4                        | G <sup>C14</sup>                                                  |
|         | τ Α1 5                                                | 5 J79-65 (B15                          | C1 5                                                              |
|         | 3, 5 SIZ1 CPU (E) A1 6                                | 5 J79-67 ( B16                         | C16                                                               |
|         | <sup>2</sup> ◀────Ð <sup>A17</sup>                    | □ <sup>B17</sup>                       |                                                                   |
|         | D A1 8                                                | □ <sup>B18</sup>                       | ←C C 1 8                                                          |
|         | 3, 5 GA2RM                                            | □ 81 9<br>D20                          | ⊖ <sup>c19</sup>                                                  |
| 3       |                                                       |                                        |                                                                   |
|         | 3 RAWSEL                                              | C <sup>82</sup> !                      |                                                                   |
|         | -                                                     | □ <sup>822</sup> .<br>□ <sup>823</sup> | G <sup>C22</sup>                                                  |
|         | 3, 5 TECPU - A23                                      | D <sup>824</sup>                       |                                                                   |
|         | 5 TACPU                                               | □ <sup>01</sup>                        | <sup>5</sup> ⊲Ð <sup>C24</sup><br>⊡ <sup>C25</sup>                |
|         | G <sup>A26</sup>                                      |                                        | G <sup>C26</sup>                                                  |
|         | 3 1ABOT                                               | □ <sup>827</sup>                       | tata                                                              |
|         | G <mark>^28</mark>                                    | D 828                                  | ž                                                                 |
|         | 3 WICPU () <sup>A29</sup>                             | □ <sup>829</sup>                       | ∃ <sup>C29</sup> <b>1</b> € 4                                     |
|         | G <sup>A30</sup>                                      | □ <sup>830</sup>                       |                                                                   |
|         | 19                                                    | _                                      |                                                                   |
|         |                                                       |                                        | DATE NAME<br>24.09.90 H.R.<br>18.01.91 H.R. SYS68K/ SRM-01 REV. 1 |
|         |                                                       |                                        |                                                                   |
| <u></u> | Α                                                     | ВСС                                    | FORCE<br>COMPUTERS CONNECTOR 2 SHEET 2<br>FROM 15<br>SHEETS       |

















.







| A                                                                              | В                                                                | C                                    |                                                           | D |
|--------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------|---|
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
| 4.6,8,10,12 DLL(00:31                                                          | 1, 6, 8, 10, 12 DLM(00: 31)                                      | 4, 7, 9, 11, 13 DUM( 00: 31)         | 4, 7, 9, 11, 13 DUU( 00: 31)                              |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
| 000 / 22 - 1 N2C - 3 -                                                         | DLLOO                                                            | CHO 20 N2G 7 DUNOO                   | CHO 22 NIC J DUUDO                                        |   |
|                                                                                | DLL01                                                            | CHO 20 120 DUM01                     | GHO                                                       |   |
| cm [ 12 [ 120] 4                                                               | DLL02                                                            | EL2(R29)1_DUN02                      | CHE 12 19 DUU02                                           |   |
| CHIEF 19 11 12 12 12 12 12 12 12 12 12 12 12 12                                | DLL03 (NJA) 1 DLM03                                              |                                      | CHO NST 18 DUUOS                                          |   |
|                                                                                | DLL04 2 R33 J DLW04                                              | end 22 10 DUM04                      | сно   28 _ нэр ] 16 DUU04                                 |   |
| CHO - 20 - ( W31 - 9                                                           | DLL05 CHO 10 HTG 17 DLM05                                        | CN0 20 12F 6 DUM05                   | 000   20 15 DUU05                                         |   |
| and 120 19                                                                     | DLL06                                                            | 040 - 20 UW06                        | CHU 20 11 DUUD6                                           |   |
| CN0 20 16                                                                      | DLL07 CHO 14 DLW07                                               | CND - 20 - 128 2 DUMO7               | eno   10 [N3L]12 DUU07                                    |   |
| CH0 - 10 - 11                                                                  | DLL15 GHO 28 N7W 13 DLM08                                        | DUMOB                                | 2 R34 1 DUU15                                             |   |
| GND - 20 N 4E 5                                                                | DLL14 ONED 20 MSE 5 DLM09                                        | CHO 20 H2R 18 DUMO9                  | eno   20 <u>NSN</u> 14 DUU14                              |   |
| GRED - 29 ( N.3H )8                                                            | DLL13 GHD 20 NJW 13 DLM10                                        | OND 20 120 17 DUMIO                  | ana 29 13 DUUI 3                                          |   |
| SHO - 10 - 12                                                                  | DLL12 GHO _ 20 N7K _11 DLM11                                     | 000 20 N2N 14 DUM11                  | CHID 10 HAC J DUUL 2                                      |   |
| CHO - 20 - 1146 - 7                                                            | DLL11 GHD 20 HAH B DLM12                                         | GHD - 70 N2W 13 DUM1 2               | 0000 20 N4F 6 DUU11                                       |   |
| CMD   10   15                                                                  | DLL10                                                            | 000 29 USI 9 DUM13                   | CHID 20 10 DUULO                                          |   |
| 000 20 <u>NJE 5</u>                                                            | DLL09 2 R41 J DLW14                                              | 000 - 20                             | 940 10 N5G 7 DUU09                                        |   |
| CHUD 10 141 9                                                                  | DLL08                                                            | CND 20 N3J 10 DUM1 5                 | 040 10 N7L 1.2 DUUDB                                      |   |
| OND 20 114A                                                                    | DLL16 0H0 28 NSC 17 DLM16                                        | OKO 20 N45 19 DUW16                  | CHO 20 KSP 16 DUU16                                       |   |
| 2 (R35)                                                                        |                                                                  | GHD 20 NAR 18 DUM17                  | Gent 10 15 DUUL 7                                         |   |
| CHED   29 ( <u>HEH</u> ).                                                      | DLL18 GHO 29 18 DLW18                                            | 040 20 14P 16 DUM18                  | MEL 12 NEL 12 DUUI8                                       |   |
| 0000 - <u>10 - 17 - 17 - 14</u>                                                | DLL19exc)_20Nex_11_DLW19                                         | CH2 10 15 DUM1 9                     | CHID   20 HSK 11 DUU19                                    |   |
| Caso   20 KéN   1 4 7                                                          | DLL20                                                            | CHIO 20 12 DUM20                     | Card 10 DUU20                                             |   |
| 000 <u>10 100 7</u>                                                            | DLL21                                                            | CHID   _ 10 _ 11 _ DUW21             | CHAD   29   NEF   6 DUU21                                 |   |
|                                                                                | DLL22 040 2 0LW22                                                | CHAP 12 15F 6 DUM22                  |                                                           |   |
| cms  -22- <u>["ISH</u> ] <sup>6</sup><br>cms  -22- <u>["ISH</u> ] <sup>6</sup> | DLL 23 000   29 10 DLW23                                         | CHO 20 10 DUM23                      | 0400 - 20 ( NEC 3 DUU23                                   |   |
| CHO   22   KGA   -                                                             | DLL31                                                            | CHO 20 NSR 18 DUW31                  | CHO   20 16 10031                                         |   |
| ₩ /                                                                            | 046 - 47 - 47 - 2 - 2 - 47 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - 2 - | 000 20 17 DUM30                      |                                                           |   |
| 8 (K37)<br>cwo   10 (K38)?                                                     | 01128 040 - 20 - 175 - 01 M27                                    | CHEC 20 17 DUM29                     |                                                           |   |
|                                                                                | DLL27                                                            | 0000   191919200028<br>8 2(R36200027 |                                                           |   |
| out []<br>out [                                                                | CHR 4/U                                                          | 040 20 15C 3 DUM26                   | end + 22 <u>N85 19 DUU27</u><br>end + 28 <u>N85 DUU27</u> |   |
|                                                                                | DLL25                                                            | CHID 20 180 4 DUM25                  | CHID   20   176 ] 7 DUU25                                 |   |
|                                                                                | DLL24 exe 22 (N7N) 14 DLN31                                      | CHO 28 NEE 5 DUM24                   | GHD 28 W71 9 DUU24                                        |   |
|                                                                                |                                                                  | www.lwec                             |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |
|                                                                                |                                                                  |                                      |                                                           |   |

В

Ľ

Α

 DATE
 NAME

 24.09.90
 H.R.

 18.01.91
 H.R.

 FORCE
 PULL

 COMPUTERS
 PULL

С



#### APPENDIX F

#### DEFAULT JUMPER SETTINGS ON THE CPU BOARD

The following are the default jumper settings and a location diagram displaying all jumpers.

#### Default Jumper Settings for the CPU

| Jumperfield | Description                                       | Default<br>Connection | Schematics |
|-------------|---------------------------------------------------|-----------------------|------------|
| В2          | Reset Voltage Sensor                              |                       | SH4<br>B4  |
| B20         | Backup Supply for Local SRAM and RTC via +5VSTDBY |                       | SH4<br>B2  |
| B1          | Backup Supply for Local SRAM and RTC via Bat 1    | 1-2                   | SH4<br>B2  |

#### Default Jumper Settings for System EPROMs and SRAM/EEPROM

| Jumperfield | Description                   | Default<br>Connection | Schematics |
|-------------|-------------------------------|-----------------------|------------|
| B11         | System EPROM device select    | 1-6                   | SH5<br>A4  |
| B16         | FLASH EPROM write dis-/enable | 1-2                   | SH4<br>C2  |

#### Default Jumper Settings for Serial I/O (RS232)

| Jumperfield | Description                               | Default<br>Connection | Schematics |
|-------------|-------------------------------------------|-----------------------|------------|
| В3          | Connector 1, PD1<br>(DUSCC1 Port #1)      | 2-15<br>8-9           | SH6<br>B2  |
| B4          | Connector 2, PD2<br>(DUSCC1 Port #2)      | 2-15<br>8-9           | SH6<br>B3  |
| B5          | Connector 1, PD1<br>(DUSCC1 Port #1)      |                       | SH6<br>C2  |
| В6          | Connector 2, PD2<br>(DUSCC Port #2)       |                       | SH6<br>C3  |
| В7          | Connector 3, PD3<br>(DUSCC2 Port #3)      | 2-15<br>8-9           | SH7<br>B2  |
| B8          | Connector 4, PD4<br>(DUSCC2 Port #4)      | 2-15<br>8-9           | SH7<br>B3  |
| В9          | Connector 3, PD3<br>(DUSCC2 Port #3), PD3 |                       | SH7<br>C2  |
| В10         | Connector 4, PD4<br>(DUSCC Port #4), PD4  |                       | SH7<br>C3  |

#### Default Jumper Settings for VMEbus

| Jumperfield | Description                                                     | Default<br>Connection    | Schematics |
|-------------|-----------------------------------------------------------------|--------------------------|------------|
| B19         | Four level Arbiter Request Level                                | 1-6<br>2-5<br>3-4        | SH9<br>B4  |
| B13         | SYSCLK<br>SYSFAIL<br>Receive VMEbus RESET<br>Drive VMEbus RESET | 1-8<br>2-7<br>3-6<br>4-5 | SH10<br>C2 |

#### Default Jumper Settings for Test

| Jumperfield | Description         | Default<br>Connection | Schematics |
|-------------|---------------------|-----------------------|------------|
| B17         | Clock Signal to CPU | 1-2                   | SH16<br>A1 |

#### Headers for 12 Bit I/O and 8 Bit I/O

| Jumperfield | Description | Default<br>Connection | Schematics |
|-------------|-------------|-----------------------|------------|
| B12         | User I/O    |                       | SH8<br>D1  |

#### Location Diagram for All Jumperfields



#### APPENDIX G

#### CONNECTOR PIN ASSIGNMENTS OF CPU BOARD

### G.1 VMEbus/P1 Pin Assignments

| PIN<br>NUMBER | ROW A<br>SIGNAL<br>MNEMONIC | ROW B<br>SIGNAL<br>MNEMONIC | ROW C<br>SIGNAL<br>MNEMONIC |
|---------------|-----------------------------|-----------------------------|-----------------------------|
| 1             | D00                         | BBSY*                       | D08                         |
| 2             | D01                         | BCLR*                       | D09                         |
| 3             | D02                         | ACFAIL*                     | D10                         |
| 4             | D03                         | BGOIN*                      | D11                         |
| 5             | D04                         | BF0OUT*                     | D12                         |
| 6             | D05                         | BG1IN*                      | D13                         |
| 7             | D06                         | BG1OUT*                     | D14                         |
| 8             | D07                         | BG2IN*                      | D15                         |
| 9             | GND                         | BG2OUT*                     | GND                         |
| 10            | SYSCLK                      | BG3IN*                      | SYSFAIL*                    |
| 11            | GND                         | BG3OUT*                     | BERR*                       |
| 12            | DS1*                        | BR0*                        | SYSRESET*                   |
| 13            | DS0*                        | BR1*                        | LWORD*                      |
| 14            | WRITE*                      | BR2*                        | AM5                         |
| 15            | GND                         | BR3*                        | A23                         |
| 16            | DTACK*                      | AMO                         | A22                         |
| 17            | GND                         | AM1                         | A21                         |
| 18            | AS*                         | AM2                         | A20                         |
| 19            | GND                         | AM3                         | A19                         |
| 20            | IACK*                       | GND                         | A18                         |
| 21            | IACKIN*                     | SERCLK(1)                   | A17                         |
| 22            | IACKOUT*                    | SERDAT*(1)                  | A16                         |
| 23            | AM4                         | GND                         | A15                         |
| 24            | AO7                         | IRQ7*                       | A14                         |
| 25            | AO6                         | IRQ6*                       | A13                         |
| 26            | A05                         | IRQ5*                       | A12                         |
| 27            | A04                         | IRQ4*                       | A11                         |
| 28            | A03                         | IRQ3*                       | A10                         |
| 29            | A02                         | IRQ2*                       | A09                         |
| 30            | A01                         | IRQ1*                       | A08                         |
| 31            | -12V                        | + 5VSTDBY                   | + 12V                       |
| 32            | +5V                         | + 5V                        | + 5V                        |

#### G.2 VMEbus/P2 Pin Assignments

| PIN<br>NUMBER                                                                                                                                                                                        | ROW A<br>SIGNAL<br>MNEMONIC | ROW B<br>SIGNAL<br>MNEMONIC | ROW C<br>SIGNAL<br>MNEMONIC |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------|-----------------------------|
| 1                                                                                                                                                                                                    | x                           | + 5V                        | х                           |
|                                                                                                                                                                                                      | x                           | GND                         | х                           |
| 3                                                                                                                                                                                                    | X                           | RESERVED                    | x                           |
| 2<br>3<br>4                                                                                                                                                                                          | X                           | A24                         | X                           |
| 5                                                                                                                                                                                                    | x                           | A25                         | x                           |
| 5                                                                                                                                                                                                    |                             | A25                         | ~                           |
| 6                                                                                                                                                                                                    | X                           | A26                         | Х                           |
| 7                                                                                                                                                                                                    | x                           | A27                         | х                           |
| 8                                                                                                                                                                                                    | x                           | A28                         | x                           |
| 9                                                                                                                                                                                                    | x                           | A29                         | х                           |
| 10                                                                                                                                                                                                   | x x                         | A30                         | х                           |
|                                                                                                                                                                                                      |                             |                             |                             |
| 11                                                                                                                                                                                                   | x                           | A31                         | х                           |
| 12                                                                                                                                                                                                   | X X                         | GND                         | х                           |
| 13                                                                                                                                                                                                   | X X                         | + 5V                        | х                           |
| 14                                                                                                                                                                                                   | x                           | D16                         | х                           |
| 15                                                                                                                                                                                                   | X                           | D17                         | Х                           |
| 10                                                                                                                                                                                                   |                             | D10                         | v                           |
| 16                                                                                                                                                                                                   | X                           | D18                         | Х                           |
| 17                                                                                                                                                                                                   | X                           | D19                         | X                           |
| 18                                                                                                                                                                                                   | X                           | D20                         | X                           |
| 19                                                                                                                                                                                                   | X                           | D21                         | Х                           |
| 20                                                                                                                                                                                                   | X                           | D22                         | Х                           |
| 21                                                                                                                                                                                                   | x                           | D23                         | х                           |
| 22                                                                                                                                                                                                   | x                           | GND                         | X                           |
| 23                                                                                                                                                                                                   | X                           | D24                         | X                           |
| 24                                                                                                                                                                                                   | X                           | D25                         | X                           |
| 25                                                                                                                                                                                                   | x                           | D26                         | X                           |
| 20                                                                                                                                                                                                   |                             |                             | ~                           |
| 26                                                                                                                                                                                                   | x                           | D27                         | Х                           |
| 27                                                                                                                                                                                                   | x x                         | D28                         | X                           |
| 28                                                                                                                                                                                                   | x x                         | D29                         | X                           |
| 29                                                                                                                                                                                                   | Y Y                         | D30                         | Y                           |
| 30                                                                                                                                                                                                   | Y Y                         | D31                         | Y                           |
| 50                                                                                                                                                                                                   |                             |                             | 1                           |
| 31                                                                                                                                                                                                   | Y                           | GND                         | Y                           |
| 32                                                                                                                                                                                                   | Y                           | + 5V                        | Y                           |
| <ul> <li>X: EAGLE Module dependent</li> <li>Y: EAGLE Module dependent or serial I/O interface if these pins are not used by an EAGLE module and the solder bridge field b22 is assembled.</li> </ul> |                             |                             |                             |

#### **APPENDIX H**

#### GLOSSARY OF VME/1014 TERMS

#### A16

A type of module that provides or decodes an address on address line A01 through A15.

#### A24

A type of module that provides or decodes an address on address lines A01 through A23.

#### A32

A type of module that provides or decodes an address on address lines A01 through A31.

#### **ADDRESS-ONLY CYCLE**

A DTB cycle that consists of an address broadcast, but no data transfer. SLAVES do not acknowledge ADDRESS-ONLY cycles and MASTERS terminate the cycle without waiting for an acknowledgment.

#### ARBITER

A functional module that accepts bus requests from REQUESTOR modules and grants control of the DTB to one REQUESTOR at a time.

#### ARBITRATION

The process of assigning control of the DTB to a REQUESTOR.

### **ARBITRATION BUS**

One of the four buses provided by the 1014 backplane. This bus allows an ARBITER module and several REQUESTOR modules to coordinate use of the DTB.

### **ARBITRATION CYCLE**

An ARBITRATION CYCLE begins when the ARBITER senses a bus request. The ARBITER grants the bus to a REQUESTOR, which signals that the DTB is busy. The REQUESTOR terminates the cycle by taking away the bus busy signal which causes the ARBITER to sample the bus requests again.

### BACKPLANE (1014)

A printed circuit (PC) board with 96-pin connectors and signal paths that bus the connector pins. Some 1014 systems have a single PC board, called the J1 backplane. It provides the signal paths needed for basic operation. Other 1014 systems also have an optional second PC board called a J2 backplane. It provides the additional 96-pin connectors and signal paths needed for wider data and address transfers. Still others have a single PC board that provides the signal conductors and connectors of both the J1 and J2 backplanes.

### **BACKPLANE INTERFACE LOGIC**

Special interface logic that takes into account the characteristics of the backplane: its signal line impedance, propagation time, termination values, etc. The 1014 specification prescribes certain rules for the design of this logic based on the maximum length of the backplane and its maximum number of board slots.

### **BLOCK READ CYCLE**

A DTB cycle used to transfer a block of 1 to 256 bytes from a SLAVE to a MASTER. This transfer is done using a string of 1, 2, or 4 byte data transfers. Once the block transfer is started, the MASTER does not release the DTB until all of the bytes have been transferred. It differs from a string of read cycles in that the MASTER broadcasts only one address and address modifier (at the beginning of the cycle). Then the SLAVE increments this address on each transfer; the data for the next cycle is retrieved from the next higher location.

### **BLOCK WRITE CYCLE**

A DTB cycle used to transfer a block of 1 to 256 bytes from a MASTER to a SLAVE. The block write cycle is very similar to the block read cycle. It uses a string of 1, 2, or 4 byte data transfers and the MASTER does not release the DTB until all of the bytes have been transferred. It differs from a string of write cycles in that the MASTER broadcasts only one address and address modifier (at the beginning of the cycle). Then the SLAVE increments this address on each transfer so that the next transfer is stored on the next higher location.

### BOARD

A printed circuit (PC) board, its collection or electronic components, and either one or two 96-pin connectors that can be plugged into 1014 backplane connectors.

### **BUS TIMER**

A functional module that measures how long each data transfer takes on the DTB, and terminates the DTB cycle if a transfer takes too long. If the MASTER tries to transfer data to or from a nonexistent SLAVE location, it might wait forever. The BUS TIMER prevents this by terminating the cycle.

### D08(0)

A SLAVE that sends and receives data 8 bits at a time over D00-D07, or an INTERRUPT HANDLER that receives 8 bit STATUS/IDs over D00-D07, or an INTERRUPTER that sends 8 bit STATUS/IDs over D00-D07.

### D08(E0)

A MASTER that sends or receives data 8 bits at a time over either D00-D07 or D08-D15, or A SLAVE that sends and receives data 8 bits at a time over either D00-D07 or D08-D15, or an INTERRUPT HANDLER that receives 8 bit STATUS/IDs over D00-D07, or an INTERRUPTER that sends 8 bit STATUS/IDs over D00-D07.

#### D16

A MASTER that sends and receives data 16 bits at a time over D00-D15, or A SLAVE that sends and receives data 16 bits at a time over D00-D15, or an INTERRUPT HANDLER that receives 16 bit STATUS/IDs over D00-D15, or an INTERRUPTER that sends 16 bit STATUS/IDs over D00-D15.

### D32

A MASTER that sends and receives data 32 bits at a time over D00-D31, or A SLAVE that sends and receives data 32 bits at a time over D00-D31, or an INTERRUPT HANDLER that receives 32 bit STATUS/IDs over D00-D31, or an INTERRUPTER that sends 32 bit STATUS/IDs over D00-D31.

#### DAISY CHAIN

A special type of 1014 signal line that is used to propagate a signal level from board to board, starting with the first slot and ending with the last slot. There are four bus grant daisy chains and one interrupt acknowledge daisy chain on the 1014.

#### **DATA TRANSFER BUS**

One of the four buses provided by the 1014 backplane. The DATA TRANSFER BUS allows MASTERS to direct the transfer of binary data between themselves and SLAVES. (DATA TRANSFER BUS is often abbreviated to DTB).

#### DATA TRANSFER BUS CYCLE

A sequence of level transitions on the signal lines of the DTB that result in the transfer of an address or an address and data between a MASTER and a SLAVE. There are seven types of data transfer bus cycles.

#### DTB

An acronym for DATA TRANSFER BUS.

#### **FUNCTIONAL MODULE**

A collection of electronic circuitry that resides on one 1014 board and works together to accomplish a task.

### **IACK DAISY CHAIN DRIVER**

A functional module which activates the interrupt acknowledge daisy chain whenever an INTERRUPT HANDLER acknowledges an interrupt request. This daisy chain ensures that only one INTERRUPTER will respond with its STATUS/ID when more than one has generated an interrupt request.

### INTERRUPT ACKNOWLEDGE CYCLE

A DTB cycle, initiated by an INTERRUPT HANDLER that reads a "STATUS/ID" from an INTERRUPTER. An INTERRUPT HANDLER generates this cycle when it detects an interrupt request from an INTERRUPTER and it has control of the DTB.

#### **INTERRUPT BUS**

One of the four buses provided by the 1014 backplane. The INTERRUPT BUS allows INTERRUPTER modules to send interrupt requests to INTERRUPT HANDLER modules.

#### INTERRUPTER

A functional module that generates an interrupt request on the INTERRUPT BUS and then provides STATUS/ID information when the INTERRUPT HANDLER requests it.

#### **INTERRUPT HANDLER**

A functional module that detects interrupt requests generated by INTERRUPTERS and responds to those requests by asking for STATUS/ID information.

### LOCATION MONITOR

A functional module that monitors data transfers over the DTB in order to detect accesses to the locations it has been assigned to watch. When an access occurs to one of these assigned locations, the LOCATION MONITOR generates an on-board signal.

#### MASTER

A functional module that initiates DTB cycles in order to transfer data between itself and a SLAVE module.

#### OBO

A SLAVE that sends and receives data 8 bits at a time over D00-D07.

#### POWER MONITOR MODULE

A functional module that monitors the status of the primary power source to the 1014 system and signals when that power has strayed outside the limits required for reliable system operation. Since most systems are powered by an AC source, the power monitor is typically designed to detect drop-out or brown-out conditions on AC lines.

#### **READ CYCLE**

A DTB cycle used to transfer 1, 2, or 4 bytes from a SLAVE to a MASTER. The cycle begins when the MASTER broadcasts and address and an address modifier. Each SLAVE captures this address and address modifier, and checks to see if it is to respond to the cycle. If so, it retrieves the data from its internal storage, places it on the data bus, and acknowledges the transfer. Then the MASTER terminates the cycle.

#### **READ-MODIFY-WRITE CYCLE**

A DTB cycle that is used to both read from, and write to a SLAVE location without permitting any other MASTER to access that location. This cycle is most useful in multiprocessing systems where certain memory locations are used to control access to certain systems resources. (For example, semaphore locations.)

### REQUESTOR

A functional module that resides on the same board as a MASTER or INTERRUPT HANDLER and requests use of the DTB whenever its MASTER or INTERRUPT HANDLER needs it.

### SERIAL CLOCK DRIVER

A functional module that provides a periodic timing signal that synchronizes operation of the VMSbus. (Although the 1014 specification defines a SERIAL CLOCK DRIVER for use with the VMSbus, and although it reserves two backplane signal lines for use by that bus, the VMSbus protocol is completely independent of the 1014.)

### SLAVE

A functional module that detects DTB cycles initiated by a MASTER and, when those cycles specify their participation, transfers data between itself and the MASTER.

### SLOT

A position where a board can be inserted into a 1014 backplane. If the 1014 system has both a J1 and a J2 backplane (or a combination J1/J2 backplane) each slot provides a pair of 96-pin connectors. If the system has only a J1 backplane, then each slot provides a single 96-pin connector.

#### **SUBRACK**

A rigid framework that provides mechanical support for boards inserted into the backplane, ensuring that the connectors mate properly and that adjacent boards do not contact each other. It also guides the cooling airflow through the system, and ensures that inserted boards do not disengage themselves from the backplane due to vibration or shock.

### SYSTEM CLOCK DRIVER

A functional module that provides a 16 MHz timing signal on the UTILITY BUS.

### SYSTEM CONTROLLER BOARD

A board which resides in slot 1 of a 1014 backplane and has a SYSTEM CLOCK DRIVER, a DTB ARBITER, an IACK DAISY CHAIN DRIVER, and a BUS TIMER. Some also have a SERIAL CLOCK DRIVER, a POWER MONITOR or both.

#### UAT

A MASTER that sends or receives data in an unaligned fashion, or a SLAVE that sends and receives data in an unaligned fashion.

#### UTILITY BUS

One of the four buses provided by the 1014 backplane. This bus includes signals that provide periodic timing and coordinate the power up and power down of 1014 systems.

#### WRITE CYCLE

A DTB cycle used to transfer 1, 2, or 4 bytes from a MASTER to a SLAVE. The cycle begins when the MASTER broadcasts an address and address modifier and places data on the DTB. Each SLAVE captures this address and address modifier, and checks to see if it is to respond to the cycle. If so, it stores the data and then acknowledges the transfer. The MASTER then terminates the cycle.

#### **APPENDIX I**

#### LITERATURE REFERENCE

Please refer to the following books for further more detailed information.

- 1) MC 68040 Users Manual.
- 2) VMEbus Standards:

2618 S Shannon Tempe Arizona 85282 (602) 966-5936

#### APPENDIX J

#### PRODUCT ERROR REPORT

ALTHOUGH FORCE COMPUTERS HAS ACHIEVED A VERY HIGH STANDARD OF QUALITY IN PRODUCTS AND DOCUMENTATION, SUGGESTIONS FOR IMPROVEMENT ARE ALWAYS WELCOME.

ANY FEEDBACK YOU CARE TO OFFER WOULD BE APPRECIATED.

PLEASE USE ATTACHED "PRODUCT ERROR REPORT" FORM FOR YOUR COMMENTS AND RETURN IT TO ONE OF OUR FORCE COMPUTERS OFFICES.

FORCE COMPUTERS, GmbH

## **PRODUCT ERROR REPORT**



#### HARDWARE/SOFTWARE/SYSTEMS

| PRODUCT:                         | SERIAL NO.:             |  |
|----------------------------------|-------------------------|--|
| DATE OF PURCHASE:                | ORIGINATOR:             |  |
| COMPANY:                         | POINT OF CONTACT:       |  |
| ADDRESS:                         | TELEPHONE:              |  |
|                                  | EXT:                    |  |
|                                  |                         |  |
|                                  |                         |  |
| PRESENT DATE:                    |                         |  |
| THIS AREA TO BE COMPLETED BY FOR | CE COMPUTERS:           |  |
| DATE                             |                         |  |
| DATE:<br>PR#:                    | -                       |  |
| RESPONSIBLE DEPT.:               |                         |  |
|                                  |                         |  |
| ENGINEERING<br>MARKETING         |                         |  |
| PRODUCTION                       |                         |  |
|                                  |                         |  |
| AFFECTED PRODUCT:                | AFFECTED DOCUMENTATION: |  |
| HARDWARE                         | HARDWARE                |  |
| SOFTWARE                         | SOFTWARE                |  |
| SYSTEM                           | SYSTEM                  |  |
| ERROR DESCRIPTION:               |                         |  |
|                                  |                         |  |
|                                  |                         |  |
|                                  |                         |  |

Please send this product error report to one of our nearest FORCE COMPUTERS offices:

#### FORCE COMPUTERS Inc.

3165 Winchester Blvd. Campbell, CA 95008-6557 U. S. A.

FORCE COMPUTERS FRANCE Sarl 11, rue Casteja 92100 Boulogne France

#### FORCE COMPUTERS GmbH

Prof.-Messerschmitt-Str. 1 D - 8014 Neubiberg/Munich West Germany

Buckinghamshire HP22 6PE

England

FORCE COMPUTERS UK Ltd. No. 1 Holly Court 3 Tring Road Wendover

# **COPIES OF DATA SHEETS**

\*

# **COPIES OF DATA SHEETS**

RTC 72423

DUSCC 68562

PI/T 68230

## REAL TIME CLOCK MODULE RTC-72421/72423

The RTC-72421/72423 module is a Real Time Clock designed for use in direct bus-compatible microprocessor applications. It features a built-in guartz crystal, time and date function, and C-MOS circuity for low power consumption. The built in crystal eliminates the need for external components and allows for easy design. Three control registers provide STOP, HOLD, RESET, 30 SEC ADJUST, and INTERRUPT MASK-ING, AUTO LEAP YEAR and 24/12 HOUR formats are also provided.

#### **FEATURES**

- The built-in quartz crystal makes board design easy.
- Direct bus-compatibility (120 nsec access time)
- Address Lutch Enable INPUT terminal available for 8048, 8051 series and 8085.
- 24/12 hour clock switching function and automatic leap vear setting.
- Interrupt masking.
- 30 seconds error adjustment function.
- 18 pin dual in line plastic package. (RTC-72421)
- 24 pin SOP plastic package. (RTC-72423)
- Capable of withstanding reflow temperatures of 260°C for 20 seconds. (RTC-72423)

## ■ SPECIFICATIONS

#### Absolute Maximum Ratings

| Item                 | Symbol | Conditions            | Rating Value                           | Unit |  |
|----------------------|--------|-----------------------|----------------------------------------|------|--|
| Power Supply Voltage | VDD    | $T_a = 25^{\circ}C$   | -0.3 to 7.0                            | ۷    |  |
| Input Voltage        | ٧,     | T <sub>a</sub> =25°C  | GND = 0.3 to V <sub>DD</sub> + 0.3     | ٧    |  |
| Output Voltage       | Vo     | $T_a = 25^{\circ}C$   | GND - 0.3 to V <sub>DD</sub> + 0.3     | ٧    |  |
| Storage              |        | 72421                 | - 55 to 85                             | °C   |  |
|                      | tstg   | 72423                 | - 55 to 125                            |      |  |
| Solder Heat          |        | 72421 at the terminal | 260°C × 10sec                          |      |  |
| Resistance           | tsol   | 72423                 | 260°C × 10sec × 21<br>ar 230°C × 3mout |      |  |

#### **Operating Range**

| Item                | Symbol          | Conditions               | Value        | Unit |
|---------------------|-----------------|--------------------------|--------------|------|
| Power Supply        | V <sub>DD</sub> | in operating temperature | 4.5 to 5.5   | v    |
| Data holding        | V <sub>DH</sub> | in operating temperature | 2.0 to 5.5   | ٧    |
| Crystal Erequinency | fo              |                          | 32.768       | kHz  |
| Operating Temp      |                 | 72421                    | - 10 to + 70 | ۲    |
| oberganik (suih     | LOPR            | 72423                    | -40 to +85   |      |

#### Frequency Characteristics

| Item           | Туре           | Conditions                                     | Value       | Unit         |
|----------------|----------------|------------------------------------------------|-------------|--------------|
|                | 72421A         |                                                | ±10         |              |
| ✓ #1 Frequency | 72421B         | T,=25°C                                        | ± 50        | 1            |
| Tolerance      | 72423A         | $V_{DD} = 5V$                                  | ± 20        | ppm          |
|                | 72423B         |                                                | ± 50        | 1            |
| the bags agen  | 72421          | - : 0to + 70°C,F/F = 0 . at 25°C               | + 10/-120   | *            |
| Stability      | 72423          | - 10to + 70°C. /_F/F = 0 . at 25°C             | + 10/ - 120 | ppm          |
|                | 12423          | - 40to + 85°CF/F = 0 . at 25°C                 | + 10/ - 220 |              |
| Aging          | 72421<br>72423 | $V_{DD} = 5V. T_a = 25^{\circ}C$<br>First year | ±5          | ppm/<br>year |

\*1 The symbol of the frequency tolerance (B)±50ppm) of RTC 72423 is not marked on the parts.
\*2 Temperature Coefficient is =0.04ppm 'C<sup>2</sup>



#### **TERMINAL CONNECTION**



#### DIMENSIONS



## SEIKO EPSON CORPORATION

## Electrical Characteristics

 $*V_{DD} = 5V \pm 0.5V$ , T = -10 to 70°C (RTC-72421)/T = -40 to +85°C (RTC-72423)

| Item                  | Symbol           | Condi                                                   | tions                | MIN  | TYP | MAX    | UNIT | Remarks                                 |
|-----------------------|------------------|---------------------------------------------------------|----------------------|------|-----|--------|------|-----------------------------------------|
| H. Input Voltage      | V <sub>IH1</sub> |                                                         |                      | 2.2  |     | _      | v    | All inputs                              |
| L. Input Voltage      | VILI             |                                                         |                      |      |     | 0.8    | v    | except CS1                              |
| Input Leak 1          | I <sub>LK1</sub> | v, = v,                                                 | /01/                 | —    |     | 1/-1   |      | Inputs except Do-D3                     |
| Input Leak 2          | ILK2             | <b>v</b> <sub>1</sub> - <b>v</b> <sub>1</sub>           | 00/UV                |      | -   | 10/-10 | μA   | $D_0 - D_3$                             |
| L. Output Voltage 1   | VOLI             | 1 <sub>01</sub> = 2                                     | .5mA                 |      | —   | 0.4    | v    | 0 0                                     |
| H. Output Voltage     | V <sub>OH</sub>  | $I_{OH} = -400 \mu A$                                   |                      | 2.4  |     |        | V    | $D_0 - D_3$                             |
| L. Dutput Voltage 2   | Volz             | $I_{OL} = 2.5 \text{mA}$<br>$V_1 = V_{DD} / 0 \text{V}$ |                      |      | —   | 0.4    | ۷    | STD.P                                   |
| Off Leak Current      | IOFFLK           |                                                         |                      |      |     | 10     | μA   |                                         |
| Input Capacitance 1   | C <sub>11</sub>  | Test freg. IMHz                                         |                      | —    | 10  | —      | ·    | Inputs except Do-D3                     |
| Input Capacitance 2   | Ciz              | restree                                                 | 1. I MINZ            |      | 20  | -      | ₽F   | D <sub>0</sub> – D <sub>3</sub> , STD.P |
| Current Consumption 1 | lodi             | cc _ m                                                  | V <sub>DD</sub> = 5V |      | —   | 10     |      | V                                       |
| Current Consumption 2 | looz             | $CS_1 = 0V$                                             | V <sub>DD</sub> =2V  | —    |     | 5      | μA   | V <sub>DD</sub>                         |
| H. Input Voltage 2    | VIH2             | v _ 2                                                   |                      | ŧν₀₀ |     |        | v    | <u></u>                                 |
| L. Input Voltage 2    | VILZ             | V <sub>DD</sub> = 2                                     | ~ 5.5V               | —    | -   | ţv₀₀   |      | CS1                                     |
| Start up time         | tsoc             | T.=25°C V                                               | DD = 4.5V            |      |     | 1      | sec  | Standard pulse = 64Hz out               |

SWITCHING CHARACTERISTICS (with ALE) (Please connect ALE to  $V_{DD}$  if the microprocessor does not have an ALE OUTPUT)  $\text{*V}_{100} = 5V \pm 0.5V$ ,  $T_{*} = -10$  to 70°C (RTC-72421)/ $T_{*} = -40$  to  $+85^{\circ}$ C (RTC-72423)

| ltem                        | Symbol                 | Condition      | MIN  | MAX            | Unit |
|-----------------------------|------------------------|----------------|------|----------------|------|
| CS <sub>1</sub> Set up Time | tsuicsi)               |                | 1000 |                |      |
| Address Set up Time         | t <sub>su(a-ale)</sub> |                | 50   |                |      |
| Address Hold Time           | th(ALE-A)              |                | 50   |                |      |
| ALE Pulse Width             | tw(ALE)                |                | 80   |                |      |
| ALE Before WRITE            | tsu(ALE-W)             |                | 0    |                |      |
| ALE Before READ             | tsu(ALE-R)             |                | 0    | 1 0 1 ma ann 1 |      |
| ALE After WRITE             | t <sub>Su(W-ALE)</sub> |                | 50   |                | nsec |
| ALE After READ              | tsu(R-ALE)             |                | 50   |                |      |
| WRITE Pulse Width           | tw(w)                  |                | 120  |                |      |
| RD to Date                  | tpzv(r-q)              | $C_L = 120 pF$ |      | 120            |      |
| Data Hold                   | tpvz(R-Q)              | ·              | 0    |                |      |
| DATA Set up Time            | tsuko-w)               |                | 80   |                |      |
| DATA Hold Time              | t <sub>h(w-D)</sub>    |                | 10   |                |      |
| CS <sub>1</sub> Hold Time   | th(CS))                |                | 1000 |                |      |
| RD/WR Recovery Time         | trec(r/w)              |                | 200  |                |      |

#### • STANDBY mode



Note

- Please take precautions to prevent damage due to electric static discharge because this device uses C-MOS.
- A  $0.1\mu$ F ceramic capacitor and a 1 to  $10\mu$ F tantalum capacitor should be placed for stable operation.
- Please store the unit under normal temperature and humidity conditions because drastic temperature change may cause damage.

#### FUNCTION TABLE

| _       | ·  |            |    |    |                 |                 |                |                  |                  |          |                               |
|---------|----|------------|----|----|-----------------|-----------------|----------------|------------------|------------------|----------|-------------------------------|
| Address | •  | A2         | ^  | ۸. | Register        |                 | Da             | ata              |                  | Count    | Remarks                       |
| Add     | ~3 | <b>~</b> 2 | ~1 | ~  | Reg             | D3              | D2             | D1               | Do               | Value    | Remarks                       |
| 0       | 0  | 0          | 0  | 0  | Sı              | S8              | 5 <sub>4</sub> | Sz               | S <sub>1</sub>   | 0-9      | 1-second digit register       |
| 1       | 0  | 0          | 0  | 1  | S10             | ***             | 540            | S <sub>20</sub>  | S <sub>10</sub>  | 0-5      | 10-second digit register      |
| 2       | 0  | 0          | 1  | 0  | MI1             | mi <sub>8</sub> | mi₄            | miż              | mi <sub>1</sub>  | 0-9      | 1-minute digit register       |
| 3       | 0  | 0          | 1  | 1  | MI 10           | **              | mi₄o           | mi <sub>20</sub> | mi <sub>10</sub> | 0-5      | 10-minute digit register      |
| 4       | 0  | 1          | 0  | 0  | H1              | h <sub>8</sub>  | h4             | h <sub>2</sub>   | h,               | 0-9      | I-hour digit register         |
| 5       | 0  | I          | 0  | 1  | H10             | *               | PM/AM          | h <sub>20</sub>  | h <sub>10</sub>  | 0-20r0-1 | PM/AM, 10-hour digit register |
| 6       | 0  | ١          | 1  | 0  | D1              | d <sub>8</sub>  | d4             | d₂               | dı               | 0-9      | I-day digit register          |
| 7       | 0  | ١          | T  | 1  | D10             | ₩               | *              | d <sub>20</sub>  | d10              | 0-3      | 10-day digit register         |
| 8       | I  | 0          | 0  | 0  | MO1             | mo <sub>s</sub> | mo4            | mo <sub>2</sub>  | mo <sub>1</sub>  | 0-9      | I-month digit register        |
| 9       | ١  | 0          | 0  | 1  | MO10            | **              | *              | *                | m010             | 0-1      | 10-month digit register       |
| A       | 1  | 0          | T  | 0  | Y <sub>1</sub>  | Ув              | y4             | y <sub>2</sub>   | У1               | 0-9      | I-year digit register         |
| В       | T  | 0          | I  | I  | Y <sub>10</sub> | Уво             | y40            | y20              | y10              | 0-9      | 10-year digit register        |
| С       | 1  | Т          | 0  | 0  | w               | ₩               | W4             | W2               | w <sub>1</sub>   | 0-6      | Week register                 |
| D       | 1  | 1          | 0  | I  | Reg D           | 30sec ADJ       | IRQ FLAG       | BUSY             | HOLD             |          | Control Register D            |
| Ε       | ١  | ١          | ١  | 0  | Reg E           | t1              | t <sub>o</sub> | ITRPT/STND       | MASK             |          | Control Register E            |
| F       | 1  | Ŧ          | ۱  | I  | Reg F           | TEST            | 24/12          | STOP             | REST             |          | Control Register F            |

\*0 = "L" revel, 1 = "H" revel, REST = RESET ITRPT/STND=INTERRUPT/ STANDARD 1)Bit ≍ does not exist 5) Test must be set 0.

2) Please mask PM /AM bit with

12 hours mode 3) Busy is read only

4) • IRQ must be set1.
• Set IRQ to O after interruption.

Data Bit PM/AM ITRPT/STND 24/12

|   | PM | 11.4021 | 24 |
|---|----|---------|----|
| 0 | AM | STND    | 12 |
|   |    |         |    |

WRITE mode (with ALE)



•READ mode (with ALE)



- Standard ultrasonic cleaning may damage the quartz crystal. The manufacturer assure no responsibility for damage caused by ultrasonic cleaning.
- The specifications are subject to change without prior notice. Contact SEIKO EPSON CORP. for the instruction and application manual that describes unit operation and function in detail.

## **SEIKO EPSON GROUP**

SEIKO EPSON CORP. International Marketing Group Device Component 3-5. Owa 3-chome, Suwa-shi, Nagano-ken, 392 JAPAN Phone: (0266)52-3131 FAX: (0266)58-9861 Telex: 3362-435

MATSUSHIMA KOGYO CO., LTD. Sales Dept. 8548 Nakaminowa, Minowa-machi, Kamiina-gun, Nagano-ken, 399-46 JAPAN Phone: (0265)79-9144 (Direct) FAX: (0265)79-9492 Telex: 3364-780

MOTOROLA

## SEMICONDUCTORS

EAST KILBRIDE. SCOTLAND

## **Advance Information**

# MC68230

## PARALLEL INTERFACE/TIMER (PI/T)

DECEMBER, 1983

This document contains information on a new product. Specifications and information herein are subject to change without notice.

ADI-860-R2

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 and are registered trademarks of Motorola, Inc.

.

.

. .

## TABLE OF CONTENTS

Paragraph Number

#### Title

## Page Number

#### Section 1 Introduction

| 1.1    | Port Mode Description                   | 1-2  |
|--------|-----------------------------------------|------|
| 1.2    | Signal Description                      | 1-5  |
| 1.2.1  | Bidirectional Data Bus (D0-D7)          | 1-5  |
| 1.2.2  | Register Selects (RS1-RS5)              | 1-5  |
| 1.2.3  | Read/Write (R/ $\overline{W}$ )         | 1-6  |
| 1.2.4  | Chip Select (CS)                        | 1-6  |
| 1.2.5  | Data Transfer Acknowledge (DTACK)       | 1-7  |
| 1.2.6  | Reset (RESET)                           | 1-7  |
| 1.2.7  | Clock (CLK)                             | 1-7  |
| 1.2.8  | Port A and Port B (PA0-PA7 and PB0-PB7) | 1-7  |
| 1.2.9  | Handshake Pins (H1-H4)                  | 1-7  |
| 1.2.10 | Port C (PC0-PC7/ Alternate Function)    | 1-7  |
| 1.3    | Register Model                          | 1-8  |
| 1.4    | Bus Interface Operation                 | 1-10 |
| 1.4.1  | Read Cycles                             | 1-10 |
| 1.4.2  | Interrupt Acknowledge Cycles            | 1-11 |
| 1.4.3  | Write Cycles                            | 1-11 |

#### Section 2

#### Port General Information and Conventions

| 2.1   | Unidirectional vs Bidirectional       | 2-1 |
|-------|---------------------------------------|-----|
| 2.1.1 | Control of Double-Buffered Data Paths | 2-1 |
| 2.1.2 | Double-Buffered Input Transfers       | 2-2 |
| 2.1.3 | Double-Buffered Output Transfers      | 2-2 |
| 2.2   | Requesting Bus Master Service         | 2-4 |
| 2.2.1 | Vectored, Prioritized Port Interrupts | 2-5 |
| 2.2.2 | Autovectored Port Interrupts          | 2-5 |
| 2.2.3 | DMA Request Operation                 | 2-6 |
| 2.3   | Direct Method of Resetting Status     | 2-6 |
| 2.4   | Handshake Pin Sense Control           | 2-7 |
| 2.5   | Enabling Ports A and B                | 2-7 |
| 2.6   | Port A and B Alternate Registers      | 2-7 |

## TABLE OF CONTENTS (Continued)

Paragraph Number

Title

Page Number

#### Section 3

## Port Modes

| 3.1     | Port A Control Register                                       | 3-1  |
|---------|---------------------------------------------------------------|------|
| 3.2     | Port B Control Register                                       | 3-1  |
| 3.3     | Mode 0 – Unidirectional 8-Bit Mode                            | 3-2  |
| 3.3.1   | Submode 00 – Pin-Definable Double-Buffered Input or           |      |
|         | Single-Buffered Output                                        | 3-2  |
| 3.3.2   | Submode 01 — Pin-Definable Double-Buffered Output or          |      |
|         | Non-Latched Input                                             | 3-4  |
| 3.3.3   | Submode 1X – Bit I/O (Pin-Definable Single-Buffered Output or |      |
|         | Non-Latched Input)                                            | 3-6  |
| 3.4     | Mode 1 – Unidirectional 16-Bit Mode                           | 3-8  |
| 3.4.1   | Port A Control Register                                       | 3-9  |
| 3.4.2   | Port B Control Register                                       | 3-9  |
| 3.4.3   | Submode X0 – Pin-Definable Double-Buffered Input or           |      |
|         | Single-Buffered Output                                        | 3-9  |
| 3.4.4   | Submode X1 — Pin-Definable Double-Buffered Output or          |      |
|         | Non-Latched Input                                             | 3-12 |
| 3.5     | Mode 2 — Bidirectional 8-Bit Mode                             | 3-14 |
| 3.5.1   | Port A Bit I/O (Pin-Definable Single-Buffered Output or       |      |
|         | Non-Latched Input)                                            | 3-14 |
| 3.5.2   | Port B Double-Buffered I/O                                    | 3-14 |
| 3.5.2.1 | Double-Buffered Input Transfers                               | 3-15 |
| 3.5.2.2 | Double-Buffered Output Transfers                              | 3-15 |
| 3.6     | Mode 3 — Bidirectional 16-Bit Mode                            | 3-17 |
| 3.6.1   | Double-Buffered Input Transfers                               | 3-17 |
| 3.6.2   | Double-Buffered Output Transfers                              | 3-18 |

### Section 4

## Programmer's Model

| 4.1   | Port General Control Register (PGCR)   | 4-2 |
|-------|----------------------------------------|-----|
| 4.2   | Port Service Request Register (PSRR)   | 4-3 |
| 4.3   | Port Data Direction Registers          | 4-4 |
| 4.3.1 | Port A Data Direction Register (PADDR) | 4-4 |
| 4.3.2 | Port B Data Direction Register (PBDDR) | 4-4 |
| 4.3.3 | Port C Data Direction Register (PCDDR) | 4-4 |
| 4.4   | Port Interrupt Vector Register (PIVR)  | 4-4 |
| 4.5   | Port Control Registers (PACR, PBCR)    | 4-4 |
| 4.6   | Port Data Registers                    | 4-5 |
| 4.6.1 | Port A Data Register (PADR)            | 4-5 |
| 4.6.2 | Port B Data Register (PBDR)            | 4-5 |
| 4.6.3 | Port C Data Register (PCDR)            | 4-5 |

## TABLE OF CONTENTS (Concluded)

.

#### Paragraph Number

Title

#### Page Number

| 4.7   | Port Alternate Registers                  | 4-6 |
|-------|-------------------------------------------|-----|
| 4.7.1 | Port A Alternate Register (PAAR)          | 4-6 |
| 4.7.2 | Port B Alternate Register (PBAR)          | 4-6 |
| 4.8   | Port State Register (PSR)                 | 4-6 |
| 4.9   | Timer Control Register (TCR)              | 4-6 |
| 4.10  | Timer Interrupt Vector Register (TIVR)    | 4-8 |
| 4.11  | Counter Preload Register H, M, L (CPRH-L) | 4-8 |
| 4.12  | Count Register H, M, L (CNTRH-L)          | 4-8 |
| 4.13  | Timer Status Register (TSR)               | 4-8 |
| 4.14  | Register Value After Reset                | 4-9 |

#### Section 5

#### Timer Operation and Applications Summary

| 5.1     | Timer Operation                      | 5-1 |
|---------|--------------------------------------|-----|
| 5.1.1   | Run/Halt Definition                  | 5-1 |
| 5.1.2   | Timer Rules                          | 5-2 |
| 5.1.3   | Timer Interrupt Acknowledge Cycles   | 5-2 |
| 5.2     | Timer Applications Summary           | 5-2 |
| 5.2.1   | Periodic Interrupt Generator Example | 5-3 |
| 5.2.2   | Square Wave Generator                | 5-3 |
| 5.2.3   | Interrupt After Timeout              | 5-4 |
| 5.2.4   | Elapsed Time Measurement Examples    | 5-5 |
| 5.2.4.1 | System Clock Example                 | 5-5 |
| 5.2.4.2 | External Clock                       | 5-6 |
| 5.2.5   | Device Watchdog                      | 5-6 |

## Section 6

#### **Electrical Specifications**

| 6.1 | Maximum Ratings                             | 6-1 |
|-----|---------------------------------------------|-----|
| 6.2 | Thermal Characteristics                     | 6-1 |
| 6.3 | Power Considerations                        | 6-1 |
| 6.4 | DC Electrical Characteristics               | 6-2 |
| 6.5 | AC Electrical Specifications – Clock Timing | 6-3 |
| 6.6 | AC Electrical Specifications                | 6-4 |

#### Section 7

## Mechanical Data and Ordering Information

| 7.1 | Pin Assignment       | 7-1 |
|-----|----------------------|-----|
|     | Ordering Information |     |
| 7.3 | Package Dimensions   | 7-2 |

## LIST OF ILLUSTRATIONS

.

| Figure<br>Number | Title                                           | Page<br>Number      |
|------------------|-------------------------------------------------|---------------------|
| 1-1              | Block Diagram                                   | 1-2                 |
| 1-2              | Port Mode Layout                                | 1-4                 |
| 1-3              | Logical Pin Assignment                          | 1-6                 |
| 2-1              | Double-Buffered Input Transfers Timing Diagram  | 2-3                 |
| 2-2              | Double-Buffered Cutput Transfers Timing Diagram | 2-4                 |
| 2-3              | DMAREQ Associated with Output Transfers         | 2-6                 |
| 2-4              | DMAREQ Associated with Input Transfers          | 2-6                 |
| 5-1              | Periodic Interrupt Generator Example            | 5-3                 |
| 5-2              | Square Wave Generator Example                   | 5-4                 |
| 5-3              | Single Interrupt After Timeout Example          | 5-5                 |
| 5-4              | Elapsed Time Measurement Example                | 5-6                 |
| 5-5              | Device Watchdog Example                         | 5-7                 |
| 6-1              | Clock Input Timing Diagram                      | 6-3                 |
| 6-2              | Read Cycle Timing Diagram                       |                     |
| 6-3              | Write Cycle Timing Diagram                      |                     |
| 6-4              | IACK Timing Diagram                             |                     |
| 6-5              | Peripheral Input Timing Diagram                 |                     |
| 6-6              | Peripheral Output Timing Diagram                | Foldouts<br>5 and 6 |

## LIST OF TABLES

| Table<br>Number | Title                                   | Page<br>Number |
|-----------------|-----------------------------------------|----------------|
| 1-1             | Port Mode Control Summary               | 1-3            |
| 1-2             | Signal Summary                          | 1-6            |
| 1-3             | Register Model.                         | 1-8            |
| 2-1             | Response to Port Interrupt Acknowledge  | 2-5            |
| 3-1             | Mode 0 Port Data Paths                  | 3-2            |
| 3-2             | Mode 1 Port Data Paths                  | 3-8            |
| 3-3             | Mode 2 Port A Data Paths                | 3-14           |
| 3-4             | Mode 2 Port B Data Paths                | 3-16           |
| 3 5             | Mode 3 Port A and B Data Paths          | <u>3-1</u> 8   |
| 4-1             | PI/T Register Addressing Assignments    | 4-1            |
| 4-2             | PSRR Port Interrupt Priority Control    | 4-3            |
| 4-3             | PCDR Hardware Accesses                  | 4-5            |
| 5-1             | Response to Timer Interrupt Acknowledge | 5-2            |

·

## SECTION 1 INTRODUCTION

The MC68230 parallel interface/timer (PI/T) provides versatile double buffered parallel interfaces and a system oriented timer for M68000 systems. The parallel interfaces operate in unidirectional or bidirectional modes, either 8 or 16 bits wide. In the unidirectional modes, an associated data direction register determines whether each port pin is an input or output. In the bidirectional modes the data direction registers are ignored and the direction is determined dynamically by the state of four handshake pins. These programmable handshake pins provide an interface flexible enough for connection to a wide variety of low, medium, or high speed peripherals or other computer systems. The PI/T ports allow use of vectored or autovectored interrupts, and also provide a DMA request pin for connection to the MC68450 direct memory access controller (DMAC) or a similar circuit. The PI/T timer contains a 24-bit wide counter and a 5-bit prescaler. The timer may be clocked by the system clock (PI/T CLK pin) or by an external clock (TIN pin), and a 5-bit prescaler can be used. It can generate periodic interrupts, a square wave, or a single interrupt after a programmed time period. It can also be used for elapsed time measurement or as a device watchdog.

Features of the PI/T include:

- M68000 Bus Compatible
- Port Modes Include: Bit I/O Unidirectional 8 Bit and 16 Bit Bidirectional 8 Bit and 16 Bit
- Programmable Handshaking Options
- 24-Bit Programmable Timer Modes
- Five Separate Interrupt Vectors
- Separate Port and Timer Interrupt Service Requests
- Registers are Read/Write and Directly Addressable
- Registers are Addressed for MOVEP (Move Peripheral) and DMAC Compatibility

The PI/T consists of two logically independent sections: the ports and the timer. The port section consists of port A (PA0-PA7), port B (PB0-PB7), four handshake pins (H1, H2, H3, and H4), two general input/output (I/O) pins, and six dual-function pins. The dual-function pins can individually operate as a third port (port C) or an alternate function related to either port A, port B, or the timer. The four programmable handshake pins, depending on the mode, can control data transfer to and from the ports, or can be used as interrupt generating inputs or I/O pins. Refer to Figure 1-1.

The timer consists of a 24-bit counter, optionally clocked by a 5-bit prescaler. Three pins provide complete timer I/O: PC2/TIN, PC3/TOUT, and PC7/TIACK. Only the ones needed for the given configuration perform the timer function, while the others remain port C I/O.





The system bus interface provides for asynchronous transfer of data from the PI/T to a bus master over the data bus (D0-D7). Data transfer acknowledge ( $\overline{DTACK}$ ), register selects (RS1-RS5), timer interrupt acknowledge ( $\overline{TIACK}$ ), read/write line ( $R/\overline{W}$ ), chip select ( $\overline{CS}$ ), or port interrupt acknowledge ( $\overline{PIACK}$ ) control data transfer between the PI/T and an M68000.

#### **1.1 PORT MODE DESCRIPTION**

The primary focus of most applications will be on port A, port B, the handshake pins, the port interrupt pins, and the DMA request pin. They are controlled in the following way: the port general control register contains a 2-bit field that specifies one of four operation modes. These govern the overall operation of the ports and determine their interrelationships. Some modes require additional information from each port's control register to further define its operation. In each port control register, there is a 2-bit submode field that serves this purpose. Each port mode/submode combination specifies a set of programmable characteristics that fully define the behavior of that port and two of the handshake pins. This structure is summarized in Table 1-1 and Figure 1-2.

#### Table 1-1. Port Mode Control Summary





Figure 1-2. Port Mode Layout (Sheet 1 of 2)



Figure 1-2. Port Mode Layout (Sheet 2 of 2)

#### **1.2 SIGNAL DESCRIPTION**

Throughout this data sheet, signals are presented using the terms active and inactive or asserted and negated independent or whether the signal is active in the high-voltage state or low-voltage state. (The active state of each logic pin is given below.) Active low signals are denoted by a superscript bar.  $R/\overline{W}$  indicates a write is active low and a read active high. Table 1-2 further describes each pin and the logical pin assignments are given in Figure 1-3.

#### 1.2.1 Bidirectional Data Bus (D0-D7)

The data bus pins, D0-D7, form an 8-bit bidirectional data bus to/from an M68000 bus master. These pins are active high.

#### 1.2.2 Register Selects (RS1-RS5)

The register select pins, RS1-RS5, are active high high-impedance inputs that determine which of the 23 internal registers is being selected. They are provided by the M68000 bus master or other bus master.

| Signal Name                      | Input/Output                     | Active State         | Edge/Level Sensitive    | Output States              |
|----------------------------------|----------------------------------|----------------------|-------------------------|----------------------------|
| CLK                              | Input                            |                      | Falling and Rising Edge |                            |
| CS                               | Input                            | Low                  | Level                   |                            |
| D0-D7                            | Input/Output                     | High = 1, Low = 0    | Level                   | High, Low, High Impedance  |
| DMAREQ                           | Output                           | Low                  |                         | High, Low                  |
| DTACK                            | Output                           | Low                  |                         | High, Low, High Impedance* |
| H1(H3)***                        | Input                            | Low or High          | Asserted Edge           |                            |
| H2(H4) * *                       | Input or Output                  | Low or High          | Asserted Edge           | High, Low, High Impedance  |
| PA0-PA7**, PB0-P87**,<br>PC0-PC7 | Input/Output,<br>Input or Output | High = 1, Low = 0    | Level                   | High, Low, High Impedance  |
| PIACK                            | Input                            | Low                  | Level                   |                            |
| PIRQ                             | Output                           | Low                  |                         | Low, High Impedance*       |
| RS1-RS5                          | Input                            | High = 1, Low = 0    | Level                   |                            |
| R/₩                              | Input                            | High Read, Low Write | Level                   |                            |
| RESET                            | Input                            | Low                  | Level                   |                            |
| TIACK                            | Input                            | Low                  | Level                   |                            |
| TIN (External Clock)             | Input                            |                      | Rising Edge             |                            |
| TIN (Run/Halt)                   | Input                            | High                 | Level                   |                            |
| TOUT (Square Wave)               | Output                           | Low                  |                         | High, Low                  |
| TOUT (TIRO)                      | Output                           | Low                  |                         | Low, High Impedance*       |

\* Pullup resistors required.

\*\*Note these pins have internal pullup resistors.

\*\*\*H1 is level sensitive for output buffer control in modes 2 and 3



\*Individually Programmable Dual-Function Pin

Figure 1-3. Logical Pin Assignment

#### 1.2.3 Read/Write (R/W)

 $R/\overline{W}$  is a high-impedance read/write input signal from the M68000 bus master, indicating whether the current bus cycle is a read (high) or write (low) cycle.

#### 1.2.4 Chip Select (CS)

 $\overline{CS}$  is a high-impedance input that selects the PI/T registers for the current bus cycle. Address strobe and the data strobe (upper or lower) of the bus master, along with the appropriate address bits, must be included in the chip-select equation. A low level corresponds to an asserted chip select.

#### 1.2.5 Data Transfer Acknowledge (DTACK)

DTACK is an active low output that signals the completion of the bus cycle. During read or interrupt acknowledge cycles, DTACK is asserted after data has been provided on the data bus; during write cycles it is asserted after data has been accepted at the data bus. Data transfer acknowledge is compatible with the MC68000 and with other M68000 bus masters such as the MC68450 direct memory access controller (DMAC). A pullup resistor is required to maintain DTACK high between bus cycles.

#### 1.2.6 Reset (RESET)

**RESET** is a high-impedance input used to initialize all PI/T functions. All control and data direction registers are cleared and most internal operations are disabled by the assertion of **RESET** (low).

#### 1.2.7 Clock (CLK)

The clock pin is a high-impedance TTL-compatible signal with the same specifications as the MC68000. The PI/T contains dynamic logic throughout, and hence this clock must not be gated off at any time. It is not necessary that this clock maintain any particular phase relationship with the M68000 system clock. It may be connected to an independent frequency source (faster or slower) as long as all bus specifications are met.

#### 1.2.8 Port A and Port B (PA0-PA7 and PB0-PB7)

Ports A and B are 8-bit ports that may be concatenated to form a 16-bit port in certain modes. The ports may be controlled in conjunction with the handshake pins H1-H4. For stabilization during system power up, ports A and B have internal pullup resistors to  $V_{CC}$ . All port pins are active high.

#### 1.2.9 Handshake Pins (H1-H4)

Handshake pins H1-H4 are multi-purpose pins that (depending on the operational mode) may provide an interlocked handshake, a pulsed handshake, an interrupt input (independent of data transfers), or simple I/O pins. For stabilization during system power up, H2 and H4 have internal pullup resistors to V<sub>CC</sub>. The sense of H1-H4 (active high or low) may be programmed in the port general control register bits 3-0. Independent of the mode, the instantaneous level of the handshake pins can be read from the port status register.

#### 1.2.10 Port C (PC0-PC7/Alternate Function)

This port can be used as eight general purpose I/O pins (PC0-PC7) or any combination of six special function pins and two general purpose I/O pins (PC0-PC1). Each dual-function pin can be a standard I/O or a special function independent of the other port C pins. When used as a port C pin, these pins are active high. They may be individually programmed as inputs or outputs by the port C data direction register. The dual-function pins are defined in the following paragraphs.

The alternate functions TIN, TOUT, and TIACK are timer I/O pins. TIN may be used as a rising-edge triggered external clock input or an external run/halt control pin (the timer is in the run state if run/halt is high and in the halt state if run/halt is low). TOUT may provide an active low timer interrupt request output or a general-purpose square-wave output, initially high. TIACK is an active low high-impedance input used for timer interrupt acknowledge.

Port A and B functions have an independent pair of active low interrupt request (PIRQ) and interrupt acknowledge (PIACK) pins.

The DMAREQ (direct memory access request) pin provides an active low direct memory access controller request pulse for three clock cycles, completely compatible with the MC68450 DMAC.

#### **1.3 REGISTER MODEL**

A register model that includes the corresponding register selects is shown in Table 1-3.

|    |   | egis<br>Sele<br>Bit: | ct |   |                                       |             |                 |             |          |          |             |          | Register<br>Value<br>After<br>RESET<br>(Hex |                                   |
|----|---|----------------------|----|---|---------------------------------------|-------------|-----------------|-------------|----------|----------|-------------|----------|---------------------------------------------|-----------------------------------|
| 5  | 4 |                      |    | 1 | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        | Value)                                      | _                                 |
| 0  | 0 | 0                    | 0  | 0 |                                       | Mode        | H34             | H12         | H4       | НЗ       | H2          | H1       | 00                                          | Port General                      |
|    |   |                      |    |   | Cor                                   | ntrol       | Enable          | Enable      | Sense    | Sense    | Sense       | Sense    | 4                                           | Contol Register                   |
| 0  | 0 | 0                    | 0  | 1 | •                                     | svo         |                 | IP          |          |          | ort Interru |          | 00                                          | Port Service                      |
|    |   |                      |    |   | ļ                                     |             | ect             | Sel         |          | +        | ority Cont  |          |                                             | Request Register                  |
| 0  | 0 | 0                    | 1  | 0 | Bit<br>7                              | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | 00                                          | Port A Data                       |
|    | - |                      |    |   |                                       | 6           | 5               | 4           | 3        | 2        | 1           | 0        |                                             | Direction Register                |
| 0  | 0 | 0                    | 1  | 1 | Bit<br>7                              | Bit<br>6    | Bit<br>5        | Bit<br>4    | Bit<br>3 | Bit<br>2 | Bit<br>1    | Bit<br>0 | 00                                          | Port B Data<br>Direction Register |
| 0  | 0 | 1                    | 0  | 0 | Bit                                   | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | 00                                          | Port C Data                       |
|    |   |                      |    |   | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        |                                             | Direction Register                |
| С  | С | 1                    | 0  | 1 |                                       |             | Interrup<br>Nun |             |          |          | •           | •        | 0 F                                         | Port Interrupt<br>Vector Register |
| С  | С | 1                    | 1  | 0 | Por                                   | • •         |                 |             |          | H2       | н           | н1       | 00                                          | Port A Control                    |
| C. | C | '                    | 1  | U | Subr                                  | •           |                 | H2 Control  |          |          | SVCRO       | Stat     | 00                                          | Register                          |
|    |   |                      |    |   | 0000                                  |             |                 | 12 001110   |          | Enable   | Enable      | Ctrl     |                                             | riegister                         |
| 0  | 0 | 1                    | 1  | 1 | Por                                   | 1.8         |                 |             |          | H4       | НЗ          | НЗ       | 00                                          | Port B Control                    |
|    |   |                      |    |   | Subr                                  | node        | l I             | H4 Control  |          | Int      | SVCRQ       | Stat     |                                             | Register                          |
|    |   |                      |    |   |                                       |             |                 |             |          | Enable   | Enable      | Ctrl     |                                             | -                                 |
| 0  | 1 | 0                    | 0  | 0 | Bit                                   | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | **                                          | Port A Data                       |
|    |   |                      |    |   | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        | ]                                           | Register                          |
| 0  | 1 | 0                    | 0  | 1 | Bit                                   | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | **                                          | Port B Data                       |
|    |   |                      |    |   | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        |                                             | Register                          |
| 0  | 1 | С                    | 1  | 0 | Bit                                   | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | ***                                         | Port A Alternate                  |
|    |   |                      |    |   | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        |                                             | Register                          |
| 0  | 1 | 0                    | 1  | 1 | Bit                                   | Bit         | Bit             | Bit         | Bit      | Bit      | Bit         | Bit      | ***                                         | Port B Alternate                  |
|    |   |                      | -  |   | 7                                     | 6           | 5               | 4           | 3        | 2        | 1           | 0        | 4                                           | Register                          |
| 0  | 1 | 1                    | 0  | 0 | Bit<br>7                              | Bit<br>6    | B⊧t<br>5        | Bit<br>4    | Bit      | Bit      | Bit         | Bit      | ****                                        | Port C Data                       |
| ~  |   |                      | ~  |   | · · · · · · · · · · · · · · · · · · · |             |                 |             | 3        | 2        | 1           | 0        | 1                                           | Register                          |
| 0  | 1 | 1                    | 0  | 1 | H4<br>Level                           | H3<br>Level | H2<br>Level     | H1<br>Level | H4S      | нзѕ      | H2S         | HIS      | ****                                        | Port Status                       |
| 0  | 1 | 1                    | 1  | 0 | . Levei                               |             |                 |             |          |          | <u> </u>    |          |                                             | Register                          |
| U  | 1 | ł                    | 1  | U | •                                     | *           | •               | •           | *        | *        | *           | •        | 00                                          | (Null)                            |
| 0  | 1 | 1                    | 1  | 1 | •                                     | *           | •               | •           | •        | *        | •           | *        | 00                                          | ( <b>N</b> u <sup>[]</sup> )      |

#### Table 1-3. Register Model (Sheet 1 of 2)

\*Unused, read as zero

\* \* Value before RESET

\*\*\*Current value on pins

\* \* \* \* Undetermined value

|   | S | egis<br>Sele<br>Bitt | ct |   |           |                     |           |             |           |           |              |                 | Register<br>Value<br>After<br>RESET<br>(Hex |                                    |
|---|---|----------------------|----|---|-----------|---------------------|-----------|-------------|-----------|-----------|--------------|-----------------|---------------------------------------------|------------------------------------|
| 5 | 4 | 3                    | 2  | 1 | 7         | 6                   | 5         | 4           | 3         | 2         | 1            | 0               | Value)                                      | _                                  |
| 1 | 0 | 0                    | 0  | 0 | T         | OUT/TIAC<br>Control | ТК<br>ТК  | Z D<br>Ctrl | *         |           | ock<br>htrol | Timer<br>Enable | 00                                          | Timer Control<br>Register          |
| 1 | 0 | 0                    | 0  | 1 | Bit<br>7  | Bit<br>6            | Bit<br>5  | Bit<br>4    | Bit<br>3  | Bit<br>2  | Bit<br>1     | Bit<br>0        | OF                                          | Timer Interrupt<br>Vector Register |
| 1 | 0 | 0                    | 1  | 0 | *         | *                   | *         | *           | *         | *         | *            | *               | 00                                          | (Null)                             |
| 1 | 0 | 0                    | 1  | 1 | Bit<br>23 | Bit<br>22           | Bit<br>21 | Bit<br>20   | Bit<br>19 | Bit<br>18 | Bit<br>17    | Bit<br>16       | **                                          | Counter Preload<br>Register (High) |
| 1 | 0 | 1                    | 0  | 0 | Bit<br>15 | Bit<br>14           | Bit<br>13 | Bit<br>12   | Bit<br>11 | Bit<br>10 | Bit<br>9     | Bit<br>8        | **                                          | Counter Preload<br>Register (Mid)  |
| 1 | 0 | 1                    | 0  | 1 | Bit<br>7  | Bit<br>6            | Bit<br>5  | Bit<br>4    | Bit<br>3  | Bit<br>2  | Bit<br>1     | Bit<br>0        | **                                          | Counter Preload<br>Register (Low)  |
| 1 | 0 | 1                    | 1  | 0 | *         | *                   | *         | *           | *         | *         | *            | *               | 00                                          | (Null)                             |
| 1 | 0 | 1                    | 1  | 1 | Bit<br>23 | Bit<br>22           | Bit<br>21 | Bit<br>20   | Bit<br>19 | Bit<br>18 | Bit<br>17    | Bit<br>16       | **                                          | Count Register<br>(High)           |
| 1 | 1 | 0                    | 0  | 0 | Bit<br>15 | Bit<br>14           | Bit<br>13 | Bit<br>12   | Bit<br>11 | Bit<br>10 | Bit<br>9     | Bit<br>8        | **                                          | Count Register<br>(Mid)            |
| 1 | 1 | 0                    | 0  | 1 | Bit<br>7  | Bit<br>6            | Bit<br>5  | Bit<br>4    | Bit<br>3  | Bit<br>2  | Bit<br>1     | Bit<br>O        | **                                          | Count Register<br>(Low)            |
| 1 | 1 | 0                    | 1  | 0 | *         | *                   | *         | *           | *         | *         | *            | ZDS             | 00                                          | Timer Status<br>Register           |
| 1 | 1 | 0                    | 1  | 1 | *         | *                   | *         | *           | *         | *         | *            | *               | 00                                          | (Null)                             |
| 1 | 1 | 1                    | 0  | 0 | •         | *                   | +         | #           | *         | *         | *            | *               | 00                                          | (Null)                             |
| 1 | 1 | 1                    | 0  | 1 | •         | *                   | *         | •           | *         | •         |              | *               | 00                                          | (Null)                             |
| 1 | 1 | 1                    | 1  | 0 | *         | *                   | *         | *           | *         | *         | *            | •               | 00                                          | (Null)                             |
| 1 | 1 | 1                    | 1  | 1 | •         | *                   | *         | *           | *         | *         | *            | *               | 00                                          | (Null)                             |
|   |   |                      |    |   |           |                     |           |             |           |           |              |                 | -                                           |                                    |

## Table 1-3. Register Model (Sheet 2 of 2)

\*Unused, read as zero \* \*Value before RESET

.

NOTE

Table 1-3 has been duplicated on foldout pages 1 and 2 at the end of this document for your convenience.

.

#### 1.4 BUS INTERFACE OPERATION

The PI/T has an asynchronous bus interface, primarily designed for use with an M68000 microprocessor. With care, however, it can be connected to synchronous microprocessor buses. This section completely describes the PI/T's bus interface, and is intended for the asynchronous bus designer unless otherwise mentioned.

In an asynchronous system the PI/T clock may operate at a significantly different frequency, either higher or lower, than the bus master and other system components, as long as all bus specifications are met. The MC68230 CLK pin has the same specifications as the MC68000 CLK pin, and must not be gated off at any time.

The following signals generate normal read and write cycles to the PI/T:  $\overline{CS}$  (chip select), R/W (read/write), RS1-RS5 (five register select bits), D0-D7 (the 8-bit bidirectional data bus), and DTACK (data transfer acknowledge). To generate interrupt acknowledge cycles, PC6/PIACK or PC7/TIACK is used instead of  $\overline{CS}$ , and the register select pins are ignored. No combination of the following pin functions may be asserted simultaneously:  $\overline{CS}$ ,  $\overline{PIACK}$ , or  $\overline{TIACK}$ .

#### 1.4.1 Read Cycles

This category includes all register reads, except port or timer interrupt acknowledge cycles. When  $\overline{CS}$  is asserted, the register select and  $R/\overline{W}$  inputs are latched internally. They must meet small setup and hold time requirements with respect to the asserted edge of  $\overline{CS}$ . (Refer to **6.6 AC ELEC-TRICAL SPECIFICATIONS** for further information.) The PI/T is **not** protected against aborted (shortened) bus cycles generated by an address error or bus error exception in which it is addressed.

Certain operations triggered by normal read (or write) bus cycles are not complete within the time allotted to the bus cycle. One example is transfers to/from the double-buffered latches that occur as a result of the bus cycle. If the bus master's clock is significantly faster than the PI/T's the possibility exists that, following the bus cycle,  $\overline{CS}$  can be negated then re-asserted before completion of these internal operations. In this situation the PI/T does not recognize the re-assertion of  $\overline{CS}$  until these operations are complete. Only at that time does it begin the internal sequencing necessary to react to the asserted  $\overline{CS}$ . Since  $\overline{CS}$  also controls the  $\overline{DTACK}$  response, this "bus cycle recovery time" can be related to the clock edge on which  $\overline{DTACK}$  is asserted for that cycle. The PI/T will recognize the subsequent assertion of  $\overline{CS}$  three clock periods after the clock edge on which  $\overline{DTACK}$  was previously asserted.

The register select and  $R/\overline{W}$  inputs pass through an internal latch that is transparent when the PI/T can recognize a new  $\overline{CS}$  pulse (see above paragraph). Since the internal data bus of the PI/T is continuously engaged for read transfers, the read access time (to the data bus buffers) begins when the register selects are stabilized internally. Also, when the PI/T is ready to begin a new bus cycle, the assertion of  $\overline{CS}$  enables the data bus buffers within a short propagation delay. This does not contribute to the overall read access time unless  $\overline{CS}$  is asserted significantly after the register select and  $R/\overline{W}$  inputs are stabilized (as may occur with synchronous bus microprocessors).

In addition to the chip select's previously mentioned duties, it controls the assertion of DTACK and latching of read data at the data bus interface. Except for controlling input latches and enabling the data bus buffers, all of these functions occur only after  $\overline{CS}$  has been recognized internally and synchronized with the internal clock. Chip select is recognized on the falling edge of the clock if the setup time is met; DTACK is asserted (low) on the next falling edge of the clock. Read data is

latched at the PI/T's data bus interface at the same time DTACK is asserted. It is stable as long as chip select remains asserted independent of other external conditions.

From the above discussion it is clear that if the chip select setup time prior to the falling edge of the clock is met, the PI/T can consistently respond to a new read or write bus cycle every four clock cycles. This fact is especially useful in designing the Pi/T's clock in synchronous bus systems not using DTACK. (An extra clock period is required in interrupt acknowledge cycles, see **1.4.2 Interrupt Acknowledge Cycles**.)

In asynchronous bus systems in which the PI/T's clock differs from that of the bus master, generally there is no way to guarantee that the chip select setup time with respect to the PI/T clock is met. Thus, the only way to determine that the PI/T recognized the assertion of  $\overline{CS}$  is to wait for the assertion of  $\overline{DTACK}$ . In this situation, all latched bus inputs to the PI/T must be held stable until  $\overline{DTACK}$  is asserted. These include register select, R/W, and write data inputs (see below).

System specifications impose a maximum delay from the trailing (negated) edge of  $\overline{CS}$  to the negated edge of  $\overline{DTACK}$ . As system speeds increase this becomes more difficult to meet with a simple pullup resistor tied to the  $\overline{DTACK}$  line. Therefore, the PI/T provides an internal active pullup device to reduce the rise time, and a level-sensitive circuit that later turns this device off.  $\overline{DTACK}$  is negated asynchronously as fast as possible following the rising edge of chip select, then three stated to avoid interference with the next bus cycle.

The system designer must take care that  $\overrightarrow{DTACK}$  is negated and three-stated quickly enough after each bus cycle to avoid interference with the next one. With an M68000 this necessitates a relatively fast external path from the data strobe negation to  $\overrightarrow{CS}$  bus master negation.

#### 1.4.2 Interrupt Acknowledge Cycles

Special internal operations take place on PI/T interrupt acknowledge cycles. The port interrupt vector register or the timer vector register are implicitly addressed by the assertion of PC6/PIACK or PC7/TIACK, respectively. The signals are first synchronized with the falling edge of the clock. One clock period after they are recognized, the data bus buffers are enabled and the vector is driven onto the bus. DTACK is asserted after another clock period to allow the vector some setup time prior to DTACK. DTACK is negated, then three-stated, as with normal read or write cycles, when PIACK or TIACK is negated.

#### 1.4.3 Write Cycles

In many ways, write cycles are similar to normal read cycles. On write cycles, data at the D0-D7 pins must meet the same setup specifications as the register select and R/W lines. Like these signals, write data is latched on the asserted edge of  $\overline{CS}$ , and must meet small setup and hold time requirements with respect to that edge. The same bus cycle recovery conditions exist as for normal read cycles. No other differences exist.

#### NOTE

For mask sets GG7 and KD1 if the RS lines are selecting the port interrupt vector register (PIVR) or timer interrupt vector register (TIVR) during an interrupt acknowledge bus cycle then those registers may be changed. Four cases exist for this situation, they are:

| 1. | Case:    | RS lines are addressing PIVR during a port interrupt acknowledge cycle (PIACK asserted).                       |
|----|----------|----------------------------------------------------------------------------------------------------------------|
|    | Results: | Incorrect IACK vector on data lines, bits 0 and 1 are zero, PIVR and TIVR remain the same and are not changed. |
| 2. | Case:    | RS lines are addressing TIVR during a port interrupt acknowledge cycle (PIACK asserted).                       |
|    | Results: | Incorrect IACK vector on data lines, PIVR and TIVR are changed.                                                |
| 3. | Case:    | RS lines are addressing PIVR during a timer interrupt acknowledge cycle (TIACK asserted).                      |
|    | Results: | Incorrect IACK vector on data lines, PIVR and TIVR are changed.                                                |
| 4. | Case:    | RS lines are addressing TIVR during a timer interrupt acknowledge cycle (TIACK asserted).                      |
|    | Results: | Correct IACK vector on data lines, PIVR and TIVR remain the same and are not changed.                          |
|    |          |                                                                                                                |

For MC68000 and MC68010 systems that use A1-A5 for RS lines RS1-RS5 the above cases will never occur. A5 and A4 will remain high during interrupt acknowledge cycles and thus PIVR and TIVR will not be selected as shown below.

|                      | RS5 | RS4 | RS3  | RS2      | RS1  |
|----------------------|-----|-----|------|----------|------|
| MC68000 IACK Cycle   | 1   | 1   | — En | coded Le | vel— |
| MC68230 PIVR Address | 0   | 0   | 1    | 0        | 1    |
| MC68230 TIVR Address | 1   | 0   | 0    | 0        | 1    |

## SECTION 2 PORT GENERAL INFORMATION AND CONVENTIONS

This section introduces concepts that are generally applicable to the PI/T ports independent of the chosen mode and submode. For this reason, no particular port or handshake pins are mentioned; the notation H1(H3) indicates that, depending on the chosen mode and submode, the statement given may be true for either the H1 or H3 handshake pin.

#### 2.1 UNIDIRECTIONAL VS BIDIRECTIONAL

Figure 1-2 shows the configuration of ports A and B and each of the handshake pins in each port mode and submode. In modes 0 and 1, a data direction register is associated with each of the ports. These registers contain one bit for each port pin to determine whether that pin is an input or an output. Modes 0 and 1 are, thus, called unidirectional modes because each pin assumes a constant direction, changeable only by a reset condition or a programming change. These modes allow double-buffered data transfers in one direction. This direction, determined by the mode and submode definition, is known as the primary direction. Data transfers in the primary direction are controlled by the handshake pins. Data transfers not in the primary direction are generally unrelated, and single or unbuffered data paths exist.

In modes 2 and 3 there is no concept of primary direction as in modes 0 and 1. Except for port A in mode 2 (bit I/O), the data direction registers have no effect. These modes are bidirectional, in that the direction of each transfer (always 8 or 16 bits, double buffered) is determined dynamically by the state of the handshake pins. Thus, for example, data may be transferred out of the ports, followed very shortly by a transfer into the same port pins. Transfers to and from the ports are independent and may occur in any sequence. Since the instantaneous direction is always determined by the external system, a small amount of arbitration logic may be required.

#### 2.1.1 Control of Double-Buffered Data Ports

Generally speaking, the PI/T is a double-buffered device. In the primary direction, double buffering allows orderly transfers by using the handshake pins in any of several programmable protocols. (When bit I/O is used, double buffering is not available and the handshake pins are used as outputs or status/interrupt inputs.)

Use of double buffering is most beneficial in situations where a peripheral device and the computer system are capable of transferring data at roughly the same speed. Double buffering allows the fetch operation of the data transmitter to be overlapped with the store operation of the data receiver. Thus, throughput measured in bytes or words-per-second may be greatly enhanced. If there is a large mismatch in transfer capability between the computer and the peripheral, little or no benefit is obtained. In these cases there is no penalty in using double buffering.

#### 2.1.2 Double-Buffered Input Transfers

In all modes, the PI/T supports double-buffered input transfers. Data that meets the port setup and hold times is latched on the asserted edge of H1(H3). H1(H3) is edge sensitive, and may assume any duty cycle as long as both high and low minimum times are observed. The PI/T contains a port status register whose H1S(H3S) status bit is set anytime any input data that has not been read by the bus master is present in the double-buffered latches. The action of H2(H4) is programmable; it may indicate whether there is room for more data in the PI/T latches or it may serve other purposes. The following options are available, depending on the mode.

- 1. H2(H4) may be an edge-sensitive input that is independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by the direct method (refer to 2.3 DIRECT METHOD OF RESETTING STATUS), the RESET pin being asserted, or when the H12 enable (H34 enable) bit of the port general control register is zero.
- 2. H2(H4) may be a general purpose output pin that is always negated. The H2S(H4S) status bit is always zero.
- 3. H2(H4) may be a general purpose output pin that is always asserted. The H2S(H4S) status bit is always zero.
- 4. H2(H4) may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H1(H3) input. As soon as the input latches become ready, H2(H4) is again asserted. When both double-buffered latches are full, H2(H4) remains negated until data is removed by a read of port A (port B) data register. Thus, anytime the H2(H4) output is asserted, new input data may be entered by asserting H1(H3). At other times transitions of H1(H3) are ignored. The H2S(H4S) status bit is always zero. When H12 enable (H34 enable) is zero, H2(H4) is held negated.
- 5. H2(H4) may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H1(H3) asserted edge occurs before termination of the pulse, H2(H4) is negated asynchronously. Thus, anytime after the leading edge of the H2(H4) pulse, new data may be entered in the PI/T double-buffered input latches. The H2S(H4S) status bit is always zero. When H12 enable (H34 enable) is zero, H2(H4) is held negated.

A sample timing diagram is shown in Figure 2-1. The H2(H4) interlocked and pulse input handshake protocols are shown. The DMAREQ pin is also shown assuming it is enabled. All handshake pin sense bits are assumed to be zero (refer to **4.1 PORT GENERAL CONTROL REGISTER (PGCR)**); thus, the pins are in the low state when asserted. Due to the great similarity between modes, this timing diagram is applicable to all double-buffered input transfers.

#### 2.1.3 Double-Buffered Output Transfers

The PI/T supports double-buffered output transfers in all modes. Data, written by the bus master to the PI/T, is stored in the port's output latch. The peripheral accepts the data by asserting H1(H3), which causes the next data to be moved to the port's output latch as soon as it is available. The function of H2(H4) is programmable; it may indicate whether new data has been moved to the output latch or it may serve other purposes. The H1S(H3S) status bit may be programmed for two interpretations. First, the status bit is a one when there is at least one latch in the double-buffered data path that can accept new data. After writing one byte/word of data to the ports, an interrupt



Figure 2-1. Double-Buffered Input Transfers Timing Diagram

service routine could check this bit to determine if it could store another byte/word, thus filling both latches. Second, when the bus master is finished, it is often useful to be able to check whether all of the data has been transferred to the peripheral. The H1S(H3S) status bit is set when both output latches are empty. The programmable options of the H2(H4) pin are given below, depending on the mode.

- H2(H4) may be an edge-sensitive input pin independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by the direct method (refer to 2.3 DIRECT METHOD OF RESETTING STATUS), the RESET pin being asserted, or when the H12 enable (H34 enable) bit of the port general control register is zero.
- 2. H2(H4) may be a general-purpose output pin that is always negated. The H2S(H4S) status bit is always zero.
- 3. H2(H4) may be a general-purpose output pin that is always asserted. The H2S(H4S) status bit is always zero.
- 4. H2(H4) may be an output pin in the interlocked output handshake protocol. H2(H4) is asserted two clock cycles after data is transferred to the double-buffered output latches. The data remains stable and H2(H4) remains asserted until the next asserted edge of the H1(H3) input. At that time, H2(H4) is asynchronously negated. As soon as the next data is available, it is transferred to the output latches and H2(H4) is asserted. When H2(H4) is negated, asserted transitions on H1(H3) have no effect on the data paths. As is explained later, however, in modes 2 and 3 H1 does control the three-state output buffers of the bidirectional port(s). The H2S(H4S) status bit is always zero. When H12 enable (H34 enable) is zero, H2(H4) is held negated.
- 5. H2(H4) may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked output protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock pulse is generated. But in the case that a subsequent H1(H3) asserted edge occurs before termination of the pulse, H2(H4) is negated asynchronously, thus shortening the pulse. The H2S(H4S) status bit is always zero. When H12 enable (H34 enable) is zero, H2(H4) is held negated.

A sample timing diagram is shown in Figure 2-2. The H2(H4) interlocked and pulsed output handshake protocols are shown. The DMAREQ pin is also shown assuming it is enabled. All handshake pin sense bits are assumed to be zero; thus, the pins are in the low state when asserted. Due to the great similarity between modes, this timing diagram is applicable to all double-buffered output transfers.



Figure 2-2. Double-Buffered Output Transfers Timing Diagram

#### 2.2 REQUESTING BUS MASTER SERVICE

The PI/T has several means of indicating a need for service by a bus master. First, the processor may poll the port status register. It contains a status bit for each handshake pin, plus a level bit that always reflects the instantaneous state of that handshake pin. A status bit is one when the PI/T needs servicing (i.e., generally when the bus master needs to read or write data to the ports) or when a handshake pin used as a simple status input has been asserted. The interpretation of these bits is dependent on the chosen mode and submode.

Second, the PI/T may be placed in the processor's interrupt structure. As mentioned previously, the PI/T contains port A and B control registers that configure the handshake pins. Other bits in these registers enable an interrupt associated with each handshake pin. This interrupt is made available through the PC5/PIRQ pin, if the PIRQ function is selected. Three additional conditions are required for PIRQ to be asserted: 1) the handshake pin status bit is set, 2) the corresponding interrupt (service request) enable bit is set, and 3) DMA requests are not associated with that data transfer (H1 and H3 only). The conditions from each of the four handshake status bits and corresponding status bits are ORed to determine PIRQ. To clear the interrupt, the proper status bit must be cleared (see 2.3 DIRECT METHOD OF RESETTING STATUS).

The third method of requesting service is via the PC4/DMAREQ pin. This pin can be associated with double-buffered transfers in each mode. If it is used as a DMA controller request, it can initiate requests to keep the PI/T's input/output double-buffering empty/full as much as possible. It will not overrun the DMA controller. The pin is compatible with the MC68450 direct memory access controller (DMAC).

#### 2.2.1 Vectored, Prioritized Port Interrupts

Use of MC68000-compatible vectored interrupts with the PI/T requires the PIRQ and PIACK pins. When PIACK is asserted while PIRQ is asserted, the PI/T places an 8-bit vector on the data pins D0-D7. Under normal conditions, this vector corresponds to the highest priority enabled active port interrupt source with which the DMAREQ pin is not currently associated. The most-significant six bits are provided by the port interrupt vector register (PIVR), with the lower two bits supplied by prioritization logic according to conditions present when PIACK is asserted. It is important to note that the only effect on the PI/T caused by interrupt acknowledge cycles is that the vector is placed on the data bus. Specifically, no registers, data, status, or other internal states of the PI/T are affected by the cycle.

Several conditions may be present when the PIACK input is asserted to the PI/T. These conditions affect the PI/T's response and the termination of the bus cycle. If the PI/T has no interrupt function selected, or is not asserting PIRQ, the PI/T will make no response to PIACK (DTACK will not be asserted). If the PI/T is asserting PIRQ when PIACK is received, the PI/T will output the contents of the port interrupt vector register and the prioritization bits. If the PIVR has not been initialized, \$0F will be read from this register. These conditions are summarized in Table 2-1.

| Table 2-1. | Response | to | Port | Interrupt / | Acknowle | dge |
|------------|----------|----|------|-------------|----------|-----|
|------------|----------|----|------|-------------|----------|-----|

| Conditions                                | PIRO negated OR interrupt<br>request function not selected | PIRQ asserted                                            |
|-------------------------------------------|------------------------------------------------------------|----------------------------------------------------------|
| PIVR has not been initialized since RESET | No response from PI/T.<br>No DTACK.                        | PI/T provides \$0F, the<br>Uninitialized Vector*         |
| PIVR has been initialized since RESET     | No response from PI/T.<br>No DTACK.                        | PI/T provides PIVR contents<br>with prioritization bits. |

\* The uninitialized vector is the value returned from an interrupt vector register before it has been initialized.

The vector table entries for the PI/T appear as a contiguous block of four vector numbers whose common upper six bits are programmed in the PIVR. The following table pairs each interrupt source with the 2-bit value provided by the prioritization logic when interrupt acknowledge is asserted (see **4.2. PORT SERVICE REQUEST REGISTER (PSRR)**).

| H1 source – 00 | H3 source – 10 |
|----------------|----------------|
| H2 source – 01 | H4 source – 11 |

#### 2.2.2 Autovectored Port Interrupts

Autovectored interrupts use only the PIRQ pin. The operation of the PI/T with vectored and autovectored interrupts is identical except that no vectors are supplied and the PC6/PIACK pin can be used as a port C pin.

#### 2.2.3 DMA Request Operation

The direct memory access request (DMAREQ) pulse (when enabled) is associated with output or input transfers to keep the initial and final output latches full or initial and final input latches empty, respectively. Figures 2-3 and 2-4 show all the possible paths in generating DMA requests. See **4.2 PORT SERVICE REQUEST REGISTER (PSRR)** for programming the operation of the DMA request bit.

DMAREQ is generated on the bus side of the MC68230 by the synchronized\* chip select. If the conditions of Figures 2-3 or 2-4 are met, an assertion of CS will cause DMAREQ to be asserted three PI/T clocks (plus the delay time from the clock edge) after CS is synchronized. DMAREQ remains asserted three clock cycles (plus the delay time from the clock edge) and is then negated.

DMAREQ pulses are associated with peripheral transfers or are generated by the synchronized\* H1(H3) input. If the conditions of Figures 2-3 or 2-4 are met, an assertion of the H1(H3) input will cause DMAREQ to be asserted 2.5 PI/T clock cycles (plus the delay time from clock edge) after H1(H3) is synchronized. DMAREQ remains asserted three clock cycles (plus the delay time from the clock edge) and is then negated.



#### 2.3 DIRECT METHOD OF RESETTING STATUS

In certain modes one or more handshake pins can be used as edge-sensitive inputs for the sole purpose of setting bits in the port status register. These bits consist of simple flip-flops. They are set (to one) by the occurrence of the asserted edge of the handshake pin input. Resetting a handshake status bit can be done by writing an 8-bit mask to the port status register. This is called the direct method of resetting. To reset a status bit that is resettable by the direct method, the mask must

<sup>\*</sup> Synchronized means that the appropriate input signal (H1, H3, or  $\overline{CS}$ ) has been sampled by the PI/T on the appropriate edge of the clock (rising edge for H1(H3) and falling edge for  $\overline{CS}$ ). Refer to 1.4 BUS INTERFACE OPERATION for the exception concerning  $\overline{CS}$ . If a bus access (assertion of  $\overline{CS}$ ) and a port access (assertion of H1(H3)) occur at the same time,  $\overline{CS}$  will be recognized without any delay. H1(H3) will be recognized one clock cycle later.

contain a one in the bit position of the port status register corresponding to the desired status bit. For status bits that are not resettable by the direct method in the chosen mode, the data written to the port status register has no effect. For status bits that are resettable by the direct method in the chosen mode, a zero in the mask has no effect.

#### 2.4 HANDSHAKE PIN SENSE CONTROL

The PI/T contains exclusive-OR gates to control the sense of each of the handshake pins, whether used as inputs or outputs. Four bits in the port general control register may be programmed to determine whether the pins are asserted in the low- or high-voltage state. As with other control registers, these bits are reset to zero when the RESET pin is asserted, defaulting the asserted level to be low.

#### 2.5 ENABLING PORTS A AND B

Certain functions involved with double-buffered data transfers, the handshake pins, and the status bits may be disabled by the external system or by the programmer during initialization. The port general control register contains two bits, H12 enable and H34 enable, which control these functions. These bits are cleared to the zero state when the RESET pin is asserted, and the functions are disabled. The functions are the following:

- Independent of other actions by the bus master or peripheral (via the handshake pins), the PI/T's disabled handshake controller is held to the "empty" state; i.e., no data is present in the double-buffered data path.
- 2. When any handshake pin is used to set a simple status flip-flop, unrelated to double-buffered transfers, these flip-flops are held reset to zero (see Table 1-1).
- 3. When H2(H4) is used in an interlocked or pulsed handshake with H1(H3), H2(H4) is held negated, regardless of the chosen mode, submode, and primary direction. Thus, for double-buffered input transfers, the programmer may signal a peripheral when the PI/T is ready to begin transfers by setting the associated handshake enable bit to one.

#### 2.6 PORT A AND B ALTERNATE REGISTERS

In addition to the port A and B data registers, the PI/T contains port A and B alternate registers. These registers are read only, and simply provide the instantaneous (non-latched) level of each port pin. They have no effect on the operation of the handshake pins, double-buffered transfers, status bits, or any other aspect of the PI/T, and they are mode/submode independent. Refer to **4.7 PORT ALTERNATE REGISTERS** for further information.

## SECTION 3 PORT MODES

This section contains information that distinguishes the various port modes and submodes. General characteristics common to all modes are defined in **SECTION 2 PORT GENERAL INFORMATION AND CONVENTIONS.** A description of the port A control register (PACR) and port B control register (PBCR) is given before each mode description. After each submode description, the programmable options are listed for that submode.

#### 3.1 PORT A CONTROL REGISTER

#### Port A Control Register (PACR)

|      |      |            |   | -         |        | · ·     |
|------|------|------------|---|-----------|--------|---------|
|      |      |            |   | H2        | H1     | H1 .    |
| Por  | t A  |            | 1 | Interrupt | SVCRQ  | Status  |
| Subr | node | H2 Control |   | Enable    | Enable | Control |

The port A control register, in conjunction with the programmed mode and the port B-submode, controls the operation of port A and the handshake pins H1 and H2. The port A control register contains five fields: bits 7 and 6 specify the port A submode; bits 5, 4, and 3 control the operation of the H2 handshake pin and the H2S status bit; bit 2 determines whether an interrupt will be generated when the H2S status bit goes to one; and bit 1 determines whether a service request (interrupt request or DMA request) will occur; bit 0 controls the operation of the H1S status bit. The PACR is always readable and writable.

All bits are cleared to zero when the RESET pin is asserted. When the port A submode field is relevant in a mode/submode definition, it must not be altered unless the H12 enable bit in the port general control register is clear (see Table 1-3 located on foldout pages 1 and 2 at the end of this document). Altering these bits will give unpredictable results.

#### 3.2 PORT B CONTROL REGISTER

|   | Port B Control Register (PBCR) |   |            |   |   |                     |        |         |
|---|--------------------------------|---|------------|---|---|---------------------|--------|---------|
|   | 7                              | 6 | 5          | 4 | 3 | 2                   | 1      | 0       |
| Г |                                |   |            |   |   | H4                  | H3     | H3      |
|   | Port B<br>Submode              |   |            |   |   | Interrupt<br>Enable | SVCRQ  | Status  |
|   |                                |   | H4 Control |   |   | Enable              | Enable | Control |

The port B control register specifies the operation of port B and the handshake pins H3 and H4. The port B control register contains five fields: bits 7 and 6 specify the port B submode; bits 5, 4, and 3 control the operation of the H4 handshake pin and H4S status bit; bit 2 determines whether an interrupt will be generated when the H4S status bit goes to a one; bit 1 determines whether a service request (interrupt request or DMA request) will occur; and bit 0 controls the operation of the H3S status bit. The PBCR is always readable and writable. There is never a consequence to reading the register.

All bits are cleared to zero when the RESET pin is asserted. When the port B submode field is relevant in a mode/submode definition, it must not be altered unless the H34 enable bit in the port general control register is clear (see Table 1-3 located on foldout pages 1 and 2 at the end of this document).

#### 3.3 MODE 0 - UNIDIRECTIONAL 8-BIT MODE

In mode 0, ports A and B operate independently. Each may be configured in any of its three possible submodes:

Submode 00 - Pin-Definable Double-Buffered Input or Single-Buffered Output

Submode 01 - Pin-Definable Double-Buffered Output or Non-Latched Input

Submode 1X - Bit I/O (Pin-Definable Single-Buffered Output or Non-Latched Input)

Handshake pins H1 and H2 are associated with port A and configured by programming the port A control register. (The H12 enable bit of the port general control register enables port A transfers.) Handshake pins H3 and H4 are associated with port B and configured by programming the port B control register. (The H34 enable bit of the port general control register enables port B transfers.) The port A and B data direction registers operate in all three submodes. Along with the submode, they affect the data read and write at the associated data register according to Table 3-1. They also enable the output buffer associated with each port pin. The DMAREQ pin may be associated with either (not both) port A or port B, but does not function if the bit I/O submode (submode 1X) is programmed for the chosen port.

| Mode                                                                                                                                                              |                                             | Port A/B<br>Register                     | Write Port A/B<br>Data Register                         |                             |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|------------------------------------------|---------------------------------------------------------|-----------------------------|--|
|                                                                                                                                                                   | DDR=0                                       | DDR = 1                                  | DDR = X                                                 |                             |  |
| 0 Submode 00                                                                                                                                                      | FIL, D.B.                                   | FOL Note 3                               | FOL, S.B.                                               | Note 1                      |  |
| 0 Submode 01                                                                                                                                                      | Pin                                         | FOL Note 3                               | IOL/FOL, D.B.                                           | Note 2                      |  |
| 0 Submode 1X                                                                                                                                                      | Pin                                         | FOL Note 3                               | FOL, S.B.                                               | Note 1                      |  |
| IOL — Initial Output<br>FOL — Final Output<br>FIL — Final Input La                                                                                                | Latch                                       | D.B Do                                   | ngle Buffered<br>Suble Buffered<br>ata Direction Regist | er                          |  |
| off if the DE<br>Note 2: Data is latch                                                                                                                            | ed at the pin<br>DR is 0.<br>ed in the doul | if the DDR is 1. The ble-buffered output | ne output buffers wi<br>it data registers. The          | II be turned<br>data in the |  |
| final output latch will appear on the port pin if the DDR is a 1.<br>Note 3: The output drivers that connect the final output latch to the pins are turned<br>on. |                                             |                                          |                                                         |                             |  |

Table 3-1. Mode 0 Port Data Paths

#### 3.3.1 Submode 00 - Pin-Definable Double-Buffered Input or Single-Buffered Output

In mode 0, double-buffered input transfers of up to eight bits are available by programming submode 00 in the desired port's control register. Data that meets the port setup and hold times is latched on the asserted edge of H1(H3) and is placed in the initial or final input latch. H1(H3) is edge sensitive and may assume any duty cycle as long as both high and low minimum times are observed. The PI/T contains a port status register whose H1S(H3S) status bit is set anytime any input data that has not been read by the bus master is present in the double-buffered latches. The action of H2(H4) is programmable. The following options are available:

- H2(H4) may be an edge-sensitive status input that is independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H12 enable (H34 enable) bit of the port general register is clear.
- 2. H2(H4) may be a general-purpose output pin that is always negated. In this case the H2S(H4S) status bit is always clear.
- H2(H4) may be a general-purpose output pin that is always asserted. In this case the H2S(H4S) status bit is always clear.
- 4. H2(H4) may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H1(H3) input. As soon as the input latches become ready, H2(H4) is again asserted. When the input double-buffered latches are full, H2(H4) remains negated until data is removed. Thus, anytime the H2(H4) output is asserted, new input data may be entered by asserting H1(H3). At other times, transitions on H1(H3) are ignored. The H2S(H4S) status bit is always clear. When H12 enable (H34 enable) in the port general control register is clear, H2(H4) is held negated.
- 5. H2(H4) may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case of a subsequent H1(H3) asserted edge occurring before termination of the pulse, H2(H4) is negated asynchronously. Thus, anytime after the leading edge of the H2(H4) pulse, new data may be entered in the double-buffered input latches. The H2S(H4S) status bit is always clear. When H12 enable (H34 enable) is clear, H2(H4) is held negated.

For pins used as outputs, the data path consists of a single latch driving the output buffer. Data written to the port's data register does not affect the operation of any handshake pin or status bit. Output pins may be used independently of the input transfers. However, read bus cycles to the data register do remove data from the port. Therefore, care should be taken to avoid processor instructions that perform unwanted read cycles.

#### Programmable Options Mode 0 — Port A Submode 00 and Port B Submode 00 (Sheet 1 of 2)

| PACR  |                                                                          |
|-------|--------------------------------------------------------------------------|
| 76    | Port A Submode                                                           |
| 00    | Submode 00                                                               |
| PACR  |                                                                          |
| 543   | H2 Control                                                               |
| 0 X X | Input pin - edge-sensitive status input, H2S is set on an asserted edge. |
| 100   | Output pin – negated, H2S is always clear.                               |
| 101   | Output pin – asserted, H2S is always clear.                              |
| 110   | Output pin - interlocked input handshake protocol, H2S is always clear.  |
| 111   | Output pin - pulsed input handshake protocol, H2S is always clear.       |
| PACR  |                                                                          |
| 2     | H2 Interrupt Enable                                                      |
| 0     | The H2 interrupt is disabled.                                            |
|       |                                                                          |

1 The H2 interrupt is enabled.

#### Programmable Options Mode 0 — Port A Submode 00 and Port B Submode 00 (Sheet 2 of 2)

## PACR

#### H1 SVCR Enable

- 0 The H1 interrupt and DMA request are disabled.
- 1 The H1 interrupt and DMA request are enabled.

#### PACR 0 X

#### H1 Status Control

The H1S status bit is set anytime input data is present in the double-buffered input path.

#### PBCR

- 7 6 Port B Submode
- 0 0 Submode 00

#### PBCR

- 5 4 3 H4 Control
- 0 X X Input pin edge-sensitive status input, H4S is set on an asserted edge.
- 1 0 0 Output pin negated, H4S is always cleared.
- 1 0 1 Output pin asserted, H4S is always cleared.
- 1 1 0 Output pin interlocked input handshake protocol, H4S is always cleared.
- 1 1 1 Output pin pulsed input handshake protocol, H4S is always cleared.

#### PBCR 2

#### H4 Interrupt Enable

- 0 The H4 interrupt is disabled.
- 1 The H4 interrupt is enabled.

## PBCR

#### H3 SVCRQ Enable

- 0 The H3 interrupt and DMA request are disabled.
- 1 The H3 interrupt and DMA request are enabled.

#### PBCR 0

#### H3 Status Control

X The H3S status bit is set anytime input data is present in the double-buffered input path.

#### 3.3.2 Submode 01 - Pin-Definable Double-Buffered Output or Non-Latched Input

In mode 0, double-buffered output transfers of up to eight bits are available by programming submode 01 in the desired port's control register. The operation of H2 and H4 may be selected by programming the port A and B control registers, respectively. Data, written by the bus master to the PI/T, is stored in the port's output latches. The peripheral accepts the data by asserting H1(H3), which causes the next data to be moved to the port's output latch as soon as it is available.

The H1S(H3S) status bit may be programmed for two interpretations:

- 1. The H1S(H3S) status bit is set when either the port initial or final output latch can accept new data. It is cleared when both latches are full and cannot accept new data.
- 2. The H1S(H3S) status bit is set when both of the port output latches are empty. It is cleared when at least one latch is full.

The programmable options of the H2(H4) pin are:

1. H2(H4) may be an edge-sensitive input pin independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by either the

RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H1(H2) enable (H3(H4) enable) bit of the port general control register is clear.

- 2. H2(H4) may be a general-purpose output pin that is always negated. The H2S(H4S) status bit is always clear.
- 3. H2(H4) may be a general-purpose output pin that is always asserted. The H2S(H4S) status bit is always clear.
- 4. H2(H4) may be an output pin in the interlocked output handshake protocol. H2(H4) is asserted two clock cycles after data is transferred to the double-buffered output latches. The data remains stable at the port pins and H2(H4) remains asserted until the next asserted edge of the H1(H3) input. At that time, H2(H4) is asynchronously negated. As soon as the next data is available, it is transferred to the output latches. When H2(H4) is negated, asserted transitions of H1(H3) have no affect on data paths. The H2S(H4S) status bit is always clear. When H12 enable (H34 enable) is clear, H2(H4) is held negated.
- 5. H2(H4) may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock pulse is generated. But in the case that a subsequent H1(H3) asserted edge occurs before termination of the pulse, H2(H4) is negated asynchronously shortening the pulse. The H3S(H4S) status bit is always clear. When H12 enable (H34 enable) is clear H2(H4) is held negated.

For pins used as inputs, data written to the associated data register is double-buffered and passed to the initial or final output latch, but, the output buffer is disabled.

#### Programmable Options Mode 0 — Port A Submode 01 and Port B Submode 01 (Sheet 1 of 2)

#### PACR

7 6 Port A Submode

0 1 Submode 01

PACR

#### 5 4 3 H2 Control

0 X X Input pin - edge-sensitive status input, H2S is set on an asserted edge.

1 0 0 Output pin - negated, H2S is always clear.

1 0 1 Output pin - asserted, H2S is always clear.

- 1 1 0 Output pin interlocked input handshake protocol, H2S is always clear.
- 1 1 1 Output pin pulsed input handshake protocol, H2S is always clear.

#### PACR

2 H2 Interrupt Enable

0 The H2 interrupt is disabled.

1 The H2 interrupt is enabled.

#### PACR 1

#### H1 SVCRQ Enable

0 The H1 interrupt and DMA request are disabled.

1 The H1 interrupt and DMA request are enabled.

#### Programmable Options Mode 0 — Port A Submode 01 and Port B Submode 01 (Sheet 2 of 2)

## **PACR 0**

#### H1 Status Control

- The H1S status bit is set when either the port A initial or final output latch can accept new data. It is clear when both latches are full and cannot accept new data.
- The H1S status bit is one when both of the port A output latches are empty. It is clear when at least one latch is full.

#### PBCR

1

- 7 6 Port B Submode
- 0 1 Submode 01

#### PBCR

#### 5 4 3 H4 Control

- 0 X X Input pin edge-sensitive status input, H4S is set on an asserted edge.
- 1 0 0 Output pin negated, H4S is always cleared.
- 1 0 1 Output pin asserted, H4S is always cleared.
- 1 1 0 Output pin interlocked input handshake protocol, H4S is always cleared.
- 1 1 1 Output pin pulsed input handshake protocol, H4S is always cleared.

#### PBCR 2

#### H4 Interrupt Enable

- 0 The H4 interrupt is disabled.
- 1 The H4 interrupt is enabled.

#### PBCR 1

#### H3 SVCRQ Enable

- 0 The H3 interrupt and DMA request are disabled.
- 1 The H3 interrupt and DMA request are enabled.

#### PBCR

#### 0 H3 Status Control

- 0 The H3S status bit is set when either the port B initial or final output latch can accept new data. It is clear when both latches are full and cannot accept new data.
- 1 The H3S status bit is one when both of the port B output latches are empty. It is clear when at least one latch is full.

#### 3.3.3 Submode 1X - Bit I/O (Pin-Definable Single-Buffered Output or Non-Latched Input)

In mode 0, simple bit I/O is available by programming submode 1X in the desired port's control register. This submode is intended for applications in which several independent devices must be controlled or monitored. Data written to the associated (input/output) register is single buffered. If the data direction register bit for that pin is a one (output), the output buffer is enabled. If it is a zero (input), data written is still latched, but is not available at the pin. Data read from the data register is the instantaneous value of the pin or what was written to the data register, depending on the contents of the data direction register. H1(H3) is an edge-sensitive status input pin only and it controls no data related function. The H1S(H3S) status bit is set following the asserted edge of the input waveform. It is cleared by either the RESET pin being asserted, writing a one to the associated status bit in the port status register (PSR), or when the H12 enable (H34 enable) bit of the port general control register is clear. H2 may be programmed as:

 H2(H4) may be an edge-sensitive status input that is independent of H1(H3) and the transfer of port data. On the asserted edge of H2(H4), the H2S(H4S) status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H12 enable (H34 enable) bit of the port general control register is clear.

- 2. H2(H4) may be a general-purpose output pin that is always negated. In this case the H2S(H4S) status bit is always clear.
- 3. H2(H4) may be a general-purpose output pin that is always asserted. In this case the H2S(H4S) status bit is always clear.

#### Programmable Option Mode 0 — Port A Submode 1X and Port B Submode 1X (Sheet 1 of 2)

#### PACR

- 7 6 Port A Submode
- 1 X Submode 1X

#### PACR

### 5 4 3 H2 Control

- 0 X X Input pin edge-sensitive status input, H2S is set on an asserted edge.
- 1 X 0 Output pin negated, H2S is always cleared.
- 1 X 1 Output pin asserted, H2S is always cleared.

#### PACR

| 2 | H2 | Interrupt | Enable |
|---|----|-----------|--------|

- 0 The H2 interrupt is disabled.
- 1 The H2 interrupt is enabled.

# PACR

#### H1 SVCRQ Enable

- 0 The H1 interrupt is disabled.
- 1 The H1 interrupt is enabled.

#### PACR 0

#### H1 Status Control

X H1 is an edge-sensitive status input, H1S is set by an asserted edge of H1.

## PBCR

#### 7 6 Port B Submode

1 X Submode 1X

## PBCR

#### 5 4 3 H4 Control

- 0 X X Input pin edge-sensitive status input, H4S is set on an asserted edge.
- 1 X 0 Output pin negated, H4S is always cleared.
- 1 X 1 Output pin asserted, H4S is always cleared.

#### PBCR 2

#### H4 Interrupt Enable

- 0 The H4 interrupt is disabled.
- 1 The H4 interrupt is enabled.

#### PBCR 1

#### H3 SVCRQ Enable

- 0 The H3 interrupt is disabled.
- 1 The H3 interrupt is enabled.

#### Programmable Options Mode 0 — Port A Submode 1X and Port B Submode 1X (Sheet 2 of 2)

PBCR 0

H3 Status Control

X H3 is an edge-sensitive status input, H3S is set by an asserted edge of H3.

## 3.4 MODE 1 - UNIDIRECTIONAL 16-BIT MODE

In mode 1, ports A and B are concatenated to form a single 16-bit port. The port B submode field controls the configuration of both ports. The possible submodes are:

Port B Submode X0 - Pin-Definable Double-Buffered Input or Single-Buffered Output

Port B Submode X1 - Pin-Definable Double-Buffered Output or Non-Latched Input

Handshake pins H3 and H4, configured by programming the port B control register, are associated with the 16-bit double-buffered transfer. These 16-bit transfers are enabled by setting the H34 enable bit in the port general control register (PGCR). Handshake pins H1 and H2 may be used as simple status inputs not related to the 16-bit data transfer or H2 may be an output. Enabling of the H1 and H2 handshake pins is done by setting the H12 enable bit of the port general control register. The port A and B data direction registers operate in each submode. Along with the submode, they affect the data read and written at the data register according to Table 3-2. The data direction register also enables the output buffer associated with each port pin. The DMAREQ pin may be associated only with H3.

| Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           | d Port A/B<br>Register | Write Port A/B<br>Register                             |                             |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------------------|--------------------------------------------------------|-----------------------------|--|--|--|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DDR = 0   | DDR = 1                | DDR=0                                                  | DDR = 1                     |  |  |  |  |  |  |
| 1, Port B<br>Submode X0                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FIL, D.B. | FOL<br>Note 3          | FOL, S.B.<br>Note 2                                    | FOL, S.B.<br>Note 2         |  |  |  |  |  |  |
| 1, Port B<br>Submode X1                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Pin       | FOL<br>Note 3          | IOL/FOL,<br>D.B.,<br>Note 1                            | IOL/FOL,<br>D.B.,<br>Note 1 |  |  |  |  |  |  |
| <ul> <li>Note 1: Data written to Port A goes to a temporary latch. When the Port B data register is later written, Port A data is transferred to IOL/FOL.</li> <li>Note 2: Data is latched in the output data registers (final output latch) and will be single buffered at the pin if the DDR is 1. The output buffers will be turned off if the DDR is 0.</li> <li>Note 3: The output drivers that connect the final output latch to the pins are turned on.</li> </ul> |           |                        |                                                        |                             |  |  |  |  |  |  |
| Abbreviations:<br>IOL – Initial Output<br>FOL – Final Output<br>FIL – Final Input La                                                                                                                                                                                                                                                                                                                                                                                      | Latch     | D.B Do                 | ngle Buffered<br>buble Buffered<br>ata Direction Regis | ster                        |  |  |  |  |  |  |

Table 3-2. Mode 1 Port Data Paths

Mode 1 can provide convenient high-speed 16-bit transfers. The port A and port B data registers are addressed for compatibility with the MC68000 move peripheral (MOVEP) instruction and with the MC68450 direct memory access controller (DMAC). To take advantage of this, port A should contain the most-significant byte of data and always be read or written by the bus master first. The interlocked and pulsed handshake protocols, status bits, and DMAREQ are keyed to the access of port B data register in mode 1. Transfers proceed properly with interlocked or pulsed handshakes when the port B data register is accessed last.

#### 3.4.1 Port A Control Register

| 7         6         5         4         3         2         1         0           Port A         H2         H1         H1         H1         H1         H1         Status |           |      |   |           |   |           |        |         |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|---|-----------|---|-----------|--------|---------|--|--|
| Port A Interrupt SVCRQ Status                                                                                                                                             | 7 6 5 4 3 |      | 2 | 1         | 0 |           |        |         |  |  |
|                                                                                                                                                                           |           |      |   |           |   | H2        | H1     | H1      |  |  |
|                                                                                                                                                                           | Po        | rt A |   |           |   | Interrupt | SVCRQ  | Status  |  |  |
| Submode H2 Control Enable Enable Control                                                                                                                                  | Sub       | mode |   | H2 Contro | I | Enable    | Enable | Control |  |  |

Port A Control Register (PACR)

The port A control register, in conjunction with the programmed mode and the port B submode, controls the operation of port A and the handshake pins H1 and H2. The port A control register contains five fields: bits 7 and 6 specify the port A submode; bits 5, 4, and 3 control the operation of the H2 handshake pin and H2S status bit; bit 2 determines whether an interrupt will be generated when the H2S status bit goes to one; bit 1 determines whether a service request (interrupt request or DMA request) will occur; and bit 0 controls the operation of the H1S status bit. The PACR is always readable and writable. There is never a consequence to reading the register.

All bits are cleared to zero when the RESET pin is asserted. When the port A submode field is relevant in a mode/submode definition, it must not be altered unless the H12 enable bit in the port general control register is clear (see Table 1-3 located on foldout pages 1 and 2 at the end of this document). Altering these bits may give unpredictable results if the H12 enable bit in the PGCR is set.

#### 3.4.2 Port B Control Register

#### Port B Control Register (PBCR) л 3 ٥ 5 2 H3 H3 H4 SVCRO Port B Interrup Status Submode H4 Control Enable Enable Control

The port B control register specifies the operation of port B and the handshake pins H3 and H4. The port B control register contains five fields: bits 7 and 6 specify the port B submode; bits 5, 4, and 3 control the operation of the H4 handshake pin and H4S status bit goes to a one; bit 1 determines whether a service request (interrupt request or DMA request) will occur; and bit 0 controls the operation of the H3S status bit. The PBCR is always readable and writable.

All bits are cleared to zero when the RESET pin is asserted. When the port B submode field is relevant in a mode/submode definition, it must not be altered unless the H34 enable bit in the port general control register is clear (see Table 1-3 located on foldout pages 1 and 2 at the end of this document). Altering these bits may give unpredictable results if the H12 enable bit in the PGCR is set.

#### 3.4.3 Submode X0 — Pin-Definable Double-Buffered Input or Single-Buffered Output

In mode 1 submode X0, double-buffered input transfers of up to 16 bits may be obtained. The level of each pin is asynchronously latched with the asserted edge of H3 and placed in the initial input latch or the final input latch. The processor may check the H3S status bit to determine if new data is present. The DMAREQ pin may be used to signal a DMA controller to empty the input buffers. Regardless of the bus master, port A data should be read first and port B data should be read last. The operation of the internal handshake controller, the H3S bit, and the DMAREQ are keyed to the reading of the port B data register. (The MC68450 DMAC can be programmed to perform the exact transfers needed for compatibility with the PI/T.) H4 may be programmed as:

- 1. H4 may be an edge-sensitive status input that is independent of H3 and the transfer of port data. On the asserted edge of H4, the H4S status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H34 enable bit of the port general control register is clear.
- 2. H4 may be a general-purpose output pin that is always negated. In this case the H4S status bit is always clear.
- 3. H4 may be a general-purpose output pin that is always asserted. In this case the H4S status bit is always clear.
- 4. H4 may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H3 input. As soon as the input latches become ready, H4 is again asserted. When the input double-buffered latches are full, H4 remains negated until data is removed. Thus, anytime the H4 output is asserted, new input data may be entered by asserting H3. At other times transitions on H3 are ignored. The H4S status bit is always clear. When H34 enable in the port general control register is clear, H4 is held negated.
- 5. H4 may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H3 asserted edge occurs before termination of the pulse, H4 is negated asynchronously. Thus, anytime after the leading edge of the H4 pulse, new data may be entered in the double-buffered input latches. The H4S status bit is always clear. When H34 enable is clear, H4 is held negated.

For pins used as outputs, the data path consists of a single latch driving the output buffer. Data written to the port's data register does not affect the operation of any handshake pin, status bit, or any other aspect of the PI/T. Thus, output pins may be used independently of the input transfer.

The programmable options of the H2 pin are:

- 1. H2 may be an edge-sensitive input pin independent of H1 and the transfer of port data. On the asserted edge of H2, the H2S status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H12 enable bit of the port general control register is clear.
- 2. H2 may be a general-purpose output pin that is always negated. The H2S status bit is always clear.
- 3. H2 may be a general-purpose output pin that is always asserted. The H2S status bit is always clear.

## Programmable Options Mode 1 – Port A Submode XX and Port B Submode X0

## PACR

| <b>76</b><br>00                                                          | Port A Submode<br>Submode XX                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PACR</b><br>5 4 3<br>0 X X<br>1 X 0<br>1 X 1                          | H2 Control<br>Input pin – edge-sensitive status input, H2S is set on an asserted edge.<br>Output pin – negated, H2S is always cleared.<br>Output pin – asserted, H2S is always cleared.                                                                                                        |
| <b>PACR</b><br>2<br>0<br>1                                               | H2 Interrupt Enable<br>The H2 interrupt is disabled.<br>The H2 interrupt is enabled.                                                                                                                                                                                                           |
| <b>PACR</b><br>1<br>0<br>1                                               | H1 SVCRQ Enable<br>The H1 interrupt is disabled.<br>The H1 interrupt is enabled.                                                                                                                                                                                                               |
| PACR<br>0<br>X                                                           | H1 Status Control<br>H1 is an edge-sensitive status input. H1S is set by an asserted edge of H1.                                                                                                                                                                                               |
| <b>PBCR</b><br><b>7 6</b><br>0 0                                         | Port B Submode<br>Submode X0                                                                                                                                                                                                                                                                   |
| <b>PBCR</b><br><b>5 4 3</b><br>0 X X<br>1 0 0<br>1 0 1<br>1 1 0<br>1 1 1 | H4 Control<br>Input pin – edge-sensitive status input, H4S is set on an asserted edge.<br>Output pin – negated, H4S is always cleared.<br>Output pin – asserted, H4S is always cleared.<br>Output pin – interlocked input handshake protocol.<br>Output pin – pulsed input handshake protocol. |
| <b>PBCR</b><br>2<br>0<br>1                                               | H2 Interrupt Enable<br>The H4 interrupt is disabled.<br>The H4 interrupt is enabled.                                                                                                                                                                                                           |
| <b>PBCR</b><br>1                                                         | H3 SVCRQ Enable                                                                                                                                                                                                                                                                                |

The H3 interrupt and DMA request are disabled.
 The H3 interrupt and DMA request are enabled.

#### PBCR 0 X

#### H3 Status Control

The H3S status bit is set anytime input data is present in the double-buffered input path.

## 3.4.4 Submode X1 - Pin-Definable Double-Buffered Output or Non-Latched Input

In mode 1 submode X1, double-buffered output transfers of up to 16 bits may be obtained. Data is written by the bus master (processor or DMA controller) in two bytes. The first byte (most significant) is written to the port A data register. It is stored in a temporary latch until the next byte is written to the port B data register. Then all 16 bits are transferred to one of the output latches of ports A and B. The DMAREQ pin may be used to signal a DMA controller to transfer another word to the port output latches. (The MC68450 DMAC can be programmed to perform the exact transfers needed for compatibility with the PI/T.) H4 may be programmed as:

- 1. H4 may be an edge-sensitive status input that is independent of H3 and the transfer of port data. On the asserted edge of H4, the H4S status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H34 enable bit of the port general control register is clear.
- 2. H4 may be a general-purpose output pin that is always negated. In this case the H4S status bit is always clear.
- 3. H4 may be a general-purpose output pin that is always asserted. In this case the H4S status bit is always clear.
- 4. H4 may be an output pin in the interlocked output handshake protocol. H4 is asserted two clock cycles after data is transferred to the double-buffered output latches. The data remains stable at the port pins and H4 remains asserted until the next asserted edge of the H3 input. At that time, H4 is asynchronously negated. As soon as the next data is available, it is transferred to the output latches. When H4 is negated, asserted transitions of H3 have no affect on data paths. The H4S status bit is always clear. When H34 enable is clear, H4 is held negated.
- 5. H4 may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock pulse is generated. But in the case that a subsequent H3 asserted edge occurs before termination of the pulse, H4 is negated asynchronously shortening the pulse. The H4S status bit is always cleared. When H34 enable is clear, H4 is held negated.

The H3S status bit may be programmed for two interpretations:

- 1. The H3S status bit is set when either the port initial or final output latch can accept new data. It is clear when both latches are full and cannot accept new data.
- 2. The H3S status bit is set when both of the port output latches are empty. It is clear when at least one latch is full.

The programmable options of the H2 pin are:

- 1. H2 may be an edge-sensitive input pin independent of H1 and the transfer of port data. On the asserted edge of H2, the H2S status bit is set. It is cleared by either the RESET pin being asserted, writing a one to the particular status bit in the port status register (PSR), or when the H12 enable bit of the port general control register is clear.
- 2. H2 may be a general-purpose output pin that is always negated. The H2S status bit is always clear.
- 3. H2 may be a general-purpose output pin that is always asserted. The H2S status bit is always clear.

For pins used as inputs, data written to either data register is double buffered and passed to the initial or final output latch, as usual, but the output buffer is disabled (refer to 3.3.2 Submode 01 -Pin-Definable Double-Buffered Output or Non-Latched Input).

#### Programmable Options Mode 1 - Port A Submode XX and Port B Submode X1 (Sheet 1 of 2)

## PACR

76 Port A Submode

00 Submode XX

PACR

#### 543 H2 Control

0 X X Input pin - edge-sensitive status input, H2S is set on an asserted edge.

- 1 X 0 Output pin - negated, H2S is always cleared.
- 1 X 1 Output pin asserted, H2S is always cleared.

#### PACR

#### H2 Interrupt Enable

| 2 | H2 Interrupt Enable                |
|---|------------------------------------|
| 0 | The H2 interrupt is disabled.      |
| 4 | The life is a second second second |

The H2 interrupt is enabled. 1

#### PACR 1

| H1 SVCRQ E | Enabl | е |
|------------|-------|---|
|------------|-------|---|

0 The H1 interrupt is disabled.

1 The H1 interrupt is enabled.

## PACR

0 H1 Status Control

Х H1 is an edge-sensitive status input. H1S is set by an asserted edge of H1.

#### PBCR

#### 76 Port B Submode

00 Submode X1

#### PBCR

#### 543 H4 Control

- 0 X X Input pin edge-sensitive status input, H4S is set on an asserted edge.
- 100 Output pin - negated, H4S is always cleared.
- Output pin asserted, H4S is always cleared. 101
- Output pin interlocked input handshake protocol. 110
- 111 Output pin - pulsed input handshake protocol.

#### PBCR

2 H4 Interrupt Enable

0 The H4 interrupt is disabled.

1 The H4 interrupt is enabled.

#### Programmable Options Mode 1 - Port A Submode XX and Port B Submode X1 (Sheet 2 of 2)

#### PBCR 1

#### H3 SVCRQ Enable

- 0 The H3 interrupt and DMA request are disabled. 1
  - The H3 interrupt and DMA request are enabled.

#### PBCR n

#### H3 Status Control

- · 0 The H3S status bit is set when either the initial or final output latch of ports A and B can accept new data. It is clear when both latches are full and cannot accept new data. 1
  - The H3S status bit is set when both the initial and final output latches of ports A and B are empty. The H3S status bit is clear when a t least one set of output latches is full.

#### 3.5 MODE 2 - BIDIRECTIONAL 8-BIT MODE

In mode 2, port A is used for bit I/O with no associated handshake pins. Port B is used for bidirectional 8-bit double-buffered transfers. H1 and H2, enabled by the H12 enable bit in the port general control register, control output transfers, while H3 and H4, enabled by the port general control register bit H34 enable, control input transfers. The instantaneous direction of the data is determined by the H1 handshake pin. The port B data direction register is not used. The port A and port B submode fields do not affect PI/T operation in mode 2.

#### 3.5.1 Port A Bit I/O (Pin-Definable Single-Buffered Output or Non-Latched Input)

Mode 2, port A performs simple bit I/O with no associated handshake pins. This configuration is intended for applications in which several independent devices must be controlled or monitored. Data written to the port A data register is single buffered. If the port A data direction register bit for that pin is set (output), the output buffer is enabled. If it is zero (input), data written is still latched but not available at the pin. Data read from the data register is either the instantaneous value of the pin (if data is stable from CS asserted to DTACK asserted, data on these pins will be guaranteed valid in the data register) or what was written to the data register, depending on the contents of the port A data direction register. This is summarized in Table 3-3.

| er     | Data Reg      | ert A<br>pister |  |
|--------|---------------|-----------------|--|
| DR = 1 | DDR = 0       | DDR = 1         |  |
| FOL    | FOL           | FOL, S.B.       |  |
|        | DR = 1<br>FOL | DR = 1 DDR = 0  |  |

## 3.5.2 Port B - Double-Buffered Bidirectional Data

The output buffers of port B are controlled by the level of H1. When H1 is negated, the port B output buffers (all eight) are enabled and the pins drive the bidirectional bus. Generally, H1 is negated by the peripheral in response to an asserted H2, which indicates that new output data is present in the double-buffered latches. Following acceptance of the data, the peripheral asserts H1, disabling the port B output buffers. Other than controlling the output buffers, H1 is edge-sensitive as in other modes.

**3.5.2.1 DOUBLE-BUFFERED INPUT TRANSFERS.** Port B input data that meets the port setup and hold times is latched on the asserted edge of H3 and placed in the initial input latch or the final input latch. H3 is edge-sensitive, and may assume any duty-cycle as long as both high and low minimum times are observed. The PI/T contains a port status register whose H3S status bit is set anytime any input data that has not been read by the bus master is present in the double-buffered latches. The action of H4 is programmable and can be programmed as:

- H4 may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H3 input. As soon as the input latches become ready, H4 is again asserted. When the input double-buffered latches are full, H4 remains negated until data is removed. Thus, anytime the H4 output is asserted, new input data may be entered by asserting H3. At other times transitions on H3 are ignored. The H4S status bit is always clear. When H34 enable in the port general control register is clear, H4 is held negated.
- 2. H4 may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H3 asserted edge occurs before termination of the pulse, H4 is negated asynchronously. Thus, anytime after the leading edge of the H4 pulse, new data may be entered in the double-buffered input latches. The H4S status bit is always clear. When H34 enable is clear, H4 is held negated.

**3.5.2.2 DOUBLE-BUFFERED OUTPUT TRANSFERS.** Data, written by the bus master to the PI/T, is stored in the port's output latch. The peripheral accepts the data by asserting H1, which causes the next data to be moved to the port's output latch as soon as it is available. The H1S status bit, in the port status register, may be programmed for two interpretations. Normally the status bit is a one when there is at least one latch in the double-buffered data path that can accept new data. After writing one byte of data to the ports, an interrupt service routine could check this bit to determine if it could store another byte; thus filling both latches. When the bus master is finished, it is often useful to be able to check whether all of the data has been transferred to the peripheral. The H1S status bit is set when both output latches are empty. The programmable options for H2 are:

- 1. H2 may be an output pin in the interlocked output handshake protocol. It is asserted when the port output latches are ready to transfer new data. It is negated asynchronously following the asserted edge of the H1 input. As soon as the output latches become ready, H2 is again asserted. When the output double-buffered latches are full, H2 remains asserted until data is removed. Thus, anytime the H2 output is asserted, new output data may be transferred by asserting H1. At other times transitions on H1 are ignored. The H2S status bit is always clear. When H12 enable in the port general control register is clear, H2 is held negated.
- 2. H2 may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked input protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H1 asserted edge occurs before termination of the pulse, H2 is negated asynchronously. Thus, anytime after the leading edge of the H2 pulse, new data may be transferred to the double-buffered output latches. The H2S status bit is always clear. When H12 enable is clear, H2 is held negated.

The DMAREQ pin may be associated with either input transfers (H3) or output transfers (H1), but not both. Refer to Table 3-4 for a summary of the port B data register responses in mode 2.

## Table 3-4. Mode 2 Port B Data Paths

| Mode                                                                                      | Read Port B<br>Data Register | Write Port B<br>Data Register |
|-------------------------------------------------------------------------------------------|------------------------------|-------------------------------|
| 2                                                                                         | FIL, D.B.                    | IOL/FOL, D.B                  |
| Abbreviations:<br>OL – Initial Output L<br>FOL – Final Output L<br>FIL – Final Input Late | atch D.B                     | Double Buffered               |

#### Programmable Options Mode 2 - Port A Submode XX and Port B Submode XX (Sheet 1 of 2)

## PACR

- 76 Port A Submode
- ХХ Submode XX

## PACR

- 543 H2 Control
- X X 0 Output pin interlocked output handshake protocol, H2S is always cleared. X X 1 Output pin pulsed output handshake protocol, H2S is always cleared.

#### PACR 2

## H2 Interrupt Enable

- The H2 interrupt is disabled. 0
- The H2 interrupt is enabled. 1

#### PACR 1

#### H1 SVCRQ Enable

- 0 The H1 interrupt and DMA request are disabled.
- The H1 interrupt and DMA request are enabled. 1

#### PACR 0

#### H1 Status Control

- 0 The H1 status bit is set when either the port B initial or final output latch can accept new data. It is clear when both latches are full and cannot accept new data.
- The H1S status bit is set when both of the port B output latches are empty. It is clear when at least 1 one latch is full.

## PBCR

#### 76 Port B Submode

ХХ Submode XX

#### PBCR

#### 543 H4 Control

- X X 0 Output pin interlocked input handshake protocol, H4S is always cleared.
- Output pin pulsed input handshake protocol, H4S is always cleared. X X 1

#### PBCR 2

#### H4 Interrupt Enable

- 0 The H4 interrupt is disabled.
- 1 The H4 interrupt is enabled.

#### Programmable Options Mode 2 – Port A Submode XX and Port B Submode XX (Sheet 2 of 2)

# **PBCR** 1

## H3 SVCRQ Enable

The H3 interrupt and DMA request are disabled.

1 The H3 interrupt and DMA request are enabled.

#### PBCR 0

## H3 Status Control

X The H3S status bit is set anytime input data is present in the double-buffered input path.

## 3.6 MODE 3 - BIDIRECTIONAL 16-BIT MODE

In mode 3, ports A and B are used for bidirectional 16-bit double-buffered transfers. H1 and H2 control output transfers, while H3 and H4 control input transfers. H1 and H2 are enabled by the H12 enable bit while H3 and H4 are enabled by the H34 enable bit of the port general control register. The instantaneous direction of data is determined by the H1 handshake pin, thus, the data direction registers are not used and have no affect. The port A and port B submode fields do not affect PI/T operation in mode 3. Port A and port B output buffers are controlled by the level of H1. When H1 is negated, the output buffers (all 16) are enabled and the pins drive the bidirectional port bus. Generally a peripheral will negate H1 in response to an asserted H2, which indicates that new output data is present in the double-buffered latches. Following acceptance of the data, the peripheral asserts H1, disabling the output buffers. Other than controlling the output buffers, H1 is edgesensitive as in other modes. The port A and port B data direction registers are not used.

## 3.6.1 Double-Buffered Input Transfers

Port A and B input data that meets the port setup and hold times is latched on the asserted edge of H3 and placed in the initial input latch or the final input latch. H3 is edge-sensitive, and may assume any duty-cycle as long as both high and low minimum times are observed. The PI/T contains a port status register whose H3S status bit is set anytime any input data is present in the double-buffered latches that has not been read by the bus master. The action of H4 is programmable and can be programmed as:

- 1. H4 may be an output pin in the interlocked input handshake protocol. It is asserted when the port input latches are ready to accept new data. It is negated asynchronously following the asserted edge of the H3 input. As soon as the input latches become ready, H4 is again asserted. When the input double-buffered latches are full, H4 remains negated until data is removed. Thus, anytime the H4 output is asserted, new input data may be entered by asserting H3. At other times transitions on H3 are ignored. The H4S status bit is always clear. When H34 enable in the port general control register is clear, H4 is held negated.
- 2. H4 may be an output pin in the pulsed input handshake protocol. It is asserted exactly as in the interlocked input protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock cycle pulse is generated. But in the case that a subsequent H3 asserted edge occurs before termination of the pulse, H4 is negated asynchronously. Thus, anytime after the leading edge of the H4 pulse, new data may be entered in the double-buffered input latches. The H4 status bit is always clear. When H34 enable is clear, H4 is held negated.

#### 3.6.2 Double-Buffered Output Transfers

Data, written by the bus master to the PI/T, is stored in the port's output latch. The peripheral accepts the data by asserting H1, which causes the next data to be moved to the port's output latch as soon as it is available. The H1S status bit, in the port status register, may be programmed for two interpretations. Normally the status bit is a one when there is at least one latch in the double-buffered data path that can accept new data. After writing one byte of data to the ports, an interrupt service routine could check this bit to determine if it could store another byte; thus filling both latches. When the bus master is finished, it is often useful to be able to check whether all of the data has been transferred to the peripheral. The H1S status control bit of the port A control register provides this flexibility. The H1S status bit is set when both output latches are empty. The programmable options for H2 are:

- 1. H2 may be an output pin in the interlocked output handshake protocol. It is asserted when the port output latches are ready to transfer new data. It is negated asynchronously following the asserted edge of the H1 input. As soon as the output latches become ready, H2 is again asserted. When the output double-buffered latches are full, H2 remains asserted until data is removed. Thus, anytime the H2 output is asserted, new output data may be transferred by asserting H1. At other times transitions on H1 are ignored. The H2S status bit is always clear. When H12 enable in the port general control register is clear, H2 is held negated.
- 2. H2 may be an output pin in the pulsed output handshake protocol. It is asserted exactly as in the interlocked output protocol above, but never remains asserted longer than four clock cycles. Typically, a four clock pulse is generated. But in the case that a subsequent H1 asserted edge occurs before termination of the pulse, H2 is negated asynchronously shortening the pulse. The H2S status bit is always zero. When H12 enable is zero, H2 is held negated.

Mode 3 can provide convenient high-speed 16-bit transfers. The port A and B data registers are addressed for compatibility with the MC68000's move peripheral (MOVEP) instruction and with the MC68450 DMAC. To take advantage of this, port A should contain the most significant data and always be read or written by the bus master first. The interlocked and pulsed handshake protocols, status bits, and DMAREQ are keyed to the access of port B data register in mode 3. If it is accessed last, the 16-bit double-buffered transfer proceeds smoothly.

The DMAREQ pin may be associated with either input transfers (H3) or output transfers (H1), but not both. Refer to Table 3-5 for a summary of the port A and B data paths in mode 3.

| Node                                      | Read Port A and B<br>Data Register | Write Port A and B<br>Data Register                   |
|-------------------------------------------|------------------------------------|-------------------------------------------------------|
| 3                                         | FIL, D.B.                          | IOL/FOL, D.B., Note 1                                 |
|                                           | ater written, Port A data is tra   | ary latch. When the Port B data ansferred to IOL/FOL. |
| IOL - Initial Output                      | tLatch S.B. –                      | Single Buffered                                       |
| FOL - Final Output<br>FIL - Final Input L |                                    | Double Buffered                                       |

Table 3-5. Mode 3 Port A and B Data Paths

## Programmable Options Mode 3 — Port A Submode XX and Port B Submode XX

#### PACR

- 7 6 Port A Submode
- X X Submode XX

#### PACR 543

## H2 Control

- X X 0 Output pin interlocked output handshake protocol, H2S status always cleared.
- X X 1 Output pin pulsed output handshake protocol, H2S status always cleared.

#### PACR 2

#### H2 Interrupt Enable

0 The H2 interrupt is disabled.

1 The H2 interrupt is enabled.

#### **PACR** 1 0

#### H1 SVCRQ Enable

- The H1 interrupt and DMA request are disabled.
- The H1 interrupt and DMA request are enabled.

## 1 PACR 0

#### H1 Status Control

- 0 The H1 status bit is set when either the port B initial or final output latch can accept new data. It is clear when both latches are full and cannot accept new data.
- 1 The H1S status bit is set when both of the port B output latches are empty. It is clear when at least one latch is full.

## PBCR

## 7 6 Port B Submode

X X Submode XX

#### PBCR

## 5 4 3 H4 Control

- X X 0 Output pin interlocked input handshake protocol, H4S is always clear.
- X X 1 Output pin pulsed input handshake, H4S is always clear.

#### PBCR 2

### H4 Interrupt Enable

- 0 The H4 interrupt is disabled.
- 1 The H4 interrupt is enabled.

#### PBCR 1

#### H3 SVCRQ Enable

- 0 The H3 interrupt and DMA request are disabled.
- 1 The H3 interrupt and DMA request are enabled.

#### PBCR 0

#### H3 Status Control

X The H3S status bit is set anytime input data is present in the double-buffered input path.

3-19/3-20

,

## SECTION 4 PROGRAMMER'S MODEL

This section describes the internal accessible register organization as represented in Table 1-3 located on foldout pages 1 and 2 at the end of this document and in Table 4-1. Address space within the address map is reserved for future expansion.

|                                 |         |   |   |   | ter<br>Bit | 3 |            | Affected by | Affected<br>by Read |
|---------------------------------|---------|---|---|---|------------|---|------------|-------------|---------------------|
| Register                        |         | 5 | 4 | 3 | 2          | 1 | Accessible | Reset       | Cycle               |
| Port General Control Register   | (PGCR)  | 0 | 0 | 0 | 0          | 0 | RW         | Yes         | No                  |
| Port Service Request Register   | (PSRR)  | 0 | 0 | 0 | 0          | 1 | RW         | Yes         | No                  |
| Port A Data Direction Register  | (PADDR) | 0 | 0 | 0 | 1          | 0 | RW         | Yes         | No                  |
| Port B Data Direction Register  | (PBDDR) | 0 | 0 | 0 | 1          | 1 | RW         | Yes         | No                  |
| Port C Data Direction Register  | (PCDDR) | 0 | 0 | 1 | 0          | 0 | RW         | Yes         | No                  |
| Port Interrupt Vector Register  | (PIVR)  | 0 | 0 | 1 | 0          | 1 | RW         | Yes         | No                  |
| Port A Control Register         | (PACR)  | 0 | 0 | 1 | 1          | 0 | RW         | Yes         | No                  |
| Port B Control Register         | (PBCR)  | 0 | 0 | 1 | 1          | 1 | RW         | Yes         | No                  |
| Port A Data Register            | (PADR)  | 0 | 1 | 0 | 0          | 0 | RW         | No          | **                  |
| Port B Data Register            | (PBDR)  | 0 | 1 | 0 | 0          | 1 | RW         | No          | **                  |
| Port A Alternate Register       | (PAAR)  | 0 | 1 | 0 | 1          | 0 | R          | No          | No                  |
| Port B Alternate Register       | (PBAR)  | 0 | 1 | 0 | 1          | 1 | R          | No          | No                  |
| Port C Data Register            | (PCDR)  | 0 | 1 | 1 | 0          | 0 | RW         | No          | No                  |
| Port Status Register            | (PSR)   | 0 | 1 | 1 | 0          | 1 | RW*        | Yes         | No                  |
| Timer Control Register          | (TCR)   | 1 | 0 | 0 | 0          | 0 | RW         | Yes         | No                  |
| Timer Interrupt Vector Register | (TIVR)  | 1 | 0 | 0 | 0          | 1 | RW         | Yes         | No                  |
| Counter Preload Register High   | (CPRH)  | 1 | 0 | 0 | 1          | 1 | RW         | No          | No                  |
| Counter Preload Register Middle | (CPRM)  | 1 | 0 | 1 | 0          | 0 | RW         | No          | No                  |
| Counter Preload Register Low    | (CPRL)  | 1 | 0 | 1 | 0          | 1 | RW         | No          | No                  |
| Count Register High             | (CNTRH) | 1 | 0 | 1 | 1          | 1 | R          | No .        | No                  |
| Count Register Middle           | (CNTRM) | 1 | 1 | 0 | 0          | 0 | R          | No          | No                  |
| Count Register Low              | (CNTRL) | 1 | 1 | 0 | 0          | 1 | R          | No          | No                  |
| Timer Status Register           | (TSR)   | 1 | 1 | 0 | 1          | 0 | R W*       | Yes         | No                  |

## Table 4-1. PI/T Register Addressing Assignments

\* A write to this register may perform a special status resetting operation. \* \* Mode dependent. R = Read W = Write

Throughout this section the following conventions are maintained:

- 1. A read from a reserved location in the map results in a read from the "null register." The null register returns all zeros for data and results in a normal bus cycle. A write to one of these locations results in a normal bus cycle, but written data is ignored.
- 2. Unused bits of a defined register are denoted by "\*" and are read as zeros; written data is ignored.

- Bits that are unused in the chosen mode/submode but are used in others are denoted by "X", and are readable and writable. Their content, however, is ignored in the chosen mode/submode.
- 4. All registers are addressable as 8-bit quantities. To facilitate operation with the MOVEP instruction and the DMAC, addresses are ordered such that certain sets of registers may also be accessed as words (two bytes) or long words (four bytes).

#### 4.1 PORT GENERAL CONTROL REGISTER (PGCR)

# Port General Control Register (PGCR) 6 5 4 3 2 1 0

| , ,       |        |        |       | ~     |       |       |  |
|-----------|--------|--------|-------|-------|-------|-------|--|
| Port Mode | H34    | H12    | H4    | Н3    | H2    | H1    |  |
| Control   | Enable | Enable | Sense | Sense | Sense | Sense |  |

The port general control register controls many of the functions that are common to the overall operation of the ports. The PGCR is composed of three major fields: bits 7 and 6 define the operational mode of ports A and B and affect operation of the handshake pins and status bits; bits 5 and 4 allow a software-controlled disabling of particular hardware associated with the handshake pins of each port; and bits 3-0 define the sense of the handshake pins. The PGCR is always readable and writable.

All bits are reset to zero when the RESET pin is asserted.

The port mode control field should be altered only when the H12 enable and H34 enable bits are zero. Except when mode zero is desired (submode 1X), the port general control register should be written once to establish the mode with the H12 and H34 bits clear. Any other necessary control registers can then be programmed, after which H12 or H34 is set. In order to enable the respective operation(s), the port general control register should be written again.

#### PGCR

## 7 6 Port Mode Control

- 0 0 Mode 0 (Unidirectional 8-Bit Mode)
- 0 1 Mode 1 (Unidirectional 16-Bit Mode)
- 1 0 Mode 2 (Bidirectional 8-Bit Mode)
- 1 1 Mode 3 (Bidirectional 16-Bit Mode)

PGCR 5 0

5 H34 Enable

#### Disabled

1 Enabled

PGCR

#### H12 Enable

- 0 Disabled
- 1 Enabled

#### PGCR 3-0

#### Handshake Pin Sense

- 0 The associated pin is at the high-voltage level when negated and at the low-voltage level when asserted.
- 1 The associated pin is at the low-voltage level when negated and at the high-voltage level when asserted.

# 4.2 PORT SERVICE REQUEST REGISTER (PSRR)

Port Service Request Register (PSRR)

| 7 | 6   | 5     | 4  | 3     | 2              | 1          | 0    |
|---|-----|-------|----|-------|----------------|------------|------|
|   | SVO | SVCRQ |    | ation | Port Interrupt |            | pt   |
|   | Se  | lect  | Se | ect   | Pr             | iority Con | trol |

The port service request register controls other functions that are common to the overall operation to the ports. It is composed of four major fields: bit 7 is unused and is always read as zero; bits 6 and 5 define whether interrupt or DMA requests are generated from activity on the H1 and H3 hand-shake pins; bits 4 and 3 determine whether two dual-function pins operate as port C or port interrupt request/acknowledge pins; and bits 2, 1, and 0 control the priority among all port interrupt sources. Since bits 2, 1, and 0 affect interrupt operation, it is recommended that they be changed only when the affected interrupt(s) is (are) disabled or known to remain inactive. The PSRR is always readable and writable.

All bits are reset to zero when the RESET pin is asserted.

#### PSRR

#### 6 5 SVCRQ Select

0 X The PC4/DMAREQ pin carries the PC4 function; DMA is not used.

#### PSRR SVCRQ Select

- 1 0 The PC4/DMAREQ pin carries the DMAREQ function and is associated with double-buffered transfers controlled by H1. H1 is removed from the PI/T's interrupt structure, and thus, does not cause interrupt requests to be generated. To obtain DMAREQ pulses, port A control register bit 1 (H1 SVCRQ enable) must be a one.
- 1 1 The PC4/DMAREQ pin carries the DMAREQ function and is associated with double-buffered transfers controlled by H3. H3 is removed from the PI/T's interrupt structure, and thus, does not cause interrupt requests to be generated. To obtain DMAREQ pulses, port B control register bit 1 (H3 SVCRQ enable) must be one.

#### PSRR

#### 4 3 Interrupt Pin Function Select

- 0 0 The PC5/PIRQ pin carries the PC5 function, no interrupt support.
  - The PC6/PIACK pin carries the PC6 function, no interrupt support.
- 0 1 The PC5/PIRO pin carries the PIRO function, supports autovectored interrupts. The PC6/PIACK pin carries the PC6 function, supports autovectored interrupts.
- 1 0 The PC5/PIRQ pin carries the PC5 function.
- The PC6/PIACK pin carries the PIACK function.
- 1 1 The PC5/PIRQ pin carries the PIRQ function, supports vectored interrupts. The PC6/PIACK pin carries the PIACK function, supports vectored interrupts.

Bits 2, 1, and 0 determine port interrupt priority. The priority as shown in Table 4-2 is in descending order left to right.

| Table 4-2. | PSRR | Port | Interrupt | Priority | Control |
|------------|------|------|-----------|----------|---------|
|------------|------|------|-----------|----------|---------|

| 210 | Highest |     |     | Lowest |
|-----|---------|-----|-----|--------|
| 000 | H1S     | H2S | H3S | H4S    |
| 001 | H2S     | H1S | H3S | H4S    |
| 010 | H1S     | H2S | H4S | H3S    |
| 011 | H2S     | H1S | H4S | H3S    |

| 210 | HighestLowest |     |     |     |  |  |  |  |  |
|-----|---------------|-----|-----|-----|--|--|--|--|--|
| 100 | H3S           | H4S | H1S | H2S |  |  |  |  |  |
| 101 | H3S           | H4S | H2S | H1S |  |  |  |  |  |
| 110 | H4S           | H3S | H1S | H2S |  |  |  |  |  |
| 111 | H4S           | H3S | H2S | H1S |  |  |  |  |  |

#### **4.3 PORT DATA DIRECTION REGISTERS**

The following paragraphs describe the port data direction registers.

#### 4.3.1 Port A Data Direction Register (PADDR)

The port A data direction register determines the direction and buffering characteristics of each of the port A pins. One bit in the PADDR is assigned to each pin. A zero indicates that the pin is used as a input, while a one indicates it is used as an output. The PADDR is always readable and writable. This register is ignored in mode 3.

All bits are reset to the zero (input) state when the RESET pin is asserted.

#### 4.3.2 Port B Data Direction Register (PBDDR)

The PBDDR is identical to the PADDR for the port B pins and the port B data register, except that this register is ignored in modes 2 and 3.

#### 4.3.3 Port C Data Direction Register (PCDDR)

The port C data direction register specifies whether each dual-function pin that is chosen for port C operation is an input (zero) or an output (one) pin. The PCDDR, along with bits that determine the respective pin's function, also specify the exact hardware to be accessed at the port C data register address (see **4.6.3 Port C Data Register (PCDR)** for more details). The PCDDR is an 8-bit register that is readable and writable at all times. Its operation is independent of the chosen PI/T mode.

These bits are cleared to zero when the RESET pin is asserted.

### 4.4 PORT INTERRUPT VECTOR REGISTER (PIVR)

#### Port Interrupt Vector Register (PIVR)

| 7 | 6   | 5          | 4  | 3 | 2 | 1 | 0 |
|---|-----|------------|----|---|---|---|---|
|   | Int | errupt Veo | er |   | ٠ | • |   |

The port interrupt vector register contains the upper order six bits of the four port interrupt vectors. The contents of this register may be read two ways: by an ordinary read cycle, or by a port interrupt acknowledge bus cycle. The exact data read depends on how the cycle was initiated and other factors. Behavior during a port interrupt acknowledge cycle is summarized in Table 2-1.

From a normal read cycle, there is never a consequence to reading this register. Following negation of the RESET pin, but prior to writing to the PIVR, a \$0F will be read. After writing to the register, the upper six bits may be read and the lower two bits are forced to zero. No prioritization computation is performed.

#### 4.5 PORT CONTROL REGISTERS (PACR, PBCR)

The port A and B control registers (PACR and PBCR) are described in **SECTION 3 PORT MODES**. The description is organized such that for each mode/submode all programmable options of each pin and status bit are given.

## 4.6 PORT DATA REGISTERS

The following paragraphs describe the port data registers.

### 4.6.1 Port A Data Register (PADR)

The port A data register is a holding register for moving data to and from the port A pins. The port A data direction register determines whether each pin is an input (zero) or an output (one), and is used in configuring the actual data paths. The data paths are described in **SECTION 3 PORT MODES**.

This register is readable and writable at all times. Depending on the chosen mode/submode, reading or writing may affect the double-buffered handshake mechanism. The port A data register is not affected by the assertion of the RESET pin.

#### 4.6.2 Port B Data Register (PBDR)

The port B data register is a holding register for moving data to and from port B pins. The port B data direction register determines whether each pin is an input (zero) or an output (one), and is used in configuring the actual data paths. The data paths are described in **SECTION 3 PORT MODES**.

This register is readable and writable at all times. Depending on the chosen mode/submode, reading or writing may affect the double-buffered handshake mechanism. The port B data register is not affected by the assertion of the RESET pin.

## 4.6.3 Port C Data Register (PCDR)

The port C data register is a holding register for moving data to and from each of the eight port C/alternate-function pins. The exact hardware accessed is determined by the type of bus cycle (read or write) and individual conditions affecting each pin. These conditions are: 1) whether the pin is used for the port C or alternate function, and 2) whether the port C data direction register indicates the input or output direction. The port C data register is single buffered for output pins and non-latched for input pins. These conditions are summarized in Table 4-3.

|                            | Port C                                    | Function                                 | Alternate Function |                    |  |
|----------------------------|-------------------------------------------|------------------------------------------|--------------------|--------------------|--|
| Operation                  | PCDDR=0                                   | PCDDR = 1                                | PCDDR=0            | PCDDR = 1          |  |
| Read Port C Data Register  | Pin                                       | Output<br>Register                       | Pin                | Output<br>Register |  |
| Write Port C Data Register | Output<br>Register,<br>Buffer<br>Disabled | Output<br>Register,<br>Buffer<br>Enabled | Output<br>Register | Output<br>Register |  |

Note that two additional useful benefits result from this structure. First, it is possible to directly read the state of a dual-function pin while used for the non-port C function. Second, it is possible to generate program controlled transitions on alternate-function pins by switching back to the port C function and writing to the PCDR.

This register is readable and writable at all times and operation is independent of the chosen PI/T mode. The port C data register is not affected by the assertion of the RESET pin.

#### 4.7 PORT ALTERNATE REGISTERS

The following paragraphs describe the port alternate registers.

#### 4.7.1 Port A Alternate Register (PAAR)

The port A alternate register is an alternate register for reading the port A pins. It is a read-only address and no other PI/T condition is affected. In all modes, the instantaneous pin level is read and no input latching is performed except at the data bus interface. Writes to this address are answered with DTACK, but the data is ignored.

#### 4.7.2 Port B Alternate Register (PBAR)

The port B alternate register is an alternate register for reading the port B pins. It is a read-only address and no other PI/T condition is affected. In all modes, the instantaneous pin level is read and no input latching is performed except at the data bus interface. Writes to this address are answered with DTACK, but the data is ignored.

#### 4.8 PORT STATUS REGISTER (PSR)

| Port Status Register (PSR) |          |          |          |     |     |     |     |  |  |
|----------------------------|----------|----------|----------|-----|-----|-----|-----|--|--|
| 7 6 5 4 3 2 1 0            |          |          |          |     |     |     |     |  |  |
| H4 Level                   | H3 Level | H2 Level | H1 Level | H4S | H3S | H2S | H1S |  |  |

The port status register contains information about handshake pin activity. Bits 7-4 show the instantaneous level of the respective handshake pin, and are independent of the handshake pin sense bits in the port general control register. Bits 3-0 are the respective status bits referred to throughout this document. Their interpretation depends on the programmed mode/submode of the PI/T. For bits 3-0 a one is the active or asserted state.

#### 4.9 TIMER CONTROL REGISTER (TCR)

#### Timer Control Register (TCR)

| 7 | 6          | 5 | 4       | 3       | 2   | 1      | 0 |
|---|------------|---|---------|---------|-----|--------|---|
| T | TOUT/TIACK |   |         | *       | Cic | Timer  |   |
|   | Control    |   | Control | Control |     | Enable |   |

The timer control register (TCR) determines all operations of the timer. Bits 7-5 configure the PC3/TOUT and PC7/TIACK pins for port C, square wave, vectored interrupt, or autovectored interrupt operation; bit 4 specifies whether the counter receives data from the counter preload register or continues counting when zero detect is reached; bit 3 is unused and is read as zero; bits 2 and 1 configure the path from the CLK and TIN pins to the counter controller; and bit 0 enables the timer. This register is readable and writable at all times. All bits are cleared to zero when the RESET pin is asserted.

## TCR

#### 7 6 5 TOUT/TIACK Control

- 0 0 X The dual-function pins PC3/TOUT and PC7/TIACK carry the port C function.
- 0 1 X The dual-function pin PC3/TOUT carries the TOUT function. In the run state it is used as a square-wave output and is toggled on zero detect. The TOUT pin is high while in the halt state. The dual-function pin PC7/TIACK carries the PC7 function.

- 1 0 0 The dual-function pin PC3/TOUT carries the TOUT function. In the run or halt state it is used as a timer interrupt request output. The timer interrupt is disabled; thus, the pin is always three stated. The dual-function pin PC7/TIACK carries the TIACK function; however, since interrupt request is negated, the PI/T produces no response (i.e., no data or DTACK) to an asserted TIACK. Refer to 5.1.3 Timer Interrupt Acknowledge Cycles for details.
- 1 0 1 The dual-function pin PC3/TOUT carries the TOUT function and is used as a timer interrupt request output. The timer interrupt is enabled; thus, the pin is low when the timer ZDS status bit is one. The dual-function pin PC7/TIACK carries the TIACK function and is used as a timer interrupt acknowledge input. Refer to the 5.1.3 Timer Interrupt Acknowledge Cycles for details. This combination supports vectored timer interrupts.
- 1 1 0 The dual-function pin PC3/TOUT carries the TOUT function. In the run or halt state it is used as a timer interrupt request output. The timer interrupt is disabled; thus, the pin is always three-stated. The dual-function pin PC7/TIACK carries the PC7 function.
- 1 1 1 The dual-function pin PC3/TOUT carries the TOUT function and is used as a timer interrupt request output. The timer interrupt is enabled; thus, the pin is low when the timer ZDS status bit is one. The dual-function pin PC7/TIACK carries the PC7 function and autovectored interrupts are supported.

#### TCR 4

#### Zero Detect Control

- 0 The counter is loaded from the counter preload register on the first clock to the 24-bit counter after zero detect, then resumes counting.
  - The counter rolls over on zero detect, then continues counting.

## TCR

1

3 Unused and is always read as zero.

#### TCR

#### 2 1 Clock Control

- 0 0 The PC2/TIN input pin carries the port C function, and the CLK pin and prescaler are used. The prescaler is decremented on the falling transition of the CLK pin; the 24-bit counter is decremented, rolls over, or is loaded from the counter preload registers when the prescaler rolls over from \$00 to \$1F. The timer enable bit determines whether the timer is in the run or halt state.
- 0 1 The PC2/TIN pin serves as a timer input, and the CLK pin and prescaler are used. The prescaler is decremented on the falling transition of the CLK pin; the 24-bit counter is decremented, rolls over, or is loaded from the counter preload registers when the prescaler rolls over from \$00 to \$1F. The timer is in the run state when the timer enable bit is one and the TIN pin is high; otherwise, the timer is in the halt state.
- 1 0 The PC2/TIN pin serves as a timer input and the prescaler is used. The prescaler is decremented following the rising transition of the TIN pin after being synchronized with the internal clock. The 24-bit counter is decremented, rolls over, or is loaded from the counter preload registers when the prescaler rolls over from \$00 to \$1F. The timer enable bit determines whether the timer is in the run or halt state.
- 1 1 The PC2/TIN pin serves as a timer input and the prescaler is not used. The 24-bit counter is decremented, rolls over, or is loaded from the counter preload registers following the rising edge of the TIN pin after being synchronized with the internal clock. The timer enable bit determines whether the timer is in the run or halt state.

#### 

#### Timer Enable

- 0 Disabled
- 1 Enabled

## 4.10 TIMER INTERRUPT VECTOR REGISTER (TIVR)

The timer interrupt vector register contains the 8-bit vector supplied when the timer interrupt acknowledge pin TIACK is asserted. The register is readable and writable at all times, and the same value is always obtained from a normal read cycle or a timer interrupt acknowledge bus cycle (TIACK). When the RESET pin is asserted the value of \$0F is loaded into the register. Refer to **5.1.3** Timer Interrupt Acknowledge Cycles for more details.

#### 4.11 COUNTER PRELOAD REGISTER H, M, L (CPRH-L)

#### Counter Preload Register H, M, L (CPRH-L)

| 7     | 6     | 5     | 4      | 3     | 2     | 1     | 0     | _    |
|-------|-------|-------|--------|-------|-------|-------|-------|------|
|       |       |       | Bit 20 |       |       |       |       |      |
|       |       |       | Bit 12 |       |       |       |       |      |
| Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | CPRL |

The counter preload registers are a group of three 8-bit registers used for storing data to be transferred to the counter. Each of the registers is individually addressable, or the group may be accessed with the MOVEP.L or the MOVEP.W instructions. The address \$12 (one less than the address of CPRH) is the null register and is reserved so that zeros are read in the upper eight bits of the destination data register when a MOVEP.L is used. Data written to this address is ignored.

These registers are readable and writable at all times. A read cycle proceeds independently of any transfer to the counter, which may be occurring simultaneously. To insure proper operation of the PI/T timer, a value of \$000000 may not be stored in the counter preload registers for use with the counter. The RESET pin does not affect the contents of these registers.

#### 4.12 COUNT REGISTER H, M, L (CNTRH-L)

#### Count Register H, M, L (CNTRH-L)

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      | _     |
|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| Bit 23 | Bit 22 | Bit 21 | Bit 20 | Bit 19 | Bit 18 | Bit 17 | Bit 16 | CNTRH |
| Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8  | CNTRM |
| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | CNTRL |

The count registers are a group of three 8-bit addresses at which the counter can be read. The contents of the counter are not latched during a read bus cycle; thus, the data read at these addresses is not guaranteed if the timer is in the run state. Write operations to these addresses result in a normal bus cycle but the data is ignored.

Each of the registers is individually addressable, or the group may be accessed with the MOVEP.L or the MOVEP.W instructions. The address, one less than the address CNTRH, is the null register and is reserved so that zeros are read in the upper eight bits of the destination data register when a MOVEP.L is used. Data written to this address is ignored.

#### 4.13 TIMER STATUS REGISTER (TSR)

#### Timer Status Register (TSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|---|---|---|---|---|---|---|-----|
| • | * | • | * | * | • | • | ZDS |

The timer status register contains one bit from which the zero detect status can be determined. The ZDS status bit (bit 0) is an edge-sensitive flip-flop that is set to one when the 24-bit counter decrements from \$000001 to \$000000. The ZDS status bit is cleared to zero following the direct reset operation or when the timer is halted. Note that when the RESET pin is asserted the timer is disabled, and thus enters the halt state.

This register is always readable without consequence. A write access performs a direct reset operation if bit 0 in the written data is one. Following that, the ZDS bit is zero.

This register is constructed with a reset dominant S-R flip-flop so that all clearing conditions prevail over the possible zero detect condition.

Bits 7-1 are unused and are read as zero.

### 4.14 REGISTER VALUE AFTER RESET

Table 1-3, located on foldout pages 1 and 2 at the end of this document, shows the values that remain or are changed after a reset. Note that interrupt vector registers are initialized to \$0F. For the port interrupt vector register, the only time that bits 0 and 1 are set is after reset.

.

. . .

. . .

.

.

## SECTION 5 TIMER OPERATION AND APPLICATIONS SUMMARY

This section describes the programmable options available, capabilities, and restrictions that apply to the timer. Programming of the timer control register is outlined with several examples given.

#### 5.1 TIMER OPERATION

The MC68230 timer can provide several facilities needed by M68000 operating systems. It can generate periodic interrupts, a square wave, or a single interrupt after a programmed time period. Also, it can be used for elapsed time measurement or as a device watchdog.

The PI/T timer contains a 24-bit synchronous down counter that is loaded from three 8-bit counter preload registers. The 24-bit counter may be clocked by the output of a 5-bit (divide-by-32) prescaler or by an external timer input (TIN). If the prescaler is used, it may be clocked by the system clock (CLK pin) or by the TIN external input. The counter signals the occurrence of an event primarily through zero detection. (A zero is when the counter of the 24-bit timer is equal to zero.) This sets the zero detect status (ZDS) bit in the timer status register. It may be checked by the processor or may be used to generate a timer interrupt. The ZDS bit can be reset by writing a one to the timer status register in that bit position independent of timer operation.

The general operation of the timer is flexible and easily programmable. The timer is fully configured and controlled by programming the 8-bit timer control register (refer to **4.9 TIMER CONTROL REGISTER (TCR)** for additional information). It controls: 1) the choice between the port C operation and the timer operation of three timer pins, 2) whether the counter is loaded from the counter preload register or rolls over when zero detect is reached, 3) the clock input, 4) whether the prescaler is used, and 5) whether the timer is enabled.

#### 5.1.1 Run/Halt Definition

The overall operation of the timer is described in terms of the run or halt states. The control of the current state is determined by programming the timer control register. When in the halt state, all of the following occur:

- 1. The prior content of the counter is not altered and is reliably readable via the count registers.
- 2. The prescaler is forced to \$1F whether or not it is used.
- 3. The ZDS status bit is forced to zero, regardless of the possible zero contents of the 24-bit counter.

The run state is characterized by:

- 1. The counter is clocked by the source programmed in the timer control register.
- 2. The counter is not reliably readable.
- 3. The prescaler is allowed to decrement if programmed for use.
- 4. The ZDS status bit is set when the 24-bit counter transitions from \$000001 to \$000000.

### 5.1.2 Timer Rules

The following is a set of rules that allow easy application of the timer.

- 1. Refer to 5.1.1 Run/Halt Definition.
- 2. When the RESET pin is asserted, all bits of the timer control register are cleared, configuring the dual function pins as port C inputs.
- 3. The contents of the counter preload registers and counter are not affected by the RESET pin.
- 4. The count registers provide a direct read data path from each portion of the 24-bit counter, but data written to their addresses is ignored. (This results in a normal bus cycle.) These registers are readable at any time, but their contents are never latched. Unreliable data may be read when the timer is in the run state.
- The counter preload registers are readable and writable at any time and this occurs independently of any timer operation. No protection mechanisms are provided against ill-timed writes.
- The input frequency to the 24-bit counter from the TIN pin or prescaler output must be between zero and the input frequency at the CLK pin divided by eight, regardless of the configuration chosen.
- 7. For configurations in which the prescaler is used (with the CLK pin or TIN pin as an input), the contents of the counter preload register (CPR) is transferred to the counter the first time that the prescaler passes from \$00 to \$1F (rolls over) after entering the run state. Thereafter, the counter decrements, rolls over, or is loaded from the counter preload register each time the prescaler rolls over.
- 8. For configurations in which the prescaler is not used, the contents of the counter preload registers are transferred to the counter on the first asserted edge of the TIN input after entering the run state. On subsequent asserted edges the counter decrements, rolls over, or is loaded from the counter preload registers.
- 9. The smallest value allowed in the counter preload register for use with the counter is \$000001.

## 5.1.3 Timer Interrupt Acknowledge Cycles

Several conditions may be present when the timer interrupt acknowledge pin (TIACK) is asserted. These conditions affect the PI/T's response and the termination of the bus cycle (see Table 5-1).

| PC3/TOUT Function                          | Response to Asserted TIACK     |
|--------------------------------------------|--------------------------------|
| PC3 – Port C Pin                           | No Response<br>No DTACK        |
| TOUT Square Wave                           | No Response<br>No DTACK        |
| TOUT - Negated Timer<br>Interrupt Request  | No Response<br>No DTACK        |
| TOUT - Asserted Timer<br>Interrupt Request | Timer Interrupt Vector Content |

#### Table 5-1. Response to Timer Interrupt Acknowledge

## 5.2 TIMER APPLICATIONS SUMMARY

The following paragraphs outline programming of the timer control register for several typical examples.

## 5.2.1 Periodic Interrupt Generator Example

|   | Peri      | iodic lı | nterrupt G      | ienera | tor Exan | nple |                 |
|---|-----------|----------|-----------------|--------|----------|------|-----------------|
| 7 | 6         | 5        | 4               | 3      | · 2      | 1    | 0               |
|   | COUT/TIAC | ĸ        | Z.D.<br>Control | •      | Clo      |      | Timer<br>Enable |
| 1 | x         | 1        | 0               | 0      | 00 o     | r 1X | Changed         |

In this configuration the timer generates a periodic interrupt. The TOUT pin is connected to the system's interrupt request circuitry and the TIACK pin may be used as an interrupt acknowledge input to the timer. The TIN pin may be used as a clock input.

The processor loads the counter preload registers (CPR) and timer control register (TCR), and then enables the timer. When the 24-bit counter passes from \$000001 to \$000000, the ZDS status bit is set and the TOUT (interrupt request) pin is asserted. At the next clock to the 24-bit counter, it is again loaded with the contents of the CPRs and thereafter decrements. In normal operation, the processor must direct clear the status bit to negate the interrupt request (see Figure 5-1).





#### 5.2.2 Square Wave Generator

|       |              | Squ      | lare Wave        | e Gene | rator |   |                 |
|-------|--------------|----------|------------------|--------|-------|---|-----------------|
| 7     | 6            | 5        | 4                | 3      | 2     | 1 | 0               |
| T     |              | <u>K</u> | Z. D.<br>Control | •      | Clo   |   | Timer<br>Enable |
| <br>0 | Control<br>1 | x        |                  |        | 00 0  |   | Changed         |

In this configuration the timer produces a square wave at the TOUT pin. The TOUT pin is connected to the user's circuitry and the TIACK pin is not used. The TIN pin may be used as a clock input.

The processor loads the counter preload registers and timer control register, and then enables the timer. When the 24-bit counter passes from \$000001 to \$000000 the ZDS status bit is set and the

TOUT (square wave output) pin is toggled. At the next clock to the 24-bit counter it is again loaded with the contents of the CPRs, and thereafter decrements. In this application there is no need for the processor to direct clear the ZDS status bit; however, it is possible for the processor to sync itself with the square wave by clearing the ZDS status bit, then polling it. The processor may also read the TOUT level at the port C address.

Note that the PC3/TOUT pin functions as PC3 following the negation of RESET. If used in the square wave configuration, a pullup resistor may be required to keep a known level prior to programming. Prior to enabling the timer, TOUT is high (see Figure 5-2).



Figure 5-2. Square Wave Generator Example

## 5.2.3 Interrupt After Timeout

|    |                       | int | errupt Aft       | er Tim | eout         |    |                 |
|----|-----------------------|-----|------------------|--------|--------------|----|-----------------|
| .7 | 6                     | 5   | 4                | 3      | 2            | 1_ | 0               |
|    | TOUT/TIACK<br>Control |     | Z. D.<br>Control | •      | Cloc<br>Cont |    | Timer<br>Enable |
| 1  | x                     | 1   | 1                | 0      | 00 or        | 1X | Changed         |

In this configuration the timer generates an interrupt after a programmed time period has expired. The TOUT pin is connected to the system's interrupt request circuitry and the TIACK pin may be an interrupt acknowledge input to the timer. The TIN pin may be used as a clock input.

This configuration is similar to the periodic interrupt generator except that the zero detect control bit is set. This forces the counter to roll over after zero detect is reached, rather than reloading from the CPRs. When the processor takes the interrupt it can halt the timer, read the counter and calculate the time from the interrupt request to entering the service routine. Accurate knowledge of the interrupt latency may be useful in some applications (see Figure 5-3).



Figure 5-3. Single Interrupt After Timeout Example

#### 5.2.4 Elapsed Time Measurement Examples

Elapsed time measurement takes several forms; two forms are described in the following paragraphs.

**5.2.4.1 SYSTEM CLOCK EXAMPLE.** This configuration allows time interval measurement by software. The TIN pin may be used as an external timer enable if desired.

|   |                     | Sy       | stem Clo         | ck Exa | mple |              |                 |
|---|---------------------|----------|------------------|--------|------|--------------|-----------------|
| 7 | 6                   | 5        | 4                | 3      | 2    | 1            | 0               |
| Т | OUT/TIAC<br>Control | <u>K</u> | Z. D.<br>Control | *      |      | ock<br>htrol | Timer<br>Enable |
| 0 | 0                   | X        | 1                | 0      | 0    | 0            | Changed         |

The processor loads the counter preload registers (generally with all ones), loads the timer control register, and then enables the timer. The counter is allowed to decrement until the ending event takes place. When it is desired to read the time interval, the processor must halt the timer and then read the counter. If TIN is used as an enable, the start and stop counter functions are controlled externally.

For applications in which the interval may exceed the programmed time interval, zero detection can be counted by polling the status register or through interrupts to simulate additional timer bits. Note that the ZDS bit is latched and should be cleared after each detection of zero. At the end, the timer can be halted and read (see Figure 5-4).



\* Analog representation of counter value.

#### Figure 5-4. Elapsed Time Measurement Example

**5.2.4.2 EXTERNAL CLOCK.** This configuration allows measurement (counting) of the number of input pulses occurring in an interval in which the counter is enabled. The TIN input pin provides the input pulses. Generally the TOUT and TIACK pins are not used.

|       |                     |   | External         | Clock |            |   |                 |
|-------|---------------------|---|------------------|-------|------------|---|-----------------|
| <br>7 | 6                   | 5 | 4                | 3     | 2          | 1 | 0               |
| ٦     | OUT/TIAC<br>Control | ĸ | Z. D.<br>Control | *     | Clc<br>Con |   | Timer<br>Enable |
| 0     | 0                   | X | 1                | 0     | 1          | x | Changed         |

This configuration is similar to the elapsed time measurement/system clock configuration except that the TIN pin is used to provide the input frequency. It can be connected to a simple oscillator and the same methods could be used. Alternately, it could be gated off and on externally and the number of cycles occurring while in the run state can be counted. However, minimum pulse width high and low specifications must be met.

#### 5.2.5 Device Watchdog

**Device Watchdog Example** 

| 7 | 6       | 5   | 4       | 3 | 2   | 1     | 0       |
|---|---------|-----|---------|---|-----|-------|---------|
|   | TOUT/TI | ACK | Z. D.   | • | Clo | ock   | Timer   |
|   | Contro  | bl  | Control |   | Cor | ntrol | Enable  |
| 1 | X       | 1   | 1       | 0 | 0   | 1     | Changed |

This configuration provides the watchdog function needed in many systems. The TIN pin is the timer input whose period at the high (one) level is to be checked. Once allowed by the processor, the TIN input pin controls the run/halt mode. The TOUT pin is connected to external circuitry requiring notification when the TIN pin has been asserted longer than the programmed time. The TIACK pin (timer interrupt acknowledge) is only needed if the TOUT pin is connected to the interrupt circuitry.

The processor loads the counter preload register and timer control register, and then enables the timer. When the TIN input is asserted (one, high) the timer transfers the contents of the counter preload register to the counter and begins counting. If the TIN input is negated before zero detect is reached, the TOUT output and the ZDS status bit remain negated. If zero detect is reached while the TIN input is still asserted, the ZDS status bit is set and the TOUT output is asserted. (The counter rolls over and keeps counting.)



In either case, when the TIN input is negated the ZDS status bit is zero, the TOUT output is negated, the counting stops, and the prescaler is forced to all ones (see Figure 5-5).

Figure 5-5. Device Watchdog Example

•

## SECTION 6 ELECTRICAL SPECIFICATIONS

This section contains electrical specifications and associated timing information for the MC68230.

#### 6.1 MAXIMUM RATINGS

| Characteristics             | Symbol | Value         | Unit |
|-----------------------------|--------|---------------|------|
| Supply Voltage              | Vcc    | -0.3 to +7.0  | V    |
| Input Voltage               | Vin    | -0.3 to +7.0  | V    |
| Operating Temperature Range | TA     | 0 to 70       | °C   |
| Storage Temperature         | Tstg   | - 55 to + 150 | °C   |

#### 6.2 THERMAL CHARACTERISTICS

| Characteristics    | Symbol | Value | Rating |  |  |
|--------------------|--------|-------|--------|--|--|
| Thermal Resistance |        |       |        |  |  |
| Ceramic            | Αίθ    | 50    | °C/W   |  |  |
| Plastic            |        | TBD   |        |  |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precuations 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 VSS or VCC).

#### 6.3 POWER CONSIDERATIONS

The average chip-junction temperature, TJ, in °C can be obtained from:

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

Where:

T<sub>A</sub> = Ambient Temperature, °C

 $\theta_{JA}$  = Package Thermal Resistance, Junction-to-Ambient, °C/W

PD = PINT + PI/O

 $P_{INT} = I_{CC} \times V_{CC}$ , Watts – Chip Internal Power

PI/O = Power Dissipation on Input and Output Pins – User Determined

For most applications  $P_{I/O} < P_{INT}$  and can be neglected.

An approximate relationship between PD and TJ (if  $P_{I/O}$  is neglected) is:

 $P_{D} = K + (T_{J} + 273 °C)$ Solving equations 1 and 2 for K gives:  $K = P_{D} \bullet (T_{A} + 273 °C) + \theta_{J} A \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>.

(1)

# 6.4 DC ELECTRICAL CHARACTERISTICS (V\_{CC}=5.0 Vdc $\pm5\%$ , T\_A=0 to 70°C, unless otherwise noted)

| Characteristics                                                                                                                                                                                |                                                                              | Symbol | Min                  | Max         | Unit     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--------|----------------------|-------------|----------|
| Input High Voltage                                                                                                                                                                             | All Inputs                                                                   | VIH    | VSS+2.0              | Vcc         | V        |
| Input Low Voltage                                                                                                                                                                              | All Inputs                                                                   | VIL    | VSS-0.3              | VSS+0.8     | V        |
| Input Leakage Current (V <sub>in</sub> = 0 to 5.25 V) H1, H3, F                                                                                                                                | R/W, RESET, CLK, RS1-RS5, CS                                                 | lin    | -                    | 10.0        | μA       |
| Hi-Z (Off State) Input Current (Vin=0.4 to 2.4)                                                                                                                                                | DTACK, PC0-PC7, D0-D7<br>H2, H4, PA0-PA7, PB0-PB7                            | ITSI   | -0.1                 | 20<br>- 1.0 | μA<br>mA |
| Output High Voltage<br>(I <sub>Load</sub> = -400 μA, V <sub>C</sub> C = min)<br>(I <sub>Load</sub> = -150 μA, V <sub>C</sub> C = min)<br>(I <sub>Load</sub> = -100 μA, V <sub>C</sub> C = min) | DTACK, D0-D7<br>H2, H4, PB0-PB7, PA0-PA7<br>PC0-PC7                          | ∨он    | V <sub>SS</sub> +2.4 | -           | v        |
| Output Low Voltage<br>ii_Load = 8 8 mA, V <sub>C</sub> C = min)<br>ii_Load = 5.3 mA, V <sub>C</sub> C = min)<br>ii_Load = 2.4 mA, V <sub>C</sub> C = min) PA0-PA7, PB0-PB7,                    | PC3/TOUT, PC5/ <u>PIRQ</u><br>D0-D7, DTACK<br>H2, H4, PC0-PC2, PC4, PC6, PC7 | VOL    | -                    | 0.5         | v        |
| Internal Power Dissipation (Measured at $T_A = 0$ °C)                                                                                                                                          |                                                                              | PINT   | -                    | 750         | mW       |
| Input Capacitance ( $V_{in} = 0$ , $T_A = 25^{\circ}C$ , $f = 1 \text{ MHz}$ )                                                                                                                 |                                                                              | Cin    | -                    | 15          | pF       |

.

6.5 AC ELECTRICAL SPECIFICATIONS - CLOCK TIMING (See Figure 6-1)

|                           | 8 MHz      |          | 10         | MHz      | 12.5 MHz   |          |            |      |
|---------------------------|------------|----------|------------|----------|------------|----------|------------|------|
| Characteristic            | Symbol     | Min      | Max        | Min      | Max        | Min      | Max        | Unit |
| Frequency of Operation    | f          | 2.0      | 8.0        | 2.0      | 10.0       | 4.0      | 12.0       | MHz  |
| Cycle Time                | tcyc       | 125      | 500        | 100      | 500        | 80       | 250        | ns   |
| Clock Pulse Width         | tCL<br>tCH | 55<br>55 | 250<br>250 | 45<br>45 | 250<br>250 | 35<br>35 | 125<br>125 | ns   |
| Clock Rise and Fall Times | tCr<br>tCf | _        | 10<br>10   | -        | 10<br>10   | -        | 5<br>5     | ns   |



Figure 6-1. Clock Input Timing Diagram

.

|          |                                                                              | <u> </u> | ЛНz | 10  | MHz  | 12.5 | 12.5 MHz |       |
|----------|------------------------------------------------------------------------------|----------|-----|-----|------|------|----------|-------|
| Number   | Characteristic                                                               | Min      | Max | Min | Max  | Min  | Max      | Unit  |
| 1        | R/W, RS1 RS5 Valid to CS Low (Setup Time)                                    | 0        | -   | 0   | -    | 0    | -        | ns    |
| 2(10)    | CS Low to R. W and RS1-RS5 Invalid (Hold Time)                               | 100      | -   | 65  | -    | 60   | -        | ns    |
| 3(1)     | CS Low to CLK Low (Setup Time)                                               | 30       | -   | 20  | -    | 20   | -        | ns    |
| 4(2)     | CS Low to Data Out Valid                                                     | -        | 75  | -   | 60   | -    | 55       | ns    |
| 5        | RS1-RS5 Valid to Data Out Valid                                              | -        | 140 | -   | 100  | _    | 80       | ns    |
| 6        | CLK Low to DTACK Low (Read/Write Cycle)                                      | 0        | 70  | 0   | 60   | 0    | 55       | ns    |
| 7(3)     | DTACK Low to CS High (Hold Time)                                             | 0        | -   | 0   | -    | 0    | -        | ns    |
| 8        | CS or PIACK or TIACK High to Data Out Invalid                                | 0        | -   | 0   | -    | 0    |          | ns    |
| 9        | CS or PIACK or TIACK High to D0-D7<br>High Impedance                         | -        | 50  | -   | 45   | -    | 45       | ns    |
| 10       | CS or PIACK or TIACK High to DTACK High                                      |          | 50  | -   | 45   | _    | 40       | ns    |
| 11       | CS or PIACK or TIACK High to DTACK<br>High Impedance                         | -        | 100 | -   | 55   | -    | 45       | ns    |
| 12       | Data In Valid to CS Low (Setup Time)                                         | 0        | _   | 0   | -    | 0    | -        | ns    |
| 13       | CS Low to Data In Invalid (Hold Time)                                        | 100      |     | 65  | - 1  | 60   | -        | ns    |
| 14       | Port Input Data Valid to H1(H3) Asserted<br>(Setup Time)                     | 100      | _   | 60  | -    | 50   | -        | ns    |
| 15       | H1(H3) Asserted to Port Input Data Invalid<br>(Hold Time)                    | 20       | -   | 20  | -    | 20   | -        | ns    |
| 16       | Handshake Input H1(H4) Pulse Width Asserted                                  | 40       | -   | 40  | -    | 40   | _        | ns    |
| 17       | Handshake Input H1(H4) Pulse Width Negated                                   | 40       |     | 40  | -    | 40   | _        | ns    |
| 18       | H1(H3) Asserted to H2(H4) Negated (Delay Time)                               |          | 150 | -   | 120  | _    | 100      | ns    |
| 19       | CLK Low to H2(H4) Asserted (Delay Time)                                      |          | 100 |     | 100  | -    | 80       | ns    |
| 20(4)    | H2(H4) Asserted to H1(H3) Asserted                                           | 0        | -   | 0   | -    | 0    | -        | ns    |
| 21(5)    | CLK Low to H2(H4) Pulse Negated (Delay Time)                                 | -        | 125 |     | 125  | -    | 100      | ns    |
| 22(9,11) | Synchronized H1(H3) to CLK Low on which<br>DMAREQ is Asserted                | 2.5      | 3.5 | 2.5 | 3.5  | 2.5  | 3.5      | CLK F |
| 23       | CLK Low on which DMAREQ is Asserted to CLK<br>Low on which DMAREQ is Negated | 2.5      | 3   | 2.5 | 3    | 2.5  | 3        | CLK F |
| 24       | CLK Low to Port Output Data Valid (Delay Time)<br>(Modes 0 and 1)            | _        | 150 | -   | 120  | -    | 100      | ns    |
| 25(9,11) | Synchronized H1(H3) to Port Output Data Invalid<br>(Modes 0 and 1)           | 1.5      | 2.5 | 1.5 | 2.5  | 1.5  | 2.5      | CLK F |
| 26       | H1 Negated to Port Output Data Valid<br>(Modes 2 and 3)                      | -        | 70  | -   | - 50 | -    | 50       | ns    |
| 27       | H1 Asserted to Port Output Data High Impedance<br>(Modes 2 and 3)            | 0        | 70  | 0   | 70   | 0    | 70       | ns    |
| 28       | Read Data Valid to DTACK Low (Setup Time)                                    | 0        | -   | 0   | -    | 0    | -        | ns    |
| 29       | CLK Low to Data Output Valid, Interrupt<br>Acknowledge Cycle                 | -        | 120 | -   | 100  | -    | 80       | ns    |
| 30(7)    | H1(H3) Asserted to CLK High (Setup Time)                                     | 50       | - 1 | 40  | -    | 40   | -        | ns    |
| 31       | PIACK or TIACK Low to CLK Low (Setup Time)                                   | 50       | -   | 40  | -    | 30   | -        | ns    |
| 32(11)   | Synchronized CS to CLK Low on which<br>DMAREQ is Asserted                    | 3        | 3   | 3   | 3    | 3    | 3        | CLK F |
| 33(9,11) | Synchronized H1(H3) to CLK Low on which<br>H2(H4) is Asserted                | 3.5      | 4.5 | 3.5 | 4.5  | 3.5  | 4.5      | CLK F |
| 34       | CLK Low to DTACK Low Interrupt Acknowledge<br>Cycle (Delay Time)             |          | 100 |     | 100  | -    | 80       | ns    |
| 35       | CLK Low to DMAREQ Low (Delay Time)                                           | C        | 120 | 0   | 100  | 0    | 80       | ns    |
| 36       | CLK Low to DMAREQ High (Delay Time)                                          | 0        | 120 | 0   | 100  | 0    | 80       | ns    |
| 37(11)   | Synchronized H1(H3) to CLK Low on which<br>PIRQ is Asserted                  | 3        | 3   | 3   | 3    | 3    | 3        | CLK F |

# 6.6 AC ELECTRICAL SPECIFICATIONS (V\_{CC}=5.0 Vdc $\pm5\%$ , V\_{SS}=0 Vdc, T\_{A}=0°C to 70°C, unless otherwise noted)

6-4

#### 6.6 AC ELECTRICAL SPECIFICATIONS (Continued)

|        |                                                            | 8 MHz |     | 10 MHz |     | 12.5 MHz |     |                              |
|--------|------------------------------------------------------------|-------|-----|--------|-----|----------|-----|------------------------------|
| Number | Characteristic                                             | Min   | Max | Min    | Max | Min      | Max | Unit                         |
| 38(11) | Synchronized CS to CLK Low on which PIRO is High Impedance | 3     | 3   | 3      | 3   | 3        | 3   | CLK Per                      |
| 39     | CLK Low to PIRQ Low or High Impedance                      | 0     | 250 | 0      | 225 | 0        | 200 | ns                           |
| 40(8)  | TIN Frequency (External Clock) - Prescaler Used            | 0     | 1   | 0      | 1   | 0        | 1   | f <sub>clk</sub> (Hz)<br>(6) |
| 41     | TIN Frequency (External Clock) – Prescaler<br>Not Used     | 0     | 1/8 | 0      | 1/8 | 0        | 1/8 | f <sub>clk</sub> (Hz)<br>(6) |
| 42     | TIN Pulse Width High or Low (External Clock)               | 55    | -   | 45     | -   | 45       | -   | ns                           |
| 43     | TIN Pulse Width Low (Run/Halt Control)                     | 1     | -   | 1      | -   | 1        | -   | CLK Per                      |
| 44     | CLK Low to TOUT High, Low, or High Impedance               | 0     | 250 | 0      | 225 | 0        | 200 | ns                           |
| 45     | CS, PIACK, or TIACK High to CS, PIACK, or<br>TIACK Low     | 50    | -   | 30     | -   | 30       | -   | ns                           |

NOTES:

 This specification only applies if the PI/T had completed all operations initiated by the previous bus cycle when CS was asserted. Following a normal read or write bus cycle, all operations are complete within three clocks after the falling edge of the CLK pin on which DTACK was asserted. If CS is asserted prior to completion of these operations, the new bus cycle, and hence, DTACK is postponed.

If all operations of the previous bus cycle were complete when  $\overline{CS}$  was asserted, this specification is made only to insure that  $\overline{\text{DTACK}}$  is asserted with respect to the falling edge of the CLK pin as shown in the timing diagram, not to guarantee operation of the part. If the  $\overline{CS}$  setup time is violated,  $\overline{\text{DTACK}}$  may be asserted as shown, or may be asserted one clock cycle later.

- 2. Assuming the RS1-RS5 to data valid time has also expired.
- 3. This specification imposes a lower bound on CS low time, guaranteeing that CS will be low for at least 1 CLK period.
- 4. This specification assures recognition of the asserted edge of H1(H3).
- 5. This specification applies only when a pulsed handshake option is chosen and the pulse is not shortened due to an early asserted edge of H1(H3).
- 6. CLK refers to the actual frequency of the CLK pin, not the maximum allowable CLK frequency.
- 7. If the setup time on the rising edge of the clock is not met, H1(H3) may not be recognized until the next rising of the clock.
- 8. This limit applies to the frequency of the signal at TIN compared to the frequency of the CLK signal during each clock cycle. If any period of the waveform at TIN is smaller than the period of the CLK signal at that instant, then it is likely that the timer circuit will completely ignore one cycle of the TIN signal.

If these two signals are derived from different sources they will have different instantaneous frequency variations. In this case the frequency applied to the TIN pin must be distinctly less than the frequency at the CLK pin to avoid lost cycles of the TIN signal. With signals derived from different crystal oscillators applied to the TIN and CLK pins with fast rise and fall times, the TIN frequency can approach 80 to 90% of the frequency of the CLK signal without a loss of a cycle of the TIN signal.

If these two signals are derived from the same frequency source then the frequency of the signal applied to TIN can be 100% of the frequency at the CLK pin. They may be generated by different buffers from the same signal or one may be an inverted version of the other. The TIN signal may be generated by an 'AND' function of the clock and a control signal.

- 9. The maximum value is caused by a peripheral access (H1(H3) asserted) and bus access (CS asserted) occurring at the same time.
- 10. See 1.4 BUS INTERFACE OPERATION for exception.
- 11. Synchronized means that the input signal has been seen by the PI/T on the appropriate edge of the clock (rising edge for H1(H3) and falling edge for CS). (Refer to the **1.4 BUS INTERFACE OPERATION** for the exception concerning CS.)

Timing diagrams (Figures 6-2, 6-3, 6-4, 6-5, and 6-6) are located on foldout pages 3, 4, 5, and 6 at the end of this document.

6-5/6-6

## SECTION 7 MECHANICAL DATA AND ORDERING INFORMATION

This section contains the pin assignments and package dimensions of the MC68230. In addition, detailed information is provided to be used as a guide when ordering.

#### 7.1 PIN ASSIGNMENT

÷.

|              |    | _     |            |
|--------------|----|-------|------------|
| D5 🕻         |    | 48 0. | D4         |
| D6 🖸         | 2  | 47    | D3         |
| D7 🕻         | 3  | 46    | D2         |
| PAO          | 4  | 45 🛛  | D1         |
| PA1          | 5  | 44Þ   | D0         |
| PA2          | 6  | 43    | R/₩        |
| PA3 🕻        | 7  | 42    | DTACK      |
| PA4 🕻        | 8  | 41    | टड         |
| PA5 🕻        | 9  | 40    | CLK        |
| PA6 🕻        | 10 | 39 🖬  | RESET      |
| PA7          | 11 | 38 🛛  | Vss        |
| Vcc <b>⊑</b> | 12 | 37 🗖  | PC7/TIACK  |
| н [          | 13 | 36    | PC6/PIACK  |
| H2 🕻         | 14 | 35 🛛  | PC5/PIRQ   |
| нз 🕻         | 15 | 34    | PC4/DMAREQ |
| H4 🕻         | 16 | 33    | PC3/TOUT   |
| РВО          | 17 | 32    | PC2/TIN    |
| PB1 🕻        | 18 | 31    | PC1        |
| РВ2 🕻        | 19 | 30 🗖  | PC0        |
| РВЗ 🕻        | 20 | 29 1  | RS1        |
| PB4          | 21 | 28    | RS2        |
| PB5          | 22 | 27    | RS3        |
| рвб 🕻        | 23 | 26    | RS4        |
| РВ7          | 24 | 25    | RS5        |
|              |    |       |            |

#### 7.2 ORDERING INFORMATION

| Package Type | Frequency<br>(MHz) | Temperature | Order Number |
|--------------|--------------------|-------------|--------------|
| Ceramic      | 8.0                | 0°C to 70°C | MC68230L8    |
| L Suffix     | 10.0               | 0°C to 70°C | MC68230L10   |
|              | 12.5               | 0°C to 70°C | MC68230L12   |
| Plastic      | 8.0                | 0°C to 70°C | MC68230G8    |
| G Suffix     | 10.0               | 0°C to 70°C | MC68230G10   |
|              | 12.5               | 0°C to 70°C | MC68230G12   |

#### 7.3 PACKAGE DIMENSIONS





NOTES:

- 1. DIMENSION A: IS DATUM. 2. POSTIONAL TOLERANCE FOR LEADS:

.

♥Ø 0.25 (0.010)@T A@

- T: IS SEATING PLANE.
   DIMENSION "L" TO CENTER OF LEADS WHEN FORMED PARALLEL.
   DIMENSIONING AND TOLERANCING PER ANSI Y14.5, 1973.

|     | MILLIN | ETERS | INC   | HES   |  |
|-----|--------|-------|-------|-------|--|
| DIM | MIN    | MAX   | MIN   | MAX   |  |
| A   | 60.35  | 61.57 | 2.376 | 2.424 |  |
| B   | 14.63  | 15.34 | 0.576 | 0.604 |  |
| C   | 3.05   | 4.32  | 0.120 | 0.160 |  |
| D   | 0.381  | 0.533 | 0.015 | 0.021 |  |
| F   | 0.762  | 1.397 | 0.030 | 0.055 |  |
| G   | 2.54   | BSC   | 0.100 | ) BSC |  |
| J   | 0.203  | 0.330 | 0.008 | 0.013 |  |
| K   | 2.54   | 4.19  | 0.100 | 0.165 |  |
| L   | 14.99  | 15.65 | 0.590 | 0.616 |  |
| M   | 00     | 100   | 00    | 100   |  |
| N   | 1.016  | 1.524 | 0.040 | 0.060 |  |

G SUFFIX PLASTIC PACKAGE CASE 767-01



#### NOTES: 1. .... IS END OF PACKAGE DATUM PLANE.

- SEATING PLANE. 2. POSITIONAL TOLERANCE FOR LEADS 24 & 25:
  - €0.35 (0.014) T B M R
- POSITIONAL TOLERANCE FOR LEAD PATTERN: ♦ 0.25 (0.010) T B M
- 3. DIM B DOES NOT INCLUDE
- MOLD FLASH. 4. DIM L IS TO CENTER OF LEADS WHEN FORMED PARALLEL.
- 5. DIMENSIONING AND **TOLERANCING PER** ANSI Y14.5, 1973.

|     | MILLIN  | ETERS | INCHES    |       |  |
|-----|---------|-------|-----------|-------|--|
| DIM | MIN MAX |       | MIN       | MAX   |  |
| A   | 61.67   | 61.77 | 2.428     | 2.432 |  |
| 8   | 13.92   | 14.02 | 0.548     | 0.552 |  |
| C   | 4.83    | 5.06  | 0.190     | 0.200 |  |
| D   | 0.38    | 0.50  | 0.015     | 0.020 |  |
| F   | 1.22    | 1.34  | 0.048     | 0.053 |  |
| G   | 2.54    | BSC   | 0.100 BSC |       |  |
| 1   | 0.25    | 0.30  | 0.010     | 0.012 |  |
| K   | 3.23    | 3.37  | 0.127     | 0.133 |  |
| L   | 15.24   | BSC   | 0.600     | BSC   |  |
| M   | 00      | 100   | 00        | 100   |  |
| N   | 0.64    | 0.88  | 0.025     | 0.035 |  |
| U   | 1.79    | BSC   | 0.070 BSC |       |  |

7-3/7-4

. .

· · · · ·

|   |   | egis<br>Sele<br>Bitz | ct |   |          |          |                 |            |          |          |              |          | Register<br>Value<br>After<br>RESET<br>(Hex |                                   |
|---|---|----------------------|----|---|----------|----------|-----------------|------------|----------|----------|--------------|----------|---------------------------------------------|-----------------------------------|
| 5 | 4 |                      | -  | 1 | 7        | 6        | 5               | 4          | 3        | 2        | 1            | 0        | Value)                                      |                                   |
| 0 | 0 | 0                    | 0  | 0 | Port     | Mode     | H34             | H12        | H4       | H3       | H2           | H1       | 00                                          | Port General                      |
|   |   |                      |    |   | Cor      | ntrol    | Enable          | Enable     | Sense    | Sense    | Sense        | Sense    |                                             | Contol Register                   |
| 0 | 0 | 0                    | 0  | 1 | *        | SVC      |                 | IP IP      |          |          | ort Interrup |          | 00                                          | Port Service                      |
|   |   |                      |    |   |          | Sel      | ect             | Sel        | ect      | Pri      | iority Cont  |          |                                             | Request Register                  |
| 0 | 0 | 0                    | 1  | 0 | Bit      | Bit      | Bit             | Bit        | Bit      | Bit      | Bit          | Bit      | 00                                          | Port A Data                       |
|   |   |                      |    |   | 7        | 6        | 5               | 4          | 3        | 2        | 1            | 0        |                                             | Direction Register                |
| 0 | 0 | 0                    | 1  | 1 | Bit      | Bit      | Bit             | Bit        | Bit .    | Bit      | Bit          | Bit      | 00                                          | Port B Data                       |
|   |   |                      | _  |   | 7        | 6        | 5               | 4          | 3        | 2        | 1            | 0        |                                             | Direction Register                |
| 0 | 0 | 1                    | 0  | 0 | Bit<br>7 | Bit<br>6 | Bit<br>5        | Bit<br>4   | Bit<br>3 | Bit<br>2 | Bit<br>1     | Bit<br>0 | 00                                          | Port C Data<br>Direction Register |
| • | 0 |                      | ~  | 4 | . /      | 0        |                 |            | 3        | 2        |              |          | 0 F                                         | Port Interrupt                    |
| 0 | U | 1                    | 0  | ' |          |          | Interrup<br>Nun |            |          |          | *            | *        |                                             | Vector Register                   |
| 0 | 0 | 1                    | 1  | 0 | Por      | t Δ      |                 |            |          | H2       | Н1           | H1       | 00                                          | Port A Control                    |
| Ũ | v | '                    |    | Ŭ | Subr     |          |                 | H2 Control |          | Int      | SVCRQ        | Stat     |                                             | Register                          |
|   |   |                      |    |   |          |          |                 |            |          | Enable   | Enable       | Ctrl     |                                             | <b>3</b>                          |
| 0 | 0 | 1                    | 1  | 1 | Por      | t B      |                 |            |          | H4       | НЗ           | НЗ       | 00                                          | Port B Control                    |
|   |   |                      |    |   | Subr     | node     |                 | H4 Control |          | Int      | SVCRQ        | Stat     |                                             | Register                          |
|   |   |                      |    |   |          |          |                 |            |          | Enable   | Enable       | Ctrl     |                                             |                                   |
| 0 | 1 | 0                    | 0  | 0 | Bit      | Bit      | Bit             | Bit        | Bit      | Bit      | Bit          | Bit      | **                                          | Port A Data                       |
|   |   |                      |    |   | 7        | 6        | 5               | 4          | 3        | 2        | 1            | 0        |                                             | Register                          |
| 0 | 1 | 0                    | 0  | 1 | Bit      | Bit      | Bit             | Bit        | Bit      | Bit      | Bit          | Bit      | **                                          | Port B Data                       |
|   |   |                      |    |   | 7        | 6        | 5               | 4          | 3        | 2        | 1            | 0        |                                             | Register                          |
| 0 | 1 | 0                    | 1  | 0 | Bit<br>7 | Bit      | Bit             | Bit        | Bit      | Bit      | Bit          | Bit      | ***                                         | Port A Alternate                  |
| ~ |   | ~                    |    |   |          | 6        | 5               | 4          | 3        | 2        | 1            | 0        |                                             | Register                          |
| 0 | 1 | 0                    | 1  | 1 | Bit<br>7 | Bit<br>6 | Bit<br>5        | Bit<br>4   | Bit<br>3 | Bit<br>2 | Bit<br>1     | Bit<br>0 | ***                                         | Port B Alternate<br>Register      |
| 0 | 1 | 1                    | ^  | ~ | Bit      | Bit      | Bit             | Bit        | Bit      | Bit      | Bit          | Bit      | ****                                        | Port C Data                       |
| 0 | 1 |                      | U  | 0 | ы<br>7   | 6<br>6   | 5               | 4          | 3        | 2        | 1            | 0        | ****                                        | Register                          |
| 0 | 1 | 1                    | 0  | 1 | H4       | НЗ       | H2              | Н1         | H4S      | H3S      | H2S          | HIS      |                                             | Port Status                       |
| Ŭ | ' | •                    | Ŭ  |   | Level    | Level    | Level           | Level      | 1110     | 100      | 1120         | mo       |                                             | Register                          |
| 0 | 1 | 1                    | 1  | 0 | +        | *        | *               | *          | *        | *        | *            | *        | 00                                          | (Null)                            |
|   |   |                      |    |   |          |          |                 |            |          |          |              |          |                                             |                                   |
| 0 | 1 | 1                    | 1  | 1 | *        | *        | *               | *          | *        | *        | *            | *        | 00                                          | (Null)                            |

#### Table 1-3. Register Model (Sheet 1 of 2)

\* Unused, read as zero \* \* Value before RESET \* \* \* Current value on pins \* \* \* \* Undetermined value

.

|   |   | egis<br>Sele |   |   |     |          |     |      |     |     |       |        | Register<br>Value<br>After<br>RESET |                          |
|---|---|--------------|---|---|-----|----------|-----|------|-----|-----|-------|--------|-------------------------------------|--------------------------|
|   |   | Bit          |   |   |     |          |     |      |     |     |       |        | (Hex                                |                          |
| 5 | 4 | 3            | 2 | 1 | 7   | 6        | 5   | 4    | 3   | 2   | 1     | 0      | Value)                              | -                        |
| 1 | 0 | 0            | 0 | 0 | Т   | OUT/TIAC | ĸ   | ZD   | +   |     | ock   | Timer  | 00                                  | Timer Control            |
|   |   |              |   |   |     | Control  |     | Ctrl |     | Cor | ntrol | Enable | ŀ                                   | Register                 |
| 1 | 0 | 0            | 0 | 1 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | 0 F                                 | Timer Interrupt          |
|   |   |              |   |   | 7   | 6        | 5   | 4    | 3   | 2   | 1     | 0      |                                     | Vector Register          |
| 1 | 0 | 0            | 1 | 0 | *   | *        | *   | *    | *   | +   | *     | *      | 00                                  | (Null)                   |
| 1 | 0 | 0            | 1 | 1 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | **                                  | Counter Preload          |
|   |   |              |   |   | 23  | 22       | 21  | 20   | 19  | 18  | 17    | 16     |                                     | Register (High)          |
| 1 | 0 | 1            | 0 | 0 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | **                                  | Counter Preload          |
|   |   |              |   |   | 15  | 14       | 13  | 12   | 11  | 10  | 9     | 8      |                                     | Register (Mid)           |
| 1 | 0 | 1            | 0 | 1 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | ] **                                | Counter Preload          |
|   |   |              |   |   | 7   | 6        | 5   | 4    | 3   | 2   | 1     | 0      |                                     | Register (Low)           |
| 1 | 0 | 1            | 1 | 0 | *   | *        | *   | *    | *   | •   | *     | *      | 00                                  | (Null)                   |
| 1 | 0 | 1            | 1 | 1 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | 1 **                                | Count Register           |
|   |   |              |   |   | 23  | 22       | 21  | 20   | 19  | 18  | 17    | 16     |                                     | (High)                   |
| 1 | 1 | 0            | 0 | 0 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | **                                  | Count Register           |
|   |   |              |   |   | 15  | 14       | 13  | 12   | 11  | 10  | 9     | 8      |                                     | (Mid)                    |
| 1 | 1 | 0            | 0 | 1 | Bit | Bit      | Bit | Bit  | Bit | Bit | Bit   | Bit    | **                                  | Count Register           |
|   |   |              |   |   | 7   | 6        | 5   | 4    | 3   | 2   | 1     | 0      |                                     | (Low)                    |
| 1 | 1 | 0            | 1 | 0 | *   | *        | *   | *    | *   | *   | *     | ZDS    | 00                                  | Timer Status<br>Register |
| 1 | 1 | 0            | 1 | 1 | •   | *        | *   | *    | *   | *   | *     | *      | 00                                  | (Null)                   |
| 1 | 1 | 1            | 0 | 0 | *   | *        | *   | *    | *   | *   | *     | *      | 00                                  | (Null)                   |
| 1 | 1 | 1            | 0 | 1 | *   | *        | *   | *    | *   | *   | *     | *      | 00                                  | (Null)                   |
| 1 | 1 | 1            | 1 | 0 | *   | •        | *   | *    | *   | *   | *     | *      | 00                                  | (Null)                   |
| 1 | 1 | 1            | 1 | 1 | *   | *        | *   | *    | *   | *   | *     | *      | 0.0                                 | (Null)                   |

#### Table 1-3. Register Model (Sheet 2 of 2)

.

\*Unused, read as zero \* \*Value before RESET



Figure 6-2. Read Cycle Timing Diagram





NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.



NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

Figure 6-4. IACK Timing Diagram



Figure 6-5. Peripheral Input Timing Diagram



Figure 6-6. Peripheral Output Timing Diagram

NOTES. 1 Timing diagram shows H1, H2, H3, and H4 asserted low 2 Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted

Foldout 5

Foldout 6



÷.

MOTOROLA LTD. Semiconductor Products Group COLVILLES ROAD, KELVIN ESTATE, EAST KILBRIDE, GLASGOW, G75 0TG, SCOTLAND

Printed in Great Britain - Watkiss Studios Ltd. 7/85 2,000

# SYS68K/EAGLE-01C USER'S MANUAL

Revision No. 1 August 1991

# FORCE COMPUTERS Inc./GmbH All Rights Reserved

This document shall not be duplicated, nor its contents used

for any purpose, unless express permission has been granted.

Copyright by FORCE COMPUTERS®

## <u>N O T E</u>

The information in this document has been carefully checked and is believed to be entirely reliable. FORCE COMPUTERS makes no warranty of any kind with regard to the material in this document, and assumes no responsibility for any errors that may appear in this document. FORCE COMPUTERS reserves the right to make changes without notice to this, or any of its products, to improve reliability, performance or design.

FORCE COMPUTERS assumes no responsibility for the use of any circuitry other than circuitry which is part of a product of FORCE COMPUTERS GmbH/Inc.

FORCE COMPUTERS does not convey to the purchaser of the product described herein any license under the patent rights of FORCE COMPUTERS GmbH/Inc. nor the rights of others.

## FORCE COMPUTERS Inc.

3165 Winchester Blvd. Campbell, CA 95008-6557 U.S.A.

## FORCE COMPUTERS GmbH

Prof.-Messerschmitt-Str. 1 D-8014 Neubiberg/Munich West Germany

| Phone: | (408) 370-6300 | Phone: | (089) 608 14-0  |
|--------|----------------|--------|-----------------|
| FAX:   | (408) 374-1146 | Telex: | 524190 forc-d   |
|        |                | FAX:   | (089) 609 77 93 |

| FORCE COMPUTERS FRANCE Sarl<br>11, rue Casteja<br>92100 Boulogne<br>France |                                                                                    | FORCE Computers UK Ltd.<br>No. 1 Holly Court<br>3 Tring Road<br>Wendover<br>Buckinghamshire HP22 6PE<br>England |               |  |
|----------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------|--|
| Phone:                                                                     | <ol> <li>(1) 4620 37 37</li> <li>206 304 forc-f</li> <li>(1) 4621 35 19</li> </ol> | Phone:                                                                                                          | (0296) 625456 |  |
| Telex:                                                                     |                                                                                    | Telex:                                                                                                          | 838033        |  |
| FAX:                                                                       |                                                                                    | FAX:                                                                                                            | (0296) 624027 |  |

This page is intentionally left blank.

## **Table of Contents**

| 1.                 | GENERAL INFORMATION                                            | 1     |
|--------------------|----------------------------------------------------------------|-------|
| 1.1                | The FLXibus                                                    | 4     |
| 1.2                | The Floppy Interface                                           | 4     |
| 1.3                | The SCSI Interface                                             | 5     |
| 1.4                | The LAN Interface                                              | 6     |
| 1.5                | The EAGLE FLASH EPROM                                          | 6     |
| 1.6                | Default Jumper Settings and Location Diagrams                  |       |
| 1.0                | Delaut Jumper Soldings and Decation Diagrams                   | ,     |
| 2.                 | HARDWARE DESCRIPTION                                           | 11    |
| 2.1                | Address Map of the EAGLE-01C                                   | 11    |
| 2.2                | Floppy Interface                                               | 11    |
| 2.2.1              | Floppy Disk Controller 37C65                                   | 12    |
| 2.2.1.1            | Address Map of the 37C65                                       | 12    |
| 2.2.1.2            | The FDC Interrupt                                              | 13    |
| 2.2.1.3            | Summary of the 37C65                                           | 13    |
| 2.2.2              | The LCÁ                                                        | 14    |
| 2.2.2.1            | LCA Data Transfers                                             | 15    |
| 2.2.2.2            | LCA DMA Control Lines                                          | 16    |
| 2.2.2.3            | LCA DMA Control Register                                       | 17    |
| 2.2.3              | Floppy Buffer Memory                                           | 17    |
| 2.2.3.1            | Summary of the Floppy Buffer Memory                            | 18    |
| 2.2.4              | The Floppy Disk Bus                                            | 18    |
| 2.2.4.1            | The Floppy Drive Signals on VMEbus P2 Connector                | 22    |
| 2.2.4.1            | SCSI Interface                                                 | 22    |
| 2.3.1              | SCSI Controller MB87031                                        | 23    |
|                    |                                                                | 23    |
| 2.3.1.1<br>2.3.1.2 | Address Map of the MB87031 Registers<br>The SCSI CPU Interface | 24 25 |
|                    |                                                                | 25    |
| 2.3.1.3            | The SCSI DMA Interface                                         |       |
| 2.3.1.4            | SCSI DMA Control Register                                      | 25    |
| 2.3.1.5            | The MB80731 Interrupt                                          | 26    |
| 2.3.1.6            | Summary of the MB87031                                         | 26    |
| 2.3.2              | SCSIbus                                                        | 27    |
| 2.3.2.1            | SCSIbus Configuration                                          | 27    |
| 2.3.2.2            | SCSIbus Signals                                                | 29    |
| 2.3.2.3            | SCSIbus Signal Termination                                     | 30    |
| 2.3.2.4            | SCSIbus Termination Resistor Power (TERMPWR)                   | 33    |
| 2.3.2.5            | The SCSIbus Signals on VMEbus P2 Connector                     | 33    |
| 2.4                | The LAN Interface                                              | 35    |
| 2.4.1              | LAN Controller for Ethernet (LANCE) AM7990                     | 36    |
| 2.4.1.1            | Address Map of the LANCE Registers                             | 37    |
| 2.4.1.2            | The LANCE Interrupt                                            | 38    |
| 2.4.1.3            | Summary of the LANCE                                           | 38    |
| 2.4.2              | The Am7992B Serial Interface Adapter (SIA)                     | 39    |
| 2.4.2.1            | The Am7992B Transmitter                                        | 40    |
| 2.4.2.2            | The Am7992B Receiver                                           | 41    |
| 2.4.3              | Ethernet Signals                                               | 42    |
| 2.4.3.1            | Ethernet on the 15-Pin Female DSUB Connector                   | 44    |
| 2.4.4              | LAN Buffer Memory                                              | 45    |
| 2.4.4.1            | Summary of the LAN RAM                                         | 46    |
| 2.5                | The EAGLE FLASH EPROM                                          | 47    |
| 2.5.1              | Summary of the EAGLE FLASH EPROM                               | 47    |
| 2.6                | The SYS68K/IOBP-1                                              | 48    |
|                    |                                                                |       |

| 3. | CIRCUIT SCHEMATICS          | 53 |
|----|-----------------------------|----|
| 4. | COMPONENT PART LIST         | 55 |
| 5. | COPIES OF DATA SHEETS       | 57 |
| б. | ORDERING INFORMATION        | 61 |
| 7. | HISTORY OF MANUAL REVISIONS | 63 |
| 8. | PRODUCT ERROR REPORT        | 65 |

# Table of Figures

| Figure 1-1:  | Photo of the EAGLE-01                     | 2  |
|--------------|-------------------------------------------|----|
| Figure 1-2:  | Block Diagram of the EAGLE-01             | 3  |
| Figure 1-3:  | Location of Switches and Jumperfields     | 8  |
| Figure 1-4:  | Default Setting of Dip Switch Array SW1   | 9  |
| Figure 2-1:  | Location of Dip Switch Array SW1          | 21 |
| Figure 2-2:  | Default Setting of Dip Switch Array SW1   | 22 |
| Figure 2-3:  | SCSI I.D. Bits                            | 27 |
| Figure 2-4:  | Sample SCSI Configurations                | 28 |
| Figure 2-5:  | Location of SCSIbus Term. Resistors A1-A3 | 31 |
| Figure 2-6:  | Location of Jumpers B4 and B5             | 32 |
| Figure 2-7:  | Manchester II Code Transmitter Encoding   | 40 |
| Figure 2-8:  | Decoding with the Manchester Decoder      | 41 |
| Figure 2-9:  | Location of Jumper B2                     | 43 |
| Figure 2-10: | Pinout of the 15 Pin DSUB Connector       | 45 |

# Table of Tables

| Table 1-1:  | Default Jumper Settings                         | 7  |
|-------------|-------------------------------------------------|----|
| Table 2-1:  | Address Map of the EAGLE-01C                    | 11 |
| Table 2-2:  | Register Layout of the 37C65                    | 12 |
| Table 2-3:  | Address Map for Generating TC                   | 16 |
| Table 2-4:  | LCA DMA Control Register Layout                 | 17 |
| Table 2-5:  | Description of LCA DMA Control Register Bits    | 17 |
| Table 2-6:  | Dip Switch Setting for MO12/HEADLOAD            | 18 |
| Table 2-7:  | Address Map for Generating EJECT                | 19 |
| Table 2-8:  | Dip Switch Setting for HEADLOAD/EJECT           | 19 |
| Table 2-9:  | Dip Switch Setting for DRIVE TYPE               | 20 |
| Table 2-10: | Dip Switch Setting for PRECOMPENSATION VALUE    | 20 |
| Table 2-11: | Dip Switch Setting for DISK CHANGE ENABLE       | 20 |
| Table 2-12: | Pin Assignment for Floppy Drive Signals         | 22 |
| Table 2-13: | MB87031 Register Layout                         | 24 |
| Table 2-14: | SCSI DMA Control Register                       | 26 |
| Table 2-15: | SCSI DMA Direction Bit                          | 26 |
| Table 2-16: | Jumper Setting - SCSIbus Termination Res. Power | 33 |
| Table 2-17: | Pin Assignment for SCSIbus Signals              | 34 |
| Table 2-18: | LANCE Register Layout                           | 37 |
| Table 2-19: | Jumper Setting for Ethernet Power Supply        | 42 |
| Table 2-20: | Pin Assignment of the 15 Pin Female DSUB        | 44 |
| Table 2-21: | Dip Switch Setting for FLASH EPROMs             | 47 |
| Table 2-22: | SYS68K/IOBP-1 P1 Pin Assignment                 | 49 |
| Table 2-23: | SYS68K/IOBP-1 P2 Pin Assignment                 | 50 |
| Table 2-24: | SYS68K/IOBP-1 P3 Pin Assignment                 | 51 |
| Table 2-25: | SYS68K/IOBP-1 P4 Pin Assignment                 | 52 |

,

# 1. GENERAL INFORMATION

The EAGLE-01C is an I/O module which contains a Floppy Disk Interface, an SCSI Interface, a LAN Interface and FLASH EPROMs. The EAGLE-01C is connected to the base board via three module connectors. One module connector connects to the 64 user-defined signals of the VMEbus P2 Connector via the base board to the module and is called the EAGLE I/O Connector. The remaining two module connectors contain the FLXibus (FORCE Local eXpansion interface bus) and are called EAGLE FLXibus Connectors. On the EAGLE-01C, these two module connectors also contain the 8 bit Local Interface and the 8 bit DMA Interface of the gate array FGA-002.

# Figure 1-1: Photo of the EAGLE-01C



# Figure 1-2: Block Diagram of the EAGLE-01C



# 1.1 The FLXibus

The FLXibus (FORCE Local eXpansion interface bus) is an interface which allows the connection between an EAGLE module and a base board. The FLXibus is a 32 bit interface with non-multiplexed data and address lines. The FLXibus is fully compatible to the 68020 bus timing. The dynamic bus sizing mechanism of the 68020 is fully supported. The bus activities use the asynchronous protocol so that all 68020 compatible devices can be connected to the FLXibus. An EAGLE module is connected with the base board via three connectors. The EAGLE FLXibus Connectors hold the signals of the FLXibus. The EAGLE I/O Connector holds the I/O signals which are routed to the VMEbus P2 of the base board.

# **1.2 The Floppy Interface**

The Floppy Interface on the EAGLE-01C is built with the 37C65 Floppy Disk Controller. A 16 Kbyte Buffer Memory and a DMA Controller allow read and write of a sector without any decrease in CPU or main (shared) RAM performance. This configuration is installed for maximum performance and realtime capability of the system. The Floppy Interface allows the control of two floppy drives. The Floppy Interface supports 3 1/2", 5 1/4" and 8"floppy drives. Interrupts of the 37C65 are fully supported. The I/O signals of the Floppy Interface are provided on the VMEbus P2 Connector of the base board via the EAGLE I/O Connector. The floppy drives can be connected to the VMEbus P2 Connector via the backpanel SYS68K/IOBP-1.

The DMA controller is built in an LCA (logic cell array) which is a field programmable gate array. The LCA manages the data transfer between the CPU, the 16 Kbyte Buffer Memory and the Floppy Disk Controller (see Figure 1-2, Block Diagram of the EAGLE-01C).

The LCA manages the following accesses:

- · CPU to Floppy Disk Controller.
- CPU to 16 Kbyte Buffer Memory.
- Floppy Disk Controller to 16 Kbyte Buffer Memory via the DMA controller built in the LCA.

14

## **1.3 The SCSI Interface**

On the EAGLE-01C the MB87031 SCSI Controller is installed for direct interface to SCSI Winchester Disks, optical drives, tape streamers and other SCSI compatible devices with a data transfer rate of up to 4 Mbyte/s. Interrupts of the MB87031 are fully supported. The I/O signals of the SCSI interface are provided on the VMEbus P2 Connector of the base board via the EAGLE I/O Connector. The mass memory devices can be connected to the VMEbus P2 Connector via the backpanel SYS68K/IOBP-1.

The MB87031 is directly connected to the 8 bit Local Interface and the 8 bit DMA Interface of the FGA-002 via the EAGLE FLXibus connectors.

The 8 bit Local Interface of the FGA-002 is used to access the registers of the MB87031. Parity is generated when writing to the registers of the MB87031.

The 8 bit DMA Interface is used to transfer data between the DMA channel of the MB87031 and the DMA Controller of the FGA-002. Parity is generated when writing to the DMA channel of the MB87031.

The DMA Controller of the FGA-002 contains a 32 byte FIFO. The DMA channel of the FGA-002 contains an additional 8 byte FIFO. This allows data transfer via the DMA Interface of the FGA-002 with a data rate of 4 Mbyte/s.

In a DMA READ transfer the DMA Controller waits until the FIFO is filled with SCSI data and then requests local bus mastership to transfer the 32 bytes in 8 CPU cycles. In a DMA WRITE transfer the DMA Controller requests local bus mastership and fills its FIFO with 32 bytes from the source address in 8 CPU cycles. When the FIFO is filled the DMA Controller transfers the data to the DMA channel of the SCSI Controller.

# **1.4 The LAN Interface**

The LAN Interface on the EAGLE-01C is built with the Local Area Network Controller for Ethernet (LANCE) AM7990, the Serial Interface Adapter (SIA) AM7992B and a 64 Kbyte Buffer Memory. Interrupts of the AM7990 are fully supported. The LAN Interface is Ethernet and IEEE 802.3 Rev. 0 compatible. The I/O signals of the LAN Interface are provided on the DSUB Connector on the front panel.

The memory buffer is a shared memory allowing access from both the AM7990 and the local CPU. The 64 Kbyte Buffer Memory stores the incoming and outgoing data packets. An incoming data packet is transferred to the Buffer Memory by the LAN Controller. The presence of data in the Buffer Memory is indicated to the CPU by an interrupt. The CPU can then read the data packet from the Buffer Memory. An outgoing data packet is transferred to the Buffer Memory by the CPU. The LAN Controller then transfers the data packet to the network and indicates the completion of the transfer by an interrupt to the CPU.

The advantage of this architecture is that the CPU and the Ethernet Controller can operate in parallel which guarantees the full realtime capability in a LAN environment and the maximum performance of the system.

# **1.5 The EAGLE FLASH EPROM**

On the EAGLE-01C, 256 Kbytes of FLASH EPROM are installed. The FLASH EPROM area is 8 bit wide and contains information about the EAGLE-01C for the base board. This information is read by the base board to identify the EAGLE-01C after a reset. The FLASH EPROM area also contains the low level software drivers for the I/O devices of the EAGLE-01C.

FLASH EPROMs can be erased and reprogrammed electrically without removing them from the board. Therefore FLASH EPROMs ensure easy maintenance and update of software.

# **1.6 Default Jumper Settings and Location Diagrams**

The following is the default jumper settings and location of all jumpers and switches on the EAGLE-01C.

# **Table 1-1: Default Jumper Settings**

| Jumperfield | Description                        | Default Setting | Schematics |
|-------------|------------------------------------|-----------------|------------|
| B1          | Ethernet Power<br>Supply +12V      | 1-2             | SH1        |
| B2          | Ethernet Power<br>Supply Ground    |                 | SH1        |
| B3          | Module Clock for<br>Test           | 1-2             | SH4        |
| B4          | SCSI Termination<br>Resistor Power | 1-2             | SH8        |
| В5          | SCSI Termination<br>Resistor Power | '               | SH8        |









,

.

This page is intentionally left blank.

# 2. HARDWARE DESCRIPTION

# 2.1 Address Map of the EAGLE-01C

The following table shows the address map of the EAGLE-01C. It contains the access addresses of all I/O devices and memory devices of the EAGLE-01C.

| Start Address | End Address | I/O Device Type        |
|---------------|-------------|------------------------|
| FD800000      | FD83FFFF    | FLASH EPROMs           |
| FEF00000      | FEF0FFFF    | LAN Buffer Memory      |
| FEF80000      | FEF80003    | LAN Controller         |
| FF803400      | FF8035FF    | SCSI Controller        |
| FF803800      | FF8039FF    | Floppy Disk Controller |
| FF880000      | FF8803FFF   | Floppy Buffer Memory   |

## Table 2-1: Address Map of the EAGLE-01C

# 2.2 Floppy Interface

The Floppy Interface on the EAGLE-01C is built with the Floppy Disk Controller 37C65, a 16 Kbyte SRAM Buffer Memory, and an LCA (logic cell array) which is a programmable gate array. The Floppy Interface is byte-wide and is connected to the CPU on the base board via the EAGLE FLXibus Connectors. This LCA contains a data manager which manages the data transfer between the CPU, the 16 Kbyte Buffer Memory and the Floppy Disk Controller (See *Figure 1-2, Block Diagram of the EAGLE-01C*). The Floppy Interface allows the control of two floppy drives. The Floppy Interface supports 3 1/2", 5 1/4" and 8" floppy drives. Single, double and high density floppies are supported. The I/O signals of the Floppy Interface are provided on the VMEbus P2 Connector of the base board via the EAGLE I/O Connector. The floppy drives can be connected to the VMEbus P2 Connector via the backpanel SYS68/IOBP-1 (See *Chapter 2.6 The SYS68K/IOBP-1*).

# 2.2.1 Floppy Disk Controller 37C65

The Floppy Disk Controller 37C65 is an LSI device used to interface floppy drives to a CPU bus. The chip integrates the formatter/controller, data separation, write precompensation, data rate selection and clock generation. The chip also contains the drivers and receivers for the Floppy Disk bus so that no additional buffers are necessary.

## **Features of the Floppy Disk Controller**

- · IBM PC AT compatible format (single, double, and high density)
- Data transfer in DMA or non-DMA mode
- Direct floppy disk drive interface
- · Internal address mark detection circuitry
- 128, 256, 512, 1024, 2048 or 4096 bytes sector length
- · Multisector and multitrack transfer capability
- · Automatic write precompensation

# 2.2.1.1 Address Map of the 37C65

The registers of the 37C65 are accessible via the 8 bit Local Interface of the FGA-002. The following table shows the register layout of the 37C65. Additional information is provided in the 37C65 data sheet (See *Chapter 5, COPIES OF DATA SHEETS*).

# Table 2-2: Register Layout of the 37C65

| Default I/O Base Address:<br>Default Offset: |                      | \$FF800000<br>\$00003800 |                                        |                                                                                   |  |
|----------------------------------------------|----------------------|--------------------------|----------------------------------------|-----------------------------------------------------------------------------------|--|
| Address<br>HEX                               | Offset<br>HEX        | Mode                     | Label                                  | Description                                                                       |  |
| FF803800<br>FF803801<br>FF803802<br>FF803803 | 00<br>01<br>02<br>03 | R/W<br>R/W<br>R/W<br>W   | STATREG<br>DATAREG<br>CTRLREG<br>OPREG | Master Status register<br>Data register<br>Control register<br>Operation register |  |

# 2.2.1.2 The FDC Interrupt

The interrupt of the FDC is programmable in the FGA-002 Gate Array. It is connected to the Interrupt Request Channel #1 of the FGA-002 Gate Array. For detailed information please refer to the FGA-002 User's Manual.

# 2.2.1.3 Summary of the 37C65

| Device                            | 37C65                 |
|-----------------------------------|-----------------------|
| Access Address                    | \$FF803800            |
| Port Width                        | Byte                  |
| Interrupt Request Level           | Software programmable |
| FGA-002 Interrupt Request Channel | Local IRQ #1          |

# 2.2.2 The LCA

The LCA on the EAGLE-01C manages the data transfer between the CPU via the Local I/O Interface of the FGA-002, the Buffer Memory, and the Floppy Disk Controller (See *Figure 1-2, Block Diagram of the EAGLE-01C*). The LCA controls the Buffer Memory and the Floppy Disk Controller.

Three paths for data transfers are possible:

## 1. CPU <==> Floppy Disk Controller

The CPU can read from or write to the Floppy Disk Controller via the LCA (non-DMA mode).

## 2. CPU $\langle = = \rangle$ Buffer Memory

The CPU can read from or write to the 16 Kbyte Buffer Memory via the LCA (non-DMA mode).

## 3. Floppy Disk Controller <==> Buffer Memory

The Floppy Disk Controller can read from or write to the 16 Kbyte Buffer Memory via the DMA controller which is inside the LCA.

# 2.2.2.1 LCA Data Transfers

The CPU accesses the Floppy Disk Controller via the FGA-002 for initializing, for writing the floppy commands and for reading the status information of the Floppy Disk Controller. When the Floppy Disk Controller is initialized and it has received a floppy command (e.g. read/write a sector/track command), the Floppy Disk Controller starts transferring the floppy data bytes. The Floppy Disk Controller can be initialized in DMA mode and in non-DMA mode.

The data transfer of floppy data is described as follows:

## Non-DMA Mode

In non-DMA mode floppy data is transferred by the CPU. The Floppy Disk Controller generates an interrupt to the CPU when it has received a data byte from the floppy drive or when it wants to send a data byte to the floppy drive. The CPU must then transfer the data byte to or from the Floppy Disk Controller within a certain amount of time so that no data will be lost. For each byte which has to be transferred the Floppy Disk Controller will generate an interrupt.

## DMA mode

In DMA mode floppy data is transferred with the help of the DMA controller inside the LCA. The Floppy Disk Controller generates a DMA request to the LCA when it has received a data byte from the floppy drive (DMA READ) or when it wants to send a data byte to the floppy drive (DMA WRITE). After each DMA request the LCA generates a DMA acknowledge to the Floppy Disk Controller. The LCA contains a DMA Control Register. One bit holds the information for the LCA about the direction of the DMA transfer (DMA READ or DMA WRITE). It has to be set to the right value before a DMA transfer is started (See *Chapter 2.2.2.3 LCA DMA Control Register*).

In a DMA READ operation the LCA transfers byte for byte of the floppy data (e.g. a sector or a track) from the Floppy Disk Controller into the Buffer Memory. When the transfer is complete the Floppy Disk Controller generates an interrupt to the CPU to indicate that the buffer memory is filled with the floppy data and that the Buffer Memory can be read by the CPU.

Before a DMA WRITE operation is started the CPU has to fill the Buffer Memory with the floppy data (e.g. a sector or a track). Then the LCA transfers byte for byte of the floppy data from the Buffer Memory to the Floppy Disk Controller. When the transfer is complete the Floppy Disk Controller generates an interrupt to the CPU to indicate that the memory buffer has been read by the Floppy Disk Controller and the floppy data has been transferred.

# 2.2.2.2 LCA DMA Control Lines

The LCA automatically generates the DMA control lines for the Floppy Disk Controller.

A DMA control line called TC (Terminal Count) exists on the Floppy Disk Controller. TC is used to stop a data transfer between the Floppy Disk Controller and the Floppy Drive. This is done by accessing a dedicated address (read or write access). This address is shown in the table below. TC will become active during the access and inactive after the access. For detailed information please refer to the FDC Data Sheet in *Chapter 5*, "COPIES OF DATA SHEETS".

.

# Table 2-3: Address Map for Generating TC

| Default I/O Base Address:<br>Default Offset: |               | \$FF800000<br>\$00003800 |       |                |  |
|----------------------------------------------|---------------|--------------------------|-------|----------------|--|
| Address<br>HEX                               | Offset<br>HEX | Mode                     | Label | Description    |  |
| FF803805                                     | 05            | R/W                      | TC    | Terminal Count |  |

#### 2.2.2.3 LCA DMA Control Register

The LCA contains a register which controls the DMA transfer between Floppy Controller and the Buffer Memory. Register bit 0 controls the direction of the DMA transfer and must be set to the right value before a DMA transfer is started. The register bit 0 can be read back. Register bit 1 indicates whether a DMA transfer is in progress or not. It can only be read and will not be affected by a write access.

#### Table 2-4: LCA DMA Control Register Layout

| Default I/O Base A<br>Default Offset: | e Address: \$FF800000<br>\$00003804 |      |                |        |                      |
|---------------------------------------|-------------------------------------|------|----------------|--------|----------------------|
| Address<br>HEX                        | Offset<br>HEX                       | Mode | Reset<br>Value | Label  | Description          |
| FF803804                              | 04                                  | R/W  | FC             | LCAREG | DMA Control Register |

#### Table 2-5: Description of LCA DMA Control Register Bits

| Bit | Value  | Mode | Description                                                                                               |
|-----|--------|------|-----------------------------------------------------------------------------------------------------------|
| 0   | 1<br>0 | R/W  | Buffer Memory to Floppy Disk Controller (DMA WRITE)<br>Floppy Disk Controller to Buffer Memory (DMA READ) |
| 1   | 1<br>0 | R    | DMA transfer in progress<br>DMA transfer ready                                                            |

#### 2.2.3 Floppy Buffer Memory

The Floppy Interface of the EAGLE-01C holds a 16 Kbyte Buffer Memory. The Buffer Memory can be accessed by the CPU and by the Floppy Disk Controller via the LCA (See *Chapter 2.2.2.1 LCA Data Transfers*). The Floppy Buffer Memory is accessed by the CPU via the 8 bit Local I/O Interface of the FGA-002 in the address range \$FF880000 to \$FF883FFF. When the Floppy Buffer Memory is accessed by the Floppy Disk Controller, the LCA generates the address for the Buffer Memory. The address is set to zero at the beginning of a DMA transfer and is counted upwards by the LCA during the DMA transfer.

#### 2.2.3.1 Summary of the Floppy Buffer Memory

| Device            | 32K * 8 SRAM             |
|-------------------|--------------------------|
| Addressable Space | 16 Kbytes                |
| Access Address    | \$FF880000 to \$FF883FFF |
| Port Width        | Byte                     |

#### 2.2.4 The Floppy Disk Bus

The floppy disk bus is an SA450 type drive interface. The floppy drive signals are provided directly from the Floppy Disk Controller with no additional buffers. Some of the floppy drive signals can be changed via switch 1 to switch 8 of the dip switch array SW1. The switches must be changed for the different types of floppy drives which are used. Switch 9 is used for the LCA configuration mode and must not be changed by the user. Switch 10 is used for the write protection of the FLASH EPROMs and is described in *Chapter 2.5 The EAGLE FLASH EPROM*. The default setting of the dip switch array SW1 is shown in Figure 2-2. The location of the dip switch array is shown in Figure 2-1.

The following floppy disk signals can be changed via the dip switch array SW1:

#### MO12/HEADLOAD

The motor on signals MO1/DS3 and MO2/DS4 of the Floppy Disk Controller are open collector lines. They are tied together and have the signal name MO12. Via switch 1 and switch 2 either MO12 or HEADLOAD can be connected to the MOTOR ON signal of the floppy drive. So both signals can be used to start the motor of the floppy drive.

CAUTION: The switches must not be both opened or both closed at the same time.

#### Table 2-6: Dip Switch Setting for MO12/HEADLOAD

| Active signal | Switch 1 | Switch 2 | Default Setting |
|---------------|----------|----------|-----------------|
| MO12          | off      | on       | *               |
| HEADLOAD      | on       | off      |                 |

#### HEADLOAD/EJECT

There are special 3 1/2" drives which need an eject pulse to eject the floppy out of the drive. The eject signal must be connected to the pin which normally holds the HEADLOAD signal. Via switch 3 and switch 4 either HEADLOAD or EJECT can be connected to the floppy drive.

The EJECT signal can be generated by accessing (read or write) a dedicated address. EJECT is active during the read or write cycle to this address and automatically becomes inactive after two microseconds.

#### Table 2-7: Address Map for Generating EJECT

| Default I/O Base<br>Default Offset: | ult I/O Base Address: \$FF800000<br>ult Offset: \$00003806 |      |       |                         |
|-------------------------------------|------------------------------------------------------------|------|-------|-------------------------|
| Address<br>HEX                      | Offset<br>HEX                                              | Mode | Label | Description             |
| FF803806                            | 06                                                         | R/W  | EJECT | Ejection of Floppy Disk |

CAUTION: The switches must not be both opened or both closed at the same time.

#### Table 2-8: Dip Switch Setting for HEADLOAD/EJECT

| Active signal | Switch 3 | Switch 4 | Default Setting |
|---------------|----------|----------|-----------------|
| HEADLOAD      | off      | on       | *               |
| EJECT         | on       | off      |                 |

#### DRIVE TYPE

The DRIVE TYPE (DRV) signal is used to indicate to the Floppy Disk Controller whether a floppy drive with a two spindle motor or a one spindle motor is used.

CAUTION: The switches must be both opened or both closed at the same time.

#### Table 2-9: Dip Switch Setting for DRIVE TYPE

| Drive Type        | Switch 5 | Switch 6 | Default Setting |
|-------------------|----------|----------|-----------------|
| One Spindle Motor | off      | off      |                 |
| Two Spindle Motor | on       | on       | *               |

#### PRECOMPENSATION VALUE

The PRECOMPENSATION VALUE (PCVAL) signal is used to select the write precompensation time of the Floppy Disk Controller. The time is selected via switch 7.

#### Table 2-10: Dip Switch Setting for PRECOMPENSATION VALUE

| Precompensation Time | Switch 7 | Default Setting |
|----------------------|----------|-----------------|
| 125 ns               | off      |                 |
| 187 ns               | on       | *               |

#### DISK CHANGE ENABLE

The DISK CHANGE ENABLE (DCHGEN) signal is used to enable the DCHG input status at pin 40 of the Floppy Disk Controller. DCHG is the door lock signal of the floppy drive and indicates whether the door of the floppy drive is open or not.

#### Table 2-11: Dip Switch Setting for DISK CHANGE ENABLE

| DCHG Signal | Switch 8 | Default Setting |
|-------------|----------|-----------------|
| Enabled     | on       | *               |
| Disabled    | off      |                 |











#### 2.2.4.1 The Floppy Drive Signals on VMEbus P2 Connector

The floppy drive signals are available on the EAGLE I/O Connector which is connected to row C of the VMEbus P2 Connector. The pin assignment for the floppy disk signals is shown in Table 2-12. The floppy drives can be connected to the VMEbus P2 Connector via the backpanel SYS68/IOBP-1 (See *Chapter 2.6 The SYS68K/IOBP-1*).

| <b>Table 2-12:</b> | Pin Assignment for Floppy Drive Signals on VMEbus P2 Con- |
|--------------------|-----------------------------------------------------------|
|                    | nector                                                    |
|                    |                                                           |

| Pin Number | Signal Mnemonic   |
|------------|-------------------|
| C1         | RWC/RPM           |
| C2         | HEADLOAD/EJECT    |
| C3         | DRIVE SELECT 2    |
| C4         | INDEX             |
| C5         | DRIVE SELECT 1    |
| C6         | DRIVE SELECT 2    |
| C7         | DRIVE SELECT 1    |
| C8         | MOTOR ON/HEADLOAD |
| C9         | DIRECTION IN      |
| C10        | STEP              |
| C11        | WRITE DATA        |
| C12        | WRITE GATE        |
| C13        | TRACK 000         |
| C14        | WRITE PROTECT     |
| C15        | READ DATA         |
| C16        | HEAD SELECT       |
| C17        | DISK CHANGE       |

#### 2.3 SCSI Interface

The SCSI Interface on the EAGLE-01C is built with the SCSI Controller MB87031. The SCSI Interface is installed for direct interface to SCSI Winchester Disks, optical drives, tape streamers and other SCSI compatible devices with a data transfer rate of up to 4 Mbyte/s. The I/O signals of the SCSI interface are provided on the VMEbus P2 Connector of the base board via the EAGLE I/O Connector. The SCSI devices can be connected to the VMEbus P2 Connector via the backpanel SYS68/IOBP-1 (See Chapter 2.6 The SYS68K/IOBP-1).

#### 2.3.1 SCSI Controller MB87031

The SCSI Controller MB87031 is a CMOS LSI chip designed to control an SCSI Interface. The MB87031 can serve as either an INITIATOR or TARGET for the SCSIbus. The Controller contains an 8 byte FIFO data buffer register and a 24 bit transfer byte counter. The Controller has two independent 8 bit buses for the DMA transfer and non-DMA transfer.

#### Features of the MB87031 SCSI Controller

- Full support for SCSI control
- · Serves as either initiator or target device
- Eight byte data buffer register incorporated
- Transfer byte counter (24 bit)
- · Independent control and data transfer bus
- · Asynchronous data transfer speed of 2 Mbytes/sec
- Synchronous data transfer speed of up to 4 Mbytes/sec

#### 2.3.1.1 Address Map of the MB87031 Registers

The registers of the MB87031 are accessible via the 8 bit Local Interface of the FGA-002. The following table shows the register layout of the MB87031. Additional information is provided in the MB87031 data sheets (See *Chapter 5, COPIES OF DATA SHEETS*).

#### Default I/O Base Address: \$FF800000 **Default Offset:** \$00003400 Offset Hex **Read/Write** Address Hex Label Description FF803400 00 R/W BDID **BUS DEVICE ID** SCTL FF803401 01 R/W SPC CONTROL FF803402 02 R/W SCMD COMMAND FF803403 03 R/W TMOD TRANSFER MODE FF803404 04 INTS INTERRUPT SENSE R w **RESET INTERRUPT** FF803405 05 PSNS PHASE SENSE R w SDGC SPC DIAGNOSTIC CONTROL FF803406 06 R SSTS SPC STATUS FF803407 07 SERR SPC ERROR STATUS R FF803408 08 R PCTL PHASE CONTROL FF803409 09 R MBC MODIFIED BYTE COUNTER 0**A** FF80340A R DREG DATA REGISTER FF80340B 0**B** R TEMP TEMPORARY REGISTER FF80340C 0**C** тсн TRANSFER COUNT HIGH R FF80340D 0D тсм TRANSFER COUNT MIDDLE R 0E TRANSFER COUNT LOW FF80340E R TCL FF80340F 0F R EXBF EXTERNAL BUFFER

#### Table 2-13: MB87031 Register Layout

#### 2.3.1.2 The SCSI CPU Interface

The 8-bit Local Interface of the FGA-002 is used to access the registers of the MB87031. Parity is generated when writing to the registers of the MB87031.

#### 2.3.1.3 The SCSI DMA Interface

The 8 bit DMA channel of the SCSI Controller is directly connected to the installed DMA Controller of the FGA-002 allowing data transfers with a maximum speed of 4 Mbyte/s. Parity is generated when writing to the DMA channel of the MB87031.

The DMA Controller of the FGA-002 contains a 32 byte FIFO. The DMA channel of the FGA-002 contains an additional 8 byte FIFO. This allows data transfer via the DMA Interface of the FGA-002 with a data rate of 4 Mbyte/s.

In a DMA READ transfer the DMA Controller waits until the FIFO is filled with SCSI data and then requests CPU bus mastership to transfer the 32 bytes in 8 CPU cycles. In a DMA WRITE transfer the DMA Controller requests CPU bus mastership and fills its FIFO with 32 bytes from the source address in 8 CPU cycles. When the FIFO is filled the DMA Controller transfers the data to the DMA channel of the SCSI Controller.

#### 2.3.1.4 SCSI DMA Control Register

The control signal HIN indicates to the MB87031 the direction of the DMA transfer (DMA READ or DMA WRITE). The HIN signal can be set to "0" or "1" by writing to a dedicated address and can also be read back. The address is shown in the following table. The second table shows the function of the register bit.

#### Table 2-14: SCSI DMA Control Register

| Default I/O Ba<br>Default Offset: |               | •    | F800000<br>0002C00        |
|-----------------------------------|---------------|------|---------------------------|
| Address<br>HEX                    | Offset<br>HEX | Mode | Description               |
| FF802C00                          | 00            | R/W  | SCSI DMA Control Register |

#### Table 2-15: SCSI DMA Direction Bit

| Bit | Value | Description                                      |  |
|-----|-------|--------------------------------------------------|--|
| 0   | 1     | Data from SCSI Controller to FGA-002 (DMA READ)  |  |
|     | 0     | Data from FGA-002 to SCSI Controller (DMA WRITE) |  |

#### 2.3.1.5 The MB80731 Interrupt

The interrupt of the MB80731 is programmable in the FGA-002 Gate Array. It is connected to the Interrupt Request Channel #7 of the FGA-002 Gate Array. For detailed information, please refer to the FGA-002 User's Manual.

#### 2.3.1.6 Summary of the MB87031

| Device                            | MB87031               |
|-----------------------------------|-----------------------|
| Access Address                    | \$FF803400            |
| Port Width                        | Byte                  |
| Interrupt Request Level           | Software programmable |
| FGA-002 Interrupt Request Channel | Local IRQ #7          |

#### 2.3.2 SCSIbus

#### **2.3.2.1** SCSIbus Configuration

Communication on the SCSIbus is only allowed between *two* SCSI devices at any given time. There is a maximum of eight SCSI devices. Each SCSI device has an SCSI I.D. bit assigned as shown in *Figure 2-3: SCSI I.D. Bits*. When two SCSI devices communicate on the SCSIbus, one acts as an initiator and the other acts as a target. An SCSI device usually has a fixed role as an initiator or target, but some devices may be able to assume either role.

An initiator may address up to seven peripheral devices that are connected to a target. An option allows the addressing of up to 2.048 peripheral devices per target using extended messages. Three sample system configurations are shown in *Figure 2-4: Sample SCSI Configurations*.



#### Figure 2-3: SCSI I.D. Bits

Up to eight devices can be supported on the SCSIbus. They can be any combination of initiators and targets. Certain SCSIbus functions are assigned to the target. The initiator may arbitrate for the SCSIbus and select a particular target. The target may request the transfer of COMMAND, DATA, STATUS, or other information and reselect an initiator for the purpose of continuing an operation. Information transfers on the data bus are asynchronous and follow a defined REQ/ACK handshake protocol. One byte of information may be transferred with each handshake. An option is defined for synchronous data transfer.

Figure 2-4: Sample SCSI Configurations



MULTIPLE INITIATOR, MULTIPLE TARGET

### 2.3.2.2 SCSIbus Signals

All SCSIbus signals are available on the EAGLE I/O Connector which is routed to the VMEbus P2 Connector. There are a total of 18 signals. Nine are used for control, and nine are used for data (data signals include the parity signal option).

These signals are described as follows:

| ACK       | (ACKNOWLEDGE)  | A signal driven by an initiator to indicate an acknowledgement for a REQ/ACK data transfer handshake.                                                                                                                                                                                                                                                                                     |
|-----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ATN       | (ATTENTION)    | A signal driven by an initiator to indicate the ATTENTION condition.                                                                                                                                                                                                                                                                                                                      |
| BSY       | (BUSY)         | An "OR-tied" signal that indicates that the bus is being used.                                                                                                                                                                                                                                                                                                                            |
| C/D       | (CONTROL/DATA) | A signal driven by a target that indicates<br>whether CONTROL or DATA information is<br>on the data bus. True indicates CONTROL.                                                                                                                                                                                                                                                          |
| DB(7-0,P) | (DATA BUS)     | Eight data bit signals, plus a parity bit signal<br>which together form a data bus. DB(7) is the<br>most significant bit, and has the highest priority<br>during the ARBITRATION phase. Bit<br>number, significance, and priority decrease<br>downward to DB(0). A data bit is defined as<br>one when the signal value is true, and is defined<br>as zero when the signal value is false. |
| I/O       | (INPUT/OUTPUT) | A signal driven by a target that controls the direction of data movement on the data bus with respect to an initiator. True indicates input to the initiator. This signal is also used to distinguish between SELECTION and RESELECTION phases.                                                                                                                                           |

| MSG | (MESSAGE) | A signal driven by a target during the MESSAGE phase.                                     |
|-----|-----------|-------------------------------------------------------------------------------------------|
| REQ | (REQUEST) | A signal driven by a target to indicate a request for a REQ/ACK data transfer handshake.  |
| RST | (RESET)   | An "OR-tied" signal that indicates the RESET condition.                                   |
| SEL | (SELECT)  | A signal used by an initiator to select a target or by a target to reselect an initiator. |

Data parity DB(P) is odd. The use of parity is a system option (i.e., a system configured so that all SCSI devices on a bus generate parity and have parity detection enabled, or all SCSI devices have parity detection disabled or not implemented). Parity is not valid during the ARBITRATION phase.

#### 2.3.2.3 SCSIbus Signal Termination

Each SCSIbus signal is terminated at the physical start and the physical end of the SCSIbus. Therefore, the termination resistors must be removable, in order to join one SCSI device to two others.

Figure 2-5 on the following page shows the location of the termination resistors on the EAGLE-01C. These termination resistors are plugged into sockets and can be removed if necessary. If the termination resistors are removed, Jumper B4 and B5 must not be installed. The location diagram of Jumpers B4 and B5 is shown in Figure 2-6.











#### 2.3.2.4 SCSIbus Termination Resistor Power (TERMPWR)

Any SCSI device must be able to provide the power supply for the SCSI termination resistors of the SCSIbus to fulfill the SCSI Specification. On the EAGLE-01C the source of the power supply for termination resistors (either the EAGLE-01C or another SCSI device) can be selected via the jumpers B4 and B5. The jumper setting and the location diagram of jumper B4 and B5 is shown in Table 2-16 and Figure 2-6.

#### Table 2-16: Jumper Setting for SCSIbus Termination Resistor Power

| Termination Resistors of:             | Supplied by:            | Jumper B4 | Jumper B5 | Default Setting |
|---------------------------------------|-------------------------|-----------|-----------|-----------------|
| Only EAGLE-01C                        | EAGLE-01C               | 1-2       |           | *               |
| EAGLE-01C and other<br>SCSIbus device | Other SCSIbus<br>device |           | 1-2       |                 |
| EAGLE-01C and other<br>SCSIbus device | EAGLE-01C               | 1-2       | 1-2       |                 |

#### 2.3.2.5 The SCSIbus Signals on VMEbus P2 Connector

The SCSIbus signals are available on the EAGLE I/O Connector which is routed to the VMEbus P2 Connector. The pin assignment for SCSI devices is shown in Table 2-17. The SCSI devices can be connected to the VMEbus P2 Connector via the backpanel SYS68K/IOBP-1 (See *Chapter 2.6 The SYS68K/IOBP-1*).

| Pin Number | Signal Mnemonic |  |  |
|------------|-----------------|--|--|
| A01        | DB0             |  |  |
| A02        | DB1             |  |  |
| A03        | DB2             |  |  |
| A04        | DB3             |  |  |
| A05        | DB4             |  |  |
| A06        | DB5             |  |  |
| A07        | DB6             |  |  |
| A08        | DB7             |  |  |
| A09        | DBP             |  |  |
| A13        | TERMPWR         |  |  |
| A16        | ATN             |  |  |
| A18        | BSY             |  |  |
| A19        | ACK             |  |  |
| A20        | RST             |  |  |
| A21        | MSG             |  |  |
| A22        | SEL             |  |  |
| A23        | C/D             |  |  |
| A24        | REQ             |  |  |
| A25        | I/O             |  |  |

# Table 2-17:Pin Assignment for SCSIbus Signals on VMEbus P2<br/>Connector

#### 2.4 The LAN Interface

The LAN Interface on the EAGLE-01C is built with the Local Area Network Controller for Ethernet (LANCE) AM7990, the Serial Interface Adapter (SIA) AM7992B and a 64 Kbyte Buffer Memory. Interrupts of the AM7990 are fully supported. The LAN Interface is Ethernet and IEEE 802.3 Rev. 0 compatible. The I/O signals of the LAN Interface are provided on the DSUB Connector on the front panel.

#### **Features of the LAN Interface**

- Compatibility to IEEE 802.3/Ethernet
- · Data rate of 10 MBit per second
- · DMA capability
- · Interrupt generation
- · 64 Kbyte SRAM Buffer Memory

The memory buffer is a shared memory allowing access from both the AM7990 and the local CPU. The 64 Kbyte Buffer Memory stores the incoming and outgoing data packets. An incoming data packet is transferred to the Buffer Memory by the LAN Controller. The presence of data in the Buffer Memory is indicated to the CPU by an interrupt. The CPU can then read the data packet from the Buffer Memory. An outgoing data packet is transferred to the Buffer Memory. An outgoing data packet is transferred to the Buffer Memory by the CPU. The LAN Controller then transfers the data packet to the network and indicates the completion of the transfer by an interrupt to the CPU.

The advantage of this architecture is that the CPU and the Ethernet Controller can operate in parallel which guarantees the full realtime capability in a LAN environment and the maximum performance of the system.

#### 2.4.1 LAN Controller for Ethernet (LANCE) AM7990

The LANCE is a 68-pin VLSI device which provides many functions for the connection of a microprocessor to the Ethernet.

#### **Features of the LAN Controller**

- Compatible with Ethernet and IEEE 802.3 Rev. 0
- · On-chip DMA and buffer management
- · 48 byte FIFO
- · 24 bit wide linear addressing
- · Network and packed error reporting
- Back-to-back packet with as little as  $4.1 \,\mu$ s interpacked gap time
- · Diagnostic routines

In the transmitting mode the LANCE transfers data from the Buffer Memory to an internal FIFO called SILO. The serial output of the SILO is connected with the AM7992 SIA, where the data is sent to the Ethernet cable. In the receiving mode the SIA transfers the received data from the Ethernet cable to the serial SILO input and the LANCE transfers the data to the Buffer Memory.

After reset the Control Status Registers CSR0 and CSR3 are cleared, the LANCE is stopped and can be initialized. During initialization the CPU must be bus master of the LAN bus. To start the LANCE operation the STRT bit in the CSR0 must be set. For detailed information please refer to the AM7990 LANCE Data sheets in *Chapter 5 COPIES OF DATA SHEETS*.

### 2.4.1.1 Address Map of the LANCE Registers

The LANCE contains one Register Address Pointer (RAP) and four status control registers (CSR0, CSR1, CSR2, CSR3). To read or write to CSR1, CSR2, and CSR3 the LANCE must be stopped by setting the stop bit in CSR0. Therefore, CSR0 and RAP can be accessed at anytime the LANCE is in the slave mode. To read or write to a CSR the number of the CSR must be written to the RAP first. The address map is shown in the table on the page to follow.

| I/O Address:<br>Default Offset:                          |                                  |                                   | \$FEF8 0000<br>\$0000 0000          |                                                                                                                                                              |  |
|----------------------------------------------------------|----------------------------------|-----------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Address<br>HEX                                           | Offset<br>HEX                    | Reset<br>Value                    | Label                               | Description                                                                                                                                                  |  |
| FEF80002<br>FEF80000<br>FEF80000<br>FEF80000<br>FEF80000 | 02<br>00<br>00<br>00<br>00<br>00 | 0000<br>0004<br>N/A<br>N/A<br>N/A | RAP<br>CSR0<br>CSR1<br>CSR2<br>CSR3 | Register Address Pointer<br>Control and Status Register 0<br>Control and Status Register 1<br>Control and Status Register 2<br>Control and Status Register 3 |  |
| N/A = NOT APPLICABLE OR NOT EFFECTED                     |                                  |                                   |                                     |                                                                                                                                                              |  |

#### Table 2-18: LANCE Register Layout

## 2.4.1.2 The LANCE Interrupt

The interrupt of the LANCE is programmable in the FGA-002 Gate Array. It is connected to the Interrupt Request Channel #6 of the FGA-002 Gate Array. For detailed information please refer to the FGA-002 User's Manual.

### 2.4.1.3 Summary of the LANCE

.

| Device                            | AM7990       |
|-----------------------------------|--------------|
| Access Address                    | \$FEF80000   |
| Access Mode                       | Word Only    |
| Interrupt Request Level           | Programmable |
| FGA-002 Interrupt Request Channel | Local IRQ #6 |

#### 2.4.2 The Am7992B Serial Interface Adapter (SIA)

The Am7992B Serial Interface Adapter (SIA) is a Manchester Encoder/Decoder compatible with IEEE-802.3, Cheapernet, and Ethernet specifications.

#### Features of the Am 7992B SIA

- Compatible with Ethernet/Cheapernet/IEEE-802.3 specifications
- · Crystal controlled Manchester Encoder
- Manchester Decoder acquired clock and data within four bit times with an accuracy of +/-3 ns
- Guaranteed carrier and collision detection squelch threshold limits
  - Carrier/collision detected for inputs greater than -275 mV
  - No carrier/collision for inputs less than -175 mV
  - Input signal conditioning reject transient noise
    - Transients < 10 ns for collision detector inputs
    - Transients <20 ns for carrier detector inputs
  - Receiver decodes Manchester data with worst case +/-19 ns of clock jitter (at 10 MHz)
  - TTL compatible host interface
  - Transmit accuracy +/-0.01% (without adjustments)

#### 2.4.2.1 The Am7992B Transmitter

The transmitter encodes data coming from the LANCE into a Manchester II Code (see below). The output signal is sent to a buffer on the CPU board. An oscillator provides the 20 MHz clock signal for the LANCE. For further details please refer to the Am7992B Data Sheet, found in *Chapter 5, COPIES OF DATA SHEETS*.

Figure 2-7: Manchester II Code Transmitter Encoding



#### 2.4.2.2 The Am7992B Receiver

The receiver signals the LANCE that there is a message to receive. It decodes the Manchester encoded data stream and sends the data to the LANCE (see next figure). For further information please refer to the Am7992B Data Sheets in *Chapter 5*, *COPIES OF DATA SHEETS*.

Figure 2-8: Decoding with the Manchester Decoder



#### 2.4.3 Ethernet Signals

The I/O signals of the LAN Interface are provided on the 15-pin female DSUB Connector on the front panel. On the DSUB Connector the following Ethernet signals are available:

#### Transmit+ / Transmit- (differential line output)

This line pair is intended to operate into terminated transmission lines.

#### **Receive+ / Receive- (differential line input)**

This pair of internally biased line receivers consists of a carrier detect receiver and a data recovery receiver.

#### Collision+ / Collision- (differential line input)

This pair of internally biased line receivers have offset threshold and noise filtering.

In addition +12 Volts/GND is available on the DSUB Connector. The +12 Volts are protected by the 500 mAmps fuse SI1 to fulfill the IEEE Specification for LANs. The fuse can be short-circuited by inserting jumper B2.

#### Table 2-19: Jumper Setting for Ethernet Power Supply

| Description                              | Jumper B2 | Default Setting |
|------------------------------------------|-----------|-----------------|
| 12 Volts on DSUB with fuse protection    |           | *               |
| 12 Volts on DSUB without fuse protection | 1-2       |                 |







#### 2.4.3.1 Ethernet on the 15-Pin Female DSUB Connector

The Ethernet signals are available on the 15-pin female DSUB Connector on the front panel. The pinout of the DSUB Connector is shown in Figure 2-10 and the pin assignment is shown in the next table.

Table 2-20: Pin Assignment of the 15 Pin Female DSUB Connector

| Pin Number | Signal Mnemonic |
|------------|-----------------|
| 1          | GND             |
| 2          | Collision+      |
| 3          | Transmit+       |
| 4          | GND             |
| 5          | Receive+        |
| 6          | GND             |
| 7          | N.C.            |
| 8          | GND             |
| 9          | Collision-      |
| 10         | Transmit-       |
| 11         | GND             |
| 12         | Receive-        |
| 13         | +12V            |
| 14         | GND             |
| 15         | N.C.            |
|            |                 |

#### Figure 2-10: Pinout of the 15 Pin Female DSUB Connector



#### 2.4.4 LAN Buffer Memory

The LAN Buffer Memory is accessible via address \$FEF00000 to \$FEF0FFFF and the port width is 16 bits (word). The LAN Buffer Memory consists of two 32 K \* 8 bit SRAMs. These devices can be accessed by the CPU and the LANCE as long as the CPU or LANCE has bus mastership. With this dedicated memory, it is not necessary to stop the CPU while the LANCE is bus master. This assures that the realtime capability of the CPU board is guaranteed.

# 2.4.4.1 Summary of the LAN RAM

Devices

Access Address

Capacity

Port Width

2 \* 32K \* 8 SRAM

\$FEF00000 to \$FEF0FFFF

64 Kbytes

Word

#### 2.5 The EAGLE FLASH EPROM

The EAGLE-01C holds 256 Kbytes FLASH EPROM. Two 128 Kbyte FLASH EPROM devices are installed on the EAGLE-01C. The address range for the FLASH EPROMs reaches from \$FD800000 to \$FD83FFFF. Two 128 Kbyte devices are installed by default. For programming the FLASH EPROMs a special programming algorithm is needed. For detailed information about programming the FLASH EPROMs see *Chapter 5, COPIES OF DATA SHEETS*. The FLASH EPROMs are write protected by switch 10 of the dip switch array SW1. When the FLASH EPROMs must be programmed the switch 10 of the dip switch array SW1 has to be closed. The location diagram of the dip switch array SW1 is shown in Figure 2-1.

#### Table 2-21: Dip Switch Setting for FLASH EPROMs

| Write protection of FLASH EPROMs | Switch 10 | Default Setting |
|----------------------------------|-----------|-----------------|
| yes                              | off       | *               |
| no                               | on        |                 |

#### 2.5.1 Summary of the EAGLE FLASH EPROM

Devices 2 \* 128 K \* 8

Access Address \$FD800000 to \$FD83FFFF

Capacity 256 Kbytes

Port Width Byte

#### 2.6 The SYS68K/IOBP-1

There is a back panel SYS68K/IOBP-1 available from FORCE COMPUTERS. This board can be plugged into the VMEbus P2 Connector of a VMEbus board which carries the EAGLE-01C. The backpanel contains the connectors (P1)...(P4). The connector (P1) is plugged on the backside of the VMEbus P2 Connector. Note that the pins of connector (P1) are numbered in the other direction than the pins of VMEbus P2 Connector. The backpanel also contains the 50-pin male SCSIbus Connector (P2), the 34-pin male Floppy Drive Connector (P3), and the 64-pin male connector (P4). The connector (P4) contains all signals of row A and row C of the VMEbus P2 Connector. The pinout of the connectors (P1)...(P4) are shown in the following tables.

| Pin No. | Pin No.                                                                                                                                                                                                                                 | Row a           | Row b           | Row c             |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-------------------|--|
| P1      | VMEbus P2                                                                                                                                                                                                                               | Signal Mnemonic | Signal Mnemonic | Signal Mnemonic   |  |
| 32      | 1                                                                                                                                                                                                                                       | DB 0            |                 | RWC/RPM           |  |
| 31      | 2                                                                                                                                                                                                                                       | DB 0<br>DB 1    | GND             | HEADLOAD/EJECT    |  |
| 30      | 3                                                                                                                                                                                                                                       | DB 1<br>DB 2    |                 | DRIVE SELECT 2    |  |
| 29      | 4                                                                                                                                                                                                                                       | DB 3            |                 | INDEX             |  |
| 28      | 5                                                                                                                                                                                                                                       | DB 4            |                 | DRIVE SELECT 1    |  |
| 27      | 6                                                                                                                                                                                                                                       | DB 5            |                 | DRIVE SELECT 2    |  |
| 26      | 7                                                                                                                                                                                                                                       | DB 6            |                 | DRIVE SELECT 1    |  |
| 25      | 8                                                                                                                                                                                                                                       | DB 7            |                 | MOTOR ON/HEADLOAD |  |
| 24      | 9                                                                                                                                                                                                                                       | DB P            |                 | DIRECTION IN      |  |
| 23      | 10                                                                                                                                                                                                                                      | GND             |                 | STEP              |  |
| 22      | 11                                                                                                                                                                                                                                      | GND             |                 | WRITE DATA        |  |
| 21      | 12                                                                                                                                                                                                                                      | GND             | GND             | WRITE GATE        |  |
| 20      | 13                                                                                                                                                                                                                                      | TERMPWR         |                 | TRACK 000         |  |
| 19      | 14                                                                                                                                                                                                                                      | GND             |                 | WRITE PROTECT     |  |
| 18      | 15                                                                                                                                                                                                                                      | GND             |                 | READ DATA         |  |
| 17      | 16                                                                                                                                                                                                                                      | ATN             |                 | HEAD SELECT       |  |
| 16      | 17                                                                                                                                                                                                                                      | GND             |                 | DISK CHANGE       |  |
| 15      | 18                                                                                                                                                                                                                                      | BSY             |                 | N.C.              |  |
| 14      | 19                                                                                                                                                                                                                                      | ACK             |                 | GND               |  |
| 13      | 20                                                                                                                                                                                                                                      | RST             |                 | GND               |  |
| 12      | 21                                                                                                                                                                                                                                      | MSG             |                 | N.C.              |  |
| 11      | 22                                                                                                                                                                                                                                      | SEL             | GND             | GND               |  |
| 10      | 23                                                                                                                                                                                                                                      | C/D             |                 | GND               |  |
| 9       | 24                                                                                                                                                                                                                                      | REQ             |                 | N.C.              |  |
| 8       | 25                                                                                                                                                                                                                                      | I/O             |                 | N.C.              |  |
| 7       | 26                                                                                                                                                                                                                                      | N.C.            |                 | N.C.              |  |
| 6       | 27                                                                                                                                                                                                                                      | GND             |                 | RESERVED          |  |
| 5       | 28                                                                                                                                                                                                                                      | N.C.            |                 | RESERVED          |  |
| 4       | 29                                                                                                                                                                                                                                      | RESERVED        |                 | RESERVED          |  |
| 3       | 30                                                                                                                                                                                                                                      | RESERVED        |                 | RESERVED          |  |
| 2       | 31                                                                                                                                                                                                                                      | RESERVED        | GND             | RESERVED          |  |
| 1       | 32                                                                                                                                                                                                                                      | RESERVED        |                 | RESERVED          |  |
| NOTE:   | NOTE: The table above shows the pinout of the 96-pin female connector which performs the connection to the VMEbus P2 Connector. If the module SYS68K/IOBP-1 is plugged in, Pin 32a of P1 connects to Pin 1a of the VMEbus P2 Connector. |                 |                 |                   |  |

# Table 2-22: SYS68K/IOBP-1 P1 Pin Assignment

| Pin No. | Signal Mnemonic | Connected to<br>VMEbus P2 Pin | Pin No. | Signal Mnemonic |
|---------|-----------------|-------------------------------|---------|-----------------|
| 2       | DB 0            | A01                           | 1       | GND             |
| 4       | . DB 1          | A02                           | 3       | GND             |
| 6       | <b>DB 2</b>     | A03                           | 3<br>5  | GND             |
| 8       | DB 3            | A04                           | 7       | GND             |
| . 10    | DB 4            | A05                           | 9       | GND             |
| 12      | DB 5            | A06                           | ii ii   | GND             |
| 14      | DB 6            | A07                           | 13      | GND             |
| 16      | DB 7            | A08                           | 15      | GND             |
| 18      | DB P            | A09                           | 17      | GND             |
| 20      | GND             |                               | 19      | GND             |
| 22      | GND             |                               | 21      | GND             |
| 24      | GND             |                               | 23      | GND             |
| 26      | TERMPWR         | A13                           | 25      | N.C.            |
| 28      | GND             |                               | 27      | GND             |
| 30      | GND             |                               | 29      | GND             |
| 32      | ATN             | A16                           | 31      | GND             |
| 34      | GND             |                               | 33      | GND             |
| 36      | BSY             | A18                           | 35      | GND             |
| 38      | ACK             | A19                           | 37      | GND             |
| 40      | RST             | A20                           | 39      | GND             |
| 42      | MSG             | A21                           | 41      | GND             |
| 44      | SEL             | A22                           | 43      | GND             |
| 46      | C/D             | A23                           | 45      | GND             |
| 48      | REQ             | A24                           | 47      | GND             |
| 50      | I/O             | A25                           | 49      | GND             |

# Table 2-23: SYS68K/IOBP-1 P2 Pin Assignment

| Pin No. | Signal Mnemonic   | Connected to<br>VMEbus P2 Pin | Pin No. | Signal Mnemonic |
|---------|-------------------|-------------------------------|---------|-----------------|
| 2       | RWC/RPM           | C01                           | 1       | GND             |
| 4       | HEADLOAD/EJECT    | C02                           | 3       | GND             |
| 6       | DRIVE SELECT 2    | C03                           | 5       | GND             |
| 8       | INDEX             | C04                           | 7       | GND             |
| 10      | DRIVE SELECT 1    | C05                           | 9       | GND             |
| 12      | DRIVE SELECT 2    | C06                           | 11      | GND             |
| 14      | DRIVE SELECT 1    | C07                           | 13      | GND             |
| 16      | MOTOR ON/HEADLOAD | C08                           | 15      | GND             |
| 18      | DIRECTION IN      | C09                           | 17      | GND             |
| 20      | STEP              | C10                           | 19      | GND             |
| 22      | WRITE DATA        | C11                           | 21      | GND             |
| 24      | WRITE GATE        | C12                           | 23      | GND             |
| 26      | TRACK 000         | C13                           | 25      | GND             |
| 28      | WRITE PROTECT     | C14                           | 27      | GND             |
| 30      | READ DATA         | C15                           | 29      | GND             |
| 32      | HEAD SELECT       | C16                           | 31      | GND             |
| 34      | DISK CHANGE       | C17                           | 33      | GND             |

•

# Table 2-24: SYS68K/IOBP-1 P3 Pin Assignment

| Pin No.                    | o. Rowa Rowc    |                   |  |  |
|----------------------------|-----------------|-------------------|--|--|
| ГШ NO.                     | Signal Mnemonic | Signal Mnemonic   |  |  |
|                            | Signal Milenome |                   |  |  |
| 1                          | DB 0            | RWC/RPM           |  |  |
| 2                          | <b>DB</b> 1     | HEADLOAD/EJECT    |  |  |
| 3                          | DB 2            | DRIVE SELECT 2    |  |  |
| 1<br>2<br>3<br>4<br>5<br>6 | DB 3            | INDEX             |  |  |
| 5                          | DB 4            | DRIVE SELECT 1    |  |  |
| 6                          | DB 5            | DRIVE SELECT 2    |  |  |
| 7.                         | DB 6            | DRIVE SELECT 1    |  |  |
| 8                          | <b>DB 7</b>     | MOTOR ON/HEADLOAD |  |  |
| 9                          | DB P            | DIRECTION IN      |  |  |
| 10                         | GND             | STEP              |  |  |
| 11                         | GND             | WRITE DATA        |  |  |
| 12                         | GND             | WRITE GATE        |  |  |
| 13                         | TERMPWR         | TRACK 000         |  |  |
| 14                         | GND             | WRITE PROTECT     |  |  |
| 15                         | GND             | READ DATA         |  |  |
| 16                         | ATN             | HEAD SELECT       |  |  |
| 17                         | GND             | DISK CHANGE       |  |  |
| 18                         | BSY             | N.C.              |  |  |
| 19                         | ACK             | GND               |  |  |
| 20                         | RST             | GND               |  |  |
| 21                         | MSG             | N.C.              |  |  |
| 22                         | SEL             | GND               |  |  |
| 23                         | C/D             | GND               |  |  |
| 24                         | REQ             | N.C.              |  |  |
| 25                         | I/O             | N.C.              |  |  |
| 26                         | N.C.            | N.C.              |  |  |
| 27                         | GND             | RESERVED          |  |  |
| 28                         | N.C.            | RESERVED          |  |  |
| 29                         | RESERVED        | RESERVED          |  |  |
| 30                         | RESERVED        | RESERVED          |  |  |
| 31                         | RESERVED        | RESERVED          |  |  |
| 32                         | RESERVED        | RESERVED          |  |  |

# Table 2-25: SYS68K/IOBP-1 P4 Pin Assignment

.

## 3. CIRCUIT SCHEMATICS

. . . .

.

This page is intentionally left blank.



,



·

















`



· .

## 4. COMPONENT PART LISTS

## FOR INTERNAL USE ONLY

This page is intentionally left blank.

## 5. COPIES OF DATA SHEETS

Page 57

This page intentionally left blank

### **COPIES OF DATA SHEETS**

Floppy Disk Controller WD37C65 SCSI Controller MB87031 LAN Controller AM7990 Serial Interface Adapter AM7992B FLASH EPROM 28F010 .

This page is intentionally left blank.

.



35 Marcus Blvd Hauppauge, NY 11788 (516) 273-3100 Fax (516) 231-6004

## FDC37C65C PRELIMINARY INFORMATION

## Floppy Disk Subsystem Controller

### FEATURES

- Supports 1 Mbit/sec Data Rate
- Integrates Formatter/Controller, Data Separation, Write Precompensation, Data Rate Selection, Clock Generation, and Drive Interface Drivers and Receivers ers into one Chip
- IBM PC/AT Compatible Format (Single and Double Density)
- Provides Required Signal Qualification to DMA Channel (in PC/AT Mode)
- BIOS Compatible; Dual Speed Spindle Drive Support
- Enhanced Host Interface:
  - Supports 12 MHz, 286 µP With 0 Wait States
  - Capable of Driving 20 LS TTL Loads
  - Schmitt Trigger Inputs (Except Data Bus and XTAL)
- □ Compatible With PD8080/85, PD8086, and PD780 (Z-80®) Microprocessors
- Internal Address Mark Detection Circuitry
- Internal Power Up Reset Circuitry
- Provides Direct Interface to Floppy Disk Drives
- Provides the Disk Change and Disk Change Enable Inputs, Allowing Direct Connection of DCHG to the FDC37C65C
- 48 mA Sink Drivers and Schmitt Trigger Line Receivers
- D 125, 250, 300, 500, & 1 Mbit/sec Data Rates
- Multisector and Multitrack Transfer Capability
- □ User Programmable Track Stepping Rate and Head Load/Unload Time
- Controls up to Four Floppy or Micro-Floppy Drives

The FDC37C65C is a CMOS device which interfaces a

host microprocessor to the floppy disk drive. It inte-

grates the functions of the Formatter/Controller, Data

Separator, Write Precompensation, Data Rate Selection,

Clock Generation, High Current Drivers, and TTL

compatible Schmitt Trigger Receivers. The FDC37C65C

consists of a microprocessor interface, a microsequenc-

The microprocessor interface of the FDC37C65C

supports a 12 MHz, 286 microprocessor bus without the

use of wait states. For PC and PC//AT applications, the

device provides qualification of interrupt and DMA

er, and a disk drive interface.

requests.

- Data Transfer in DMA or Non-DMA Mode
- Parallel Seek Operations on up to Four Drives

PIN CONFIGURATION



- Integrates Improved Standard Microsystems FDC92C39 Digital Data Separator Algorithm
- Automatic Write Precompensation, Selectable Between 125 or 187 nsec, with disable option
- D Power-Down Mode For Reduced Power Consumption
- On-Chip Clock Generation
- Pin-to-Pin Compatible with Industry Standard WD37C65C
- Available in Either 40-Pin DIP or 44-Pin PLCC
- XTAL Oscillator Circuits (PLCC)/TTL Clock Inputs (DIP) Allow for Use Of Non-Standard As Well As Standard Data Rates
- □ Low Power CMOS, +5 V Supply

#### **GENERAL DESCRIPTION**

All host and drive related inputs except for the data bus and crystal have internal Schmitt triggers.

The FDC37C65C uses two clock inputs which provide the necessary signals for internal timing. A 16 MHz oscillator handles the data rates of 500, 250, and 125 Kbits/sec. a 9.6 MHz oscillator handles the 300 Kbits/sec data rate used in PC/AT designs. A 32 MHz oscillator is used for the 1 Mbit/sec data rate. Internal crystal oscillator circuits may be used with the 44-pin PLCC package. The 40-pin DIP requires TTL clock inputs.

The FDC37C65C may be used in applications using two speed disk drives, such as AT compatible systems

The disk drive interface of the FDC37C65C directly connects to up to four drives. All drive-related outputs can sink 48 mA; all host related outputs can sink 12 mA.

\* IBM and PC/AT are registered trademarks of International Business Machines Corporation. Z-80 is a registered trademark of Z-log Incorporated. (+ t+)

# TABLE OF CONTENTS

| FEATURES                           | 1   |
|------------------------------------|-----|
| PIN CONFIGURATION                  | 1   |
| GENERAL DESCRIPTION                | 1   |
| DESCRIPTION OF PIN FUNCTIONS       | 3   |
| SYSTEM DESCRIPTION                 | 8   |
|                                    | 8   |
|                                    | 8   |
| FUNCTIONAL DESCRIPTION             | 8   |
|                                    | 8   |
| INTERNAL REGISTERS                 | 9   |
| Data Rate Selection Register       | 9   |
| Main Status Register               | 0   |
| Status Registers 0-3 1             | 1   |
| Data Register                      | 4   |
| Digital Output Register            | 14  |
| MODES OF OPERATION 1               | 4   |
| Base Mode                          | 4   |
| PC/AT/EISA Mode                    | 4   |
| Special Mode                       | 15  |
| POLLING ROUTINE 1                  | 1.5 |
| RESET LOGIC                        | 16  |
| CLOCK GENERATION                   | 17  |
| COMMAND SEQUENCE                   | 17  |
| INSTRUCTION SET                    | 20  |
| FUNCTIONAL DESCRIPTION OF COMMANDS | 29  |
| OPERATIONAL DESCRIPTION            | 36  |
| MAXIMUM GUARANTEED RATINGS         | 36  |
| DC ELECTRICAL CHARACTERISTICS      | 36  |
| TIMING DIAGRAMS                    | 37  |
|                                    |     |

|                          |                | ·····                                        | DESCRIP | TION OF PIN FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|--------------------------|----------------|----------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PLCC<br>PIN NO.          | DIP PIN<br>NO. | NAME                                         | SYMBOL  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| HOST PROCESSOR INTERFACE |                |                                              |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 7-14                     | 7-14           | Data 0-7                                     | D0-D7   | Input/Output. The data bus connection used by the host microprocessor to transmit data to and from the FDC37C65C. These pins are in a high-impedance state when not in use.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 1                        | 1              | Read                                         | RD      | Input. This active low signal is issued by the host microproces-<br>sor to indicate a read operation. A low pulse on this input<br>when the FDC37C65C is selected enables data from the Buffer<br>or Status Register onto the data bus for reading by the host.                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 2                        | 2              | Write                                        | WR      | Input. This active low signal is issued by the host microproces-<br>sor to indicate a write operation. A low pulse on this input<br>when the FDC37C65C is selected enables data from the data<br>bus to be written into the FDC37C65C.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 3                        | 3              | Chip<br>Select                               | टड      | Input. This active low signal issued by the host microprocessor allows data transfers to occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 4                        | 4              | Address 0                                    | A0      | Input. This host processor signal determines whether data or status information will appear on the Data Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 15                       | 15             | Direct<br>Memory<br>Access<br>Request        | DMA     | Output. This active high signal is a DMA request for byte<br>transfers of data. This signal is cleared when the host re-<br>sponds with the DACK signal going low. This signal is normally<br>driven in the Base Mode. When the FDC37C65C is in the<br>Special or PC/AT mode, this pin is three-stated and is enabled<br>by the DMAEN signal from the Digital Output Register.                                                                                                                                                                                                                                                        |  |  |
| 5                        | 5              | DMA Ac-<br>knowledge                         | DACK    | Input. A low level on this pin indicates a response by the host<br>to a DMA request. It is used by the DMA controller to transfer<br>data to or from the FDC37C65C. Logical equivalent to CS and<br>A0 = logic "1". In Special or PC/AT mode, this signal is quali-<br>fied by DMAEN from the Digital Output Register.                                                                                                                                                                                                                                                                                                                |  |  |
| 6                        | 6              | Terminal<br>Count                            | тс      | Input. This active high signal indicates to the FDC37C65C that<br>data transfer is complete. In Base Mode, TC will be qualified<br>by DACK only in DMA operations. In non-DMA (Programmed<br>I/O) operations, CS and the RD and WR signals are used as a<br>gating function. In Special or PC/AT mode, TC will always be<br>qualified by DACK (whether in DMA or non-DMA operations),<br>but will only be qualified by DACK if DMAEN from the Digital<br>Output Register is a logic "1". In PC/AT mode, non-DMA<br>operations will occur successfully but will cause an abnormal<br>termination error at the completion of a command. |  |  |
| 16                       | 16             | Interrupt                                    | IRQ     | Output. This interrupt indicates the completion of command<br>execution or data transfer requests (in non-DMA operations).<br>This signal is normally driven in the Base mode. When the<br>FDC37C65C is in the Special or PC/AT mode, this pin is three-<br>stated and is enabled by the DMAEN signal from the Digital<br>Output Register.                                                                                                                                                                                                                                                                                            |  |  |
| 18                       | 17             | Load Digi-<br>tal Output<br>Register         | LDOR    | Input. Active low Digital Output Register load enable. When LDOR and WR are low, the Data Bus is latched into the Digital Output Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 19                       | 18             | Load Data<br>Rate Se-<br>lection<br>Register | LDCR    | Input. This active low signal allows access to the Data Rate<br>Selection Register. When LDCR and WR are low, the two<br>LSB's of the Data Bus are latched into this register. When<br>LDCR, RD, and DCHGEN are low, the DCHG input status is<br>carried on bit D7 of the Data Bus, while bits D0-D6 remain in<br>the high impedance state.                                                                                                                                                                                                                                                                                           |  |  |

### DESCRIPTION OF PIN FUNCTIONS

|                 |                |                                     |           | TION OF PIN FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|----------------|-------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLCC<br>PIN NO. | DIP PIN<br>NO. | NAME                                | SYMBOL    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20              | 19             | Réset                               | RST       | Input. This active high signal resets the FDC37C65C. When<br>RST occurs, the FDC37C65C defaults to Base Mode and the<br>data rate is defaulted to 250K MFM (or 125K FM, code depen-<br>dent). When RST is active, the high current driver outputs to<br>the disk drive are disabled.                                                                                                                                                                                                      |
|                 |                |                                     | D         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21              | 20             | Read Disk<br>Data                   | RDD       | Input. Raw serial bit stream from the disk drive. Each falling edge represents a flux transition of the encoded data.                                                                                                                                                                                                                                                                                                                                                                     |
| 29              | 26             | Write<br>Enable                     | WE        | Output. This active low high current driver allows current to flow through the write head. It becomes active just prior to writing to the diskette.                                                                                                                                                                                                                                                                                                                                       |
| 30              | 27             | Write<br>Data                       | <u>wn</u> | Output. This active low high current driver provides the en-<br>coded data to the disk drive. Each falling edge causes a flux<br>transition on the media.                                                                                                                                                                                                                                                                                                                                 |
| 28              | 25             | Head<br>Select                      | ਜਤ        | Output. This high current output selects the floppy disk side for reading or writing. A logic "1" on this pin means side 0 will be accessed, while a logic "0" means side 1 will be accessed.                                                                                                                                                                                                                                                                                             |
| 31              | 28             | Direction<br>Control                | DIRC      | Output. This high current output determines the direction of the head movement. A logic "1" on this pin means outward motion, while a logic "0" means inward motion.                                                                                                                                                                                                                                                                                                                      |
| 32              | 29             | Step Pulse                          | STEP      | Output. This active low high current driver issues a low pulse for each track-to-track movement of the head.                                                                                                                                                                                                                                                                                                                                                                              |
| 40              | N/A            | Disk<br>Change                      | DCHG      | Input. This active low input senses from the disk drive that the<br>drive door is open or that the diskette has possibly been<br>changed since the last drive selection.                                                                                                                                                                                                                                                                                                                  |
| 17              | NiA            | Disk<br>Change<br>Enable            | DCHGEN    | Input. This active low input enables the DCHG input status<br>onto D7 during a read of the Data Rate Selection Register.<br>This signal is connected to an internal pull-up resistor.                                                                                                                                                                                                                                                                                                     |
| 33              | 30             | Drive<br>Select 1                   | DST       | Output. This is an active low output. When the FDC37C65C is<br>in the PC/AT/EISA Mode, a logic "0" on DSEL and a logic "1"<br>on MOEN1 from the Digital Output Register will cause DS1 to<br>enable the Drive 1 interface. When the FDC37C65C is in the<br>Base Mode or the Special Mode, DS1 is number 1 of the four<br>decoded Unit Selects, as specified in the device command, and<br>the Digital Output Register has no effect.                                                      |
| 35              | 32             | Drive<br>Select 2                   | DS2       | Output. This is an active low output. When the FDC37C65C is<br>in the PC/AT Mode, a logic "0" on DSEL and a logic "1" on<br>MOEN2 from the Digital Output Register will cause DS2 to<br>enable the Drive 2 interface. When the FDC37C65C is in the<br>Base Mode or the Special Mode, this output is number 2 of the<br>four decoded Unit Solects, as specified in the device command,<br>and the Digital Output register has no effect.                                                   |
| 36              | 33             | Motor<br>On 17<br>Drive<br>Select 3 | MO1/DS3   | Output. This is an active low output. When the FDC37C65C is<br>in the PC/AT Mode, a logic "1" on MOEN1 from the Digital<br>Output Register will cause this output to go low, thereby acting<br>as the Motor-On Enable for Drive 1. When the FDC37C65C is<br>in the Base Mode or the Special Mode, this output is number 3<br>of the four decoded Unit Selects, as specified in the device<br>command, thereby acting as drive select 3, and the Digital<br>Output Register has no effect. |

|                      | DESCRIPTION OF PIN FUNCTIONS |                                                                |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|----------------------|------------------------------|----------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PLCC                 |                              | NAME                                                           | SYMBOL          | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| <u>PIN NO.</u><br>37 | <u>NO.</u><br>34             | Motor<br>On 2/<br>Drive<br>Select 4                            | MO2/DS4         | Output. This is an active low output. When the FDC37C65C is<br>in the PC/AT Mode, a logic "1" on MOEN2 from the Digital<br>Output Register will cause this output to go low, thereby acting<br>as the Motor-On Enable for Drive 2. When the FDC37C65C is<br>in the Base Mode or the Special Mode, this output is number 4<br>of the four decoded Unit Selects, as specified in the device<br>command, thereby acting as drive select 4, and the Digital<br>Output Register has no effect. |  |  |
| 38                   | 35                           | Head<br>Loaded                                                 | HOL             | Output. This active low high current driving signal causes the head to be loaded against the media in the selected drive.                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 39                   | 36                           | Reduced<br>Write<br>Current/<br>Revolut-<br>ions Per<br>Minute | RWC/RPM         | Output. This active low signal occurs when tracks greater than<br>28 are being accessed, and the inner track location has caused<br>increased bit density. This signal, valid in the Base Mode and<br>the Special Mode, indicates that write precompensation is<br>necessary. In the PC/AT mode, this signal may be used to<br>select a 300 RPM spindle rate on two speed drives when 250<br>Kbps MFM is selected.                                                                        |  |  |
| 41                   | 37                           | Write<br>Protected                                             | WP              | Input. This active low Schmitt Trigger input senses from the disk drive that a disk is write protected.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 42                   | 38                           | Track 00                                                       | TROO            | Input. This active low Schmitt Trigger input senses from the disk drive that the head is positioned over the outermost track.                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 43                   | 39                           | Index                                                          | אסו             | Input. This active low Schmitt Trigger input senses from the disk drive that the head is positioned over the beginning of a track, as marked by an index hole.                                                                                                                                                                                                                                                                                                                            |  |  |
| 27                   | 24                           | Precomp-<br>ensation<br>Value                                  | PCVAL           | Input. The level on this pin determines the amount of write<br>precompensation to be used on the inner tracks of the diskette.<br>Logic "1" programs the value of 125 ns; Logic "0" programs<br>187 ns. When precompensation is disabled, this pin has no<br>effect. This input has an internal pull up resistor.                                                                                                                                                                         |  |  |
| 24                   | 22                           | Drive<br>Type                                                  | DRV             | Input. This input is used to indicate the drive type being used.<br>A logic "0" on this input indicates a two speed spindle motor, in<br>which case the second clock input should be grounded. This<br>signal is connected to an internal pull-up resistor.                                                                                                                                                                                                                               |  |  |
|                      |                              |                                                                | I               | MISCELLANEOUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| N/A                  | 23                           | CLOCK 1                                                        | CLK1            | 16 or 32 MHz TTL level clock input for all standard data rates.<br>The frequency should be accurate to within 0.1% and may have<br>a 40% or 60% duty cycle.                                                                                                                                                                                                                                                                                                                               |  |  |
| N/A                  | 21                           | CLOCK 2                                                        | CLK2            | TTL level clock input for non-standard data rates. The fre-<br>quency is selected from the Data Rate Selection Register in<br>Table 1.                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 25,26                | <b>N/A</b>                   | Crystal 1,<br>Crystal 1                                        | XTAL1,<br>XTAL1 | An external 16 MHz or 32 MHz series resonant crystal should<br>be connected to these pins for all standard data rates. If an<br>external 16 MHz or 32 MHz TTL clock is used instead, it should<br>be connected to XTAL1 and XTAL1 should be left floating.                                                                                                                                                                                                                                |  |  |
| 22,23                | N/A                          | Crystal 2,<br>Crystal 2                                        | XTAL2,<br>XTAL2 | An external series resonant crystal should be connected to<br>these pins for all non-standard data rates. If an external TTL<br>clock is used instead, it should be connected to XTAL2 and<br>XTAL2 should be left floating.                                                                                                                                                                                                                                                              |  |  |
| 44                   | 40                           | Power                                                          | V <sub>cc</sub> | + 5 Volt supply pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 34                   | 31                           | Ground                                                         | GND             | Ground pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |

### DESCRIPTION OF PIN FUNCTIONS





#### SYSTEM DESCRIPTION

The system block diagram in Figure 1 illustrates a complete implementation of the FDC37C65C used in a floppy disk drive system. The FDC37C65C provides simple interfacing to both the microprocessor and the drive.

#### MICROPROCESSOR INTERFACE

The left half of Figure 1 illustrates a typical FDC37C65C interface to the microprocessor. It consists of an 8-bit data bus and a control bus: All signals are directly connected to the host, eliminating the need for external circuitry. All inputs to the FDC37C65C (except for the data bus) are Schmitt triggers and the outputs to the host are able to sink 12 mA. The FDC37C65C contains the following internal registers for interfacing to the host microprocessor: Data Rate Selection Register, Main Status Register, Data Register, and Digital Output Register. The Data Rate Selection Register selects the data rate for internal clock generation and synchronization of disk data transfers. The Main Status Register contains information related to the status of the drives and provides handshaking functions for the microproces-

sor. The Data Register is used in data transfers with the drive during Read and Write operations, and holds the command blocks issued by the microprocessor and the results after the command is executed. The Digital Output Register provides the Motor On and Drive Select signals and the DMA Enable qualifier for the DMA and IRQ outputs.

#### DRIVE INTERFACE

The right half of Figure 1 illustrates a typical FDC37C65C interface to up to four drives. All signals are directly connected to the drives, eliminating the need for external circuitry. All inputs to the FDC37C65C are Schmitt triggers and the outputs are open-drain, 48 mA drivers. The FDC37C65C contains the Standard Microsystems FDC92C39 algorithm, which provides Data Separation as well as Automatic Write Precompensation. The FDC37C65C also provides the DCHG and DCHGEN signals, which provide the option of connecting the DCHG signal directly to the FDC37C65C so that the DCHG status may be supplied to the host microprocessor via D7 of the data bus.

### FUNCTIONAL DESCRIPTION

Refer to Figure 2 for Internal Block Diagram of the FDC37C65C.

#### HOST INTERFACE LOGIC

The internal registers are used chiefly in writing commands to, and reading status from, the FDC37C65C. In the interfacing of the internal registers to the host, the user must keep in mind a few considerations. During the Command Phase of a command, the Main Status Register must be read before each byte of the command word is written into the data register to ensure that bits D6 and D7 are logic "0" and "1 ", respectively. During the Result Phase of a command, the Main Status Register must be read before each result byte from the data register is read to ensure that bits D6 and D7 are both logic "1 ". The user should ensure that 12 µs elapses before each access of the Main Status Register < by the CPU. To avoid waiting 12 µs before each access to the Main Status Register in a Command Phase, the user may save time by polling D6 and D7 of the Main Status Register for the appropriate bit settings. When the correct bit settings appear, the FDC37C65C is ready for commands. No access of the Main Status Register is necessary in the execution phase of a command. During the execution phase, each receipt of a data byte from the drive is indicated by an interrupt signal on the IRQ pin when the FDC37C65C is in the non-DMA mode. The generation of a Read or Write signal clears the interrupt and outputs the data onto the data bus. If the processor cannot respond to the interrupts quickly enough (every 13 µs for MFM and 27 µs for FM), then it may poll the Main Status Register and bit D7 functions

as the interrupt signal. If a Write command is in process, then the Write signal performs the reset to the interrupt. The timing parameters mentioned above will double for mini floppy data rates. After an interrupt in the non-DMA Mode, the Main Status Register must be examined to determine the cause, since it could be a data interrupt or a command termination interrupt, either normal or abnormal. In the DMA Mode, no interrupt signals occur during the Execution Phase. Instead. a DMA Request is generated and the DMA controller responds with a DMA Acknowledge and either a Read or a Write, which clears the DMA Request. After the completion of the Execution Phase or the EOT sector has been read or written, an interrupt will occur, signifying the beginning of the Result Phase. The reading of the first byte of data from the Data Register clears the interrupt.

In PC/AT use, since non-DMA host transfers are not normally used, the FDC37C65C will successfully complete commands but will always give abnormal termination error status, since the TC signal is qualified by the DACK signal.

The  $\overline{RD}$  or  $\overline{WR}$  signals should be asserted while DACK is true and the  $\overline{CS}$  signal is gated with  $\overline{RD}$  and  $\overline{WR}$ during programmed I/0 operations.  $\overline{CS}$  has no effect during DMA operations. If the non-DMA Mode is being used, the DACK signal should be pulled up to V<sub>cc</sub>.

During the Result Phase of a command, all bytes from the Data Register must be read in order to successfully complete the command, and the FDC37C65C will not accept a new command until all bytes have been read The bytes in the Command Phase and the Result Phase must be written and read in the exact order as seen in the Commands section of this document. No shortening of the phases is allowed. The last byte sent to the FDC37C65C in a Command Phase causes the Execution Phase to automatically begin and when the last data byte is read out in the Result Phase, the command is automatically ended, making the FDC37C65C ready for a new command.

### INTERNAL REGISTERS

The FDC37C65C contains eight internal registers which facilitate the interfacing between the host microprocessor and the disk drive. The eight registers consist of the Data Rate Selection Register, the Main Status Register, Status Registers 0-3, the Data Register, and the Digital Output Register. Table 1 shows the bit combinations required to access the registers. Combinations other than the ones shown below are illegal.

| DCHGEN | <u>cs</u> | AO | LDCR | LDOR | RD | WR | FUNCTION                           | ADDR |
|--------|-----------|----|------|------|----|----|------------------------------------|------|
| X      | 1         | х  | 1    | 0    | 1  | 0  | Write Digital Output Register      | 3F2H |
| x      | 0         | 0  | 1    | 1    | 0  | 1  | Read Main Status Register          | 3F4H |
| ×      | 0         | 1  | 1    | 1    | 0  | 1  | Read Data Register                 | 3F5H |
| X      | 0         | 1  | 1    | 1    | 1  | 0  | Write Data Register                | 3F5H |
| 0      | 1         | x  | 0    | 1    | 0  | 1  | Read DCHG Register                 | 3F7H |
| ×      | 1         | x  | 0    | 1    | 1  | 0  | Write Data Rate Selection Register | 3F7H |
| X      | 0         | 0  | 1    | 1    | 1  | 0  | illegal*                           |      |
| X      | х         | x  | ×    | x    | 0  | 0  | lliegal                            |      |

#### Table 1 - Register Accesses

Status Registers 0-3 are available only in the result phase of a command and may be read only after the completion of the command.

\*  $\overline{CS} = \overline{WR} = 0$  is allowed when A0 = 0, the RST pin is inactive, and bit 2 of the Digital Output Register = 1 (Software Reset disabled). This places the FDC37C65C into the Power Down Mode.

#### **Data Rate Selection Register**

The Data Rate Selection Register provides support logic that latches the two LSB's of the data bus upon receiving LDCR and WR. These bits are used to select the desired data rate which, in turn, controls the internal clock generation. When the data rate is switched, the clock is de-glitched to allow for continuous operation. If the Data Rate Selection Register is not being used, the data rate is determined by the supplied clock or crystal. The frequency must be 64 times the desired MFM data rate, up to a maximum frequency of 32 MHz. Therefore, the maximum data rate that can be used without the use of the Data Rate Selection Register is 250 kbits/sec or 500k for 32 MHz. Refer to Table 2 for manipulation of the Data Rate Selection Register.

| DB1 | DB0   | DRV | Encoding Scheme  | Data Rate<br>(kbits/s) | RPM<br>(in PC/AT/<br>EISA Mode) |
|-----|-------|-----|------------------|------------------------|---------------------------------|
| 0   | · 0 · | х   | MFM              | 500                    | 1                               |
| 0   | 0     | x   | FM               | 250                    | 1                               |
| 0   | 1     | 0   | MFM              | 250                    | 0                               |
| 0   | 1     | 1   | MFM              | 300                    | 0                               |
| 1   | 0     | х   | MFM, RST Default | 250                    | 1                               |
| 1   | 0     | x   | FM, RST Default  | 125                    | <b>1</b> · ·                    |
| 1   | 1     | x   | FM               | 125                    | 0                               |

Table 2A - Data Rate Selection Register - 16 MHz

Table 2B - Data Rate Selection Register - 32 MHz

| DB1 | DB0 | DRV | Encoding Scheme    | Data Rate<br>(bits/s) | RPM<br>(in PC/AT/<br>EISA Mode) |
|-----|-----|-----|--------------------|-----------------------|---------------------------------|
| 0   | 0   | x   | MFM                | 1 <b>M</b>            | 1                               |
| 0   | 0   | х   | FM                 | 500k                  | 1                               |
| 0   | 1   | 0   | MFM                | 500k                  | 0                               |
| 0   | 1   | 1   | MFM (9.6 MHz XTAL) | 300k                  | 0                               |
| 4   | 0   | X   | MFM, RST Dafault   | 500k                  | 1                               |
| ţ   | 0   | * X | FM, RST Default    | 250k                  | · †                             |
| 1   | 1   | X   | FM                 | 250k                  | 0                               |

The FDC supports 150 kbps FM data transfer as shown in table 2C. This data rate is selected by driving CLK1 or XTAL1 with 9.6 MHz.

| Table 2C - | Data Rate | Selection | Register - | 150/300 | kbps Option |
|------------|-----------|-----------|------------|---------|-------------|
|            |           |           |            |         |             |

| DB1 | DB0 | DRV | Encoding Scheme | Data Rate<br>(kbits/s) | RPM<br>(in PC/AT/<br>EISA Mode) |
|-----|-----|-----|-----------------|------------------------|---------------------------------|
| 0   | 0   | x   | MFM             | 300                    | 1                               |
| 0   | 0   | x   | FM              | 150                    | 1                               |

The Write Precompensation may be disabled in the PC/AT/EISA mode by writing a logic high to bit 2 of the Control Register. Please note that a hardware reset

will reset bit 2 to a logic low, re-enabling Write Precompensation.

# Main Status Register

The Main Status Register is an 8-bit register that contains the status information of the FDC37C65C, and may be accessed at any time. Only the Main Status Register may be accessed to facilitate the transfer of data between the microprocessor and the FDC37C65C. That is, Status Registers 0-3 may be read only after the completion of a command and provide no assistance in the transfer of data between the microprocessor and the FDC37C65C. Each time the Main Status Register is accessed, the microprocessor should wait 12  $\mu$ s if 500 kbits/sec MFM is selected as the data rate, 6  $\mu s$  if 1 Mbit/sec is selected, and 24  $\mu s$  if 250 kbits/sec MFM is

selected. Refer to Table 3 for the contents of the Maim Status Register.

| BIT NO. | BIT NAME          | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                 |
|---------|-------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | FDD 0 Busy        | D0B    | A high level on this bit indicates that drive 0 is in the Seek Mode and that the FDC37C65C will not accept READ or WRITE commands.*                                                                                                                         |
| . 1     | FDD 1 Busy        | D1B    | A high level on this bit indicates that drive 1 is in the Seek Mode and that the FDC37C65C will not accept READ or WRITE commands.                                                                                                                          |
| 2       | FDD 2 Busy        | D2B    | A high level on this bit indicates that drive 2 is in the Seek Mode and that the FDC37C65C will not accept READ or WRITE commands.                                                                                                                          |
| 3       | FDD 3 Busy        | D3B    | A high level on this bit indicates that drive 3 is in the Seek Mode and<br>that the FDC37C65C will not accept READ or WRITE commands.                                                                                                                       |
| 4       | FDC Busy          | СВ     | A high level on this bit indicates that a READ or WRITE command is improgress and that the FDC37C65C will not accept any other command.                                                                                                                     |
| 5       | Execution<br>Mode | EXM    | A high level on this bit indicates that the FDC37C65C is in the Execution<br>Phase in Non-DMA Mode. When this bit goes low, the Execution Phase<br>has ended and the Results Phase has begun. This bit operates only im<br>the Non-DMA Mode.                |
| 6       | Data              | DIO    | A high level on this bit indicates that the direction of data transfer is<br>from the Data Register to the microprocessor. A low level on this bit<br>indicates that the direction of data transfer is from the microprocessor to<br>the Data Register.     |
| 7       | Request           | RQM    | A high level on this bit indicates that the Data Register is ready to send<br>or receive data to or from the microprocessor. Both the DIO and the<br>RQM bits should be used to perform the "ready" and "direction" hand-<br>shaking functions to the host. |

Table 3 - Main Status Register

\* Note: A write to the Main Status Register ( $\overline{CS} = \overline{WR} = 0$ ) when bit DB0 = 1, bit DB2 of the Digital Output Register = 1 and A0 = RST = 0, will place the FDC37C65 in the Power Down Mode.

#### Status Registers 0-3

Status Registers 0-3 are each 8 bit registers that contain status information on the FDC37C65C and are available only in the Result Phase and may be read only after

completing a command. The command that has been executed determines which of the Status Registers with be read. Refer to Tables 4-7 for the contents of Status Registers 0-3.

| BIT NO. | BIT NAME           | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|---------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0       | Unit Select 0      | US0    | This flag is used to indicate a Drive Unit Number at interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 1       | Unit Select 1      | US1    | This flag is used to indicate a Drive Unit Number at interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 2       | Head Select        | HS     | This flag is used to indicate the state of the head at interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 3       | Not Ready          | NR     | This bit will always be a logic "0", since Drive Ready is always presumed to be true.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 4       | Equipment<br>Check | EC .   | A high level on this bit indicates that the Track 0 signal has failed to occur after 77 step pulses (Recalibrate Command).                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 5       | Seek End           | SE     | A high level on this bit indicates that the FDC37C65C has completed the seek command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 6,7     | Interrupt<br>Code  | IC     | <ul> <li>seek command.</li> <li>The four combinations of these bits indicate four different situations:</li> <li>7 6<br/>0 0</li> <li>Normal Termination of command was completed and properly executed.</li> <li>1 Abnormal Termination (AT) of command. Execution of command was started but not successfully completed.</li> <li>1 0 Invalid Command (IC) issue. Command which was issued was never started.</li> <li>1 1 Abnormal Termination (AT) of command. During execution of command, the ready signal from drive changed state.</li> </ul> |  |

Table 4 - Status Register 0

|         |                           |        | Table 5 - Status Register 1                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|---------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIT NO. | BIT NAME                  | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0       | Missing Ad-<br>dress Mark | MA     | A high level on his bit indicates that the FDC37C65C cannot detect the<br>Data Address Mark or the Deleted Data Address Mark. In this case, the<br>MD bit of Status Register 2 is also set to a logic "1".                                                                                                                                                                                                                        |
| 1       | Not Writable              | NW     | A high level on this bit indicates that, during execution of the WRITE<br>DATA, WRITE DELETED DATA, or FORMAT A TRACK Command, the<br>FDC37C65C has detected a WP signal from the drive, indicating that the<br>diskette is write protected.                                                                                                                                                                                      |
| 2       | No Data                   | ND     | A high level on this bit indicates one of three conditions. Either 1) during the execution of the READ DATA, or FORMAT A TRACK Command, the FDC37C65C cannot find the sector specified in the Internal Data Register, or 2) during the execution of the READ ID Command, the FDC37C65C cannot read the ID field without an error, or 3) during the execution of the READ A CYLINDER Command, the starting sector cannot be found. |
| 3       | (not used)                | 1      | This bit is not used and is always at a logic "0".                                                                                                                                                                                                                                                                                                                                                                                |
| 4       | Overrun)                  | OR     | A high level on this bit indicates that the FDC37C65C has not been serviced by the microprocessor during data transfers within a certain time interval.                                                                                                                                                                                                                                                                           |
| 5       | Data Error                | DE     | A high level on this bit indicates that the FDC37C65C has detected a Cyclic Redundancy Check Error in either the ID field or the data field.                                                                                                                                                                                                                                                                                      |
| 6       | (not used)                |        | This bit is not used and is always at a logic "0".                                                                                                                                                                                                                                                                                                                                                                                |
| 7       | End of Cylin-<br>der      | EN     | A high level on this bit indicates that the FDC37C65C has tried to access a sector beyond the final sector of a cylinder.                                                                                                                                                                                                                                                                                                         |

| BIT NO. | BIT NAME                                   | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                               |
|---------|--------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Missing Ad-<br>dress Mark<br>in Data Field | MD     | A high level on this bit indicates that the FDC37C65C, upon reading data from the drive, cannot find a Data Address Mark, or Deleted Data Address Mark.                                                                                                   |
| 1       | Bad Cylinder                               | BC     | A high level on this bit indicates that the contents of the cylinder on the medium is different from that stored in the Internal Data Register and the contents of the cylinder is FFH. This bit is related to the ND (No Data) bit of Status Register 1. |
| 2       | Scan Not<br>Satisfied                      | SN     | A high level on this bit indicates that, during the execution of a SCAN<br>Command, the FDC37C65C cannot find a sector on the cylinder which<br>meets the specified condition.                                                                            |
| 3       | Scan Equal<br>Hit                          | SH     | A high level on this bit indicates that, during the execution of a SCAN command, the condition of "equal" has been satisfied.                                                                                                                             |
| 4       | Wrong<br>Cylinder                          | wc     | A high level on this bit indicates that the contents of the cylinder on the medium is different from that stored in the Internal Data Register. This bit is related to the ND (No Data) bit of Status Register 1.                                         |
| 5       | Data Error                                 | DE     | A high level on this bit indicates that the FDC37C65C has detected a Cyclic Redundancy Check Error in the data field.                                                                                                                                     |
| 6       | Control Mark                               | СМ     | A high level on this bit indicates that, during the execution of the READ DATA or SCAN Command, the FDC37C65C has encountered a sector which contains a Deleted Data Address Mark.                                                                        |
| 7       | (not used)                                 |        | This bit is not used and is always at a logic "0".                                                                                                                                                                                                        |

Table 6 - Status Register 2

`ئان

# Table 7 - Status Register 3

| BIT NO. | BIT NAME           | SYMBOL | DESCRIPTION                                                                                                       |
|---------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------|
| 0       | Unit Select 0      | US0    | This bit is used to indicate the status of the Unit Select 0 signal to the drive.                                 |
| 1       | Unit Select 1      | US1    | This bit is used to indicate the status of the Unit Select 1 signal to the drive.                                 |
| 2       | Head<br>Address    | HD     | This bit is used to indicate the status of the Side Select signal to the drive.                                   |
| 3       | Two Side           | TS     | This bit is used to indicate the status of the Two-Side signal to the drive.                                      |
| 4       | Track 0            | то     | This bit is used to indicate the status of the Track 0 signal to the drive.                                       |
| 5       | Ready              | RY     | This bit is used to indicate the status of the Ready signal from the drive.<br>This bit is always at a logic "1". |
| 6       | Write<br>Protected | WP     | This bit is used to indicate the status of the WRITE PROTECTED signal from the drive.                             |
| 7       | Fault              | FT     | This bit is used to indicate the status of the Fault signal from the drive.                                       |

.

#### **Data Register**

The Data register is an 8-bit register which stores data, commands, parameters, and drive status information. Data is read from or written to the Data Register in order to program or obtain results of a command that has been issued.

# **Digital Output Register**

The Digital Output Register provides for selection of the disk drive and control of the disk drive spindle motors. These selections are typically implemented with the standard latched port found in floppy disk subsystems. The Digital Output Register provides support logic that latches the data bus upon receiving the LDOR and  $\overline{WR}$  signals. Refer to Table 8 for the contents of the Digital Output Register.

| BIT NO. | BIT NAME               | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                               |
|---------|------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Drive Select           | DSEL   | A low level on this bit, when MOEN 1 is a logic "1", activates a DS1<br>(Drive Select 1 output pin). A high level on this bit, when MOEN2<br>is a logic "1" activates DS2 (Drive Select 2 output pin). This bit<br>only activates DS1 or DS2 when the FDC37C65C is in PC/AT/EISA<br>Mode. |
| 1       | Drive Select<br>Enable | DSELEN | A low level on this bit enables $\overline{\text{DS1}}$ and $\overline{\text{DS2}}$ to become active.                                                                                                                                                                                     |
| 2       | Soft Reset             | SRST   | A low level on this bit provides for soft reset of the FDC37C65C.                                                                                                                                                                                                                         |
| 3       | DMA Enable             | DMAEN  | This bit, active in Special Mode and PC/AT/EISA Mode, qualifies the DMA and IRQ outputs and the DACK input.                                                                                                                                                                               |
| 4       | Motor 1 On<br>Enable   | MOEN1  | The MO1 signal is the inverted output of this signal, which is active only in the PC/AT/EISA Mode.                                                                                                                                                                                        |
| 5       | Motor 2 On<br>Enable   | MOEN2  | The MO2 signal is the inverted output of this signal, which is active only in the PC/AT/EISA Mode.                                                                                                                                                                                        |
| 6       | (not used)             |        | This bit is not used.                                                                                                                                                                                                                                                                     |
| 7.      | Mode Select            | MSEL   | During a software reset, a low level on this bit selects PC/AT/EISA<br>Mode while a high level selects Special Mode.                                                                                                                                                                      |

#### Table 8 - Digital Output Register

### MODES OF OPERATION

The FDC37C65C may operate under three different modes. They are the Base, Special, and PC/AT/EISA Modes. Table 9 illustrates the features of each mode of operation. The Data Rate Selection Register is used in any of the three modes without a change in its functionality. Figure 3 illustrates the block diagram of all the possible entries within the three operation modes.

#### **Base Mode**

After a hardware reset, Base Mode may be entered by a microprocessor access to the FDC37C65C. The recommended access is a read of the Main Status Register. When a hardware reset occurs, the FDC37C65C is held in a soft reset, with the DMA and IRQ outputs tri-stated. When the Base Mode is entered, the DMA and IRQ signals resume their normal driving conditions. The Drive Select (DS1 - DS4) outputs, which provide for a 1 out of 4 decoding of the Unit Select bits of the command structure, may be used in the Base Mode. Please note that the Digital Output Register may not be used during Base Mode. There is, consequently, no qualifying by DMAEN and no Soft Reset. The Reduced Write Current (RWC) output, which indicates the necessity of write precompensation, may be used in the Base Mode.

### PC/AT/EISA Mode

When the FDC37C65C is being used in a PC/AT/EISA or compatible system environment, the user will have to be in the PC/AT Mode.

In the PC/AT/EISA Mode, the Drive Select (DS1-DS4) outputs are replaced with the DSEL, MOEN1, and MOEN2 signals from the Digital Output Register. The DMAEN signal from the Digital Output Register may be used as a qualifier for the DMA and IRQ outputs, and the SRST signal may be used to do a software driven reset. The Reduced Write Current (RWC) output now performs the function of Revolutions Per Minute (RPM). Users with two speed drives may reduce spindle speed from a nominal 360 RPM to 300 RPM when this signal is active low. Similarly, this signal may be used to reduce write current when a slower data rate is selected for a given drive. In order to enter the PC/AT/EISA Mode from the Base Mode, the user will perform a write to the Digital Output Register (an LDOR and a WR). The data written may be anything except an 80H, because a logic "1" in Bit 7 of the Digital Output Register is used to select Special Mode.

In order to enter the PC/AT Mode from the Special Mode, the user will write 00H to the Digital Output Register. That is,

| Bit 0: | X (Don't care)                       |
|--------|--------------------------------------|
| Bit 1: | X (Don't care)                       |
| Bit 2: | 0 (A low level on SRST causes a soft |
|        | reset)                               |
| Bit 3: | X (Don't care)                       |
| Bit 4: | 0 (Disable Motor On Enable 1)        |
| Bit 5: | 0 (Disable Motor On Enable 2)        |
| Bit 6: | X (Don't care)                       |

Bit 7: 0 (A low level on MSEL selects PC/AT/EISA Mode)

To complete the entry into the PC/AT/EISA Mode from the Special Mode, the user will then read the Data Rate Selection Register address (an LDCR and an RD).

### Special Mode

In the Special Mode, the Drive Select (DS1 - DS4)

outputs, which provide for a 1 out of 4 decoding of the Unit Select bits of the command structure, may be used. The DMAEN signal from the Digital Output Register may be used as a qualifier for the DMA and IRQ outputs and the DACK input. The SRST bit may be used to do a software driven reset. The Reduced Write Current (RWC) output, which indicates the necessity of write precompensation, may also be used in the Special Mode.

The Special Mode may only be entered from the Base Mode. In order to enter the Special Mode, the user will write 80H into the Digital Output Register (an LDOR and a WR) because a logic "1" in Bit 7 of the Digital Output Register selects Special Mode. That is,

- Bit 0: X (Don't care)
- Bit 1: X (Don't care)
- Bit 2: 0 (A low level on SRST causes a soft reset)
- Bit 3: X (Don't care)
- Bit 4: 0 (Disable Motor On Enable 1)
- Bit 5: 0 (Disable Motor On Enable 2)
- Bit 6: X (Don't care)
- Bit 7: 0 (A high level on MSEL selects Special Mode)

To complete the entry into the Special Mode, the user will then read the Data Rate Selection Register address (an LDCR and RD).

|                                   |           | <u>or operation</u> |                 |
|-----------------------------------|-----------|---------------------|-----------------|
| FEATURES                          | BASE MODE | PC/AT/EISA<br>MODE  | SPECIAL<br>MODE |
| Functions of DSEL1-4              | DSEL1-4   | DSEL1-2,<br>MOEN1-2 | DSEL1-4         |
| Software Reset<br>supported       | No        | Yes                 | Yes             |
| DMA pin supported by<br>DMAEN bit | No        | Yes                 | Yes             |
| IRQ pin qualified by DMAEN<br>bit | No        | Yes                 | Yes             |
| Functions of RPM/RWC              | RWC       | RPM                 | RWC             |

# Table 9 - Modes of Operation

#### **Power Down Mode**

The FDC37C65C may be placed into the Power down Mode by writing to the Main Status Register ( $\overline{WR} = \overline{CS}$ = 0) when hardware and software resets are inactive, A0 = 0, and bit DB0 of the Main Status Register = 0. The FDC37C65C will return to normal operation when RST is made active, resetting the FDC37C65C. In the Power Down Mode, the controller core is halted, stopping the oscillators, shutting down all Schmitt trigger reference voltages, three-stating all 48 mA drivers,, and shutting down the low  $V_{cc}$  detect circuit. This will reduce  $I_{cc}$  to less than 100  $\mu$ A.



FIGURE 3 - POSSIBLE MODE ENTRIES

### POLLING ROUTINE

Following either a hard or soft reset, the FDC37C65C automatically begins polling the drives for a change in the Ready lines. The polling is done continuously between commands and between step pulses in the SEEK command. The purpose of the polling routine is to detect when the drives return to a Ready status after being reset or after a command is completed. The polling sequence is Drive 1, 2, 3, 4, and each drive is polled every 1.024 ms, except during the READ/WRITE commands. For minifloppies, the polling rate is 2.048 ms. In Special or PC/AT Modes, if DMAEN is not valid by 1 ms after reset becomes inactive, then IRQ may already be set and pending when enabled onto the bus When the FDC37C65C is in the PC/AT Mode, the user will not see the polling at the Drive Select signals Refer to Figure 4 for the general timing of the Drive Select Polling.



FIGURE 4 - DRIVE SELECT POLLING TIMING

### **RESET LOGIC**

A hardware reset is performed by applying a logic "1" to the RST pin of the FDC37C65C. When a hardware reset occurs, the device will remain in the reset condition for the duration of the pulse. Once the pulse is removed, the FDC37C65C will default to Base Mode with a data rate of 250 kbits/s MFM (or 125 kbits/s FM, code dependent) when a 16 MHz input clock is used. The FDC37C65C will default to 500 kbits/s MFM when a 32 MHz input clock is used. A software reset is performed by applying a logic "0" to bit 2 of the Digital Output Register. When a software reset occurs, the FDC37C65C is reset the same as it is during a hardware reset, with the exception that the mode and the data rate are not affected. During a reset, the high current driver outputs to the drives are disabled. Neither a hard reset nor a soft reset will affect the values of the internal timers, that is, Head Unload Time, Head Load Time, and Step Rate Time (described in the COMMANDS section of this document). If the on chip crystal oscillators are used instead of the TTL clock inputs, a longer duration of the pulse on the RST pin during a hardware reset is required to stabilize the internal timing.

The FDC37C65C contains internal circuitry to automatically reset the device during initial power-up. The device also contains power fail protection circuitry in the disk interface which allows it to reset itself in the event of power failure.

### DATA SEPARATOR AND WRITE PRECOMPENSA-TION

The Data Separator portion of the FDC37C65C is based on the Standard Microsystems FDC92C39. It performs the complete data separation function of separating the data and clock pulses from the FM and MFM encoded data. In addition, it contains the Automatic Write Precompensation Logic necessary when writing to the inner and outer tracks of the drive. The encoded Write Data signal is synchronized to the input clock and is clocked through an internal shift register, but is delayed upon being output. When a logic "0" is applied to the PCVAL pin and a track inside of track 43 is accessed, data will be precompensated by  $\pm 187$  ns. For MFM encoding, when a logic "1" is applied to the PCVAL Pin, data will be precompensated by  $\pm 125$  ns. regardless of track number and data rate. For frequencies other than 16 MHz on the CLK1 pin, the precompensation value will be three clock cycles for PCVAL="0", or two clock cycles for PCVAL="1". When CLK2 is used for nonstandard data rates, the precompensation value is always two clock cycles, thus disabling the function of PCVAL. Note that FM encoding is not precompensated. Precompensation may be disabled by writing a logic high to bit D2 of the Data Rate Selection Register.

### **CLOCK GENERATION**

The FDC37C65C generates the three required internal clocks from the clock input. The three internal clocks include the Master Clock (MCLK), Sampling Clock (SCLK), and Write Clock (WCLK). The MCLK is used by the microsequencer to clock the latches in a two-phase scheme. One microinstruction cycle consists of four MCLK cycles. The frequency of MCLK is 8 times the selected MFM data rate or 16 times the FM data rate. SCLK is used in the internal data separator for data recovery. The frequency of SCLK is 32 times the selected data rate. WCLK is used in MFM or FM encoding when writing data to the disk. WCLK has a frequency of twice the selected data rate. Refer to Table 10 for the frequencies of the internal clocks and their relationship to the selected data rates and codes.

### **Table 10 - Internal Clock Frequencies**

| Data<br>Rate<br>(bits/s) | Code | MCLK<br>(MHz) | SCLK<br>(MHz) | WCLK<br>(kHz) |
|--------------------------|------|---------------|---------------|---------------|
| 1 Mbps                   | MFM  | 8.0           | 32.0          | 2000          |
| 500k                     | MFM  | 4.0           | 16.0          | 1000          |
| 250k                     | FM   | 4.0           | 8.0           | 500           |
| 250k                     | MFM  | 2.0           | 8.0           | 500           |
| 125k                     | FM   | 2.0           | 4.0           | 250           |
| 300k                     | MFM  | 2.4           | 9.6           | 600           |

### COMMAND SEQUENCE

The FDC37C65C is capable of performing 18 different commands. Each command is initiated by a multi-byte transfer from the processor, and the result after execution of the command may also be a multi-byte transfer back to the processor. Because of this multi-byte interchange of information between the FDC37C65C and the processor, it is convenient to consider each command as consisting of three phases :

Command Phase: The FDC37C65C receives all information required to perform a particular operation from the processor. Execution Phase : The FDC37C65C performs the operation it was instructed to do.

Result Phase: After completion of the operation, status and other housekeeping information is made available to the processor.

| SYMBOL         | NAME                      | DESCRIPTION                                                                                                                                                                                                     |
|----------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| À <sub>0</sub> | Address Line 0            | $A_{0}$ controis selection of the Main Status Register ( $A_{0} = 0$ ) or the Data Register ( $A_{0} = 1$ ).                                                                                                    |
| С              | Cylinder<br>Number        | C stands for the current/selected Cylinder (track) number 0 through 76 of the medium.                                                                                                                           |
| D              | Data                      | D stands for the data pattern which is going to be written into a sector.                                                                                                                                       |
| D, - D,        | Data Bus                  | 8-bit Data bus; D, is the most significant bit, and $D_0$ is the least significant bit.                                                                                                                         |
| DTL            | Data<br>Length            | When N is defined as 00, DTL stands for the data length which users are going to read out or write into the sector.                                                                                             |
| EOT            | End of<br>Track           | EOT is the final Sector number on a Cylinder. During Read or Write operation the FDC37C65C will stop data transfer after a sector number equal to EOT.                                                          |
| GPL            | Gap<br>Length             | GPL stands for the length of Gap 3. During Read/Write commands, this value determines the number of bytes that VCO's will stay low after two CRC bytes. During Format command GPL determines the size of Gap 3. |
| Н              | Head<br>Address           | H stands for head number 0 or 1, as specified in the ID field.                                                                                                                                                  |
| HD             | Head                      | HD stands for a selected head number 0 or 1 and controls the polarity of pin 27. (H = HD in all command words).                                                                                                 |
| HLT            | Head Load<br>Time         | HLT stands for the head load time in the FDC37C65C (2 to 254 ms in 2 ms incre-<br>ments).                                                                                                                       |
| нит            | Head Un-<br>load Time     | HUT stands for the head unload time after a read or write operation has occurred (16 to 240 ms in 16 ms increments).                                                                                            |
| MF             | FM or<br>MFM Mode         | If MF is low, FM mode is selected, and if it is high, MFM mode is selected.                                                                                                                                     |
| мт             | Multi-Track               | If MT is high, a multi-track operation is to be performed. If MT = 1 after finishing Read/Write operation on side 0, the FDC37C65C will automatically start searching for sector 1 on side 1.                   |
| N              | Number                    | N stands for the number of data bytes written in a sector.                                                                                                                                                      |
| NCN            | New<br>Cylinder<br>Number | NCN stands for a new Cylinder number, which is going to be reached as a result of<br>the Seek operation. Desired position of head.                                                                              |
| ND             | Non-DMA<br>Mode           | ND stands for operation in the Non-DMA Mode.                                                                                                                                                                    |

## Table 11 - Description of Command Symbols

|                          | NAME                                         | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCN                      | Present<br>Cylinder<br>Number                | PCN stands for the Cylinder number at the completion of SENSE INTERRUPT<br>STATUS Command. Position of Head at present time.                                                                                                                                                                                                                                                                                        |
| R                        | Record                                       | R is the Sector number which will be read or written.                                                                                                                                                                                                                                                                                                                                                               |
| R/W                      | Read/Write                                   | R/W is the Read (R) or Write (W) signal.                                                                                                                                                                                                                                                                                                                                                                            |
| sc                       | Sector                                       | SC indicates the number of Sectors per Cylinder.                                                                                                                                                                                                                                                                                                                                                                    |
| SK                       | Skip                                         | SK stands for Skip Deleted Data Address Mark.                                                                                                                                                                                                                                                                                                                                                                       |
| SRT                      | Step Rate<br>Time                            | SRT is the Stepping Rate for the FDC37C65C. The stepping rate applies to all drives. The stepping rate is programmable from 1 to 16 ms in 1 ms increments. $F_{\mu} = 1$ ms, $E_{\mu} = 2$ ms, etc.                                                                                                                                                                                                                 |
| STO<br>ST1<br>ST2<br>ST3 | Status 0<br>Status 1<br>Status 2<br>Status 3 | ST0-ST3 stand for one of four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the main status register (selected by $A_0 = 0$ ). ST0-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP                      |                                              | During a Scan operation, if STP = 1, the data in contiguous sectors is compared byte<br>by byte with data sent from the processor (or DMA); if STP = 2, then alternate<br>sectors are read and compared.                                                                                                                                                                                                            |
| US0, US1                 | Unit Select                                  | US stands for a selected drive (0 or 1).                                                                                                                                                                                                                                                                                                                                                                            |

### Table 11 - Description of Command Symbols

### INSTRUCTION SET

Table 12 lists the required parameters and the results associated with each command that the FDC37C65C is capable of performing. Refer to Table 11 for explanations of the various symbols used.

# TABLE 12 - INSTRUCTION SET ' 2 '

| -           |     |    |    | `, | R   | EAD D      | ATA |      |     |                                                      |
|-------------|-----|----|----|----|-----|------------|-----|------|-----|------------------------------------------------------|
| PHASE       | R/W |    |    |    | DAT | BUS        |     |      |     | REMARKS                                              |
| · · · · · · |     | D7 | D6 | D5 | D4  | D3         | D2  | D1   | D0  |                                                      |
| COMMAND     | W   | MT | MF | SK | 0   | 0          | 1   | 1    | 0   | Command Codes                                        |
|             | w   | Х  | Х  | X  | X   | Х          | HD  | US1  | US0 |                                                      |
|             | w   | -  |    |    | C   | :          |     |      |     | Sector ID information prior to                       |
|             | w   | _  |    |    | ŀ   |            |     |      |     | Command execution. The 4                             |
|             | w   |    |    |    | F   | <b>} }</b> |     |      |     | bytes are compared against<br>header on Floppy Disk. |
|             | w   |    |    |    | N   | J          |     |      |     |                                                      |
|             | w   | _  |    |    | EC  | DT TC      |     |      |     |                                                      |
|             | w   |    |    |    | Gl  | า          |     |      |     |                                                      |
|             | w   |    |    |    | D'  | ۲L —       |     |      |     |                                                      |
| Execution   |     | -  |    |    |     |            |     |      |     | Data transfer between the FDD and main system.       |
| Result      | R   |    |    |    | s'  | ro ——      |     |      |     | Status information after Com-                        |
|             | R   | -  |    |    | s'  | r1         |     |      |     | mand execution.                                      |
|             | R   |    |    |    | s'  | r2 ——      |     |      |     |                                                      |
|             | R   |    |    |    | (   | C          |     |      |     | Sector ID information after Com-                     |
|             | R   |    |    |    | }   | 4          |     | ···· |     | mand execution.                                      |
|             | R   |    |    |    | î   | २          |     |      |     |                                                      |
| 1           | R   |    |    |    | ;   | 1          |     |      |     |                                                      |

<sup>1</sup> Symbols used in this table are described in the beginning of this section

 $^{3}$  X = Don't care, usually made to equal binary 0.

 $<sup>^{2}</sup>$  A<sub>0</sub> should equal binary 1 for all operations.

|           |     |    |    | F  | READ        | DELET   | ED DA     | TA       |             |                                                      |
|-----------|-----|----|----|----|-------------|---------|-----------|----------|-------------|------------------------------------------------------|
| PHASE     | R/W |    |    |    | DATA        | REMARKS |           |          |             |                                                      |
|           |     | D7 | D6 | D5 | , <b>D4</b> | D3      | D2        | D1       | DO          |                                                      |
| COMMAND   | w   | MT | MF | SK | 0           | 1       | 1         | 0        | 0           | Command Codes                                        |
|           | w   | Х  | X  | Х  | X           | Х       | HD        | US1      | US0         |                                                      |
|           | w   | -  |    |    | C           | ;       | · · · · · |          |             | Sector ID information prior to                       |
|           | w   | _  |    |    | H           |         |           |          |             | Command execution. The 4                             |
|           | w   | _  |    |    | R           |         |           |          |             | bytes are compared against<br>header on Floppy Disk. |
|           | w   |    |    |    | — N         |         |           |          |             |                                                      |
|           | w   |    |    |    | EC          | )T      |           |          |             |                                                      |
|           | w   | _  | ·  |    | GF          | °L      |           |          |             |                                                      |
|           | w   | -  |    |    | DT          | ʻL ——   |           |          |             |                                                      |
| Execution |     |    |    |    |             |         |           |          |             | Data transfer between the FDD and main system.       |
| Result    | R   | -  |    |    | st          | 0       |           |          |             | Status information after Com-                        |
|           | R   | _  |    |    | — st        | 1       | ·····-    |          | <del></del> | mand execution.                                      |
|           | R   |    |    |    | — st        | 2       |           | <u> </u> |             |                                                      |
|           | R   | _  |    |    | — c         | ;       |           |          |             | Sector ID information after Com-                     |
|           | R   |    |    |    | ⊦           |         |           |          |             | mand execution.                                      |
|           | R   |    |    |    | F           | ł ——    |           |          |             |                                                      |
|           | R   | -  |    |    | N           |         |           |          |             |                                                      |

|           |     |    |      |                       | W     | RITE C | ATA      |             |          |                                                      |
|-----------|-----|----|------|-----------------------|-------|--------|----------|-------------|----------|------------------------------------------------------|
| PHASE     | R/W |    |      |                       | DAT   | BUS    |          |             |          | REMARKS                                              |
|           |     | D7 | · D6 | D5 -                  | D4    | D3     | D2       | D1          | DO       |                                                      |
| COMMAND   | W   | MT | MF   | 0                     | 0     | 0      | 1        | 0           | 1        | Command Codes                                        |
|           | w   | X  | x    | X                     | х     | X      | HD       | US1         | US0      |                                                      |
|           | w   |    |      |                       | C     | ;      |          |             | —        | Sector ID information prior to                       |
|           | w   |    |      |                       | H     |        |          | <del></del> | <u> </u> | Command execution. The 4                             |
|           | w   | -  |      |                       | F     |        | <u> </u> |             | _        | bytes are compared against<br>header on Floppy Disk. |
|           | W   |    |      |                       | N     |        |          |             | _        |                                                      |
|           | w   | _  |      |                       | —– EC | от то  |          |             | <b>-</b> |                                                      |
|           | W   |    |      |                       | GF    | °L     |          |             |          |                                                      |
|           | w   |    |      | • • • • • • • • • • • | D1    | Ղ      |          |             |          |                                                      |
| Execution |     |    |      |                       |       |        |          |             |          | Data transfer between the main system and FDD.       |
| Result    | R   | -  |      |                       | — st  | 0      |          |             |          | Status information after Com-                        |
|           | R   | _  |      |                       | st    | 1 ——   |          | ·····       |          | mand execution.                                      |
|           | R   |    |      |                       | — st  | 2      |          | <u>-</u>    | -        |                                                      |
|           | R   |    |      |                       | C     | ;      |          |             | _        | Sector ID information after                          |
|           | R   |    |      |                       | H     |        |          |             | —        | Command execution.                                   |
|           | R   |    |      |                       | F     |        |          |             |          |                                                      |
|           | R   |    |      |                       | N     |        |          |             |          |                                                      |

|           |     |     |                   | N  | RITE | DELET | ED DA | TA  | <u> </u> |                                                      |
|-----------|-----|-----|-------------------|----|------|-------|-------|-----|----------|------------------------------------------------------|
| PHASE     | R/W |     |                   |    | DATA | BUS   |       |     |          | REMARKS                                              |
|           |     | D7  | D6                | D5 | D4   | D3    | D2    | D1  | D0       |                                                      |
| COMMAND   | W   | MT  | MF                | 0  | 0    | 1     | 0     | 0   | 1        | Command Codes                                        |
|           | w   | х   | Х                 | X  | X    | Х     | HD    | US1 | US0      |                                                      |
|           | w   | -   |                   |    | — c  |       |       |     |          | Sector ID information prior to                       |
|           | w   |     |                   |    | Н    |       |       |     |          | Command execution. The 4                             |
|           | w   | _   |                   |    | R    |       |       |     | <u> </u> | bytes are compared against<br>header on Floppy Disk. |
|           | w   | _   | -                 |    | N    |       |       |     |          |                                                      |
|           | w   | . – |                   |    |      |       |       |     |          |                                                      |
| -         | w   |     |                   |    | GP   | ۲L    |       |     | _        |                                                      |
|           | w   | -   |                   |    | DT   | ïL    |       |     |          |                                                      |
| Execution |     |     |                   |    |      |       |       |     |          | Data transfer between the main system and FDD.       |
| Result    | R   | -   |                   |    | ST   | 0     |       |     |          | Status information after Com-                        |
|           | R   | _   |                   |    | — st | 1     |       |     |          | mand execution.                                      |
|           | R   |     |                   |    | — st | 2     |       |     |          |                                                      |
|           | R   |     | · · · · · · · · · |    | — c  | ;     |       |     |          | Sector ID information after                          |
|           | R   | -   |                   |    | H    |       |       |     |          | Command execution.                                   |
|           | R   |     |                   |    | R    |       |       |     |          |                                                      |
|           | R   |     |                   |    | —— N |       |       |     |          |                                                      |

|           |     |    |    |          | RE      | DAT | RACK |     |     |                                                                                                           |
|-----------|-----|----|----|----------|---------|-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------|
| PHASE     | R/W |    |    |          | REMARKS |     |      |     |     |                                                                                                           |
|           |     | D7 | D6 | D5       | D4      | D3  | D2   | D1  | D0  |                                                                                                           |
| COMMAND   | w   | 0, | MF | SK       | 0       | 0   | 0    | 1   | 0   | Command Codes                                                                                             |
|           | W.  | х  | X  | X        | х       | х   | HD   | US1 | US0 |                                                                                                           |
| -         | Ŵ   |    |    |          |         |     |      |     |     | Sector ID information prior to                                                                            |
|           | w   | _  |    |          |         |     |      |     |     | Command execution.                                                                                        |
|           | w   | -  |    | ·····    |         |     |      |     |     |                                                                                                           |
|           | W   | -  |    | <u> </u> |         |     |      |     |     |                                                                                                           |
|           | w   | -  |    |          |         |     |      |     |     | Į                                                                                                         |
|           | W   |    |    |          |         |     |      |     |     |                                                                                                           |
|           | w   |    |    |          | D1      | Ľ   |      |     |     |                                                                                                           |
| Execution |     |    |    |          |         |     |      |     |     | Data transfer between the FDD<br>and main system. FDC reads<br>all data fields from index hole<br>to EOT. |
| Result    | R   | -  |    |          | s1      | 0   |      |     |     | Status information after Com-                                                                             |
|           | R   |    |    |          |         |     |      |     |     | mand execution.                                                                                           |
|           | R   | -  |    | <u> </u> |         |     |      |     |     |                                                                                                           |
|           | R   | -  |    |          | -       |     |      |     |     | Sector ID information after                                                                               |
|           | R   |    |    |          |         |     |      |     |     | Command execution.                                                                                        |
|           | R   | -  |    |          |         |     |      |     |     |                                                                                                           |
|           | R   |    |    |          | א א     | 1 1 |      |     |     |                                                                                                           |

|           | READ ID |    |    |    |     |          |    |                               |     |                                                                                   |  |  |  |
|-----------|---------|----|----|----|-----|----------|----|-------------------------------|-----|-----------------------------------------------------------------------------------|--|--|--|
| PHASE     | R/W     |    |    |    | DAT | REMARKS  |    |                               |     |                                                                                   |  |  |  |
|           |         | D7 | D6 | D5 | D4  | D3       | D2 | D1                            | DO  |                                                                                   |  |  |  |
| COMMAND   | W       | 0  | MF | 0  | 0   | 1        | 0  | 1                             | 0   | Command Codes                                                                     |  |  |  |
|           | w       | х  | х  | x  | X   | х        | HD | US1                           | US0 |                                                                                   |  |  |  |
| Execution |         |    |    |    |     |          |    |                               |     | The first correct ID information<br>on the Cylinder is stored in<br>Data Register |  |  |  |
| Result    | R       |    |    |    | ST  | 0        |    |                               |     | Status information after Com-                                                     |  |  |  |
|           | R       | -  |    |    | st  | 1        |    |                               |     | mand execution.                                                                   |  |  |  |
|           | R       | -  |    |    | ST  | 2        |    | · · · · · · · · · · · · · · · |     |                                                                                   |  |  |  |
|           | R       |    |    |    | C   | ;        |    |                               |     | Seector ID information read                                                       |  |  |  |
|           | R       |    |    |    | H   | I ———    |    |                               |     | during Execution Phase from                                                       |  |  |  |
|           | R       | _  |    |    | F   | <u>،</u> |    |                               |     | Floppy Disk                                                                       |  |  |  |
|           | R       |    |    |    | N   |          |    |                               | _   |                                                                                   |  |  |  |

|           | FORMAT A TRACK |     |    |       |      |       |    |        |     |                                  |  |  |  |
|-----------|----------------|-----|----|-------|------|-------|----|--------|-----|----------------------------------|--|--|--|
| PHASE     | R/W            |     |    |       | DATA | BUS   |    |        |     | REMARKS                          |  |  |  |
|           |                | D7  | D6 | D5    | D4   | D3    | D2 | D1     | D0  |                                  |  |  |  |
| COMMAND   | W              | 0   | MF | 0     | 0    | 1     | 1  | 0      | 1   | Command Codes                    |  |  |  |
|           | w              | х   | х  | х     | х    | х     | HD | US1    | US0 |                                  |  |  |  |
|           | • w            | -   |    | ····· | N    |       |    |        |     | Bytes/Sector                     |  |  |  |
|           | w              | ·   |    |       | sc   | :     |    |        | _   | Sectors/Track                    |  |  |  |
|           | w              | -   |    |       | GP   | ۰L    |    |        |     | Gap 3                            |  |  |  |
|           | w              | -   |    |       | D    |       |    |        |     | Filler Byte                      |  |  |  |
| Execution |                |     |    |       |      |       |    |        |     | FDC formats an entire track      |  |  |  |
| Result    | R              | -   |    |       | ST   | 0     |    |        |     | Status information after Com-    |  |  |  |
|           | R              | -   |    |       | ST   | 1     |    |        | _   | mand execution.                  |  |  |  |
|           | R              |     |    |       | st   | 2     |    |        |     |                                  |  |  |  |
|           | R              | -   |    |       | C    | ;     |    | ······ |     | In this case, the ID information |  |  |  |
|           | R              | - 1 |    |       | — н  | I ——— |    |        | _   | has no meaning                   |  |  |  |
|           | R              | -   |    |       | R    |       |    |        |     |                                  |  |  |  |
|           | R              | -   |    |       | N    |       |    |        |     |                                  |  |  |  |

|           |     |    |    |    | SC   | AN EC                       | UAL                                   |     |          |                                                |
|-----------|-----|----|----|----|------|-----------------------------|---------------------------------------|-----|----------|------------------------------------------------|
| PHASE     | R/W |    |    |    | DATA | BUS                         |                                       |     |          | REMARKS                                        |
|           |     | D7 | D6 | D5 | D4   | D3                          | D2                                    | D1  | DO       |                                                |
| COMMAND   | w   | MT | MF | SK | 1    | 0                           | 0                                     | 0   | 1        | Command Codes                                  |
|           | w   | X  | х  | х  | Х    | Х                           | HD                                    | US1 | US0      |                                                |
|           | w   | -  |    |    | C    | ;                           | _,                                    |     |          | Sector ID information prior to                 |
|           | w   | -  |    |    | H    |                             |                                       |     | _        | Command execution.                             |
|           | w   | -  |    |    | R    |                             |                                       |     | <u> </u> |                                                |
|           | w   | -  |    |    | N    |                             |                                       |     |          |                                                |
|           | w   | _  |    |    | — EC | от —— то                    |                                       |     |          |                                                |
|           | w   | -  |    |    | GF   | °L                          |                                       |     |          |                                                |
|           | w   | -  |    |    | ST   | P                           |                                       |     |          |                                                |
| Execution |     |    |    |    |      |                             |                                       |     |          | Data compared between the FDD and main system. |
| Result    | R   | -  |    |    | st   | 0                           |                                       |     | _        | Status information after Com-                  |
|           | R   | -  |    |    | — s1 | 1 ——                        | · · · · · · · · · · · · · · · · · · · |     | _        | mand execution.                                |
|           | R   | -  |    |    | st   | 2                           |                                       |     |          |                                                |
|           | R   | -  |    |    | —— c | Sector ID information after |                                       |     |          |                                                |
|           | R   | -  |    |    | H    | 1                           |                                       |     |          | Command execution.                             |
|           | R   | -  |    |    | F    | R ———                       |                                       |     |          |                                                |
|           | R   |    |    |    | N    | l                           | <u></u>                               |     |          |                                                |

|           |     |     |                                        | S  | SCAN L | 0 <b>W</b> O. | R EQU                          | AL       |                    |                                                |
|-----------|-----|-----|----------------------------------------|----|--------|---------------|--------------------------------|----------|--------------------|------------------------------------------------|
| PHASE     | R/W |     |                                        |    | DATA   | BUS           |                                |          |                    | REMARKS                                        |
|           |     | D7  | D6                                     | D5 | D4     | D3            | D2                             | D1       | DO                 |                                                |
| COMMAND   | w   | MT  | MF                                     | SK | 1      | 1             | 0                              | 0        | 1                  | Command Codes                                  |
|           | w   | х   | X                                      | X  | X      | х             | HD                             | US1      | US0                |                                                |
|           | w   | _   |                                        |    | C      |               | Sector ID information prior to |          |                    |                                                |
|           | WH  |     |                                        |    |        |               |                                |          | Command execution. |                                                |
|           | w   | -   | R                                      |    |        |               |                                |          |                    |                                                |
|           | w   |     |                                        |    | N      |               |                                |          |                    |                                                |
|           | w   | EOT |                                        |    |        |               |                                |          |                    |                                                |
|           | w   | GPL |                                        |    |        |               |                                |          |                    |                                                |
|           | w   | -   |                                        |    | ST     | P             |                                |          | _                  |                                                |
| Execution |     |     |                                        |    |        |               |                                |          |                    | Data compared between the FDD and main system. |
| Result    | R   | -   |                                        |    | — st   | 0             | <u>.</u> .                     |          |                    | Status information after Com-                  |
|           | R   | -   |                                        |    | st     | 1             |                                |          |                    | mand execution.                                |
|           | R   | -   |                                        |    | st     | 2             |                                |          |                    |                                                |
|           | R   | -   | <u></u>                                |    | —— C   | ;             | ·                              |          |                    | Sector ID information after                    |
|           | R   |     | ······································ |    | H      |               |                                | <u> </u> |                    | Command execution.                             |
|           | R   | -   |                                        |    | R      |               |                                |          |                    |                                                |
|           | R   | -   |                                        |    | N      |               |                                |          |                    |                                                |

|           |     |     |    | S       | CAN H | IIGH O  | REQL                           | JAL  |     |                                                |
|-----------|-----|-----|----|---------|-------|---------|--------------------------------|------|-----|------------------------------------------------|
| PHASE     | R/W |     |    |         | DATA  | BUS     |                                |      |     | REMARKS                                        |
|           |     | D7  | D6 | D5      | D4    | D3      | D2                             | D1   | DO  |                                                |
| COMMAND   | w   | MT  | MF | SK      | 1     | 1       | 1                              | 0    | 1   | Command Codes                                  |
|           | w   | Х   | X  | Х       | х     | Х       | HD                             | US1  | US0 |                                                |
|           | w   |     |    |         | c     | _       | Sector ID information prior to |      |     |                                                |
|           | w   |     |    |         | H     |         |                                |      |     | Command execution.                             |
|           | w   | _   |    |         |       |         |                                |      |     |                                                |
|           | w   |     |    |         | —— N  | <u></u> |                                |      |     |                                                |
|           | w   |     |    |         |       |         |                                |      |     |                                                |
|           | w   | GPL |    |         |       |         |                                |      |     |                                                |
|           | w   |     |    | <u></u> | ST    | P       |                                | ··   |     |                                                |
| Execution |     |     |    |         |       |         |                                |      |     | Data compared between the FDD and main system. |
| Result    | R   |     |    |         | — st  | 0 ——    |                                |      |     | Status information after Com-                  |
|           | R   | _   |    |         | — st  | 1 —     |                                |      |     | mand execution.                                |
|           | R   | -   |    |         | — ST  | 2 ——    |                                |      |     |                                                |
|           | R   | _   |    |         | C     |         |                                |      |     | Sector ID information after                    |
|           | R   |     |    |         | H     |         |                                |      |     | Command execution.                             |
|           | R   | —   |    |         | R     |         |                                |      |     |                                                |
|           | R   | —   |    |         | N     |         |                                | ···· | _   |                                                |

|           |     |    |    |    | RE   | CALIBI | RATE    |     |     |                            |
|-----------|-----|----|----|----|------|--------|---------|-----|-----|----------------------------|
| PHASE     | R/W |    |    |    | DATA |        | REMARKS |     |     |                            |
|           |     | D7 | D6 | D5 | D4   | D3     | D2      | D1  | D0  |                            |
| COMMAND   | w   | 0  | 0  | 0  | 0    | 0      | 1       | 1   | 1   | Command Codes              |
|           | w   | x  | х  | х  | х    | х      | 0       | US1 | US0 |                            |
| Execution |     |    |    |    |      |        |         |     |     | Head retracted to Track 0. |

|         |     |    |    | SEN     | ISE IN | TERRL                  | IPT ST | ATUS |     |                               |  |
|---------|-----|----|----|---------|--------|------------------------|--------|------|-----|-------------------------------|--|
| PHASE   | R/W |    | -  | REMARKS |        |                        |        |      |     |                               |  |
|         | 1   | D7 | D6 | D5      | D4     | D3                     | D2     | D1   | D,0 |                               |  |
| COMMAND | w   | 0  | 0  | 0       | 0      | 1                      | 0      | 0    | 0   | Command Codes                 |  |
|         | w   |    |    |         |        |                        |        |      |     |                               |  |
| RESULT  | w   | -  |    |         | — st   | o                      |        |      |     | FDC status information at the |  |
|         | w   | _  |    |         | PC     | end of seek-operation. |        |      |     |                               |  |

|         |     |    |    |       |       | SPECI   | FY |      |    |               |
|---------|-----|----|----|-------|-------|---------|----|------|----|---------------|
| PHASE   | R/W |    |    |       | DAT   | REMARKS |    |      |    |               |
|         |     | D7 | D6 | D5    | D4    | D3      | D2 | D1 - | D0 |               |
| COMMAND | w   | 0  | 0  | 0     | 0     | 0       | 0  | 1    | 1  | Command Codes |
|         | w   |    | SR | кт —— |       |         | H  | IUT  |    |               |
|         | w   | -  |    |       | - HLT |         |    | -    | ND |               |

|         | SENSE DRIVE STATUS |    |    |    |     |         |    |     |     |                              |  |  |  |
|---------|--------------------|----|----|----|-----|---------|----|-----|-----|------------------------------|--|--|--|
| PHASE   | RW                 |    |    |    | DAT | REMARKS |    |     |     |                              |  |  |  |
|         |                    | D7 | D6 | D5 | D4  | D3      | D2 | D1  | D0  | м.<br>С                      |  |  |  |
| COMMAND | w                  | Ø  | 0  | 0  | 0   | 0       | 1  | 0   | 0   | Command Codes                |  |  |  |
|         | w                  | х  | х  | х  | х   | x       | HD | US1 | US0 |                              |  |  |  |
| RESULT  | w                  | _  |    |    | ST  | .3 ——   |    |     | _   | Status information about FDD |  |  |  |

|           | SEEK |    |    |    |      |         |    |     |     |                                                  |  |  |
|-----------|------|----|----|----|------|---------|----|-----|-----|--------------------------------------------------|--|--|
| PHASE     | R/W  |    |    |    | DATA | REMARKS |    |     |     |                                                  |  |  |
|           |      | D7 | D6 | D5 | D4   | D3      | D2 | D1  | D0  |                                                  |  |  |
| COMMAND   | w    | 0  | 0  | 0  | 0    | 1       | 1  | 1   | 1   | Command Codes                                    |  |  |
|           | w    | х  | х  | х  | х    | Х       | HD | US1 | US0 |                                                  |  |  |
| Execution | w    |    |    |    | ST   | 0       |    |     |     | Head positioned over proper cylinder on diskette |  |  |

|         |     |    |                           |    | INV     | ALID C  | ODES |    |    |                                                                    |
|---------|-----|----|---------------------------|----|---------|---------|------|----|----|--------------------------------------------------------------------|
| PHASE   | R/W |    |                           |    | DAT     | REMARKS |      |    |    |                                                                    |
|         |     | D7 | D6                        | D5 | D4      | D3      | D2   | D1 | D0 |                                                                    |
| Command | W   |    |                           |    | Invalid | Codes   |      |    | _  | Invalid Command Codes<br>(NoOp - FDC goes into Stand-<br>by State) |
| Result  | R   |    | STO STO = 80 <sub>H</sub> |    |         |         |      |    |    |                                                                    |

|           | SOFTWARE RESET |    |    |    |      |         |    |    |    |                        |  |  |  |
|-----------|----------------|----|----|----|------|---------|----|----|----|------------------------|--|--|--|
| PHASE     | R/W            |    |    |    | DAT/ | REMARKS |    |    |    |                        |  |  |  |
|           |                | D7 | D6 | D5 | D4   | D3      | D2 | D1 | D0 |                        |  |  |  |
| COMMAND   | W              | 0  | 0  | 1  | 1    | 0       | 1  | 1  | 0  | Command Codes          |  |  |  |
| Execution |                |    |    |    |      |         |    |    |    | Same as hardware reset |  |  |  |

### FUNCTIONAL DESCRIPTION OF COMMANDS

### **Read Data**

A set of nine (9) byte words are required to place the FDC37C65C into the Read Data Mode. After the Read Data command has been issued, the FDC37C65C loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the Specify Command), and begins reading ID Address Marks and ID fields. When the current sector number ("R") stored in the ID Register (IDR) compares with the sector number read off the diskette, then the FDC37C65C outputs data (from the data field) byte-to-byte to the main system via the data bus.

After completion of the read operation from the current sector, the Sector Number is incremented by one, and

the data from the next sector is read and output on the data bus. This continuous read function is called a "Multi-Sector Read Operation". The Read Data Command may be terminated by the receipt of a Terminal count signal. TC should be issued at the same time that the DACK for the last byte of data is sent. Upon receipt of this signal, the FDC37C65C stops outputting data to the processor, but will continue to read data from the current sector, check CRC (Cyclic Redundancy Count) bytes, and then, at the end of the sector, terminate the Read Data Command.

The amount of data which can be handled with a single command to the FDC37C65C depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector). Table 13 shows the Transfer Capacity.

| Multi-Track<br>MT | MFM/FM<br>MF | Bytes/Sector<br>N | Maximum Transfer Capacity<br>(Bytes/Sector) X (Number of<br>Sectors) | Final Sector Read<br>from Diskette |
|-------------------|--------------|-------------------|----------------------------------------------------------------------|------------------------------------|
| 0                 | 0            | 00                | $(128) \times (26) = 3,328$                                          | 26 at Side 0                       |
| 0                 | 1            | 01                | $(256) \times (26) = 6,656$                                          | or 26 at Side 1                    |
| 1                 | 0            | 00                | (128) x (52) = 6,656                                                 | 26 at Side 1                       |
| 1                 | 1            | 01                | (256) x (52) = 13,312                                                |                                    |
| 0                 | 0            | 01                | (256) x (15) = 3.840                                                 | 15 at Side 0                       |
| 0                 | 1            | 02                | (512) x (15) = 7.680                                                 | or 15 at Side 1                    |
| 1<br>1            | 0            | - 01<br>02        | (256) x (30) = 7,680<br>(512) x (30) = 15,360                        | 15 at Side 1                       |
| 0                 | 0            | 02                | $(512) \times (8) = 4,096$                                           | 8 at Side 0                        |
| 0                 |              | 03                | $(1024) \times (8) = 8,192$                                          | or 8 at Side 1                     |
| 1                 | 0            | 02<br>03          | (512) x (16) = 8,192<br>(1024) x (16) = 16,384                       | 8 at Sid <del>e</del> 1            |

#### TABLE 13 - TRANSFER CAPACITY

The "multi-track" function (MT) allows the FDC37C65C to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector L, Side 0 and completing at Sector L, Side 1 (Sector L is the last sector on the side). Please note that this function pertains to only one cylinder (the same track) on each side of the diskette.

When N = 0, the DTL defines the data length which the FDC37C65C must treat as a sector. If DTL is smaller than the actual data length in a Sector, the data beyond DTL in the Sector is not sent to the Data Bus. The FDC37C65C reads (internally) the complete Sector performing the CRC check, and depending upon the manner of command termination, may perform a Multi-Sector Read Operation. When N is non-zero, then DTL has no meaning and should be set to FF Hexadecimal.

At the completion of the Read Data command, the head is not unloaded until after the Head Unload Time Interval (specified in the Specify Command) has elapsed. If the processor issues another command before the head unloads, then the head settling time may be saved between subsequent reads. This time out is particularly valuable when a diskette is copied from one drive to another.

If the FDC37C65C detects the Index Hole twice without finding the right sector, (indicated in "R"), then the FDC37C65C sets the ND (No Data) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command. Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.

After reading the ID and Data Fields in each sector, the FDC37C65C checks the CRC bytes. If a read error is

detected (incorrect CRC in ID field), the FDC37C65C sets the DC (Data Error) flag in Status Register 1 to a 1 (high), and if a CRC error occurs in the Data Field the FDC37C65C also sets the DD (Data Error in Data field) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command. Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.

If the FDC37C65C reads a Deleted Data Address Mark from the diskette, and the SK bit (bit D5 in the first Command Word is not set (SK = 0) then the FDC37C65C sets the CM (Control Mark) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command, after reading all the data in the Sector. If SK = 1, the FDC37C65C skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when SK = 1. During disk data transfers between the FDC37C65C and the processor, via the data bus, the FDC37C65C must be serviced by the processor every 27  $\mu$ s in the FM Mode, and every 13  $\mu$ s in the MFM Mode, or the FDC37C65C sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command.

If the processor terminates a read (or write) operation in the FDC, then the ID information in the Result Phase is dependent upon the state of the MT bit and EOT byte. Table 14 shows the value for C, H, R, and N, when the processor terminates the Command.

| MT | HD | Final Sector Transferred to | 1     | D Information | at Result Phas | i <b>0</b> |
|----|----|-----------------------------|-------|---------------|----------------|------------|
|    |    | Processor                   | с     | н             | R              | N          |
|    | Q  | Less than EOT               | NC    | NC            | R + 1          | NC         |
|    | 0  | Equal to EOT                | C + 1 | NC            | R = 01         | NC         |
| 0  | 1  | Less than EOT               | NC    | NC            | R + 1          | NC         |
| [  | ;  | Equal to EOT                | C ÷ 1 | NC            | R = 01         | NC         |
| ř  | 0  | Less than EOT               | NC    | NC            | R+1            | NC         |
|    | 0  | Equal to EOT                | NC    | LSB           | R = 01         | -NC        |
| 1  | 1  | Less than EOT               | NC    | NC            | R + 1          | NC         |
|    | 1  | Equal to EOT                | C + 1 | LSB           | R = 01         | NC         |

| Table 14 - ID | Information | in Processor - | Terminated | Command |
|---------------|-------------|----------------|------------|---------|
|               |             |                |            |         |

Notes: 1. NC (No Change): The same value as the one at the beginning of command execution. 2. LSB (Least Significant Bit): The least significant bit of H is complemented.

#### Write Data

A set of nine (9) bytes are required to set the FDC37C65C into the Write Data mode. After the Write Data command has been issued, the FDC37C65C loads the head (if it is in the unloaded state), waits the specified Head Settling Time (defined in the specify command), and begins reading ID Fields. When all four bytes loaded during the Command (C, H, R, N) match the four bytes of the ID field from the diskette, the FDC37C65C takes data from the processor byte-by-byte via the data bus, and outputs it to the drive.

After writing data into the current sector, the Sector Number stored in "R" is incremented by one, and the next data field is written. The FDC37C65C continues this "Multi-Sector Write Operation" until the issuance of a Terminal Count signal. If a Terminal Count signal is sent to the FDC37C65C, it continues writing into the current sector to complete the data field. If the Terminal Count signal is received while a data field is being written, then the remainder of the data field is filled with 00 (zeros).

The FDC37C65C reads the ID field of each sector and checks the CRC bytes. If the FDC37C65C detects a read error (incorrect CRC) in one of the ID Fields, it sets the DE (Data Error) flag of Status Register 1 to a 1 (high), and terminates the Write Data Command. Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.

The Write Command operates in much the same manner as the Read Command. The following items are the same, and one should refer to the Read Data Command for details:

- Transfer Capacity
- EN (End of Cylinder) Flag
- ND (No Data) Flag
- Head Unload Time Interval
- ID Information when the processor terminates command (see Table 2)
- Definition of DTL when N = 0 and when  $N \neq 0$

In the Write Data mode, data transfers between the processor and FDC, via the Data Bus, must occur every 27  $\mu$ s in the FM mode, and every 13  $\mu$ s in the MFM mode. If the time interval between data transfers is longer than this, the FDC37C65C sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Write Data Command. Status register 0 also has bit 7 and 6 set to 0 and 1 respectively.

### Write Deleted Data

This command is the same as the Write Data Command except a Deleted Data Address Mark is written at the beginning of the Data Field instead of the normal Data Address Mark.

### Read Deleted Data

This command is the same as the Read Data Command except that when the FDC37C65C detects a Data Address Mark at the beginning of a Data Field and SK = 0 (low), it will read all the data in the sector and set the CM flag in Status Register 2 to a 1 (high), and then terminate the command. If SK = 1, the FDC37C65C skips the sector with the Data Address Mark and reads the next sector.

### Read a Track

This command is similar to the READ DATA Command except that this is a continuous READ operation where the entire data field from each of the sectors are read. Immediately after encountering the INDEX HOLE, the FDC37C65C starts reading all data fields on the track, as continuous blocks of data. If the FDC37C65C finds an error in the ID or DATA CRC check bytes, it continues to read data from the track. The FDC37C65C compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag of Status Register 1 to a 1 (high) if there is no comparison. Multi-track or skip operations are not allowed with this command.

This command terminates when the number of sectors read is equal to EOT. If the FDC37C65C does not find an ID Address Mark on the diskette after it encounters the INDEX HOLE for the second time, it sets the MA (missing address mark) flag in Status register 1 to a 1 (high), and terminates the command. Status Register 0 has bits 7 and 6 set to 0 and 1 respectively.

### Read ID

The READ ID Command is used to give the present position of the recording head. The FDC37C65C stores the values from the first ID field it is able to read. If no proper ID Address Mark is found on the diskette before the INDEX HOLE is encountered for the second time, the MA (Missing Address Mark) flag in Status Register 1 is set to a "1" (high), and if no data is found then the ND (No Data) flag is also set in Status Register 1 to a "1" (high). The command is then terminated with Bits 7 and 6 in Status Register 0 set to "0" and "1" respectively. During this command there is no data transfer between FDC37C65C and the CPU except during the result phase.

### Format a Track

The Format Command allows an entire track to be formatted. After the INDEX HOLE is detected, Data is written on the Diskette. Gaps, Address Marks, ID Fields and Data Fields, all per the IBM System 34 (Double Density) or System 3740 (Single Density) Format are recorded. The particular format which will be written is controlled by the values programmed into N (number of bytes/sector), SC (sectors/ cylinder), GPL (Gap Length), and D (Data Pattern) which are supplied by the processor during the Command Phase. The Data Field is filled with the Byte of data stored in D. The ID Field for each sector is supplied by the processor; four data requests per sector are made by the FDC37C65C for C (Cylinder Number), H (Head Number), R (Sector Number) and N (Number of Bytes/Sector). This allows the diskette to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for C, H, R, and N to the FDC37C65C for each sector on the track. If the FDC37C65C is set for DMA mode, it will issue 4 DMA requests per sector. If it is set for interrupt mode, it will issue four interrupts per sector and the processor must supply C, H, R and N load for each sector. The contents of the R register are incremented by one after each sector is formatted. The R register therefore contains a value of R when it is read during the Result Phase. This incrementing and formatting continues for the whole track until the FDC37C65C encounters the INDEX HOLE for the second time, whereupon it terminates the command.

If a FAULT signal is received from the drive at the end of a write operation, then the FDC37C65C sets the EC flag of Status Register 0 to a 1 (high), and terminates the command after setting bits 7 and 6 of Status Register 0 to 0 and 1 respectively. Also, the loss of a READY signal at the beginning of a command execution phase causes bits 7 and 6 of Status Register 0 to be set to 0 and 1 respectively. Table 15 shows the relationship between N, SC, GPL for various sector sizes. (See Table 16 for recommended IBM PC and PC/AT compatible programming parameters.)

| 01       02       03       04       05       01       02       03       04       05       01       02       03       04       05       03       04       05                            | 1A<br>0F<br>08<br>04<br>02<br>01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10 | GPL <sup>(1)</sup><br>07<br>0E<br>1B<br>47<br>C8<br>C8<br>0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8<br>C8<br>C8<br>07<br>10 | GPL <sup>(2)(3)</sup><br>1B<br>2A<br>3A<br>8A<br>FF<br>FF<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>FF<br>99<br>19 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| 01       02       03       04       05       01       02       03       04       05       03       04       05       03       04       05       05       06       Py       00       00 | 0F<br>08<br>04<br>02<br>01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10       | 0E<br>1B<br>47<br>C8<br>C8<br>0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8<br>C8<br>C8<br>C8<br>C8<br>C8<br>C8<br>C8           | 2A<br>3A<br>8A<br>FF<br>FF<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>FF                                            |
| 02       03       04       05       01       02       03       04       05       03       04       05       05       06       Py       00       00                                     | 08<br>04<br>02<br>01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10             | 1B         47         C8         0E         1B         35         99         C8         C8         07                    | 3A<br>8A<br>FF<br>FF<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>FF<br>09                                            |
| 03       04       05       01       02       03       04       05       04       05       06       Py       00       00                                                                | 04<br>02<br>01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10                   | 47<br>C8<br>C8<br>0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8<br>07                                                           | 8A<br>FF<br>5F<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>99                                                        |
| 04       05       01       02       03       04       05       04       05       06       Py       00       00                                                                         | 02<br>01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10                         | C8<br>C8<br>0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8                                                                       | FF<br>FF<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>09                                                              |
| 05       01       02       03       04       05       06       Py       00                                                                                                             | 01<br>1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10                               | C8<br>0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8<br>07                                                                       | FF<br>36<br>54<br>74<br>FF<br>FF<br>FF<br>09                                                                    |
| )1       )2       )3       )4       )5       )6       Py       )00       )00                                                                                                           | 1A<br>0F<br>06<br>04<br>02<br>01<br>12<br>10                                     | 0E<br>1B<br>35<br>99<br>C8<br>C8<br>C8<br>07                                                                             | 36<br>54<br>74<br>FF<br>FF<br>FF<br>09                                                                          |
| )2       )3       )4       )5       )6       Py       )0       )0                                                                                                                      | 0F<br>06<br>04<br>02<br>01<br>12<br>10                                           | 1B           35           99           C8           C8           07                                                      | 54<br>74<br>FF<br>FF<br>FF<br>09                                                                                |
| )3       )4       )5       )6       Py       )0       )0                                                                                                                               | 08<br>04<br>02<br>01<br>12<br>10                                                 | 35<br>99<br>C8<br>C8<br>07                                                                                               | 74<br>FF<br>FF<br>FF<br>09                                                                                      |
| 04<br>05<br>06<br>Py<br>00<br>00                                                                                                                                                       | 04<br>02<br>01<br>12<br>10                                                       | 99<br>C8<br>C8<br>07                                                                                                     | FF<br>FF<br>FF<br>09                                                                                            |
| 05<br>06<br>Py<br>00<br>00                                                                                                                                                             | 02<br>01<br>12<br>10                                                             | C8<br>C8<br>07                                                                                                           | FF<br>FF<br>09                                                                                                  |
| 06<br>Py<br>00<br>00                                                                                                                                                                   | 01<br>12<br>10                                                                   | C8<br>07                                                                                                                 | FF<br>09                                                                                                        |
| ру<br>00<br>00                                                                                                                                                                         | 12<br>10                                                                         | 07                                                                                                                       | 09                                                                                                              |
| 00                                                                                                                                                                                     | 10                                                                               |                                                                                                                          |                                                                                                                 |
| 00                                                                                                                                                                                     | 10                                                                               |                                                                                                                          |                                                                                                                 |
|                                                                                                                                                                                        |                                                                                  | 10                                                                                                                       | 19                                                                                                              |
| 11                                                                                                                                                                                     | 00                                                                               |                                                                                                                          | • •                                                                                                             |
| 1                                                                                                                                                                                      | 08                                                                               | 18                                                                                                                       | 30                                                                                                              |
| 02                                                                                                                                                                                     | 04                                                                               | 46                                                                                                                       | 87                                                                                                              |
| 03                                                                                                                                                                                     | 02                                                                               | C8                                                                                                                       | FF                                                                                                              |
| 04                                                                                                                                                                                     | 01                                                                               | C8                                                                                                                       | FF                                                                                                              |
| 1 10                                                                                                                                                                                   | 12                                                                               | 0A                                                                                                                       | 00                                                                                                              |
| 21                                                                                                                                                                                     | 10                                                                               | -20                                                                                                                      | 32                                                                                                              |
| 35                                                                                                                                                                                     | Ŋa                                                                               | 2 <b>4</b>                                                                                                               | 50                                                                                                              |
| 03                                                                                                                                                                                     | 04                                                                               | 80                                                                                                                       | F0                                                                                                              |
| 04                                                                                                                                                                                     | 02                                                                               | C8                                                                                                                       | FF                                                                                                              |
| 05                                                                                                                                                                                     | 01                                                                               | C8                                                                                                                       | FF                                                                                                              |
| oppydi                                                                                                                                                                                 | isk                                                                              |                                                                                                                          |                                                                                                                 |
| 0                                                                                                                                                                                      | 0F                                                                               | 07                                                                                                                       | 1B                                                                                                              |
| 1                                                                                                                                                                                      | 09                                                                               | 0E                                                                                                                       | 2A                                                                                                              |
| 2                                                                                                                                                                                      | 05                                                                               | 18                                                                                                                       | 3A                                                                                                              |
|                                                                                                                                                                                        | 0F                                                                               | 0E                                                                                                                       | 36                                                                                                              |
| 1                                                                                                                                                                                      | 09                                                                               | 18                                                                                                                       | 54                                                                                                              |
| 1 2                                                                                                                                                                                    | 05                                                                               | 35                                                                                                                       | 74                                                                                                              |
|                                                                                                                                                                                        |                                                                                  |                                                                                                                          | com-                                                                                                            |
|                                                                                                                                                                                        | 1<br>2<br>3                                                                      | 1 OF<br>2 09<br>3 05                                                                                                     | 1 OF OE<br>2 09 1B                                                                                              |

(2) Suggested values of GPL in format command.

(3) All values except sector size and hexadecimal.

 In MFM mode FDC37C65C cannot perform a Read/Write/Format operation with 128 bytes/sector. (N = 00)

### Scan Commands

.

from the diskette to be compared against data which is being supplied from the main system. The FDC37C65C compares the data on a byte-by-byte basis, and looks

The SCAN Commands allow data which is being read

for a sector of data which meets the conditions of:

$$D_{FDD} = D_{PROCESSOR}, D_{FDD} \leq D_{PROCESSOR}$$
, or

The hexadecimal byte of FF either from memory or from the drive can be used as a mask byte because it always meets the condition of the compare. Ones complement arithmetic is used for comparison (FF = largest number. 00 = smallest number). After a whole sector of data is compared, if the conditions are not met, the sector number is incremental (R + STP - R), and the scan operation is continued. The scan operation continues until one of the following conditions occur:

1. The conditions for scan are met (equal, low, or high), or,

- 2. The last sector on the track is reached (EOT), or
- 3. The terminal count signal is received.

COMMAND **STATUS REGISTER 2** COMMENTS BIT 2 (SN) BIT 3 (SH) Scan Equal 0 1 D<sub>FDD</sub> = D<sub>PROCESSOR</sub> DFDD + DPROCESSOR 1 0 0 1 DFDD = DFROCESSOR 0 0 DFDD < DFROCESSOR Scan Low or Equal D<sub>FDD</sub> > D<sub>PROCESSOR</sub> 1 0 0 D<sub>FDD</sub> = D<sub>PROCESSOR</sub> 1 0 0 D<sub>FDD</sub> > D<sub>PROCESSOR</sub> Scan High or Equal D<sub>FDD</sub> < D<sub>PROCESSOR</sub> 1 0

Table 16

If the FDC37C65C encounters a Deleted Data Address Mark on one of the sectors (and SK = 0), then it regards the sector as the last sector on the cylinder, sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) and terminates the command. If SK = 1, the FDC37C65C skips the sector with the Deleted Address Mark, and reads the next sector. In the second case (SK = 1), the FDC37C65C sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) in order to show that a Deleted Sector had been encountered.

When either the STP (contiguous sectors = 01, or alternate sectors = 02) sectors are read, or the MT (Multi-Track) is programmed, it is necessary to remember that the last sector on the track must be read. For example, if STP = 02, MT = 0, the sectors are numbered sequentially 1 through 26, and we start the Scan Command at sector 21, the following will happen: Sectors 21,

23 and 25 will be read, then the next sector (26) will be skipped, and the Index Hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT has been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.

If the conditions for scan are met, then the FDC37C65C sets the SH (Scan Hit) flag of Status Register 2 to a "1" (high), and terminates the Scan Command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC37C65C sets the SN (Scan Not Satisfied) flag of Status Register 2 to a 1 (high), and

terminates the Scan Command. The receipt of a

TERMINAL COUNT signal from the Processor or DMA

Controller during the scan operation will cause the

FDC37C65C to complete the comparison of the particu-

lar byte which is in process, and then to terminate the command. Table 16 shows the status of bits SH and SN

under various conditions of SCAN.

During the Scan Command, data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1, it is necessary to have the data available in less than 27 µs (FM Mode) or 13 µs (MFM Mode). If an Overrun occurs the FDC37C65C ends the command with bits 7 and 6 of Status Register 0 set to 0 and 1, respectively.

#### Seek

The read/write head within the drive is moved from cylinder to cylinder under control of the Seek Command. FDC37C65C has four independent Present Cylinder Registers for each drive. They are clear only after the Recalibrate command. The FDC37C65C compares the PCN (Present Cylinder Number), which is the current head position, with the NCN (New Cylinder Number), and if there is a difference performs the following operation:

| PCN < NCN: | Direction signal to drive set to a 1 (high),and Step Pulses are |  |  |  |
|------------|-----------------------------------------------------------------|--|--|--|
|            | issued (Step In).                                               |  |  |  |
| PCN > NCN: | Direction signal to drive set to                                |  |  |  |

a 0 (low), and Step Pulses are issued (Step Out).

The rate at which Step Pulses are issued is controlled by the SRT (Stepping Rate Time) in the SPECIFY Command. After each Step Pulse is issued, NCN is compared against PCN; when NCN = PCN, the SE (Seek End) flag in Status Register 0 is set to a 1 (high), and the command is terminated. At this point the FDC37C65C interrupt goes high. Bits DB0 - DB3 in the Main Status Register are set during the seek operation and are cleared by the Sense Interrupt Status Command.

During the Command Phase of the Seek operation, the FDC37C65C is in the FDC37C65C BUSY state, but during the Execution Phase it is in the NON-BUSY state. While the FDC37C65C is in the NON-BUSY state, another seek Command may be issued, and in this manner parallel Seek Operations may be performed on up to 4 Drives at once. No other command can be issued for as long as the FDC37C65C is in process of sending Step Pulses to any drive.

If a drive is in a NOT READY state at the beginning of the command execution phase or during the seek operation, then the NR (NOT READY) flag is set in Status Register 0 to a 1 (high), and the command is terminated after bits 7 and 6 of Status Register 0 are set to 0 and 1 respectively.

If the time to write 3 bytes of seek command exceeds 150  $\mu$ s, the timing between the first two Step Pulses may be shorter than set in the Specify command by as much as 1 ms.

### Recalibrate

The function of this command is to retract the read/write head within the drive to the Track 0 position. The FDC37C65C clears the contents of the PCN counter, and checks the status of the Track 0 signal from the drive. As long as the Track 0 signal is low, the Direction signal remains 0 (low) and Step Pulses are issued. When the Track 0 signal goes high, the SE (SEEK END) flag in Status Register 0 is set to a 1 (high) and the command is terminated. If the Track 0 signal is still low after 77 Step Pulses have been issued, the FDC37C65C sets the SE (SEEK END) and EC (EQUIPMENT CHECK) flags of Status Register 0 to both 1's (highs), and terminates the command after bits 7 and 6 of Status Register 0 are set to 0 and 1 respectively.

For IBM compatibility, two RECALIBRATE Commands must be issued for disks with more than 77 tracks.

The ability to overlap RECALIBRATE Commands to multiple drives and the loss of the READY signal, as described in the Seek Command, also applies to the RECALIBRATE Command.

#### Sense Interrupt Status

An Interrupt signal will be generated by the FDC37C65C for one of the following reasons:

- 1. Upon entering the Result Phase of:
  - a. Read Data Command
  - b. Read a Track Command
  - c. Read ID Command
  - d. Read Deleted Data Command
  - e. Write Data Command
  - f. Format a Cylinder Command
  - g. Write Deleted Data Command
  - h. Scan Commands
- 2. Ready Line of drive changes state
- 3. End of Seek or Recalibrate Command
- 4. During Execution Phase in the NON-DMA Mode

interrupts caused by reasons 1 and 4 above occur during normal command operations—and are easily discernible by the processor. During an execution phase in the NON-DMA Mode, DB5 in the Main Status Register is high. Upon entering the Result Phase this bit is cleared. Reasons 1 and 4 do not require a Sense Interrupt Status command. The interrupt is cleared by reading or writing data to the FDC. Interrupts caused by reasons 2 and 3 above may be uniquely identified with the aid of the Sense Interrupt status Command. This command when issued resets the interrupt signal and via bits 5, 6, and 7 of Status Register, 0 identifies the cause of the interrupt. See Table 17.

Neither the Seek or Recalibrate Command have a Result Phase. Therefore, it is mandatory to use the Sense Interrupt Status Command after these commands to effectively terminate them and to provide verification of the head position (PCN).

Issuing the Sense Interrupt Status Command without an interrupt pending is treated as an invalid command.

### Specify

The Specify Command sets the initial values for each of the three internal timers. The HUT (Head Unload Time)

| SEEK<br>END |       |       | CAUSE                                                       |
|-------------|-------|-------|-------------------------------------------------------------|
| BIT 5       | BIT 6 | BIT 7 |                                                             |
| 0           | 1     | 1     | Ready Line changed state,<br>either polarity                |
| 1           | 0     | 0     | Normal Termination of Seek<br>or Recalibrate Command        |
| 1           | 1     | 0     | Abnormal Termination of<br>Seek or Recalibrate Com-<br>mand |

Table 17

defines the time from the end of the Execution Phase of one of the Read/Write Commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of 16 ms (01 = 16 ms, 02 = 32 ms, ... 0F = 240 ms). The SRT (Step Rate Time) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of 1 ms (F = 1 ms, E = 2 ms, D = 3 ms, etc.). The HLT (Head Load Time) defines the time between the Head Load signal going high and the Read/Write operation starting. This timer is programmable from 2 to 254 ms in increments of 2 ms (01 = 2 ms, 02 = 4 ms, 03 = 6 ms,... 7F = 254 ms).

The time intervals mentioned above are a direct function of the clock (CLK1 or XTAL1). Times indicated above are for a 16 MHz clock; if the clock is reduced to 8 MHz then the time intervals are increased by a factor of two. If the clock is increased to 32 MHz then all time intervals are decreased by a factor of two.

The choice of DMA or non-DMA operation is made by the ND (NON-DMA) bit. When this bit is high (ND = 1), the non-DMA mode is selected, and when ND = 0, the DMA mode is selected.

# Sense Drive Status

This command may be used by the processor whenever it wishes to obtain the status of the drives. Status Register 3 contains the Drive Status information stored internally in the FDC37C65C registers.

#### Invalid

If an invalid command is sent to the FDC37C65C (a command not defined above), then the FDC37C65C will terminate the command after bits 7 and 6 of Status Register 0 are set to 1 and 0 respectively. No interrupt is generated by the FDC37C65C during this condition. Bit 6 and bit 7 (DIO and RQM) in the Main Status Register are both high ("1") indicating to the processor that the FDC37C65C is in the Result Phase and the contents of Status Register 0 (STO) must be read. When the processor reads Status Register 0, it will find an 80 hex indicating an invalid command was received.

A Sense Interrupt Status Command must be sent after a Seek or Recalibrate Interrupt, otherwise the FDC37C65C will consider the next command to be an Invalid Command.

In some applications the user may wish to use this command as a No-Op command, to place the FDC37C65C in a standby or no operation state.

| Table 18                          |
|-----------------------------------|
| COMPARISON: FDC37C65B & FDC37C65C |

| FDC37C65B                           | FDC37C65C                         |
|-------------------------------------|-----------------------------------|
| Max Data Rate: 1 Mbps               | Max Data Rate: 1 Mbps             |
| Max Clock: 32 MHz                   | Max Clock: 32 MHz                 |
| No Power Down Mode                  | Power Down Mode                   |
| No Write Precomp Disable<br>Feature | Write Precomp Disable<br>Feature  |
| Pull up resistor on DMA<br>pin      | No Pull-up resistor on<br>DMA pin |

| GAP 4a<br>80x<br>4E | SYNC<br>12x<br>00                   | IAM<br>3x FC<br>C2 | GAP1<br>50x<br>4E | SYNC<br>12x<br>00 | IDAM<br>3x FE<br>A1 | C<br>Y<br>L | H<br>D | S<br>E<br>C | N O | C<br>R<br>C | GAP2<br>22x<br>00 | SYNC<br>12x<br>00 | DATA AN<br>3x FB<br>A1 F8 |        | C<br>R<br>C | GAP3 | GAP<br>4b |   |
|---------------------|-------------------------------------|--------------------|-------------------|-------------------|---------------------|-------------|--------|-------------|-----|-------------|-------------------|-------------------|---------------------------|--------|-------------|------|-----------|---|
|                     | SYSTEM 3740 (SINGLE DENSITY) FORMAT |                    |                   |                   |                     |             |        |             |     |             |                   |                   |                           |        |             |      |           |   |
| GAP4a               | SYNC                                | IAM                | GAP1              | SYNC              | IDAM                | С           | н      | S           | N   | С           | GAP2              | SYNC              | DATA AN                   | A DATA | C           | GAP3 | GAP       | 1 |
| 40x                 | 6x                                  | 50                 | 26x               | 6x                |                     | Y           | D      | E           | 0   | R           | 11x               | 6x                | 50                        | -      | R           | 1    | 4b        | ł |
| FF                  | 00                                  | FC                 | FF                | 00                | FE                  | L           |        | С           |     | С           | FF                | 00                | FB or F8                  | 5      | С           |      |           |   |

SYSTEM 34 (DOUBLE DENSITY) FORMAT

### OPERATIONAL DESCRIPTION

### **MAXIMUM GUARANTEED RATINGS\***

| Operating Temperature Range                                                                | 0°C to +70°C |
|--------------------------------------------------------------------------------------------|--------------|
| Storage Temperature Range                                                                  |              |
| Lead Temperature Range (soldering, 10 seconds)                                             | +325°C       |
| Positive Voltage on any pin, with respect to Ground                                        | V,+0.3V      |
| Negative Voltage on any pin, with respect to Ground                                        | <b>0.3V</b>  |
| $Maximum  V_{cc}  \ldots  \ldots  \ldots  \ldots  \ldots  \ldots  \ldots  \ldots  \ldots $ | <b>+7V</b>   |

\* Stresses above those listed above could cause permanent damage to the device. This is a stress rating only and functional operation of the device at any other condition above those indicated in the operation sections of this specification is not implied.

Note: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes on their outputs when the AC power is switched on or off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists, it is suggested that a clamp circuit be used.

| PARAMETER                                                                                                                                                                                      | SYMBOL                                                    | MIN         | ТҮР | MAX                  | UNITS          | COMMENTS                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-------------|-----|----------------------|----------------|----------------------------------------------------------------------------------------------------------------|
| Low Input Voltage 1<br>(D0-D7, XTAL1, XTAL2<br>High Input Voltage 1<br>(D0-D7, XTAL1, XTAL2)                                                                                                   | V <sub>i⊩1</sub><br>V <sub>i№1</sub>                      | 2.0         |     | 0.8                  | v<br>v         | TTL Levels                                                                                                     |
| Low Input Voltage 2<br>(Low to High Threshold)<br>(All inputs except D0-D7,<br>XTAL1, XTAL2)<br>High Input Voltage 2<br>(High to Low (hreshold)<br>(All inputs except D0-D7,<br>XTAL1, XTAL2). | V <sub>IL2</sub><br>V <sub>IH2</sub>                      | 0.8         |     | 2.0                  | v              | Schmitt Trigger<br>Schmitt Trigger                                                                             |
| Schmitt Trigger Hysteresis                                                                                                                                                                     | V <sub>hys</sub>                                          | 0.45        | 1   | 1                    | V              |                                                                                                                |
| Low Output Voltage 1<br>(D0-D7, IRQ, DMA)<br>High Output Voltage 1<br>(D0-D7, IRQ, DMA)                                                                                                        | V <sub>ol1</sub><br>V <sub>oh1</sub>                      | 2.8         |     | 0.4                  | v<br>v         | I <sub>оL</sub> = 24.0 mA<br>I <sub>он</sub> = -5.0 mA                                                         |
| Low Output Voltage 2 (All outputs<br>except D0-D7, IRQ, DMA)                                                                                                                                   | V <sub>ol2</sub>                                          |             |     | 0.4                  | v              | I <sub>oL</sub> = 48 mA                                                                                        |
| Latch Up Current                                                                                                                                                                               | ارں                                                       | ±200        |     |                      | mA             |                                                                                                                |
| Input Leakage Current 1 (All in-<br>puts except PCVAL and DRV)<br>Low Input Pull-Up Current<br>(PCVAL and DRV)<br>High Input Leakage Current 2<br>(PCVAL and DRV)                              | <sub>L1</sub><br>   <sub>PU</sub><br>   <sub>L2</sub>     | 10.0<br>0.0 |     | ±10.0<br>60<br>-10.0 | μΑ<br>μΑ<br>μΑ | $V_{iN} = 0V$<br>$V_{iN} = 5V$                                                                                 |
| V <sub>cc</sub> Supply Current 1<br>V <sub>cc</sub> Supply Current 2<br>Power Down Mode V <sub>cc</sub> Supply<br>Current                                                                      | I <sub>cc1</sub><br>I <sub>cc2</sub><br>I <sub>ccPD</sub> |             |     | 45<br>95<br>100      | mA<br>mA<br>μA | 100 $\mu$ A Source Loads<br>5 mA Source Loads<br>V <sub>IN</sub> = GND or V <sub>cc</sub> ; I <sub>o</sub> = 0 |
| Power Dissipation 1<br>Power Dissipation 2                                                                                                                                                     | PD,<br>PD,                                                |             |     | 425<br>575           | mW<br>mW       | I <sub>cc1</sub> Max<br>I <sub>cc2</sub> Max **                                                                |
| Power Qualified Reset Threshold                                                                                                                                                                | V <sub>PCR</sub>                                          | 2.8         |     | 4.35                 | V              |                                                                                                                |

DC ELECTRICAL CHARACTERISTICS ( $T_A = 0^{\circ}C - 70^{\circ}C$ ,  $V_{cc} = +5.0 V \pm 10\%$ )

\*\* Includes open drain high current drivers at  $V_{\rm or}$  = 0.4V

# TIMING DIAGRAMS



|                | Parameter                               | min | typ | max          | units |
|----------------|-----------------------------------------|-----|-----|--------------|-------|
| t,             | A0, CS, DACK, LDCR<br>Set Up to RD Low  | 0   |     |              | ns    |
| t <sub>2</sub> | RD Width                                | 90  |     |              | ns    |
| t,             | A0, CS, DACK, LDCR<br>Hold from RD High | 0   |     |              | ns    |
| t,             | Data Access Time from RD Low            |     |     | 90           | ns    |
| t,             | Data to Float Delay from RD High        |     |     | 65           | ns    |
| t,             | IRQ Reset Delay from RD High            |     |     | X + (150ns)* |       |

\* X specifies one MCLK period. It is dependent upon selected data rate (see Table 1.0).

FIGURE 5 - MICROPROCESSOR READ TIMING



|                | Parameter                                         | min | typ | max | units               |
|----------------|---------------------------------------------------|-----|-----|-----|---------------------|
| t,             | A0, CS, DACK, LDCR, LDOR<br>Set Up time to WR Low | 0   |     |     | ns .                |
| t <sub>z</sub> | WR Width                                          | 60  |     |     | ns                  |
| t,             | A0, CS, DACK, LDCR, LDOR<br>Hold from WR High     | 0   |     |     | ns                  |
| t,             | Data Set Up Time to WR High                       | 80  |     |     | ns                  |
| t,             | Data Hold Time from WR High                       | 0   |     |     | ns                  |
| t <sub>e</sub> | IRQ Reset Delay from WR High                      |     |     | x·  | ⊦ (150n <b>s</b> )* |

# FIGURE 6 - MICROPROCESSOR WRITE TIMING

38



|                | Parameter                        | min | typ | max | units      |
|----------------|----------------------------------|-----|-----|-----|------------|
| t,             | DMA Cycle Time                   | 52  |     |     | ×٠         |
| t <sub>z</sub> | DACK Delay Time from DMA High    | 0   |     |     | ns         |
| t,             | DMA Reset Delay from DACK Low    |     |     | 140 | ns         |
| t,             | DACK Width                       | 90  |     |     | ns         |
| t,             | RD or WR Response From DMA High  |     |     | 48  | ×٠         |
| t <sub>s</sub> | RD Delay from DMA High           | 0   |     |     | ns         |
| t,             | WR Delay from DMA High           | 0   |     |     | ns         |
| t,             | Data Access Time from RD Low     |     |     | 90  | ns         |
| t,             | Data Set Up Time to WR High      | 80  |     |     | n <b>s</b> |
| t,,            | Data to Float Dalay from RD High | 10  |     | 65  | រាទ        |
| t,,            | Data Hold Time from WR High      | 0   |     |     | ns         |

FIGURE 7 - DMA TIMING



|                | Parameter                         | min | typ | max | units |
|----------------|-----------------------------------|-----|-----|-----|-------|
| t,             | TC Delay from Last DMA or IRQ, RD | 0   |     | 192 | X     |
| t,             | TC Delay from Last DMA or IRQ, WR | 0   |     | 384 | x     |
| t <sub>s</sub> | TC Width                          | 60  |     |     | ns    |

# FIGURE 8 - TERMINAL COUNT TIMING



|    | Parameter                                             | min  | typ | max | units |
|----|-------------------------------------------------------|------|-----|-----|-------|
| t, | RESET Width - TTL Driven CLK1                         | 250  |     |     | ns    |
| t, | RESET Width - Software Reset                          | 5    |     |     | ×٠    |
| t, | Chip Access Delay from RESET Low - TTL                | 32   |     |     | ×٠    |
| t. | Chip Access Delay from Software RESET Low             | 40   |     |     | ×٠    |
| t, | Chip Access Delay from RESET Low - XTAL1 at 16<br>MHz | 500  |     |     | μs    |
| t, | XTAL2 Access Delay after Reset 9.6 MHz                | 1000 |     |     | μs    |

\* X specifies one MCLK period. It is dependent upon selected data rate (see Table 10).

FIGURE 9 - RESET TIMING



|                | Parameter                     | min | typ | max | units |
|----------------|-------------------------------|-----|-----|-----|-------|
| t,             | DIRC Set Up to STEP Low       | 4   |     |     | x٠    |
| t,             | STEP Active time Low          | 24  |     |     | x•    |
| t,             | DIRC Hold Time After STEP     | 96  |     |     | ×٠    |
| t,             | STEP Cycle Time               | 132 |     |     | ×٠    |
| t,             | DS1-4 Hold Time from STEP Low | 20  |     |     | ×٠    |
| t <sub>s</sub> | IDX Pulse Width               | 2   |     |     | ×٠    |
| t,             | RDD Active Time Low           | 40  |     |     | ns    |
| t <sub>a</sub> | WD Write Data Width Low       |     | .5  |     | Y٠    |

\*\* Y specifies one WCLK period. It is dependent upon selected data rate (see Table 10)

FIGURE 10 - DISK DRIVE TIMING



|                | Parameter                                      | min  | typ | max | units |
|----------------|------------------------------------------------|------|-----|-----|-------|
| t,             | Clock Rise Time (V <sub>IN</sub> = 0.8 TO 2.0) |      |     | 2   | ns    |
| t <sub>2</sub> | Clock Fall Time (V <sub>IN</sub> = 2.0 to 0.8) |      |     | 2   | ns    |
| t,             | Clock Period                                   | 31.0 |     |     | ns    |
| t,             | Clock Active (High or Low)                     | 13.5 |     |     | ns    |

FIGURE 11 - CLOCK TIMING

### Table 16 - PROGRAMMING VALUES FOR FLOPPY DISK CONTROLLERS (IBM PC AND PC/AT COMPATIBLE SYSTEMS)

| Parameter                  | HEX VALUES TO BE PROGRAMMED |                |                 |                 |  |  |
|----------------------------|-----------------------------|----------------|-----------------|-----------------|--|--|
|                            | 1.44 MB<br>3.5"             | 720 KB<br>3.5" | 1.2 MB<br>5.25" | 360 KB<br>5.25" |  |  |
| Bytes/Sector {N}           | 02                          | 02             | 02              | 02              |  |  |
| Sectors/Track {SC}         | 12                          | 09             | OF              | 09              |  |  |
| Gap Length (1) {GPL1}      | 1B                          | 2A             | 1B              | 2A              |  |  |
| Gap Length (2),(3){GPL2,3} | 6C                          | 50             | 54              | 50              |  |  |
| Head Settle Time (ms)      | 15                          | 15             | 15              | 15              |  |  |
| Motor Start Up (1/8 sec)   | 08                          | 08             | 08              | 08              |  |  |
| Cylinders                  | 80                          | 80             | 80              | 40              |  |  |
| Tracks                     | 160                         | 160            | 160             | 80              |  |  |
| Tracks/Inch                | 135                         | 135            | 96              | 48              |  |  |
| Heads                      | 02                          | 02             | 02              | 02              |  |  |
| RPM                        | 300                         | 300            | 360             | 300             |  |  |
| Transfer (KB/s)            | 500                         | 250            | 500             | 250             |  |  |



Circuit diagrams utilizing SMC products are included as a means of illustrating typical applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any licenses under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.

-HALDCAUGE NY 117 516-273 3100 Fax 15161 231 6004 COMPONENT PRODUCTS DIVISION

10/4/90

May 1988 Edition 1.0

FUJITSU FUJITSU MICROELECTRONICS, INC.



## SCSI Protocol Controller (SPC)

#### **GENERAL DESCRIPTION**

The M887030 and M887031 SCSI Protocol Controller (SPC) are CMOS LSI circuits specifically designed to control a Small Computer Systems Interface (SCSI). In terms of features, functional operation, and electrical specifications, the two devices are identical. However, the M887030 is housed in an 88-pin ceramic pin grid array package, whereas, the M887031 is designed for surface mounting and is housed in a 100-pin plastic flat package.

The SPC can serve as either an INITIATOR or TARGET for the SCSI; thus, it can be used as in I/O controller or as a host adapter. To use the device in the most effective manner, it is recommended that the user be thoroughly familiar with the SCSI and interface control procedures. For detailed information in these areas, the user should contact the nearest Sales Office of Fulltsu.

The SPC is designed to control all SCSI interface signals and virtually all interface control procedures. Used as an 8- or 16-bit peripheral, the device provides high-level control for almost all SCSI configurations.

To achieve optimum performance and interface flexibility, the SPC contains an 8-byte First in First Out (FIFO) data buffer register and a 24-bit transfer byte counter. Independent data busses for the CPU and the DMA controller plus separate input/output pins for all control signals greatly reduces the possibility of a "busy" condition. Data transfers can be executed in either the synchronous or asynchronous mode with a maximum offset of 8-bytes.

#### SCSI Compatibility

- Supports all mandatory commands, many optional commands, and some extended commands of SCSI Specification (ANSI X3.131/1986)
- Serves as either INITIATOR or TARGET
- Both synchronous and asynchronous operation
- Software compatible with MB87033

#### Data Busses

Data Transfer Speed

- Independent busses for CPU and DMA controller
- Synchronous data transfers with programmable offset of up to eight bytes

#### Selectable Transfer Modes • DMA transfer

- Program transfer
- Manual transfer

Interface Connections

Single-ended or differential options
 TTL-compatible I/O

## Clock Requirements

• 8 MHz clock with 33% to 66% duty cycle

#### **Technology/Power Requirements**

Slicon-gate CMOS
Single +5V power supply

#### Available Packaging

- 88-pin ceramic repeated quad-in-line
- 100-pin plastic flat package

#### ABSOLUTE MAXIMUM BATINGS1

Up to a maximum of 4-megabytes-per-second

| Patien                           | 0 mb al | Valu                |                       |      |
|----------------------------------|---------|---------------------|-----------------------|------|
| Rating                           | Symbol  | Min                 | Max                   | Unit |
| Supply Voltage                   | V DO    | V <sub>SS</sub> 205 | 7.0                   | v    |
| Input Voltage                    | V 1     | Vss205              | V <sub>DD</sub> + 0.5 | V    |
| Output Voltage 2                 | ۷o      | V <sub>SS</sub> 205 | V <sub>DD</sub> + 0.5 | v    |
| Storage Temperature (Ceramic)    | T STG   | -65                 | +150                  | •c   |
| Temperature Under Blas (Ceramic) | T BIAS  | -40                 | +125                  | •c   |
| Output Current 3                 | 1 os    | -40                 | +70                   | mA   |

#### NOTES:

Permanent device damage may occur if the above Absolute Maximum Ratings are exceeded. Functional
operation should be restricted to the conditions as detailed in the operational sections of this data sheet.
Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

2. Vss = 0V.

3. Not more than one output may be shorted at a time for a maximum duration of one second.

Copyright 

1988 by FUUITSU UMITED and Fujitsu Microelectronics, Inc.

May 1988 Edition 1.0

MB87030/31



## PIN ASSIGNMENTS (Continued)

FPT-100P-M01



| Pin<br>No. | 1/0 | Designator      | Pin<br>No. | 1/0 | Designator      | Pin<br>No. | 1/0 | Designator       | Pin<br>No. | 1/0 | Designator      |
|------------|-----|-----------------|------------|-----|-----------------|------------|-----|------------------|------------|-----|-----------------|
| 1          | I   | DRESP           | 26         | 1/0 | D2              | 51         | 0   | TARG             | 76         | 0   | SDBE5           |
| 2          | 0   | DREQ            | 27         | 1/0 | D3              | 52         | 0   | INIT             | 77         | o   | SDBO5           |
| 3          | -   | V <sub>DD</sub> | 28         | -   | V <sub>DO</sub> | 53         | -   | V <sub>DD</sub>  | 78         | -   | VDD             |
| 4          | -   | V <sub>SS</sub> | 29         | -   | V <sub>SS</sub> | 54         | -   | ∨ <sub>S8</sub>  | 79         | _   | V <sub>SS</sub> |
| 5          | 1   | HIN             | 30         | 1/0 | D4              | 55         | 1   | ACKI             | 80         | -   | N/C             |
| 6          | 1/0 | HDB0            | 31         | 1/0 | D5              | 56         | 0   | АСКО             | 81         | 1   | SDBI4           |
| 7          | 1/0 | HDB1            | 32         | 1/0 | D6              | 57         | _   | N/C              | 82         | 0   | SDBE4           |
| 8          | 1/0 | HDB2            | 33         | 1/0 | D7              | 58         | -   | N/C              | 83         | 0   | SDBO4           |
| 9          | 1/0 | HDB3            | 34         | 1/0 | DP              | 59         | 1   | BSYI             | 84         | 1   | SDB13           |
| 10         | 1/0 | HDB4            | 35         | 1   | A0              | 60         | 0   | BSYO             | 85         | 0   | SDBE3           |
| 11         | 1/0 | HDB5            | 36         | 1   | A1              | 61         | 1   | ATNI             | 86         | 0   | SDBO3           |
| 12         | 1/0 | HDB6            | 37         | 1   | A2              | 62         | ο   | ATNO             | 87         | I   | SDBI2           |
| 13         | 1/0 | HDB7            | 38         | I   | A3              | 63         | -1  | RSTI             | 88         | 0   | SDBE2           |
| 14         | 1/0 | HDBP            | 39         | 1   | RST             | 64         | 0   | RSTO             | 89         | 0   | SDBO2           |
| 15         | -   | ∨ <sub>ss</sub> | 40         | -   | V <sub>SS</sub> | 65         | -   | ∨ <sub>5\$</sub> | 90         | -   | ∨ <sub>SS</sub> |
| 16         | 1   | CLK             | 41         | I   | REQI            | 66         | 1   | SDBIP            | 91         | 1   | SDBE1           |
| 17         | 1   | <u>cs</u>       | 42         | 0   | REQO            | 67         | ο   | SDBEP            | 92         | 0   | SDBE1           |
| 18         | 1.  | WT              | 43         | 1   | 1/01            | 68         | 0   | SDBOP            | 93         | ο   | SDBO1           |
| 19         | 1   | WTG             | 44         | 0   | 1/00            | 69         | I I | SDBI7            | 94         | 1   | SDB10           |
| 20         | 1   | RD              | 45         | 1   | C/DI            | 70         | ο   | SDBE7            | 95         | Ó   | SDBE0           |
| 21         | 1   | RDG             | 46         | 0   | C/DO            | 71         | 0   | SDBO7            | 96         | ο   | SDBO0           |
| 22         | 0   | INTR            | 47         | 1   | SELI            | 72         | 1   | SDBI6            | 97         | -   | N/C             |
| 23         | -   | N/C             | 48         | 0   | SELO            | 73         | 0   | SDBE6            | 98         | -   | N/C             |
| 24         | 1/0 | D0              | 49         | I   | MSG1            | 74         | 0   | SDBO6            | 99         | -   | N/C             |
| 25         | 1/0 | D1              | 50         | ο   | MSG0            | 75         | I I | SDBI5            | 100        | -   | N/C             |

. .



## PIN DESCRIPTIONS (Continued)

|                | No.            | Designator     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MB 87030       | MB 87031       |                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 64             | 71             | SDBO7          | Outputs for the SCSI data bus. Most significant bit (MSB) is SDBO7;                                                                                                                                                                                                                                                                                                                                                                                 |
| 65             | 74             | SDBO6          |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27             | 77             |                | least significant bit is SDBO0. SDBOP is an odd parity bit.                                                                                                                                                                                                                                                                                                                                                                                         |
| -              |                | SDBO5          |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 29             | 83             | SDBO4          | If the bus driver is an open collector device, these signals should be                                                                                                                                                                                                                                                                                                                                                                              |
| 70             | 85             | SDBO3          | applied directly to the driver circuit. If the bus driver is a three-state                                                                                                                                                                                                                                                                                                                                                                          |
| 32             | 89             | SDBO2          | device, these signals are used as data and SDBO7-SDBO0 and SDBOP                                                                                                                                                                                                                                                                                                                                                                                    |
| 72             | 93             | SDBO1          | are used as drive-enable signals.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 36             | 96             | SDBO0          |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23             | 68             | SDBOP          |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 37             | 17             | <u>Cs</u>      | Selection enable signal for accessing an internal register in SPC. When CS is active, input/output signals RD, RDG, WT, WTG, DP, A0-A3, and D0-D7 are active.                                                                                                                                                                                                                                                                                       |
| 38             | 16             | CLK            | input clock for controlling internal operation and data transfer speed of SPC.                                                                                                                                                                                                                                                                                                                                                                      |
|                |                |                | Input strobes used for reading out contents of internal register; strobes are effective only when CS is active Low.                                                                                                                                                                                                                                                                                                                                 |
| 39<br>40       | 20<br>21       | RD<br>RDG      | When RDG is active Low, the contents of an internal register selected<br>by address inputs A0-A3 are placed on data bus lines D0-D7 and DP.                                                                                                                                                                                                                                                                                                         |
|                |                |                | For a data transfer cycle in the program transfer mode, the trailing edge of $\overline{\text{RD}}$ is used as a timing signal to indicate the end of data read.                                                                                                                                                                                                                                                                                    |
| 41             | 1              | DRESP          | During a data transfer cycle in the DMA mode, DRESP is a response<br>signal to the data transfer request signal DREQ. The DRESP pin must<br>be refreshed with an applied pulse after each byte of data is trans-<br>ferred.<br>In output operations, the failing edge of DRESP is used for sampling<br>data on HDB0-HDB7 and HDBP bus lines; in input operations, the SPC<br>holds data to be transferred onto HDB0-HDB7 and HDBP until the failing |
| 51             | 33             | D7             | edge of DRESP occurs.<br>Used for writing-or-reading data into-or-from an internal register in                                                                                                                                                                                                                                                                                                                                                      |
| 50<br>49<br>48 | 32<br>31<br>30 | D6<br>D5<br>D4 | SPC; these bus lines are three-state and bidirectional. The Most Signifi-<br>cant Bit (MSB) is D7; the Least Significant Bit (LSB) is D0. DP is an<br>odd parity bit.                                                                                                                                                                                                                                                                               |
| 80             | 27             | D3             |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 79             | 26             | D2             | When the CS and RDG inputs are active Low, contents of the internal                                                                                                                                                                                                                                                                                                                                                                                 |
| 43             | 25             | D1             | register are output to the data bus (read operation). In operations                                                                                                                                                                                                                                                                                                                                                                                 |
| 42             | - 24           | DO             | other than read, these bus lines are kept in a high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                |
| 52             | 34             | DP             | ourer under read, uneer one wree die kept is a sugremmpoud Ke state.                                                                                                                                                                                                                                                                                                                                                                                |
| 44-47          | 35-38          | A0-A3          | Address input signals for selecting an internal register in the SPC. The<br>Most Significant Bit (MSB) is A3; the Least Significant Bit (LSB) is A0.                                                                                                                                                                                                                                                                                                |
|                |                |                | When $\overline{\text{CS}}$ is active Low, read/write is enabled and a internal register is selected by these address inputs via data bus lines D0-D7 and DP.                                                                                                                                                                                                                                                                                       |
| 53             | 22             | INTR           | Requests an interrupt to indicate completion of an SPC internal opera-<br>tion or the occurrence of an error.                                                                                                                                                                                                                                                                                                                                       |
|                |                |                | Interrupt masking is allowed except for an interrupt caused by the RSTI<br>input (reset condition of SCSI). When an interrupt is permitted, the<br>INTR signal remains active until the interrupt is cleared.                                                                                                                                                                                                                                       |
| 56             | 47             | SELI           | Used for receiving SCSI control signals; outputs of the SCSI receiver                                                                                                                                                                                                                                                                                                                                                                               |
| 61             | 59             | BSYI           | can be directly connected. (Waveform distortion or any other distur-                                                                                                                                                                                                                                                                                                                                                                                |
| 58             | 41             | REQ            | bance should not occur in the REQI and ACKI signals which are used as                                                                                                                                                                                                                                                                                                                                                                               |
|                | 1              |                | - · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                             |
| 60             | 55             | ACKI           | timing control signals for sequencing data transfers.)                                                                                                                                                                                                                                                                                                                                                                                              |
| 57             | 49             | MSGI           |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 55             | 45             | C/DI           |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 54             | 43             | 1/01           |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 62             | 61             | ATNI           |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| •              |                |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



May 1988 Edition 1.0

MB87030/31

#### **PIN ASSIGNMENTS**

,

PGA-88C-A01



| Pin<br>No. | 1/0 | Designator | Pin<br>No. | 1/0 | Designator    | Pin<br>No. | 1/0 | Designator | Pin<br>No. | 1/0          | Designator      |
|------------|-----|------------|------------|-----|---------------|------------|-----|------------|------------|--------------|-----------------|
| 1          | 1   | HIM        | 23         | 0   | SDBOP         | 45         | 1   | A1         | 67         | 0            | SDBE5           |
| 2          | 1/0 | HDBO0      | 24         | 0   | SDBE7         | 46         |     | A2         | 68         | 0            | SDBE4           |
| 3          | 1/0 | HDBO1      | 25         |     | SDBI7         | 47         |     | A3         | 69         |              | SDBI4           |
| 4          | 1/0 | HDBO2      | 26         | 0   | SDBE6         | 48         | vo  | D4         | 70         | 0            | SDBO3           |
| 5          | 1/0 | HDBO3      | 27         | 0   | SDBO5         | 49         | 10  | D5         | 71         |              | SDBI2           |
| 6          | vo  | HDBO4      | 28         | ,   | SDBI5         | 50         | 1/0 | D6         | 72         | 0            | SDB01           |
| 7          | 10  | HDBO5      | 29         | 0   | SDBO4         | 51         | 1/0 | D7         | 73         | 0            | SDBEO           |
| 8          | 1/0 | HDBO5      | 23<br>30   | 0   | SDBC4         | 52         | 1/0 | DP         | 74         |              | SDBIO           |
| 9          | 1/0 | HDBO7      | 30         |     | SDBE3         | 52         | 0   | INTR       | 75         |              | RST             |
| 10         | 1/0 | HDBOP      |            | •   |               |            |     |            | 75<br>76   |              | DREQ            |
|            |     |            | 32         | 0   | SDBO2         | 54         |     | 1/01       |            | 0            | WT              |
| 11         | 0   | INIT       | 33         | 0   | SDBE2         | 55         |     | C/DI       | 77         |              |                 |
| 12         | 0   | TARG       | 34         | 1   | SDBI1         | 56         | 1   | SELI       | 78         | 1            | WTG             |
| 13         | 0   | 1/00       | 35         | 0   | SDBE1         | 57         | 1   | MSG1       | 79         | 1/0          | D2              |
| 14         | 0   | C/DO       | 36         | 0   | SDBO0         | 58         | 1   | REQI       | 80         | 1/0          | D3              |
| 15         | 0   | SELO       | 37         | 1   | <del>cs</del> | 59         | 1   | RSTI       | 81         | Power Supply | V <sub>SS</sub> |
| 16         | 0   | MSGO       | 38         | I   | CLK           | 60         | 1   | ACKI       | 82         | Power Supply | VDD             |
| 17         | 0   | REQO       | 39         | 1   | RD            | 61         | 1   | BSYI       | 83         | Power Supply | VDD             |
| 18         | 0   | RSTO       | 40         | 1   | RGD           | 62         | 1   | ANTI       | 84         | Power Supply | V <sub>SS</sub> |
| 19         | 0   | АСКО       | 41         | 1   | DRESP         | 63         | 1   | SDBIP      | 85         | Power Supply | V <sub>SS</sub> |
| 20         | 0   | BSYO       | 42         | 1/0 | D0            | 64         | 0   | SDBO7      | 86         | Power Supply | VDD             |
| 21         | 0   | ATNO       | 43         | 1/0 | D1            | 65         | 0   | SDBO6      | 87         | Power Supply | VDD             |
| 22         | 0   | SDBEP      | 44         | 1   | A0            | 66         | 1   | SDBI6      | 88         | Power Supply | V <sub>SS</sub> |

FUJITSU



MB87030/31

## PIN DESCRIPTIONS

| Pin                                                                              | No.                                                                              | Declanator                                                                                                           |                                                                                                                                                                                                                                                                                                                                                | Function                                                                                                                                                                            | _                                                                                                                                                                     |                                                                                                           |                                                                                                |
|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| MB 87030                                                                         | MB 87031                                                                         | Designator                                                                                                           |                                                                                                                                                                                                                                                                                                                                                | Function                                                                                                                                                                            | •                                                                                                                                                                     |                                                                                                           |                                                                                                |
| 1                                                                                | 5                                                                                | HIN                                                                                                                  | Indicates direction of tran<br>HDBP in the DMA transfer<br>mission must be properly<br>SPC.<br>When HIN is Low, the dat<br>state (Input mode). When<br>output mode.                                                                                                                                                                            | r mode. To b<br>coordinated v<br>a bus lines ar                                                                                                                                     | e executed, e<br>with internal o<br>re placed in th                                                                                                                   | direction of<br>operation of<br>ne high-imp                                                               | trans-<br>the                                                                                  |
|                                                                                  |                                                                                  |                                                                                                                      | Three-state bidirectional of<br>external buffer memory in<br>tion of data transmission                                                                                                                                                                                                                                                         | the DMA mo                                                                                                                                                                          | de. As shown                                                                                                                                                          | n below, th                                                                                               |                                                                                                |
| 2-9<br>10                                                                        | 6-13                                                                             | HDB0-HDB7                                                                                                            | HIN                                                                                                                                                                                                                                                                                                                                            | HDBn                                                                                                                                                                                | Oper                                                                                                                                                                  | ation                                                                                                     |                                                                                                |
| 10                                                                               | 14                                                                               | HDBP                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                | put Mode<br>tput Mode                                                                                                                                                               | Ou<br>Inp                                                                                                                                                             | itput<br>jut                                                                                              |                                                                                                |
|                                                                                  |                                                                                  |                                                                                                                      | These two signals indicate<br>able as control signals for                                                                                                                                                                                                                                                                                      | -                                                                                                                                                                                   |                                                                                                                                                                       |                                                                                                           | so avall-                                                                                      |
|                                                                                  |                                                                                  |                                                                                                                      | Initiator Target                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                     | Status                                                                                                                                                                |                                                                                                           | ]                                                                                              |
| 11<br>12                                                                         | 52<br>51                                                                         | INIT<br>TARG                                                                                                         |                                                                                                                                                                                                                                                                                                                                                | SPC is e<br>operation<br>SPC is e                                                                                                                                                   | not connected<br>executing residues a target<br>executing sele<br>executing sele                                                                                      | election ph<br>t.<br>ection phas                                                                          |                                                                                                |
| 13<br>14<br>15                                                                   | 44<br>46<br>48                                                                   | I/OO<br>C/DO<br>SELO                                                                                                 | Used to output SCS, cont<br>are active High only when                                                                                                                                                                                                                                                                                          | the SPC ser                                                                                                                                                                         | ves as a targ                                                                                                                                                         | et. ACKO                                                                                                  | and                                                                                            |
| 16<br>17<br>18<br>19<br>20<br>21<br>22                                           | 50<br>42<br>64<br>56<br>60<br>62<br>67                                           | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP                                                                | ATNO are active High oni                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                     |                                                                                                                                                                       |                                                                                                           |                                                                                                |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67                         | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76                         | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5                                     |                                                                                                                                                                                                                                                                                                                                                | esponding to<br>for the SCSI<br>BO7-SDBO0 a                                                                                                                                         | respective bil<br>data bus SE<br>and SDBOP, 1                                                                                                                         | t positions)<br>DBE7-SDBE<br>respectivel                                                                  | when a<br>0 and                                                                                |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26                               | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73                               | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6                                              | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD                                                                                                                                                                                                                                                             | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus                                                                                                                           | respective bil<br>data bus SE<br>and SDBOP, 1                                                                                                                         | t positions)<br>DBE7-SDBE<br>respectivel<br>elow.                                                         | when a<br>0 and                                                                                |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33       | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82                   | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4                            | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to t                                                                                                                                                                                                                              | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus                                                                                                                           | respective bit<br>data bus SE<br>and SDBOP, t<br>are shown be                                                                                                         | t positions)<br>DBE7-SDBE<br>respectivel<br>elow.                                                         | when a<br>20 and<br>y. Rela-                                                                   |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to t<br>SCSI Bus Status                                                                                                                                                                                                           | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>SDB<br>ID                                                                                                              | respective bill<br>data bus SI<br>and SDBOP, i<br>are shown be<br>DOn                                                                                                 | t positions)<br>DBE7-SDBE<br>respectivel<br>alow.<br>SD<br>ID                                             | when a<br>E0 and<br>y Rela-<br>IBEn<br>ID                                                      |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33       | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88       | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2          | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to t                                                                                                                                                                                                                              | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus                                                                                                                           | respective bit<br>data bus SE<br>and SDBOP, t<br>are shown be<br>DOn                                                                                                  | t positions)<br>DBE7-SDBE<br>respectivel<br>plow.<br>SD                                                   | when a<br>E0 and<br>y. Rela-                                                                   |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to to<br><u>SCSI Bus Status</u><br>Bus Free<br>Arbitration<br>Selection/Reselection                                                                                                                                               | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>SDB<br>ID<br>L                                                                                                         | respective bit<br>data bus SE<br>and SDBOP, t<br>are shown be<br>DOn<br>ID                                                                                            | t positions)<br>DBE7-SDBE<br>respectivel<br>elow.<br>SD<br>ID<br>L                                        | when a<br>20 and<br>y. Rela-<br>IBEn<br>ID<br>L                                                |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to t<br>SCSI Bus Status<br>Bus Free<br>Arbitration                                                                                                                                                                                | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>SDB<br>ID<br>L<br>H                                                                                                    | respective bit<br>data bus SE<br>and SDBOP, a<br>are shown be<br>DOn<br>ID<br>L<br>L                                                                                  | t positions)<br>DBE7-SDBE<br>respectivel<br>blow.<br>SD<br>ID<br>L<br>H                                   | when a<br>20 and<br>y. Rela-<br><u>BEn</u><br>ID<br>L<br>L                                     |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to th<br><u>SCSI Bus Status</u><br>Bus Free<br>Arbitration<br>Selection/Reselection<br>Information Transfer                                                                                                                       | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>SDB<br>ID<br>L<br>H<br>D                                                                                               | respective bit<br>data bus SE<br>and SDBOP, a<br>are shown be<br>DOn<br>ID<br>L<br>L<br>L<br>D                                                                        | t positions)<br>DBE7-SDBE<br>respectivel<br>blow.<br>SD<br>ID<br>L<br>H<br>H<br>H                         | when a<br>E0 and<br>y. Rela-<br>BEn<br>ID<br>L<br>L<br>H                                       |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to to<br><u>SCSI Bus Status</u><br>Bus Free<br>Arbitration<br>Selection/Reselection<br>Information Transfer<br>SPC → SCSI                                                                                                         | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>ID<br>L<br>L<br>H<br>D<br>L<br>L<br>tions corresp<br>bit position.                                                     | respective bit<br>data bus. SE<br>and SDBOP, t<br>are shown be<br>DOn<br>ID<br>L<br>L<br>D<br>L<br>L<br>D<br>L                                                        | t positions)<br>DBE7-SDBE<br>respectivel<br>alow.<br>ID<br>L<br>H<br>H<br>H<br>L                          | when a<br>E0 and<br>y. Rela-<br>BEn<br>ID<br>L<br>L<br>H<br>H<br>L                             |
| 16<br>17<br>18<br>19<br>20<br>21<br>22<br>24<br>26<br>67<br>68<br>30<br>33<br>35 | 50<br>42<br>64<br>56<br>60<br>62<br>67<br>70<br>73<br>76<br>82<br>85<br>88<br>92 | MSGO<br>REQO<br>RSTO<br>ACKO<br>BSYO<br>ATNO<br>SDBEP<br>SDBE7<br>SDBE6<br>SDBE5<br>SDBE4<br>SDBE3<br>SDBE2<br>SDBE1 | Drive enable signals (corr<br>three-state buffer is used<br>SDBEP correspond to SD<br>tionships with respect to the<br>SCSI Bus Status<br>Bus Free<br>Arbitration<br>Selection/Reselection<br>Information Transfer<br>SPC $\rightarrow$ SCSI<br>SCSI $\leftarrow$ SPC<br>Notes:<br>1. <u>"ID"</u> indicates bit posi<br>ID indicates the other | esponding to<br>for the SCSI<br>BO7-SDBO0<br>the SCSI bus<br>ID<br>L<br>L<br>H<br>D<br>L<br>L<br>tions corresp<br>bit position.<br>of valid infor<br>bus. Most sig<br>BI0. SDBIP is | respective bit<br>data bus. SE<br>and SDBOP, i<br>are shown be<br>DOn<br>ID<br>L<br>L<br>D<br>D<br>L<br>onding to the<br>mation.<br>nificant bit (M<br>s an odd parit | t positions)<br>DBE7-SDBE<br>respective<br>slow<br>ID<br>L<br>H<br>H<br>H<br>L<br>SCSI bus<br>ISB) is SDI | when a<br>E0 and<br>y. Rela-<br>BEn<br>ID<br>L<br>L<br>H<br>H<br>L<br>device ID;<br>BI7; least |



May 1988 Edition 1.0

| Pin               | No.                                 |                  |                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|-------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MB \$7030         | MB 87031                            | Designator       | Function                                                                                                                                                                                                                                                                                                                                               |
| 76                | 2                                   | DREQ             | When executing a data transfer cycle in the DMA mode, DREQ is used<br>to indicate a request for data transfer between the SPC and external<br>buffer memory. In the DMA mode, routing of data is as shown below.                                                                                                                                       |
|                   |                                     |                  | Output Operations:<br>From External Buffer Memory to HDB0-HDB7/HDBBP to SPC Inter-<br>nal Data Buffer Register (eight Bytes) to SDB00-SDB07/SDB0P to<br>SCSI.                                                                                                                                                                                          |
|                   |                                     |                  | Input Operations:<br>From SCSI to SDBI9-SDBI7/SDBIP to SPC Internal Data Buffer Reg-<br>later (eight bytes) to HDB0-HDB7/DHDBP to External Buffer Mem-<br>ory.                                                                                                                                                                                         |
|                   |                                     |                  | In an output operation, DREQ becomes active to request a data trans-<br>fer from the external buffer memory when the SPC internal data buffer<br>register has free space available. In an input operation, DREQ becomes<br>active to request a data transfer to the external buffer memory when<br>the SPC internal buffer memory contains valid data. |
| 77                | 18                                  | wт               | Input strobe used for writing data into an SPC internal register; this sig-<br>nal is asserted only when CS is active Low. On the trailing edge of WT,<br>data placed on data bus lines D0-D7/DP is loaded into the internal regis-<br>ter selected by address inputs A0-A3, except when all address lines are<br>High (A0-A3 = H).                    |
|                   |                                     | -                | For a data transfer cycle in the program transfer mode, the trailing edge of WT is used as a timing signal to indicate a data-ready state.                                                                                                                                                                                                             |
| 78                | 19                                  | WTG              | When WTG is active Low, data appearing on data bus lines D0-D7/DP is<br>output to HDB0-HDB7/HDBP if the following input conditions are satis-<br>fied:<br>CS = L<br>A0-A3 = H<br>HIN = H                                                                                                                                                               |
| 81, 84,<br>85, 88 | 4, 15, 29,<br>40, 54, 65,<br>79, 90 | V <sub>\$3</sub> | Power supply ground.                                                                                                                                                                                                                                                                                                                                   |
| 82,83<br>86,87    | 3, 28,<br>53, 78                    | V <sub>DO</sub>  | +5V Power supply.                                                                                                                                                                                                                                                                                                                                      |
| -                 | 23, 57, 58<br>80, 97, 98<br>99, 100 | -                | Not used.                                                                                                                                                                                                                                                                                                                                              |

## PIN DESCRIPTIONS (Continued)

#### ADDRESSING OF INTERNAL REGISTERS

.

Both the MB87030 and the MB87031 contain sixteen (16) byte-wide registers that are externally accessible. These registers are used to control internal operations of the SPC and also to indicate processing/result status. A unique address, identified by address bits A3-A0, is assigned to each of the sixteen registers. These addresses are defined in Table 1. (Note. The phase sense (PSNS) and SPC diagnostic (SDGC) registers have the same hexadecimal address; however, depending upon whether a read or write command is executed, the registers provide two separate functions.)

| Register                 | Mnemonic | Operation  | Chip Select (CS) |    | ddres<br>A2 |   | s<br>A0  |
|--------------------------|----------|------------|------------------|----|-------------|---|----------|
|                          |          | R          |                  |    |             |   |          |
| Bus Device ID            | BDID     | w          | O                | 0  | 0           | 0 | 0        |
| 000 0                    |          | R          |                  |    |             |   | 1        |
| SPC Control              | SCTL     | w          | 0                | 0  | 0           | 0 | 1        |
| Command                  | 50110    | R          | 0                |    | 0           | 1 | 0        |
| Commang                  | SCMD     | w          | U                | 0  | U           |   | U        |
| Transfer Mode            | TMOD     | R          | 0                | 0  | 0           | 1 | 1        |
|                          | IMOD     | w          | 0                |    | 0           |   |          |
| Interrupt Sense          | INTS     | 8          | 0                | 0  | 1           | 0 | 0        |
| Reset Interrupt          | 1141.5   | w          |                  |    |             |   |          |
| Phase Sense              | PSNS     | R          | o                | 0  | 1           | 0 | 1        |
| · SPC Diagnostic Control | SDGC     | w          |                  |    |             |   |          |
| SPC Status               | SSTS     | R          |                  |    |             |   |          |
|                          |          | w          | 0                | 0  | 1           | 1 | 0        |
| SPC Error Status         | SERR     | R          |                  |    |             |   | Ι.       |
|                          |          | w          | 0                | 0  | 1           | 1 | 1        |
| Phase Control            | 007      | <b>R</b> - |                  |    | 0           |   | 0        |
| Phase Control            | PCTL     | w          | 0                | 1  | U           | 0 |          |
| Modified Byte Counter    | MBC      | R          |                  | Ι. | 0           | 0 | 1        |
| ·                        |          | w          | 0                | 1  | U           | U | <u> </u> |
| Data Pasistas            | 0050     | R          | 0                | ,  | 0           | 1 | 0        |
| Data Register            | DREG     | w          |                  |    |             |   |          |
| Tomosona Declator        | TEMP     | R          | 0                | 1  | 0           | 1 | 1        |
| Temporary Register       | IEMP     | w          |                  |    |             |   | '        |
| Transfer Counter Lit-h   | тсн      | R          | 0                | 1  | 1           | 0 | 0        |
| Transfer Counter High    |          | w          |                  |    | Ľ           | Ľ | Ľ        |
| Transfer Counter Middle  | тсм      | R          | 0                | 1  | 1           | 0 | 1        |
|                          |          | w          |                  |    | Ľ           | Ľ | Ļ.       |
| Transfer Counter Low     | TCL      | R          | 0                | 1  | 1           | 1 | 0        |
| Hansler Counter Low      |          | w          |                  |    | Ŀ           |   | Ľ        |
| External Buffer          | EXBF     | R          | 0                | 1  | 1           | 1 | 1        |
|                          | EADF     | w          |                  |    |             |   |          |

#### Table 1. Internal Register Addressing

FUJITSU

May 1988 Edition 1.0 MB87030/31

1

#### **BIT ASSIGNMENTS**

Table 2 lists the bit assignments for the seventeen internal registers defined in Table 1. During read/write access of an internal register, the following rules are invoked:

- Internal registers include only those registers identified in Table 1.
- A write command to a read-only register is ignored.
- . For write operations, all bit positions with a "---" (blank) designator can be written as a "0" or as a "1".
- All bit positions with an assigned "0" are always read as a zero (0).

| HEX<br>Address | Register<br>and<br>Mnemonic  | R/W<br>Oper-<br>ation | 7<br>(MSB)            | 6                 | 5       | 4                    | 3                          | 2               | 1                    | 0<br>(LSB)              | Parity |
|----------------|------------------------------|-----------------------|-----------------------|-------------------|---------|----------------------|----------------------------|-----------------|----------------------|-------------------------|--------|
|                | Bus<br>Device ID             | R                     | #7                    | #6                |         | us Device            | ID<br>  #3                 | #2              | #1                   | #0                      | o      |
| 0              | (BDID                        | w                     |                       |                   | _       |                      |                            | SCSI But<br>ID4 | Device II<br>ID2     | D<br>ID1                | -      |
| 1              | SPC<br>Control               | R                     | Reset<br>& Dis-       | Cont-<br>rol      | Diag    | ARBIT                | Parity                     | Select          | Resel-<br>ect        | INT                     | Р      |
|                | (SCTL)                       | w                     | able                  | Reset             | Mode    | Enable               | Enable                     | Enable          | Enable               | Enable                  |        |
| 2              | Command<br>(SCMD)            | R                     | Comma                 | ind Code          |         | RST                  | inter-<br>cept             | Transfer<br>PRG | Modifier             | Term                    | Р      |
|                |                              | w                     |                       |                   |         | Out                  | Xfer                       | Xfer            | 0                    | Mode                    |        |
| 3              | Transfer<br>Mode<br>(TMOD)   | R<br>W                | Sync.<br>Xfer         | Max. Ti<br>Offset | ransfer |                      | Min. Tra<br>Period         | nster           | o                    | 0                       | P      |
|                |                              |                       |                       | 4                 | 2       | 1                    | 2                          | 1               |                      |                         |        |
| 4              | Interrupt<br>Sense<br>(INTS) | R                     | Selec-<br>ted         | Resel-<br>ected   | Disco-  | Com-<br>mand<br>Com- | Ser-<br>vice Re-<br>quired | Time<br>Out     | SPC<br>Hard<br>Error | Reset<br>Condi-<br>tion | P      |
| 4              | (                            |                       |                       |                   |         | piete                |                            |                 |                      |                         |        |
|                |                              | W                     |                       |                   |         | Reset In             | terrupt                    |                 |                      | ·····                   | -      |
|                | Phase<br>Sense               | R                     | REQ                   | ACK               | ATN     | SEL                  | BSY                        | MSG             | C/D                  | 1/0                     | Р      |
| 5              | (PSNS)                       | W                     |                       |                   |         | _                    |                            | <u>.</u>        |                      |                         | -      |
|                | SPC Diag<br>Control          | R                     |                       |                   |         | _                    |                            |                 |                      |                         | -      |
|                | (SDGC)                       | w                     | Diag.<br>REQ          | Diag.<br>ACK      | _       |                      | Diag.<br>BSY               | Diag.<br>MSG    | Dlag.<br>C/D         | Diag.<br>I/O            | -      |
| 6              | SPC<br>Status                | R                     | Connec                |                   | SPC     | XFER<br>in Pro-      | SCSI                       | TC=0            | DREG S               | 1                       | Р      |
|                | (SSTS)                       |                       | INIT                  | TARG              | BSY     | gress                | RST                        |                 | Full                 | Empty                   |        |
|                |                              | W                     |                       |                   |         | -                    |                            |                 |                      |                         | -      |
| 7              | SPC<br>Error<br>Status       | R                     | Data Er<br>SCSI       | TOF<br>SPC        | 0       | 0<br>                | TC<br>Parity<br>Error      | Phase<br>Error  | Short<br>Period      | Offset                  | Р      |
|                | (SERR)                       | w                     |                       | L                 | L       |                      |                            |                 |                      |                         | 1 -    |
| 8              | Phase<br>Control             | R                     | Bus<br>Free<br>Inter- |                   |         | 0                    |                            | Transfer        | 1                    | 1                       |        |
|                | (PCTL)                       | w                     | rupt<br>Enable        |                   |         |                      |                            | MSG<br>Out      | C/D<br>Out           | I/D<br>Out              | P      |
| 9              | Modified<br>Byte             | R                     |                       |                   | 0       |                      | Blt3                       | ME<br>Bit2      | IC<br>  Bit1         | BitO                    | Р      |
|                | Counter<br>(MBC)             | w                     |                       |                   |         |                      | <u></u>                    |                 |                      | -                       |        |

Table 2. Bit Assignments For Internal Registers

.

.



| HEX<br>Address | Register<br>and<br>Mnemonic | R/W<br>Oper-<br>ation | 7<br>(MSB) | 6  | 5             | 4               | 3               | 2             | 1      | 0<br>(LSB) | Parity |
|----------------|-----------------------------|-----------------------|------------|----|---------------|-----------------|-----------------|---------------|--------|------------|--------|
|                | Data                        | R                     |            |    | internal      | Data Reg        | ister (8 By     | rte FIFO)     |        |            | P      |
| A              | Register<br>(DREG)          | W                     | Bit7       | 6  | 5             | 4               | 3               | 2             | 1      | 10         | F      |
| 8              | Temporary<br>Register       | R                     | Bit7       | 6  | Tempor<br>5   | ary Data        | (Input: Fr      | om SCSI)      | 1      | 10         | Р      |
| _              | (TEMP)                      | W                     | Bit7       | 6  | Tempor<br>5   | ary Data<br>4   | (Output:<br>3   | to SCSI)<br>2 | 1      | 0          | Ρ      |
|                | Transfer                    | R                     |            |    |               |                 |                 |               | I      |            |        |
| с              | Counter<br>High<br>(TCH)    | w                     | Bit23      | 22 | Transfe<br>21 | r Counter<br>20 | High (MSI<br>19 | 3)<br>18      | 17<br> | 16<br>     | Р      |
| D              | Transfer                    | R                     |            |    | <b>T</b> (    |                 |                 | Dented        |        |            | Р      |
| U              | Counter<br>Mid.<br>(TCM)    | w                     | Bit15      | 14 | 13            | 12              | High (2nd<br>11 | 10            | 9      | 8<br>1     | F      |
| E              | Transfer<br>Counter         | R                     |            |    | Tanaat        |                 |                 |               |        | 1          | P      |
| 5              | Low<br>(TCL)                | <b>.</b>              | Bit7       | 6  | 5             | 4               | High (LSE<br>3  | 2             | 1      | 0          |        |
| _              | External                    | Ŕ                     |            |    | ÷ .           |                 |                 |               |        |            |        |
| F              | Buffer<br>(EXBF)            | w                     | Bh7        | 6  | Externa<br>5  | l Buffer<br>4   | 3               | 2             | 1      | 0          | P      |

#### Table 2. Bit Assignments For Internal Registers (Continued)



May 1988 Edition 1.0 MB87030/31

6

DC CHARACTERISTICS

(Recommended operating conditions unless otherwise specified)

|                       |                 | <b>-</b>                                          |                 | Values |                 |      |
|-----------------------|-----------------|---------------------------------------------------|-----------------|--------|-----------------|------|
| Parameter             | Designator      | Condition                                         | Min             | Тур    | Max             | Unit |
| Power Supply Current  | loos            | Steady State <sup>1</sup>                         |                 |        | 100             | µ۸   |
| Power Dissipation     | PD              |                                                   |                 | 300    |                 | m₩   |
| Output High Voltage   | V <sub>OH</sub> | l <sub>oH</sub> = -0.4mA                          | 4.2             |        | V <sub>DD</sub> | v    |
| Output Low Voltage    | VOL             | l <sub>OL</sub> = 3.2mA                           | V <sub>SS</sub> |        | 0.4             | V    |
| Input High Voltage    | VH              |                                                   | 2.2             |        |                 | ۷    |
| Input Low Voltage     | V <sub>L</sub>  |                                                   |                 |        | 0.8             | V    |
| Input Leakage Current | lu              | $V_1 = 0 - V_{DD}$                                | -10             |        | 10              | μA   |
| Input Leakage Current | luz             | Tri-State<br>V <sub>i</sub> = 0 - V <sub>DD</sub> | -10             |        | 10              | µА   |

Note: 1. V<sub>M</sub> = V<sub>DD</sub> = V<sub>L</sub> = V<sub>SS</sub>



### AC CHARACTERISTICS

D7-D0, DP

.

(Recommended operating conditions unless otherwise noted)

#### MPU INTERFACE

| Parameter               | Designator |     |     |     |            |
|-------------------------|------------|-----|-----|-----|------------|
|                         | Designator | Min | Тур | Max | Unit       |
| Clock Cycle             | tci_F      | 125 |     | 200 | ns         |
| Clock High              | t CHCL     | 50  |     |     | n <b>s</b> |
| Clock Pulse Width (Low) | t CLCH     | 40  |     |     | ns         |





| Parameter       | Designator |             | Values |     | Unit      |
|-----------------|------------|-------------|--------|-----|-----------|
| raiametei       | Designator | Min         | Тур    | Max |           |
| Address Setup   | taws       | 40          |        |     | ns        |
| Address Hold    | tawn       | 5           |        |     | ns        |
| CS Setup        | tcws       | 25          |        |     | ns        |
| CS Hold         | tcwh       | 10          |        |     | ns        |
| Data Bus Setup  | tows       | 25          |        |     | na        |
| Data Bus Hold   | town       | 20          |        |     | <b>ns</b> |
| WT Pulse Width  | twr        | 50          |        |     | ns        |
| A3-A0           |            |             | 1      |     |           |
| <del>wi</del> — | - tcws-    | ⊷¦≁ '<br>¬∕ | wr     |     |           |

|                                                               | Basisses   |     |     |     |            |
|---------------------------------------------------------------|------------|-----|-----|-----|------------|
| Parameter                                                     | Designator | Min | Тур | Max | Unit       |
| Address Setup                                                 | tAWSE      | 40  |     |     | hs         |
| Address Hold                                                  | tAWHE      | 5   |     |     | ns         |
| CS Setup                                                      | towse      | 25  |     |     | ns         |
| ČŠ Hold                                                       | towne      | 10  |     |     | <b>TIS</b> |
| WTG Low to DMA Data Bus<br>HDB7-HDB0, HDBP                    | twund      | _   | 40  | 60  | ns         |
| WTG High to DMA Data Bus<br>HDB7-HDB0, HDBP                   | twied      | 10  | 30  |     | ns         |
| MPU Data Bus (D7-D0, DP)<br>DMA Data Bus<br>(HDB7-HDB0, HDBP) | t DHD      | 5   | 25  | 50  | <b>7</b> 8 |
| HIN High to DMA Data Bus<br>(HD87-HD80, HD8P)                 | tHINZ      | 10  |     | 40  | ns         |



| Parameter                       | Declaration       |     |     |     |           |
|---------------------------------|-------------------|-----|-----|-----|-----------|
| Falaineter                      | Designator        | Min | Тур | Max | Unit      |
| Address Setup                   | TARS              | 40  |     |     | <b>ns</b> |
| Address Hold                    | tARH              | 5   |     |     | ns        |
| CS Setup (RD)                   | tcrs              | 10  |     |     | ns        |
| CS Hold                         | t CRH             | 5   |     |     | ns        |
| RD Pulse Width                  | t <sub>RD</sub>   | 50  |     |     | <b>ns</b> |
| RDG Low to Data Output          | t <sub>RLNZ</sub> | 10  |     | 45  | ns        |
| RDG High to D7-D0, DP<br>High Z | <sup>î</sup> RHHZ |     |     | 40  | ns        |
| RD Low to Data Establish        | t <sub>RLD</sub>  |     |     | 85  | <b>ns</b> |
| RD High to Data Hold            | t <sub>RHD</sub>  | 10  |     |     | <b>ns</b> |
| CS Setup (RDG)                  | tcrigs            | 5   |     |     | ns        |



### MB87030/31

## AC CHARACTERISTICS (Continued)

| Parameter                                                        | Designation       |     |     |     |      |
|------------------------------------------------------------------|-------------------|-----|-----|-----|------|
| F & : & : + + Ø ( Ø (                                            | Designator        | Min | Тур | Max | Unit |
| Address Setup                                                    | TARSE             | 40  |     |     | ns   |
| Address Hold                                                     | tARHE             | 5   |     |     |      |
| CS Setup                                                         | tCRSE             | 10  |     |     | ns   |
| CS Hold                                                          | tCRHE             | 10  |     |     | ns   |
| RDG Low to Data Output                                           | t <sub>RLNZ</sub> | 10  |     | 45  | ns   |
| RDG High to D7-D0, DP<br>High Z                                  | t <sub>RHHZ</sub> |     |     | 40  | ns   |
| DMA Data Bus (HDB7-HDB0,<br>HDBP) to MPU Data Bus<br>(D7-D0, DP) | <sup>t</sup> HDD  | 5   |     | 50  | ns   |
| ilN Low to HD87-HD80,<br>iDBP High                               | tHINZ             |     |     | 40  |      |



Note: 1. These two signals may be applied simultaneously.

6

| Parameter                                | Designation       |                        | Values |                        |             |  |  |
|------------------------------------------|-------------------|------------------------|--------|------------------------|-------------|--|--|
|                                          | Designator        | Min                    | Тур    | Max                    | Unit        |  |  |
| CLK High to INTR High                    | t <sub>CHIR</sub> | 5                      |        | 55                     | ns          |  |  |
| WT High to INTR Low<br>(Interrupt Reset) | twnin             | t <sub>CLF</sub> 1+ 10 |        | 2t <sub>CLF</sub> + 80 | . <b>DS</b> |  |  |
| Interrupt Reset Cycle Time*              | twacy             | 4t <sub>CLF</sub>      |        |                        | ns          |  |  |

- Notes: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.
  - 2. Cycle time for WT when interrupt is continuous.



#### AC CHARACTERISTICS (Continued) DMA Interface

| Parameter               | Designator        |                         | Unit |     |      |
|-------------------------|-------------------|-------------------------|------|-----|------|
| rarameter               | Designator        | Min                     | Тур  | Max | Unit |
| DREQ High to DRESP High | t DRRP            | t <sub>CLF</sub> (Note) |      |     | ns   |
| DRESP High to DREQ Low  | t APDR            | 10                      | 45   | 80  | ns   |
| DREQ Low to DREQ High   | t DLDH            | 0                       |      |     | ns   |
| DRESP Pulse Width       | tRPSW             | 50                      |      |     | ne . |
| DRESP Cycle Time (1)    | 1 APCY            | 2t <sub>CLF</sub>       |      |     | ns   |
| DRESP Cycle Time (2)    | t <sub>RLRH</sub> | 3t <sub>CLF</sub>       |      |     | ns   |

#### Note:

1. Refer to "Clock Signal" timing for definition of tour.



| Parameter                                  | Values            |     |     |                         | Unit |
|--------------------------------------------|-------------------|-----|-----|-------------------------|------|
|                                            | Designator        | Min | Тур | Max                     | Unit |
| HIN High to HD87-HD80,<br>HDBP Data Output | <sup>t</sup> hinz | 10  |     | 40                      |      |
| DREQ High to Data Establish                | t DRDV            |     | 15  | 60                      | ns   |
| DRESP Low to Data Change                   | t <sub>RPOV</sub> | 15  | 55  | 90                      | ກຣ   |
| REQI or ACKI High to<br>DREQ High1         | TRADR             |     |     | 3t <sub>CL</sub> 2 + 70 | ns   |

Notes:

When SPC receives REQ (initiator) or ACK (Target) with an empty FIFO during DMA (hardware ) transfer.
 Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.



| Parameter                                      | Destander         |     |     | / <b>1</b> _ 1A                      |           |
|------------------------------------------------|-------------------|-----|-----|--------------------------------------|-----------|
|                                                | Designator -      | Min | Тур | Max                                  | Unit      |
| HIN Low to HDB7-HDB0,<br>HDBP (High Z)         | timiz             |     |     | 40                                   | ns        |
| Data Bus Setup                                 | t <sub>HOBS</sub> | 20  |     |                                      | ns        |
| Data Bus Hold                                  | tновн             | 20  |     |                                      | ns        |
| DREQ Low to DRESP (Note)                       | t <sub>DLRP</sub> |     |     | 5t <sub>CLF</sub> 1                  | ns.       |
| DRESP Low to REQO or<br>ACKO High <sup>2</sup> | <sup>t</sup> DRRA |     |     | 4t <sub>CLF</sub> <sup>2</sup> + 115 | <b>ns</b> |

Notes:

1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.

 The indicated timing is invoked if SPC receives DRESP when the internal data buffer is empty during a DMA (hardware) transfer. The timing parameter is waived for ACKO when the last byte is transferred with the SPC serving as an initiator.



May 1988 Edition 1.0 MB87030/31

## AC CHARACTERISTICS (Continued) SCSI Interface (Selection Phase)

| Parameter                                           | Dealerates        | Values                            |                         |                                    |            |  |
|-----------------------------------------------------|-------------------|-----------------------------------|-------------------------|------------------------------------|------------|--|
| Parameter                                           | Designator        | Min <sup>4,2</sup>                | Тур                     | Max                                |            |  |
| Bus Free Time                                       | t <sub>BFR</sub>  | 4t <sub>CLF</sub> + 50            |                         |                                    | ns         |  |
| BSYI Low to BSYO High<br>(Start of arbitration)     | t <sub>BFBO</sub> | (6 + n) x<br>t <sub>CLF</sub> + 5 |                         | (7 + n) x<br>t <sub>CLF</sub> + 65 | ns         |  |
| BSYO High to ID Bit High                            | t <sub>BHID</sub> | 0                                 | 20                      | 55                                 | ns         |  |
| BSYO High to Prioritize                             | tARB              | 32t <sub>CLF</sub> - 40           |                         |                                    | ns         |  |
| Data Bus Valid (High Priority<br>Bit) to Prioritize | t ADV             | 70                                |                         |                                    | ns         |  |
| Data Bus Valid (Low Priority<br>Bit) to Prioritize  |                   | 5                                 |                         |                                    | ns         |  |
| Bus Usage Permission Granted<br>to SELO High        | tawso             | 0                                 |                         | 45                                 | ns         |  |
| SELO High to Data Bus (ID) Send                     | tsoiD             | 11t <sub>CLF</sub> - 30           | 11t <sub>CLF</sub> +15  | 11t <sub>CLF</sub> +45             | ns         |  |
| SELO High to INIT High                              | tsorr             | 11t <sub>CLF</sub> - 30           | 11t <sub>CLE</sub> - 10 | 11t <sub>CLF</sub> + 40            | ns         |  |
| INIT High to ATNO High                              | titat             | 5                                 | 5                       | 25                                 | ns         |  |
| Data Bus (ID) Send to BSYO Low                      | t IDBL            | 2t <sub>CLF</sub> - 50            | 2t <sub>CLF</sub> - 10  | 2t <sub>CUF</sub> +25              | ns         |  |
| BSYO Low to BSYI Low                                | t <sub>BOBI</sub> | 0                                 |                         | tcur                               | ns         |  |
| BSYI High to SELO Low                               | tBISO             | 2t <sub>CLF</sub> + 5             |                         |                                    | fis        |  |
| BSYI High to Data Bus (ID) Hold                     | t <sub>BIDH</sub> | 2t <sub>CLF</sub> + 5             |                         |                                    | ns         |  |
| SELO Low to INTR High                               | tSCIR             |                                   | 0                       | 35                                 | П <b>З</b> |  |
| SELI High to BSYO, ID Bit Low                       | t SBCR            |                                   |                         | 3t <sub>CLF</sub> + 115            | ns         |  |
| Prioritize to BSYO, ID Bit Low                      | t PBCR            |                                   |                         | 125                                | ns         |  |

Notes:

1. Refer to "Clock Signal" timing for definition of  $t_{CLF}$ . 2. n = TCL register set value

.

FUJITSU

### AC CHARACTERISTICS (Continued)



6

#### **AC CHARACTERISTICS (Continued)**

| Parameter                           | Designator        | Values                            |                         |                                    |            |
|-------------------------------------|-------------------|-----------------------------------|-------------------------|------------------------------------|------------|
|                                     | Congristor        | Min <sup>1,2</sup>                | Тур                     | Max                                | Unit       |
| Bus Free to Data Bus (ID) .<br>Send | t <sub>FRID</sub> | (6 + n) x<br>t <sub>CLF</sub> + 5 |                         | (7 + n) x<br>t <sub>CLF</sub> + 85 | ne         |
| ID Send to SELO High                | tipso             | 11t <sub>CLF</sub> - 50           | 11t <sub>CLF</sub> - 15 | 11t <sub>CLF</sub> + 25            | ns         |
| ID Send to INIT High                | tion T            | 11t CLF - 50                      | 11tcur                  | 11t <sub>CLF</sub> + 40            | ne         |
| INIT High to ATNO High              | t <sub>ITAT</sub> | -5                                | 5                       | 25                                 | ns         |
| BSYI High to SELO Low               | t <sub>BISO</sub> | 21CLF+ 5                          |                         |                                    | ns         |
| BSYI High to Data Bus (ID) Hold     | t BIDH            | 21 <sub>CLF</sub> + 5             |                         |                                    | <b>T18</b> |
| SELO Low to INTR High               | tscia             |                                   | 0                       | 35                                 | ns         |

÷

i

Notes:

1. Refer to "Clock Signal" timing for definition of  $t_{CLF}$ . 2. n = TCL register set value



| FARGET with Arbitration                   |                    |                         |                        |                        |      |
|-------------------------------------------|--------------------|-------------------------|------------------------|------------------------|------|
| Parameter                                 | Designator         |                         | Unit                   |                        |      |
|                                           | Designator         | Min                     | Тур                    | Max                    |      |
| SELI High to BSYI Low                     | <sup>t</sup> siBi  | 0                       |                        |                        | ns   |
| Data Bus (ID) Valid to BSYI Low           | tioai              | 0                       |                        |                        | ns   |
| I/OI Low to BSYI Low                      | tiiBi              | 0                       |                        |                        | ns   |
| BSYI Low to BSYO High<br>(Response time)  | t SLBO             | 4t <sub>CLF</sub> 1 + 5 |                        | 5t <sub>CLF</sub> + 60 | ns   |
| BSYO High to Data Bus (ID) Hold           | tBOID              | 20                      |                        |                        | , ns |
| BSYO High to SELI Low                     | teosi              | 0                       |                        |                        | ne   |
| ATNI High to SELI Low                     | tATSI              | 0                       |                        |                        | ns   |
| SELI Low to TARG High                     | <sup>t</sup> SLTG  | 3t <sub>CLF</sub> + 5   |                        | 4t <sub>CLF</sub> + 60 | ns   |
| TARG High to Phase Signal Output          | t <sub>тб</sub> рн | -5                      | 10                     | 30                     | ns   |
| I/OO High to Data Bus Enable <sup>2</sup> | t IODE             | 4t <sub>CLF</sub> - 30  | 4t <sub>CLF</sub> + 20 | 4t <sub>CLF</sub> + 70 | ns   |
| SELI Low to INTR High                     | ts⊔R               |                         |                        | 3t <sub>CLF</sub> + 65 | ns   |

Notes:

Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>
 In case of bit 0 (I/O out) of PCTL register is set in advance.

•

.







| Parameter                                     | Designator        | Values                 |                        |                        |           |
|-----------------------------------------------|-------------------|------------------------|------------------------|------------------------|-----------|
|                                               | Cesignator        | Min                    | Тур                    | Max                    | Unit      |
| Data Bus (ID) Vaild to SELI High              | tiosi             | 0                      |                        |                        | <b>ns</b> |
| I/OI Low to SELI High                         | t <sub>iisi</sub> | 0                      |                        |                        | ns        |
| SELI High to BSYO High<br>(Response time)     | t SLBO            | 2t <sub>CU</sub> =+ 5  |                        | 3t <sub>CLF</sub> + 65 | ns        |
| BSYO High to Data Bus (ID) Hold               | taoio             | 20                     |                        |                        | ns        |
| BSYO High to SELI Low                         | taosi             | 0                      |                        |                        | ns        |
| ATNI High to SELI Low                         | tATSI             | 0                      |                        |                        | THE I     |
| SELI Low to TARG High                         | tSLTG             | 3t <sub>CLF</sub> + 5  |                        | 4t <sub>CLF</sub> + 60 | ns        |
| TARG High to Phase Signal Output <sup>a</sup> | t TGPH            | -5                     | 10                     | 30                     | ns        |
| I/OO High to Data Bus Enable                  | t IODE            | 4t <sub>CLF</sub> - 30 | 4t <sub>CLF</sub> + 20 | 4t <sub>CLF</sub> + 70 | ns        |
| SELI Low to INTR High                         | tsur              |                        |                        | 3t <sub>CLF</sub> + 65 | ns        |

Notes: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub> 2. In case bit 0 (I/O) of PCTL register is set in advance.



6



## AC CHARACTERISTICS (Continued) SCSI Interface (Reselection Phase)

| Parameter                                           | Deslands          | Values                            |                         |                                    |            |  |
|-----------------------------------------------------|-------------------|-----------------------------------|-------------------------|------------------------------------|------------|--|
|                                                     | Designator        | Min <sup>1,2</sup>                | Тур                     | Max                                | Unit       |  |
| Bus Free Time                                       | t <sub>BFR</sub>  | 4t <sub>CLF</sub> + 50            |                         |                                    | ns         |  |
| BSYI Low to BSYO High<br>(Start of arbitration)     | <sup>t</sup> BFBO | (6 + n) x<br>t <sub>CLF</sub> + 5 |                         | (7 + n) x<br>t <sub>CLF</sub> + 65 | ns         |  |
| BSYO High to ID Bit High                            | <sup>t</sup> вню  | 0                                 | 20                      | 55                                 | ns         |  |
| BSYO High to Prioritize                             | t <sub>ARB</sub>  | 32t <sub>CLF</sub> - 40           |                         |                                    | ne         |  |
| Data Bus Valid (High Priority<br>Bit) to Prioritize | tADT              | 70                                |                         |                                    | Ne         |  |
| Data Bus Valid (Low Priority<br>Bit) to Prioritize  |                   | 5                                 |                         |                                    | ns         |  |
| Bus Usage Permission Grant<br>to SELO High          | tawso             | 0                                 |                         | 45                                 | ns         |  |
| SELO High to Data Bus (ID) Send                     | tsoio             | 11t <sub>CLF</sub> - 30           | 11t <sub>CLF</sub> + 15 | 11t <sub>CLF</sub> + 45            | ns         |  |
| SELO High to TARG High                              | tsorg             | 11t <sub>CLF</sub> - 30           | 11t <sub>CLF</sub> + 5  | 11t <sub>CLF</sub> + 30            | ns         |  |
| TARG High to Phase Signal Send                      | t <sub>TGPH</sub> | -5                                | 10                      | 30                                 | ns         |  |
| I/OO High to BSYO Low                               | t IOBL            | 2t <sub>CLF</sub> - 40            | 2t <sub>CLF</sub> - 10  | 2t <sub>CLF</sub> + 20             | <b>N</b> 8 |  |
| Data Bus (ID) Send to BSYO Low                      | t <sub>IOBL</sub> | 2t <sub>CLF</sub> - 50            | 2t <sub>CLF</sub> - 10  | 2t <sub>CLF</sub> + 25             | ns         |  |
| BSYO Low to BSYI Low                                | t <sub>BOBI</sub> | 0                                 |                         | tcLF                               | ns         |  |
| BSYI High to SELO Low                               | taiso             | 3t <sub>CIJ</sub> + 5             |                         |                                    |            |  |
| BSYI High to Data Bus (ID) Hold                     | t <sub>BIOH</sub> | 3t <sub>CLF</sub> + 5             |                         |                                    | ns         |  |
| SELQ Low to INTR High                               | tscira            |                                   | 0                       | 35                                 | ns         |  |
| SELI High to BSYO, ID Bit Low                       | t SBCR            |                                   |                         | 3t <sub>CLF</sub> + 115            | ns         |  |
| Prioritize to BSYO, ID Bit Low                      | t <sub>PBCR</sub> |                                   |                         | 125                                | ns         |  |
| BSYI High to BSYO High                              | t BIBO            | 2t <sub>CLF</sub> + 5             |                         |                                    | ns         |  |

Notes: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>. 2. n = TCL register set value





| Parameter                                                | Designator        | Values                          |     |                        |      |
|----------------------------------------------------------|-------------------|---------------------------------|-----|------------------------|------|
|                                                          |                   | Min                             | Тур | Max                    | Unit |
| SELI High to BSYI Low                                    | t SiBi            | 0                               |     |                        | ns   |
| Data Bus (ID) Valid to BSYI Low                          | t IDBI            | 0                               |     |                        | ns   |
| I/OI Low to BSYI Low                                     | t <sub>iiBi</sub> | 0                               |     | •                      | ns   |
| BSYI Low to BSYO High<br>(Response time)                 | t SLBO            | 4t <sub>CLF</sub> + 5<br>(Note) |     | 5t cur + 60            | ns   |
| BSYO High to Data Bus (ID) Hold                          | teoro             | 20                              |     |                        | ns   |
| BSYO High to SELI Low                                    | teosi             | 0                               |     |                        | ns   |
| SELI Low to BSYO Low                                     | t sieo            | 2t <sub>CLF</sub> + 5           |     | 3t <sub>CLF</sub> + 60 | ns   |
| SELI Low to I/OI Hold                                    | t <sub>SMH</sub>  | 4t <sub>CLF</sub> + 20          |     |                        | ne   |
| SELI Low to INTR High                                    | tsur              |                                 |     | 3t <sub>CUF</sub> + 65 | ns   |
| SELI Low to INIT High                                    | tsur              | 3t <sub>CLF</sub> + 5           |     | 4t <sub>CLF</sub> + 65 | ns   |
| INIT High to Data Bus Enable<br>(With I/OI at low level) | tITDE             | 10                              |     |                        | ns   |



# AC CHARACTERISTICS (Continued) SCSI Interface (Transfer Phase)

| Parameter                    | Designator        | Values                 |     |                         |      |
|------------------------------|-------------------|------------------------|-----|-------------------------|------|
|                              |                   | Min                    | Тур | Max                     | Unli |
| 1/00 High to Data Bus Enable | tIODE             | 3t <sub>CLF</sub>      |     | 4t <sub>CLF</sub> + 100 | ns   |
| Data Bus Valid to REQO High  | TOVRG             | 2t <sub>CLF</sub> - 80 |     |                         | ns   |
| ACKI High to Data Bus Hold   | t AKDV            | 15                     | 55  |                         | ns   |
| REQO High to ACKI High       | t <sub>RHAH</sub> | 20                     |     |                         | ns   |
| ACK! High to REQO Low        | tAHRL             | 10                     | 30  | 55                      | ns   |
| REQC Low to ACKI Low         | t <sub>RLAL</sub> | 0                      |     |                         | ns   |
| ACKL Low to REQO High        | <sup>1</sup> ALRH | 10                     | 35  |                         | ns   |
| ACKI High to REQC High       | tAHRH             | 21 <sub>C1 = +</sub> 5 |     |                         | 75   |

Note: 1. Refer to "Clock Signal" timing for definition of tour



6



| Parameter                    | Designator        |                      |     |       |        |
|------------------------------|-------------------|----------------------|-----|-------|--------|
|                              |                   | Min                  | Тур | Max   | - Unit |
| 1/00 Low to Data Bus Disable | tioop             |                      | 20  | 55    | ns     |
| Data Bus Valid to ACKI High  | t <sub>DVAK</sub> | 10                   |     |       | ne     |
| REQD Low to Data Bus Hold    | t <sub>RLDV</sub> | 25                   |     |       | ne     |
| REQO High to ACKI High       | t <sub>RHAH</sub> | 20                   |     |       | - ns   |
| ACKI High to REQO Low        | t AHRL            | 10                   | 30  | 55    | ns     |
| REQO Low to ACK! Low         | TRLAL             | 0                    |     |       | ne     |
| ACK! Low to REQO High        | <sup>t</sup> ALRH | 10                   | 35  | ····· | ne     |
| ACKI High to REQO High       | t AHRH            | 2t <sub>CLF</sub> +5 |     |       | ns     |



6

#### AC CHARACTERISTICS (Continued)

| Parameter                   | Designator -      |                                  | Unit |     |    |
|-----------------------------|-------------------|----------------------------------|------|-----|----|
|                             |                   | Min                              | Тур  | Max |    |
| /OI Low to Data Bus Enable  | t IDE             | 10                               | 50   | 90  | ns |
| Phase Specify to REQI High  | t <sub>PHRG</sub> | 100                              |      |     | ne |
| ACKO Low to Phase Change    | TALPH             | 10                               |      |     | ns |
| REQI High to ATNO Low'      | t <sub>RATL</sub> | 2t <sub>CLF<sup>2</sup>+ 5</sub> |      |     | ns |
| ATNO Low to ACKO High!      | tatia             | t <sub>CLF</sub> - 20            |      |     | ns |
| Data Bus Valid to ACKO Hign | tovak             | 2t <sub>CLF</sub> - 80           |      |     | פת |
| REQI Low to Data Bus Hold   | 1 RLDV            | 20                               | 60   |     | ns |
| REQI High to ACKO High      | t <sub>RHAH</sub> | 20                               | 45   | 75  | ns |
| ACKC High to REGI Low       | TAHRL             | C                                |      |     | ns |
| REGI Low to ACKO Low        | RLAL              | 10                               | 45   | 75  | ns |
| ACKO Low to REQI High       | TALRH             | 10                               |      |     | ns |
| REGI Low to ACKO High       | TRUNA             | 2t <sub>CLF</sub> + 5            |      |     | ns |

Notes:

1. With these timing parameters, the ATNO signal is reset only when the last byte is sent at the MESSAGE OUT phase.

2. Refer to "Clock Signal" timing for definition of tours

3. Except for the last byte.





Asynchronous Transfer Input (INITIATOR)

| Parameter                     | Designator        | Values                 |                       |     |        |
|-------------------------------|-------------------|------------------------|-----------------------|-----|--------|
|                               |                   | Min                    | Тур                   | Max | - Unit |
| I/OI High to Data Bus Disable | tinDD             |                        | 45                    | 75  | ាន     |
| Phase Specify to REQI High    | t PHRQ            | 100                    |                       |     | ិាន    |
| ACKO Low to Phase Change      | t ALPH            | 10                     |                       |     | ns     |
| Data Bus Valid to REQI High   | t DVRQ            | 10                     |                       |     | 718    |
| ACKO High to Data Bus Hold    | t AKDV            | 15                     |                       |     | - me   |
| REQI High to ACKO High        | t <sub>RHAH</sub> | 15                     | 40                    | 70  | ns     |
| ACKO High to REQI Low         | tAHRL             | 0                      |                       |     | me     |
| REQI Low to ACKO Low          | TRLAL             | 10                     | 45                    | 75  | ns     |
| ACKO Low to REQI High         | t <sub>ALRH</sub> | 10                     |                       |     | ກຮ     |
| REQI Low to ACKO High         | t <sub>RLNA</sub> | t <sub>CLF</sub> 1 + 5 |                       |     | ns     |
| ATNO High to ACKO Low?        | TATAL             | t <sub>CLF</sub> - 20  | t <sub>CLF</sub> + 15 |     | ns     |

Notes:

Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.
 With these timing parameters, the ATNO signal is sent only when parity checking is enabled and a parity error is detected in the input data.



| Parameter                    | Designator        | Values                |                   |                         |      |
|------------------------------|-------------------|-----------------------|-------------------|-------------------------|------|
|                              |                   | Min <sup>1,2</sup>    | Тур               | Max                     | Unit |
| I/OO High to Data Bus Enable | tiode             | 3t <sub>CLF</sub>     |                   | 4t <sub>CLF</sub> + 100 | ns   |
| Data Bus Valid to REQO High  | tovra             | tar                   |                   |                         | ns   |
| REQO Assertion Period        | troap             | t <sub>CLF</sub> - 10 | tcur              |                         | ns   |
| REQO Nonassertion Period     | tRNAP             | nt <sub>CLF</sub> -10 | nt <sub>CUF</sub> |                         | ns   |
| REQO Low to Data Bus Hold    | t RLDH            | 0                     | 5                 |                         | ns   |
| REQO High to ACKI High       | trhah             | 0                     |                   |                         | ns   |
| ACKI cycle time (1)          | t <sub>AKF1</sub> | tar .                 |                   |                         | ns   |
| ACKI cycle time (2)          | t <sub>AKF2</sub> | 3t CLF                | · ·               |                         | na   |
| ACKI Assertion Period        | takap             | 50                    |                   |                         | ns   |
| ACKI Nonassertion Period     | TANAP             | 50                    |                   |                         | ns   |

Notes:

1. Refer to "Clock Signal" timing for definition of  $t_{CLF}$ . 2. n = TMOD register set value







| Parameter                   | Designator        |                        |                   |     |        |
|-----------------------------|-------------------|------------------------|-------------------|-----|--------|
|                             |                   | Min <sup>1,2</sup>     | Тур               | Max | - Unit |
| CO Low to Data Bus Disable  | tiodd             |                        | 20                | 55  | ns     |
| EQO Assertion Period        | tROAP             | t <sub>CLF</sub> - 10  | tcLF              |     | ns     |
| REQO Nonassertion Period    | tRNAP             | nt <sub>CLF</sub> - 10 | nt <sub>CLF</sub> |     | ns     |
| REQO High to ACKI High      | t <sub>RHAH</sub> | 0                      |                   |     | ns     |
| ACKI Assertion Period       | takap             | 50                     |                   |     | ns     |
| ACKI Nonassertion Period    | tanap             | 50                     |                   |     | ns     |
| ACKI Cycle time (1)         | t <sub>AKF1</sub> | tCLF                   |                   |     | ns     |
| ACKI Cycle time (2)         | <sup>t</sup> AKF2 | 3t <sub>CLF</sub>      |                   | -   | ns     |
| Data Bus Valid to ACKI High | tovak             | 10                     |                   |     | ns     |
| ACK! High to Data Bus Hold  | takDH             | 40                     |                   |     | ns     |

#### Notes:

Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.
 n = TMOD register set value



## AC CHARACTERISTICS (Continued)

| Parameter                   | Designator        |                        |                    |     |        |
|-----------------------------|-------------------|------------------------|--------------------|-----|--------|
|                             |                   | Min <sup>1,2</sup>     | Тур                | Max | - Unit |
| I/OI Low to Data Bus Enable | t IDE             | 10                     | 50                 | 90  | ns     |
| Phase Specify to REQI High  | t <sub>PHRQ</sub> | 100                    |                    |     | ms     |
| ACKO Low to Phase Change    | t ALPH            | 10                     |                    |     | ns     |
| REQI Assertion Period       | TROAP             | 50                     |                    |     | na     |
| REQI Nonassertion Period    | tRNAP             | 50                     |                    |     | កទ     |
| REQI Cycle time (1)         | tROF1             | tclf                   |                    |     | na     |
| REQI Cycle time (2)         | t <sub>RGF2</sub> | 3t <sub>CLF</sub>      |                    |     | ns     |
| REQI High to ACKO High      | trhah             | 3t <sub>CLF</sub>      |                    |     | ns     |
| ACKO Assertion Period       | takap             | t <sub>CLF</sub> - 10  | t <sub>CLF</sub> - |     | ns     |
| ACKO Nonassertion Period    | tanap             | nt <sub>CLF</sub> - 10 | nt <sub>CLF</sub>  |     | ns     |
| Data Bus Valid to ACKO High | t DTAK            | t <sub>CLF</sub> .     |                    |     | ns     |
| ACKO Low to Data Bus Hold   | t ALDH            | 0                      | 5                  |     | ns     |

Notes:

Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.
 n = TMOD register set value



| Parameter                           | Designator        | Values                 |                        |     | 1      |
|-------------------------------------|-------------------|------------------------|------------------------|-----|--------|
|                                     |                   | Min <sup>1,2</sup>     | Тур                    | Max | - Unli |
| OI High to Data Bus Disable         | tipp              |                        | 45                     | 75  | ne     |
| hase Specify to REQI High           | t <sub>PHRQ</sub> | 100                    |                        |     | ns     |
| CKO Low to Phase Change             | t ALPH            | 10                     |                        |     | ns     |
| Data Bus Valid to RÉQI High         | t DVRQ            | 10                     |                        |     | ns     |
| EQI High to Data Bus Hold           | t RODH            | 40                     |                        |     | ns     |
| EQI Assertion Period                | TROAP             | 50                     |                        |     | ne     |
| EQI Nonassertion Period             | t <sub>RNAP</sub> | 50                     |                        |     | ns     |
| REQI Cycle time (1)                 | t <sub>RQF1</sub> | t <sub>CLF</sub>       |                        |     | ns     |
| REQI Cycle time (2)                 | t ROFZ            | 3t <sub>CLF</sub>      |                        |     | ne     |
| REQI High to ACKO High              | t <sub>RHAH</sub> | 6t <sub>CLF</sub> + 5  |                        |     | ns     |
| ACKO Assertion Period               | takap             | t <sub>ćUF</sub> - 10  | tcur                   |     | ns     |
| CKO Nonassertion Period             | TANAP             | mt <sub>CLF</sub> - 10 | nt <sub>CLF</sub>      |     | ns     |
| REQI High to ATNO High <sup>a</sup> | t BATH            | 3t <sub>CLF</sub> +5   | 4t <sub>CLF</sub> - 30 |     | ns     |

Notes:

Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.
 n = TMOD register set value
 With these timing parameters, the ATNO signal is sent only when parity checking is enabled and a parity error is detected in the input data.







| Transfer Phase Change (TARG                    | IET)              |     |     |     |      |
|------------------------------------------------|-------------------|-----|-----|-----|------|
| Parameter                                      |                   | T   |     |     |      |
|                                                | Designator -      | Min | Тур | Max | Unit |
| WT High to MSGO, C/DO, 1/OO<br>(PCTL register) | t <sub>PHCH</sub> | 10  | 40  | 65  | ns   |



| Parameter                                            | Designator        | Values                |     |                        |      |
|------------------------------------------------------|-------------------|-----------------------|-----|------------------------|------|
|                                                      |                   | Min ²                 | Тур | Max                    | Unit |
| WT High to Data Bus Valid<br>(TEMP register output)  | twidv             |                       | 40  | 60                     | ns   |
| WT High to REQO, ACKO High<br>(Set ACK/REQ command)  | tSTRA             | 2t <sub>CLF</sub> + 5 |     | 3t <sub>CLF</sub> + 80 | ns   |
| WT Nigh to REQO, ACKO Low<br>(Reset ACK/REQ command) | <sup>t</sup> rtra | 2t <sub>CLF</sub> + 5 |     | 3t <sub>CLF</sub> + 80 | ns   |



| Parameter                                                              | Basisses     | Values                          |     |                        |      |
|------------------------------------------------------------------------|--------------|---------------------------------|-----|------------------------|------|
|                                                                        | Designator - | Min                             | Тур | Max                    | Unit |
| WT High to ATNO High/Low<br>(Set ATN command and Reset<br>ATN command) | tatno        | 2t <sub>CLF</sub> + 5<br>(Note) |     | 3t <sub>CLF</sub> + 90 | ns   |

Note: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.





# AC CHARACTERISTICS (Continued) SCSI Interface (Bus Free)

| Parameter             | Designed         | Values |     |                                  | Unit |
|-----------------------|------------------|--------|-----|----------------------------------|------|
| L SI SUDIAL           | Designator       | Min    | Тур | Max                              |      |
| BSYI Low to INIT Low  | <sup>t</sup> выт |        |     | 5t <sub>CLF</sub> + 70<br>(Note) | ns   |
| INIT Low to Bue Clear | titce            |        | 20  | 50                               |      |
| BSYI Low to INTR High | teur             |        |     | 6t <sub>CLF</sub> + 75           | ns   |



| Parameter                              |                   | Values |     |                                  | Inte |
|----------------------------------------|-------------------|--------|-----|----------------------------------|------|
|                                        | Designator        | Min    | Тур | Max                              | Unit |
| WT High to BSYO Low<br>(SCMD register) | twals             |        |     | 3t <sub>CLF</sub> + 80<br>(Note) | ns   |
| WT High to TARG Low<br>(SCMD register) | twra              |        |     | 3t <sub>CLF</sub> + 80           | ns.  |
| TARG Low to Bus Clear                  | t <sub>TGCR</sub> |        | 20  | 50                               | na - |

Note: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.





| Parameter                                      | Designator | Values |     |                                  |      |
|------------------------------------------------|------------|--------|-----|----------------------------------|------|
|                                                |            | Min    | Тур | Max                              | Unit |
| WT High to SELO Low<br>(INTS register)         | twsL       |        |     | 3t <sub>CLF</sub> + 80<br>(Note) | ns   |
| WT High to Data Bus Disable<br>(INTS register) |            | ·      |     | 3t <sub>CLF</sub> + 105          | na   |
| WT High to TARG or INIT Low<br>(INTS register) | twill      |        |     | 3t <sub>CLF</sub> + 80           | na . |
| TARG Low to 1/00 Low                           | tTGIO      |        | 10  | 30                               | ns   |
| WT High to INTR Low<br>(INTS register)         | twinL      |        |     | 3t <sub>CLF</sub> + 105          | na   |



## AC CHARACTERISTICS (Continued) SCSI Interface (Reset Condition))

| Parameter                                |            |     | Values |     |      |
|------------------------------------------|------------|-----|--------|-----|------|
|                                          | Designator | Min | Тур    | Max | Unit |
| WT High (bit 4 of SCMD register) to RSTO | testo      | 5   | 35     | 55  | ns   |
| Reset Delay                              | tasop      |     | 70     | 115 | ns   |



| Parameter             | Destantes  |                   | Values |                         |      |
|-----------------------|------------|-------------------|--------|-------------------------|------|
| F & . # ! ! ! # L # [ | Designator | Min 1             | Тур    | Max                     | Unit |
| RSTI Pulse Width      | tsRiw      | 3t <sub>CLF</sub> |        |                         | ns   |
| Reset Delay           | tRSID      |                   |        | 4t <sub>CLF</sub> + 115 | ns   |

Note: 1. Refer to "Clock Signal" timing for definition of t<sub>CLF</sub>.



## CAPACITANCE (T = $25 °C_A V = V = 0 V$ , $f_i = 1 MHz$ )

| Parameter              | Declaration      |     | Values |     | Unit |
|------------------------|------------------|-----|--------|-----|------|
| raiameter              | Designator       | Min | Тур    | Max | Onit |
| input Pin Capacitance  | C <sub>N</sub>   |     |        | 9   | pF   |
| Output Pin Capacitance | Cout             |     |        | 9   | pF   |
| I/O Pin Capacitance    | C <sub>1/O</sub> |     |        | 11  | pF   |



May 1988 Edition 1.0 MB87030/31

6

### **GRID ARRAY**

88-Lead Ceramic Pin Grid Array





May 1988 Edition 1.0 MB87030/31



### **GRID ARRAY (Continued)**

100-Lead Plastic Flat Package





## Am7990

Local Area Network Controller for Ethernet (LANCE)



# •

05698A



|                                                          | PIN DESC                                                                                                                                                                                                                                                                                                                                          | CRIPTION                                                                                                                                                     |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DAL <sub>00</sub> -<br>DAL <sub>15</sub>                 | <b>Deta/Address Lines (Input/Output 3-State)</b><br>The time multiplexed Address/Data bus. During<br>the address portion of a memory transfer,<br>$DAL_{00} - DAL_{15}$ contains the lower 16 bits of the<br>memory address. The upper 8 bits of address<br>are contained in $A_{16} - A_{23}$ .<br>During the data portion of a memory transfer, | Byte selection ma<br>line and DAL <sub>00</sub> lin<br>portion of the b<br>BYTE only as a B<br>a Bus Slave sele<br>BM <sub>1</sub> ).<br>Byte selection is d |
|                                                          | DAL <sub>00</sub> – DAL <sub>15</sub> contains the read or write data,<br>depending on the type of transfer.                                                                                                                                                                                                                                      | ing table.<br>BYTE                                                                                                                                           |
|                                                          | The LANCE drives these lines as a Bus Master<br>and as a Bus Slave.                                                                                                                                                                                                                                                                               | LOW                                                                                                                                                          |
| A <sub>16</sub> - A <sub>23</sub>                        | High Order Address Bus (Output 3-State)<br>The additional address bits necessary to extend<br>the DAL lines to access a 24-bit address. These<br>lines are driven as a Bus Master only.                                                                                                                                                           | HIGH<br>HIGH<br>BUSAKO is a bus<br>the chip is not req<br>HLDA, BUSAKO                                                                                       |
| READ                                                     | (Input/Output 3-State)<br>Indicates the type of operation to be performed<br>in the current bus cycle. This signal is an output<br>when the LANCE is a Bus Master.                                                                                                                                                                                | LANCE is reques<br>HLDA, BUSAKO<br>Byte Swapping                                                                                                             |
|                                                          | High – Data is taken off the DAL by the chip.<br>Low – Data is placed on the DAL by the chip.<br>The signal is an input when the LANCE is a Bus                                                                                                                                                                                                   | In an effort to be compatibl<br>microprocessors available to the<br>programmed to swap the position<br>bytes on data involved in trans                       |
|                                                          | Slave.<br>High – Data is placed on the DAL by the chip<br>Low – Data is taken off the DAL by the chip.                                                                                                                                                                                                                                            | Byte swapping is done when B<br>byte of the word in this case wi<br>the least significant byte on D                                                          |
| BM <sub>0</sub> /<br>Byte<br>BM <sub>1</sub> /<br>BUSAKO | (Output 3-state)<br>Pins 15 and 16 are programmable through bit<br>(00) of CSR <sub>3</sub> .<br>BM <sub>0</sub> , BM <sub>1</sub>                                                                                                                                                                                                                | When BYTE = H (indicating a by<br>on which part of the 16-bit of<br>appear.<br>Whenever byte swap is actin<br>swapped is data traveling to a                 |
|                                                          | If CSR <sub>3</sub> (00) BCON = 0<br>PIN 15 = $\overline{BM_0}$ (Output 3-state)<br>PIN 16 = $\overline{BM_1}$ (Output 3-state)                                                                                                                                                                                                                   | Signal Line and BC                                                                                                                                           |
|                                                          | BM <sub>0</sub> , BM <sub>1</sub> (Byte Mask). This indicates the<br>byte(s) on the DAL are to be read or written<br>during this bus transaction. The LANCE drives<br>these lines only as a Bus Master. It ignores the                                                                                                                            | BYTE = L and Wor<br>DAL <sub>00</sub> = L                                                                                                                    |
|                                                          | Byte Mask lines when it is a Bus Slave and assumes word transfers.                                                                                                                                                                                                                                                                                | BYTE = L and Illeg                                                                                                                                           |
|                                                          | Byte selection using Byte Mask is done as described by the following table.                                                                                                                                                                                                                                                                       | BYTE = H and<br>DAL <sub>00</sub> = H Upper                                                                                                                  |
|                                                          | BM1 BM0                                                                                                                                                                                                                                                                                                                                           | BYTE = H and<br>DAL <sub>00</sub> = L Lower                                                                                                                  |
|                                                          | LOW LOW Whole Word<br>LOW HIGH Upper Byte<br>HIGH LOW Lower Byte<br>HIGH HIGH None                                                                                                                                                                                                                                                                | CS Chip Select (Inp<br>Indicates, when as<br>slave device of th<br>valid throughout                                                                          |
|                                                          | BYTE, BUSAKO<br>If CSR <sub>3</sub> (00) BCON = 1<br>PIN 15 = BYTE (Output 3-state)<br>PIN 16 = BUSAKO (Output)                                                                                                                                                                                                                                   | cycle. CS must no<br>Low.                                                                                                                                    |

•

ay also be done using the BYTE ine, latched during the address ous cycle. The LANCE drives Bus Master and ignores it when ection is done (similar to BMo,

done as outlined in the follow-

## DAL00

| LOW  | LOW  | Whole Word        |
|------|------|-------------------|
| LOW  | HIGH | Illegal Condition |
| HIGH | LOW  | Lower Byte        |
| HIGH | HIGH | Upper Byte        |

request daisy chain output. If questing the bus and it receives will be driven Low. If the ting the bus when it receives will remain High.

ble with the variety of 16-bit the designer, the LANCE may be on of the upper and lower order nsfers with the internal FIFO.

ISWP = 1. The most significant ill appear on DAL lines 7-0 and DAL lines 15-8.

yte transfer) the table indicates data bus the actual data will

vated, the only data that is and from the FIFO.

|                                       | Mode Bits                |                          |  |  |
|---------------------------------------|--------------------------|--------------------------|--|--|
| Signal Line                           | BSWP = 0<br>and BCON = 1 | BSWP = 1<br>and BCON = 1 |  |  |
| BYTE = L and<br>DAL <sub>00</sub> = L | Word                     | Word                     |  |  |
| BYTE = L and<br>DAL <sub>00</sub> = H | lliegal                  | Illegal                  |  |  |
| BYTE = H and<br>DAL <sub>00</sub> = H | Upper Byte               | Lower Byte               |  |  |
| BYTE = H and<br>DAL <sub>00</sub> = L | Lower Byte               | Upper Byte               |  |  |

out)

sserted, that the LANCE is the he data transfer. CS must be the data portion of the bus ot be asserted when HLDA is

.

| ADR            | Register Address Port Select (Input).<br>When LANCE is slave, ADR indicates which of<br>the two register ports is selected. ADR LOW<br>selects register data port; ADR HIGH selects<br>register address port. ADR must be valid<br>throughout the data portion of the bus cycle and<br>is only used by the LANCE when CS is Low. | HLDA  | Bus Hold Acknowledge (Input)<br>A response to HOLD. When HLDA is Low in<br>response to the chip's assertion of HOLD, the<br>chip is the Bus Master. HLDA deasserts upon<br>the deassertion of HOLD.<br>Interrupt (Output Open Drain)<br>An attention signal that indicates, when active,                                                         |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ALE/AS         | Address Latch Enable (Output 3-State)<br>Used to demultiplex the DAL lines and define the<br>address portion of the bus cycle. This I/O pin is<br>programmable through bit (01) of CSR <sub>3</sub> .<br>As ALE (CSR <sub>3</sub> (01), ACON = 0), the signal                                                                    |       | that one or more of the following CSR <sub>0</sub> status<br>flags is set: BABL, MERR, MISS, RINT, TINT or<br>IDON. INTR is enabled by bit 06 of CSR <sub>0</sub><br>(INEA = 1). INTR remains asserted until the<br>source of Interrupt is removed.                                                                                              |
|                | transitions from a HIGH to a LOW during the<br>address portion of the transfer and remains Low<br>during the data portion. ALE can be used by a                                                                                                                                                                                  | RX    | <b>Receive (Input)</b><br>Receive Input Bit Stream.                                                                                                                                                                                                                                                                                              |
|                | Slave device to control a latch on the bus<br>address lines. When ALE is High, the latch is<br>open, and when ALE goes Low, the latch is<br>closed.                                                                                                                                                                              | тх    | Transmit (Output)<br>Transmit Output Bit Stream.                                                                                                                                                                                                                                                                                                 |
|                | As $\overline{AS}$ (CSR <sub>3</sub> (01), ACON = 1), the signal pulses<br>Low during the address portion of the bus<br>transaction. The Low-to-High transition of $\overline{AS}$<br>can be used by a Slave device to strobe the                                                                                                | TENA  | Transmit Enable (Output)<br>Transmit Output Bit Stream enable. A level<br>asserted with the Transmit Output Bit Stream,<br>TX, to enable the external transmit logic.                                                                                                                                                                            |
|                | address into a register.<br>The LANCE drives the ALE/AS line only as a<br>Bus Master.                                                                                                                                                                                                                                            | RCLK  | Receive Clock (Input)<br>A 10MHz square wave synchronized to the<br>Receive data and only active while receiving an<br>Input Bit Stream.                                                                                                                                                                                                         |
| DAS            | Data Strobe (Input/Output 3-State)<br>Defines the data portion of the bus transaction.<br>DAS is high during the address portion of a bus<br>transaction and low during the data portion. The                                                                                                                                    | CLSN  | Collision (Input)<br>A logical input that indicates that a collision is<br>occurring on the channel.                                                                                                                                                                                                                                             |
|                | Low-to-High transition can be used by a Slave<br>device to strobe bus data into a register. DAS is<br>driven only as a Bus Master.                                                                                                                                                                                               | RENA  | Receive Enable (Input)<br>A logical input that indicates the presence of<br>carrier on the channel.                                                                                                                                                                                                                                              |
| DALO           | Data/Address Line Out (Output 3-State)<br>An external bus transceiver control line. DALO is<br>asserted when the LANCE drives the DAL lines                                                                                                                                                                                      | TCLK  | Transmit Clock (Input)<br>10MHz clock                                                                                                                                                                                                                                                                                                            |
|                | DALO will be Low only during the address<br>portion if the transfer is a READ. It will be Low<br>for the entire transfer if the transfer is a WRITE.<br>DALO is driven only when LANCE is a Bus<br>Master.                                                                                                                       | READY | (Input/Output Open Drain)<br>When the LANCE is a Bus Master, READY is an<br>asynchronous acknowledgement from the bus<br>memory that it will accept data in a WRITE cycle<br>or that it has put data on the DAL lines in a<br>READ cycle.                                                                                                        |
| DALI           | Data/Address Line In (Output 3-State)<br>An external bus transceiver control line. DALI is<br>asserted when the LANCE reads from the DAL<br>lines. It will be Low during the data portion of a<br>READ transfer and remain High for the entire<br>transfer if it is a WRITE. DALI is driven only when<br>LANCE is a Bus Master.  |       | As a Bus Slave, the LANCE asserts READY<br>when it has put data on the DAL lines during a<br>READ cycle or is about to take data off the DAL<br>lines during a write cycle. READY is a response<br>to DAS and will return High after DAS has gone<br>High. READY is an input when the LANCE is a<br>Bus Master and an output when the LANCE is a |
| HOLD/<br>BUSRQ | Bus Hold Request (Output Open Drain)<br>Asserted by the LANCE when it requires access<br>to memory. HOLD is held Low for the entire<br>ensuing bus transaction. The function of this pin<br>is programmed through bit (00) of CSR3. Bit (00)<br>of CSR3 is cleared when RESET is asserted                                        | RESET | Bus Slave.<br>(Input)<br>Bus Request Signal. Causes the LANCE to<br>cease operation, clear its internal logic, and<br>enter an Idle state with the stop bit of CSR <sub>0</sub> set.                                                                                                                                                             |
|                | When $CSR_3$ (00) BCON = 0                                                                                                                                                                                                                                                                                                       | Vcc   | Power supply pin +5 volts ±5%.                                                                                                                                                                                                                                                                                                                   |
|                | PIN 17 = HOLD (Output Open Drain)                                                                                                                                                                                                                                                                                                | Vec   | Ground. Pins 1 and 24 should be connected                                                                                                                                                                                                                                                                                                        |
|                | When $CSR_3$ (00) $BCON = 1$                                                                                                                                                                                                                                                                                                     | VSS   | together externally, as close to the chip as                                                                                                                                                                                                                                                                                                     |
|                | PIN 17 = BUSRQ (Output Open Drain)                                                                                                                                                                                                                                                                                               |       | possible.                                                                                                                                                                                                                                                                                                                                        |
|                | BUSRO will be asserted only if pin 17 is High<br>prior to assertion.                                                                                                                                                                                                                                                             |       |                                                                                                                                                                                                                                                                                                                                                  |

#### **PRODUCT OVERVIEW**

The parallel interface of the Local Area Network Controller for Ethernet (LANCE) has been designed to be "friendly" or easy to interface to a variety of popular 16-bit microprocessors. These microprocessors include the following: Z8000, 8086, 68000 and LSI-11. The LANCE has a 24-bit wide linear address space when it is in the Bus Master Mode, allowing it to DMA directly into the entire address space of the above microprocessors. A programmable mode of operation allows byte addressing in one of two ways: a Byte/Word control signal compatible with the 8086 and 28000 or an Upper Data Strobe and Lower Data Strobe signal compatible with microprocessors such as the 68000. A programmable polarity on the Address Strobe signal eliminates the need for external logic. The LANCE interfaces with both multiplexed and demultiplexed data busses and features control signals for address/ data bus transceivers.



During initialization, the CPU loads the starting address of the initialization block into two internal control registers. The LANCE has four internal control and status registers (CSR<sub>0</sub>, 1, 2, 3) which are used for various functions, such as the loading of the initialization block address, different programming modes and status conditions. The host processor communicates with the LANCE during the initialization phase for demand transmission and periodically to read the status bits following interrupts. All other transfers to and from the memory are handled as DMA under microword control.

Interrupts to the microprocessor are generated by the LANCE upon: 1) completion of its initialization routine, 2) the reception of a packet, 3) the transmission of a packet, 4) transmitter timeout error, 5) a missed packet and 6) memory error.

The cause of the interrupt is ascertained by reading  $CSR_0$ . Bit (06) of  $CSR_0$ , (INEA), enables or disables interrupts to the microprocessor. In systems where polling is used in place of interrupts, bit (07) of  $CSR_0$ , (INTR), indicates an interrupt condition.

The basic operation of the LANCE consists of two distinct modes: transmit and receive. In the transmit mode, the LANCE chip directly accesses data (in a transmit buffer) in memory. It prefaces the data with a preamble, sync pattern, and calculates and appends a 32-bit CRC. This packet is then ready for transmission to the Am7991A SIA. On transmission, the first byte of data loads into the 48-byte FIFO. The LANCE then begins to transmit preamble while simultaneously loading the rest of the packet into FIFO for transmission.

In the receive mode, packets are sent via the SIA to the LANCE. The packets are loaded into the 48-byte FIFO for preparation of automatic downloading into buffer memory. A CRC is calculated and compared with the CRC appended to the data packet. If the calculated CRC checksum doesn't agree with the packet CRC, an error bit is set.

#### ADDRESSING

Packets can be received using 3 different destination addressing schemes: physical, logical and promiscuous.

The first type is a full comparison of the 48-bit destination address in the packet with the node address that was programmed into the LANCE during an initialization cycle. There are two types of logical address. One is group type mask where the 48-bit address in the packet is put through a hash filter to map the 48-bit physical addresses into 1 of 64 logical groups. If any of these 64 groups have been preselected as the logical address, then the 48-bit address is stored in main memory. At this time, a look up is performed comparing the 48-bit incoming address with the pre-stored 48-bit logical address. This mode can be useful if sending packets to all of a particular type of device simultaneously (i.e., send a packet to all file servers or all printer servers). Additional details on logical addressing can be found in the INITIALIZATION section under "Logical Address Filter." The second logical address is a broadcast address where all nodes on the network receive the packet. The last receive mode of operation is the so-called "promiscuous mode" in which a node will accept all packets on the coax regardless of their destination address.

#### COLLISION DETECTION AND IMPLEMENTATION

The Ethernet CSMA/CD network access algorithm is implemented completely within the LANCE. In addition to listening for a clear coax before transmitting, Ethernet handles collisions in a predetermined way. Should two transmitters attempt to seize the coax at the same time, they will collide and the data on the coax will be garbled. The transmitting nodes listen while they transmit, detect the collision, then continue to transmit for a predetermined length of time to "jam" the network and ensure that all nodes have recognized the collision. The transmitting nodes then delay a random amount of time according to the Ethernet "truncated binary backoff" algorithm in order that the colliding nodes don't try to attempts to access the network at the same time. Up to 16 attempts to access the network at made by the LANCE before reporting back an error due to excessive collisions.

#### ERROR REPORTING AND DIAGNOSTICS

Extensive error reporting is provided by the LANCE. Error conditions reported relate either to the network as a whole or to data packets. Network-related errors are recorded as flags in the CSRs and are examined by the CPU following interrupt. Packet-related errors are written into descriptor entries corresponding to the packet.

#### System errors include:

- Babbling Transmitter
- Transmitter attempting to transmit more than 1518 data bytes.
- Collision
- Collision detection circuitry nonfunctional
- Missed packet
- Insufficient buffer space
- Memory timeout
   Memory response failure
- Packet-related errors:
- CRC
- Invalid data
- Framing
- Packet did not end on a byte boundary
- Overflow/Underflow
- Indicates abnormal latency in servicing a DMA reguest
- Buffer

6

- Insufficient buffer space available

The LANCE performs several diagnostic routines which enhance the reliability and integrity of the system. These include a CRC logic check and two loop back modes (internal/ external). Errors may be introduced into the system to check error detection logic. A Time Domain Reflectometer is incorporated into the LANCE to aid system designers locate faults in the Ethernet cable. Shorts and opens manifest themselves in reflections which are sensed by the TDR.





#### BUFFER MANAGEMENT

A key feature of the LANCE and its on-board DMA channel is the flexibility and speed of communication between the LANCE and the host microprocessor through common memory locations. The basic organization of the buffer management is a circular queue of tasks in memory called descriptor rings, as shown in Figure 2a. There are separate descriptor rings to describe transmit and receive operations. Up to 128 tasks may be queued up on a descriptor ring awaiting execution by the LANCE Each entry in a descriptor ring holds a pointer to a data memory buffer and an entry for the length of the data buffer. Data buffers can be chained or cascaded to handle a long packet in multiple data buffer areas. The LANCE searches the descriptor rings in a "lookahead manner" to determine the next empty buffer in order to chain buffers together or to handle back-to-back packets. As each buffer is filled, an "own" bit is reset, allowing the host processor to process the data in the buffer.

#### LANCE INTERFACE

CSR bits such as ACON, BCON and BSWP are used for programming the pin functions used for different interfacing schemes. For example, ACON is used to program the polarity of the Address Strobe signal (ALE/ $\overline{\text{AS}}$ ).

BCON is used for programming the pins, for handling either the BYTE/WORD method for addressing word organized, byte addressable memories where the BYTE signal is decoded along with the least significant address bit to determine upper or lower byte, or an explicit scheme in which two signals labeled as BYTE MASK ( $\overline{BM}_0$  and  $\overline{BM}_1$ ) indicate which byte is addressed. When the BYTE scheme is chosen, the  $\overline{BM}_1$  pin can be used for performing the function  $\overline{BUSAKO}$ .

BCON is also used to program pins for different DMA modes. In a daisy chain DMA scheme, 3 signals are used (BUSRO, HLDA, BUSAKO). In systems using a DMA controller for arbitration, only HOLD and HLDA are used.

#### LANCE IN BUS MASTER MODE

All data transfers from the LANCE in the Bus Master mode are timed by ALE, DAS, and READY. The automatic adjustment of the LANCE cycle by the READY signal allows synchronization with variable cycle time memory due either to memory refresh or to dual port access. Bus cycles are a minimum of 600ns in length and can be increased in 100ns increments.



,



#### WRITE SEQUENCE

The write cycle is similar to the read cycle except that the  $DAL_{00}-DAL_{15}$  lines change from containing addresses to data after either ALE or  $\overline{AS}$  goes inactive. After data is valid on the bus,  $\overline{DAS}$  goes active. Data to memory is held valid after  $\overline{DAS}$  goes inactive. Refer to Figure 5b.

#### LANCE IN BUS SLAVE MODE

The LANCE enters the Bus Slave Mode whenever  $\overline{CS}$  becomes active. This mode must be entered whenever writing or reading the four status control registers (CSR<sub>0</sub>, CSR<sub>1</sub>, CSR<sub>2</sub>, and CSR<sub>3</sub>) and the Register Address Pointer (PAP). RAP and CSR<sub>0</sub> may be read or written to at anytime, but the LANCE must be stopped (by setting the stop bit in CSR<sub>0</sub>) for CSR<sub>1</sub>, CSR<sub>2</sub>, and CSR<sub>3</sub> access

#### READ SEQUENCE

At the beginning of a read cycle,  $\overline{CS}$ , READ, and  $\overline{DAS}$  are asserted. ADR also must be valid at this time (If ADR is a "1," the contents of RAP are placed on the DAL lines. Otherwise the contents of the CSR register addressed by RAP are placed on the DAL lines.) After the data on the DAL lines become valid, the LANCE asserts READY,  $\overline{CS}$ , READ,  $\overline{DAS}$ , and ADR must remain stable throughout the cycle. Refer to Figure 3.

#### WRITE SEQUENCE

This cycle is similar to the read cycle, except that during this cycle, READ is not asserted (READ is Low). The DAL buffers are tristated which configures these lines as inputs. The assertion of READY by LANCE indicates to the memory device that the data on the DAL lines have been stored by LANCE in its appropriate CSR register.  $\overline{CS}$ , READ,  $\overline{DAS}$ , ADR, and DAL <15:00> must remain stable throughout the write cycle. Refer to Figure 4.







#### DIFFERENCES BETWEEN ETHERNET VERSIONS 1 AND 2

a. Version 2 specifies that the collision detect of the transceiver must be activated during the interpacket gap time.

- b. Version 2 specifies some network management functions, such as reporting the occurrence of collisions, retries and deferrals.
- c. Version 2 specifies that when transmission is terminated, the differential transmit lines are driven OV diff. (half step).

## DIFFERENCES BETWEEN IEEE-802.3 AND ETHERNET

- a. IEEE-802.3 specifies a 2-byte length field rather than a type field. The length field (802.3) described the actual amount of data in the frame.
- b. IEEE-802.3 allows the use of a PAD field in the data section of a frame, while Ethernet specifies the minimum packet size at 64 bytes. The use of a PAD allows the user to send and receive packets which have less than 46 bytes of data.

A partial list of significant differences between Ethernet and IEEE-802.3 at the physical layer include the following:

|                           | IEEE-802.3       | Ethernet                                   |
|---------------------------|------------------|--------------------------------------------|
| End of Transmission State | Half Step        | High State (Rev 1) or<br>Half Step (Rev 2) |
| Common Mode<br>Voltage    | ±5.5V            | 0 - +5V                                    |
| Common Mode<br>Current    | Less than<br>1mA | 1.6mA ±40%                                 |
| Receive±, Collision±      |                  |                                            |
| Input Threshold           | ± 160mV          | ± 175mV                                    |
| Fault Protection          | 16V              | ov                                         |

#### PROGRAMMING SPECIFICATION

This section defines the control and Status Registers and the memory data structures required to program the Am7990 (LANCE).

#### **PROGRAMMING THE Am7990 (LANCE)**

The Am7990 (LANCE) is designed to operate in an environment that includes close coupling with a local memory and a microprocessor (HOST). The Am7990 LANCE is programmed by a combination of registers and data structures resident within the chip and in memory. There are four Control and Status Registers (CSRs) within the chip which are programmed by the HOST device. Once enabled, the chip has the ability to access memory locations to acquire additional operating parameters.

The Am7990 has the ability to do independent buffer management as well as transfer data packets to and from the Ethernet. There are three memory structures accessed by the Chip:

- 1. Initialization Block 12 words in contiguous memory starting on a word boundary. It also contains the operating parameters necessary for device operation. The initialization block is comorised of:
  - Mode of Operation
  - Physical Address
  - Logical Address Mask
- Location to Receive and Transmit Descriptor Rings
- Number of Entries in Receive and Transmit **Descriptor Rings**
- 2. Receive and Transmit Descriptor Rings Two ring structures, one each for incoming and outgoing packets. Each entry in the rings is 4 words long and each entry must start on a quadword boundary. The Descriptor Rings are comprised of:
  - The address of a data buffer
  - · The length of that data buffer
  - · Status information associated with the buffer
- 3 Data Buffers Contiguous portions of memory reserved for packet buffering. Data buffers may begin on arbitrary byte boundaries

In general, the programming sequence of the chip may be, summarized as

- 1 Programming the chip's CSRs by a host device to locate an initialization block in memory. The byte control, byte addressing, and address latch enable modes are defined here also.
- 2. The chip loading itself with the information contained within the initialization block.
- 3. The chip accessing the descriptor rings for packet handling.

#### CONTROL AND STATUS REGISTERS

There are four Control and Status Registers (CSRs) resident within the chip. The CSRs are accessed through two bus addressable ports, an address port (RAP) and a data port (RDP)

#### ACCESSING THE CONTROL AND STATUS REGISTERS

The CSRs are read (or written) in a two step operation. The address of the CSR to be accessed is written into the address port (RAP) during a bus slave transaction. During a subsequent bus slave transaction, the data being read from (or written into) the data port (RDP) is read from (or written into) the CSR selected in the RAP.

Once written, the address in RAP remains unchanged until rewritten

To distinguish the data port from the address port, a discrete 1/O pin is provided.

ADR I/O Pin Port

| L | Register | Data Port (RDP)    |
|---|----------|--------------------|
| н | Register | Address Port (RAP) |

#### **Register Data Port (RDP)**

CSR DATA

AF001450

| Bit   | Name     | Description                                                                                                                                                                                                                             |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:00 | CSR Data | Writing data into RDP writes the data into the CSR selected in RAP. Reading the data from the RDP reads the data from the CSR selected in RAP. CSR1, CSR2 and CSR3 are accessible only when the STOP bit of CSR0 is set.                |
|       |          | If the STOP bit is not set while<br>attempting to access CSR <sub>1</sub> ,<br>CSR <sub>2</sub> or CSR <sub>3</sub> , the chip will<br>return READY, but a READ<br>operation will return undefined<br>data. WRITE operation is ignored. |

#### **Register Address Port (RAP)**

|       |          | <u> </u>                                                                |                                                                              |
|-------|----------|-------------------------------------------------------------------------|------------------------------------------------------------------------------|
|       | L        |                                                                         | CSR 1 0                                                                      |
| Bit   | Name     | Description                                                             | AF001490                                                                     |
| 15:02 | RES      | Reserved and re                                                         | ad as zeroes                                                                 |
| 01:00 | CSR(1:0) | CSR address s<br>WRITE. Selects<br>accessed through<br>is cleared by Bu | the CSR to be the RDP. RAP                                                   |
|       |          | CSR(1:0)                                                                | CSR                                                                          |
|       | · .      | 00<br>01<br>10<br>11                                                    | CSR <sub>0</sub><br>CSR <sub>1</sub><br>CSR <sub>2</sub><br>CSR <sub>3</sub> |

| ONTRO<br>EFINIT |              | TATUS REGISTER                                                                                                                                                                                                                                                                                                                                                                     | Bit | Name | Description                                                                                                                                                                                                                                                                                                                                    |
|-----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | and Status   | Register 0 (CSR <sub>0</sub> )                                                                                                                                                                                                                                                                                                                                                     |     |      | CERR is READ/CLEAR ONLY<br>and is set by the chip and cleared<br>by writing a "1" into the bit.<br>Writing a "0" has no effect. It is<br>cleared by RESET or by setting<br>the STOP bit. CERR error will not<br>cause an interrupt to occur<br>(INTR = 0).                                                                                     |
|                 | ING" the pre | The Top                                                                                                                                                                                                                                                                                                                                        | 12  | MISS | MISSED PACKET is set when the<br>receiver loses a packet because<br>it does not own any receive<br>buffer, indicating loss of data.<br>Silo overflow is not reported<br>because there is no receive ring<br>entry in which to write status.<br>MISS is not valid in internal<br>loopback mode.                                                 |
| Bit             | Name         | Description                                                                                                                                                                                                                                                                                                                                                                        |     |      | When MISS is set, an interrupt                                                                                                                                                                                                                                                                                                                 |
| 15              | ERR          | ERROR summary is set by the<br>"OR" of BABL, CERR, MISS and<br>MERR. ERR remains set as long<br>as any of the error flags are true.<br>ERR is read only; writing it has no<br>effect. It is cleared by Bus<br>RESET, by setting the STOP bit,                                                                                                                                      |     |      | will be generated if INEA = 1.<br>MISS is READ/CLEAR ONLY,<br>and is set by the chip and cleared<br>by writing a "1" into the bit.<br>Writing a "0" has no effect. It is<br>cleared by RESET or by setting<br>the STOP bit.                                                                                                                    |
| 14              | BABL         | or clearing the individual error<br>flags.<br>BABBLE is a transmitter timeout<br>error. It indicates that the<br>transmitter has been on the<br>channel longer than the time<br>required to send the maximum<br>length packet.                                                                                                                                                     | 11  | MERR | MEMORY ERROR is set when<br>the chip is the Bus Master and<br>has not received READY within<br>25.6 µs after asserting the<br>address on the DAL lines.<br>When a Memory Error is<br>detected, the receiver and<br>transmitter are turned off (CSR <sub>0</sub> ,                                                                              |
|                 |              | BABL is a flag which indicates<br>excessive length in the transmit<br>buffer. It will be set after 1519<br>data bytes have been<br>transmitted; the chip will continue<br>to transmit until the whole packet<br>is transmitted or until there is a<br>failure before the whole packet is<br>transmitted. When BABL error<br>occurs, an interrupt will be<br>generated if INEA = 1. | 10  | RINT | TXON = 0, RXON = 0) and an interrupt is generated if INEA = 1.<br>MERR is READ/CLEAR ONLY, and is set by the chip and cleared by writing a "1" into the bit.<br>Writing a "0" has no effect. It is cleared by RESET or by setting the STOP bit.<br>RECEIVER INTERRUPT is set when the chip updates an entry in the Receive Descriptor Ring for |
|                 |              | BABL is READ/CLEAR ONLY<br>and is set by the chip, and<br>cleared by writing a "1" into the<br>bit. Writing a "0" has no effect. It<br>is cleared by RESET or by setting<br>the STOP bit.                                                                                                                                                                                          |     |      | the last buffer received or<br>reception is stopped due to a<br>failure.<br>When RINT is set, an interrupt is<br>generated if INEA = 1.                                                                                                                                                                                                        |
| 13              | CERR         | COLLISION ERROR indicates<br>that the collision input to the chip<br>failed to activate within $2\mu$ s after<br>a chip-initiated transmission was<br>completed. The collision after<br>transmission is a transceiver test                                                                                                                                                         |     |      | RINT is READ/CLEAR ONLY,<br>and is set by the chip and cleared<br>by writing a "1" into the bit.<br>Writing a "0" has no effect. It is<br>cleared by RESET or by setting<br>the STOP bit.                                                                                                                                                      |
|                 |              | feature.This function is also<br>known as heartbeat or SQE<br>(Signal Quality Error) test.                                                                                                                                                                                                                                                                                         | 09  | TINT | TRANSMITTER INTERRUPT is<br>set when the chip updates an<br>entry in the transmit descriptor<br>ring for the last buffer sent or<br>transmission is stopped due to a<br>failure.                                                                                                                                                               |

| Bit | Name | Description                                                                                                                                                                                                                                             | Bit | Name | Description                                                                                                                                                                                                                                                                                                                                      |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | When TINT is set, an interrupt is<br>generated if INEA = 1.<br>TINT is READ/CLEAR ONLY and<br>is set by the chip and cleared by<br>writing a "1" into the bit. Writing a<br>"0" has no effect. It is cleared by<br>RESET or by setting the STOP<br>bit. | 05  | RXON | RECEIVER ON indicates that the<br>receiver is enabled. RXON is so<br>when STRT is set if DRX = 0<br>the MODE register in the<br>initialization block and the<br>initialization block has been read<br>by the chip by setting the INIT b<br>RXON is cleared when IDON                                                                             |
| 08  | IDON | INITIALIZATION DONE indicates<br>that the chip has completed the<br>initialization procedure started by<br>setting the INIT bit. When IDON is<br>set, the chip has read the<br>Initialization Block from memory<br>and stored the new parameters.       | 04  | TXON | set from setting the INIT bit ar<br>DRX = 1 in the MODE register,<br>a memory error (MERR) ha<br>occurred. RXON is READ ONL<br>writing this bit has no effec<br>RXON is cleared by RESET or t<br>setting the STOP bit.<br>TRANSMITTER ON indicate                                                                                                |
|     |      | When IDON is set, an interrupt is generated if INEA = 1.                                                                                                                                                                                                | 04  | TAON | TRANSMITTER ON indicate<br>that the transmitter is enable<br>TXON is set when STRT is set                                                                                                                                                                                                                                                        |
|     |      | IDON is READ/CLEAR ONLY,<br>and is set by the chip and cleared<br>by writing a "1" into the bit.<br>Writing a "0" has no effect. It is<br>cleared by RESET or by setting<br>the STOP bit.                                                               |     |      | DTX = 0 in the MODE register<br>the initialization block and the<br>INIT bit has been set. TXON<br>cleared when IDON is set ar<br>DTX = 1 in the MODE register,<br>an error, such as MERR, UFLO<br>BUFF, has occurred durin                                                                                                                      |
| 07  | INTR | INTERRUPT FLAG is set by the<br>"OR" of BABL, MISS, MERR,<br>RINT, TINT and IDON. If<br>INEA = 1 and INTR = 1, the INTR<br>I/O pin will be Low.                                                                                                         |     |      | transmission.<br>TXON is READ ONLY; writing th<br>bit has no effect. TXON is clear<br>by RESET or by setting the STC<br>bit.                                                                                                                                                                                                                     |
|     |      | INTR IS READ ONLY; writing this<br>bit has no effect. INTR is cleared<br>by RESET, by setting the STOP<br>bit, or by clearing the condition<br>causing the interrupt.                                                                                   | 03  | TDMD | TRANSMIT DEMAND, when so<br>causes the chip to access the<br>Transmit Descriptor Ring witho<br>waiting for the politime interval<br>elapse. TDMD need not be set                                                                                                                                                                                 |
| 06  | INEA | INTERRUPT ENABLE allows the<br>INTR I/O pin to be driven Low<br>when the Interrupt Flag is set. If<br>INEA = 1 and INTR = 1, the INTR<br>I/O pin will be Low. If INEA = 0,                                                                              |     |      | transmit a packet; it mere<br>hastens the chip's response to<br>Transmit Descriptor Ring ent<br>insertion by the host.<br>TDMD is WRITE WITH ON                                                                                                                                                                                                  |
|     |      | the INTR I/O pin will be High.<br>regardiess of the state of the<br>Interrupt Flag.                                                                                                                                                                     |     |      | ONLY and is cleared by the microcode after it is used. It m read as a "1" for a short time                                                                                                                                                                                                                                                       |
|     |      | INEA is READ/WRITE and<br>cleared by RESET or by setting<br>the STOP bit.                                                                                                                                                                               |     |      | after it is written because to<br>microcode may have been bu<br>when TDMD was set. It is all<br>cleared by RESET or by setti                                                                                                                                                                                                                     |
|     |      | INEA cannot be set while STOP<br>bit is set. INEA can be set in<br>parallel or after INIT and/or                                                                                                                                                        |     |      | the STOP bit. Writing a ''0'' in the bit has no effect.                                                                                                                                                                                                                                                                                          |
|     |      | STRT bit are set.                                                                                                                                                                                                                                       | 02  | STOP | STOP disables the chip from<br>external activity when set a<br>clears the internal logic. Setti<br>STOP is the equivalent<br>asserting RESET. The ch<br>remains inactive and STC<br>remains set until the STRT<br>INIT bit is set. If STRT, INIT a<br>STOP are all set together, STC<br>will override the other bits a<br>only STOP will be set. |

| Bit   | Name      | Description                                                                                                                                                                           | 15        |         | 8 7 8                                                                                                                                     |
|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
|       |           | STOP is READ/WRITE WITH<br>ONE ONLY and set by RESET.                                                                                                                                 |           |         |                                                                                                                                           |
|       |           | Writing a "0" to this bit has no<br>effect. STOP is cleared by setting                                                                                                                | ·         | Ì       | L                                                                                                                                         |
|       |           | either INIT or STRT. CSR <sub>1</sub> ,<br>CSR <sub>2</sub> , and CSR <sub>3</sub> must be                                                                                            |           |         | AF000920                                                                                                                                  |
|       |           | reloaded when the STOP bit is set.                                                                                                                                                    | Bit       | Name    | Description                                                                                                                               |
|       | STRT      | START enables the chip to send                                                                                                                                                        | 15:08     | RES     | Reserved.                                                                                                                                 |
|       |           | and receive packets, perform<br>direct memory access, and do<br>buffer management. The STOP<br>bit must be set prior to setting the<br>STRT bit. Setting STRT clears<br>the STOP bit. | 07:00     | IADR    | The high order 8 bits of the ad-<br>dress of the first word (lowest<br>address) in the Initialization<br>Block.                           |
|       |           | If STRT and INIT are set<br>together, the INIT function will be                                                                                                                       |           |         | Register 3 (CSR <sub>3</sub> )<br>of the Bus Master interface.                                                                            |
|       |           | executed first.<br>STRT is READ/WRITE and is set                                                                                                                                      |           |         | RAP = 3                                                                                                                                   |
|       |           | with one only. Writing a "0" into<br>this bit has no effect. STRT is<br>cleared by RESET or by setting<br>the STOP bit.                                                               | READ/WRIT | ONE. CS | le only when the STOP bit of $CSR_0$ is $R_3$ is cleared by RESET or by setting P bit in $CSR_0$ .                                        |
|       | INIT      | INITIALIZE, when set, causes the                                                                                                                                                      | 15        |         | 3 2 1 0                                                                                                                                   |
|       |           | chip to begin the initialization procedure and access the                                                                                                                             |           |         |                                                                                                                                           |
|       |           | Initialization Block. The STOP bit<br>must be set prior to setting the<br>INIT bit. Setting INIT clears the<br>STOP bit.                                                              | ·         |         | BCON<br>BSWP                                                                                                                              |
|       |           | If STRT and INIT are set<br>together, the INIT function will be                                                                                                                       |           | L       | RES<br>AF000900                                                                                                                           |
|       |           | executed first. INIT is READ/                                                                                                                                                         | Dia       | Mama    |                                                                                                                                           |
|       |           | WRITE WITH "1" ONLY. Writing<br>a "0" into this bit has no effect.                                                                                                                    | 15:03     | RES     | Reserved and read as "0."                                                                                                                 |
|       |           | INIT is cleared by RESET or by<br>setting the STOP bit.                                                                                                                               | 02        | BSWP    | BYTE SWAP allows the chip to                                                                                                              |
| ol an | d Status  | Register 1 (CSR <sub>1</sub> )                                                                                                                                                        |           |         | operate in systems that consider                                                                                                          |
|       |           | RAP = 1                                                                                                                                                                               |           |         | bits (15:08) of data to be pointed<br>by an even address and bits                                                                         |
| WRIT  |           | le only when the STOP bit of CSR <sub>0</sub> is<br>CSR <sub>1</sub> is unaffected by RESET.                                                                                          |           |         | (07:00) to be pointed by an odd address.                                                                                                  |
|       |           | 1 0                                                                                                                                                                                   |           |         | When BSWP = 1, the chip will swap the high and low bytes on                                                                               |
|       |           |                                                                                                                                                                                       |           |         | DMA data transfers between the                                                                                                            |
|       |           |                                                                                                                                                                                       |           |         | silo and bus memory. Only data<br>from silo transfers is swapped;<br>the Initialization Block data and<br>the Descriptor Ring entries are |
| •     | Name      | Description                                                                                                                                                                           |           |         | NOT swapped.                                                                                                                              |
| :01   | IADR      | The low order 16 bits of the<br>address of the first word (lowest<br>address) in the Initialization                                                                                   |           |         | BSWP is READ/WRITE and<br>cleared by RESET or by setting<br>the STOP bit in CSR <sub>0</sub> .                                            |
|       |           | Block                                                                                                                                                                                 | 01        | ACON    | ALE CONTROL defines the as-<br>sertive state of ALE when the                                                                              |
|       | d Status  | Must be zero.                                                                                                                                                                         |           |         | chip is a Bus Master, ACON is<br>READ/WRITE and cleared by                                                                                |
| ro:81 | NU 3181US | Register 2 (CSR <sub>2</sub> )<br>RAP = 2                                                                                                                                             |           |         | RESET and by setting the STOP                                                                                                             |
| /writ |           | le only when the STOP bit of CSR <sub>0</sub> is<br>CSR <sub>2</sub> is unaffected by RESET.                                                                                          |           |         | bit in CSR <sub>0</sub> .<br>ACON ALE                                                                                                     |

•

| 00                                                                     | BCON                                             | BYTE CONTROL r<br>Byte Mask and Ho                                                                                         | old I/O pins.                                                    | Bit | Name | Description                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                        |                                                  | BCON is READ/<br>cleared by RESET<br>the STOP bit in CS<br>BCON Pin16 Pin<br>0 BM <sub>1</sub> BM<br>1 BUSAKO BY           | or by setting<br>iR <sub>0</sub> .<br>15 Pin17                   | 06  | INTL | INTERNAL LOOPBACK is use<br>with the LOOP bit to determin<br>where the loopback is to be done<br>Internal loopback allows the chi<br>to receive its own transmitte<br>packet. Since this represents fu                                                                                                                        |
| n wordś. Ho                                                            | wever, the                                       | LANCE in the Bus Mas<br>LANCE can handle<br>ats with an odd numbe                                                          | odd address                                                      |     |      | duplex operation, the packet siz<br>is limited to 8-32 bytes. Interna<br>loopback in the LANCE is opera<br>tional only when the packets ar<br>addressed to the node itself.                                                                                                                                                   |
| NITIALIZA<br>NITIALIZA                                                 |                                                  | ЮСК                                                                                                                        |                                                                  |     |      | The Lance will not receive an<br>packets externally when it is i<br>internal loopback mode.                                                                                                                                                                                                                                   |
| Thip initializat<br>n memory to<br>a definition of<br>The Initializati | ion includes<br>obtain the op<br>if the Initiali | the reading of the initia<br>perating parameters. Th<br>zation Block.<br>read by the chip when t<br>should be set before d | e following is                                                   |     |      | EXTERNAL LOOPBACK allow<br>the LANCE to transmit a packet<br>through the SIA transceiver cabil<br>out to the Ethernet coax. It is<br>used to determine the operabilit<br>of all circuitry and connection<br>between the LANCE and the co                                                                                      |
| with the STR<br>hip operation                                          | T bit to insur<br>h. After the c                 | e proper parameter init<br>chip has read the Initiali<br>an interrupt is generated                                         | ialization and<br>ization Block,                                 |     |      | axial cable. Multicast addressin<br>in external loopback is valid on<br>when DTCR = 1 (user needs t<br>append the 4 bytes CRC).                                                                                                                                                                                               |
| ligher Addres                                                          | ses                                              | RLEN-RDRA (23:16)<br>RDRA (15:00)<br>LADRF (63:48)                                                                         | IADR +20                                                         |     |      | In external loopback, the LANC<br>also receives packets from othe<br>nodes.<br>INTL is only valid if LOOP =<br>otherwise, it is ignored                                                                                                                                                                                       |
|                                                                        |                                                  | LADRF (31:16)<br>LADRF (15:00)<br>PADR (47:32)<br>PADR (31:16)                                                             | IADR + 10<br>IADR + 08<br>IADR + 06<br>IADR + 04<br>IADR + 02    |     |      | LOOPINTL LOOPBACK<br>0 X No loopback, norma<br>1 0 External<br>1 1 Internal                                                                                                                                                                                                                                                   |
|                                                                        | egister allow                                    |                                                                                                                            | IADR +00<br>p's operating                                        | 05  | DRTY | DISABLE RETRY. When<br>DRTY = 1, the chip will attemp<br>only one transmission of a pact<br>et. If there is a collision on the<br>first transmission attempt, a Retri<br>Error (RTRY) will be reported in<br>Transmit Message Descriptor<br>(TMD <sub>3</sub> ).                                                              |
|                                                                        |                                                  |                                                                                                                            | DAX<br>DTX<br>DTX<br>LOOP<br>DTCA<br>DTCA<br>COLL<br>DRTY<br>WRL | 04  | COLL | FORCE COLLISION This bit a lows the collision logic to be test ed. The chip must be in internal loopback mode for COLL to be valid. If $COLL = 1$ , a collision we be forced during the subsequent transmission attempt. This will result in 16 total transmission a tempts with a retry error reported in TMD <sub>3</sub> . |
|                                                                        |                                                  | Description                                                                                                                | AF000510                                                         | 03  | DTCR | DISABLE TRANSMIT CRC<br>When DTCR = 0, the transmitt<br>will generate and append a CR<br>to the transmitted packet. Whe                                                                                                                                                                                                       |
|                                                                        | PROM                                             | PROMISCUOUS                                                                                                                |                                                                  |     |      | DTCR = 1, the CRC logic is all<br>cated to the receiver and no CR                                                                                                                                                                                                                                                             |
| Bit<br>15                                                              |                                                  | PROM = 1, all incom<br>are accepted.                                                                                       | ming packets                                                     |     |      | is generated and sent with th<br>transmitted packet.                                                                                                                                                                                                                                                                          |

| 1 | Name | Description                                                                                                                                                                                                                                 | Bit                                                                                         | Name                                                                                                    | Description                                                                                                                                                                                                                                                             |
|---|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      | During loopback, DTCR = 0 will<br>cause a CRC to be generated on<br>the transmitted packet, but no<br>CRC check will be done by the<br>receiver since the CRC logic is<br>shared and cannot generate and<br>check CRC at the same time. The | 00                                                                                          | DRX                                                                                                     | DISABLE THE RECEIVER cau<br>es the chip to reject all incomir<br>packets and not access the Ri-<br>ceive Descriptor Ring. DRX –<br>will clear the RXON bit in th<br>CSR <sub>0</sub> when initialization is con<br>plete.                                               |
|   |      | generated CRC will be written<br>into memory with the data and<br>can be checked by the host soft-<br>ware.                                                                                                                                 | Physical<br>47                                                                              | Address                                                                                                 | here.                                                                                                                                                                                                                                                                   |
|   |      | If DTCR = 1 during loopback, the<br>host software must append a<br>CRC value to the transmit data.<br>The receiver will check the CRC<br>on the received data and report                                                                    | L <u></u>                                                                                   |                                                                                                         | PADR (47<br>AF000                                                                                                                                                                                                                                                       |
|   |      | any errors.                                                                                                                                                                                                                                 | Bit                                                                                         | Name                                                                                                    | Description                                                                                                                                                                                                                                                             |
|   | LOOP | LOOPBACK allows the chip to<br>operate in full duplex mode for<br>test purposes. The packet size is                                                                                                                                         | 47:00                                                                                       | PADR                                                                                                    | PHYSICAL ADDRESS is th<br>unique 48-bit physical addres<br>assigned to the chip. PADR ((<br>must be zero.                                                                                                                                                               |
|   |      | limited to 8-32 bytes. The re-<br>ceived packet can be up to 36<br>bytes (32 + 4 bytes CRC) when                                                                                                                                            | Logical A                                                                                   | Address Filt                                                                                            |                                                                                                                                                                                                                                                                         |
|   |      | DTCR=0. During loopback, the<br>runt packet filter is disabled be-                                                                                                                                                                          |                                                                                             |                                                                                                         | LADRE                                                                                                                                                                                                                                                                   |
|   |      | cause the maximum packet is<br>forced to be smaller than the<br>minimum size Ethernet packet                                                                                                                                                | Bit                                                                                         | Name                                                                                                    | AF00050<br>Descriptor                                                                                                                                                                                                                                                   |
|   |      | (64 bytes).<br>LOOP = 1 allows simultaneous                                                                                                                                                                                                 | 63:00                                                                                       | LADRF                                                                                                   | The 64-bit mask used by the chi to accept logical addresses.                                                                                                                                                                                                            |
|   |      | transmission and reception for a<br>message constrained to fit within<br>the silo. The chip waits until the<br>entire message is in the silo be-                                                                                            |                                                                                             | s is deemed                                                                                             | ing address is a "1" [PADR (0) = $1$<br>iogical and is passed through th                                                                                                                                                                                                |
|   |      | fore serial transmission begins.<br>The incoming data stream fills the<br>silo from behind as it is being<br>emptied. Moving the received<br>message out of the silo to memo-<br>ry does not begin until reception<br>has ceased.           | sixteen-bit i<br>that is use<br>incoming ac<br>bits of the<br>high order 6<br>into a regist | registers, LAD<br>ad to accept<br>ddress is sent<br>address have<br>bits of the res<br>ter. This regist | is a 64-bit mask composed of fou<br>RF (63:00) in the initialization block<br>incoming Logical Addresses. Th<br>through the CRC circuit, After all 4<br>gone through the CRC circuit, th<br>sultant CRC (32-bit CRC) are strobe<br>or is used to select one of the 64-b |
|   |      | In loopback mode, transmit data<br>chaining is not possible. Receive<br>data chaining is possible if re-<br>ceive buffers are 32 bytes long to<br>allow time for lookahead.                                                                 | is a "1," the<br>memory. Th<br>possibility t<br>node. To d                                  | e address is a<br>ne logical addr<br>hat the incom<br>letermine if it                                   | ddress Filter. If the selected filter b<br>coepted and the packet will be put i<br>ess filter only assures that there is<br>ning logical address belongs to th<br>belongs to the node, the incomin<br>red in main memory is compared b                                  |
|   | XTD  | DISABLE THE TRANSMITTER<br>causes the chip to not access the<br>Transmitter Descriptor Ring, and                                                                                                                                            | •                                                                                           |                                                                                                         | cal addresses to be accepted by thi                                                                                                                                                                                                                                     |
|   |      | therefore, no transmissions are<br>attempted. $DTX = 1$ will clear the<br>TXON bit in CSR <sub>0</sub> when initializa-<br>tion is complete.                                                                                                | positions re<br>A) which us                                                                 | quires a simp<br>les the same                                                                           | logical address to one of 64-b<br>le computer program (see Appendi<br>CRC algorithm (used in LANCE an<br>calculate the HASH (see Figure 7                                                                                                                               |
|   |      |                                                                                                                                                                                                                                             | the Logical                                                                                 | Address Filter<br>ter is loaded                                                                         | rhich is all ones, does not go throug<br>and is always enabled. If the Logica<br>with all zeroes, all incoming logica                                                                                                                                                   |



32 BIT RESULTANT CRO

|      | TLEN                                                                                                                                      | Number of Entries |  |  |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--|--|--|
|      | 0                                                                                                                                         | 1                 |  |  |  |
|      | 1                                                                                                                                         | 2                 |  |  |  |
|      | 2                                                                                                                                         | 4                 |  |  |  |
|      | 3                                                                                                                                         | 8                 |  |  |  |
|      | 4                                                                                                                                         | 16                |  |  |  |
|      | 5                                                                                                                                         | 32                |  |  |  |
|      | 6                                                                                                                                         | 64                |  |  |  |
|      | 7                                                                                                                                         | 128               |  |  |  |
| RES  | RESERVED                                                                                                                                  | )                 |  |  |  |
| TDRA | TRANSMIT DESCRIPTOR RING<br>ADDRESS is the base address<br>(lowest address) of the Transmit<br>Descriptor Ring.                           |                   |  |  |  |
|      | MUST-BE ZEROES. These bits<br>are TDRA (02:00) and must be<br>zeroes because the Transmit<br>Rings are aligned on quadword<br>boundaries. |                   |  |  |  |

#### BUFFER MANAGEMENT

12:08

07:00

15:03

02:00

Buffer Management is accomplished through message descriptors organized in ring structures in memory. Each message descriptor entry is four words long. There are two rings allocated for the device: a Receive ring and a Transmit ring. The device is capable of polling each ring for buffers to either empty or fill with packets to or from the channel. The device is also capable of entering status information in the descriptor entry. Chip polling is limited to looking one ahead of the descriptor entry the chip is currently working with.

The location of the descriptor rings and their length are found in the initialization block, accessed during the initialization procedure by the chip. Writing a "ONE" into the STRT bit of CSR<sub>0</sub> will cause the chip to start accessing the descriptor rings and enable it to send and receive packets.

The chip communicates with a HOST device (probably a mircoprocessor) through the ring structures in memory. Each entry in the ring is either "owned" by the chip or the HOST. There is an ownership bit (OWN) in the message descriptor entry. Mutual exclusion is accomplished by a protocol which states that each device can only relinguish ownership of the descriptor entry to the other device; it can never take ownership, and no device can change the state of any field in any entry after it has relinguished ownership.

#### DESCRIPTOR RINGS

Each descriptor in a ring in memory is a 4-word entry. The following is the format of the receive and the transmit descriptors.

#### Receive Message Descriptor Entry

#### Receive Message Descriptor 0 (RMD<sub>0</sub>)

|       |      | LADR                                                                                                                                          |  |  |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       |      | AF000940                                                                                                                                      |  |  |
| Bit   | Name | Description                                                                                                                                   |  |  |
| 15:00 | LADR | The LOW ORDER 16 address<br>bits of the buffer pointed to by<br>this descriptor. LADR is written by<br>the host and unchanged by the<br>chip. |  |  |

|     |        | escriptor 1 (RMD <sub>1</sub> )                                                                                                                                                                                | Bit       | Name              | Description                                                                                                                                                              |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        |                                                                                                                                                                                                                | 10        | BUFF              | BUFFER ERROR is set any tir<br>the chip does not own the n                                                                                                               |
|     |        |                                                                                                                                                                                                                |           |                   | <ul> <li>buffer while data chaining<br/>received packet. This can occur.</li> </ul>                                                                                      |
|     |        | ENP                                                                                                                                                                                                            |           |                   | in either of two ways: 1) the OV                                                                                                                                         |
|     |        | \$17<br>BUFF                                                                                                                                                                                                   |           |                   | <ul> <li>bit of the next buffer is zero, or<br/>silo overflow occurred before t</li> </ul>                                                                               |
|     | L      |                                                                                                                                                                                                                |           |                   | chip received the next STATU                                                                                                                                             |
| 1 L | ······ | OFLO                                                                                                                                                                                                           |           |                   | BUFF is set by the chip a<br>cleared by the host.                                                                                                                        |
| L   | ·····  | EM                                                                                                                                                                                                             |           |                   | If a Buffer Error occurs,                                                                                                                                                |
|     | A+     |                                                                                                                                                                                                                |           |                   | Overflow Error may also occ<br>internally in the SILO, but will r<br>be reported in the descrip                                                                          |
| Bit | Name   | Description                                                                                                                                                                                                    |           |                   | and OFLO errors occur at 1                                                                                                                                               |
| 15  | OWN    | This bit indicates that the<br>descriptor entry is owned by the                                                                                                                                                |           |                   | same time.                                                                                                                                                               |
|     |        | host (OWN = 0) or by the chip<br>(OWN = 1). The chip clears the<br>OWN bit after filling the buffer<br>pointed to by the descriptor entry.<br>The host sets the OWN bit after<br>emptying the buffer. Once the | 09        | STP               | START OF PACKET indica<br>that this is the first buffer used<br>the chip for this packet. It is us<br>for data chaining buffers. STF<br>set by the chip and cleared by   |
|     |        | chip or host has relinquished                                                                                                                                                                                  | ••        | 510               | host.                                                                                                                                                                    |
|     |        | ownership of a buffer, it must not<br>change any field in the four words<br>that comprise the descriptor<br>entry.                                                                                             | 08        | ENP               | END OF PACKET indicates the<br>this is the last buffer used by in<br>chip for this packet. It is used<br>data chaining buffers. If both S<br>and ENP are set, the packet |
| 14  | ERR    | ERROR summary is the "OR" of<br>FRAM, OFLO, CRC or BUFF<br>ERR is set by the chip and<br>cleared by the host.                                                                                                  |           |                   | into one buffer and there is<br>data chaining. ENP is set by the<br>chip and cleared by the host                                                                         |
| 13  | FRAM   | FRAMMING ERROR indicates<br>that the incoming packet<br>contained a noninteger multiple<br>of eight bits and there was a CRC                                                                                   | 07:00     | HADR              | The HIGH ORDER 8 address to<br>of the buffer pointed to by to<br>descriptor. This field is written<br>the host and unchanged by to<br>chip.                              |
|     |        | error. If there was not a CRC<br>error on the incoming packet,<br>then FRAM will not be set even if                                                                                                            | Receive h | <b>less</b> age D | escriptor 2 (RMD <sub>2</sub> )                                                                                                                                          |
|     |        | there was a noninteger multiple<br>of eight bits in the packet. FRAM                                                                                                                                           | 15 12     | <u> </u>          | î                                                                                                                                                                        |
|     |        | is not valid in internal loopback                                                                                                                                                                              |           |                   |                                                                                                                                                                          |
|     |        | mode. FRAM is set by the chip<br>and cleared by the host.                                                                                                                                                      | ĺ         |                   | L                                                                                                                                                                        |
| 12  | OFLO   | OVERFLOW error indicates that the receiver has lost all or part of                                                                                                                                             | <b>k</b>  |                   | MUST BE C<br>AF00                                                                                                                                                        |
|     |        | the incoming packet due to an                                                                                                                                                                                  | Bit       | Name              | Description                                                                                                                                                              |
|     |        | inability to store the packet in a<br>memory buffer before the internal<br>silo overflowed. OFLO is set by<br>the chip and cleared by the host.                                                                | 15:12     |                   | MUST BE ONES. This field<br>written by the host and<br>unchanged by the chip.                                                                                            |
| 11  | CRC    | CRC indicates that the receiver                                                                                                                                                                                | 11:00     | BCNT              | BUFFER BYTE COUNT is the length of the buffer pointed to                                                                                                                 |
|     |        | has detected a CRC error on the<br>incoming packet. CRC is set by<br>the chip and cleared by the host.                                                                                                         |           |                   | this descriptor, expressed as<br>two's complement number. T<br>field is written by the host a<br>unchanged by the chip. Minim<br>buffer size is 64 bytes for the f       |

| 12        | 11        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Bit      | Name      | Description                                                                                                                                                                                                                                                                                 |
|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 13       | RES       | RESERVED bit. The chip wi<br>write this bit with a "0."                                                                                                                                                                                                                                     |
| Ĺ         |           | MCNT<br>RES<br>AF000950                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 12       | MORE      | MORE indicates that more tha<br>one retry was needed to transm<br>a packet. MORE is set by the chi<br>and cleared by the host.                                                                                                                                                              |
| Bit 15:12 | RES       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 11       | ONE       | ONE indicates that exactly on<br>retry was needed to transmit                                                                                                                                                                                                                               |
| 11:00     | MCNT      | RESERVED and read as zeroes.<br>MESSAGE BYTE COUNT is the<br>length in bytes of the received<br>message. MCNT is valid only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |           | packet. ONE is set by the chi<br>and cleared by the host. One fla<br>is not valid when LCOL is set                                                                                                                                                                                          |
| ansmit    | Message C | when ERR is clear and ENP is<br>set. MCNT is written by the chip<br>and cleared by the host.<br>Descriptor Entry                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10       | DEF       | DEFERRED indicates that the<br>chip had to defer while trying t<br>transmit a packet. This condition<br>occurs if the channel is bus<br>when the chip is ready to<br>transmit. DEFER is set by the                                                                                          |
| ansmit    | Message D | escriptor 0 (TMD <sub>0</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |           | chip and cleared by the host.                                                                                                                                                                                                                                                               |
|           |           | LADR AF000940                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 09       | STP       | START OF PACKET indicate<br>that this is the first buffer to b<br>used by the chip for this packet.<br>is used for data chaining buffers                                                                                                                                                    |
| Bit       | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |           | STP is set by the host an<br>unchanged by the chip. The ST                                                                                                                                                                                                                                  |
| 15:00     | LADR      | The LOW ORDER 16 address<br>bits of the buffer pointed to by<br>this descriptor. LADR is written by<br>the host and unchanged by the<br>chip.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |           | bit must be set in the first buffe<br>of the packet, or the LANCE w<br>skip over this descriptor and po<br>the next descriptor(s) until th<br>OWN and STP bit are set.                                                                                                                      |
|           | Message C | 0         7         0           Image: state st | 08       | ENP       | END OF PACKET indicates that<br>this is the last buffer to be use<br>by the chip for this packet. It<br>used for data chaining buffers.<br>both STP and ENP are set, th<br>packet fits into one buffer an<br>there is no data chaining. ENP<br>set by the host and unchanged b<br>the chip. |
|           |           | Оне<br>Оне<br>Моле<br>Моле<br>Рез<br>Евя                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 07:00    | HADR      | The HIGH ORDER 8 address bit<br>of the buffer pointed to by thi<br>descriptor. This field is written b<br>the host and unchanged by th<br>chip.                                                                                                                                             |
|           |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 15:12    | ONES      | Must be ones. This field is set b<br>the host and unchanged by th<br>chip.                                                                                                                                                                                                                  |
| Bit       | Name      | Description<br>This bit indicates that the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Transmit | Message [ | Descriptor 2 (TMD <sub>2</sub> )                                                                                                                                                                                                                                                            |
| 15        | OWN       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |           | BC                                                                                                                                                                                                                                                                                          |
| 14        | ERR       | ERROR summary is the "OR" of<br>LCOL, LCAR, UFLO or RTRY.<br>ERR is set by the chip and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |           |                                                                                                                                                                                                                                                                                             |

| Bit              | Name                                                                                                                                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                        | Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Name           | Description                                                                                                                                                                                                                                                                                                                                            |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:00            | BCNT                                                                                                                                                                                        | BUFFER BYTE COUNT is the usable length in bytes of the                                                                                                                                                                                                                                                                                                                                                             | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RES            | RESERVED bit. The chip will write this bit with a "0."                                                                                                                                                                                                                                                                                                 |
|                  |                                                                                                                                                                                             | buffer pointed to by this<br>descriptor expressed as a two's<br>complement number. This is the<br>number of bytes from this buffer<br>that will be transmitted by the<br>chip. This field is written by the<br>host and unchanged by the chip.                                                                                                                                                                     | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | LCOL           | LATE COLLISION indicates that<br>a collision has occurred after the<br>slot time of the channel has<br>elapsed. The chip does not retry<br>on late collisions. LCOL is set by<br>the chip and cleared by the host.                                                                                                                                     |
| Fransmit I       | Message (<br>N 9                                                                                                                                                                            | The first buffer of a packet has to<br>be at least 100 bytes minimum<br>when data chaining and 64 bytes<br>(DTCR = 1) or 60 bytes<br>(DCTR = 0) when not data<br>chaining.<br>Descriptor 3 (TMD <sub>3</sub> )                                                                                                                                                                                                     | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | LCAR           | LOSS OF CARRIER is set when<br>the carrier input (RENA) to the<br>chip goes false during a chip-<br>initiated transmission. The chip<br>does not retry upon loss of<br>carrier. It will continue to transmit<br>the whole packet until done.<br>LCAR is not valid in INTERNAL<br>LOOPBACK MODE. LCAR is set<br>by the chip and cleared by the<br>host. |
|                  |                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                    | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RTRY           | RETRY ERROR indicates that<br>the transmitter has failed in 16<br>attempts to successfully transmit<br>a message due to repeated<br>collisions on the medium. If<br>DRTY = 1 in the MODE register,<br>RTRY will set after 1 failed<br>transmission attempt. RTRY is<br>set by the chip and cleared by the<br>host.                                     |
| <b>Bit</b><br>15 | Name<br>BUFF                                                                                                                                                                                | Description<br>BUFFER ERROR is set by the<br>chip during transmission when<br>the chip does not find the ENP<br>flag in the current buffer and does<br>not own the next buffer. This can<br>occur in either of two ways: either<br>the OWN bit of the next buffer is<br>zero, or SILO underflow occurred<br>before the chip received the next<br>STATUS signal. BUFF is set by<br>the chip and cleared by the host |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TDR<br>D DESCR |                                                                                                                                                                                                                                                                                                                                                        |
|                  |                                                                                                                                                                                             | BUFF error will turn off the transmitter (CSR <sub>0</sub> , TXON = 0)                                                                                                                                                                                                                                                                                                                                             | RING AC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CESS ME        | CHANISM IN THE                                                                                                                                                                                                                                                                                                                                         |
|                  |                                                                                                                                                                                             | If a Buffer Error occurs, an<br>Underflow Error will also occur<br>internally in the SILO. An<br>Underflow Error will not be<br>reported in the descriptor status                                                                                                                                                                                                                                                  | and started, the CPU and the LANCE commu<br>transmit and receive rings, for packet transmi<br>reception.                                                                                                                                                                                                                                                                                                                                                                                                                 |                |                                                                                                                                                                                                                                                                                                                                                        |
|                  | time.<br>There are 2 sets of RAM locations (four 16<br>corresponding to the 4 entries in each<br>LANCE. The first set points to the current<br>the working registers which are used for the |                                                                                                                                                                                                                                                                                                                                                                                                                    | entries in each descriptor) in the<br>ts to the current buffer, and they are                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |                                                                                                                                                                                                                                                                                                                                                        |
| 14               | UFLO                                                                                                                                                                                        | UNDERFLOW ERROR indicates<br>that the transmitter has truncated<br>a message due to data late from<br>memory. UFLO indicates that the                                                                                                                                                                                                                                                                              | for the packet. The second set contains the pointe<br>next buffer in the ring which the LANCE obtained<br>lookahead operation.<br>There are three types of ring access in the LANCE,<br>type is when the LANCE polls the rings to own a bi<br>second type is when the buffers are data chained. Th<br>does a lookahead operation between the time<br>transferring data to/from the SILO; this lookahead<br>only once. The third type is when the LANCE tries to<br>next descriptor in the ring when it clears the OWN to |                | hich the LANCE obtained from the                                                                                                                                                                                                                                                                                                                       |
|                  |                                                                                                                                                                                             | SILO has emptied before the end<br>of the packet was reached.<br>Upon UFLO error, transmitter is                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                | polls the rings to own a buffer. The<br>uffers are data chained. The LANCE                                                                                                                                                                                                                                                                             |
|                  |                                                                                                                                                                                             | turned off (CSR <sub>0</sub> , TXON = 0).<br>UFLO is set by the chip and                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                | the SILO; this lookahead is done                                                                                                                                                                                                                                                                                                                       |

#### **Transmit Ring Buffer Management**

When there is no Ethernet activity, the LANCE will automatically poll the transmit ring in the memory once it has started (CSR<sub>0</sub>, STRT = 1). This polling occurs every 1.6ms, (CSR<sub>0</sub> TDMD bit = 0) and consists of reading the status word of the transmit Ring, TMD<sub>1</sub>, until the LANCE owns the descriptor. The LANCE will read TMD<sub>0</sub> and TMD<sub>2</sub> to get the rest of the buffer address and the buffer byte count when it owns the descriptor. Each of these memory reads is done separately with a new arbitration cycle for each transfer.

If the transmit buffers are data chained (current buffer ENP = 0), the LANCE will lookahead the next descriptor in the ring while transferring the current buffer into the SILO (see Figure 8a). The LANCE does this lookahead only once. If it does not own the next transmit Descriptor Table Entry (DTE) (2nd Tx ring for this packet) it will transmit the current buffer and updates the status of current Ring with the BUFF and UFLO error bits set. If the LANCE owns the 2nd DTE, it will also read the buffer address and the buffer byte count of this entry. Once the LANCE has finished emptying the current buffer, it clears the OWN bit for this buffer, and immediately starts loading the SILO from the next (2nd) buffer. Between DMA bursts, starting from the 2nd buffer, the LANCE does a lookahead again to check if it owns the next (3rd) buffer. This activity goes on until the last transmit DTE indicates the end of the packet (TMD1, ENP = .1). Once the last part of the packet has been transmitted out from the SILO to the cable, the LANCE will update the status in TMD1, TMD3 (TMD3 is updated only when there is an error) and relinquishes the last buffer to the CPU. The LANCE tries to own the next buffer (first buffer of the next packet), immediately after it relinquishes the last buffer of the current packet. This guarantees the back-to-back transmission of the packets. If the LANCE does not own the next buffer, it then polls the Tx ring every 1.6ms.

When an error occurs before all of the buffers get transmitted, the status, TMD<sub>3</sub>, is updated in the current DTE, own bit is cleared in TMD<sub>1</sub>, and TINT bit is set in CSR<sub>0</sub> which causes an interrupt if INEA = 1. The LANCE will then skip over the rest of the descriptors for this packet (clears the OWN bit and sets the TINT bit in CSR<sub>0</sub>) until it finds a buffer with both the STP and OWN bit being set (it indicates the first buffer for the next packet).

When the transmit buffers are not data chained (current descriptor's ENP = 1), the LANCE will not perform any lookahead operation. It will transmit the current buffer, update the TMD<sub>3</sub> if any error, and then update the status and clear the OWN bit in TMD<sub>1</sub>. The LANCE will then immediately check the next descriptor in the ring to see if it owns it. If it does, the LANCE will also read the rest of the entries from the descriptor table. If the LANCE does not own it, it will poll the ring once every 1.6ms until it owns it. User may set the TDMD bit in CSR<sub>0</sub> when it has relinquished a buffer to the LANCE. This will force the LANCE to check the OWN bit at this buffer without waiting for the polling time to elapse.

#### **Receive Ring Buffer Management**

Receive Ring access is similar to the transmit ring access. Once receiver is enabled, the LANCE will always try to have a receive buffer available, should there be a packet addressed to this node for reception. Therefore, when a packet has not arrived, the LANCE will poll the receive ring entry, once every 1.6ms, until it owns the current receive DTE. Once the LANCE owns the buffer, it will read RMD<sub>0</sub> and RMD<sub>2</sub> to get the rest of buffer address and buffer byte count. When the packet arrives from the cable, the LANCE will first check to see if it owns a buffer. If not, it will poll the receive ring once for a buffer. If it does not own the buffer, it will set the MISS error in CSR<sub>0</sub> and will not poll the receive ring until the packet ends.

Assuming the LANCE owns a receive buffer when the packet arrives, it will perform a lookahead operation on the next DTE between periods when it is dumping the received data from the SILO to the first receive buffer in case the current buffer requires data chaining. When the LANCE owns the buffer, the lookahead operation consists of 3 separate single word DMA reads: RMD1, RMD0, and RMD2. When the LANCE does not own the next buffer, the lookahead operation consists of only one single DMA read, RMD1. Either lookahead operation is done only once. Following the lookahead operation, whether LANCE owns the next buffer or not, the LANCE will transfer the data from SILO to the first receive buffer of this packet in burst mode (8 word transfer per one DMA cycle arbitration).

If the packet being received requires data chaining, and the LANCE does not own the 2nd DTE, the LANCE will update the current buffer status, RMD<sub>1</sub>, with the BUFF and/or OVFL error bits set. If the LANCE does own the next buffer (2nd DTE) from previous lookahead, the LANCE will relinquish the current buffer and start filling up the 2nd buffer for this packet. Between the time that the LANCE is transferring data from the SILO to 2nd buffer, it does a lookahead operation again to see if it owns the next (3rd) buffer. If the LANCE does own the third DTE, it will also read RMD<sub>0</sub>, and RMD<sub>2</sub> to get the rest of buffer pointer address and buffer byte count.

This activity continues on until the LANCE recognizes the end of the packet (cable is idle); it then updates the current buffer status with the end of packet bit (ENP) set. The LANCE will also update the message byte count (RMD<sub>3</sub>) with the total number of bytes received for this packet in the current buffer (the last buffer for this packet).



Figure 8a. Data Chaining (Transmit)



#### Figure 8b. Buffer Management Descriptor Rings

Notes: 1. W, X, Y, Z are the packets queued for transmission. 2. A, B, C, D are the packets received by the LANCE.

# LANCE DMA TRANSFER (BUS MASTER MODE)

There are two types of DMA Transfers with the LANCE:

- Burst mode DMA

- Single word DMA

## **Burst Mode DMA**

Burst DMA is used for Transmission or Reception of the Packets, (Read/Write from/to Memory).

The Burst Transfers are 8 consecutive word reads (transmit) or writes (receive) that are done on a single bus arbitration cycle. In other words, once the LANCE receives the bus acknowledge, (HLDA = Low), it will do 8 word transfers (8 DMA cycle, min. at 600ns per cycle) without releasing the bus request signal (HOLD = Low). If there are more than 16 bytes empty in the SILO, in transmit mode, or at least 16 bytes of data, in the SILO in receive mode, when the LANCE releases the bus (HOLD deasserted), the LANCE will request the bus again within 700ns. (HOLD dwell time). Burst DMAs are always 8 cycle transfers unless there are less than 8 words left to be transferred in to/from the SILO.

## Single Word DMA Transfer

The LANCE initiates single word DMA transfers to access the transmit, receive rings or initialization block. The LANCE will not initiate any burst DMA transfer between the time that it gets to own the descriptor, and accessing the descriptor entries in the ring (an average of 3 – 4 separate DMA cycles for a multibuffer packet) or reading the initialization block.

## SILO OPERATION

The SILO provides temporary buffer storage for data being transferred between the parallel bus I/O pins and serial bus I/O pins. The capacity of the SILO is 48 bytes.

#### Transmit

Data is loaded into the SILO under internal microprogram control. SILO has to be more than 16 bytes empty before the LANCE requests the bus ( $\overline{HOLD}$  is asserted). The LANCE will start sending the preamble (if the line is idle) as soon as the first byte is loaded to the SILO from memory. Should transmitter be required to back off, there could be up to 32 bytes of data in the SILO ready for transmission. Reception has priority over transmission during the time that the transmitter is backing off.

## Receive

Data is loaded into the SILO from the serial input shift register during reception. Data leaves the SILO under microprogram control. The LANCE microcode will wait until there are at least 16 bytes of data in the SILO before initiating a DMA burst transfer. Preamble (including the synch) is not loaded into the SILO.

Note: SILO is used as an alternative name for FIFO.

## SILO - Memory Byte Alignment

Memory buffers may begin and end on arbitrary byte boundaries. Parallel data is byte aligned between the SILO and DAL lines (DAL0-DAL15). Byte alignment can be reversed by setting the Byte Swap (BSWP) bit in CSR3.

TRANSMISSION - WORD READ FROM EVEN MEMORY ADDRESS

| BSWP = 0: | SILO BYTE n     | gets DAL | <07:00> |
|-----------|-----------------|----------|---------|
|           | SILO BYTE n + 1 | gets DAL | <15:08> |
| BSWP = 1: | SILO BYTE n     | gets DAL | <15:08> |
|           | SILO BYTE n + 1 | gets DAL | <07:00> |

TRANSMISSION - BYTE READ FROM EVEN MEMORY ADDRESS BSWP = 0: SILO BYTE n gets DAL <07:00> BSWP = 1: SILO BYTE n gets DAL <15:08> TRANSMISSION - BYTE READ FROM ODD MEMORY

BSWP = 0: SILO BYTE n gets DAL <15:08> BSWP = 1: SILO BYTE n gets DAL <07:00> RECEPTION - WORD WRITE TO EVEN MEMORY AD-DRESS

BSWP = 0: DAL <07:00> gets SILO BYTE n BSWP = 1: DAL <15:08> gets SILO BYTE n + 1 RECEPTION - BYTE WRITE TO EVEN MEMORY AD-

BSWP = 0: DAL <07:00> gets SILO BYTE n DAL <15:08> - don't care

DAL <15:08> - don't care BSWP = 1: DAL <15:08> gtes SILO BYTE n DAL <07:00> - don't care

RECEPTION - BYTE WRITE TO ODD MEMORY ADDRESS

 BSWP = 0:
 DAL
 <07:00> - don't care

 DAL
 <15:08> gets SILO BYTE n

 BSWP = 1:
 DAL
 <15:08> - don't care

 DAL
 <07:00> gets SILO BYTE n

# THE LANCE RECOVERY AND REINITIALIZATION

The transmitter and receiver section of the LANCE are turned on via the initialization block (MODE REG: DRX, DTX bits). The state of the transmitter and the receiver are monitored through the CSR<sub>0</sub> register (RXON, TXON bits). The LANCE must be reinitialized if the transmitter and/or the receiver has not been turned on during the original initialization, and later it is desired to have them turned on. Another reason why it may be desirable to reinitialize the LANCE, to turn the transmitter and/or receiver back on again, is when either section shuts off because of an error (MERR, UFLO, TX BUFF error). Care must be taken when the LANCE is reinitialized. The user should rearrange the descriptors in the transmit or receiver ing prior to reinitialization. This is necessary since the transmit and receive descriptor pointers are reset to the beginning of the ring upon initialization.

Another way of starting the LANCE, once it has stopped (STOP = 0 in  $CSR_0$ ), is by setting the STRT bit in  $CSR_0$ . The STRT puts the LANCE in operation in accordance with the

parameters set up in the mode register. If DTX and/or DRX are set to 0 in the mode register, the transmitter and/or receiver will be turned on again when STRT bit is set.

This approach may look like an easier task than the reinitialization mechanism, where the user is required to rearrange the descriptors in the ring. However, this approach is not recommended when the LANCE is stopped in the middle of a transmission or reception, or when the buffers are data chained.

To reinitialize the LANCE, the user must stop the LANCE by setting the stop bit in CSR<sub>0</sub> prior to reinitialization (setting INIT bit in CSR<sub>0</sub>). The user needs to reprogram the CSR<sub>3</sub> because its content gets cleared when the stop bit gets set (soft reset). CSR<sub>3</sub> reprogramming is not needed when default values BCON, ACON, and BSWP are used. CSR<sub>1</sub> and CSR<sub>2</sub> are not affected by STOP bit; however, it is recommended that CSR<sub>1</sub> and CSR<sub>2</sub> be reloaded when the STOP bit is set.

## FRAME FORMATTING

The LANCE performs the encapsulation/decapsulation function of the data link layer (2nd layer of ISO model) as follows:

## Transmit

In transmit mode, the user must supply the destination address, source address, and Type Field (or Length Field) as a part of data in transmit data buffer memory. The LANCE will append the preamble, synch, and CRC (FCS) to the frame as is shown in Figures 9a and 9b.

#### Receive

In receive mode, the LANCE strips off the preamble and synch bits and transfers the rest of the frame, including the CRC bytes (4 bytes), to the memory. The LANCE will discard packets with less than 64 bytes (runt packet) and will reuse the receive buffer for the next packet. This is the only case where the packet is discarded. Runt packet is normally the result of a collision.

| PREAMBLE<br>1010 1010 | SYNCH<br>1 1 | DEST<br>ADR | SOURCE<br>ADR | туре       | DATA               | FCS                   |
|-----------------------|--------------|-------------|---------------|------------|--------------------|-----------------------|
| 64<br>Bats            | 2<br>Bits    | 6<br>BYTES  | 6<br>BYTES    | 2<br>BYTES | 46 - 1500<br>BYTES | 4<br>BYTES<br>DF00187 |

Figure 9a. Ethernet Frame Format



Figure 9b. IEEE 802.3 MAC Frame Format

## FRAMING ERROR (DRIBBLING BITS)

The LANCE can handle up to 7 dribbling bits when a received packet terminates; the input to the LANCE, RCLK, stops, following the deassertion of RENA. During the reception, the CRC is generated on every serial bit (including the dribbling bits) coming from the cable, and it gets stored internally on byte boundary. The framing error is reported to the user as tollows:

-If the number of the dribbling bits are 1 to 7 bits and there is no CRC error, then there is no Framing error (FRAM = 0). -If the number of the dribbling bits are less than 8 and there is a CRC error, then there is also a Framing error (FRAM = 1).

-If the number of the dribbling bits = 0, then there is no Framing error. There may or may not be a CRC error.

## INTERPACKET GAP TIME (IPG)

The interpacket gap time for back-to-back transmission is 9.6 to 10.6 microseconds, including synchronization. The interpacket delay interval begins immediately after the negation of the RENA signal. During the first 4.1 µs of the IPG, RENA activity is masked off internally in the LANCE. If RENA is asserted and remains asserted during the first 4.1 µs of IPG following a receive, the LANCE will defer to the packet (it will not receive it). If this condition occurs following a transmit, the LANCE will start to look for the synch bits (011) about 800ns (8 bit time) after the 4.1 µs window has elapsed. Therefore, the packet may be received correctly if at least 8 bits of the preamble are left following the 4.1 µs window, or the received packet may contain CRC error (not enough preamble bits left, LANCE may be locking to the synch bits in the middle of data), or the received packet may be discarded because of the runt packet (the data loss during the 4.1µs window).

If RENA is asserted after 4.1 $\mu$ s window, the LANCE will treat this as start of a new packet. It will start to look for the synch bits (011) after 8 bit time RENA becomes active. Whenever the LANCE is about to transmit and is waiting for the interpacket delay to elapse, it will begin transmission immediately after the interpacket delay interval, independent of the state of RENA. However, RENA must be asserted during the itme that TENA is high. The LCAR (loss of carrier) error bit is otherwise set in TMD<sub>3</sub>, after the packet has been transmitted.

# COLLISION DETECTION AND COLLISION JAM

Collisions are detected by monitoring the CLSN 1/O pin. If CLSN becomes asserted during a frame transmission, TENA will remain asserted for at least 32 (but not more than 40) additional bit times (including CLSN synchronization). This additional transmission after collision is referred to as COLLI-SION JAM. If collision occurs during the transmission of the preamble, the LANCE continues to send the preamble, and sends the JAM pattern following the preamble. If collision occurs after the preamble, the LANCE will send the JAM pattern following the transmission of the current byte. The JAM pattern is any pattern except the CRC bytes.

## **RECEIVE BASED COLLISION**

If CLSN becomes asserted during the reception of a packet, this reception is immediately terminated. Depending on the timing of COLLISION DETECTION, the following will occur. A collision that occurs within 6 byte times (4.8ms) will result in the packet being rejected because of an address mismatch with the SILO write pointer being reset. A collision that occurs within 64 byte times (51.2ms) will result in the packet being rejected since it is a runt packet. A collision that occurs after 64 byte times (late collision) will result in a truncated packet being written to the memory buffer with the CRC error bit most likely being set in the Status Word of the Receive Ring. Late collision error is not recognized in receive mode.

## TRANSMIT BASED COLLISION

When a transmission attempt has been terminated due to the assertion of CLSN, (a collision that occurs within 64 byte times), the LANCE will attempt to retrieve it 15 more times. The LANCE does not try to reread the descriptor entries from the T<sub>X</sub> ring upon each collision. The descriptor entries for the current buffer are internally saved. The scheduling of the

retransmissions is determined by a controlled randomized process called "truncated binary exponential backoff." Upon the negation of the COLLISION JAM interval, the LANCE calculates a delay before retransmitting. The delay is an integral multiple of the SLOT TIME. The SLOT TIME is 512 bit times. The number of SLOT TIMEs to delay before the nth retransmission is chosen as a uniformly distributed random integer in the range:  $0 \le r \le 2^k$  where k = min (n, 10).

If all 16 attempts fail, the LANCE sets the RTRY bit in the current Transmit Message Descriptor 3, TMD<sub>3</sub>, in memory, gives up ownership (sets the own bit to zero) for this packet, and processes the next packet in transmit ring for transmission. If there is a late collision (collision occurring after 64 byte times), the LANCE will not transmit again; it will terminate the transmission, note the LCOL error in TMD<sub>3</sub>, and transmit the next packet in the ring.

#### **COLLISION - MICROCODE INTERACTION**

The microprogram uses the time provided by COLLISION JAM, INTERPACKET DELAY, and the backoff interval to restore the address and byte counts internally and starts loading the SILO in anticipation of retransmission. It is important that LANCE be ready to transmit when the backoff interval elapses to utilize the channel property.

## TIME DOMAIN REFLECTOMETRY

The LANCE contains a time domain reflectometry counter. The TDR counter is ten bits wide. It counts at a 10MHz rate. It is cleared by the microprogram and counts upon the assertion of RENA during transmission. Counting ceases if CLSN becomes true, or RENA goes inactive. The counter does not wrap around; once all ONEs are reached in the counter, that value is held until cleared. The value in the TDR is written into memory following the transmission of the packet. TDR is used to determine the location of suspected cable faults.

## HEARTBEAT

During the INTERPACKET DELAY following the negation of TENA, the CLSN input is asserted by some transceivers as a self-test. If the CLSN input is not asserted within  $2\mu$ s following the completion of transmission (after TENA goes low), then the LANCE will set the CERR bit in CSR<sub>0</sub>. CERR error will not cause an interrupt to occur (INTR = 0).

## CYCLIC REDUNDANCY CHECK (CRC)

The LANCE utilizes the 32 bit CRC function used in the Autodin-II network. Refer to the Ethernet specification (section 6.2.4 Frame Check Sequence Field and Appendix C; CRC Implementation) for more detail. The LANCE requirements for the CRC logic are the following:

- TRANSMISSION MODE <02> LOOP = 0, MODE <03> DTCR = 0. The LANCE calculates the CRC from the first bit following the Start bit to the last bit of the data field. The CRC value inverted is appended onto the transmission in one unbroken bit stream.
- 2. RECEPTION MODE <02> LOOP = 0. The LANCE performs a check on the input bit stream from the first bit following the Start bit to the last bit in the frame. The LANCE continually samples the state of the CRC check on framed byte boundaries, and, when the incoming bit stream stops, the last sample determines the state of the CRC error. Framing error (FRAM) is not reported if there is no CRC error.
- 3. LOOPBACK MODE <02> LOOP = 1, MODE <03> DTRC = 0. The LANCE generates and appends the CRC

value to the outgoing bit stream as in Transmission but does not perform the CRC check of the incoming bit stream.

4. LOOPBACK - MODE <02> LOOP = 1 MODE <03> DTRC = 1. LANCE performs the CRC check on the incoming bit stream as in Reception, but does not generate or append the CRC value to the outgoing bit stream during transmission.

## LOOPBACK

The normal operation of the LANCE is as a half-duplex device. However, to provide an on-line operational test of the LANCE, a pseudo-full duplex mode is provided. In this mode simultaneous transmission and reception of a loopback packet are enabled with the following constraints:

- 1. The packet length must be no longer than 32 bytes, and less than eight bytes, exclusive of the CRC.
- 2. Serial transmission does not begin until the SILO contains the entire output packet.
- 3. Moving the input packet from the SILO to the memory does not begin until the serial input bit stream terminates.
- 4. CRC may be generated and appended to the output serial bit stream or may be checked on the input serial bit stream, but not both in the same transaction.
- 5. In internal loopback, the packets should be addressed to the node itself.
- In external loopback, multicast addressing can be used only when DTCR ≠ 1 is in the mode register. In this case, the user needs to append the bytes CRC.

Loopback is controlled by bits <06, 03, 02> INTL, DTCR, and LOOP of the MODE register.

## SERIAL TRANSMISSION

Serial transmission consists of sending an unbroken bit stream from the  $T_X + I/O$  pin consisting of:

- 1. Preamble/Start bit: 62 alternating ONES and ZEROES terminating with the synch in two ONEs. The last ONE is the Start bit.
- 2. Data: The senalized byte stream from the SILO Shifted out with LSB first.
- 3. CRC: The inverted 32 bit polynomial calculated from the Data, address, and type field CRC is not transmitted if:
- i. Transmission of the Data field is truncated for any reason.
- ii. CLSN becomes asserted any time during transmission.
- iii. MODE <03> DTCR = 1 in a normal or loopback transmission mode.

The Transmission is indicated at the I/O pin by the assertion of TENA with the first bit of the preamble and the negation of TENA after the last transmitted bit.

The LANCE starts transmitting the preamble when the following are satisfied:

1. There is at least one byte of data to be transmitted in the SILO.

2. The interpacket delay has elapsed.

3. The backoff interval has elapsed, if a retransmission.

## SERIAL RECEPTION

Serial reception consists of receiving an unbroken bit stream on the R\_X I/O pin consisting of:

- Preamble/Start bit: Two ONES occurring a minimum of 8 bit times after the assertion of RENA. The last ONE is the Start bit.
- 2. Destination Address: The 48 bits (6 bytes) following the Start bit.
- 3. Data: The serialized byte stream following the Destination Address. The last 4 complete bytes of data are the CRC. The Destination Address and the Data are framed into bytes and enter the SILO. Source Address and Type field are part of the data which are transparent to the LANCE.

Reception is indicated at the I/O pin by the assertion of RENA and the presence of clock on RCLK while TENA is inactive. The LANCE does not not sample the received data until about 800ns after RENA goes high.

## MICROPROGRAM OVERVIEW

The Ethernet protocol chip is controlled by a set of semiindependent hardware functions and a microprogram. The following are some of the routines associated with the operation of the LANCE.

## Switch Routine

Upon power-up, the microprogram finds itself in a routine to evaluate the INIT, STRT, and STOP bits of CSR<sub>0</sub>. INIT and STRT are cleared and STOP is set by the hardware by Bus RESET. Setting either INIT or STRT through an I/O transfer to CSR<sub>0</sub> will clear STOP. Setting STOP through an I/O transfer to microprogram tests the state of INIT. If set, it branches to the initialization routine, returns, and tests the state of STRT. If INIT is clear and the STRT is set, the microprogram will go on to the Polling routine without going to the Initialization routine. If, while the STOP bit is set, an I/O transfer to CSR<sub>1</sub>, CSR<sub>2</sub>, or CSR<sub>3</sub> occurs, the microprogram traps to the CSR service routine.

#### **initialization Routine**

This routine is entered only from the switch routine upon the setting of the INIT bit. Its function is to load the Chip with the data from the initialization block in memory. The routine accesses the initialization block through the address loaded into the LANCE by a trap to  $CSR_1$  and  $CSR_2$  that should have occurred prior to the INIT bit being set. This routine simply sequentially reads the initialization block, in separate single word DMA cycles, and stores the information away in the appropriate elements of the Chip.

When done, the microcode returns to the switch routine

#### **Polling Routine**

This routine is entered from:

- 1. The switch routine upon the setting of the STRT bit.
- 2. The receive routine after a packet has been received.
- 3. The transmit routine after a packet has been transmitted.
- 4. The transmit routine if a TX Abort occurs.
- The Memory Error Trap routine (MERR error) after the trap is serviced.

The routine begins by testing to see if the receiver is disabled, and, if not, tests the current receiver buffer ownership bit to see if it owns a buffer. If the Chip had not acquired a buffer previously, the microprogram goes to the receive polling routine to acquire one. Then the microprogram returns from the receive polling routine, or if the Chip had acquired a buffer previously, it tests to see if the transmitter is disabled, and if not, goes to the transmit polling routine to test if there is a buffer to be transmitted. When the microprogram returns from the transmit polling routine, the microprogram enters a timing loop, and repeats the routine upon timeout. The timer is set around 1.6ms. The timing loop can be overridden by setting the TDMD bit in CSR0. This will force the microprogram to fall through the wait loop. The TDMD bit is cleared immediately after leaving the wait loop. Therefore, to be effective, TDMD should be set after a buffer has been inserted on the transmit ring (own bit has been set).

During this routine, should the receiver become active, the microprogram traps to the receive routine.

## **Receive Polling Routine**

The Receive Polling Routine is called by the main polling routine to check to see if the chip owns the receive buffer at the current pointer address. The microprogram first reads the status word from the current receive ring descriptor. If the chip does not own the buffer, the microprogram returns to the polling routine. If the chip does own the buffer, the microprogram reads in the rest of the descriptor entry, namely the rest of the buffer address and the buffer byte count. The chip only reads in 3 of the 4 words in the descriptor entry. The message byte count is not read because it is not used by the chip. The message byte count is written by the chip during the status update at the end of a reception. This routine will then return to the polling routine.

#### **Receive Routine**

The Receive Routine is entered when the receiver is enabled and the address of the incoming packet has passed address recognition. Once the Receive Routine is entered, the microprogram checks to see if the chip owns the current receive buffer. If it does not own the buffer, the microprogram will check the ownership bit in memory once for a buffer. If it does not own the buffer, the microprogram will set the miss error in  $CSR_0$  and clear the SILO. The microprogram will then return to the polling routine once the current packet ends.

If the chip acquired buffer ownership while the receiver was still active, the microprogram will acquire the rest of the descriptor, namely the buffer address and buffer length. The microprogram will then back up the buffer address and byte count in case the packet is a runt. This is where the microprogram would have come if it had owned a receive buffer when it originally entered the receive routine.

#### **Receive Buffer Lookahead**

Receive lookahead is always done during the reception since the LANCE will not know the length of the receive packet. The lookahead is done during the time that SILO is being filled with data from the cable. The microprogram checks to see if there was only one receive buffer. If there is more than one receive buffer, the microprogram checks the ownership of the next buffer. If the chip owns the buffer, it reads the rest of the Descriptor into the internal RAM. If it does not own the buffer, it will continue with the receive routine, trapping to the RX DMA routine whenever there are 16 or more bytes available in the SILO. Lookahead is only done once whenever there is a trap to the receive routine.

When the LANCE does not own the next buffer and receive is still active after the current buffer is filled, the LANCE will update the status with BUFF error being set. OFLO (overflow) error may also get set if SILO overflows.

#### **Receive Done**

When receiver goes inactive (Done), the last byte of data has been read out of the SILO. The microprogram will check to see if the packet was a runt. If it is a runt, the receive buffer address pointer and byte count parameters are restored from the previously loaded backup locations in the internal RAM. The microprogram then returns to the Polling routine. If the packet is not a runt, the receive status is updated in the ring descriptor.

## **Data Chain**

If Byte Count of Current Buffer Equal 0 becomes true, it indicates that the receive buffer is full and the packet is not yet finished, which is the data chain case. The microprogram will update the receive status in the descriptor ring, and relinquish the buffer to the CPU. It will then check the next own bit. If the next own is false, which would be the case if there was only one buffer or if there was more than one buffer but the chip did not own the next one, the microprogram will wait for the receiver to go inactive. This indicates that no more data is arriving from the Ethernet. When the receiver goes inactive, the current RX status is updated, and the own bit is cleared.

If the chip owned the next buffer, the current receive buffer parameters in the internal RAM are updated from the next receive buffer parameters that had previously been loaded into the internal RAM. The microprogram will then check for end of the ring and update the address pointers accordingly. The microprogram will then go through the receive buffer lookahead section once, to try to acquire another receive buffer if one is available. The microprogram will finally get back to the wait loop until either receiver goes inactive, SILO overflow, or receive buffer overflow becomes true. There are two flags provided in the descriptor, STP (Start of Packet), and ENP (End of Packet), which allow the chip to mark the first and last buffers filled by the message. RMD3 is not updated if its buffer is not the last buffer in the chain.

## **Receive DMA Routine**

The Receive DMA routine is entered whenever there are 16 or more bytes of data in the SILO for transfer to memory during the reception. The routine is also entered when there are less than 16 bytes in the SILO and the receiver has gone inactive. This is to allow the SILO to empty at the end of the reception. Once entered, the Receive DMA routine will transfer 16 bytes of data to memory by doing 8 word transfers. These transfers are done on a single memory bus acquisition. This means that the chip will arbitrate through the HOLD-HLDA sequence and then keep HOLD asserted for the duration of 8 transfers. The READY signal from the bus slave device is used to control the individual word transfers.

If the memory buffer starts on an odd address boundary, the first transfer will be 1 byte rather than 1 word (2 bytes). This routine is also used to transfer less than 16 bytes at the end of a reception depending upon the packet size, buffer addresses and data chaining

#### **Transmit Polling Routine**

The transmit polling routine is entered from the polling routine to determine if a message has been scheduled on the transmit descriptor ring.

The routine begins by waiting for the TX Abort condition to finish if a TX Abort had occurred earlier. It then tests the status word of the ring descriptor entry. The routine tests the ownership of the ring buffer by reading the status word in the ring descriptor. If the Chip does not own the buffer, the microprogram returns to the polling routine. If it does own the buffer, this indicates a message is to be transmitted. The microprogram then tests the STP flag. If STP = 0, this buffer could be a fragment of a data chained packet that got an error in a previous buffer. The chip will release the buffer to the host by clearing the OWN bit. It will then update the ring address pointer and return to polling. In this manner, the chip skips

over any bad transmit buffers on the ring, until it finds a buffer with both the OWN and STP bit being set.

If STP = 1, the microprogram performs memory transactions to acquire and store the address and byte count of the buffer in the Internal RAM. It then goes to the transmit routine to allow the transmission of the buffer.

The receive active trap is enabled during this routine to allow for processing of an incoming packet and termination of the transmit process.

## **Transmit Routine**

The transmit routine is entered from the transmit polling routine when the microcode finds a buffer that it owns, indicating a message is scheduled to be transmitted. The routine is divided into three sections of microprogram, an initialization section, a buffer lookahead section, and a descriptor update section.

Upon entering the initialization section, the first thing the microprogram does is back up the buffer address and byte count in the event of a retry. It then enables the DMA engine to start filling the SILO and send the preamble. It then enters a wait loop until the transmitter is actually sending the bit stream. It then proceeds to the lookahead section. If the receiver became active while the microprogram was waiting for the transmitter to start, the transmission attempt is stopped and the microprogram goes to the receive routine via a TRAP.

#### Transmit Buffer Lookahead

Transmit lookahead occurs only when data chaining, and is done while the message is being transmitted from the SILO. In the lookahead section, the microprogram tests to determine if the current buffer it is transmitting has been marked with the end of the packet flag (ENP). If so, data chaining is not required. The microprogram enters a wait loop until either TX ERROR or TX DONE occurs. When DONE or ERROR or both finally set, the microprogram will report the error, if necessary, and then update the status word, update the nng address pointer and set the TINT bit in CSR<sub>0</sub>. It will then return to the polling routine.

## Transmit Data Chaining

There are two flags provided in transmit message descriptor 1 (TMD1), STP (Start of Packet) and ENP (End of Packet) which mark the first and last buffers in the chain. The LANCE will, under microprogram control, continue to chain buffers pointed to by the sequential descriptors in the ring until the ENP flag is encountered. If the end of packet flag (ENP) is not set, data chaining is indicated. The microprogram first checks to see if it owns the next buffer. If not, the microprogram enters the descriptor update section and waits for TX DONE or TX ERROR. Eventually, an underflow error will occur because byte count overflow will occur without DONE having been set. Since there is no more data being written into the SILO and the transmitter is continuously reading data out of the SILO. the SILO will become empty and underflow will be set. This will cause the microprogram to branch out of the wait loop and update the descriptor with both BUFF and OVFL being set. When an underflow error occurs, the transmitter is disabled.

The LANCE owns the next buffer, the microprogram attempts to obtain the next buffer descriptor status, address, and byte count before entering a wait loop that looks for byte count overflow or TX ERROR. When byte count overflow does occur, the microprogram updates the descriptor and updates the internal current transmit buffer parameters. The microprogram will then return to the microcode that checks for the end of packet flag to sequence through the rest of the buffers in the data chain. If an error had occurred, the microprogram would report the error before updating the status word.

If an error needs to be reported, an error status word is written into the ring descriptor prior to writing the status word containing the "OWN" bit which releases the buffer. If no error is to be reported, the single word containing the "OWN" bit is written. The microprogram returns to the polling routine if the "ENP" flag is found or an error was reported. Otherwise, the microprogram returns to the lookahead sections.

## **Transmit DMA Routine**

This routine is entered through a microtrap in the lookahead section of the transmit routine. The function of the routine is to move data out of local memory into the SILO. The trap is active when there are more than 16 free locations in the SILO and SILO underflow has not occurred.

Once entered, the transmit DMA routine will transfer 16 bytes of data from memory to the SILO by doing 8 word transfers. These transfers are done on a single memory bus acquisition. If the memory buffer starts on an odd addressing boundary, the first transfer will be 1 byte rather than 1 word (2 bytes). This routine is also used to transfer less than 16 bytes at the end of transmission depending upon the packet size, buffer addresses, and data chaining.

## Retry Trap Routine

This routine is entered when a collision has been detected. The buffer address pointer is restored and the SILO is cleared to restore the read and write pointers. If there is a TX error, it indicates that 15 retransmissions have occurred (16 total attempts) or that the Disable Retry bit (DRTY) is set in the mode register. The microprogram then writes the status into the transmit descriptor ring, and returns to the polling routine to transmit the next packet. If there is no TX Error, the byte count is restored and the microprogram returns to the start of the transmit routine to attempt another transmission.

#### **CSR Trap Routine**

The CSR trap routine is entered only during the switch routine when the STOP bit of the CSR<sub>0</sub> is set. The function of the routine is to allow the access of CSR<sub>1</sub> and CSR<sub>2</sub> through an I/ O transaction. The routine determines which CSR is being accessed, read or write, moves the data between the MDR and CDP RAM, and generates a Bus READY signal.

## Memory Timeout Trap Routine

This trap is invoked whenever a memory transfer times out. That is, it does not receive READY within  $25.6\mu$ sec after the assertion of the address on the bus.

The routine disables the receiver and transmitter by clearing the RXON and TXON bits in  $CSR_0$ .

## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature                | 65°C to +150°C |
|------------------------------------|----------------|
| Ambient Temperature with           |                |
| Power Applied                      | 25°C to +125°C |
| Supply Voltage to Ground Potential |                |
| Continuous                         | 0.3V to +7V    |
| Power Dissipation                  |                |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

## **OPERATING RANGES**

Commercial (C) Devices

| Temperature     | 0°C to +70°C      |
|-----------------|-------------------|
| Supply Voltage  | .+4.75V to +5.25V |
| V <sub>SS</sub> | OV                |

Operating ranges define those limits over which the functionality of the device is guaranteed.

## DC CHARACTERISTICS $T_A = 0$ to +70°C, $V_{CC} = +5V \pm 5\%$ unless otherwise specified

| Parameters      | Description         | Test Conditions   | Min | Тур | Max                    | Units |
|-----------------|---------------------|-------------------|-----|-----|------------------------|-------|
| VIL             | Input LOW Voltage   |                   | -05 |     | 0.8                    | Volts |
| ViH             | Input HIGH Voltage  |                   | 2   |     | V <sub>CC</sub> + 0.5V | Votts |
| VOL             | Output LOW Voltage  | lot = 3.2mA       |     |     | 0.5                    | Volts |
| VOH             | Output HIGH Voltage | IOH = -0.4mA      | 2.4 | [   |                        | Volts |
| 11L             | Input Leakage       | VIN = 0.4V to VCC |     |     | ± 10                   | μA    |
| GIN             | Input Capacitance   |                   |     |     | 10                     | pF    |
| COUT            | Output Capacitance  | F = 1MHz          |     |     | 10                     | pF    |
| C <sub>10</sub> | Capacitance         |                   | T   |     | 20                     | pF    |



| lumber     | Parameters        | Description                                                                                                               | Test<br>Conditions | Min | Тур  | Max | Uni      |
|------------|-------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------|-----|------|-----|----------|
| 1          | tTCT              | TCLK Period                                                                                                               |                    | 99  |      | 101 | ns       |
| 2          | TCL               | TCLK LOW Time                                                                                                             |                    | 45  |      | 55  | ns       |
| 3          | тсн               | TCLK HIGH Time                                                                                                            |                    | 45  |      | 55  | ns       |
| 4          | TCR               | Rise Time of TCLK                                                                                                         |                    | 0   |      | 8   | ns       |
| 5          | ITCF              | Fall Time of TCLK                                                                                                         |                    | 0   |      | 8   | n        |
| 6          | <b>TEP</b>        | TENA Propagation Delay After the Rising Edge of TCLK                                                                      | CL = 50pF          |     |      | 95  | n        |
| 7          | t <sub>TEH</sub>  | TENA Hold Time After the Rising Edge of TCLK                                                                              | CL = 50pF          | 5   |      |     | n        |
| 8          | 1TDP              | TX Data Propagation Delay After the Rising Edge of TCLK                                                                   | CL = 50pF          |     |      | 95  | n        |
| <u>,</u> 9 | <sup>†</sup> ТОН  | TX Data Hold Time After the Rising Edge of TCLK                                                                           | CL = 50pF          | 5   |      |     | n        |
| 10         | <sup>1</sup> RCT  | RCLK Period                                                                                                               |                    | 85  |      | 118 | n        |
| 11         | 14RCH             | RCLK HIGH Time                                                                                                            |                    | 38  |      |     | n        |
| 12         | TRCL              | RCLK LOW Time                                                                                                             |                    | 38  |      |     | n        |
| 13         | <sup>1</sup> ACR  | Rise Time of RLCK                                                                                                         |                    | 0   |      | 8   | n        |
| 14         | <sup>t</sup> RCF  | Fall Time of RCLK                                                                                                         |                    | 0   |      | 8   | n        |
| 15         | LADA              | RX Data Rise Time                                                                                                         |                    | 0   |      | 8   | · n      |
| 16         | tade.             | RX Data Fall Time                                                                                                         |                    | 0   |      | 8   | n        |
| 17         | TRDH              | RX Data Hold Time (RCLK to RX Data Change)                                                                                |                    | 5   |      |     | n        |
| 18         | TRDS              | RX Data Setup Time (RX Data Stable to the Rising Edge of RCLK)                                                            |                    | 60  |      |     | n        |
| 19         | 1DPL              | RENA LOW Time                                                                                                             |                    | 120 |      |     | n        |
| 20         | 1СРН              | CLSN HIGH Time                                                                                                            |                    | 80  |      |     | n        |
| 21         | <sup>t</sup> DOFF | Bus Master Driver Disable Alter Rising Edge of HOLD                                                                       |                    | 0   |      | 50  | n        |
| 22         | 1DON              | Bus Master Driver Enable After Falling Edge of HLDA                                                                       |                    | 0   |      | 250 | n        |
| 23         | тнна              | Delay to Falling Edge of HLDA from Falling Edge of HOLD<br>(Bus Master)                                                   |                    | 0   |      |     | n        |
| 24         | tew               | RESET Pulse Width LOW                                                                                                     |                    | 200 |      |     | n        |
| 25         | ICYCLE            | Read/Write, Address/Data Cycle Time                                                                                       | ······             | 600 |      |     | n        |
| 26         | TXAS              | Address Setup Time to the Falling Edge of ALE                                                                             |                    | 75  |      |     | n        |
| 27         | 1XAH              | Address Hold Time After the Rising Edge of DAS                                                                            |                    | 35  |      |     | n        |
| 28         | las               | Address Setup Time to the Falling Edge of ALE                                                                             |                    | 75  |      |     | n        |
| 29         | 1 <sub>AH</sub>   | Address Hold Time After the Falling Edge of ALE                                                                           |                    | 35  |      |     | -        |
| 30         | IRDAS             | Data Setup Time to the Rising Edge of DAS (Bus Master Read)                                                               |                    | 50  |      |     | n        |
| 31         | IRDAH             | Data Hold Time After the Rising Edge of DAS (Bus Master Read)                                                             |                    | 0   |      |     | n        |
| 32         | IDDAS             | Data Setup Time to the falling Edge of DAS (Bus Master<br>Write)                                                          |                    | 0   |      |     | n        |
| 33         | twos              | Data Setup Time to the Rising Edge of DAS (Bus Master Write)                                                              |                    | 200 |      |     | , r      |
| 34         | 1WDH              | Data Hold Time After the Rising Edge of DAS (Bus Master Write)                                                            |                    | 35  |      |     | ſ        |
| 35         | tSD01             | Data Driver Delay After the Falling Edge of DAS (Bus Slave<br>Read)                                                       | (CRS 0, 3, RAP)    |     | 400  |     |          |
| 36         | 1SD02             | Data Driver Delay Afte the Falling Edge of DAS (Bus Slave<br>Read)                                                        | (CSR 1, 2)         |     | 1200 |     | ļ_'      |
| 37         | ISRDH             | Data Hold Time After the Rising Edge of DAS (Bus Slave<br>Read)<br>Data Hold Time After the Rising Edge of DAS (Bus Slave | ······             | 0   |      | 35  | <u> </u> |
| 38         | ISWDH             | Data Action Time to the Falling Edge of DAS (Bus Slave                                                                    |                    | 0   |      |     | Ľ        |
| 39         | ISWDS             | Write)                                                                                                                    |                    | 0   |      |     | 1        |

| lumber | Parameters        | Description                                                                                                   | Test<br>Conditions        | Min | Тур  | Max      | Unit       |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------|---------------------------|-----|------|----------|------------|
| 40     | TALEW             | ALE Width HIGH                                                                                                |                           | 120 |      |          | ns         |
| 41     | <sup>t</sup> DALE | Delay from Rising Edge of DAS to the Rising Edge of ALE                                                       |                           | 70  |      | <u> </u> | ns         |
| 42     | tosw              | DAS Width LOW                                                                                                 |                           | 200 |      | 1        | ns         |
| 43     | IADAS             | Delay from the Falling Edge of ALE to the Falling Edge of<br>DAS                                              |                           | 80  |      |          | ns         |
| 44     | tridf             | Delay from the Rising Edge of DALO to the Falling Edge of DAS (Bus Master Read)                               |                           | 15  |      |          | ns         |
| 45     | IRDYS             | Delay from the Falling Edge of READY to the Rising Edge of DAS                                                | t <sub>ARYD</sub> = 300ns | 75  |      | 250      | ns         |
| 46     | troif             | Delay from the Rising Edge of DALO to the Falling Edge of DALI (Bus Master Read)                              | · · · · ·                 | 15  |      |          | ns         |
| 47     | <sup>t</sup> RIS  | DALI Setup Time to the Rising Edge of DAS (Bus Master Read)                                                   |                           | 135 |      |          | ns         |
| 48     | <sup>t</sup> RIH  | DALI Hold Time After the Rising Edge of DAS (Bus Master Read)                                                 |                           | 0   |      |          | ns         |
| 49     | <sup>t</sup> RIOF | Delay from the Rising Edge of DALI to the Falling Edge of DALO (Bus Master Read)                              |                           | 55  |      |          | n          |
| 50     | tos               | DALO Setup Time to the Falling Edge of ALE (Bus Master Read)                                                  |                           | 110 |      |          | nt         |
| 51     | <sup>t</sup> вон  | DALO Hold Time After the Falling Edge of ALE (Bus Master Read)                                                |                           | 35  |      |          | n          |
| 52     | twosi             | Delay from the Rising Edge of DAS to the Rising Edge of DALO (Bus Master Write)                               |                           | 35  |      |          | n          |
| 53     | 1CSH              | CS Hold Time After the Rising Edge of DAS (Bus Slave)                                                         |                           | 0   |      |          | ns         |
| 54     | ICSS .            | CS Setup Time to the Falling Edge of DAS (Bus Slave)                                                          |                           | 0   |      |          | ns         |
| 55     | 1SAH              | ADR Hold Time After the Rising Edge of DAS (Bus Slave)                                                        |                           | 0   |      |          | ns         |
| 56     | ISAS              | ADR Setup Time to the Falling Edge of DAS (Bus Slave)                                                         |                           | 0   |      |          | ns         |
| 57     | TARYD             | Delay from the Falling Edge of ALE to the Falling Edge of<br>READY to Insure a Minimum Bus Cycle Time (600ns) |                           |     |      | 80       | e          |
| 58     | <sup>t</sup> SRDS | Data Setup Time to the Falling Edge of Ready (Bus Slave Read)                                                 |                           | 75  |      |          | n          |
| 59     | <sup>t</sup> RDYH | READY Hold Time After the Rising Edge of DAS (Bus Master)                                                     |                           | 0   |      |          | n          |
| 60     | tSR01             | READY Driver Turn On After the Falling Edge of DAS (Bus Slave Read)                                           | (CSR 0, 3, RAP)           |     | 600  |          | <b>n</b> : |
| 61     | tSR02             | READY Driver Turn On After the Falling Edge of DAS (Bus<br>Slave Read)                                        | (CSR 1, 2)                |     | 1400 |          | ns         |
| 62     | 1SRYH             | READY Hold Time After the Rising Edge of DAS (Bus Slave)                                                      |                           | 0   |      | 35       | ns         |
| 63     | 1SRH              | READ Hold Time After the Rising Edge of DAS (Bus Slave)                                                       |                           | 0   |      |          | ns         |
| 64     | tSRS              | READ Setup Time to the Falling Edge of DAS (Bus Slave)                                                        |                           | 0   |      |          | nt         |
| 65     | 1CHL              | TCLK Rising Edge to Hold LOW or HIGH Delay                                                                    |                           | ļ   |      | 200      | ns         |
| 66     | ICAV              | TCLK to Address Valid                                                                                         |                           |     |      | 150      | <u></u>    |
| 67     | ICCA              | TCLK Rising Edge to Control Signals Active                                                                    |                           | ļ   |      | 165      | n          |
| 68     | ICALE             | TCLK Falling Edge to ALE LOW                                                                                  |                           |     |      | 150      | <u></u>    |
| 69     | ICDL              | TCLK Failing Edge to DAS Failing Edge                                                                         |                           |     |      | 150      | n          |
| 70     | IRCS              | Ready Setup Time to TCLK                                                                                      | ·····                     | 50  |      |          | n          |
| 71     | ЧСОН              | TCLK Rising Edge to DAS HIGH                                                                                  |                           |     |      | 150      | nt         |
| 72     | tHCS              | HLDA Setup to TCLK                                                                                            |                           | 50  |      |          | n          |

Notes 1 Parameter #25 is not shown in the timing diagrams. It specifies the minimum bus cycle for a single DMA transfer. 2 The READY setup time before negation of DAS is a function of the synchronization time of READY. The synchronization must occur within 108ns Therefore, the setup time is 100ns plus any accumulated propagation delays. Ready slips occur on 100ns increments

.



|                                        | APPENDIX A                                                                            |                |                                              |                                                            |                                                                                                                                                                                                                |  |  |
|----------------------------------------|---------------------------------------------------------------------------------------|----------------|----------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 8086 c                                 | computer program ex                                                                   | ample to ge    | nerate ti                                    | he hash filter                                             | , for multicast addressing in the LANCE.                                                                                                                                                                       |  |  |
| 6<br>7<br>8<br>9<br>10<br>11           |                                                                                       |                | GIVEN I                                      | ETHERNET LO<br>TRY SI POINTS<br>DI POINTS<br>TURN SI POINT | A BIT IN THE HASH FILTER FROM A<br>GICAL ADDRESS<br>5 TO THE LOGICAL ADDRESS WITH LSB FIRST<br>5 TO THE HASH FILTER WITH LSB FIRST<br>TS TO THE BYTE AFTER THE LOGICAL ADDRESS<br>HER REGISTERS ARE UNMODIFIED |  |  |
| 12<br>13<br>14                         |                                                                                       | ;              |                                              | SETHASH<br>E CS:CSE61                                      |                                                                                                                                                                                                                |  |  |
| 15<br>16<br>17                         | = 1DB6<br>= 04C1                                                                      | POLYL<br>POLYH | equ<br>Equ                                   | 1DB6H<br>04C1H                                             | CRC POLYNOMINAL TERMS                                                                                                                                                                                          |  |  |
| 18<br>19<br>20                         | 0000                                                                                  | CSE61          | SEGME                                        | NT PUBLIC 'CO                                              | DDE'                                                                                                                                                                                                           |  |  |
| 21<br>22<br>23<br>24<br>25             | 0000<br>0000 50<br>0001 53<br>0002 51<br>0003 52                                      | SETHASH        | PROC<br>PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSH | NEAR<br>AX<br>BX<br>CX<br>DX<br>BP                         | SAVE ALL REGISTERS                                                                                                                                                                                             |  |  |
| 26<br>27<br>28<br>29<br>30             | 0004 55<br>0005 B8 FFFF<br>0008 BA FFFF<br>0008 B5 03                                 | :              | MOV<br>MOV<br>MOV                            | _                                                          | :AX,DX = CRC ACCUMULATOR<br>;PRESET CRC ACCUMULATOR TO ALL 1'S<br>;CH = WORD COUNTER                                                                                                                           |  |  |
| 31<br>32<br>33<br>34<br>35             | 000D 8B 2C<br>000F 83 C6 02<br>0012 B1 10                                             | SETH10:        | MOV<br>ADD<br>MOV                            | BP;[S1]<br>SI,2<br>CL,16                                   | GET A WORD OF ADDRESS<br>POINT TO NEXT ADDRESS<br>CL = BIT COUNTER                                                                                                                                             |  |  |
| 36<br>37<br>38<br>39<br>40<br>41       | 0014 8B DA<br>0016 D1 C3<br>0018 33 DD<br>001A D1 E0<br>001C D1 D2<br>001E 81 E3 0001 | SETH20:        | MOV<br>ROL<br>XOR<br>SAL<br>RCL<br>AND       | BX.DX<br>BX.1<br>BX.BP<br>AX.1<br>DX.1<br>BX.0001H         | GET HIGH WORD OF CRC<br>PUT CRC31 TO LSB<br>COMBINE CRC31 WITH INCOMING BIT<br>LEFT SHIFT CRC ACCUMULATOR<br>BX = CONTROL BIT                                                                                  |  |  |
| 42<br>43<br>44                         | 0022 74 07                                                                            |                | JZ<br>PERFOF                                 | SETH30<br>RM XOR OPER                                      | ;DO NOT XOR IF CONTROL BIT = 0<br>ATION WHEN CONTROL BIT = 1                                                                                                                                                   |  |  |
| 45<br>46<br>47                         | 0024 35 1D86<br>0027 81 F2 04C1                                                       |                | XOR<br>XOR                                   | AX,POLYL<br>DX,POLYH                                       | ·····                                                                                                                                                                                                          |  |  |
| 48<br>49<br>50<br>51<br>52<br>53<br>54 | 002B 0B C3<br>002D D1 CD<br>002F FE C9<br>0031 75 E1<br>0033 FE CD<br>0035 75 D6      | SETH30:        | OR<br>ROR<br>DEC<br>JNZ<br>DEC<br>JNZ        | AX,BX<br>BP,1<br>CL<br>SETH20<br>CH<br>SETH10              | PUT CONTROL BIT IN CRC0<br>ROTATE ADDRESS WORD<br>DECREMENT BIT COUNTER<br>DECREMENT WORD COUNTER                                                                                                              |  |  |
| 55<br>56                               |                                                                                       | :              | FORMA<br>CODE                                | TION OF CRC                                                | COMPLETE, AL CONTAINS THE REVERSED HASH                                                                                                                                                                        |  |  |
| 57<br>58<br>49<br>60<br>61<br>62       | 0037 B9 000A<br>003A D0 E0<br>003C D0 DC<br>003E E2 FA                                | SETH40:        | Mov<br>Sal<br>RCR<br>Loop                    | CX,10<br>AL,1<br>AH,1<br>SETH40                            | REVERSE THE ORDER OF BITS IN AL<br>AND PUT IT IN AH                                                                                                                                                            |  |  |
| 63<br>64                               |                                                                                       | •<br>•<br>•    |                                              |                                                            | THE HASH CODE                                                                                                                                                                                                  |  |  |
| 65<br>66<br>67<br>68                   | 0040 8A DC<br>0042 B1 03<br>0044 D2 EB<br>0046 B0 01                                  |                | Mov<br>Mov<br>Shr<br>Mov                     | BL,AH<br>CL,3<br>BL,CL<br>AL,01H                           | BL = HASH CODE, BH IS ALREADY ZERO<br>DIVIDE HASH CODE BY 8<br>TO GET TO THE CORRECT BYTE<br>PRESET FILTER BIT                                                                                                 |  |  |

.

69 0048 80 E45 07 AND AH,7H EXTRACT BIT COUNT 70 0048 8A CC MOV CL,AH 71 004D D2 E0 SHL AL,CL SHIFT BIT TO CORRECT POSITION 72 004F 08 01 OR [DI + BX],AL ;SET IN HASH FILTER 73 0051 5D POP RP. 74 0052 5A POP DX 75 0053 59 POP CX 76 0054 5B POP BX 0055 58 77 POP AX 78 0056 C3 RFT 79 0057 80 SETHASH ENDP 81 82 0057 CSEG1 ENDS 83 : 84 END Basic computer program example to generate the hash filter, for multicast addressing, in the LANCE. 100 REM 110 REM PROGRAM TO GENERATE A HASH NUMBER GIVEN AN ETHERNET ADDRESS 120 REM 130 DEFINT A-Z 140 DIM A(47) : REM ETHERNET ADDRESS = 48 BITS 150 DIM C(32) : REM CRC REGISTER = 32 BITS 160 PRINT "ENTER STARTING ADDRESS'; : INPUT AS 170 IF LEN (AS) < > 12 THEN 160 : REM THE INPUT ADDRESS STARTING MUST BE 12 CHARS 180 REM REM 190 UNPACK STARTING ADDRESS INTO ADDRESS ARRAY 200 REM 210 M = 0FOR I = 0 TO 47 : A(I) = 0 : NEXT I 220 FOR N = 12 TO 1 STEP -1 230 Y\$ = MID\$ (A\$,N,1) 240 250 IF YS = "0" THEN 420 
 260
 IF
 Y\$ = "1"
 THEN
 A(M) = 1 :
 GOTO
 420

 270
 IF
 Y\$ = "2"
 THEN
 A(M + 1) = 1 :
 GOTO
 420
 280 IF YS = "3" THEN A(M + 1) = 1 : A(M) = 1 : GOTO 420 290 IF YS = "4" THEN A(M + 2) = 1 : GOTO 420 300 IF YS = "5" THEN A(M + 2) = 1 : A(M) = 1 : GOTO 420 

 310
 IF Y\$ = "6" THEN A(M + 2) = 1 : A(M + 1) = 1 : GOTO 420

 320
 IF Y\$ = "7" THEN A(M + 2) = 1 : A(M + 1) = 1 : A(M) = 1 : GOTO 420

 330 A(M + 3) = 1 340 IF Y\$ = "8" THEN 420 350 IF Y\$ = "9" THEN A(M) = 1 : GOTO 420 360 IF YS = "A" THEN A(M + 1) = 1 : GOTO 420 370 IF YS = "B" THEN A(M + 1) = 1 : A(M) = 1 : GOTO 420 380 IF YS = "C" THEN A(M + 2) = 1 : GOTO 420 IF Y\$ = "D" THEN A(M + 2) = 1 : A(M) = 1 : GOTO 420 390 IF Y\$ = "E" THEN A(M + 2) = 1 : A(M + 1) = 1 GOTO 420 400 IF YS = "F" THEN A(M + 2) = 1 : A(M + 1) = 1 : A(M) = 1 410 420 M = M + 4NEXT N 430 440 REM PERFORM CRC ALGORITHM ON ARRAY A(0-47) 450 REM 460 REM FOR I = 0 TO 31 : C(I) = 1 : NEXT I 470 480 FOR N = 0 TO 47 REM LEFT CRC REGISTER BY 1 490 500 FOR I = 32 TO 1 STEP -1 : C(I) = C(I - 1) : NEXT I C(0) = 0510 520 T = C(32) XOR A(N) : REM T = CONTROL BIT IF T < > THEN 600 : REM JUMP IF CONTROL BIT = 0 530 C(1) = C(1) XOR 1 : C(2) = C(2) XOR 1 : C(4) = C(4) XOR 1 540 C(5) = C(5) XOR 1 : C(7) = C(7) XOR 1 : C(8) = C(8) XOR 1 550 C(10) = C(10) XOR 1 : C(11) = C(11) XOR 1 : C(12) = C(12) XOR 1 560

C(16) = C(16) XOR 1 : C(22) = C(22) XOR 1 : C(23) = C(23) XOR 1 570 580 C(26) = C(26) XOR 1 C(0) = 1 590 NEXT N 600 610 REM 620 REM CRC COMPUTATION COMPLETE, EXTRACT HASH NUMBER FROM C(0) TO C(5) 630 REM HH = 32\*C(0) + 16\*C(1) + 8\*C(2) + 4\*C(3) + 2\*C(4) + C(5) PRINT "THE HASH NUMBER FOR ";A\$;" IS ";HH 640 650 660 GOTO 160

## MAPPING OF LOGICAL ADDRESS TO FILTER MASK

| LAF<br>Reg<br>Bits | LAF<br>Loc | Destination<br>Address Accepted | LAF<br>Reg<br>Bits | LAF<br>Loc | Destination<br>Address Accepted |
|--------------------|------------|---------------------------------|--------------------|------------|---------------------------------|
| Set                | Dec        | (Hex)                           | Set                | Dec        | (Hex)                           |
| 0                  | 0          | 0000 0000 0085                  | 0                  | 32         | 0000 0000 0021                  |
|                    | 1          | 0000 0000 00A5                  |                    | 33         | 0000 0000 0001                  |
| L                  | 2          | 0000 0000 00E5                  | L                  | 34         | 0000 0000 0041                  |
| A                  | 3          | 0000 0000 00C5                  | A                  | 35         | 0000 0000 0071                  |
| F                  | 4          | 0000 0000 0045                  | F                  | 36         | 0000 0000 00E1                  |
|                    | 5          | 0000 0000 0065                  | 1                  | 37         | 0000 0000 00C1                  |
| 0                  | 6          | 0000 0000 0025                  | 2                  | 38         | 0000 0000 0081                  |
| 1                  | 7          | 0000 0000 0005                  | 1                  | 39         | 0000 0000 00A1                  |
|                    | 8          | 0000 0000 002B                  |                    | 40         | 0000 0000 008F                  |
|                    | 9          | 0000 0000 0008                  |                    | 41         | 0000 0000 00BF                  |
|                    | 10         | 0000 0000 004B                  |                    | 42         | 0000 0000 00EF                  |
|                    | 11         | 0000 0000 006B                  |                    | 43         | 0000 0000 00CF                  |
|                    | 12         | 0000 0000 00EB                  |                    | 44         | 0000 0000 004F                  |
|                    | 13         | 0000 0000 00CB                  |                    | 45         | 0000 0000 006F                  |
|                    | 14         | 0000 0000 008B                  |                    | 46         | 0000 0000 002F                  |
| 15                 | 15         | 0000 0000 00BB                  | 15                 | 47         | 0000 0000 000F                  |
| 0                  | 16         | 0000 0000 00C7                  | 0                  | 48         | 0000 0000 0063                  |
|                    | 17         | 0000 0000 00E7                  |                    | 49         | 0000 0000 0043                  |
| 1                  | 18         | 0000 0000 00A7                  | 1                  | 50         | 0000 0000 0003                  |
|                    | 19         | 0000 0000 0087                  |                    | 51         | 0000 0000 0023                  |
| L ]                | 20         | 0000 0000 0007                  | L                  | 52         | 0000 0000 00A3                  |
| A                  | 21         | 0000 0000 0027                  | A                  | 53         | 0000 0000 0083                  |
| F                  | 22         | 0000 0000 0067                  | F                  | 54         | 0000 0000 00C3                  |
| 1                  | 23         | 0000 0000 0047                  | 1                  | 55         | 0000 0000 00E3                  |
| 1                  | 24         | 0000 0000 0069                  | 3                  | 56         | 0000 0000 00CD                  |
|                    | 25         | 0000 0000 0049                  |                    | 57         | 0000 0000 00ED                  |
|                    | 26         | 0000 0000 0009                  |                    | 58         | 0000 0000 00AD                  |
|                    | 27         | 0000 0000 0029                  |                    | 59         | 0000 0000 008D                  |
|                    | 28         | 0000 0000 00A9                  | 1                  | 60         | 0000 0000 000D                  |
| 1                  | 29         | 0000 0000 0089                  |                    | 61         | 0000 0000 002D                  |
|                    | 30         | 0000 0000 00C9                  |                    | 62         | 0000 0000 006D                  |
| 15                 | 31         | 0000 0000 00E9                  | 15                 | 63         | 0000 0000 004D                  |



# Am7992B

Serial Interface Adapter (SIA)

## DISTINCTIVE CHARACTERISTICS

- Compatible with Ethernet/Cheapernet/IEEE-802.3 specifications
- Crystal controlled Manchester Encoder
- Manchester Decoder acquires clock and data within four bit times with an accuracy of ±3 ns
- Guaranteed carrier and collision detection squelch threshold limits
  - Carrier/collision detected for inputs greater than -275 mV
  - No carrier/collision for inputs less than -175 mV
- Input signal conditioning rejects transient noise
   Transients < 10 ns for collision detector inputs</li> - Transients < 20 ns for carrier detector inputs

Am79928

Advanced Micro Devices

- Receiver decodes Manchester data with worst case
- ±19 ns of clock jitter (at 10 MHz)
- TTL compatible host interface
- Transmit accuracy ±0.01% (without adjustments)

## **GENERAL DESCRIPTION**

The Am7992B Serial Interface Adapter (SIA) is a Manchester Encoder/Decoder compatible with IEEE-802.3, Cheapernet and Ethernet specifications. In an IEEE-802.3/Ethernet application, the Am7992B interfaces the Am7990 Local Area Network Controller for Ethernet (LANCE) to the Ethernet transceiver cable, acquires clock and data within

four bit times, and decodes Manchester data with worst case ±19 ns phase jitter at 10 MHz. SIA provides both guaranteed signal threshold limits and transient noise suppression circuitry in both data and collision paths to minimize false start conditions.



Order # 03378E



## **PIN DESCRIPTION**

## CLSN Collision (Output, TTL Active HIGH)

Signals at the Collision  $\pm$ terminals meeting threshold and pulse width requirements will produce a logic HIGH at CLSN output. When no signal is present at Collision $\pm$ , CLSN output will be LOW.

## RX Receive Data (Output)

A MOS/TTL output, recovered data. When there is no signal at Receive± and TEST is HIGH, RX is HIGH. RX is actuated with RCLK and remains active until RENA is deasserted at the end of message. During reception, RX is synchronous with RCLK and changes after the rising edge of RCLK. When TEST is LOW, RX is enabled.

RENA Receive Enable (Output, TTL Active HIGH) When there is no signal at Receive± RENA is LOW. Signals meeting threshold and pulse width "on" requirements will produce a logic HIGH at RENA. When RENA is HIGH, Receive± signals meeting threshold and pulse width "off" requirements will produce a LOW at RENA.

## RCLK Receive Clock (Output)

A MOS/TTL output, recovered clock. When there is no signal at Receive± and TEST is HIGH, RCLK is LOW. RCLK is activated 1/4 bit time after the second negative Manchester preamble clock transition at Receive±, and remains active until end of message. When test is LOW, RCLK is enabled and meets minimum pulse width specifications.

#### TX Transmit (input)

TTL-compatible input. When TENA is HIGH, signals at TX meeting setup and hold time to TCLK will be encoded as normal Manchester at Transmit+ and Transmit-

- TX HIGH: Transmit+ is negative with respect to Transmit- for first half of data bit cell.
- TX LOW: Transmit+ is positive with respect to Transmit- for first half of data bit cell.

## TENA Transmit Enable (Input)

TTL-compatible input. Active HIGH data encoder enable. Signals meeting setup and hold time to TCLK will allow encoding of Manchester data from TX to Transmit+ and Transmit-.

## TCLK Transmit Clock (Output)

MOS/TTL output. TCLK provides symmetrical HIGH and LOW clock signals at data rate for reference timing of data to be encoded. It also provides clock signals for the controller chip (Am7990 - LANCE) and an internal timing reference for receive path voltage controlled oscillators. Transmit+ Transmit (Outputs)

## Transmit-

A differential line output. This line pair is intended to operate into terminated transmission lines. For signals meeting setup and hold time to TCLK at TENA and TX, Manchester clock and data are outputted at Transmit+/ Transmit-. When operating into a 78  $\Omega$  terminated transmission line, signaling meets the required output levels and skew for both Ethernet and IEEE-802.3 drop cables.

## FUNCTIONAL DESCRIPTION

The Am7992B Serial Interface Adapter (SIA) has three basic functions. It is a Manchester Encoder/line driver in the transmit path, a Manchester Decoder with noise filtering and quick lock-on characteristics in the receive path, and a signal detect/converter (10 MHz differential to TTL) in the collision

#### Receive+ Receiver (Inputs) Receive-

A differential input. A pair of internally biased line receivers consisting of a carrier detect receiver with offset threshold and noise filtering to detect the line activity, and a data recovery receiver with no offset for Manchester data decoding.

## Collision+ Collision (Inputs)

## Collision-

A differential input. An internally biased line receiver input with offset threshold and noise filtering. Signals at Collision± have no effect on data-path functions.

## TSEL Transmit Mode Select (Output, Open Collector; Input, Sense Amplifier)

TSEL LOW: Idle transmit state Transmit+ is positive with respect to Transmit-.

TSEL HIGH: Idle transmit state Transmit+ and Transmitare equal, providing "zero" differential to operate transformer coupled loads.

When connected with an RC network, TSEL is held LOW during transmission. At the end of transmission the open collector output is disabled, allowing TSEL to rise and provide a smooth transmission from logic HIGH to "zero" differential idle. Delay and output return to zero are externally controlled by the RC network at TSEL and Transmit± load inductance.

## X1, X2 Biased Crystal Oscillator (Input)

 $X_1$  is the input and  $X_2$  is the bypass port. When connected for crystal operation, the system clock which appears at TCLK is half the frequency of the crystal oscillator.  $X_1$  may be driven from an external source of two times the data rate.

#### RF Frequency Setting Voltage Controlled Oscillator (V<sub>CO</sub>) Loop Filter (Output)

This loop filter output is a reference voltage for the receive path phase detector. It also is a reference for timing noise immunity circuits in the collision and receive enable path. Nominal reference  $V_{CO}$  gain is 1.25 TCLK frequency MHz/V.

## TEST Test Control (Input)

A static input that is connected to V<sub>CC</sub> for Am7992B/ Am7990 operation and to Ground for testing of Receive± path threshold and RCLK output high parameters. When TEST is grounded, RX is enabled and RCLK is enabled except during Clock acquisition when RCLK is HIGH.

- GND1 High Current Ground
- GND<sub>2</sub> Logic Ground
- GND<sub>3</sub> Voltage Controlled Oscillator Ground
- V<sub>CC1</sub> High Current and Logic Supply
- V<sub>CC2</sub> Voltage Controlled Oscillator Supply

path. In addition, the SIA provides the interface between the TTL logic environment of the Local Area Network Controller for Ethernet (LANCE) and the differential signaling environment in the transceiver cable.

## **Transmit Path**

The transmit section encodes separate clock and NRZ data input signals meeting the set-up and hold time to TCLK at TENA and TX, into a standard Manchester II serial bit stream. The transmit outputs (Transmit+/Transmit-) are designed to operate into terminated transmission lines. When operating into a 78  $\Omega$  terminated transmission line, signaling meets the required output levels and skew for Cheapernet, Ethernet and IEEE-802.3.



AF003040

Figure 1. Transmit Section

#### Transmitter Timing and Operation

A 20 MHz fundamental mode crystal oscillator provides the basic timing reference in the SIA. It is divided by two to create the Transmit Clock reference (TCLK). Both 20-MHz and 10-MHz clocks are fed into the Manchester Encoder to generate the transitions in the encoded data stream. The 10 MHz clock, TCLK, is used by the SIA to internally synchronize Transmit (TX) data and Transmit Enable (TENA). TCLK is also used as a stable bit rate clock by the receive section of the SIA and by other devices in the system (the Am7990 LANCE uses TCLK to drive its internal state machine). The oscillator may use an external .005% crystal or an external TTL-level input as a reference. Transmit accuracy of .01% is achieved (no external adjustments are required).

Transmission is enabled when TENA is activated. As long as TENA remains HIGH, signals at TX will be encoded as Manchester and will appear at Transmit+ and Transmit-. When TENA goes LOW, the differential transmit outputs go to one of two idle states:

- 1. TSEL HIGH: The idle state of Transmit± yields "zero" differential to operate transformer-coupled loads (see Figure 2, Transmitter Timing – End of Transmission waveform diagram and Typical Performance Curve diagram).
- 2. TSEL LOW: In this idle state, Transmit+ is positive to Transmit- (logical HIGH) (see Figures and diagrams as referenced above).

The End of Transmission - Return to Zero is determined by the external RX network at TSEL and by the load at Transmitt.



#### SIA Oscillator

#### Specification for External Crystal

When using a crystal to drive the Am7992B oscillator, the following crystal specification should be used to ensure a transmit accuracy of 0.01%:

|                                                                                 |        | Limit   |             |         |
|---------------------------------------------------------------------------------|--------|---------|-------------|---------|
|                                                                                 | Min,   | Nom.    | <u>Max.</u> | Units   |
| 1. Resonant Frequency<br>Error with C <sub>L</sub> = 50 pF                      | - 50   | 0       | + 50        | PPM     |
| 2. Change in Resonant Fre-<br>quency Temperature with<br>C <sub>L</sub> = 50 pF | - 40   |         | + 40        | PPM     |
| 3. Parallel Resonant Frequency<br>with CL = 50 pF                               |        | 20      |             | MHz     |
| <ol> <li>Motional Crystal Capaci-<br/>tance, C<sub>1</sub></li> </ol>           |        | 0.022   | pF          |         |
| Some crystal manufacturers ha                                                   | ve ger | nerated | crystals    | to this |

Some crystal manufacturers have generated crystals to this specification. One such manufacturer is Reeves-Hoffman. Their ordering part number for this crystal is RH # 04-20423-312.

#### Specification for External TTL Level

When driving the oscillator from an external clock source,  $X_2$  must be left floating (unconnected). An external clock having the following characteristics must be used to ensure less than  $\pm 0.5$  ns jitter at Transmit<sup>±</sup> (see the  $X_1$  Driven from External Source waveform diagram):

Clock Frequency: 20 MHz ±0.01%

- Rise/Fall Time (t<sub>R</sub>/t<sub>F</sub>): < 2 ns from 0.8 V to 2.0 V
- X1 HIGH/LOW Time (tHIGH/tLOW): > 20 ns
- $X_1$  Falling Edge to Falling Edge Jitter: <  $\pm 0.2$  ns at

1.5 V input

#### **Receiver Path**

The principle functions of the Receiver are to signal the LANCE that there is information on the receive pair, and separate the incoming Manchester-encoded data stream into clock and NRZ data.

The Receiver section (see Figures 3 and 4) consists of two parallel paths. The receive data path is a zero threshold, wide bandwidth line receiver. The carrier path is an offset threshold



#### **Input Signal Conditioning**

The Carrier Receiver detects the presence of an incoming data packet by discerning and rejecting noise from expected Manchester data. It also controls the stop and start of the phase-lock loop during clock acquisition. In the Am7992B, clock acquisition requires a valid Manchester bit pattern of 1010 to lock on the incoming message (see Receive Timing – Start of Reception Clock Acquisition waveform diagram).

Transient noise pulses less than 20 ns wide are rejected by the Carrier Receiver as noise and DC inputs more positive than minus 175 mV are also suppressed. Carrier is detected for input signal wider than 45 ns with amplitude more negative than minus 275 mV. When input amplitude and pulse width conditions are met at Receive±, RENA is asserted and a clock acquisition cycle is initiated.

#### **Clock Acquisition**

When there is no activity at Receive: (receiver is idle), the receive oscillator is phase locked to TCLK. The first negative clock transition (first valid Manchester "0") after RENA is asserted interrupts the receive oscillator and presents the INTRCLK (internal clock) to the HIGH state. The oscillator is then restarted at the second Manchester "0" (bit time 4) and is phase locked to it. As a result, the SIA acquires the clock from the incoming Manchester bit stream in four bit times with "1010" Manchester bit pattern. The 10-MHz INTRCLK and INTPLLCLK are derived from the internal oscillator which runs at 4 times the data rate (40.0 MHz). The three clocks

INTRCLK: After clock acquisition, INTRCLK strobes the incoming data at 1/4 bit time. Receive data path sets the input to the data decode register (Figure 4).

INTPLLCLK: At clock acquisition, INTPLLCLK is phase locked to the incoming Manchester clock transition at bit cell center (BCC). The transition at BCC is compared to INTPLLCLK and phase correction is applied to maintain INTRCLK at 1/4 bit time in the Manchester cell.

INTCARR: From start to end of a message, INTCARR is active and establishes RENA Turn-off synchronously with RCLK rising edge. Internal carrier goes active when there is a negative transition that is more negative than -275 mV and has a pulse width greater or equal to 45 ns. Internal carrier goes inactive within 165 ns of the last positive transition at Receive2.

When TEST is strapped HIGH, RCLK and RX are enabled 1/4 bit time after clock acquisition in bit cell 5. RX is at HIGH state when the receiver is idle and TEST is strapped HIGH (no RLCK). RX, however, is undefined when clock is acquired and may remain HIGH or change to LOW state whenever RCLK is enabled. At 1/4 bit time of clock transition in bit cell 5, RCLK makes its first external transition. It also strobes the incoming fifth bit Manchester "1." RX may make a transition after the RCLK rising edge in bit cell 5, but its state is still undefined. The Manchester "1." at bit 5 is clocked to RX output at 1/4 bit time in bit cell 6.

## PLL Tracking

After clock acquisition, the INTPLLCLK is compared to the incoming transitions at BCC and the resulting phase error is applied to a correction circuit. This circuit ensures that INTPLLCLK remains locked on the received signal. Individual bit cell phase corrections of the V<sub>CO</sub> are limited to 10% of the phase difference between BCC and INTPLLCLK. Hence, input data inter is reduced in RCLK by 10 to 1.

#### **Carrier Tracking and End of Message**

The carrier receiver monitors Receive± input after RENA is asserted for an end of message. INTCARR deasserts 145 ns to 165 ns after the incoming message transitions positive. This initiates the end of reception cycle. INTCARR is strobed at 3/4 bit time by the falling edge of INTRCLK. The time delay from the last rising edge of the message to INTCARR deassert allows the last bit to be strobed by RCLK and transferred by the LANCE without an extra bit at the end of message. When RENA deasserts (see Receive Timing – End of Reception (Last Bit = 0) and Receive Timing – End of Reception (Last Bit = 1) waveform diagrams) and a RENA hold off timer inhibits RENA assertion for at least 120 ns.

## **Deta Decoding**

The data receiver is a comparator with clocked output to minimize noise sensitivity to the Receive± inputs. Input error (VIRD) is less than  $\pm 35$  mV to minimize sensitivity to input rise and fall time. RCLK strobes the data receiver output at 1/4 bit time to determine the value of the Manchester bit and clocks the data out at RX on the following RCLK. The data receiver also generates the signal used for phase detector comparison to the internal Am7992B V<sub>CO</sub>.

#### **Differential I/O Terminations**

The differential input for the Manchester data (Receive±) is externally terminated by two 40.2-ohm ±1% resistors and one optional common-mode bypass capacitor. The differential input impedance,  $Z_{IDF}$ , and the common-mode input,  $Z_{ICM}$ , are specified so that the Ethernet specification for cable termination impedance is met using standard 1% resistor terminators. The Collision± differential inputs are terminated in exactly the same way as the receive inputs (see Figure 5).



Notes: 1. Connect R1, R2, C1, for 0 differential nontransmit. Connect to ground for logic 1 differential nontransmit. 2. Pin 20 shown for normal device operation.

 The inclusion of C4 and C5 is necessary to reduce the common-mode loading on certain transceivers which are direct coupled.

## Figure 5. External Component Diagram

#### **Collision Detection**

,

A transceiver detects collisions on the network and generates a 10-MHz signal at the Collision± inputs. This collision signal passes through an input stage which detects signal levels and pulse duration. When the signal is detected by the Am7992B it sets the CLSN line HIGH. This condition continues for approximately 160 ns after the last LOW-to-HIGH transition on Collision±.

#### **Jitter Tolerance Definition and Test**

The Receive Timing – Start of Reception Clock Acquisition waveform diagram shows the internal timing relationships implemented for decoding Manchester data in the Am7992B. The Am7992B utilizes a clock capture circuit to align its internal data strobe with an incoming bit stream. The clock acquisition circuitry requires four valid bits with the values 1010. Clock is phase locked to the negative transition at bit cell center of the second "0" in the pattern.

Since data is strobed at 1/4 bit time, Manchester transitions which shift from their nominal placement through 1/4 bit time will result in improperly decoded data. For both IEEE-802.3 and Ethernet, this results in the loss of a message. With this as the criteria for an error, a definition of "Jitter Handling" is:

That peak deviation from nominal input transition approaching or crossing 1/4 bit cell position for which the Am7992B will property decode data.

Four cases of signal are needed to adequately test the ability of the Am7992B to property decode data from the Manchester bit stream. For each of the four cases two time points within a received message are tested:

1. Jitter tolerance at clock acquisition, the measure of clock capture.

#### Jitter tolerance within a message after the analogue PLL has reduced clock acquisition error to a minimum.

The four cases to test are shown the Input Jitter Timing Waveform diagram. They are: .

- 1. BCC jitter for a 01 bit pattern
- 2. BCC jitter for a 10 bit pattern
- 3. BCB jitter for an 11 bit pattern
- 4. BCB jitter for an X0 bit pattern

The test signals utilized to jitter the input data are artifical in that they may not be realizable on networks (examples are cases 2, 3 and 4 at clock acquisition). However, each pattern relates to setup and hold time measurements for the data decode register (Figure 4). Receive+ and Receive- are driven with the inputs shown to produce the zero crossing distortion at the differential inputs for the applicable test. Case 4 and 8 require only a single zero to implement when tested at the end of message.

Levels used to test jitter are within the common-mode and differential-mode range of the receive inputs and also are available from automatic test equipment. It is assumed that the incoming message is asynchronous with the local TCLK frequency for the Am7992B. This ensures that proper clock acquisition has been established with random phase and frequency error in incoming message. An additional condition placed on the jitter tolerance test is that it must meet all test requirements within 10 ms after power is applied. This forces the Am7992B crystal oscillator to start and lock the analogue PLL to within acceptable limits for receiving from a cold start.

Case 1 of the test corresponds to the expected Manchester data after clock acquisition and average values for clock leading jitter tolerance are 21.5 ns. For cases 5 through 8, average values are 24.4 ns. Cases 5 through 8 are jittered at bit times 55 or 56 as applicable. The Am7992B, then, has less than 0.6 ns static phase error for the noise-free case.



Figure 6. Typical Ethernet Node

## ABSOLUTE MAXIMUM RATINGS

| Storage Temperature65 to +150°C                  |
|--------------------------------------------------|
| Ambient Temperature with                         |
| Power Applied 0 to +70°C                         |
| Supply Voltage Continuous+7.0 V                  |
| DC Voltage Applied to Outputs0.5 to +Voc Max.    |
| DC Input Voltage (Logic Inputs)+5.5 V            |
| DC Input Voltage (Receive±/Collision±)6 to +16 V |
| Transmitt Output Current50 to +25 mA             |
| DC Output Current, Into Outputs 100 mA           |
| DC Input Current (Logic Inputs)                  |
| Transmit± Applied Voltage0 to +16 V              |

Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

## OPERATING RANGES

## Commercial (C) Devices

| Temperature    | 0 to +70°C  |
|----------------|-------------|
| Supply Voltage | +5.0 V ±10% |

Operating ranges define those limits over which the functionality of the device is guaranteed.

| Parameters | Description                                                                                  | Test Conditions                        |             | Min.        | Typ.*  | Max.   | Units |
|------------|----------------------------------------------------------------------------------------------|----------------------------------------|-------------|-------------|--------|--------|-------|
| VOH        | Output HIGH Voltage RX, RENA, CLSN, TCLK, RCLK                                               | IOH = -1.0 mA                          |             | 2.4 3.4     |        |        | V     |
|            | Output LOW Voltage                                                                           | IOL = 16 mA                            | IOL = 16 mA |             | 0.36   | 0.5    |       |
| VOL        | ROLK, TSEL, TOLK, RENA, RX, CLSN                                                             | IOL = 1 mA (Note 1)                    |             | 0.25        | 0.4    |        | V     |
|            | Differential Output Voltage                                                                  |                                        |             | 550 670 770 |        | 770    | 1     |
| VOD        | (Transmit+) - (Transmit-)                                                                    | $R_{\rm L} = 78 \ \Omega$              |             | - 550       | - 670  | - 770  | mV    |
| VOD OFF    | Transmit Differential Output Idle Voltage                                                    | Rt = 78 Ω (Note 2)                     |             | -20         | 0.5    | 20     | ۳V    |
| OD OFF     | Transmit Diffegential Output Idle Current                                                    | TŠEL - HIGH                            | (Note 1)    | -0.5        | ±0.1   | 0.5    | mA    |
| VCMT       | Transmit Output Common-Mode Voltage                                                          |                                        |             |             | 2.5    | 5      | V     |
| VODI       | Differential Output Voltage Imbalance<br>(Transmit±) IIVo1-IVo1                              | - R <sub>L</sub> = 78 Ω                | (Note 2)    |             | 5      |        | 20    |
| Мин        | Input HIGH Voltage TX, TENA                                                                  |                                        |             | 2.0         | 1      |        | v     |
| Int        | Input HIGH Current TX, TENA, TEST                                                            | VCC = Max., Vin                        | = 2.7 V     | T           | T      | + 50   | μA    |
| VIL        | Input LOW Voltage TX, TENA                                                                   |                                        |             |             |        | 0.8    | v     |
| հլ         | Input LOW Current TX, TENA, TEST                                                             | VCC - Max., Vin                        | = 0.4 V     |             | - 270  | - 400  | μA    |
| VIRD       | Differential Input Threshold (Rec Data)                                                      |                                        |             | - 35        | 0      | + 35   | m٧    |
| VIRVD      | Differential Mode Input Voltage Range<br>(Receive±/Collision±)                               |                                        |             |             |        | ± 1.5  | v     |
| VIDC       | Differential Input Threshold                                                                 |                                        |             | - 175       | - 225  | - 275  | mV    |
| łoc        | Power Supply Current                                                                         | tosc = 50 ns                           |             |             | 125    | 180    | mA    |
| ViB        | Input Breakdown Voltage (TX, TENA, TEST)                                                     | lij = 1 mA                             |             | 5.5         |        |        | V     |
| VIC        | Input Clamp Voltage                                                                          | IN = -18 mA                            |             |             |        | - 1.2  | V     |
| VODP       | Undershoot Voltage at Zero Differential Point on Transmit<br>Return to Zero (End of Message) | (Note 9)                               |             |             |        | - 100  | ۳V    |
| Isc        | Short Circuit Current<br>RCLK, RX, TCLK, CLSN, RENA                                          | V <sub>CC</sub> = Max. (Note 6)        |             | - 40        | - 80   | - 150  | mA    |
| RIDF       | Differential Input Resistance                                                                | V <sub>CC</sub> = 0 to Max             | (Note 1)    | 6           | 8.4    |        | kΩ    |
| RICM       | Common Mode Input Resistance                                                                 | V <sub>CC</sub> = 0 to Max             | (Note 1)    | 1.5         | 2.1    |        | kΩ    |
| VICM       | Receive and Collision Input Bias Voltage                                                     | h <sub>N</sub> = 0                     |             | 1.5         | 3.5    | 4.2    | V     |
| hLD        | Receive and Collision Input LOW Current                                                      | V <sub>IN</sub> = -1 V                 |             |             | - 1.06 | -164   | mA    |
| IHD        | Receive and Collision Input HIGH Current                                                     | V <sub>IN</sub> = 6 V                  |             |             | + 0.6  | + 1.10 | mA    |
| інг        | Receive and Collision Input HIGH Current                                                     | V <sub>CC</sub> = 0; V <sub>IN</sub> = | +6 V        |             | 1.28   | 1.86   | mA    |
| IIH        | Crystal Oscillator (X1) Input HIGH Current                                                   | VIH = 3.5 V (No                        | tes 3 & 5)  |             |        | + 1.2  | mA    |
| h          | Crystal Oscillator (X1) Input LOW Current                                                    | VIL = 0 V (Note                        | \$ 3 & 5)   |             |        | - 1.2  | mA    |
| VIH        | Crystal Oscillator (X1) Input HIGH Voltage                                                   | (Notes 3, 4 & .                        | 5)          |             |        | 2.0    | V     |
| VIL        | Crystal Oscillator (X1) Input LOW Volatge                                                    | (Notes 3, 4 & 1                        | 5)          | 0.8         |        |        | V     |

8

## DC CHARACTERISTICS over operating range unless otherwise specified

Notes: See notes following Switching Characteristics table.

\*Typical values listed are for V<sub>CC</sub> = 5.0 V  $T_{\rm A}$  = + 25\*C

| 1 t<br>2 t<br>3 t<br>4 t     |                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Test Conditions       | Min.     | Typ.         | Max.      | Units    |
|------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------|--------------|-----------|----------|
| 2 t<br>3 t<br>4 t            | R SPECIFIC        | ATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                       |          |              |           |          |
| 2 t<br>3 t<br>4 t            | INCT              | RCLK Cycle Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       | 85       | 100          | 118       | ne       |
| 4 1                          | ЧАСН              | RCLK HIGH Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | (Notes 7, 8 & 9)      |          | 38           | 50        |          |
|                              | taci.             | RCLK LOW Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | 38       | 50           |           | ne       |
|                              | <b>LACA</b>       | RCLK Rise Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |          | 2.5          | 8         | ns       |
| <u> </u>                     | <b>Incf</b>       | RCLK Fall Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |          | 2.5          | 8         | ns       |
|                              | 1ROA              | RX Rise Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | (Note 7)              | L        | 2.5          | 8         | ns       |
|                              | <b>LAOF</b>       | RX Fall Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                       |          | 2.5          | 8         | na       |
|                              | <b>IRDH</b>       | RX Hold Time (RCLK t to RX Change)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | (Notes 2 & 7)         | 5        | 8            |           | ne       |
| 9 1                          | 19DS              | RX Prop Delay (RCLK : to RX Stable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | (Note 7)              | <u> </u> | 8            | 25        | ns       |
| 10 t                         | ФРН               | RENA Turn-On Delay (Vipc Max. on Receive:<br>to RENA <sub>H</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       | ļ        | 50           | 80        | ne       |
|                              | 10PO              | RENA Turn-Off Delay (VIDC Min. on Receive:<br>to RENAL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | ļ        | 265          | 300       | ns       |
| 12 t                         | <sup>1</sup> OPL  | RENA LOW Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | 120      | 200          |           | ns       |
| 13 t                         | <sup>L</sup> APWR | Receive: Input Pulse Width to Reject (Input < V <sub>IDC</sub><br>Min.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       |          | 34           | 20        | ns       |
| 14 t                         | tapwo             | Receive: Input Pulse Width to Turn-On (Input > VIDC Max.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       | 45       | 34           |           | ns       |
| 15 t                         | 4ALT              | Decoder Auquisition Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |          | 390          | 450       | ns       |
|                              | REDH              | RENA Hold Time (RCLH t to RENAL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                       | 40       | 57           | 80        | ns       |
|                              | 4PWN              | Receive: input Pulse Width to Not Turn-Off INTCARR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | (Note 1)              | 1        | 155          | 165       | ns       |
| COLLISIC                     | ON SPECIFIC       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       |          |              |           |          |
| 18 1                         | CPWR              | Collision input Pulse Width to Reject (Input < VIDC Min.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       |          | 18           | 10        | ns       |
| 19 t                         | <sup>I</sup> CPWO | Collision Input Pulse Width to Turn-On Collision±<br>Exceeds V <sub>IDC</sub> Max.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       | 28       | 18           |           | ns       |
|                              | CPWE              | Collision Input to Turn-Off CSLN (Input < VIDC Max.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Notes 1 & 8)         | 80       | 117          |           | ns       |
|                              | lopwn<br>Loph     | Collision Input to Noi Turn-Off CLSN (Input > VIDC Min.)<br>CLSN Turn-On Delay (VIDC Max. on Collision±                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                       | +        | 117<br>33    | 160<br>50 | ns<br>ns |
|                              | 10P0              | to CLSNH)<br>CLSN Turn-Off Delev (VIHC Min on Collisiont                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       | <b> </b> | 133          | 160       | ns       |
|                              | ITTER SPEC        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       | 1        |              |           |          |
|                              | tTCL              | TCLK LOW Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | tosc = 50 ns (Note 2) | 45       | 50           | 55        | ns       |
|                              | TCH               | TCLK HIGH Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       | 45       | 50           | 55        | ns       |
|                              | tron              | TCLK Rise Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ·····                 | +        | 2.5          | 8         | ns       |
|                              | TOF               | TCLK Fall Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | tosc = 50 na          |          | 2.5          | 8         | ns       |
|                              | TDS. TTES         | TX and TENA Setup Time to TCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | (Note 2)              | 5        | 1.1          |           | ns       |
|                              | TDH. TTEH         | TX and TENA Hold Time to TCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | 5        | -1.1         |           | ns       |
| 30 t                         | TOCE              | Transmitt Output, (Bit Cell Center to Edge)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | 49.5     | 50           | 50.5      | ns       |
| 31 1                         | loo               | TCLK HiGH to Transarts Cotput                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       | 1        | 60           | 100       | ns.      |
|                              | TOR               | Transmits Duppet Rise Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00                    |          | 2            | 4         | ns       |
|                              | ttof              | Transmit 1 Output Fall Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 20 - 80%              |          | 2            | 4         | ns       |
| 32 t                         | отсн              | A1 to LLLK Fropagation Delay for HIGH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (biotes 2 8 5)        |          | 8.2          | 18        | ns       |
| 32 t<br>33 t                 |                   | At to TCEK imopagatine Delay the USW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (Notes 3 & 5)         | 1        | 9.6          | 18        | ns.      |
| 32 t<br>33 t<br>34 t<br>35 t | httel             | and the second se |                       |          |              |           |          |
| 32 t<br>33 t<br>34 t<br>35 t |                   | Cinck Accussion Jitter Tolerance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                       | 16<br>19 | 21.5<br>24.4 |           | ns       |

.

- 8. Tested under conditions not identical to data sheet.
- 9. Test cannot be implemented to data sheet requirements:

.









.

.









.

17

.





|                     |        | ADVANC                                  | ED MICRO DEVICES                                                               |                                  |
|---------------------|--------|-----------------------------------------|--------------------------------------------------------------------------------|----------------------------------|
| DOMESTIC SALES OFFI | CES    |                                         | INTERNATIONAL                                                                  | SALES OFFICES                    |
| ALABAMA             | (205   | ) 882-9122                              | BELGIUM.                                                                       |                                  |
| ARIZONA             | (205   | 002-9122                                | Bruxelles                                                                      | TEL (02) 771 99 93               |
| Tempe               | (602   | 242-4400                                | Diuxenes                                                                       | FAX                              |
| Tucson              |        | ) 792-1200                              |                                                                                | TLX: 61028                       |
| CALIFORNIA.         | (001   | , , , , , , , , , , , , , , , , , , , , | CANADA, Ontario,                                                               | 1020                             |
| El Segundo          | 1213   | 640-3210                                |                                                                                | TEL:                             |
| Newport Beach       |        | 752-6262                                |                                                                                | TEL: (416) 224-5193              |
| San Diego           |        | 560.7030                                | VIIIOWGard                                                                     | FAX                              |
| Sunnyvale           |        | ) 720-8811                              | FRANCE.                                                                        | PAA                              |
| Woodland Hills      |        | 992-4155                                |                                                                                | TEL:                             |
| COLORADO            |        | 691-5100                                |                                                                                | FAX:                             |
| CONNECTICUT.        | (303   | 091-5700                                |                                                                                | TI X <sup>-</sup>                |
| Southbury           | (202   |                                         |                                                                                | .20253                           |
| FLORIDA             | (203   | ′ r                                     |                                                                                | · ·                              |
| Altamonte Springs   | (305)  |                                         |                                                                                |                                  |
|                     |        |                                         |                                                                                |                                  |
| Clearwater          |        |                                         |                                                                                |                                  |
| Ft. Lauderdale      |        |                                         |                                                                                |                                  |
|                     | •      |                                         | GRUPPE E A HA                                                                  | LBLEITED                         |
| GEORGIA             |        | 905                                     | Enhine het hatten in                                                           |                                  |
| ILLINOIS            |        | 000                                     | Eching bei München, Breslau                                                    | er Straße 16                     |
|                     |        | 101.                                    | (089) 3 1901-377 · Telex 521246                                                | 7 · Telefax (089) 3 19 01-499    |
| KANSAS              |        |                                         | UTIDETO 20. HEDOWED 60/62 Tolotom                                              | (00.11) (0.00.00                 |
| MARYLAND            |        | 8057                                    | Eching, Breslauer Straße 16, Telefon                                           | (089) 3 1901-367 Telev 5 212 467 |
| MASSACHUSETTS       | (617)  | / Stu                                   | ttgart 30, Maybachstraße 39a, Telefon                                          | (07 11) 89 17-140, Telex 723061  |
| MINNESOTA           |        |                                         | inkfurt 70, Kennedy-Allee 34, Telefon                                          | (069) 6317-144, Telex 414881     |
| NEW JERSEY          | (201)  | 3 Han                                   | iseldorf 1, Ronsdorfer Str. 145 Telefon                                        | (02 11) 7361-150, Telex 8582675  |
| NEW YORK,           |        | 2 Ha                                    | nover 81, Hermann-Guthe-Str. 3, Telefon<br>mburg 70, Königsreihe 4, Telefon (( | (0511) 839051-57, Telex 923729   |
| Liverpool           | (315)  |                                         | a ret nongorenne 4, relefon ((                                                 | J401 68295-122, Telex 211998     |
| Poughkeepsie        | (914)  | <b>G</b> 1100                           |                                                                                |                                  |
| Woodbury            |        |                                         |                                                                                |                                  |
| NORTH CAROLINA,     | (704)  | 525-1875                                |                                                                                | FMA                              |
| Charlotte           |        |                                         |                                                                                | TLX:                             |
| Raleigh             |        |                                         | LATIN AMERICA,                                                                 |                                  |
| OREGON              | (503)  | 245-0080                                | Ft. Lauderdale,                                                                | TEL: (305) 484-8600              |
| OHIO,               |        |                                         |                                                                                | FAX:                             |
| Columbus            | (614)  | 891-6455                                | SWEDEN, Stockholm                                                              | TEL:                             |
| PENNSYLVANIA,       |        |                                         |                                                                                | FAX: 7332285                     |
| Allentown           | (215)  | 398-8006                                |                                                                                | TLX: 11602                       |
| Willow Grove        | (215)  | 657-3101                                | UNITED KINGDOM,                                                                |                                  |
| TEXAS,              | • •    |                                         | Manchester area                                                                | TEL:                             |
| Austin              | (512)  | 346-7830                                |                                                                                | FAX                              |
| Dailas              |        |                                         |                                                                                | TLX 628524                       |
| Houston             |        |                                         | London area                                                                    | TEL. (04862) 22121               |
| WASHINGTON          |        |                                         |                                                                                | FAX:                             |
| WISCONSIN           |        |                                         |                                                                                | TLX 859103                       |
| NORTH               | 1 AN   | IERICAN                                 | REPRESENTATIVES                                                                |                                  |
| CALIFORNIA          |        |                                         | NEW JERSEY                                                                     |                                  |
| I <sup>2</sup> INC  | 4 (408 | 988-3400                                | TAI CORPORATION                                                                | (609) 933-2600                   |
|                     |        | 498-6868                                | NEW MEXICO                                                                     |                                  |
| CONNECTICUT         | •      |                                         | THORSON DESERT STATES                                                          | (505) 293-8555                   |

.

| CALIFORNIA            |                                       | NEW JERSEY               |                |
|-----------------------|---------------------------------------|--------------------------|----------------|
| 1 <sup>2</sup> INC    | OEM (408) 988-3400                    | TAI CORPORATION          | (609) 933-2600 |
|                       | DISTI (408) 498-6868                  | NEW MEXICO               |                |
| CONNECTICUT           |                                       | THORSON DESERT STATES    | (505) 293-8555 |
| SCIENTIFIC COMPONENTS | (203) 272-2963                        | NEW YORK                 |                |
| IDAHO                 |                                       | NYCOM, INC.              | (315) 437-8343 |
| INTERMOUNTAIN TECH M  | KGT                                   | OHIO                     |                |
| INDIANA               |                                       | Dayton                   |                |
| SAI MARKETING CORP    |                                       | DOLFUSS ROOT & CO        | (513) 433-6776 |
| IOWA                  |                                       | Strongsville             |                |
| LORENZ SALES          | (319) 377-4666                        | DOLFUSS ROOT & CO.       | (216) 238-0300 |
| MICHIGAN              |                                       | PENNSYLVANIA             |                |
| SAI MARKETING CORP    |                                       | DOLFUSS ROOT & CO        | (412) 221-4420 |
| NEBRASKA              | , , , , , , , , , , , , , , , , , , , | UTAH                     |                |
| LORENZ SALES          | (402) 475-4660                        | R <sup>2</sup> MARKETING | (801) 595-0631 |

Advanced Micro Devices reserves the right to make changes in its product without notice in order to improve design or performance characteristics. The performance characteristics listed in this document are guaranteed by specific tests, correlated testing, guard banding, design and other practices common to the industry. For specific testing details, contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

 ADVANCED MICRO DEVICES 901 Thompson Pl., P.O. Box 3453, Sunnyvale, CA 94088, USA
 © 1985 Advanced Micro Devices, Inc

 TEL. (408) 732-2400 • TWX: 910-339-9280 • TELEX: 34-6306 • TOLL FREE: (800) 536-8450
 Printed in U.S.A. SOG-8-12M-10/85-0

## ADVANCED MICRO DEVICES DOMESTIC SALES OFFICES

•

| ALABAMA           | (205) 882-9122 |
|-------------------|----------------|
| ARIZONA,          |                |
| Tempe             | (602) 242-4400 |
| Tucson            | (602) 792-1200 |
| CALIFORNIA,       |                |
| El Segundo        | (213) 640-3210 |
| Newport Beach     | (714) 752-6262 |
| San Diego         | (619) 560-7030 |
| Sunnyvale         | (408) 720-8811 |
| Woodland Hills    | (818) 992-4155 |
| COLORADO          | (303) 691-5100 |
| CONNECTICUT,      |                |
| Southbury         | (203) 264-7800 |
| FLORIDA,          |                |
| Altamonte Springs | (305) 339-5022 |
| Clearwater        | (813) 530-9971 |
| Ft Lauderdale     | (305) 484-8600 |
| Melbourne         | (305) 254-2915 |
| GEORGIA           | (404) 449-7920 |
| ILLINOIS          | (312) 773-4422 |
| INDIANA           | (317) 244-7207 |
| KANSAS            | (913) 451-3115 |
| MARYLAND          | (301) 796-9310 |
|                   |                |

| MASSACHUSETTS<br>MINNESOTA<br>NEW JERSEY<br>NEW YORK. | (612) 938-0001                   |
|-------------------------------------------------------|----------------------------------|
|                                                       | (315) 457-5400                   |
| Poughkeepsie                                          | (914) 471-8180                   |
| Woodbury                                              | (516) 364-8020                   |
| NORTH CAROLINA.                                       | (704) 505 1975                   |
| Charlotte                                             |                                  |
| Raleigh<br>OREGON                                     | (503) 245-0080                   |
| OHIO.                                                 |                                  |
| Columbus                                              | (614) 891-6455                   |
| PENNSYLVANIA,                                         |                                  |
| Allentown                                             | (215) 398-8006                   |
| Willow Grove                                          | (215) 657-3101                   |
| TEXAS,                                                |                                  |
| Austin                                                | (512) 346-7830                   |
|                                                       | (214) 934-9099<br>(713) 785-9001 |
| Houston                                               | (206) 455-3600                   |
| WISCONSIN                                             | (414) 782-7748                   |
|                                                       | (,                               |

## INTERNATIONAL SALES OFFICES

| BELGIUM.         |                     | HONG KONG.         | <b>TE:</b> 0.000077 |
|------------------|---------------------|--------------------|---------------------|
| Bruxelies        | TEL: (02) 771 99 93 | Kowloon            | TEL                 |
|                  | FAX:                |                    | FAX: 1234276        |
|                  | TLX:                |                    | TLX: 50426          |
| CANADA, Ontario, |                     | ITALY, Milano      | TEL: (02) 3390541   |
| Kanata           | TEL: (613) 592-0090 |                    | FAX                 |
| Willowdale       | TEL: (416) 224-5193 |                    | TLX                 |
|                  | FAX. (416) 224-0056 | JAPAN, Tokyo       | TEL (03) 345-8241   |
| FRANCE.          |                     | - , - , -          | FAX: 3425196        |
| Paris            | TEL: (01) 687.36.66 |                    | TLX: J24064 AMDTKOJ |
| 1 4110           | FAX 6862185         | LATIN AMERICA.     |                     |
|                  | TLX: 20253          | Ft. Lauderdale     | TEL (305) 484-8600  |
| GERMANY,         | TEX                 | Lauderdale         | FAX: (305) 485-9736 |
|                  | TEL (051.40) 50 55  | OMEDENI On althous |                     |
| Hannover area    | TEL (05143) 50 55   | SWEDEN, Stockholm  | TEL. (08) 733 03 50 |
|                  | FAX: 5553           |                    | FAX: 7332285        |
|                  | TLX. 925287         |                    | TLX 11602           |
| München          | TEL. (089) 41 14-0  | UNITED KINGDOM     |                     |
|                  | FAX: 406490         | Manchester area    | TEL: (0925) 828008  |
|                  | TLX: 523883         |                    | FAX: 827693         |
| Stuttgart        | TEL:                |                    |                     |
| ololiga          | (0711) 62 33 77     |                    | TLX 628524          |
|                  | 511                 | Landon orno        | TE1 (04000) 00101   |
|                  |                     | London area        |                     |
|                  | TLX 721882          |                    | FAX. 22179          |
|                  |                     |                    | TLX 859103          |

## NORTH AMERICAN REPRESENTATIVES

| CALIFORNIA            |                      | NEW JERSEY               |                            |
|-----------------------|----------------------|--------------------------|----------------------------|
| I <sup>2</sup> INC    | OEM (408) 988-3400   | TAI CORPORATION          | (609) 933-2600             |
|                       | DISTI (408) 498-6868 | NEW MEXICO               |                            |
| CONNECTICUT           |                      | THORSON DESERT STATES    | <br>(505) 293-8555         |
| SCIENTIFIC COMPONENTS | (203) 272-2963       | NEW YORK                 |                            |
| 1DAHO                 |                      | NYCOM, INC               | <br>(315) 437-8343         |
|                       | (208) 322-5022       | OHIO                     |                            |
| INDIANA               |                      | Dayton                   |                            |
|                       | (317) 241-9276       | DOLFUSS ROOT & CO        | <br>(513) <b>433-6</b> 776 |
| AWC                   |                      | Strongsville             |                            |
| LORENZ SALES          | (319) 377-4666       | DOLFUSS ROOT & CO        | (216) 238-0300             |
| MICHIGAN              |                      | PENNSYLVANIA             |                            |
|                       | (313) 227-1786       | DOLFUSS ROOT & CO        | (412) 221-4420             |
| NEBRASKA              |                      | UTAH                     |                            |
| LORENZ SALES          | (402) 475-4660       | R <sup>2</sup> MARKETING | <br>(801) 595-0631         |

Advanced Micro Devices reserves the right to make changes in its product without notice in order to improve design or performance characteristics. The performance characteristics listed in this document are guaranteed by specific tests, guard banding, design and other practices common to the industry. For specific testing details, contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.

.

ADVANCED MICRO DEVICES 901 Thompson PL, PO Box 3453, Sunnyvale, CA 94088, USA TEL (408) 732-2400 • TWX 910-339-9280 • TELEX. 34-6306 • TOLL FREE (800) 5388450 © 1985 Advanced Micro Devices, Inc. Printed in U.S.A. SOG-B-5M-12/85-0

# Am28F010

### 131,072 x 8-Bit CMOS Flash Memory

### DISTINCTIVE CHARACTERISTICS

- High performance
   90 ns maximum access time
- Low power consumption
   30 mA maximum active current
   100 µA maximum standby current
- Compatible with JEDEC-standard bytewide 32-Pin E<sup>2</sup>PROM pinouts
   – 32-pin DIP
  - 32-pin PLCC
- 10,000 erase/program cycles
- Program and erase voltage 12.0 V ±5%
- Latch-up protected to 100 mA from -1 V to V<sub>cc</sub>+1 V

### GENERAL DESCRIPTION

The Am28F010 is a 1 Megabit "Flash" electrically erasable, electrically programmable read only memory organized as 128K bytes of 8 bits each. The Am28F010 is packaged in 32-pin PDIP and PLCC versions which allow for upgrades to the 2 Megabit density. The device is also offered in ceramic DIP and LCC packages. It is designed to be reprogrammed and erased in-system or in standard EPROM programmers.

The standard Am28F010 offers access times as fast as 90 ns, allowing operation of high-speed microprocessors without wait states. To eliminate bus contention, the Am28F010 has separate chip enable ( $\overline{CE}$ ) and output enable ( $\overline{OE}$ ) controls.

AMD's Flash memories augment EPROM functionality with in-circuit electrical erasure and programming. The Am28F010 uses a command register to manage this functionality, while maintaining a standard 32-pin pinout. The command register allows for 100% TTL level control inputs and fixed power supply levels during erase and programming, while maintaining maximum EPROM compatibility.

AMD's Flash technology reliably stores memory contents even after 10,000 erase and program cycles. The AMD cell is designed to optimize the erase and programming mechanisms. In addition, the combination of advanced tunnel oxide processing and low internal electric fields for erase and programming operations produces reliable cycling. The Am28F010 uses a  $12.0 V \pm 5\% V_{PP}$  supply to perform the Flasherase and Flashrite algorithms.

The highest degree of latch-up protection is achieved with AMD's proprietary non-epi process. Latch-up protection is provided for stresses up to 100 milliamps on address and data pins from -1 V to V<sub>CC</sub>+1 V.

■ Flasherase<sup>™</sup> Electrical Bulk Chip-Erase

Advanced

Micro Devices

- One second typical chip-erase
- Flashrite<sup>™</sup> programming
   10 µs typical byte-program
   Less than 2 seconds typical chip program
- Command register architecture for microprocessor/microcontroller compatible write interface
- On-chip address and data latches
- Advanced CMOS flash memory technology
   Low cost single transistor memory cell

The Am28F010 is byte programmable using 10 µs programming pulses in accordance with AMD's Flashrite programming algorithm. The typical room temperature programming time of the Am28F010 is less than two seconds. The entire chip is bulk erased using 10ms erase pulses according to AMD's Flasherase algorithm. Typical erasure at room temperature is accomplished in less than one second. The windowed package and the 15–20 minutes required for EPROM erasure using ultraviolet light are eliminated.

Commands are written to the command register using standard microprocessor write timings. Register contents serve as inputs to an internal state-machine which controls the erase and programming circuitry. During write cycles, the command register internally latches address and data needed for the programming and erase operations. For system design simplification, the Am28F010 is designed to support either WE or CE controlled writes. During a system write cycle, addresses are latched on the falling edge of WE or CE whichever occurs last. Data is latched on the rising edge of WE or CE whichever occurs first. To simplify the following discussion, the WE pin is used as the write cycle control pin throughout the rest of this text. All setup and hold times are with respect to the WE signal.

AMD's Flash technology combines years of EPROM and E<sup>2</sup>PROM experience to produce the highest levels of quality, reliability, and cost effectiveness. The Am28F010 electrically erases all bits simultaneously using Fowler-Nordheim tunneling. The bytes are programmed one byte at a time using the EPROM programming mechanism of hot electron injection. .

### **BLOCK DIAGRAM**



11561-0018

.

### **PRODUCT SELECTOR GUIDE**

| Family Part No.                          | Am28F010 |      |      |      |  |  |  |  |
|------------------------------------------|----------|------|------|------|--|--|--|--|
| Ordering part No:<br>± 10% Vcc Tolerance | -90      | -120 | -150 | -200 |  |  |  |  |
| ± 5% Vcc Tolerance                       | 95       | -    | -    | -    |  |  |  |  |
| Max Access Time (ns)                     | 90       | 120  | 150  | 200  |  |  |  |  |
| CE (E) Access (ns)                       | 90       | 120  | 150  | 200  |  |  |  |  |
| OE (G) Access (ns)                       | 40       | 50   | 65   | 75   |  |  |  |  |

ć



DIP

LCC/PLCC



Note: Pin 1 is marked for orientation

LOGIC SYMBOL



11559-004A

| PIN DESCRI      | PTION                                                                                                                                                                                                                                                                                  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Functional Description                                                                                                                                                                                                                                                                 |
| $A_0 - A_{16}$  | Address Inputs for memory locations. Internal latches hold addresses during write cycles.                                                                                                                                                                                              |
| $DQ_0 - DQ_7$   | Data Inputs during memory write cycles. Internal latches hold data during write cycles. Data<br>Outputs during memory read cycles.                                                                                                                                                     |
| ĈĒ (Ē)          | The Chip Enable active low input activates the chip'scontrol logic and input buffers. Chip<br>Enable high will deselect the device and operates the chip in stand-by mode.                                                                                                             |
| OE (G)          | The Output Enable active low input gates the outputs of the device through the data buffers during memory read cycles.                                                                                                                                                                 |
| WE (W)          | The Write Enable active low input controls the write function of the command register to the mem-<br>ory array. The target address is latched on the falling edge of the Write Enable pulse and the ap<br>propriate data is latched on the rising edge of the pulse.                   |
| Vpp             | Power supply for erase and programming. V <sub>PP</sub> must be at high voltage in order to write to the command register. The command register controls all functions required to alter the memory array contents. Memory contents cannot be altered when $V_{PP} \leq V_{CC} + 2V$ . |
| Vcc             | Power supply for device operation. (5.0V $\pm$ 5% or 10%)                                                                                                                                                                                                                              |
| V <sub>SS</sub> | Ground                                                                                                                                                                                                                                                                                 |
| NC              | No Connect-corresponding pin is not connected internally to the die.                                                                                                                                                                                                                   |

### ORDERING INFORMATION Standard Products

AMD standard products are available in several packages and operating ranges. The ordering number (Valid Combination)



Am28F010

1 Megabit (128K x 8-Bit) CMOS Flash Memory

| Valid Combinations                                                         |                                                                                                                                                                                                                                           |  |  |  |  |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| AM28F010-95<br>AM28F010-90<br>AM28F010-120<br>AM28F010-150<br>AM28F010-200 | C4DC, C4DCB, C4DI,<br>C4DIB, C4DE, C4DEB,<br>C4LC, C4LCB, C4LEB,<br>C4LC, C4LCB, C4LEB,<br>C4PC, C4PI, C4JC,<br>C4JI, C3DC, C3DCB,<br>C3DI, C3DIB, C3DE,<br>C3DEB, C3LC, C3LCB,<br>C3LI, C3LIB, C3LE,<br>C3LEB, C3PC, C3PI,<br>C3JC, C3JI |  |  |  |  |

#### Valid Combinations

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

### ORDERING INFORMATION APL Products

AMD products for Aerospace and Defense applications are available in several packages and operating ranges. APL (Approved Products List) products are fully compliant with MIL-STD-883C requirements. The order number (Valid Combination) is formed by a combination of: **a. Device Number** 



| Valid Combinations |                |  |  |  |  |
|--------------------|----------------|--|--|--|--|
| AM28F010-90        |                |  |  |  |  |
| AM28F010-120       | C4/BXA, C4/BUA |  |  |  |  |
| AM28F010-150       | C3/BXA, C3/BUA |  |  |  |  |
| AM28F010-200       |                |  |  |  |  |

#### **Valid Combinations**

Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.

#### **Group A Tests**

Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11.

### **BASIC PRINCIPLES**

The Am28F010 uses 100% TTL-level control inputs to manage the command register. Erase and reprogramming operations use a fixed 12.0V  $\pm$  5% power supply.

### **Read Only Memory**

Without high  $V_{PP}$  voltage, the Am28F010 functions as a read only memory and operates like a standard EPROM. The control inputs still manage traditional read, standby, output disable, and Auto select modes.

### **Command Register**

The command register is enabled only when high voltage is applied to the  $V_{PP}$  pin. The erase and reprogramming operations are only accessed via the register. In addition, two-cycle commands are required for erase and reprogramming operations. The traditional read, standby, output disable, and Auto select modes are available via the register.

The Am28F010's command register is written using standard microprocessor write timings. The register controls an internal state machine that manages all device operations. For system design simplification, the Am28F010 is designed to support either  $\overline{WE}$  or  $\overline{CE}$  controlled writes. During a system write cycle, addresses are latched on the falling edge of  $\overline{WE}$  or  $\overline{CE}$  whichever occurs last. Data is latched on the rising edge of  $\overline{WE}$  or  $\overline{CE}$  whichever occur first. To simplify the following discussion, the  $\overline{WE}$  pin is used as the write cycle control pin throughout the rest of this text. All setup and hold times are with respect to the  $\overline{WE}$  signal.

### **Overview of Erase/Program Operations**

#### Erase Sequence

A multiple step command sequence is required to erase the Flash device (a two-cycle Erase command and repeated one cycle verify commands).

#### Note:

The Flash memory array must be completely programmed prior to erasure. Refer to the Flasherase Algorithm.

- 1. Set-up Erase: Write the Set-up Erase command to the command register.
- 2. Erase: Write the Erase command (same as Set-up Erase command) to the command register again.

The second command initiates the erase operation. The system software routines must now time-out the erase pulse width (10 ms) prior to issuing the Eraseverify command.

3. Erase-verify: Write the Erase-verify command to the command register. This command terminates the erase operation. After the erase operation, each byte of the array must be verified. Address information must be supplied with the Erase-verify command. This command verifies the margin and outputs the addressed byte in order to compare the array data with FFH data (Byte erased). After successful data verification the Erase-verify command is written again with new address information. Each byte of the array is sequentially verified in this manner.

If data of the addressed location is not verified, the Erase sequence is repeated until the entire array is successfully verified or the sequence is repeated 1000 times.

#### Programming Sequence

A three step command sequence (a two-cycle Program command and one cycle Verify command) is required to program a byte of the Flash array. Refer to the Flashrite Algorithm.

- 1. Set-up Program: Write the Set-up Program command to the command register.
- 2. Program: Write the Program command to the command register with the appropriate Address and Data. The system software routines must now timeout the program pulse width ( $10 \mu s$ ) prior to issuing the Program-verify command.
- 3. Program-verify: Write the Program-verify command to the command register. This command terminates the programming operation. In addition, this command verifies the margin and outputs the byte just programmed in order to compare the array data with the original data programmed. After successful data verification, the programming sequence is initiated again for the next byte address to be programmed.

If data is not verified, the Program sequence is repeated until a successful comparison is verified or the sequence is repeated 25 times.

### FUNCTIONAL DESCRIPTION Description Of User Modes

|            | Operation                                 | CE<br>(Ē) | OE<br>(G) | WE<br>(W) | V <sub>PP</sub><br>(Note 1) | Ao             | Ag                          | ٧O                          |
|------------|-------------------------------------------|-----------|-----------|-----------|-----------------------------|----------------|-----------------------------|-----------------------------|
|            | Read                                      | ViL       | VL        | Viri      | VPPL                        | A9             | Ao                          | Dout                        |
|            | Standby                                   | VIH       | Х         | Χ.        | VPPL                        | Х              | X                           | HIGH Z                      |
| Read-Only  | Output Disable                            | VIL       | ViH       | VIH       | VPPL                        | X              | X                           | HIGH Z                      |
|            | Auto-select Manufacturer<br>Code (Note 2) | Vil       | VL        | νн        | Vppl                        | VL             | ViD<br>(Note 3)             | CODE<br>(01H)               |
|            | Auto-select Device Code<br>(Note 2)       | ViL       | Vil       | VIH       | VPPL                        | ViH            | V <sub>ID</sub><br>(Note 3) | CODE<br>(A7H)               |
|            | Read                                      | Vil       | ViL       | VIH       | Vррн                        | A <sub>0</sub> | A9                          | Dour<br>(Note 4)            |
| Read/Write | Standby (Note 5)                          | ViH       | Х         | Х         | VPPH                        | Х              | X                           | HIGH Z                      |
| neau/mile  | Output Disable                            | ViL       | VIH       | ViH       | VPPH                        | Х              | X                           | HIGH Z                      |
|            | Write                                     | ViL       | VIH       | ViL       | VPPH                        | Ao             | Ag                          | D <sub>IN</sub><br>(Note 6) |

Legend:

X = Don't care, where Don't Care is either V<sub>IL</sub> or V<sub>IH</sub> levels, V<sub>PPL</sub> = V<sub>PP</sub> < V<sub>CC</sub> + 2V, See DC Characteristics for voltage levels of V<sub>PPH</sub>, 0V < An <V<sub>CC</sub> + 2V, (normal TTL or CMOS input levels, where n = 0 or 9).

#### Notes:

- 1. V<sub>PPL</sub> may be grounded, connected with a resistor to ground, or ≤ V<sub>CC</sub> +2.0V. V<sub>PPH</sub> is the programming voltage specified for the device. Refer to the DC characteristics. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents can be read but not written or erased.
- 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 2.
- 3.  $11.5 \le V_{ID} \le 13.0V$
- 4. Read operation with Vpp = VppH may access array data or the Auto select codes.
- 5. With Vpp at high voltage, the standby current is Icc + Ipp (standby).
- 6. Refer to Table 3 for valid D<sub>IN</sub> during a write operation.
- 7. All inputs are Don't Care unless otherwise stated, where Don't Care is either V<sub>IL</sub> or V<sub>IH</sub> levels. In the Auto select mode all addresses except A<sub>9</sub> and A<sub>0</sub> must be held at V<sub>IL</sub>.

### READ ONLY MODE

### V<sub>PP</sub> < V<sub>CC</sub> + 2V Command Register Inactive

#### Read

The Am28F010 functions as a read only memory when-V<sub>PP</sub> < V<sub>CC</sub> + 2V. The Am28F010 has two control functions. Both must be satisfied in order to output data.  $\overline{CE}$ controls power to the device. This pin should be used for specific device selection.  $\overline{OE}$  controls the device outputs and should be used to gate data to the output pins if a device is selected.

Address access time  $t_{ACC}$  is equal to the delay from stable addresses to valid output data. The chip enable access time  $t_{CE}$  is the delay from stable addresses and stable  $\overline{CE}$  to valid data at the output pins. The output enable access time is the delay from the falling edge of  $\overline{OE}$  to valid data at the output pins (assuming the addresses have been stable at least  $t_{ACC} - t_{OE}$ ).

#### **Standby Mode**

The Am28F010 has two standby modes. The CMOS standby mode ( $\overline{CE}$  input held at V<sub>CC</sub> ± 0.5V), consumes less than 100µA of current. TTL standby mode ( $\overline{CE}$  is held at V<sub>H</sub>) reduces the current requirements to less than 1mA. When in the standby mode the outputs are in a high impedance state, independent of the  $\overline{OE}$  input.

If the device is deselected during erasure, programming, or program/erase verification, the device will draw active current until the operation is terminated.

### **Output Disable**

Output from the device is disabled when  $\overline{OE}$  is at a logic high level. When disabled, output pins are in a high impedance state.

### Auto Select

Flash memories can be programmed in-system or in a standard PROM programmer. The device may be soldered to the circuit board upon receipt of shipment and programmed, in-system. Alternatively, the device may initially be programmed in a PROM programmer prior to soldering the device to the board.

The Auto select mode allows the reading out of a binary code from the device that will identify its manufacturer and type. This mode is intended for the purpose of automatically matching the device to be programmed with its corresponding programming algorithm. This mode is functional over the entire temperature range of the device.

#### Programming In A Prom Programmer

To activate this mode, the programming equipme. must force  $V_{ID}$  (11.5V to 13.0V) on address  $A_9$ . Two identifier bytes may then be sequenced from the device outputs by toggling address  $A_0$  from  $V_{IL}$  to  $V_{IH}$ . All other address lines must be held at  $V_{IL}$ , and  $V_{PP}$  must be less than or equal to  $V_{CC} + 2.0V$  while using this Auto select mode. Byte 0 ( $A_0 = V_{IL}$ ) represents the manufacturer code and byte 1 ( $A_0 = V_{IH}$ ) the device identifier code. For the Am28F010 these two bytes are given in the table below. All identifiers for manufacturer and device codes will exhibit odd parity with the MSB (DQ<sub>7</sub>) defined as the parity bit.

(Refer to the AUTO SELECT paragraph in the ERASE, PROGRAM, and READ MODE section for programming the Flash memory device in-system).

|                   | Table 2. Amzoruto Adio Select Code |               |     |     |     |     |                 |                 |     |     |
|-------------------|------------------------------------|---------------|-----|-----|-----|-----|-----------------|-----------------|-----|-----|
| Туре              | Ao                                 | Code<br>(HEX) | DQ7 | DQ6 | DQ5 | DQ4 | DQ <sub>3</sub> | DQ <sub>2</sub> | DQ1 | DQo |
| Manufacturer Code | VIL                                | 01            | 0   | 0   | 0   | 0   | 0               | 0               | 0   | 1   |
| Device Code       | VIH                                | A7            | 1   | 0   | 1   | 0   | 0               | 1               | 1   | 1   |

Table 2. Am28F010 Auto Select Code

### ERASE, PROGRAM, AND READ MODE

### V<sub>PP</sub> = 12.0 V ± 5% Command Register Active Write Operations

High voltage must be applied to the VPP pin in order to activate the command register. Data written to the register serves as input to the internal state machine. The output of the state machine determines the operational function of the device.

The command register does not occupy an addressable memory location. The register is a latch that stores the command, along with the address and data information needed to execute the command. The register is written by bringing  $\overline{WE}$  and  $\overline{CE}$  to  $V_{IL}$ , while  $\overline{OE}$  is at  $V_{IH}$ . Addresses are latched on the falling edge of  $\overline{WE}$ , while data is latched on the rising edge of the  $\overline{WE}$  pulse. Standard microprocessor write timings are used.

Register bits  $R_7 - R_0$  correspond to the data inputs  $DQ_7 - DQ_0$  (Refer to Table 3). Register bits  $R_7 - R_5$  store the command data. All register bits  $R_4$  to  $R_0$  must be zero. The only exceptions are: the reset command, when FFH is written to the register and Auto select, when 90H or 80H is written to the register.

The device requires the  $\overline{OE}$  pin to be V<sub>IH</sub> for write operations. This condition eliminates the possibility for bus contention during programming operations. In order to write,  $\overline{OE}$  must be V<sub>IH</sub>, and  $\overline{CE}$  and  $\overline{WE}$  must be V<sub>IL</sub>. If any pin is not in the correct state a write command will not be executed.

Refer to AC Write Characteristics and the Erase/Programming Waveforms for specific timing parameters.

#### **Command Definitions**

The contents of the command register default to 00H (Read Mode) in the absence of high voltage applied to the  $V_{PP}$  pin. The device operates as a read only memory. High voltage on the  $V_{PP}$  pin enables the command register. Device operations are selected by writing specific data codes into the command register. Table 4 defines these register commands.

#### **Read Command**

Memory contents can be accessed via the read command when  $V_{PP}$  is high. To read from the device, write 00H into the command register. Wait 6µs before reading the first accessed address location. All subsequent Read operations take t<sub>ACC</sub>. Standard microprocessor read cycles access data from the memory. The device will remain in the read mode until the command register contents are altered.

The command register defaults to 00H (read mode) upon V<sub>PP</sub> power-up. The 00H (Read Mode) register default helps ensure that inadvertent alteration of the memory contents does not occur during the V<sub>PP</sub> power transition. Refer to the AC Read Characteristics and Waveforms for the specific timing parameters.

|                   | 1 4010 | 0. 00111       |                 | cyisici         |     |                   |                |                 |                 |
|-------------------|--------|----------------|-----------------|-----------------|-----|-------------------|----------------|-----------------|-----------------|
| Data Input/Output | -      | DQ7            | DQ <sub>6</sub> | DQ <sub>5</sub> | DQ₄ | DQ <sub>3</sub>   | DQ2            | DQ <sub>1</sub> | DQ <sub>0</sub> |
| Command Register  |        | R <sub>7</sub> | R <sub>6</sub>  | Rs              | R4  | 'R <sub>3</sub> ' | R <sub>2</sub> | R <sub>1</sub>  | R₀              |
| Data/Commands*    |        | X              | Х               | X               | X   | X                 | X              | X               | X               |

Table 3 Command Register

\* Notes:

1. See Table 4 Am28F010 Command Definitions

2. X = Appropriate Data or Register Commands

| Table 4. Am28F010 | Command | Definitions |
|-------------------|---------|-------------|
|-------------------|---------|-------------|

|                                    | First Bus Cy          | cle                 |                  | Second Bus Cycle      |                     |                  |  |  |
|------------------------------------|-----------------------|---------------------|------------------|-----------------------|---------------------|------------------|--|--|
| Command                            | Operation<br>(Note 1) | Address<br>(Note 2) | Data<br>(Note 3) | Operation<br>(Note 1) | Address<br>(Note 2) | Data<br>(Note 3) |  |  |
| Read Memory (Note 6)               | Write                 | X                   | 00H              | Read                  | RA                  | RD               |  |  |
| Read Auto select                   | Write                 | X                   | 80H or 90H       | Read                  | 00H/01H             | 01H/A7H          |  |  |
| Set-up Erase/Erase<br>(Note 4)     | Write                 | x                   | 20H              | Write                 | x                   | 20H              |  |  |
| Erase-Verify (Note 4)              | Write                 | EA                  | A0H              | Read                  | X                   | EVD              |  |  |
| Set-up Program/Program<br>(Note 5) | Write                 | X                   | 40H              | Write                 | РА                  | PD               |  |  |
| Program-Verify (Note 5)            | Write                 | X                   | СОН              | Read                  | X                   | PVD              |  |  |
| Reset                              | Write                 | X                   | FFH              | Write                 | X                   | FFH              |  |  |

Notes:

- 1. Bus operations are defined in Table 1.
- RA = Address of the memory location to be read.
   EA = Address of the memory location to be read during erase-verify.
   PA = Address of the memory location to be programmed.
   Addresses are latched on the falling edge of the WE pulse.
- 3. RD = Data read from location RA during read operation.
   EVD = Data read from location EA during erase-verify.
   PD = Data to be programmed at location PA. Data latched on the rising edge of WE.
   PVD = Data read from location PA during program-verify. PA is latched on the Program command.
- 4. Figure 1 illustrates the Flasherase Electrical Erase Algorithm.
- 5. Figure 2 illustrates the Flashrite Programming Algorithm.
- 6. Wait 6µs after first Read command before accessing the data. When the second bus command is a Read command, all subsequent Read operations take tacc.

### **Erase Sequence**

#### Set-up Erase/Erase Commands

#### Set-up Erase

Set-up Erase is the first of a two-cycle erase command. It is a command-only operation that stages the device for bulk chip erase. The array contents are not altered with this command. 20H is written to the command register in order to perform the Set-up Erase operation.

#### Erase

The second two-cycle erase command initiates the bulk erase operation. You must write the Erase command (20H) again to the register. The erase operation begins with the rising edge of the  $\overline{WE}$  pulse. The erase operation must be terminated by writing a new command (Erase-verify) to the register.

This two step sequence of the Set-up and Erase commands helps to ensure that memory contents are not accidentally erased. Also, chip erasure can only occur when high voltage is applied to the  $V_{pp}$  pin and all control pins are in their proper state. In absence of this high voltage, memory contents cannot be altered. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

#### Note:

The Flash memory device must be fully programmed to 00H data prior to erasure. This equalizes the charge on all memory cells ensuring reliable erasure.

#### Erase-verify Command

The erase operation erases all bytes of the array in paallel. After the erase operation, all bytes must be sequentially verified. The Erase-verify operation is initiated by writing A0H to the register. The byte address to be verified must be supplied with the command. Addresses are latched on the falling edge of the  $\overline{WE}$  pulse. The rising edge of the  $\overline{WE}$  pulse terminates the erase operation.

#### Margin Verify

During the Erase-verify operation, the Am28F010 applies an internally generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are properly erased.

#### Verify Next Address

You must write the Erase-verify command with the appropriate address to the register prior to verification of each address. Each new address is latched on the falling edge of WE. The process continues for each byte in

the memory array until a byte does not return FFH data or all the bytes in the array are accessed and verified.

sure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters.

If an address is not verified to FFH data, the entire chip is erased again (refer to Set-up Erase/Erase). Erase verification then resumes at the address that failed to verify. Erase is complete when all bytes in the array have been verified. The device is now ready to be programmed. At this point, the verification operation is terminated by writing a valid command (e.g. Program set-up) to the command register. Figure 1 and Table 5, the Flasherase electrical erase algorithm, illustrate how commands and bus operations are combined to perform electrical era-

#### Note:

The erase-verify command must be written to the register in order to terminate the erase operation. During the erase operations, the local microprocessor must be dedicated to run software timing routines (erase in 10ms) as specified in AMD's Flasherase algorithm.

Should a system interrupt occur during an erase operation, always write the Erase-verify command prior to executing an interrupt sequence.





### Flasherase Electrical Erase Algorithm

This Flash memory device erases the entire array in parallel. The erase time depends on  $V_{PP}$ , temperature, and number of erase/program cycles on the device. In general, reprogramming time increases as the number of erase/program cycles increases.

The Flasherase electrical erase algorithm employs an interactive closed loop flow to simultaneously erase all bits in the array. Erasure begins with a read of the memory contents. The Am28F010 is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by executing the Flash-rite programming algorithm with the appropriate data pattern.

Should the device be currently programmed, data other than FFH will be returned from address locations. Follow the Flasherase algorithm. Uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (Data = 00H). This is accomplished using the Flashrite programming algorithm. Erasure then continues with an initial erase operation. Erase verification (Data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. If a byte fails to verify, the device is erased again. With each erase operation, an increasing number of bytes verify to the erased state. Typically, devices are erased in less than 100 pulses (1 second). Erase efficiency may be improved by storing the address of the last byte that fails to verify in a register. Following the next erase operation, verification may start at the stored address location. A total of 1000 erase operations are allowed per reprogram cycle, which corresponds to approximately 10 seconds of cumulative erase time. Erasure typically occurs in one second. The entire sequence of erase and byte verification is performed with high voltage applied to the VPP pin. Figure 1 illustrates the electrical erase algorithm.

| <b>Bus Operations</b> | Command               | Comments                                                                                                                     |
|-----------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------|
|                       |                       | Entire memory must = 00H before erasure (Note 3)<br>Note: Use Flashrite programming algorithm (Figure 2) for<br>programming. |
| Standby               |                       | Wait for V <sub>PP</sub> ramp to V <sub>PPH</sub> (Note 1)<br>Initialize:<br>Addresses<br>PLSCNT (Pulse count)               |
| Write                 | Set-Up Erase          | Data = 20H                                                                                                                   |
| Write                 | Erase                 | Data = 20H                                                                                                                   |
| Standby               |                       | Duration of Erase Operation (twnwh2)                                                                                         |
| Write                 | Erase-verify (Note 2) | Address = Byte to Verify<br>Data = A0H<br>Stops Erase Operation                                                              |
| Standby               |                       | Write Recovery Time before Read = 6µs                                                                                        |
| Read                  |                       | Read byte to verify erasure                                                                                                  |
| Standby               |                       | Compare output to FFH<br>Increment pulse count                                                                               |
| Write                 | Read                  | Data = 00H, reset the register for read operations.                                                                          |
| Standby               |                       | Wait for VPP ramp to VPPL (Note 1)                                                                                           |

#### Table 5. Flasherase Electrical Erase Algorithm

Notes:

1. See DC Characteristics for value of VppH or VppL. The Vpp power supply can be hard-wired to the device or switchable. When Vpp is switched, VppL may be ground, no connect with a resistor tied to ground, or less than V<sub>CC</sub> + 2.0V.

2. Erase Verify is performed only after chip erasure. A final read compare may be performed (optional) after the register is written with the read command.

3. The erase algorithm Must Be Followed to ensure proper and reliable operation of the device.



Figure 2. A.C. Waveforms For Erase Operations

#### Analysis Of Erase Timing Waveform

#### Note:

This analysis does not include the requirement to program the entire array to 00H data prior to erasure. Refer to the Flasherase algorithm.

#### Set-up Erase/Erase

This analysis illustrates the use of two-cycle erase commands (section A&B). The first erase command (20H) is a set-up command and does not affect the array data (section A). The second erase command (20H) initiates the erase operation (section B) on the rising edge of this WE pulse. All bytes of the memory array are erased in parallel. No address information is required.

The erase pulse occurs in section C.

#### Time-out

A software timing routine (10ms duration) must be initiated on the rising edge of the  $\overline{WE}$  pulse of section B.

#### Erase-verify

Upon completion of the erase software timing routine, the microprocessor must write the Erase-verify command (A0H). This command terminates the erase operation on the rising edge of the  $\overline{\text{WE}}$  pulse (section D). The Erase-verify command also stages the device for data verification (section F).

After each erase operation each byte must be verified. The byte address to be verified must be supplied with the Erase-verify command (section D). Addresses are latched on the falling edge of the  $\overline{WE}$  pulse.

Another software timing routine (6µs duration) must be executed to allow for generation of internal voltages for margin checking and read operation (section E).

During Erase-verification (section F) each address that returns FFH data is successfully erased. Each address of the array is sequentially verified in this manner by repeating sections D thru F until the entire array is verified or an address fails to verify. Should an address location fail to verify to FFH data, erase the device again. Repeat sections A thru F. Resume verification (section D) with the failed address.

Each data change sequence allows the device to use up to 1,000 erase pulses to completely erase. Typically 100 erase pulses are required.

#### Notes:

1. All address locations must be programmed to 00H prior to erase. This equalizes the charge on all memory cells and ensures reliable erasure.

2. The erase verify command must be written to terminate the erase operation. Should a system interrupt occur during an erase operation, always write the erase-verify command prior to executing an interrupt sequence.

#### **Programming Sequence**

#### Set-up Program/Program Command

#### Set-up Program

The Am28F010 is programmed byte by byte. Bytes may be programmed sequentially or at random. Set-up Program is the first of a two-cycle program command. It stages the device for byte programming. The Set-up Program operation is performed by writing 40H to the command register.

#### Program

Only after the program set-up operation is completed will the next WE pulse initiate the active programming operation. The appropriate address and data for programming must be available on the second WE pulse. Addresses and data are internally latched on the falling and rising edge of the WE pulse respectively. The rising edge of WE also begins the programming operation. You must write the Program-verify command to terminate the programming operation. This two step sequence of the Set-up and Program commands helps to ensure that memory contents are not accidentally written. Also, programming can only occur when high voltage is applied to the VPP pin and all control pins are in their proper state. In absence of this high voltage, memory contents cannot be programmed.

Refer to AC Characteristics and Waveforms for specific timing parameters.

#### Program Verify Command

Following each programming operation, the byte just programmed must be verified.

Write COH into the command register in order to initiate the Program-verify operation. The rising edge of this WE pulse terminates the programming operation. The Program-verify operation stages the device for verification of the last byte programmed. Addresses were previously latched. No new information is required.

#### Margin Verify

During the Program-verify operation, the Am28F010 applies an internally generated margin voltage to the addressed byte. A normal microprocessor read cycle outputs the data. A successful comparison between the programmed byte and the true data indicates that the byte was successfully programmed. The original programmed data should be stored for comparison. P gramming then proceeds to the next desired byte location. Should the byte fail to verify, reprogram (refer to Set-up Program/Program). Figure 3 and Table 6 indicate how instructions are combined with the bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters.

#### Flashrite Programming Algorithm

The Am28F010 Flashrite programming algorithm employs an interactive closed loop flow to program data byte by byte. Bytes may be programmed sequentially or at random. The Flashrite programming algorithm uses 10 microsecond programming pulses. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The program algorithm allows for up to 25 programming operations per byte per reprogramming cycle. Most bytes verify after the first or second pulse. The entire sequence of programming and byte verification is pc formed with high voltage applied to the VPP pin. Figure 3 and Table 6 illustrate the programming algorithm.





| <b>Bus Operations</b> | Command            | Comments                                                                               |
|-----------------------|--------------------|----------------------------------------------------------------------------------------|
| Standby               |                    | Wait for V <sub>PP</sub> ramp to V <sub>PPH</sub> (Note 1)<br>Initialize pulse counter |
| Write                 | Set-Up Program     | Data = 40H                                                                             |
| Write                 | Program            | Valid Address/Data                                                                     |
| Standby               |                    | Duration of Programming Operation (twnwh1)                                             |
| Write                 | Program-Verify (2) | Data = C0H Stops Program Operation                                                     |
| Standby               | :                  | Write Recovery Time before Read = 6µs                                                  |
| Read                  |                    | Read byte to verify programming                                                        |
| Standby               |                    | Compare data output to data expected                                                   |
| Write                 | Read               | Data = 00H, resets the register for read operations.                                   |
| Standby               |                    | Wait for VPP ramp to VPPL (Note 1)                                                     |

#### Table 6. Flashrite Programming Algorithm

Notes:

 See DC Characteristics for value of VPPH. The VPP power supply can be hard-wired to the device or switchable. When VPP is switched, VPPL may be ground, no connect with a resistor tied to ground, or less than Vcc + 2.0V.

2. Program Verify is performed only after byte programming. A final read/compare may be performed (optional) after the register is written with the read command.



| Figure 4. A.C. Waveforms for Prog | ramming Operations |
|-----------------------------------|--------------------|
|-----------------------------------|--------------------|

#### Analysis Of Program Timing Waveforms

#### Set-up Program/Program

Two-cycle write commands are required for program operations (section A&B). The first program command (40H) is a set-up command and does not affect the array data (section A). The second program command latches address and data required for programming on the falling and rising edge of WE respectively (section B). The rising edge of this WE pulse (section B) also initiates the programming pulse. The device is programmed on a byte by byte basis either sequentially or randomly.

The program pulse occurs in section C.

#### Time-out

A software timing routine ( $10\mu s$  duration) must be initiated on the rising edge of the WE pulse of section B.

#### Program-verify

Upon completion of the program timing routine, the microprocessor must write the program-verify command (C0H). This command terminates the programming operation on the rising edge of the  $\overline{WE}$  pulse (section D). The program-verify command also stages the device for data verification (section F). Another software timing routine (6µs duration) must be executed to allow for generation of internal voltages for margin checking and read operations (section E).

During program-verification (section F) each byte just programmed is read to compare array data with original program data. When successfully verified, the next desired address is programmed. Should a byte fail to verify, reprogram the byte (repeat section A thru F). Each data change sequence allows the device to use up to 25 program pulses per byte. Typically, bytes are verified within one or two pulses.

#### Note:

The program-verify operation must be written to terminate the programming operation. Should a system interrupt occur during a programming operation, always write the program-verify command prior to executing an interrupt sequence.

#### Algorithm Timing Delays

There are four different timing delays associated with the Flasherase and Flashrite algorithms:

- 1. The first delay is associated with the V<sub>PP</sub> rise-time when V<sub>PP</sub> first turns on. The capacitors on the V<sub>PP</sub> bus cause an RC ramp. After switching on the V<sub>PP</sub>, the delay required is proportional to the number of devices being erased and the  $0.1\mu$ F/device. V<sub>PP</sub> must reach its final value 100ns before commands are executed.
- 2. The second delay time is the erase time pulse width (10 ms). A software timing routine should be run by the local microprocessor to time out the delay. The erase operation must be terminated at the conclusion of the timing routine or prior to executing any system interrupts that may occur during the erase operation. To ensure proper device operation, write the Erase-verify operation after each pulse, or the device may continue to erase until the memory cells are driven into depletion (over-erasure). Should this happen the internal circuitry will no longer select unique addresses. A symptom of over-erasure is an error attempting to program the next time. Occasionally it is possible to recover over-erased devices by programming all of the locations with 00H data.
- 3. A third delay time is required for each programming pulse width (10  $\mu$ s). The programming algorithm is interactive and verifies each byte after a program pulse. The program operation must be terminated at the conclusion of the timing routine or prior to executing any system interrupts that may occur during the programming operation.
- 4. A fourth timing delay associated with both the Flasherase and Flashrite algorithms is the write recovery time (6 μs). During this time internal circuitry is changing voltage levels from the erase/ program level to those used for margin verify and read operations: An attempt to read the device during this period will result in possible false data (it may appear the device is not properly erased or programmed).

#### Note:

Software timing routines should be written in machine language for each of the delays. Code written in machine language requires knowledge of the appropriate microprocessor clock speed in order to accurately time each delay.

#### **Parallel Device Erasure**

Many applications will use more than one Flash memory device. Total erase time may be minimized by implementing a parallel erase algorithm. Flash memories may erase at different rates. Therefore each device must be verified seperately. When a device is completely erased and verified use a masking code to prevent further erasure. The other devices will continue to erase until verified. The masking code applied could be the read command (00H).

#### **Power-up Sequence**

#### Vcc prior to Vpp

The Am28F010 powers-up in the Read only mode. In addition, the memory contents may only be altered after successful completion of a two step command sequence.

#### VPP prior to Vcc

During power transitions, hold any control pin ( $\overline{WE}$ ,  $\overline{OE}$  or  $\overline{CE}$ ) in a non-write condition. This disables the device from executing any write operation.

When  $V_{CC} = 0$  V, the V<sub>PP</sub> voltage is internally disabled from the device. Memory contents cannot be altered. With V<sub>PP</sub> = 12 V, the Flash device resets to the Read mode when V<sub>CC</sub> rises above 2 V.

### **Reset Command**

A reset command sequence is provided to initialize the Flash memory to a known state – Read mode. The Reset command sequence also provides the user with a means to safely abort the erase or program command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state.

If  $V_{PP}$  is left at high voltage during system resets, you must incorporate the device reset command into the hardware initialization code. This minimizes the potential for over erasure or programming if the device is in the middle of an erase or program operation during reset. Execute the reset command early in the initialization routine.

#### **Auto Select Command**

Flash memories can be programmed in-system or in a standard PROM programmer. The device may be soldered to the circuit board upon receipt of shipment and programmed in-system. Alternatively, the device may initially be programmed in a PROM programmer prior to soldering the device to the board.

#### Programming In-system

AMD's Flash memories are designed for use in applications where the local CPU afters memory contents. Accordingly, manufacturer and device codes must be accessible while the device resides in the target system. PROM programmers typically access the signature codes by raising  $A_9$  to a high voltage. However, multiplexing high voltage onto address lines is not a generally desired system design practice.

The Am28F010 contains an Auto Select operation to supplement traditional PROM programming methodology. The operation is initiated by writing 80H or 90H into the command register. Following this command, a read cycle address 0000H retrieves the manufacturer code of 01H. A read cycle from address 0001H returns the device code A7H (See Table 2). To terminate the operation, it is necessary to write another valid command into the register (See Table 3).

### **ABSOLUTE MAXIMUM RATINGS**

| Storage Temperature<br>Ceramic Packages<br>Plastic Packages | – 65°C to +150°C<br>– 65°C to +125°C |
|-------------------------------------------------------------|--------------------------------------|
| Ambient Temperature<br>with Power Applied                   | – 55°C to + 125°C                    |
| Voltage with Respect To Ground                              |                                      |

| vollage with nespect to Glound                              |                 |
|-------------------------------------------------------------|-----------------|
| All pins except A <sub>9</sub> and V <sub>PP</sub> (Note 1) | - 2.0V to 7.0V  |
| Vcc (Note 1)                                                | - 2.0V to 7.0V  |
| A <sub>9</sub> (Note 2)                                     | -2.0V to 14.0V  |
| Vpp (Note 2)                                                | - 2.0V to 14.0V |

200mA

#### Output Short Circuit Current (Note 3)

#### Notes:

- Minimum DC voltage on input or I/O pins is -0.5 V. During voltage transitions, inputs may overshoot Vss to -2.0 V for periods of up to 20 ns. Maximum DC voltage on output and I/O pins is V<sub>CC</sub> + 0.5 V. During voltage transitions, outputs may overshoot to V<sub>CC</sub> + 2.0 V for periods up to 20 ns.
- Minimum DC input voltage on A<sub>9</sub> and V<sub>PP</sub> pins is -0.5V. During voltage transitions, A<sub>9</sub> and V<sub>PP</sub> may overshoot V<sub>SS</sub> to -2.0 V for periods of up to 20 ns. Maximum DC input voltage on A<sub>9</sub> and V<sub>PP</sub> is +13.5 V which may overshoot to 14.0 V for periods up to 20 ns.
- 3. No more than one output shorted at a time. Duration of the short circuit should not be greater than one second.

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure of the device to absolute maximum rating conditions for extended periods may affect device reliability.

#### **OPERATING RANGES**

| Commercial (C) Devices<br>Case Temperature (T <sub>C</sub> )                                           | 0°C to +70°C                           |
|--------------------------------------------------------------------------------------------------------|----------------------------------------|
| Industrial (I) Devices<br>Case Temperature (T <sub>C</sub> )                                           | <b>- 40°C</b> to +85°C                 |
| Extended (E) Devices<br>Case Temperature (T <sub>C</sub> )                                             | <b> 55°C to +1</b> 25°C                |
| Military (M) Devices<br>Case Temperature (T <sub>C</sub> )                                             | – <b>55°C to</b> +125°C                |
| V <sub>CC</sub> Supply Voltages<br>V <sub>CC</sub> for Am28F010–X5<br>V <sub>CC</sub> for Am28F010–XX0 | + 4.75V to +5.25V<br>+ 4.50V to +5.50V |
| Vpp Supply Voltages<br>Read<br>Program, Erase, and Verify                                              | - 0.5V to +12.6V<br>+ 11.4V to +12.0   |

Am28F010

### MAXIMUM OVERSHOOT Maximum Negative Input Overshoot



11561-009A

#### Maximum Negative Overshoot Waveform

### **Maximum Positive Input Overshoot**



11561-010A

#### Maximum Positive Overshoot Waveform

Maximum V<sub>PP</sub> Overshoot



11561-011A

Maximum VPP Overshoot Waveform

DC CHARACTERISTICS over operating range unless otherwise specified (for APL Products, Group A, Subgroups 1, 2, 3, 7 and 8 are tested unless otherwise noted). (Notes 1–3)

### DC CHARACTERISTICS-TTL/NMOS COMPATIBLE

| Parameter<br>Symbol | Parameter Description                           | Test Conditions                                                                                | Min. | Max.                     | Unit |
|---------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------|------|--------------------------|------|
| lu                  | Input Leakage Current                           | $V_{CC} - V_{CC} Max.,$<br>$V_{IN} = V_{CC} \text{ or } V_{SS}$                                |      | ± 1.0                    | μA   |
| lio                 | Output Leakage Current                          | Vcc - Vcc Max.,<br>Vour = Vcc or Vss                                                           |      | ± 1.0                    | μA   |
| lccs                | V <sub>CC</sub> Standby Current                 | $V_{CC} = V_{CC} Max.$<br>$\overline{CE} = V_{H}$                                              |      | 1.0                      | mA   |
| lcc1                | V <sub>CC</sub> Active Read Current             | $V_{CC} - V_{CC} Max., \overline{CE} = V_{IL}, \overline{OE} = V_{IH}$<br>lour = 0 mA (Note 4) |      | 20                       | mA   |
| ICC2                | Vcc Programming Current                         | CE = VIL<br>Programming in Progress                                                            |      | <b>30</b> ·              | mA   |
| lccs                | Vcc Erase Current                               | CE = V <sub>IL</sub><br>Erasure in Progress                                                    |      | 30                       | mA   |
| IPPS                | VPP Standby Current                             | VPP = VPPL                                                                                     |      | ± 1.0                    | μA   |
| PP1                 | VPP Read Current                                | Vpp = VppH<br>Vpp = VppL                                                                       | -    | 200<br>± 1.0             | μΑ   |
| IPP2                | VPP Programming Current                         | Vpp = Vppн<br>Programming in Progress                                                          |      | 30                       | mA   |
| IPP3                | VPP Erase Current                               | VPP = VPPH<br>Erasure in Progress                                                              |      | 30                       | mA   |
| Vil                 | Input Low Voltage                               |                                                                                                | -0.5 | 0.8                      | V    |
| ViH                 | Input High Voltage                              |                                                                                                | 2.0  | V <sub>CC</sub><br>+ 0.5 | V    |
| Vol                 | Output Low Voltage                              | lo 2.1 mA<br>Vcc - Vcc Min.                                                                    |      | 0.45                     | ν.   |
| V <sub>OH1</sub>    | Output High Voltage                             | Ioн2.5 mA<br>Vcc - Vcc Min.                                                                    | 2.4  |                          | V    |
| ViD                 | As Auto Select Voltage                          | Ag = V <sub>ID</sub>                                                                           | 11.5 | 13.0                     | V    |
| ۱D                  | A <sub>9</sub> Auto Select Current              | $A_9 = V_{10} Max.$<br>Vcc - Vcc Max.                                                          |      | 50                       | μА   |
| VPPL                | VPP during Read-Only<br>Operations              | Note: Erase/Program are<br>inhibited when VPP = VPPL                                           | 0.0  | V <sub>CC</sub><br>+ 2.0 | V    |
| Vррн                | V <sub>PP</sub> during Read/Write<br>Operations |                                                                                                | 11.4 | 12.6                     | V    |

| Parameter<br>Symbol | Parameter Description               | Test Conditions                                                                              | Min.                    | Max.                     | Uni |
|---------------------|-------------------------------------|----------------------------------------------------------------------------------------------|-------------------------|--------------------------|-----|
| lu                  | Input Leakage Current               | $V_{CC} - V_{CC} Max.,$<br>$V_{IN} = V_{CC} \text{ or } V_{SS}$                              |                         | ±1.0                     | μA  |
| llo                 | Output Leakage Current              | Vcc - Vcc Max.,<br>Vout = Vcc or Vss                                                         |                         | ± 1.0                    | μA  |
| lccs                | Vcc Standby Current                 | $\frac{V_{CC} - V_{CC} Max.}{\overline{CE} = V_{H}}$                                         |                         | 100                      | μА  |
| ICC1                | V <sub>CC</sub> Active Read Current | $V_{CC} = V_{CC} Max., \overline{CE} = V_{H}, \overline{OE} = V_{H}$<br>lour = 0 mA (Note 4) |                         | 20                       | mA  |
| ICC2                | Vcc Programming Current             | CE = V <sub>IL</sub><br>Programming in Progress                                              |                         | 30                       | mA  |
| lcc3                | V <sub>CC</sub> Erase Current       | CE = VIL         Erasure in Progress                                                         |                         | 30                       | mA  |
| IPPS                | VPP Standby Current                 | VPP = VPPL                                                                                   |                         | ±1.0                     | μA  |
| IPP1                | VPP Read Current                    | Vpp = Vpph                                                                                   |                         | 200                      | μA  |
| IPP2                | VPP Programming Current             | VPP = VPPH<br>Programming in Progress                                                        |                         | 30                       | mA  |
| Іррз                | VPP Erase Current                   | VPP = VPPH<br>Erasure in Progress                                                            |                         | 30                       | mA  |
| VL                  | Input Low Voltage                   |                                                                                              | 0.5                     | 0.8                      | V   |
| Vih                 | Input High Voltage                  |                                                                                              | V <sub>CC</sub><br>-0.5 | Vcc<br>+ 0.5             | V   |
| Vol .               | Output Low Voltage                  | lo <sub>L</sub> - 2.1 mA<br>Vcc - Vcc Min.                                                   |                         | 0.45                     | V   |
| V <sub>OH1</sub>    |                                     | loн2.5 mA, V <sub>CC</sub> - V <sub>CC</sub> Min.                                            | 0.85<br>V <sub>CC</sub> |                          | v   |
| V <sub>OH2</sub>    | Output High Voltage                 | loн100 μA, V <sub>CC</sub> - V <sub>CC</sub> Min.                                            |                         |                          |     |
| VID                 | As Auto Select Voltage              | $A_9 = V_{1D}$                                                                               | 11.5                    | 13.0                     | V   |
| liD                 | As Auto Select Current              | $A_9 = V_{ID} Max.$<br>Vcc - Vcc Max.                                                        |                         | 50                       | μА  |
| Vppl                | VPP during Read-Only<br>Operations  | Note: Erase/ Program are<br>inhibited when VPP = VPPL                                        | 0.0                     | V <sub>CC</sub><br>+ 2.0 | v   |
| Vррн                | Vpp during Read/Write<br>Operations |                                                                                              | 11.4                    | 12.6                     | v   |

#### Notes:

1. Caution: the Am28F010 must not be removed from (or inserted into) a socket when Vcc or Vp is applied.

2. Icc1 is tested with  $\overline{OE} = V_{IH}$  to simulate open outputs.

3. Maximum active power usage is the sum of Icc and Ipp.

4. lcc1 total = 20 mA + 1.6 mA/MHz.

### **PIN CAPACITANCE**

| Parameter<br>Symbol | Parameter Description | Test Conditions     | Тур. | Max. | Unit |
|---------------------|-----------------------|---------------------|------|------|------|
| CIN                 | Input Capacitance     | V <sub>IN</sub> = 0 | 8    | 10   | pF   |
| Солт                | Output Capacitance    | Vout = 0            | 8    | 12   | pF   |
| Cin2                | VPP Input Capacitance | Vрр = 0             | 8    | 12   | pF   |

#### Notes:

1. Sampled, not 100% tested.

2. Test conditions T<sub>A</sub> = 25°C, f = 1.0 MHz

### SWITCHING CHARACTERISTICS over operating range unless otherwise specified.

### AC CHARACTERISTICS-Read Only Operation (Notes 1-2)

|               | ameter            |                                                        |              |            | Am2  | BF010 |          |      |
|---------------|-------------------|--------------------------------------------------------|--------------|------------|------|-------|----------|------|
| Syn<br>JEDEC  | nbols<br>Standard | Parameter Description                                  |              | -90<br>-95 | -120 | -150  | -200<br> | Unit |
| tavav         | tac               | Read Cycle Time                                        | Min.<br>Max. | 90         | 120  | 150   | 200      | ns   |
| telov         | <b>İ</b> CE       | Chip Enable<br>Access Time                             | Min.<br>Max. | 90         | 120  | 150   | 200      | ns   |
| tavov         | tacc              | Address<br>Access Time                                 | Min.<br>Max. | 90         | 120  | 150   | 200      | ns   |
| tglov         | toe               | Output Enable<br>Access Time                           | Min.<br>Max. | 40         | 50   | 55    | 55       | ns   |
| telax         | tız               | Chip Enable to<br>Output in Low Z                      | Min.<br>Max. | 0          | 0    | 0     | 0        | ns   |
| tehoz         | tor               | Chip Disable to<br>Output in High Z                    | Min.<br>Max. | 25         | 30   | 35    | 35       | ns   |
| <b>t</b> GLOX | torz              | Output Enable to<br>Output in Low Z                    | Min.<br>Max. | 0          | 0    | 0     | 0        | ns   |
| tghaz         | tor               | Output Disable to<br>Output in High Z                  | Min.<br>Max. | 25         | 30   | 35    | 35       | ns   |
| taxox         | tон               | Output Hold from first of<br>Address, CE, or OE Change | Min.<br>Max. | 0          | 0    | 0     | 0        | ns   |
| twingl        |                   | Write Recovery<br>Time before Read                     | Min.<br>Max. | 6          | 6    | 6     | 6        | μs   |

Notes:

1. Output Load (except Am28F010-95): 1 TTL gate and C<sub>L</sub> = 100 pF, Input Rise and Fall. Times: ≤ 10 ns, Input Pulse levels: 0.45 to 2.4 V, Timing Measurement Reference Level - Inputs: 0.8 V and 2 V

Outputs: 0.8 V and 2 V

2. The Am28F010-95 Output Load: 1 TTL gate and CL = 30 pF

Input Rise and Fall Times: ≤ 10 ns Input Pulse levels: 0 to 3 V Timing Measúrement Reference Level: 1.5 V inputs and outputs.

|         | ameter   |                                                    |              |             | Am2         | 3F010       |             |      |
|---------|----------|----------------------------------------------------|--------------|-------------|-------------|-------------|-------------|------|
| Syn     | nbols    |                                                    | ;            | -90         | -120        | -150        | -200        | ]    |
| JEDEC   | Standard | Parameter Description                              |              | -95         |             |             |             | Unit |
| tavav   | twc      | Write Cycle Time                                   | Min.<br>Max. | 90          | 120         | 150         | 200         | ns   |
| tavwl   | tas      | Address Set-Up Time                                | Min.<br>Max. | 0           | 0           | 0           | 0           | ns   |
| twlax   | tah      | Address Hold Time                                  | Min.<br>Max. | 45          | 50          | 60          | 75          | ns   |
| tovwn   | tos      | Data Set-Up Time                                   | Min.<br>Max. | 45          | 50          | 50          | 50          | ns   |
| twhdx   | тон      | Data Hold Time                                     | Min.<br>Max. | 10          | 10          | 10          | 10          | ns   |
| twingl  | twn      | Write Recovery Time<br>before Read                 | Min.<br>Max. | 6           | 6           | 6           | 6           | μs   |
| tghwl   |          | Read Recovery Time<br>before Write                 | Min.<br>Max. | 0           | 0           | 0           | 0           | μs   |
| telwl   | tcs      | Chip Enable<br>Set-Up Time                         | Min.<br>Max. | 0           | 0           | 0           | 0           | ns   |
| twhen   | tсн      | Chip Enable<br>Hold Time                           | Min.<br>Max. | 0           | 0           | 0           | 0           | ns   |
| twlwh   | twp      | Write Pulse Width                                  | Min.<br>Max. | 45          | 50          | 50          | 50          | ns   |
| twinwi. | twph     | Write Pulse<br>Width HIGH                          | Min.<br>Max. | 20          | 20          | 20          | 20          | ns   |
| twnwn1  |          | Duration of<br>Programming Operation               | Min.<br>Max. | 10<br>25    | 10<br>25    | 10<br>25    | 10<br>25    | μs   |
| twnwn2  |          | Duration of<br>Erase Operation                     | Min.<br>Max. | 9.5<br>10.5 | 9.5<br>10.5 | 9.5<br>10.5 | 9.5<br>10.5 | ms   |
| ҍЕНѴҎ   |          | Chip Enable Set-Up<br>Time to V <sub>PP</sub> Ramp | Min.<br>Max. | 100         | 100         | 100         | 100         | ns   |
| tvpel   |          | V <sub>PP</sub> Set-Up Time to<br>Chip Enable LOW  | Min.<br>Max. | 100         | 100         | 100         | 100         | ns   |
| tvcs    |          | V <sub>CC</sub> Set-Up Time                        | Min.<br>Max. | 2           | 2           | 2           | 2           | μs   |
| tvppr   |          | VPP Rise Time                                      | Min.<br>Max. | 500         | 500         | 500         | 500         | ns   |
| typpf   |          | V <sub>PP</sub> Fall Time                          | Min.<br>Max. | 500         | 500         | 500         | 500         | ns   |

Notes:

1. Read timing characteristics during read/write operations are the same as durng read-only operations. Refer to AC Characteristics for Read Only operations.

- 2. Chip-Enable Controlled Writes: Write operations are driven by the valid combination of Chip-Enable and Write-Enable. In systems where Chip-Enable defines the Write Pulse Width (within a longer Write-Enable timing waveform) all set-up, hold and inactive Write-Enable times should be measured relative to the Chip-Enable waveform.
- 3. All devices except Am28F010-95. Input Rise and Fall times:  $\leq$  10 ns; Input Pulse Levels: 0.45 V to 2.4 V Timing Measurement Reference Level: inputs: 0.8 V and 2.0 V; Outputs: 0.8 V and 2.0 V
- 4. Am28F010-95. Input Rise and Fall times:  $\leq$  10 ns; Input Pulse Levels: 0.0 V to 3.0 V Timing Measurement Reference Level: Inputs and Outputs: 1.5 V



<sup>11561-013</sup>A





Figure 6. A.C. Waveforms for Erase Operations

26



..

•••



Am28F010

27

### SWITCHING TEST CIRCUIT



CL = 100 pF including jig capacitance (30 pF for Am28F010-95)

#### SWITCHING TEST WAVEFORMS



AC Testing: Inputs are driven at 2.4 V for a logic "1" and 0.45 V for a logic "0". Input pulse rise and fall times are  $\leq$  10 ns.

AC Testing: Inputs are driven at 3.0 V for a logic "1" and 0 V for a logic "0". Input pulse rise and fall times are  $\leq$  10 ns.

08007-003A

11561-012A

### ERASE AND PROGRAMMING PERFORMANCE

| Limit                 |        | Limits          |      |                |                                           |  |  |
|-----------------------|--------|-----------------|------|----------------|-------------------------------------------|--|--|
| Parameter             | Min.   | Тур.            | Max. | Unit           | Comments                                  |  |  |
| Chip Erase Time       |        | 0.5<br>(Note 1) | 10   | S .            | Excludes 00H programming prior to erasure |  |  |
| Chip Programming Time |        | 2<br>(Note 1)   | 24   | S <sub>.</sub> | Excludes system-level overhead            |  |  |
| Erase/Program Cycles  |        |                 |      |                |                                           |  |  |
| Am28F010-95C4JC       | 10,000 |                 |      | Cycles         |                                           |  |  |
| Am28F010-95C3JC       | 1,000  |                 |      | Cycles         |                                           |  |  |

Note:

1. 25°C, 12V VPP

### LATCHUP CHARACTERISTICS

|                                                                                                                    | Min.     | Max.        |
|--------------------------------------------------------------------------------------------------------------------|----------|-------------|
| Input Voltage with respect to $V_{SS}$ on all pins except I/O pins (Including A <sub>9</sub> and V <sub>PP</sub> ) | - 1.0 V  | 13.5 V      |
| Input Voltage with respect to Vss on all pins I/O pins                                                             | - 1.0 V  | Vcc + 1.0 V |
| Current                                                                                                            | – 100 mA | .+ 100 mA   |
| Includes all pins except V <sub>CC</sub> . Test conditions: $V_{CC} = 5.0$ V, one pin at a time.                   |          | •           |

## 6. ORDERING INFORMATION

| Name of Product     | Description                      |
|---------------------|----------------------------------|
| SYS68K/EAGLE-01C    | EAGLE Module for the CPU board.  |
| SYS68K/EAGLE-01C/UM | User's manual for the EAGLE-01C. |

.

This page is intentionally left blank.

.

-

.

### 7. HISTORY OF MANUAL REVISIONS

| 1               |                                                   |                        |
|-----------------|---------------------------------------------------|------------------------|
| Revision<br>No. | Description                                       | Date of Last<br>Change |
| 0               | First Print                                       | FEB/04/1991            |
| 1               | Default Switch Setting in Figure 2-2 was changed. | AUG/16/1991            |

1

.

This page is intentionally left blank.

### 8. PRODUCT ERROR REPORT

### DEAR CUSTOMER,

ALTHOUGH FORCE COMPUTERS HAS ACHIEVED A VERY HIGH STANDARD OF QUALITY IN PRODUCTS AND DOCUMENTATION, SUGGESTIONS FOR IMPROVEMENT ARE ALWAYS WELCOME.

ANY FEEDBACK YOU CARE TO OFFER WOULD BE APPRECIATED.

PLEASE USE THE ATTACHED "PRODUCT ERROR REPORT" FORM FOR YOUR COMMENTS AND RETURN IT TO ONE OF THE NEAREST FORCE COMPUTERS OFFICES.

FORCE COMPUTERS GmbH



### HARDWARE/SOFTWARE/SYSTEMS

| PRODUCT:                        | SERIAL NO.:             |
|---------------------------------|-------------------------|
| DATE OF PURCHASE:               | ORIGINATOR:             |
| COMPANY:                        | POINT OF CONTACT:       |
| ADDRESS:                        | TELEPHONE:              |
|                                 | EXT:                    |
|                                 |                         |
|                                 | <u> </u>                |
| PRESENT DATE:                   |                         |
| THIS AREA TO BE COMPLETED BY FO | RCE COMPUTERS:          |
|                                 |                         |
| DATE:<br>PR#:                   | -                       |
| r N#                            |                         |
| <b>RESPONSIBLE DEPT.:</b>       |                         |
| ENGINEERING                     |                         |
| MARKETING                       |                         |
| PRODUCTION                      |                         |
|                                 |                         |
| AFFECTED PRODUCT:               | AFFECTED DOCUMENTATION: |
| HARDWARE                        | HARDWARE                |
| SOFTWARE                        | SOFTWARE                |
| SYSTEM                          | SYSTEM                  |
| ERROR DESCRIPTION:              |                         |
|                                 |                         |
|                                 |                         |
|                                 |                         |

Please send this product error report to one of our nearest FORCE COMPUTERS offices:

FORCE COMPUTERS Inc. 3165 Winchester Blvd. Campbell, CA 95008-6557 U. S. A.

FORCE COMPUTERS FRANCE Sarl 11, rue Casteja 92100 Boulogne France

#### FORCE COMPUTERS GmbH

Prof.-Messerschmitt-Str. 1 D - 8014 Neubiberg/Munich West Germany

FORCE COMPUTERS UK Ltd.

No. 1 Holly Court 3 Tring Road Wendover Buckinghamshire HP22 6PE England .

SECTION 6:

SYS68K/EAGLE MODULE

# PLEASE INSERT THE EAGLE MODULE MANUAL IN THIS SPACE

# INTRODUCTION TO VMEPROM IN USE WITH THE SYS68K/CPU-40/41

This page was intentionally left blank

# TABLE OF CONTENTS

| 1.                                                          | GENERAL                                                                                                                                                                                                                                                                                                                                             | 1-1                                                         |
|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| 1.4.3<br>1.4.4                                              | General Information<br>Features of VMEPROM<br>Power-up Sequence<br>Front Panel Switches<br>RESET Switch<br>ABORT Switch<br>Control Switches<br>Default Memory Usage of VMEPROM<br>Default EPROM Usage of VMEPROM                                                                                                                                    | 1-1<br>1-2<br>1-3<br>1-3<br>1-3<br>1-3<br>1-3<br>1-7<br>1-7 |
| 2.                                                          | DETAILS OF THE CPU BOARD                                                                                                                                                                                                                                                                                                                            | 2-1                                                         |
| 2.1<br>2.2<br>2.3<br>2.4<br>2.5                             | EPROM/RAM Layout                                                                                                                                                                                                                                                                                                                                    | 2-1<br>2-2<br>2-3<br>2-4<br>2-4                             |
| 3.                                                          | CONCEPT OF VMEPROM                                                                                                                                                                                                                                                                                                                                  | 3-1                                                         |
| 3.1<br>3.2<br>3.3                                           | Getting Started<br>Command Line Syntax<br>VMEPROM Commands                                                                                                                                                                                                                                                                                          | 3-1<br>3-1<br>3-1                                           |
| 4.                                                          | SPECIAL VMEPROM COMMANDS FOR CPU BOARD                                                                                                                                                                                                                                                                                                              | 4-1                                                         |
| 4.1<br>4.2<br>4.3<br>4.4<br>4.5<br>4.6<br>4.7<br>4.8<br>4.9 | ARB - Set the Arbiter of the CPU Board<br>CONFIG - Search VMEbus for Hardware<br>FGA - Change Boot Setup for Gate Array<br>FLUSH - Set Buffered Write Mode<br>FMB - Force Message Broadcast<br>FUNCTIONAL - Perform Functional Test<br>MEM - Set Data Bus Width of the VMEbus<br>PROG - Program FLASH EPROM<br>SELFTEST - Perform On-board Selftest | 4-1<br>4-2<br>4-3<br>4-4<br>4-5<br>4-6<br>4-7<br>4-8<br>4-9 |
| 5.                                                          | INSTALLING A NEW HARD DISK WITH THE ONBOARD SCSI CONTROLLER                                                                                                                                                                                                                                                                                         | 5-1                                                         |

# LIST OF TABLES

| Table 1: | RAM Disk Usage                        | 1-5 |
|----------|---------------------------------------|-----|
| Table 2: | Program After Reset                   | 1-5 |
| Table 3: | Boot an Operating System              | 1-5 |
| Table 4: | Examples in Using the Rotary Switches | 1-6 |
| Table 5: | On-board I/O Devices                  | 2-2 |
| Table 6: | On-board Interrupt Sources            | 2-3 |
| Table 7: | Off-board Interrupt Sources           | 2-4 |

# 1. GENERAL

### 1.1 General Information

This CPU board operates under the control of VMEPROM, an EPROM resident real time multiuser multitasking monitor program. VMEPROM provides the user with a debugging tool for single and multitasking real time applications. This manual describes those parts of VMEPROM which pertains to the hardware of the CPU. All general commands and system calls are described in the VMEPROM User's Manual.

# **1.2 Features of VMEPROM**

- Line assembler/disassembler supporting all 68040 instructions.
- Numerous commands for program debugging, including breakpoints, tracing, processor register display and modify.
- Display and modify floating point data registers of the (68040 versions only).
- S-record up/downloading from any port defined in the system.
- Time stamping of user programs.
- Built-in Benchmarks.
- Support of RAM-disk, floppy and Winchester disks, also allowing disk formatting and initialization.
- Serial I/O support for up to two SIO-1/2 or ISIO-1/2 boards in the system.
- EPROM programming utility using the SYS68K/RR-2/3 boards.
- Full Screen Editor.
- Numerous commands to control the PDOS kernel and file manager.
- Complete task management.
- I/O redirection to files or ports from the command line.
- Over 100 system calls to the kernel supported.
- Data conversion and file management functions.
- Task management system calls in addition to terminal I/O functions.

### **1.3 Power-up Sequence**

After power-up, the 68040 retrieves the initial stack pointer and program counter from address locations \$0 and \$4. These locations are the first 8 bytes of the EPROM area. They are mapped down to address \$0 for a defined start after reset or power-up. Control is transferred to the BIOS modules to perform all the necessary hardware initialization of the CPU. The real time kernel is started and the user interface of VMEPROM is invoked as the first task. This sequence also reads the Real Time Clock (RTC) of the CPU board and initializes the software clock of the kernel. If a terminal is connected to the terminal port of the CPU board, the VMEPROM banner and the VMEPROM prompt ("? ") will be displayed upon power-up or reset.

The default terminal port setup is as follows:

Asynchronous communication 9600 Baud 8 data bits 1 stop bit no parity Hardware handshake protocol

If the above message does not appear, check the following:

- 1) Baud rate and character format setting of the terminal (default upon delivery of the CPU board is 9600 Baud, 8 data bits, 1 stop bit, no parity).
- 2) Cable connection from the CPU board to the terminal (refer to the Hardware User's Manual for the pinning of the D-Sub connector and the required handshake signals).
- 3) Power supply, +5V, +12V, -12V must be present. See the Hardware User's Manual for the power consumption of the CPU board.

If everything goes well, the header and prompt are displayed on the terminal and VMEPROM is now ready to accept commands.

# 1.4 Front Panel Switches

# 1.4.1 RESET Switch

Pressing the RESET switch on the front panel causes all programs to terminate immediately and resets the 68040 processor and all I/O devices.

When the VMEPROM kernel is started, it overwrites the first word in the user memory after the task control block with an EXIT system call. If breakpoints were defined and a user program was running when the RESET button was pressed, the user program could possibly be destroyed.

Pressing reset while a program is running should only be used as a last resort when all other actions (such as pressing ^C twice) have failed.

# 1.4.2 ABORT Switch

The ABORT switch is defined by VMEPROM to cause a level 7 interrupt. This interrupt cannot be disabled and is therefore the appropriate way to terminate a user program and return to the command level of VMEPROM.

If ABORT is pressed while a user program is under execution, all user registers are saved at the current location of the program counter and the message "Aborted Task" is displayed along with the contents of the processor register.

If ABORT is pressed while a built-in command is executed or the command interpreter is waiting for input, only the message is displayed and control is transferred to the command interpreter. The processor registers are not modified and are not displayed in this case.

# 1.4.3 Control Switches

The two rotary switches on the front panel of the CPU board define the default behaviour and actions taken by VMEPROM after power up or RESET.

The default definition of some of these switches can be patched in the EPROMs for the user's convenience. Please refer to the Appendix of this manual for a description of the memory locations to be patched.

The switch settings are read in by VMEPROM after reset and control various options.

The following describes the software definition for every switch:

#### Upper Rotary Switch (SW2):

- Bit 3: If this bit is set to "0", the RAM disk is initialized as defined by bit 0 and 1 of SW2. When the disk is initialized, all data on the disk is lost.
- Bit 2: This bit defines the default data bus size on the VMEbus. If the bit is set to "0", 16 bits are selected, if it is set to "1", 32 bits are selected.

Bit 1:

and

Bit 0: These two bits define the default RAM disk. See Table 1 for a detailed description.

If Autoboot is set by bit 2 and bit 3 of SW1, bit 1 and 0 of SW2 define which operating system will be booted. See Table 3 for detailed description.

#### Lower Rotary Switch (SW1):

Bit 3:

and

- Bit 2: These two bits define which program is to be invoked after reset. Please refer to Table 2 for a detailed description.
- Bit 1: If this switch is "0", VMEPROM tries to execute a startup file after reset. The default filename is SY\$STRT. If the bit is "1", VMEPROM comes up with the default banner.
- Bit 0: If this switch is set to "0", VMEPROM checks the VMEbus for available hardware after reset. In addition VMEPROM waits for SYSFAIL to disappear from the VMEbus. The following hardware can be detected:

Contiguous memory starting at the end of the on-board memory ISIO-1/2 SIO-1/2 ISCSI-1

Please refer to Chapter 4.2 of this section for details.

1-4

# Table 1: RAM Disk Usage

| Bit 1 | I Bit O |   | Upper Switch (SW2)                    |
|-------|---------|---|---------------------------------------|
| 1     | 1       | = | RAM DISK AT TOP OF MEMORY (32 Kbytes) |
| 1     | 0       | = | RAM DISK AT \$FFC10000 (64 Kbytes)    |
| 0     | 1       | = | RAM DISK AT \$40700000 (512 Kbytes)   |
| 0     | 0       | = | RAM DISK AT \$40800000 (512 Kbytes)   |

# Table 2: Program After Reset

| Bit 3 | Bit 2 |   | Lower Switch (SW1)                         |
|-------|-------|---|--------------------------------------------|
| 1     | 1     | = | VMEPROM (OR USER PROGRAM at same location) |
| 1     | 0     | = | USER PROGRAM AT \$FFC10000                 |
| 0     | 1     | = | Autoboot System                            |
| 0     | 0     | = | USER PROGRAM AT \$40800000                 |

# Table 3: Boot an Operating System

(Valid only if SW1 is set to Autoboot)

| Bit 1 | Bit O | ) | Upper Switch (SW2)            |   |
|-------|-------|---|-------------------------------|---|
| 1     | 1     | = | Boot PDOS                     |   |
| 1     | 0     | _ | Boot UNIX                     | ľ |
| 0     | 1     | = | Boot another operating system |   |
| 0     | 0     | = | Setup for UNIX mailbox driver |   |

# Table 4: Examples in Using the Rotary Switches

| Rotary Switches |       | Description                                                                                                                                                                                                                                                 |  |
|-----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Upper           | Lower |                                                                                                                                                                                                                                                             |  |
| \$F             | \$F   | No RAM Disk initialization will be done.<br>The VMEbus data size is 32 bits.<br>The RAM Disk is on top of memory.<br>VMEPROM will be started.<br>No start file will be executed.<br>The available hardware on the VMEbus will not be<br>checked.            |  |
| \$4             | \$C   | RAM Disk intialization will be done.<br>The VMEbus data size is 32 bits.<br>The RAM Disk is located at address \$40800000.<br>VMEPROM will be started.<br>VMEPROM tries to execute a startup file.<br>The available hardware on the VMEbus will be checked. |  |
| \$В             | \$7   | The VMEbus data size is 16 bits.<br>Autoboot System is enabled.<br>PDOS will be booted.                                                                                                                                                                     |  |

# 1.4.4 Default Memory Usage of VMEPROM

By default, VMEPROM uses the following memory assignment for the CPU board:

# MEMORY LAYOUT OF THE ON-BOARD RAM



Please note that the size of the first task cannot be extended beyond the highest on-board memory address. However, the additional memory which can be installed may be used for data arrays or for creating new tasks. The maximum memory which may be used for tasking is 64 Mbytes. If more memory is available, it can only be used for data storage, but not for tasking memory.

### 1.4.5 Default EPROM Usage of VMEPROM

### MEMORY LAYOUT OF THE SYSTEM EPROM



# 2. DETAILS OF THE CPU BOARD

# 2.1 EPROM/RAM Layout

| Address                     | Device           |
|-----------------------------|------------------|
| 0000 0000<br>↓<br>*         | Local RAM        |
| FF00 0000<br>↓<br>FF7F FFFF | EPROM Area       |
| FFC0 0000<br>↓<br>FFC7 FFFF | SRAM Area        |
| FFC8 0000<br>↓<br>FFCF FFFF | FLASH EPROM Area |
| FFE0 0000<br>↓<br>FFEF FFFF | EPROM Area       |
| * → Hightest On-board       | Memory Address   |

### 2.2 On-board I/O Devices

The following table shows the base addresses of the on-board I/O devices.

.

Table 5: On-board I/O Devices

| BASE ADDRESS | DEVICE       |
|--------------|--------------|
| \$FF803000   | RTC 72423    |
| \$FF802000   | DUSCC1 68562 |
| \$FF802200   | DUSCC2 68562 |
| \$FF800C00   | PI/T1 68230  |
| \$FF800E00   | PI/T2 68230  |
| \$FFD00000   | FGA-002      |

# 2.3 On-board Interrupt Sources

The following table shown is used for the on-board interrupt sources and levels which are defined by VMEPROM. All interrupt levels and vectors of the on-board I/O devices are software programmable via the FGA-002 Gate Array.

# Table 6: On-board Interrupt Sources

| DEVICE       | INTERRUPT LEVEL | INTERRUPT VECTOR |
|--------------|-----------------|------------------|
| Abort Switch | 7               | 232              |
| PI/T1        | 5               | 242              |
| DUSCC1       | 4               | 244              |
| DUSCC2       | 4               | 245              |

.

# 2.4 Off-board Interrupt Sources

VMEPROM supports several VMEbus boards. As these boards are interrupt driven the level and vectors must be defined for VMEPROM to work properly. The following table shows the default setup of the interrupt levels and vectors of the supported hardware. For a detailed description of the hardware setup of the boards, please refer to the Appendix of this manual. The supported I/O boards together with the base addresses and the interrupt level and vector are summarized in Table 7. In order for these boards to work correctly with VMEPROM, the listed interrupt vectors may not be used.

### Table 7: Off-board Interrupt Sources

| Board    | Interrupt Level | Interrupt Vector | Board Base Address |
|----------|-----------------|------------------|--------------------|
| SIO-1/2  | 4               | 64-75            | \$FCB00000         |
| ISIO-1/2 | 4               | 76-83            | \$FC960000         |
| ISCSI-1  | 4               | 119              | \$FCA00000         |

### 2.5 The On-Board Real Time Clock

During the power up sequence, the on-board real time clock of the CPU board is read and loaded in the VMEPROM. This sequence is done automatically and requires no user intervention. If the software clock of VMEPROM is set by the ID command as described in the VMEPROM User's Manual, the RTC is set automatically to the new time and date values.

# 3. CONCEPT OF VMEPROM

# 3.1 Getting Started

After power-up or after RESET has been pressed, VMEPROM prints a banner showing the version and revision being used and prints the prompt ("? ").

If the above message does not appear, check the following:

- 1) Baud rate and character format setting of the terminal (default upon delivery of the CPU board is 9600 Baud, 8 data bits, 1 stop bit, no parity).
- 2) Cable connection from the CPU board to the terminal (refer to the Hardware User's Manual for the pinning of the D-Sub connector and the required handshake signals).
- 3) Power supply, +5V, +12V, -12V; must be present. See the Hardware User's Manual for the power consumption of the CPU board.

If everything goes well, the header and prompt are displayed on the terminal and VMEPROM is now ready to accept commands.

# **3.2 Command Line Syntax**

All valid VMEPROM commands consist of the following:

```
? <u>command < cr></u> or
? <u>command parameters < cr></u>
```

The underlined areas must be entered by the user. If more than one parameter will be entered, they must be separated by a space or a comma.

For a detailed description of all functions of the command interpreter please refer to chapter 3 of the VMEPROM User's Manual.

# **3.3 VMEPROM Commands**

VMEPROM supports many commands. All of these commands are EPROM resident and are available at any time. Most of these commands are common for all versions of VMEPROM. All the common commands of VMEPROM are described in detail in the VMEPROM User's Manual. Those commands which are specific for the hardware of the CPU board are described in the following paragraphs of this manual. For a short description of one or all VMEPROM commands, the HELP command can be used. Enter HELP<cr> for a description of all commands, or enter HELP command

This page was intentionally left blank

### 4. SPECIAL VMEPROM COMMANDS FOR CPU BOARD

The following commands are implemented on the CPU board in addition to those listed in the VMEPROM User's Manual.

### 4.1 ARB - Set the Arbiter of the CPU Board

#### Format: ARB

The ARB command allows the user to set the arbitration mode of the CPU board for VMEbus. This command is also used to select the Standard Access Mode for the VMEbus. Additionally, the VMEbus interrupts can be enabled or disabled.

#### Example:

```
? ARB<cr>
```

Current arbiter mode: enabled, Mode = Prioritized ROUND ROBIN Set arbiter mode ? (Y,y/-) : Y ROUND ROBIN mode ? (Y,y/-) :Y Prioritized ROUND ROBIN ? (Y,y/-) : N New arbiter mode = ROUND ROBIN Set arbiter mode for VME-BUS:

| STATUS: | ROR & RAT & RBCLR & FAIR        |         |   | 4 |
|---------|---------------------------------|---------|---|---|
| SET:    | Release on bus clear (RBCLR)    | (Y/N) ? | Y |   |
| SET:    | Fair VME-BUS arbitration (FAIR) | (Y/N) ? | Y |   |
| *****   |                                 |         |   |   |

Standard Access Mode (A24) for Slave Accesses currently disabled. Enable A24 mode ? (Y,y/-) : Y

A31-A24 = 80

Change interrupt mask ? (Y,y/-) : Y

Enable(1) / Disable(0) VMEbus interrupts by level:

| STATUS: | Level:                    | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
|---------|---------------------------|---|---|---|---|---|---|---|
|         |                           | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| SET:    | Enter new interrupt mask: | 1 | 1 | 1 | 1 | 1 | 1 | 0 |

?\_

### 4.2 CONFIG - Search VMEbus for Hardware

#### Format: CONFIG

This command searches the VMEbus for available hardware. It is useful if VMEPROM is started and bit 0 of the lower rotary switch on the front panel is set to "1", so that VMEPROM does not check the configuration by default.

In addition this command allows the user to install additional memory in the system. Additional memory can ONLY be installed with this command.

The following hardware is detected:

- 1. ISIO-1/2
- 2. SIO-1/2
- 3. ISCSI-1
- 4. Contiguous memory starting at the highest on-board memory address

The boards must be set to the default address for 32 bit systems. This setup is summarized for all supported boards in the Appendix of this manual.

Additional memory must be contiguous to the on-board memory of the CPU board. This memory is cleared by the config command to allow DRAM boards with parity to be used. Please remember that the installation of additional memory does not effect the RAM size of the running task. However, VMEPROM identifies this installed memory area and every time memory is required (i.e. with CT or FM) it is taken from this area as long as there is enough free space.

The CONFIG command also installs Winchester disks in the system and initializes the disk controller (if available). So if a SYSFAIL is active on the VMEbus (which can come for example from the ISIO-1/2 or ISCSI-1 controller during selftest) the command is suspended until the SYSFAIL signal is no longer active.

#### Example:

CONFIG < cr>
 UART FORCE ISIO1/2 (U3) INSTALLED

 ISCSI-1: 1 boards available
 ISIO-1/2: 1 boards available

? \_

4-2

### 4.3 FGA - Change Boot Setup for Gate Array

Format: FGA

Some registers of the gate array are definable by the user. The contents of this register is stored in the on-board battery SRAM in a short form.

The boot software for the gate array will take these values after reset to initialize the gate array. The FGA command may be used to enter an interactive mode for changing this boot table in the battery SRAM.

The FGA command will show the actual value stored in the battery SRAM. To change any value, a new one has to be entered in binary form. If only a <cr> is entered, no change will be made. To step backward a minus has to be entered. If a <.> or <ESC> is given, the FGA command returns to the shell.

Example:

? FGA

>>> Setup for FGA-002 BOOTER <<<<

| REGISTER | FGA offset | value in SRAM | changed value |
|----------|------------|---------------|---------------|
| SPECIAL  | \$0420     | %00011110     | %00011110     |
| CTL_01   | \$0238     | %00000100     | %00000100     |
| CTL_02   | \$023C     | %00000000     | %00000000     |
| CTL_05   | \$0264     | %00001100     | %00001100     |
| CTL_12   | \$032C     | %00000000     | %00000000     |
| CTL_14   | \$0354     | %00000000     | %00000000     |
| CTL_15   | \$0358     | %01001100     | %01000110     |
| CTL_16   | \$035C     | %00100000     | %00100000     |
| MBX_00   | \$0000     | %00000000     | %00001001     |
| MBX_01   | \$0004     | %00000000     | %00000000     |
| MBX_02   | \$0008     | %00000000     | %00000000     |
| MBX_03   | \$000C     | %00000000     |               |
| MBX_04   | \$0010     | %00000000     |               |
| MBX_05   | \$0014     | %00000000     |               |
| MBX_06   | \$0018     | %00000000     |               |
| MBX_07   | \$001C     | %00000000     |               |

?

#### 4.4 FLUSH - Set Buffered Write Mode

Format: FLUSH FLUSH ? FLUSH ON FLUSH OFF

This command flushes all modified hashing buffers for disk write or enable or disable buffered write mode for the local SCSI controller.

If no argument is entered, all modified hashing buffers are flushed. If an argument of "ON" or "OFF" is given, the buffered write mode will be enabled or disabled. By entering a question mark as an argument, only a message will be displayed, whether the buffered write mode is enabled or disabled.

**Note:** This command only functions when an **EAGLE Module** which contains an SCSI controller is installed.

Example:

? flush

All modified buffers are flushed

? flush ON

Buffered write is enabled

### 4.5 FMB - Force Message Broadcast

Format: FMB < slotlist>, < FMB channel>, < message> FMB [< FMB channel>]

The FMB command allows sending a byte message to individual slots in the backplane, broadcast to all the boards, and getting a pending message.

The first format is used to send a message. With this the first parameter is used to select the slots to which a message should be sent. Each slot number can be separated with a '/' sign; a '-' defines a range of slot numbers. Slot numbers can range from 0 to 21. A slot number of 0 sends the message to all slots. The second parameter defines which FMB channel should be used. It can be '0' or '1'. The message is the byte to be deposited into the FMB channel(s).

The second format is used to get messages. If no parameter is given, one message of each FMB channel is fetched and displayed. If a channel is specified only this channel is addressed and the message will be displayed.

#### Example:

? FMB FMB channel 0 is empty FMB channel 1 is empty ? FMB 1-21,0,\$EF ? FMB 1-21,1,%10100001 ? FMB FMB channel 0 = \$EF FMB channel 1 = \$A1 ? FMB 1-21,1,\$77 ? FMB 1 FMB channel 1 = \$77 ? FMB 1 FMB channel 1 = \$77

#### ? \_

# 4.6 FUNCTIONAL - Perform Functional Test

Format: FUNCTIONAL

**NOTE:** This command is not designed for the user, but instead for internal purposes by FORCE COMPUTERS.

# 4.7 MEM - Set Data Bus Width of the VMEbus

| Format: | MEM    |  |  |  |  |
|---------|--------|--|--|--|--|
|         | MEM 16 |  |  |  |  |
|         | MEM 32 |  |  |  |  |

This command can display or set the data bus width of the CPU board on the VMEbus. If no argument is entered, the current data bus width is displayed. If an argument of '16' or '32' is given, the data bus width is set to 16 or 32 bits respectively.

#### Example:

? MEM<cr> Data bus width is set to 32 bits

? MEM 16<cr>

? MEM<cr> Data bus width is set to 16 bits

? MEM 32<cr>

? \_

### 4.8 PROG - Program FLASH EPROM

**Format:** PROG [<source>[,<destination>[,<length>[,<width>]]]]

This command is used to program FLASH EPROMs. All parameters may be specified on the command line or may be entered interactively after the function has been invoked.

The first parameter < source> is the start address of the data which is to program into the FLASH EPROM.

The second parameter < destination > represents the base address of the FLASH EPROM.

The third parameter < length > specifies the length of the FLASH EPROM. If 0 is entered the length and width is automatically calculated.

The fourth parameter < width > selects the data width of the FLASH EPROMs. Three values are possible:

- '1': Byte width (8-bit)
- '2': Word width (16-bit)
- '4': Long width (32-bit)

Please note that the FLASH EPROM(s) must be completely programmed. Therefore programming only parts of a FLASH EPROM is not possible.

#### Example:

? PROG \$100000 \$FFC80000 0 programming..... FLASH EPROM successfully programmed

| ? PROG |  |
|--------|--|
|--------|--|

| Source base address                    |   | \$40800000 |
|----------------------------------------|---|------------|
| FLASH EPROM base address               | - | \$FFC80000 |
| Source length (0 for automatic select) | - | \$20000    |
| Width (1,2 or 4)                       | = | 1          |
| programming                            |   |            |
| FLASH EPROM successfully programmed    |   |            |

?

# 4.9 SELFTEST - Perform On-board Selftest

#### Format: SELFTEST

This command performs a test of the on-board functions of the CPU board. It may only be run if no other tasks are created. If there are any other tasks no selftest will be made and an error will be reported. The selftest tests the memory of the CPU board and all devices on the board.

The following tests are performed in this order:

#### 1. I/O test

This function tests the access to and the interrupts from the DUSCC. If the DUSCC cannot generate interrupts an error will be reported. This test also checks if reading from and writing to the floppy disk controller and the SCSI controller proceeds as expected.<sup>1</sup>

#### 2. Memory test on the memory of the current task.

The following procedures are performed:

1) Byte Test

- 2) Word Test
- 3) Long Word Test

All passes of the memory test perform pattern reading and writing as well as bit shift tests. If an error occurs while writing to or reading from memory it will be reported.

#### 3. Clock Test

If the CPU does not receive timer interrupts from the PI/T 68230 an error will be displayed. This ensures that VMEPROM could initialize the PI/T 68230 properly and the interrupts from the PI/T are working.

**CAUTION:** During this process, all memory is cleared.

Example:

? SELFTEST

#### VMEPROM Hardware Selftest

| I/O test .  |  | . passed |
|-------------|--|----------|
| Memory test |  | . passed |
| Clock test  |  | . passed |
| ?_          |  |          |

1

Only applicable when an EAGLE Module is installed which contains these devices.

This page intentionally left blank

#### 5. INSTALLING A NEW HARD DISK WITH THE ONBOARD SCSI CONTROLLER

**NOTE:** The following is only possible if an **EAGLE Module** is installed which contains an SCSI controller.

The hard disk must be set to 256 bytes per block. The FRMT command of VMEPROM may be used to set all hard disk parameters, to format the Winchester and to divide the disk into logical partitions. Before starting the FRMT command, the number of the last logical block of the Winchester must be known. The number of physical blocks per track must be 32, the number of bytes per sector must be 256. By using the following equation:

```
(# of Heads) * (# of Cylinders) * (Blocks/Track) = # of Last logical block
```

The number of Heads and the number of Cylinders may be calculated.

**NOTE:** The maximum number of Heads is 16. The number of large and floppy partitions are free definable by the user.

The following example aids in formatting a CDC 94211-5 Winchester.

```
? FRMT
68K PDOS Force Disk Format Utility 07-Sep-88
  Possible Disk Controllers in this System are:
    Controller #1 is not defined
Controller #2 is not defined
    Controller #3 is a Force ISCSI-1
    Controller #4 is a onboard CPU-40/41 SCSI
  Drives that are currently defined in system are:
    F0 is controller #4, drive select $82
F1 is controller #4, drive select $83
    W0 is controller #4 , drive select $00
    All not named drives are undefined
  Select Menu: W,WO-W15=Winch; F,FO-F8=Floppy; Q=Quit
    Select Drive: W
  WO Main Menu: 1)Parm 2)BadT 3)Form 4)Veri 5)Part 6)Writ
                 P)Togl Q)Quit
    Command: 1
  WO Parameters Menu: A)lter, D)isplay, R)ead file, Q)uit
    Command: A
                 # of Heads = 10
             # of Cylinders = 1022
 Physical Blocks per Track = 32
  Physical Bytes per Block = 256
         Shipping Cylinder = 0
                  Step rate = 0
 Reduced write current cyl = 0
   Write Precompensate cyl = 0
  Current Winch Drive O Parameters:
                 # of Heads = 10
             # of Cylinders = 1022
 Physical Blocks per Track = 32
  Physical Bytes per Block = 256
         Shipping Cylinder = 0
                  Step rate = 0
 Reduced write current cyl = 0
   Write Precompensate cyl = 0
```

(cont'd)

```
WO Parameters Menu: A)lter, D)isplay, R)ead file, Q)uit
    Command: Q
  WO Main Menu: 1)Parm 2)BadT 3)Form 4)Veri 5)Part 6)Writ
                  P)Togl Q)Quit
  Command: 3
  Sector Interleave = 0
  Physical Tracks to FORMAT = 0,10219
Ready to FORMAT Winchester Drive 0 ? Y
  Sector Interleave Table: 0,1,2,3,4,5,6,7,8,9,10,11,12,
13,14,15,16,17,18,19,20,21,22,
23,24,25,26,27,28,29,30,31
  Issuing Format Drive Command.
  FORMAT SUCCESSFUL I
  WO Main Menu: 1)Parm 2)BadT 3)Form 4)Veri 5)Part 6)Writ
                  P)Togl Q)Quit
    Command: 5
  WO Partitions Menu: A)lter, D)isplay, R)ecalc, Q)uit
    Command: A
     # of Large partitions = 6
    # of Floppy Partitions = 15
First track for PDOS Parts = 0
 Last track for PDOS Parts = 10219
          First PDOS disk # = 2
  Current Winch Drive O Partitions:
    # of Large partitions = 6
# of Floppy Partitions = 15
First track for PDOS Parts = 0
 Last track for PDOS Parts = 10219
          First PDOS disk # = 2
 Total # of Logical Tracks = 10220
Disk #
           Logical Trks Physical Trks
                                             PDOS sectors
                            Base, Top
            Base, Top
                                              Total/{boot}
            0,1502
    2
                             0,1502
                                              48064/47872
            1503,3005
3006,4508
                            1503,3005 3006,4508
    3
                                              48064/47872
    4
                                              48064/47872
            4509,6011
6012,7514
7515,9017
    5
                             4509,6011
                                              48064/47872
                            6012,7514
7515,9017
    6
                                              48064/47872
    7
                                              48064/47872
            9018,9097
                                              2528/2336
    9
                             9018,9097
    10
            9098,9177
                             9098,9177
                                              2528/2336
    11
            9178,9257
                             9178,9257
                                              2528/2336
            9258,9337
                             9258,9337
                                              2528/2336
    12
    13
            9338,9417
                             9338,9417
                                              2528/2336
    14
            9418,9497
                             9418,9497
                                              2528/2336
    15
            9498,9577
                             9498,9577
                                              2528/2336
            9578,9657
                             9578,9657
                                              2528/2336
    16
    17
            9658,9737
                             9658,9737
                                              2528/2336
            9738,9817
9818,9897
                             9738,9817
9818,9897
    18
                                              2528/2336
                                              2528/2336
    19
            9898,9977
    20
                             9898,9977
                                              2528/2336
    21
            9978,10057
                             9978,10057
                                              2528/2336
                             10058, 10137
            10058,10137
    22
                                              2528/2336
                             10138,10217
    23
             10138,10217
                                              2528/2336
```

(cont'd)

```
W0 Partitions Menu: A)lter, D)isplay, R)ecalc, Q)uit
Command: Q
W0 Main Menu: 1)Parm 2)BadT 3)Form 4)Veri 5)Part 6)Writ P)Togl
Q)Quit
Command: 6
Write to Disk Y)es, N)o, F)ile : Y
Write to file (Y/N)?N
W0 Main Menu: 1)Parm 2)BadT 3)Form 4)Veri 5)Part 6)Writ P)Togl
Q)Quit
Command: Q
Exit to Select Drive. Update Param RAM (Y/N) ? Y
System Parameter RAM Updated!!
Select Menu: W,W0-W15=Winch; F,F0-F8=Floppy; Q=Quit
Select Drive: Q
```

After formatting the disk, all logical partitions must be initialized using the INIT command. The example below may be used to initialize the large logical partition number two.

```
? INIT
Enter Disk # :2
Directory Entries :1024
Number of sectors :47776
Disk Name :SYSTEM
Init: Disk # 2
Directory entries: 1024
Number of sectors: 47776
Disk name: SYSTEM
Initialize disk ? Y
```

?

.

This page was intentionally left blank

.

# APPENDIX TO THE INTRODUCTION TO VMEPROM

This page was intentionally left blank

# LIST OF APPENDICES

| Α.                              | VMEbus Board Setup                                                                                                        | A-1                             |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| A1.<br>A2.<br>A3.<br>A4.<br>A5. | VMEbus Memory<br>SYS68K/SIO-1/SIO-2<br>SYS68K/ISIO-1/2<br>SYS68K/ISCSI-1 Disk Controller<br>Local FDC and SCSI Controller | A-1<br>A-1<br>A-3<br>A-4<br>A-5 |
| В.                              | S-Record Formats                                                                                                          | B-1                             |
| B1.<br>B2.                      | S-Record Types                                                                                                            | B-1<br>B-2                      |
| C.                              | System RAM Definitions                                                                                                    | C-1                             |
| D.                              | Task Control Block Definitions                                                                                            | D-1                             |
| E.                              | Interrupt Vector Table of VMEPROM                                                                                         | E-1                             |
| F.                              | Benchmark Source Code                                                                                                     | F-1                             |
| G.                              | Special Locations                                                                                                         | G-1                             |
| н.                              | Generation of Applications in EPROM                                                                                       | H-1                             |
| H1.<br>H1.1                     | General Information                                                                                                       | H-1<br>H-1                      |

.

This page was intentionally left blank

.

# APPENDIX A

### A. VMEbus Board Setup

This appendix summarizes the changes to be made to the default setup of additional VMEbus boards so that they are VMEPROM compatible. Appendices A.2 through A.6 are available in EPROM, but are not installed. All drivers may be installed with the INSTALL command. When INSTALL followed by a question mark is entered, the following will appear:<sup>1</sup>

#### ? INSTALL ?

THE FOLLOWING UARTS AND DISK DRIVER ARE ALREADY IN EPROM:

| UART TYPE 1 | FORCE CPU-40/41/DUSCC | ADDR: \$FF004500 |
|-------------|-----------------------|------------------|
| UART TYPE 2 | FORCE SIO-1/2         | ADDR: \$FF004800 |
| UART TYPE 3 | FORCE ISIO-1/2        | ADDR: \$FF004C00 |
| UART TYPE 4 | FORCE UNIX MAIL       | ADDR: \$FF005100 |
| DISK DRIVER | FORCE SCSI CPU-40/41  | ADDR: \$FF005900 |
| DISK DRIVER | FORCE ISCSI-1         | ADDR: \$FF007300 |

By typing in: INSTALL <file>,<address><cr>, a specific driver may be loaded in the system. The addressed file should be located in EPROM.

### A1. VMEbus Memory

In general, every FORCE memory board can be used together with VMEPROM. The base address must be set correctly in order to use the board within the tasking memory of VMEPROM. The board base addresses of any additional memory boards must be set to be contiguous to the on-board memory. It is strongly recommended that only 32 bit memory boards are used because of speed purposes.

## A2. SYS68K/SIO-1/SIO-2

These two serial I/O boards are set to the base address \$B00000 by default. VMEPROM expects the first SIO-1/SIO-2 boards at \$FCB00000. This is in the standard VME address range (A24, D16, D8) with the address \$B00000. The address modifier decoder (AM-Decoder) of the SIO-1/2 boards must be set to:

Standard Privileged Data Access Standard Nonpriviledged Data Access

Please note that the printed UART and Disk Driver addresses are only examples. They may alternate according to software versions.

Please refer to the SIO User's Manual for setup. If a second SIO-1/2 board will be used, the base address must be set to FCB00200. The AM-decoder setup described above must again be used. Please refer to the User's Manual of your SIO board for the address setup of the second SIO board. Before using the driver for the SIO-1/2 board, the driver must be installed by using the INSTALL command. The following must be entered:

#### ? INSTALL U2,\$FF004800

In order to install one of the ports of the SIO boards in VMEPROM, the BP command can be used. The SIO-1/2 boards use the driver type 2. To install the first port of a SIO board with a 9600 baud rate, the following command line can be used:

#### ? BP 4, 9600, 2, \$FCB00000

The port can then be used as port number 4. Please note that the hardware configuration must be detected before a port can be installed. This can be done with the CONFIG command or by setting a front panel switch on the CPU Board and pressing RESET. Please refer to the command description in the VMEPROM User's Manual for a detailed description of the CONFIG and BP commands. The base addresses of all ports of a SIO-1/2 board which must be specified with the BP command is as follows:

| SIO port #           | Address    |
|----------------------|------------|
| 1 (first SIO board)  | \$FCB00000 |
| 2                    | \$FCB00040 |
| 3                    | \$FCB00080 |
| 4                    | \$FCB000C0 |
| 5                    | \$FCB00100 |
| 6                    | \$FCB00140 |
| 1 (second SIO board) | \$FCB00200 |
| 2                    | \$FCB00240 |
| 3                    | \$FCB00280 |
| 4                    | \$FCB002C0 |
| 5                    | \$FCB00300 |
| 6                    | \$FCB00340 |

VMEPROM supports up to two serial I/O boards. These can be either the SIO-1/2 board, the ISIO-1/2 board, or a mixture of both. Please note that the first board of every type must be set to the first base address. In using one SIO-1 board and one ISIO-1 board, the base address of the boards must to be set to:

| SIO-1  | \$FCB00000 |
|--------|------------|
| ISIO-1 | \$FC960000 |

# A3. SYS68K/ISIO-1/2

These serial I/O boards are set to the address \$960000 in the standard VME address range by default. VMEPROM awaits this board at this address (FC960000 for the CPU-40/41); no changes need to be made to the default setup. An optional second board may be used. When used, the address must be set to \$980000. Read the SYS68K/ ISIO-1/2 User's Manual for a description of the base address setup. Before using the driver for the ISIO-1/2 board, the driver must be installed by using the INSTALL command. The following must be entered:

#### ? INSTALL U3,\$FF004C00

In order to install one of the ports of an ISIO board in VMEPROM, the BP command can be used. The ISIO-1/2 boards are driver type 3. In order to install the first port of an ISIO board with a 9600 baud rate, the following command line can be used:

#### ? BP 4, 9600, 3, \$FC968000

The port number is four. The hardware configuration must be detected before a port can be installed. This is done with the CONFIG command, or by setting a front switch on the CPU board and pressing RESET. Read the command description in the VMEPROM User's Manual for a description of the CONFIG and BP commands. The base address of all ISIO-1/2 ports, specified by the BP command, is as follows:

| ISIO port #           | Address    |
|-----------------------|------------|
| 1 (first ISIO board)  | \$FC968000 |
| 2                     | \$FC968020 |
| 3                     | \$FC968040 |
| 4                     | \$FC968060 |
| 5                     | \$FC968080 |
| 6                     | \$FC9680A0 |
| 7                     | \$FC9680C0 |
| 8                     | \$FC9680E0 |
| 1 (second ISIO board) | \$FC988000 |
| 2                     | \$FC988020 |
| 3                     | \$FC988040 |
| 4                     | \$FC988060 |
| 5                     | \$FC988080 |
| 6                     | \$FC9880A0 |
| 7                     | \$FC9880C0 |
| 8                     | \$FC9880E0 |

VMEPROM supports two serial I/O boards. These can be the SIO-1/2 or ISIO-1/2 board or mixture of both. The first board of each type must be set to the first base address. When using one SIO-1 and one ISIO-1 board, the base address of the boards must be set to:

| SIO-1  | \$FCB00000 |
|--------|------------|
| ISIO-1 | \$FC960000 |

### A4. SYS68K/ISCSI-1 Disk Controller

VMEPROM supports up to two floppy disk drives and three Winchester disk drives together with the ISCSI-1 disk controller. The floppy drives must be jumpered to drive select 3 and 4 and can be accessed as disk number 0 and 1 out of VMEPROM. The floppy drives are installed automatically when a ISCSI-1 controller is detected by the CONFIG command or after pressing RESET when the front panel switch of the CPU board is set to detect the hardware configuration. Usable floppy drives must support 80 tracks/side, and must be double sided/double density. The step rate used is 3 ms. The Winchester drives are not installed automatically. The VMEPROM FRMT command must be used for defining the following factors:

- The physical structure of the drive (i.e. number of heads, number of cylinders, drive select number, etc.)
- The bad block of the Winchester drive
- The partitions to be used

If this setup is done once for a particular drive, the data is stored in the first sector of the Winchester and is loaded automatically when the disk controller is installed in VMEPROM. The driver for the ISCSI-1 may be installed by using the INSTALL command. The following must be entered:

#### ? INSTALL W,\$FF007300

The default base address of the ISCSI-1 controller is \$A00000 in the standard VME address range. This is the address \$FCA00000 for the CPU board and no changes have to be made to this setup. The ISCSI-1 driver uses interrupts by default. This cannot be disabled. Please make sure that the interrupt daisy chain is closed so that the controller can work properly.

### A5. Local FDC and SCSI Controller

**NOTE:** The following chapter only applies to those CPU boards which contain an installed **EAGLE Module** with a floppy and/or SCSI controller.

VMEPROM supports up to two floppy disk drives and three Winchester disk drives together with the local FDC and SCSI Controller. The floppy drives are installed automatically.

Here are the required floppy drive settings:

- Drive select 2(0) or 3(1); VMEPROM access drive select 2 as disk 0 and drive select 3 as disk
   1
- Head Load is to be executed if Motor On and Drive Select is TRUE.
- Pin 34 of the floppy interface should select the Disk Change signal.<sup>2</sup>
- Pin 2 of the floppy interface selects high or normal density.<sup>3</sup> When this signal is "low level", it designates normal density mode. VMEPROM only operates under normal density.
- Pin 4 should be the Eject signal.<sup>4</sup>

The step rate used is 3 ms.

The Winchester drives are not installed automatically.

The VMEPROM FRMT command must be used for defining the following factors:

- The physical structure of the drive (i.e. number of heads, number of cylinders, drive select number, etc.)
- The bad block of the Winchester drive
- The partitions to be used

If this setup is done once for a particular drive, the data is stored in the first sector of the Winchester and is loaded automatically when the disk controller is installed in VMEPROM. Upon viewing the VMEPROM Banner, the driver for the local FDC and SCSI controller is already installed. For this driver, memory is needed for hashing. The storage for the hashing buffers is allocated at the top of memory.

- <sup>3</sup> DITO
- <sup>4</sup> DITO

<sup>&</sup>lt;sup>2</sup> Only if the floppy drive is able to generate or read this signal.

+

. :

This page intentionally left blank

۰.

# **APPENDIX B**

### **B. S-Record Formats**

### **B1.** S-Record Types

Eight types of S-records have been defined to accommodate the needs of the encoding, transportation and decoding functions. VMEPROM supports S0, S1, S2, S3, S7, S8 and S9 records (S7 and S8 on load only).

An S-record format module may contain S-records of the following types:

- **S0** The header record for each block of S-records.
- S1 A record containing code/data and the 2-byte address at which the code/data is to reside.
- S2 A record containing code/data and the 3-byte address at which the code/data is to reside.
- S3 A record containing code/data and the 4-byte address at which the code/data is to reside.
- S5 A record containing the number of S1, S2 and S3 records transmitted in a particular block. The count appears in the address field. There is no code/data field. Not supported by VMEPROM.
- **S7** A termination record for a block of S3 records. The address field may optionally contain the 4-byte address of the instruction to which control is to be passed. There is no code/data field.
- S8 A termination record for a block of S2 records. The address field may optionally contain the 3-byte address of the instruction to which control is to be passed. There is no code/data field.
- **S9** A termination record for a block of S1 records. The address field may optionally contain the 2-byte address of the instruction to which control is to be passed.

Only one termination record is used for each block of S-records. S7 and S8 records are usually used only when control is to be passed to a 3 or 4 byte address. Normally, only one header record is used, although it is possible for multiple header records to occur.

### **B2.** S-Record Example

S21402000000004440002014660000CB241F8044CB1 S214020010203C0000020E428110C1538066FA487AE4 S214020020001021DF0008487A001221DF000C4E750E S21402003021FC425553200030600821FC41444452C2

| XX                                     | Check-sum      |
|----------------------------------------|----------------|
| XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | Data           |
| 0200XX                                 | 24 bit Address |
| 14                                     | Byte Count     |
| S2                                     | Record Type    |

#### S903000FC

| FC   | Check-sum   |
|------|-------------|
| 0000 | Data        |
| 03   | Byte Count  |
| S9   | Record Type |

# **APPENDIX C**

# C. System RAM Definitions

| 05-Jar<br>BRIAN                                                                                                                                                                                                           | n-88<br>C. C                                                                                                                            | DEFINITION OF SYRAM BLOCK OF M<br>Revised to correspond to PDOS<br>DOPER, EYRING RESEARCH INSTITUT<br>1985-1988                                              | 3.3                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| #define<br>#define<br>#define<br>#define<br>#define                                                                                                                                                                       | NT<br>NM<br>ND<br>NC<br>NF<br>NU<br>IZ<br>MZ<br>TZ                                                                                      | 64<br>((NT+3)&0xFC)<br>16<br>((NT+3)&0xFC)<br>8<br>64<br>15<br>6<br>0x4000000<br>64                                                                          | /*//*//*//*//*                               | number of tasks<br>number of task messages<br>number of task message pointers<br>number of delay events<br>number of active channel buffers<br>number of file slots<br>number of I/O UART ports<br>input buffer size (2^p2p.<br>maximum memory size<br>task message size                                                                                                                                                           | */<br>*/<br>*/<br>*/<br>*/<br>*/<br>*/       |
| #define<br>#define<br>#define<br>#define                                                                                                                                                                                  | NEV<br>NIE<br>NPS<br>P2P                                                                                                                | NT<br>NM<br>NP<br>NC<br>NF<br>ND<br>(ND/2)<br>(NU+1)<br>IZ<br>MZ<br>TZ                                                                                       |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                              |
| #define<br>#define<br>#define<br>#define<br>#define<br>#define<br>#define<br>#define<br>#define                                                                                                                           | MBZ<br>NMB<br>FSS<br>TQB<br>TQM<br>TQE<br>TQS<br>TBZ                                                                                    | (0xFF>>(8-P2P))<br>((1< <p2p)+2)<br>2048<br/>(MMZ/MPZ)<br/>(MBZ/8)<br/>38<br/>2<br/>(TQB+4)<br/>(TQH+2)<br/>(TQE+2)<br/>(TQS+2+4)<br/>256<br/>4</p2p)+2)<br> | /**********<br>/*////////////////////////    | <pre>input buffer wrap around mask<br/>(# characters/port) + 2<br/>memory page size<br/>memory bitmap size<br/>number of map bytes<br/>file slot size<br/>TCB index<br/>map index<br/>event #1 / event #2<br/>scheduled event<br/>TASK entry size<br/>bytes per sector<br/>number of RAM disks</pre>                                                                                                                               | */<br>*/<br>*/<br>*/<br>*/<br>*/<br>*/<br>*/ |
| /*00A*/ (<br>/*010*/ (<br>/*010*/ (<br>/*012*/ '<br>/*014*/ (<br>/*018*/ '<br>/*014*/ (<br>/*020*/ (<br>/*020*/ (<br>/*022*/ (<br>/*022*/ (<br>/*025*/ (<br>/*028*/ (<br>/*028*/ (<br>/*038*/ (<br>/*058*/ (<br>/*058*/ ( | char<br>char<br>unsig<br>char<br>char<br>char<br>int<br>char<br>int<br>long<br>unsig<br>unsig<br>unsig<br>unsig<br>char<br>char<br>char | *_bios;<br>*_mail;<br>ned int _rdkn;<br>ned int _rdks;<br>* rdka;<br>_bflg;<br>_dflg;<br>_f681;<br>*_sram;<br>pare1;<br>fcnt;                                | <u>/////////////////////////////////////</u> | address of bios rom<br>*mail array address<br>*ram disk #<br>*ram disk size<br>*ram disk size<br>*ram disk address<br>basic present flag<br>directory flag<br>68000/68010 flag<br>run module B\$SRAM<br>reserved for expansion<br>fine counter<br>32 bit counter<br>month<br>day<br>year<br>hours<br>minutes<br>seconds<br>input port allocation table<br>input break flags<br>port flag bits<br>port uart type<br>port rate table | *********************                        |

# C. System RAM Definitions (cont'd)

| /*078*/ char _evtb[10];                                                                            | /* (  | )-79 event table                    | */  |
|----------------------------------------------------------------------------------------------------|-------|-------------------------------------|-----|
| /*082*/ char _evto[2];                                                                             | /* 8  | 30-95 output events                 | */  |
| /*084*/ char _evti[2];                                                                             | /* 9  | P6-111 input events                 | */  |
| /*086*/ char _evts[2];                                                                             | /* 1  | 112-127 system events               | */  |
| /*088*/ char _ev128[16];                                                                           | /* 1  | task 128 events                     | */  |
| /*098*/ long _evtm[4];                                                                             |       | events 112-115 timers               | */  |
| /*OA8*/ long _bclk;                                                                                |       | clock adjust constant               | */  |
| /*OAC*/ char *_tltp;                                                                               |       | task list pointer                   | */  |
| /*0B0*/ char *_utcb;                                                                               |       | user tcb ptr                        | */  |
| /*OB4*/ int _suim;                                                                                 |       | supervisor interrupt mask           | */  |
| /*OB6*/ int _usim;                                                                                 |       | user interrupt mask                 | */  |
| /*0B8*/ char _sptn;                                                                                |       | spawn task no. (** must be even **) | */  |
| /*OB9*/ char _utim;                                                                                |       | user task time                      | */  |
| /*OBA*/ char _tpry;<br>/*OBB*/ char _tskn;                                                         |       | task priority (** must be even **)  | */  |
| /*OBB*/ char _tskn;                                                                                |       | current task number                 | */  |
| /*0BC*/ char spare2;                                                                               |       | reserved                            | */  |
| /*OBD*/ char_tqux;                                                                                 |       | task queue offset flag/no           | */  |
| /*OBE*/ chun _tick[2];<br>/*OCO*/ chun _e122;                                                      |       | task lock/reschedule flags          | */  |
| /*000*/ ch +                                                                                       |       | patch task #                        | */  |
| /*0C1*/ ch > _e123;                                                                                | /~ 9  | spooler task #                      | */  |
| /*0C2*/ che124;<br>/*0C3*/ chare125;                                                               |       |                                     |     |
| /*00/*/ La                                                                                         | 14    |                                     | ÷ / |
| /*0C4*/ long_cksm;                                                                                 |       | system checksum                     | */  |
| /*0C8*/ int _pnod;<br>/*0C4*(_phon_boon[6];                                                        |       | onet node #                         | */  |
| /*0CA*/ char bser[6];<br>(*0D0*/ char ilon[6];                                                     |       | bus error vector                    | */  |
| /*0D0*/ char iler[6];                                                                              |       | illegal vector                      | */  |
| /*0D6*/ char ccnt[16];                                                                             |       | control C count                     | */  |
| /*0E6*/ char *_wind;                                                                               |       | window id's                         | */  |
| /*OEA*/ char *_wadr;                                                                               | •     | window addresses                    | */  |
| /*OEE*/ char *_chin;                                                                               |       | input stream                        | */  |
| /*OF2*/ char *_chot;                                                                               |       | output stream                       | */  |
| /*0F6*/ char *_iord;                                                                               |       | i/o redirect                        | */  |
| /*OFA*/ char _fect;                                                                                |       | file expand count                   | */  |
| /*OFB*/ char _pidn;                                                                                |       | processor ident byte                | */  |
| /*OFC*/ long *_begn;                                                                               |       | abs addr of K1\$BEGN table          | */  |
| /*100*/ int _rwcl[14];                                                                             |       | port row/col 115                    | */  |
| /*11C*/ char *_opip[15];                                                                           |       | output port pointers 115            | */  |
| /*158*/ char *_uart[16];                                                                           |       | uart base addresses 115             | */  |
| /*198*/ long _mapb;                                                                                | /* r  | nemory map bias                     | */  |
| /* the following shanne with different conf                                                        | £ ;   | tions                               | */  |
| <pre>/* the following change with different conf /* configuration for VMEPROM is defined to:</pre> |       |                                     | */  |
|                                                                                                    | •     |                                     | */  |
| /* NT = 64, NF = 64, MZ = \$400000<br>/*                                                           |       |                                     | */  |
|                                                                                                    |       | deted only for this                 | -   |
|                                                                                                    | cateu | nated only for this                 | */  |
| /* configuration                                                                                   |       |                                     | */  |
| /*<br>/*010C*/ abonmana[NW0].                                                                      | /* .  | aveter memory bitmen                | */  |
| /*019C*/ char _maps[NMB];<br>(*119C*/ char _maps[(NDS=1)*NCD];                                     |       | system memory bitmap                | */  |
|                                                                                                    |       | character input buffers             | */  |
| /*157A*/ char _iout[(NPS-1)*NCP];                                                                  | /* (  | character output buffers            | */  |
| /*1958*/ char rdtb[16];                                                                            |       | redirect table                      | */  |
| /*1968*/ int _tque[NTB+1];                                                                         |       | task queue                          | */  |
| /*19EA*/ char _tlst[NTB*TBZ];                                                                      |       | task list                           | */  |
| /*1DEA*/ char _tsev[NTB*32];                                                                       |       | task schedule event table           | */  |
| /*25EA*/ long _tmtf[NTM];                                                                          |       | to/from/INDEX.W                     | */  |
| /*26EA*/ char _tmbf[TMZ*NTM];<br>/*36EA*/ char _tmsp[NTP*6];                                       |       | task message buffers                | */  |
| /*JOEA*/ CHAF _TMSP[N]P*6];                                                                        |       | task message pointers               | */  |
| /*374A*/ char _deiq[2+8+NIE*10];                                                                   |       | delay event insert queue            | */  |
| /*3894*/ char _devt[2+NEV*10];                                                                     |       | delay events                        | */  |
| /*3B16*/ int _bsct[32];                                                                            |       | basic screen command table          | */  |
| /*3856*/ int _xchi[NCB];                                                                           |       | channel buffer queue                | */  |
| /*3B66*/ char _xchb[NCB*BPS];                                                                      |       | channel buffers                     | */  |
| /*4366*/ char _xfsl[NFS*FSS];<br>/*4CE6*/ char _l2lk;                                              |       | file slots                          | */  |
| /^4UEO*/ CNAR_121K;                                                                                | /*    | level 2 lock (file prims, evnt 120) | */  |
| /*4CE/*/ char _l3lk;                                                                               |       | level 3 lock (disk prims, evnt 121) | */  |
| /*4CE8*/ long _drvl;                                                                               |       | driver link list entry point        | */  |
| /*4CEC*/ long _utll;                                                                               |       | utility link list entry point       | */  |
| /*4CF0*/ int _rdkl[NRD*4 + 1];                                                                     | /*    | RAM disk list                       | */  |
| );<br>                                                                                             | •     |                                     |     |

# APPENDIX D

## D. Task Control Block Definitions

| #define MAXARG 10<br>#define MAXBP 10                   | /* max argument count of the cmd line<br>/* max 10 breakpoints | */<br>*/ |
|---------------------------------------------------------|----------------------------------------------------------------|----------|
| #define MAXNAME 5                                       | /* max 5 names in name buffer                                  | */       |
| #define TMAX 64                                         | /* Max number of tasks                                         | */       |
| #define ARGLEN 20                                       | /* maximum argument length                                     | */       |
| /* special system flags for VMEPROM                     |                                                                | */       |
| #define SOMEREG 0x0001                                  | /* display only PC,A7,A6,A5                                    | */       |
| #define T DISP 0x0002                                   | <pre>/* no register display during trace(TC&gt;1)</pre>        | */       |
| #define T_SUB 0x0004                                    | /* trace over subroutine set                                   | */       |
| #define T_ASUB 0x0008                                   | /* trace over subroutine active                                | */       |
| #define T_RANG 0x0010                                   | /* trace over range set                                        | */       |
| #define REG INI 0x0020                                  | /* no register initialization if set                           | */       |
| #define RE DIR 0x0040                                   | <pre>/* output redirection into file and</pre>                 | */       |
| -                                                       | /* console at the same time                                    | */       |
|                                                         |                                                                |          |
| <pre>/* the registers are stored in the following</pre> | order:                                                         | */       |
| #define VBR 0                                           |                                                                |          |
| #define SFC 1                                           |                                                                |          |
| #define DFC 2                                           |                                                                |          |
| #define CACR 4                                          |                                                                |          |
| #define PC 5                                            |                                                                |          |
| #define SR 6                                            |                                                                |          |
| #define USTACK 7                                        |                                                                |          |
| #define SSTACK 8                                        |                                                                |          |
| #define MSTACK 9                                        |                                                                | <b>.</b> |
| #define D0 10                                           | /* 10-17 = D0-D7                                               | */       |
| #define A0 18                                           | /* 18-24 = A0-A6                                               | */       |
| #define N_REGS 25                                       |                                                                |          |
| #define BYTE unsigned char                              |                                                                |          |
| #define WORD unsigned int                               |                                                                |          |
| #define LWORD unsigned long                             |                                                                |          |
| ······                                                  |                                                                |          |
| struct TCB{                                             |                                                                |          |
| /*000*/ char _ubuf[256];                                | /* 256 byte user buffer                                        | */       |
| /*100*/ char _clb[80];                                  | /* 80 byte monitor command line buffer                         | */       |
| /*150*/ char;                                           | /* 32 byte monitor parameter buffer                            | */       |
| /*170*/ char _mpb[60];                                  | /* monitor parameter buffer                                    | */       |
| /*1AC*/ char cob[8];                                    | /* character out buffer                                        | */       |
| /*1B4*/ char _swb[508];                                 | <pre>/* system work buffer/task pdos stack</pre>               | */       |
| /*3B0*/ char *_tsp;                                     | /* task stack pointer                                          | */       |
| /*3B4*/ char *_kil;                                     | /* kill self pointer                                           | */       |
| /*3B8*/ long _sfp;                                      | /* RESERVED FOR INTERNAL PDOS USE                              | */       |
| /*3BC*/ char _svf;                                      | /* save flag 68881 support (x881)                              | */       |
| /*3BD*/ char _iff;                                      | /* RESERVED FOR INTERNAL PDOS USE                              | */       |
| /*3BE*/ long _trp[16];                                  | /* user TRAP vectors                                           | */       |
| /*3FE*/ long _zdv;                                      | /* zero divide trap                                            | */       |
| /*402*/ long _chk;                                      | /* CHCK instruction trap                                       | */       |
| /*406*/ long _trv;                                      | /* TRAPV Instruction trap                                      | */       |

## D. Task Control Block Definitions (cont'd)

| /*40A*/ lo | ong _trc;            | /*  | trace vector                         | */         |
|------------|----------------------|-----|--------------------------------------|------------|
| /*40E*/ lo | ong fpa[2];          | /*  | floating point accumulator           | */         |
| /*416*/ lo | ong *_fpe;           | /*  | fp error processor address           | */         |
| /*41A*/ ch | iar * clp;           | /*  | command line pointer                 | */         |
| /*41E*/ ch | ar * bum;            |     | beginning of user memory             | */         |
| /*422*/ ch |                      | /*  | end user memory                      | */         |
| /*426*/ ch |                      | /*  | entry address                        | */         |
| /*42A*/ ch | nar *_imp;           | /*  | internal memory pointer              | */         |
| /*42E*/ in | nt _aci;             | /*  | assigned input file ID               | */         |
| /*430*/ in |                      | /*  | assigned input file ID's             | */         |
| /*432*/ in | nt len;              | /*  | last error number                    | */         |
| /*434*/ in |                      | /*  | spool file id                        | */         |
| /*436*/ BY | TE_flg;              | /*  | task flags (bit 8=command line echo) | */         |
| /*437*/ BY | TE_slv;              | /*  | directory level                      | */         |
| /*438*/ ch | nar _fec;            | /*  | file expansion count                 | */         |
| /*439*/ ch |                      | /*  | reserved for future use              | */         |
|            |                      | /*  | clear screen characters              | */         |
|            |                      | /*  | position cursor characters           | */         |
| /*43E*/ ch | nar sds[3];          |     | alternate system disks               | */         |
| /*441*/ BY |                      |     | system disk                          | */         |
| /*442*/ ch | nar * ext;           | /*  | XEXT address                         | */         |
| /*446*/ ch |                      | /*  | XERR address                         | */         |
| /*44A*/ ch | nar cmd;             | /*  | command line delimiter               | */         |
| /*44B*/ BY | TE tid;              | /*  | task id                              | */         |
| /*44C*/ ch |                      | /*  | echo flag                            | */         |
| /*44D*/ ch |                      | /*  | output column counter                | */         |
| /*44E*/ ch | nar mmf;             |     | memory modified flag                 | */         |
| /*44F*/ ch | har prt;             |     | input port #                         | */         |
| /*450*/ ch |                      |     | spooling unit mask                   | */         |
| /*451*/ BY |                      |     | output unit mask                     | */         |
| /*452*/ ch | nar Tulp;            |     | unit 1 port #                        | */         |
| /*453*/ ch | har u2p;             |     | unit 2 port #                        | */         |
| /*454*/ ch |                      |     | unit 4 port #                        | */         |
| /*455*/ ch | nar Tu8p;            | /*  | unit 8 port #                        | */         |
|            |                      |     | reserved for system use              | */         |
|            |                      |     | *****                                | 1          |
| <b>′</b> . |                      | *** | ********                             |            |
|            | MEPROM variable area | *** | *******                              | */<br>***/ |
| /          |                      |     |                                      | /          |
| /*470*/ ch | nar linebuf[82];     | /*  | command line buffer                  | */         |
|            | •                    | -   | alternate line buffer                | */         |
|            |                      | /*  | alternate cmdline for XGNP           | */         |
|            |                      |     | argc save and count for XGNP         | */         |
| /*56A*/ in |                      |     | argument counter                     | */         |
|            |                      |     | pointer to arguments of the cmd line | */         |
|            |                      |     | I/O redirection args from cmd line   | */         |
| /*59C*/ in |                      |     | I/O port assignments                 | *'/        |
|            |                      |     | holds pointer to line in_mwb         | */         |
| · ·        | JORD offset;         | ·/* | base memory pointer                  | */         |
| /*5A8*/ in |                      |     | num of defined breakpoints           | */         |
|            | WORD bpadr [MAXBP];  |     | breakpoint address                   | */         |
| /*5D2*/ WO |                      | · · | breakpoint instruction               | */         |
| /*5E6*/ ch |                      |     | breakpoint command                   | *'/        |
|            | ······               |     |                                      | •          |

#### D. Task Control Block Definitions (cont'd)

- /\*654\*/ WORD bpocc[MAXBP]; /\*668\*/ WORD bpcocc [MAXBP];
- /\*FCC\*/ LWORD t\_range[2]; /\*FD4\*/ LWORD ex regs;
- /\* # of times the breakpoint should be /\* skipped
  /\* # of times the breakpoint is already /\*668\*/ WORD bpcocc[MAXBP]; /\* # of times the breakpoint is already /\*67C\*/ LWORD bptadr; /\* temp. breakpoint is truction /\*682\*/ WORD bptocc; /\* temp. breakpoint instruction /\*682\*/ WORD bptcocc; /\* # of times the temp. breakpoint should /\*684\*/ WORD bptcocc; /\* # of times the temp. breakpoint is /\*684\*/ WORD bptcocc; /\* # of times the temp. breakpoint is /\*691\*/ char outflag; /\* dot times the temp. breakpoint is /\*691\*/ char outflag; /\* already skipped /\*684\*/ WORD errent; /\* already skipped /\*684\*/ WORD pregs[MAXNAME][8]; /\* Name buffer, name /\*684\*/ WORD pregs[MAKNAME][40]; /\* Name buffer, data /\*784\*/ WORD pregs[N\_REGS]; /\* storage area of processor regs /\*7F0\*/ WORD tflag; /\* storage area of processor regs /\*7F0\*/ WORD tacount; /\* trace count /\*7F6\*/ WORD tacount; /\* active flag /\*7F2\*/ WORD tacount; /\* active flag /\*7F2\*/ WORD tacount; /\* supervisor stack during GO/T etc /\*7F6\*/ WORD bact; /\* supervisor stack during GO/T etc /\*7F6\*/ WORD f\_fpreg[3\*8]; /\* floating point data regs /\*F0A\*/ LWORD f\_fpreg[3\*8]; /\* floating point data regs /\*F0A\*/ LWORD f\_fpre; /\* FPSR reg /\*F64\*/ LWORD f\_fprin; /\* save defined prompt sign /\*FC0\*/ BYTE f\_save[0X3C]; /\* save cache control register /\*F64\*/ HORD f\_fprin; /\* save cache control register /\*F64\*/ LWORD f\_fprin; /\* save cache control register /\*F64\*/ LWORD f\_fprin; /\* save cache control register /\*F64\*/ LWORD f\_fprin; /\* save cache control register /\*F64\*/ HORD f\_fprin; /\* save cache control register /\*F64\*/ BYTE cleol[2]; /\* clear to end of line parameters /\*F64\*/ HORD g\_save; /\* save cache control register /\*F64\*/ HORD sysflg; /\* system flags used by WEPROM /\* bit 0: display registers short form /\* bit 1: trace without reg, display /\* bit 0: display registers short form /\* bit 1: trace without reg, display /\* bit 2: trace over subroutine /\* skipped /\* bit 1: trace without reg. display /\* bit 2: trace over subroutine /\* bit 3: trace over subroutine active /\* bit 4: trace over range
  /\* bit 5: no register initialization /\* bit 6: output redirection into file ´/\* <sup>'</sup> and console at the same time /\* start/stop PC for trace over range /\* pointer to area for saved regs /\* make tcb size \$1000 bytes /\* task beginning

>:

This page was intentionally left blank

# **APPENDIX E**

# E. Interrupt Vector Table of VMEPROM

| Vector   | Vector | Assignment                                |  |  |  |  |  |
|----------|--------|-------------------------------------------|--|--|--|--|--|
| Number/s | HEX    | Assignment                                |  |  |  |  |  |
| 0        | 000    | Reset: Initial Interrupt Stack Pointer    |  |  |  |  |  |
| 1        | 004    | Reset: Initial Program Counter            |  |  |  |  |  |
| 2        | 008    | Bus Error                                 |  |  |  |  |  |
| 3        | 000    | Address Error                             |  |  |  |  |  |
| 4        | 010    | Illegal Instruction                       |  |  |  |  |  |
| 5        | 014    | Zero Divide                               |  |  |  |  |  |
| 6        | 018    | CHK, CHK2 Instruction                     |  |  |  |  |  |
| 7        | 01C    | FTRAPcc, TRAPcc, TRAPV Instructions       |  |  |  |  |  |
| 8        | 020    | Privilege Violation                       |  |  |  |  |  |
| 9        | 024    | Trace                                     |  |  |  |  |  |
| 10       | 028    | VMEPROM System Calls                      |  |  |  |  |  |
| 11       | 02C    | Coprocessor Instructions                  |  |  |  |  |  |
| 12       | 030    | (Unassigned, Reserved)                    |  |  |  |  |  |
| 13       | 034    | Not used by MC68040                       |  |  |  |  |  |
| 14       | 038    | Format Error                              |  |  |  |  |  |
| 15       | 03C    | Uninitialized Interrupt                   |  |  |  |  |  |
| 16       | 040    | <b>1</b> ¬                                |  |  |  |  |  |
| THROUGH  |        | ⊢► (Unassigned, Reserved)                 |  |  |  |  |  |
| 23       | 05C    |                                           |  |  |  |  |  |
| 24       | 060    | Spurious Interrupt                        |  |  |  |  |  |
| 25       | 064    | AV1                                       |  |  |  |  |  |
| 26       | 068    | AV2                                       |  |  |  |  |  |
| 27       | 06C    | AV3                                       |  |  |  |  |  |
| 28       | 070    | AV4                                       |  |  |  |  |  |
| 29       | 074    | AV5                                       |  |  |  |  |  |
| 30       | 078    | AV6                                       |  |  |  |  |  |
| 31       | 07C    | AV7                                       |  |  |  |  |  |
| 32       | 080    | л                                         |  |  |  |  |  |
| THROUGH  |        | F► TRAP #0-15 Instruction Vectors         |  |  |  |  |  |
| 47       | OBC    |                                           |  |  |  |  |  |
| 48       | 0C0    | FPCP Branch or Set on Unordered Condition |  |  |  |  |  |
| 49       | 0C4    | FPCP Inexact Result                       |  |  |  |  |  |
| 50       | 0C8    | FPCP Divide by Zero                       |  |  |  |  |  |
| 51       | 000    | FPCP Underflow                            |  |  |  |  |  |
| 52       | ODO    | FPCP Operand Error                        |  |  |  |  |  |
| 53       | 0D4    | FPCP Overflow                             |  |  |  |  |  |
| 54       | 0D8    | FPCP Signaling NAN                        |  |  |  |  |  |
| 55       | ODC    | FPCP Unimplemented Data Type              |  |  |  |  |  |
| 56       | OEO    | PMMU Configuration                        |  |  |  |  |  |
| 57       | OE4    | PMMU Illegal Operation                    |  |  |  |  |  |
| 58       | OE8    | PMMU Access Level Violation               |  |  |  |  |  |
| 59       | OEC    |                                           |  |  |  |  |  |
| THROUGH  |        | ⊢► Unassigned, Reserved                   |  |  |  |  |  |
| 63       | OFC    |                                           |  |  |  |  |  |
| 64       | 100    |                                           |  |  |  |  |  |
| THROUGH  |        | F SIO-1/2 Interrupt Vectors               |  |  |  |  |  |
| 75       | 12C    |                                           |  |  |  |  |  |
| 76       | 130    |                                           |  |  |  |  |  |
| THROUGH  |        | ⊢► ISIO-1/2 Interrupt Vectors             |  |  |  |  |  |
| 83       | 14C    |                                           |  |  |  |  |  |
|          |        |                                           |  |  |  |  |  |

cont'd.....

| Vector<br>Number/s | Vector<br>HEX | Assignment            |  |  |  |  |
|--------------------|---------------|-----------------------|--|--|--|--|
| 84                 | 150           | ٦                     |  |  |  |  |
| THROUGH            |               | ⊢► User Defined       |  |  |  |  |
| 118                | ID8           |                       |  |  |  |  |
| 119                | IDC           | Disk Interrupt Vector |  |  |  |  |
| 120                | 1EO           | ۲ – ۲                 |  |  |  |  |
| THROUGH            |               | ⊢► User Defined       |  |  |  |  |
| 191                | 2FC           |                       |  |  |  |  |
| 192                | 300           | Mailbox 0             |  |  |  |  |
| 193                | 304           | Mailbox 1             |  |  |  |  |
| 194                | 308           | Mailbox 2             |  |  |  |  |
| 195                | 30C           | Mailbox 3             |  |  |  |  |
| 196                | 310           | Mailbox 4             |  |  |  |  |
| 197                | 314           | Mailbox 5             |  |  |  |  |
| 198                | 318           | Mailbox 6             |  |  |  |  |
| 199                | 31C           | Mailbox 7             |  |  |  |  |
| 200                | 320           | 7                     |  |  |  |  |
| THROUGH            |               | ⊢► Reserved           |  |  |  |  |
| 223                | 37C           |                       |  |  |  |  |
| 224                | 380           | Timer                 |  |  |  |  |
| 225                | 384           | Reserved              |  |  |  |  |
| 226                | 388           | Reserved              |  |  |  |  |
| 227                | 38C           | Reserved              |  |  |  |  |
| 228                | 390           | FMB1 Refused          |  |  |  |  |
| 229                | 394           | FMB0 Refused          |  |  |  |  |
| 230                | 398           | FMB1 Message          |  |  |  |  |
| 231                | 39C           | FMB0 Message          |  |  |  |  |
| 232                | 3A0           | ABORT                 |  |  |  |  |
| 233                | 3A4           | ACFAIL*               |  |  |  |  |
| 234                | 3A8           | SYSFAIL*              |  |  |  |  |
| 235                | 3AC           | DMA Error             |  |  |  |  |
| 236                | 3B0           | DMA Normal            |  |  |  |  |
| 237                | 3B4           | PARITY Error          |  |  |  |  |
| 238                | 3B8           | Reserved              |  |  |  |  |
| 239                | 3BC           | Reserved              |  |  |  |  |
| 240                | 3C0           | LOCAL1                |  |  |  |  |
| 241                | 3C4           | LOCAL2                |  |  |  |  |
| 242                | 3C8           | LOCAL3                |  |  |  |  |
| 243                | 300           | LOCALS                |  |  |  |  |
| 244                | 3D0           | LOCAL4                |  |  |  |  |
| 245                | 3D4           | LOCALS                |  |  |  |  |
| 246                | 3D8           | LOCAL7                |  |  |  |  |
| 247                | 3DC           | LOCAL8                |  |  |  |  |
| 248                | 3E0           |                       |  |  |  |  |
| THROUGH            |               | ⊢► Reserved           |  |  |  |  |
| 254                | 3F4           |                       |  |  |  |  |
| 255                | 3FC           | Empty Interrupt       |  |  |  |  |
| 200                |               | - mpey meetinge       |  |  |  |  |

# **APPENDIX F**

#### F. Benchmark Source Code

```
*****
** Module name: Assembler benchmarks
                                    Version: 1.0
                                                          **
** date started: 20-Apr-87 M.S. last update: 23-Apr-87 M.S. **
       Copyright (c) 1986/87 FORCE Computers GmbH Munich
                                                         **
**
*****
*
      section 0
               alt, P=68020, P=68881
       opt
               .benchex
       xdef
               .BEN1BEG, .BEN1END
       xdef
       xdef
               .BEN2BEG, BEN2END
               .BEN3BEG, .BEN3END
       xdef
       xdef
               .BEN4BEG, .BEN4END
               .BEN5BEG, .BEN5END
       xdef
               .BEN6BEG, .BEN6END
       xdef
       xdef
               .BEN7BEG, .BEN7END
               .BEN8BEG, .BEN8END
       xdef
               .BEN9BEG, .BEN9END
       xdef
       xdef
               .BEN10BEG, .BEN10END
       xdef
               .BEN11BEG, .BEN11END
       xdef
               .BEN12BEG, .BEN12END
       xdef
               .BEN13BEG, BEN13END
               .BEN14BEG, .BEN14END
       xdef
       page
 benchmark execution: benchex(address)
*
       movem.l d1-a6,-(a7)
       move.l 15*4(a7),a0
               (a0)
       isr
       movem.1 (a7)+,d1-a6
       rts
 BENCH #1: DECREMENT LONG WORD IN MEMORY 10.000.000 TIMES
*
       LEA.L
               @010(PC),A0
       MOVE.L #10000000, (A0)
@020
       SUBQ.L #1,(A0)
       BNE.S
               @020
       RTS
@010
       DS.L
               1
*
* BENCH #2: PSEUDO DMA 1K BYTES 50.000 TIMES
                            ; DO 50000 TRANSFERS
       MOVE.L
              #50000,D2
                            ; EACH IS 1K BYTES
0001
       MOVE.W
               #SFF,D3
               @010(PC),A1
       LEA.L
                            ; A1 POINTS TO SOURCE AND DESTINATION
@002
       MOVE.L
               (A1), (A1)+
       DBRA
               D3,0002
       SUBQ.L
               #1,D2
       BNE.S
               0001
       RTS
       NOP
@010
       NOP
       PAGE
```

|                                |                                                     |                                                                  |                                                           |                         |              |                                    |        |               |      |        |       |      |         | (cont'd) |
|--------------------------------|-----------------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------|-------------------------|--------------|------------------------------------|--------|---------------|------|--------|-------|------|---------|----------|
| *                              | #3 <b>:</b>                                         | SUBS                                                             | TRING                                                     | CHARA                   | CTER         | SEARCH                             | 100.00 | 0 TIM         | IES  | TAKEN  | FROM  | EDN  | 08/08/8 | 5        |
| *                              | MOVE                                                | .L                                                               | #10000                                                    | 00,D4                   |              |                                    |        |               |      |        |       |      |         |          |
| @002                           | MOVE<br>MOVE<br>LEA.<br>BSR.<br>SUBQ<br>BNE.<br>RTS | .L<br>.L<br>L<br>S<br>.L                                         | #15,D(<br>#120,I<br>EDN1D                                 | )                       |              |                                    |        |               |      |        |       |      |         |          |
| *                              |                                                     |                                                                  |                                                           | 7 <i>1</i> 1 <b>1</b> 1 |              | 4.4.                               |        |               |      |        |       |      |         |          |
| EDN1                           | MOVE<br>SUB.<br>MOVE<br>SUBQ<br>MOVE                | M.L<br>W<br>.W<br>.W                                             | D3/D4,<br>D0,D1<br>D1,D2<br>#2,D0<br>(A0)+                |                         |              |                                    |        |               |      |        |       |      |         |          |
| @010<br>@012                   | CMP.<br>DBEQ<br>BNE.<br>MOVE<br>MOVE<br>BMI.        | S<br>.L<br>.L<br>.W                                              | (A1)+<br>D1,@0<br>@090<br>A0,A2<br>A1,A3<br>D0,D4<br>@030 |                         |              |                                    |        |               |      |        |       |      |         |          |
| @020                           | CMP.<br>DBNE<br>BNE.                                | В                                                                | -                                                         | ,(A3)+<br>20            |              |                                    |        |               |      |        |       |      |         |          |
| @030<br>@032                   | SUB.                                                | W                                                                | D1,D2                                                     | <b>,</b> D3/D4          | /A2/         | A3                                 |        |               |      |        |       |      |         |          |
| <b>@</b> 090                   |                                                     |                                                                  | #-1,D<br>@032                                             | 2                       |              |                                    |        |               |      |        |       |      |         |          |
| *******<br>EDN1DAT<br>EDN1DAT: | DC.<br>DC.                                          | B<br>B<br>B                                                      | 1000<br>1000                                              | 000000                  | 0000<br>0000 | *<br>0000000<br>0000000<br>CH00000 | 000000 | 0000 <i>1</i> |      |        |       |      |         |          |
| *                              |                                                     |                                                                  |                                                           |                         |              |                                    |        |               |      |        |       |      |         |          |
| * BENCH<br>*                   | #4 <b>:</b>                                         | BIT                                                              | TEST/                                                     | SET/RE                  | SET          | 100.000                            | TIMES  | TAKEN         | I FR | OM EDI | N 08/ | 08/8 | 5 .     |          |
|                                | MOVE<br>LEA.                                        | L                                                                |                                                           | AT (PC)                 | <b>,</b> A0  |                                    |        |               |      |        |       |      |         |          |
| @010                           | MOVE<br>BSR.<br>MOVE<br>BSR.<br>MOVE<br>BSR.        | Q.L<br>SQ.L<br>Q.L<br>SQ.L<br>SQ.L<br>SQ.L<br>SQ.L<br>SQ.L<br>SQ | EDN2                                                      | 1                       |              | ; TESI                             |        |               |      |        |       |      |         |          |
|                                |                                                     | Q.L                                                              | #2,D0<br>#10,D<br>EDN2                                    | 1                       |              | ; SET                              |        |               |      |        |       |      |         |          |

F-2

(cont'd)

| *        |       | MOVEQ.L<br>MOVEQ.L<br>BSR.S<br>MOVEQ.L<br>MOVE.W<br>BSR.S<br>MOVEQ.L<br>BSR.S<br>MOVEQ.L<br>BSR.S<br>MOVEQ.L<br>BSR.S<br>MOVEQ.L<br>BSR.S<br>SUBQ.L<br>BNE.S<br>RTS | <pre>#11,D1 EDN2 #1,D0 #123,D1 EDN2 #3,D0 #10,D1 EDN2 #1,D0 #11,D1 EDN2</pre> |   | ; RE | SET     |       |  |
|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|---|------|---------|-------|--|
| EDN      | 12    | SUB.W<br>BEQ.S<br>SUBQ.W<br>BEQ.S                                                                                                                                   | #2,D0<br>@020<br>#1,D0<br>@030                                                |   |      |         |       |  |
| @01<br>* | .0    | BFTST<br>DC.W<br>DC.W<br>SNE<br>RTS                                                                                                                                 | (AO){D1:1<br>\$E8DO<br>\$0841<br>D2                                           | } |      |         |       |  |
| @02      | 20    |                                                                                                                                                                     |                                                                               |   |      |         |       |  |
| *        |       | BFSET<br>DC.W<br>DC.W<br>SNE<br>RTS                                                                                                                                 | (A0){D1:1<br>\$EEDO<br>\$0841<br>D2                                           | } |      |         |       |  |
| @03<br>* | 0     | BFTST                                                                                                                                                               | (AO){D1:1                                                                     | ١ |      |         |       |  |
|          |       | DC.W<br>DC.W<br>SNE<br>RTS                                                                                                                                          | \$E8D0<br>\$0841<br>D2                                                        | J |      |         |       |  |
|          | 12DAT | DC.L<br>PAGE                                                                                                                                                        | 0,0,0,0                                                                       |   |      |         |       |  |
| * E<br>* | BENCH |                                                                                                                                                                     | MATRIX TR<br>EN FROM ED                                                       |   |      | 100.000 | TIMES |  |
| @OC      | )2    | MOVE.L<br>LEA.L<br>MOVE.L<br>BSR.S<br>SUBQ.L<br>BNE.S<br>RTS                                                                                                        | #0,D1<br>EDN3                                                                 |   |      |         |       |  |

.

(cont'd)

| *       |                                               |                                         |                                                          |
|---------|-----------------------------------------------|-----------------------------------------|----------------------------------------------------------|
| EDN3    | MOVE.L                                        | D1-D7,-(A7)<br>D1,D2<br>D0,D7           |                                                          |
| @010    | MOVE.L                                        | #2,D7<br>#1,D1<br>D1,D3                 | •<br>•                                                   |
| @020    | ADD.L<br>MOVE.L                               | D0,D2<br>D2,D4                          |                                                          |
|         | BFEXTU<br>BFEXTU                              | (AO){D3:1},D5<br>(AO){D4:1},D6          |                                                          |
|         | BFINS<br>BFINS<br>ADD.L                       | D5,(A0){D4:1}<br>D6,(A0){D3:1}<br>D0,D3 |                                                          |
|         | ADDQ.L<br>CMP.L                               | #1,D4<br>D3,D4                          |                                                          |
|         | BNE.S<br>DBRA<br>MOVEM.L                      | @020<br>D7,@010<br>(A7)+,D1-D7          |                                                          |
|         | RTS                                           |                                         |                                                          |
| EDN3DAT | DC.B<br>DC.B                                  | %01001001<br>%01011100                  |                                                          |
|         | DC.B                                          | \$10001110                              |                                                          |
|         | DC.B                                          | <b>%10100101</b>                        |                                                          |
|         | DC.B<br>DC.B                                  | %00000001<br>%01110010                  |                                                          |
|         | DC.B                                          | \$1000000                               |                                                          |
|         | EVEN                                          |                                         |                                                          |
| *       | PAGE                                          |                                         |                                                          |
|         | #6: CAC                                       | HE TEST - 128KB PROGR                   | AM IS EXECUTED 1000 TIMES                                |
| *<br>*  |                                               |                                         | NEEDS 128 KBYTE MEMORY                                   |
|         | LEA.L                                         | @010(PC),A2                             |                                                          |
|         | MOVE.L<br>MOVE.L                              | #\$203A0000,D1<br>#\$20000/4,D2         | ; OPCODE FOR MOVE.L (\$0,PC),D0<br>; LENGTH IS 128 KBYTE |
| 0004    | MOVE.L                                        | D1, (A2)+                               | ; LOAD OPCODE TO MEMORY                                  |
|         | SUBQ.L                                        | #1,D2                                   |                                                          |
|         | BNE.S                                         | @004<br>#CARTE (NO)                     |                                                          |
| * PROGR | MOVE.W                                        | #\$4E75,(A2)<br>W LOADED START 100      | ; APPEND RTS<br>O TIMES                                  |
| 11001   | MOVE.L                                        | #1000,D3                                |                                                          |
| 0008    | BSR.S                                         | @010                                    |                                                          |
|         |                                               | #1,D3                                   |                                                          |
|         | BNE.S<br>RTS                                  | 0008                                    |                                                          |
| *       | NID .                                         |                                         | · · · · · · · · · · · · · · · · · · ·                    |
| 0010    | DC.L                                          | 0                                       | ; PROGRAM WILL START HERE                                |
| *       | PAGE                                          |                                         |                                                          |
|         | #7: FLO                                       | ATING POINT 1.000.000                   | ADDITIONS                                                |
| *       | <i>",</i> ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                         |                                                          |
|         |                                               |                                         |                                                          |
|         | MOVE.L                                        | #1000000,D5                             |                                                          |
|         | FMOVE.L                                       | #0,FP0                                  |                                                          |
| @010    | FMOVE.L<br>FMOVE.L                            | #0,FP0<br>#1,FP1                        |                                                          |
| @010    | FMOVE.L<br>FMOVE.L                            | #0,FP0<br>#1,FP1<br>FP0,FP1             |                                                          |
| 0010    | FMOVE.L<br>FMOVE.L<br>FADD.X                  | #0,FP0<br>#1,FP1<br>FP0,FP1             |                                                          |

F-4

(cont'd)

```
* BENCH #8: FLOATING POINT 1.000.000 SINUS
4
        MOVE.L #100000,D5
        FMOVE.L #1, FP1
@010
        FSIN.X FP1
        SUBQ.L #1,D5
                0010
        BNE.S
        RTS
        PAGE
*
* BENCH #9: FLOATING POINT 1.000.000 MULTIPLICATIONS
*
        MOVE.L #1000000,D5
        FMOVE.L #1, FPO
        FMOVE.L #1, FP1
@010
        FMUL.X FPO, FP1
        SUBQ.L #1,D5
        BNE.S
                @010
        RTS
        page
* PDOS BENCHMARK #1: CONTEXT SWITCHES
        MOVE.L #100000,D6
0000
        XSWP
                                 ;CONTEXT SWITCH
        SUBQ.L #1,D6
                                 ; DONE?
          BGT.S @000
                                 ;N
        RTS
        PAGE
*
* PDOS BENCHMARK #2: EVENT SET
*
        MOVEQ.L #32,D1
                                 ;SELECT EVENT 32
        MOVE.L #100000,D6
*
0000
        XSEV
                                 ;SET EVENT
        SUBQ.L #1,D6
                                 ; DONE?
          BGT.S @000
                                 ; N
        RTS
        PAGE
* PDOS BENCHMARK #3: CHANGE TASK PRIORITY
        MOVEQ.L #-1,D0
                                 ;SELECT CURRENT TASK
        MOVEQ.L #64,D1
                                 ;SET PRIORITY TO 64
        MOVE.L #100000,D6
*
0000
        XSTP
                                 ;SET PRIORITY
        SUBQ.L #1,D6
                                ; DONE?
         BGT.S @000
                                 ;N
        RTS
```

end

#### (cont'd)

```
*
* PDOS BENCHMARK #4: SEND TASK MESSAGE
        CLR.L
                 DO
                                  ;SELECT TASK #0
                MESO1(PC),A1
                                  ; POINT TO MESSAGE
        LEA.L
        MOVE.L #100000,D6
*
0000
        XSTM
                                  ;SEND MESSAGE
        XKTM
                                  ; READ MESSAGE BACK
        SUBQ.L #1,D6
BGT.S @000
                                  ;DONE?
                                  ; N
        RTS
MES01
        DC.B
                 'BENCH #13',0
        EVEN
        PAGE
*
  PDOS BENCHMARK #5: READ TIME OF DAY
*
        MOVE.L #100000,D6
0000
        EQU
                 *
        XRTP
        SUBQ.L #1,D6
                                  ;DONE?
        BGT.S @000
                                  ;N
        RTS
```

# APPENDIX G

### G. Special Locations

The following table describes some special locations in the EPROM. These locations define the default setup of the name of the startup file, user program location and RAM disk addresses. These options can be selected by front panel switches.

The locations shown in the table can be changed by the user to adapt VMEPROM to every environment. To make the necessary changes, please conduct the following steps:

- 1. Read the EPROMs with an EPROM programmer
- 2. Modify the code
- 3. Burn new EPROMs and keep the old ones in a safe location
- 4. Insert the new EPROMs in the CPU board and test the changes

The address of the following table is located at address \$C relative to the begin of the EPROM):

| Offset | Size                                                                                   | Default                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| \$00   | DS.B 22                                                                                | 'SY\$STRT',0                                                                 | Name of the startup file. It has to be a O-terminated string.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| \$16   | DS.W 1<br>DS.L 1<br>DS.L 1<br>DS.W 1<br>DS.W 1<br>DS.L 1<br>DS.W 1<br>DS.W 1<br>DS.L 1 | 8<br>2048<br>\$40800000<br>8<br>2048<br>\$40700000<br>8<br>256<br>\$FFC10000 | Disk no. of first RAM disk entry.<br>No. of 256 byte sectors.<br>Start address of first RAM disk.<br>Disk no. of second RAM disk entry.<br>No. of 256 byte sectors.<br>Start address of second RAM disk.<br>Disk no. of third RAM disk entry.<br>No. of 256 byte sectors.<br>Start address of third RAM disk.                                                                                                                                                                                                                         |
| \$2E   | DS.B 18                                                                                | 'SY\$DSK',0                                                                  | Default name of initialized RAM disk. It must be a 0-terminated string.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| \$40   | DS.L 1<br>DS.L 1<br>DS.L 1<br>DS.L 1<br>DS.L 1                                         | \$40800000<br>\$<br>\$FFC10000<br>\$                                         | These four entries contain the address which is jumped to after kernel intialization. The second entry contains the address of the BOOT command. The fourth address is the start address of the VMEPROM shell. These values depend on the VMEPROM version.                                                                                                                                                                                                                                                                            |
| \$50   | DS.B 4                                                                                 | 'USER'                                                                       | Disk drivers need this ident to make sure that below data is valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| \$54   | DS.B 1                                                                                 | \$03                                                                         | <ul> <li>Bit 0: If this bit is "O", no message occurs indicating that VMEPROM is waiting until the hard disk is up to speed. This bit is only considered if bit 1 is set to "1".</li> <li>Bit 1: If it is "O", VMEPROM will not wait until hard disk is up to speed.</li> <li>Bit 2: Reserved, should be "O".</li> <li>Bit 3: Reserved, should be "O".</li> <li>Bit 4: Reserved, should be "O".</li> <li>Bit 5: Reserved, should be "O".</li> <li>Bit 6: Reserved, should be "O".</li> <li>Bit 7: Reserved, should be "O".</li> </ul> |
| \$55   | DS.B 7                                                                                 | 7 * \$FF                                                                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| \$5C   | DS.W 1                                                                                 | 16                                                                           | This entry defines the number of hashing buffers. Valid entries are<br>numbers from 1 to 32. The hashing buffers are used to improve disk<br>access speed. Each buffer can hold 16 Kbytes of data.                                                                                                                                                                                                                                                                                                                                    |

Example on how to find this table:

? M \$FF00000C L

FF00000C FF008A00 : .<cr>

? \_

# APPENDIX H

### H. Generation of Applications in EPROM

### H1. General Information

In general, there are three ways to bind an application program in EPROMs to the VMEPROM kernel. In all cases the application program is executed in user mode. The XSUP system call can be used to switch to supervisor mode. The first way keeps the original EPROMs of VMEPROM. The application can be put into an external RR-2 or RR-3 board on the VMEbus. In this case, the front panel switches of the CPU board must be set so that the application program is started after VMEPROM is booted. In this instance, the user stack is located at the top of the tasking memory and the supervisor stack is located within the task control block. The supervisor stack has a size of 500 bytes. No registers are predefined. If the reserved supervisor stack space is not sufficient, the stack pointer has to be set to point to an appropriate address in RAM.

### H1.1 Replacing the User Interface

The following section describes how an application program can be put into EPROMs, replacing the user interface of VMEPROM. This method gives nearly 180 Kbytes of EPROM space to the application. Two general ways are possible:

#### a. Removing All Setups:

If no setups are required, the application can be put into EPROMs at an address which is located in address \$8 relative to the EPROM start address (real address \$FF000008). The code is started in user mode, directly after the kernel has been initialized. The supervisor stack is located in the task control block (size is about 500 bytes) and the user stack is located at the top of the task's memory. Only bit 2 of SW2 of the rotary switches on the front panel is used. It defines the data bus width on the VMEBus. All other bits are insignificant.

#### b. Keep All Setups:

To keep all setups the user program can be put into EPROM at an address which is located in address \$10 relative to the EPROM start address (real address \$FF000010). In this case, the front panel switches are defined as described in the "Introduction to VMEPROM". Both the user and the supervisor stack are located in the task control block. The user stack has a reserved space of 800 bytes and the supervisor stack a space of 800 bytes. The program is started in user mode. The following values are available on the stack:

- 4(A7) Long word containing the begin address of the TCB
- 8(A7) Long word containing the begin address of the system RAM (SYRAM).

A C-program at this address could look like this:

main (tcbp, syramp)

struct TCB \*tcbp;

struct SYRAM \*syramp;

- {

H-2

# **USERS NOTES**

.

This page was intentionally left blank

.

# **OPTIONS/APPLICATIONS/MODIFICATIONS**

This page was intentionally left blank

Dear Customer,

When using the SYS68K/CABLE MICRO-9 SET 2 (See Section 1, INTRODUCTION; Chapter 4, "Ordering Information"), please adhere to the following connection diagram.



- 1 -

### This page was intentionally left blank

ŕ

-

٩,

.

.