# SPARC CPU-2CE TECHNICAL REFERENCE MANUAL

REVISION NO. A1 JANUARY 1994

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

## NOTICE

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.                                                                                                  | FORCE COMPUTERS GmbH                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 2001 Logic Drive                                                                                                      | ProfMesserschmitt-Str. 1                                                                                      |
| San Jose, CA 95124                                                                                                    | D-85579 Neubiberg/Munich                                                                                      |
| U.S.A.                                                                                                                | Germany                                                                                                       |
| Phone : (408) 371-5900<br>FAX : (408) 371-3382                                                                        | Phone : (089) 608 14-0<br>Telex : 524190 forc-d<br>FAX : (089) 609 77 93                                      |
| FORCE COMPUTERS FRANCE S.A.R.L.<br>Le Volta<br>17-19 rue Jeanne Braconnier<br>F-92366 Meudon La Foret Cedex<br>France | FORCE COMPUTERS (U.K.) Ltd.<br>No. 1 Holly Court<br>3 Tring Road<br>Wendover<br>Buckinghamshire HP<br>England |
| Phone : (1) 41 07 95 15                                                                                               | Phone : (0296) 625456                                                                                         |
| FAX : (1) 45 37 06 19                                                                                                 | Telex : 838033                                                                                                |

FORCE COMPUTERS strives to contribute to the safety and preservation of the environment with the same care it applies to the performance and quality of its products.

FAX : (0296) 624027

To support this effort, this Product Manual has been printed on paper that is completely chlorine free and conservation friendly.

## TABLE OF CONTENTS

## Section 1

| 0 INTRODUCTION                              | 1-1 |
|---------------------------------------------|-----|
| 1.1 The Processor                           | 1-4 |
| 1.2 The Memory Subsystem                    | 1-4 |
|                                             | 1-4 |
|                                             | 1-5 |
|                                             | 1-5 |
|                                             | 1-5 |
| Keyboard/Mouse Port                         | 1-5 |
|                                             | 1-5 |
|                                             | 1-5 |
|                                             | 1-6 |
| 1.7 Small Computer Systems Interface (SCSI) | 1-6 |
|                                             | 1-6 |
|                                             | 1-6 |
| 1.10 SBus Interface                         | 1-7 |
|                                             | 1-7 |
|                                             | 1-7 |
| 1.11.2 Slave Interface                      | 1-8 |
|                                             | 1-8 |
| •                                           | 1-8 |
|                                             | 1-8 |
|                                             | 1-9 |
| 1.14 Sun Tools                              | 1-9 |
| 1.15 Graphical User Interface               | 1-9 |
| 1.16 Real-Time                              | -11 |
| 1.17 Networking                             | -11 |
| 1.18 Determining Revision Level 1           | -13 |
| ection 2                                    |     |
| ISTALLATION and DIAGNOSTICS                 | 2-1 |

|                                                  | 2-1 |
|--------------------------------------------------|-----|
| 2.1 Power Up                                     | 2-2 |
| 2.2 Post Power Up Procedures                     | 2-4 |
| 2.2.1 How to Talk to the CPU-2CE On-Board Memory | 2-4 |
| 2.2.1.1 Memory Test Command One                  | 2-4 |
| 2.2.1.2 Memory Test Command Two                  | 2-4 |
| 2.2.1.3 Memory Test Command Three                | 2-5 |
| 2.2.2 Test the Ethernet Port                     | 2-5 |
| 2.2.3 How to Talk to the SPARC CPU-2CE Buses     | 2-6 |
| 2.2.3.1 Mapping Memory                           | 2-6 |
| 2.2.3.2 Accessing Memory                         | 2-6 |
| 2.2.4 How to Talk to the SBus                    | 2-6 |
|                                                  |     |

| 2.3 Running PROM Diagnostics         | 2-6  |
|--------------------------------------|------|
| 2.4 Running Functional Tests         | 2-7  |
|                                      | 2-7  |
| 2.6 Diagnostics                      | 2-7  |
| 2.6.1 Main Categories of Diagnostics |      |
| 2.6.2 Diagnostic Selections          |      |
| 2.6.3 Boot PROM Diagnostics 2        |      |
| 2.6.3.1 POST 2                       |      |
| 2.6.3.2 On Board Diagnostics         | 2-13 |
| 2.6.4 Sundiag System Exerciser       |      |
| 2.6.5 Monitor and Forth Toolkit      | 2-13 |
| 2.7 SPARC CPU-2CE NVRAM Parameters   | 2-16 |
|                                      |      |

#### Section 3

| HARDWARE                                             |
|------------------------------------------------------|
| 3.1 Card Landmarks                                   |
| 3.1.1 Card Jumpers 3-5                               |
| 3.1.2 Device Space                                   |
| 3.1.3 Control Space 3-12                             |
| 3.1.4 The Memory Map Page 3-15                       |
| 3.1.5 Interrupt Map 3-17                             |
| 3.2 Custom Chips                                     |
| 3.2.1 Cache+                                         |
| 3.2.2 RAM+ 3-18                                      |
| 3.2.3 DMA+ 3-18                                      |
| 3.2.4 MMU+                                           |
| 3.2.5 SPARC CPU-2CE CACHE Controller 3-18            |
| The Cache Controller features:                       |
| The Cache Controller functions:                      |
| Function of Write Through Cache Control              |
| 3.3 SPARC Expansion Connector 3-22                   |
| 3.3.1 Overview                                       |
| 3.3.1.1 Intent of the Expansion Connector            |
| 3.3.2 Reconciling the Differences 3-22               |
| 3.3.2.1 Pa26 3-22                                    |
| 3.3.2.2 Pa25 3-22                                    |
| 3.3.2.3 РОК 3-23                                     |
| 3.3.2.4 Ramclk $N$                                   |
| 3.3.2.5 Ramsel* vs. ramsel1* 3-23                    |
| 3.3.2.6 ParityN vs parcs1*, ramclk1, pa25, and perr* |

| 3.4 | SCSI Int  | erface                                      | 3-24 |
|-----|-----------|---------------------------------------------|------|
|     | 3.4.1     | SCSI Definition                             | 3-24 |
|     | 3.4.2     | SCSI Performance                            | 3-24 |
|     | 3.4.3     | SCSI Addresses                              | 3-25 |
|     | 3.4.4     | SCSI Interrupt                              | 3-25 |
|     | 3.4.5     | Interface Programming                       | 3-26 |
| 3.5 |           | Interface                                   |      |
|     | 3.5.1     | Ethernet Interface Definition               | 3-27 |
|     |           | 3.5.1.1 Ethernet Transmits and Receives     | 3-27 |
|     |           | 3.5.1.2 Ethernet Buffer                     | 3-27 |
|     | 3.5.2     | Ethernet Performance                        | 3-27 |
|     | 3.5.3     | Ethernet Interrupt                          | 3-27 |
|     | 3.5.4     | Ethernet Addresses                          | 3-28 |
|     | 3.5.5     | Ethernet Interface Programming              | 3-28 |
| 3.6 | SBus Int  | erface                                      | 3-31 |
|     | 3.6.1     | Introduction                                | 3-31 |
|     | 3.6.2     | SBus Connections                            | 3-31 |
|     | 3.6.3     | SBus Slot Addresses                         | 3-32 |
|     | 3.6.4     | SBus Slot 0 Devices                         | 3-33 |
|     |           | 3.6.4.1 Card ID                             | 3-33 |
|     |           | 3.6.4.2 DMA Registers                       | 3-34 |
|     |           | DMA Control/Status Register                 | 3-35 |
|     |           | DMA Address Register                        |      |
|     |           | DMA Byte Count Register                     |      |
|     |           | DMA Diagnostic Register                     |      |
|     | 3.6.5     | SBus Slot 1 Devices and Slot 2 Devices      |      |
|     |           | 3.6.5.1 SPARC Assembly Language Example     |      |
|     |           | 3.6.5.2 Forth Example                       |      |
|     |           | 3.6.5.3 C/SunOS Example                     |      |
| 3.7 |           |                                             |      |
|     |           | FEATURES                                    |      |
|     | 3.7.2     | PIN DESCRIPTION                             |      |
|     |           | 3.7.2.1 Sbus Interface                      |      |
|     |           | 3.7.2.2 DRAM Interface                      |      |
|     |           | 3.7.2.3 Power/Ground                        |      |
|     |           | 3.7.2.4 LSI Logic Buffer Naming Conventions |      |
|     | 3.7.3     | SBus INTERFACE                              |      |
|     |           | 3.7.3.1 DRAM Access                         |      |
|     |           | • Word Read                                 |      |
|     |           | • Word Write - Buffered                     |      |
|     |           | • Burst Read                                |      |
|     |           | • Burst Write                               |      |
|     | <b></b> . | 3.7.3.2 Address Mapping                     |      |
|     | 3.7.4     | DETAILED TIMING                             |      |
|     |           | 3.7.4.1 DRAM Timing                         |      |
|     |           | DRAM Errors                                 |      |
|     |           | DRAM                                        | 3-48 |

|                                            | 3-49 |
|--------------------------------------------|------|
| 3.8.1 Features                             | 3-49 |
| 3.8.2 Pin Description                      | 3-50 |
| 3.8.2.1 SBus Interface                     | 3-50 |
| 3.8.2.2 MMU Interface                      | 3-50 |
| 3.8.2.3 Decodes                            | 3-51 |
| 3.8.2.4 Miscellaneous                      | 3-52 |
| 3.8.3 Clock Generation                     | 3-52 |
| 3.8.3.1 General Description                | 3-52 |
| 3.8.3.2 Constant Clock                     | 3-53 |
| 3.8.3.3 Serial Clock                       | 3-53 |
| 3.8.4 Decodes                              | 3-53 |
| 3.8.4.1 Control Space                      | 3-53 |
| • CTL mappings                             | 3-53 |
| Context Register Access                    | 3-54 |
| • SCC Bypass                               | 3-54 |
| • EPROM Bypass                             | 3-54 |
| Segment Map Access                         | 3-55 |
| • Page Map Access                          | 3-56 |
| • Page Type Bits                           | 3-56 |
| 3.8.4.2 Device Space                       | 3-57 |
|                                            | 3-58 |
|                                            | 3-59 |
|                                            | 3-60 |
| SCC/KB Mouse Access                        | 3-60 |
| 3.8.5 Protection Checking                  | 3-61 |
| 3.8.6 Statistics Updates                   | 3-61 |
| -                                          | 3-62 |
| 3.8.8 Counters                             | 3-62 |
| 3.8.9 I/O Register                         | 3-63 |
| 3.9 P2 Bus Interface Overview              | 3-64 |
| 3.9.1 P1/P2 Connector Numbering            | 3-64 |
| 3.10 Serial Interface A and B              | 3-64 |
|                                            | 3-64 |
| 3.10.1.1 RS232/RS423 Jumper Selection      | 3-64 |
| 3.10.2 Serial Interface A/B Definition     | 3-64 |
| 3.10.3 Serial Interface A/B Performance    | 3-64 |
| 3.11 Keyboard/Mouse Interface              | 3-66 |
| 3.11.1 Keyboard/Mouse Device Address       | 3-66 |
| 3.11.2 Keyboard/Mouse Interface Definition | 3-66 |
| 3.11.3 Specifications                      | 3-66 |

#### Section 4

| APPENDICES TO THE HARDWARE USER'S MANUAL | 4-1 |
|------------------------------------------|-----|
| The CPU Card Schematic Diagrams          |     |
| DWG Schematics                           |     |
| Serial Cable Drawing                     |     |
| Ethernet Cable Drawing                   |     |
| Reader Comment Card                      |     |
| Product Error Report                     |     |
| Section 5                                |     |

| ABSTRACT COPIES OF DATA SHEETS |  | 5-1 |
|--------------------------------|--|-----|
|--------------------------------|--|-----|

## Section 6

| PROGRAMMING & FIRMWARE MANUAL                    | 6-1  |
|--------------------------------------------------|------|
| 6.0 Programming                                  | 6-1  |
| 6.1 Address Spaces                               | 6-1  |
| 6.1.1 Control Space                              |      |
| 6.1.2 System Space (ASI = 2)                     | 6-2  |
| 6.1.3 Device Space                               | 6-7  |
| 6.2 Memory Management                            |      |
| 6.2.1 Address Translation                        | 6-13 |
| 6.2.2 Modifying the MMU                          | 6-13 |
| 6.2.3 MMU Protection Criteria                    | 6-13 |
| 6.3 Programming LED's                            | 6-14 |
| 6.3.1 SPARC CPU-2CE LED Programming Example      | 6-15 |
| 6.3.1.1 Example of the ce-misc.h file            | 6-16 |
| 6.4 Additional Forth Commands for LEDs/Hexswitch |      |

| Section | 7 |
|---------|---|
|---------|---|

| VME |                                                | 7-1 |
|-----|------------------------------------------------|-----|
| 7.0 | VMEbus Interface                               | 7-1 |
| 7.1 | Features of the SPARC CPU-2CE VMEbus Interface | 7-1 |
| 7.2 | VMEbus Basics - An Introduction                | 7-3 |
| 7.3 | VME Performance                                | 7-3 |
| 7.4 | VME Addresses                                  | 7-4 |
| 7.5 | VME Implementation                             | 7-5 |

| 7.6 Major VME Register Groups                        | 7-6  |
|------------------------------------------------------|------|
| 7.6.1 Accesses To Byte Registers                     | 7-7  |
| 7.7 Master Interface                                 | 7-8  |
| 7.7.1 A32 Map Register Base Location                 | 7-8  |
| 7.7.2 A32 Map Register Initialization                | 7-8  |
| 7.7.3 VME Registers Programming Example              | 7-10 |
| 7.8 Slave Interface                                  | 7-12 |
| 7.8.1 Slave Transfer Control                         | 7-12 |
| 7.8.2 Slave Map Register                             | 7-12 |
| 7.8.2.1 Slave Map Register Initialization            | 7-13 |
| 7.9 Mail Box                                         | 7-14 |
| 7.9.1 Mail Box Register Base Location                | 7-15 |
| 7.9.1.1 Mail Box Register Initialization             | 7-15 |
| 7.9.1.2 Mail Box Register Interrupt Level            | 7-15 |
| 7.10 Mailbox Interrupt Level - Rerun Length Register | 7-16 |
| 7.11 Bus Locker                                      | 7-17 |
| 7.11.1 VME Bus Locker Register                       | 7-17 |
| 7.11.2 Initialization                                | 7-18 |
| 7.12 Interrupt Handler                               | 7-19 |
| 7.12.1 Interrupt Enable/Bus Arbiter Mode Register    | 7-19 |
| 7.12.1.1 Interrupt Enable Register Initialization    | 7-19 |
| 7.13 Bus Requester                                   | 7-20 |
| 7.13.1 Bus Arbiter                                   | 7-20 |
| 7.14 Bus Time Out Period                             | 7-20 |
| 7.14.1 Rerun Time Out                                | 7-20 |
| 7.14.2 Abort                                         | 7-20 |
| 7.15 VMEbus Watchdog Timer                           | 7-21 |
| 7.16 System Reset and the Reset Switch               | 7-21 |
| 7.16.1 Sources for a System Reset                    | 7-21 |
| "The Power-On Reset"                                 | 7-21 |
| "The Reset Switch"                                   | 7-21 |
| "The Watchdog Reset"                                 | 7-22 |
| "The Software Reset"                                 | 7-22 |
| 7.17 Jumper                                          | 7-22 |
| 7.18 Programmable Register Settings                  | 7-22 |
| 7.19 VME Interrupt Monitor Register                  | 7-23 |
| 7.19.1 Fair Mode Requester                           | 7-23 |
| 7.20 VME IACK Cycles                                 | 7-23 |
| 7.20.1 Daisy Chain IACK Driver                       | 7-24 |
| 7.20.2 Master Cycles                                 | 7-25 |
| 7.20.3 Slave Cycles                                  | 7-25 |
| 7.21 Bus Arbitration                                 | 7-25 |
| 7.22 Interrupts                                      | 7-26 |
| 7.23 Example of a VME System                         |      |
| 7.24 VMEbus Device Driver                            | 7-28 |
| 7.24.1 VMEbus Device Driver System Calls             | 7-28 |

.

| 7.24.2 VMEbus Address Modifiers               | 7-30 |
|-----------------------------------------------|------|
| Program/Data/Block Transfer Address Modifiers | 7-30 |
| Supervisory/Non-Privileged Address Modifiers  | 7-31 |
| Extended/Standard/Short Address Modifiers     | 7-31 |
| 7.24.3 VMEbus Device Driver Limitations       | 7-31 |
| Floppy and Audio Interrupt Conflicts          | 7-31 |
| Potential for SunOS Patches to Conflict       | 7-32 |
| GENERIC.VME versus GENERIC_SMALL.VME          | 7-32 |
| 7.25 VME Programming Examples                 | 7-32 |
| 7.25.1 FORTH Programming Examples             | 7-32 |
| Map the VMEbus to a Virtual Address           | 7-32 |
| Map Local Memory to the VMEbus                | 7-33 |
| Map an SBUS Address to a Virtual Address      | 7-36 |
| 7.25.2 C Programming Example                  | 7-36 |

## Section 8

| ONC/VME |                                          | 8-1 |
|---------|------------------------------------------|-----|
| 8.1     | Capabilities                             | 8-1 |
|         |                                          | 8-1 |
| 8.3     | Booting Over the VMEbus Backplane        | 8-2 |
|         | 8.3.1 Installation Example               | 8-2 |
|         | 8.3.2 Hardware Configuration             | 8-3 |
|         |                                          | 8-3 |
|         | •                                        | 8-3 |
|         | 8.3.4.1 vme-slavemap                     | 8-4 |
|         |                                          | 8-4 |
|         |                                          | 8-4 |
|         | 8.3.4.4 vm-server-addr                   | 8-4 |
|         | 8.3.4.5 vm-ip-addr                       | 8-4 |
|         |                                          | 8-5 |
|         | 8.3.6 Files To Edit on the Server        | 8-5 |
|         | 8.3.6.1 /sys/sun4c/conf/GENERIC.VME      | 8-5 |
|         |                                          | 8-5 |
|         |                                          | 8-5 |
|         |                                          | 8-6 |
|         |                                          | 8-6 |
|         |                                          | 8-6 |
|         |                                          | 8-6 |
|         | 8.3.7.3 /export/root/client-vm/etc/fstab | 8-7 |
|         | 8.3.7.4 /export/root/client-vm/etc/hosts | 8-7 |
|         |                                          | 8-7 |
|         | 8.3.8 System Start-Up                    | 8-7 |
| 8.4     |                                          | 8-7 |
|         |                                          | 8-8 |
| 8.5     |                                          | 8-9 |
|         |                                          |     |

| 8.6 Memory Usage                                                                                                                                                                                                                                                                                                                                     | 8-9                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| 8.6.1 Addressing Scheme                                                                                                                                                                                                                                                                                                                              | 8-9                                                  |
| 8.6.2 ONC/VME Region Layout                                                                                                                                                                                                                                                                                                                          |                                                      |
| 8.6.2.1 Magic Number                                                                                                                                                                                                                                                                                                                                 | 8-11                                                 |
| 8.6.2.2 Packet-Ready Flags                                                                                                                                                                                                                                                                                                                           | 8-11                                                 |
| 8.6.2.3 Host States                                                                                                                                                                                                                                                                                                                                  | 8-11                                                 |
| 8.6.2.4 IP Addresses                                                                                                                                                                                                                                                                                                                                 | 8-11                                                 |
| 8.6.2.5 Valid-Host Flags                                                                                                                                                                                                                                                                                                                             | 8-11                                                 |
| 8.6.2.7 Packet Contents                                                                                                                                                                                                                                                                                                                              | 8-11                                                 |
| 8.7 Protocol Operation                                                                                                                                                                                                                                                                                                                               | 8-11                                                 |
| 8.7.1 Initialization                                                                                                                                                                                                                                                                                                                                 | 8-12                                                 |
| 8.7.1.1 Initializing the Hardware                                                                                                                                                                                                                                                                                                                    | 8-12                                                 |
| 8.7.1.2 Initializing the Local Region                                                                                                                                                                                                                                                                                                                | 8-12                                                 |
| 8.7.1.3 Probing for Remote Hosts                                                                                                                                                                                                                                                                                                                     | 8-12                                                 |
| 8.7.2 Sending a Packet                                                                                                                                                                                                                                                                                                                               | 8-12                                                 |
| 8.7.2.1 Broadcast Packets                                                                                                                                                                                                                                                                                                                            | 8-13                                                 |
| 8.7.3 Receiving a Packet                                                                                                                                                                                                                                                                                                                             | 8-13                                                 |
| 8.7.3.1 Shutting Down                                                                                                                                                                                                                                                                                                                                | 8-14                                                 |
| 8.7.3.2 Error Handling                                                                                                                                                                                                                                                                                                                               | 8-14                                                 |
| OPTIONS AND APPLICATIONS                                                                                                                                                                                                                                                                                                                             | 9-1                                                  |
| GLOSSARY                                                                                                                                                                                                                                                                                                                                             | 10-1                                                 |
| SPARC CPU-2CE Hardware Documentation Glossary                                                                                                                                                                                                                                                                                                        | 10-1                                                 |
| SPARC Reference Materials Available from Sun         Documentation Available Other Places         Suggested Reference Material for the SCSI Interface         Ethernet Interface         Suggested Reference Material for Serial Interface A/B         Suggested Reference Material for Keyboard/Mouse Interface         Suggested Reading for FORTH | 10-1<br>10-1<br>10-2<br>10-2<br>10-2<br>10-2<br>10-3 |
| Section 11                                                                                                                                                                                                                                                                                                                                           |                                                      |
| CPU-2CE OPEN BOOT SUPPLEMENT                                                                                                                                                                                                                                                                                                                         | 11-1                                                 |

## LIST OF TABLES

| Table: 1.1 Board Function & Specification       1                         | -11  |
|---------------------------------------------------------------------------|------|
|                                                                           | 1-13 |
| Table: 2.1 Diagnostic Tools                                               |      |
| Table: 2.2 Diagnostic Switches    2                                       | 2-11 |
| Table: 2.3 Non-Volatile System Configuration Parameter Defaults         2 |      |
| Table: 2.4 NVRAM VME Configuration Parameters         2                   |      |
| Table: 2.5 Front Panel         Front Panel         2                      |      |
| Table: 2.6 CPU-2CE Connectors         2                                   |      |
| Table: 2.7 SCSI Pinout List         2                                     |      |
| Table: 2.8 Ethernet Pinout List    2                                      |      |
| Table: 2.9 Serial Pinout List    2                                        |      |
| Table: 2.10    Audio Connector (Din 8)    2                               |      |
| Table: 2.11    Keyboard/Mouse    Connector    Pinout    List    2         |      |
| Table: 2.12    SBus Connector Pinout    2                                 |      |
| Table: 2.13 P1 Bus Pinout List    2                                       |      |
| Table: 2.14    P2 Bus Pinout List    2                                    |      |
| Table: 2.15 Expansion Connector Electrical Pinout    2                    |      |
| Table: 3.1    Virtual Memory Layout                                       |      |
| Table: 3.2 Address Space Indicator Contents       3                       |      |
|                                                                           | 3-17 |
| Table: 3.4 SBus Bandwidth Estimation       3                              |      |
| Table: 3.5       SCSI Register Addresses       3                          |      |
| Table: 3.6 Ethernet Registers    3                                        |      |
| ▲ · · · · · · · · · · · · · · · · · · ·                                   | 3-31 |
| Table: 3.8 SBus Slot Addresses       3                                    |      |
| Table: 3.9 SBus Slot 0 Addresses    3                                     |      |
| <b>.</b>                                                                  | 3-34 |
| Table: 3.11    Address Ranges    3                                        |      |
| Table: 3.12 DRAM maps physical addresses to SIMM Locations         3      |      |
| Table: 3.13 CTL mappings    3                                             |      |
|                                                                           | 8-56 |
|                                                                           | 3-57 |
|                                                                           | 6-2  |
|                                                                           | 6-3  |
|                                                                           | 6-3  |
|                                                                           | 6-4  |
| Table: 6.5    Synchronous Error Register                                  | 6-4  |
| $\mathbf{v}$                                                              | 6-5  |
| Table: 6.7 Synchronous Error Register                                     | 6-5  |
| Table: 6.8    Synchronous Error Register                                  | 6-5  |
| Table: 6.9    Asynchronous Error Register                                 | 6-6  |
| Table: 6.10    Cache Tags                                                 | 6-6  |
| Table: 6.11   Type One Space                                              | 6-8  |
| Table: 6.12   TOD/NVRAM                                                   | 6-9  |
| Table: 6.13 Counters timers    Counters timers                            | 6-9  |

## LIST OF TABLES "continued"

| Table: 6.14 PError   PError                                         | 6-10 |
|---------------------------------------------------------------------|------|
| Table: 6.15 Type 1 Space for off Board DRAM                         | 6-11 |
| Table: 6.16 Interrupt Control Register                              | 6-11 |
| Table: 6.17 Aux I/O Register                                        | 6-12 |
| Table: 6.18 LED/SW3 Register (Longword access only)                 | 6-14 |
| Table: 7.1 VME Concept Definitions                                  |      |
| Table: 7.2 VME Addresses                                            |      |
| Table: 7.3 VME Address Spaces                                       | 7-5  |
| Table: 7.4 VME Registers                                            |      |
| Table: 7.5 A32 Map Register                                         |      |
| Table: 7.6 A32 Map Register Address Bits                            |      |
| Table: 7.7    A32    Map Register Bit Definitions                   | 7-9  |
| Table: 7.8    Slave Map Register Address                            | 7-13 |
| Table: 7.9    Slave Map Register Address Bits                       |      |
| Table: 7.10       Slave Master Register Bit Definitions             | 7-14 |
| Table: 7.11    Mail Box Register Address                            | 7-15 |
| Table: 7.12    Mail Box Register Address Bits                       | 7-15 |
| Table: 7.13 Mail Box Register Bit Definitions                       | 7-16 |
| Table: 7.14    Bus Locker Register Bit Definitions                  |      |
| Table: 7.15    Interrupt Enable Register Address                    | 7-19 |
| Table: 7.16 Interrupt Enable Register Bit Definitions               | 7-19 |
| Table: 7.17    Slot 1 Jumper & Functions                            | 7-22 |
| Table: 7.18 Programmable Register Settings                          | 7-22 |
| Table: 7.19 VME Interrupt Monitor Register Address                  | 7-23 |
| Table: 7.20 Interrupt Monitor Register Address Definitions          | 7-23 |
| Table: 7.21    Mail Box Register Address                            | 7-24 |
| Table: 7.22       VME IACK Cycles Register Address Bits             | 7-24 |
| Table: 7.23       VME IACK Cycles Interrupt Responses               |      |
| Table: 7.24         Slave Cycles Duration and Theoretical Bandwidth |      |
| Table: 7.25 Bus Arbitration                                         |      |
| Table: 7.26    VME Interrupt Levels and Sources                     |      |
| Table: 7.27    A16 - only    Address    Decode                      |      |
| Table: 7.28    A24 - Only Address Decode                            | 7-31 |
| Table: 7.29    Address Modifier Codes                               | 7-32 |
| Table: 8.1    Example Server Configuration                          | 8-2  |
| Table: 8.2    Example Client Configuration                          | 8-3  |
| Table: 8.3       ONC/VME Region Layout                              | 8-10 |
| Table: 11.1 SPARC Reference Materials Available from Sun            | 11-1 |
| Table: 11.2 Documentation Available Other Places    Other Places    | 11-1 |

.

## LIST OF FIGURES

| Figure: 1.1 Block Diagram                                  | 1-2  |
|------------------------------------------------------------|------|
| Figure: 1.2 Photo Page                                     | 1-3  |
| Figure: 2.1 RS-232/423 Jumper Blocks                       | 2-3  |
| Figure: 2.2 POST                                           | 2-9  |
| Figure: 2.3 Keyboard LED Diagnostic Codes                  |      |
| Figure: 2.4 Font Panel                                     | 2-18 |
| Figure: 2.5 Component Side                                 | 2-19 |
| Figure: 2.6 Solder Side                                    | 2-20 |
| Figure: 2.7 SCSI Connector and Pins (Front View)           |      |
| Figure: 2.8 Ethernet Cable Connector and Pins (Front View) | 2-22 |
| Figure: 2.9 Ethernet Cable                                 |      |
| Figure: 2.10 Serial Cable                                  | 2-25 |
| Figure: 2.11 Audio Connector                               |      |
| Figure: 2.12 Keyboard/Mouse Connector                      | 2-27 |
| Figure: 2.13 Sun Expansion Connector Pin Orientation       |      |
| Figure: 3.1 Shows the Front Panel                          |      |
| Figure: 3.2 Shows the component-side                       |      |
| Figure: 3.3 Shows the solder                               |      |
| Figure: 3.4 RS-232/423 Jumper Blocks                       |      |
| Figure: 3.5 SPARC/CPU-2CE ADDRESS SPACE VIRTUAL            |      |
| Figure: 3.6 Physical Memory Map                            |      |
| Figure: 3.7 Virtual/Physical Memory Map ASI Diagram        |      |
| Figure: 3.8 Type 1 Space (On-Board I/O) (obio)             |      |
| Figure: 3.9 Type 0 Space (Main Memory) (obmem)             |      |
| Figure: 3.10 Safe Decode Circuit                           |      |
| Figure: 3.11 Word Read                                     | 3-43 |
| Figure: 3.12 Word Read 2                                   |      |
| Figure: 3.13 Word Write                                    |      |
| Figure: 3.14 Burst Read                                    |      |
| Figure: 3.15 Burst Write                                   |      |
| Figure: 3.16 Segment Map & Page Map                        |      |
| Figure: 3.17 Internal Register Cycle                       |      |
| Figure: 3.18 Clock Cycle                                   |      |
| Figure: 3.19 SBus or DRAM Access                           |      |
| Figure: 3.20 Scan EPROM Access                             |      |
| Figure: 3.21 2nd EPROM Access                              | 3-59 |
| Figure: 3.22 Parity Register Access                        | 3-60 |
| Figure: 3.23 SCC/KB Mouse Access                           | 3-60 |
| Figure: 3.24 Statistics Updates                            | 3-61 |
| Figure: 3.25 Counter                                       | 3-63 |
| Figure: 3.26 2nd Counter                                   | 3-63 |
| Figure: 3.27 RS-232/423 Jumper Blocks                      | 3-65 |
| Figure: 6.1 Illustration Memory Management                 | 6-12 |
| Figure: 7.1 Sample VME System Diagram                      | 7-28 |
|                                                            | 1-20 |

Section 1

#### **1.0 INTRODUCTION**

A complete VMEbus-based SPARCstation<sup>TM</sup> 2 architecture with Sbus expansion. The SPARC CPU-2CE is the latest innovation resulting from the technology partnership of FORCE COMPUTERS and Sun Microsystems. Combining a true SPARCstation 2 architecture with FORCE COMPUTERS expertise and experience in standard 6U Eurocards has resulted in a faithful SPARCstation 2 implementation in a single VMEbus slot.

The SPARC CPU-2CE<sup>™</sup> offers the same I/O interfaces as the SPARC station 2, including DMA supported SCSI and Ethernet ports along with audio, keyboard/mouse, and two serial channels with full modem support. Two Sbus sockets allow the installation of standard, off-the-shelf Sbus modules such as graphic frame buffers or accelerators or any other of over 300 Sbus cards available from third-party vendors.

Through its binary compatibility with the Sun SPARC station 2 family, the SPARC CPU-2CE runs current versions of SunOS<sup>™</sup>/Solaris<sup>™</sup> as well as the more than 4,000 shrink-wrapped SPARCware<sup>™</sup> applications available today. In addition, a variety of real-time operating systems will be available.

Its IEEE 1014 compatible VMEbus interface enables the SPARC CPU-2CE user to build high-performance embedded UNIX® systems, SPARC®- based real-time systems and hybrid UNIX/real-time systems linked via the VMEbus or local- and/or wide-area networks.

The SPARC CPU-2CE is a compact single board computer that brings the power and functionality of the popular Sun SPARC station 2 to the industry-standard VMEbus for use in UNIX and real-time applications.



#### Figure: 1.1 Block Diagram

#### Figure: 1.2 Photo Page

TURRE LOT STOLES

a Sadar Sirki Capadabb Basusar ARC setatan) 32 GrBASC provem dig tata da a sata - sear te Shefici CE bettike da is maptica af ar imgaart fangar Unit/Poeng Court (Calas - a da a da a taugar Unit/SRAM based Moorry Management Scratche), a Cadar Courtific (Calas - affine) affine Sata daga. Operanty at 40 Marche Courties 23,3 Milla mager performance of the Cal tautang point realizations. The Cooke Courties is provided a 120 Will wave affine to site to self the Scratche mager and cal



#### 1.1 The Processor

A 40-Mhz SPARC (Scalable Processor ARChitecture) 32-bit RISC processor chip set is at the core of the SPARC CPU-2CE. It is comprised of an integrated Integer Unit/Floating Point Unit (IU/FPU), a Sun standard SRAM-based Memory Management Unit (MMU+), a Cache Controller (Cache+) and two Cache RAM chips. Operating at 40 Mhz, the IU/FPU provides 28.5 MIPS integer performance and 4.2 MFLOPS floating point performance. The Cache Controller provides a 2-Kbyte tag array for a 64-Kbyte, virtual, write-through cache.

The integrated CACHE+ Controller Cache/Memory Management Unit (CMMU) handles the cache memory, provides path to main memory over the SBus, handles SBus controller function, and works at 40 MHz clock speed. The SPARC CPU-2CE has two cache RAMs that are 16K x 16 devices and run at 40 MHz clock speed. The large cache and double word write buffer means higher hit ratios and the ability to sustain high I/O DMA bandwidths with only a small reduction in local CPU performance.

#### **1.2 The Memory Subsystem**

The SPARC CPU-2CE chip set includes the RAM+, an Sbus-compatible DRAM controller with single clock burst capability. RAM+ operates the DRAM in fast page mode to support 8-, 16-, 32-, and 64-byte bursts at one transfer per clock after an initial access latency of 4 clocks for reads and 2 clocks for writes. The configuration supports up to 64 Mbytes of 32-bit wide DRAM on board and incorporates parity generation and parity error detection.

The SPARC CPU-2CE is available with 16-, 32-, 48-, or 64-Mbytes of on-board DRAM. 16 Mbytes reside on the base-board and are implemented using high-reliability TSOP devices. Additional capacity, up to 64 Mbytes, is achieved using separate mezzanine modules which retain the single-slot capability without interfering with Sbus expandability on the SPARC CPU-2CE. Memory capacity upgrades are possible since the DRAM mezzanine modules are designed for field installation.

Memory can be expanded beyond the 64-Mbyte on-board limit via an SBus SRX-2 card. This option expands Type0 memory space by up to 64 Mbytes and is cacheable, an advantage over other Sbus-based memory expansion modules.

#### **1.3** System EPROM Open Boot<sup>™</sup>:

The Open Boot<sup>TM</sup> EPROM on the SPARC CPU-2CE is located in a single 32 bit DIP socket that enables easy upgrading. It provides the functionality of the boot device supplied with the SPARCstation 2, with enhancements to support the added features of the SPARC CPU-2CE (VMEbus interface and optional Flash EEPROM).

There is an EPROM-based monitor/debugger called Open Boot<sup>™</sup>. Open Boot is a trademark by Sun.

#### **1.4 FLASH EEPROM (Optional Feature)**

In addition to the boot device, the SPARC CPU-2CE employs 4 FLASH EEPROMs in TSOP packages for flexibility and customization. This 1-Mbyte FLASH EEPROM is organized to be 32-bits wide and is mapped in place of the Sun SPARC station 2 Sbus Slot 3.

These EEPROMs are erasable and writable by the user and allow the system integrator to incorporate FCODE drivers for system specific VME-based products using routines supplied in the boot ROM. With 150 ns EEPROMs, the access time is 4 clocks.

The SPARC CPU-2CE allows integrators to specify their product as the console or boot device without having to modify the on-board firmware. It also allows them to take advantage of SunOS loadable drivers for their VME products. This feature provides a path to firmware-assisted system auto-configuration.

#### 1.5 Local I/O

Ethernet, SCSI interfaces, two serial interface ports, a keyboard specific serial port, a mouse specific serial port, a floppy disk controller, and an audio input / output port are provided.

#### Serial Interface Ports

The Zilog Z85C30 Serial Communications Controller (SCC) supports two serial interface ports using 26-pin connectors on the front panel for synchronous and asynchronous communications. Data rates up to 64 Kbaud are supported and are user configurable, with a pluggable shunt for either RS-232C or RS-423C, and offer full modem control and interrupt capability. Both ports must be set identical as either RS-232 or RS-423.

#### Keyboard/Mouse Port

The connector for the keyboard/mouse port uses a SPARCstation Type 2 8-pin Mini-circular DIN connector on the front panel. The Z85C30 SCC for the keyboard/mouse specific port is terminated with TTL buffers and uses all TTL-compatible data signals. The interface is fully compatible with Sun SPARCstation 2 keyboard and mouse product offerings and uses the same cables.

#### Floppy Disk Controller

An Intel i82072 functions as the floppy disk controller and is fully compatible with the Sun SPARCstation 2. The floppy disk controller signals are available on the User I/O lines of the P2 connector.

#### Audio Port

The audio interface is implemented with an AMD Am79CA30 ISDN/audio controller device and is fully compatible with the Sun SPARCstation 2. The audio connector on the front panel is an 8-pin Mini-circular DIN connector. As in the SPARCstation 2, the ISDN functionality of the Am79CA30 is not implemented.

#### 1.6 DMA+

The DMA ASIC provides DMA and data assembly-disassembly functions for both the Ethernet and SCSI interfaces. The ASIC contains a 32 byte FIFO for each interface and performs DMA in 16 byte bursts when alignment and transfer length permit.

#### 1.7 Small Computer Systems Interface (SCSI)

The SCSI interface provides a standard interface to a wide variety of mass storage devices, such as hard disks, tapes, and CD-ROMs.

The SPARC CPU-2CE board features a Small Computer System Interface (SCSI) controller device using the NCR 53C90A controller chip augmented by the DMA+(D-channel). This provides SCSI-I functionality and can transfer at up to 5 Mbytes/sec, depending on the speed of the target.

The SCSI controller on the SPARC CPU-2CE acts as a SCSI initiator. Up to seven SCSI target devices can be connected to a SPARC CPU-2CE board. The SCSI bus is properly buffered and terminated on the SPARC CPU-2CE, so that the connection of SCSI devices is simple and straight forward. Just attach a terminated SCSI device with a cable and the CPU-2CE will automatically adjust for proper termination.

The DMA features full SCSI specification, ANSI X3.131/1986, compatibility. It supports both synchronous and asychronous operation with SCSIbus signals connected to the front panel connector and VMEbus P2 connector. Single ended mode is supported only.

The SCSI bus is routed to both the front panel, via a 50-pin SCSI-II connector, and to the board's P2 User I/O pins.

#### **1.8 Ethernet Interface**

The Ethernet interface is comprised of the DMA+ interface chip for DMA, the AMD Am7990 Local Area Network Controller (LANCE) chip and the AMD Am7992B Serial Interface Adapter (SIA). The IEEE 802.3 Ethernet interface is available via a 15-pin Micro-D connector on the front panel. An adapter cable for the Micro-D to the regular DB15 is available. The DMA+ chip contains a 32-byte FIFO and increases performance through its 16-byte DMA burst capability.

The Ethernet interface features compatibility to the IEEE 802.3 Ethernet specification, DMA burst capability, data rate of up to 10 Mbit/sec, interrupt generation (Level 6), and utilization of up to 128 Kbytes of memory.

#### 1.9 Real-Time Clock/NVRAM

The SPARC CPU-2CE board uses the Mostek MK48T08 RTC-NVRAM chip. This device includes an 8-Kbyte non-volatile static RAM, of which 2 Kbyte is user programmable, and a clock/calendar circuit. Both are supported by a 10-year shelf-life lithium battery, in order to retain data when the board is powered down.

#### 1.10 SBus Interface

The SBus is a high performance CMOS bus and the basic interconnection mechanism for the system between the CPU and main memory and I/O devices. Two Sbus connectors are available for I/O expansion into the next VME slot.

The Sbus is a high-performance expansion bus with a bandwidth of over 50 Mbytes/sec. The Sbus forms the local memory and I/O bus for the SPARC CPU-2CE and features 32-bit virtual addressing, 28-bit physical addressing, 32-bit data path, synchronous data transfer and master/slave capability. The SPARC CPU-2CE incorporates two Sbus sockets for I/O expansion. These provide support and compatibility with the hundreds of third-party Sbus expansion products on the market, including products for video and graphics, connectivity and networking, manufacturing and process control, engineering, and scientific instrumentation.

FORCE offers a 6U VMEbus Front Panel with two SBus board cutouts used to mount SBus boards to the CPU-2CE.

#### 1.11 VMEbus Interface

The SPARC CPU-2CE utilizes the Sun VME Chip to provide a complete 32-bit VMEbus interface. Since this is the same device used on the SPARC CPU-1E from FORCE COMPUTERS system performance upgrades with minimal software changes are guaranteed. Supported functions include master and slave data transfer capabilities, and VMEbus interrupt handling and arbitration functions. Additional VMEbus utility functions and a special loop-back cycle for standalone testing of the interface are provided.

The VMEbus interface on the SPARC CPU-2CE is fully supported by a driver for the SunOS/Solaris operating system. The software support also includes an implementation of the ONC/VME protocol which supports standard networking protocols such as TCP/IP, NFS and RPCs across the VMEbus backplane. The VME Driver is needed to implement VME software.

#### 1.11.1 Master Interface

The VMEbus master interface allows 16-, 24-, and 32-bit addressing with 8-, 16-, and 32-bit data transfers. A full 4-GByte address range is available and may be mapped contiguously without the 512-Mbyte limitation typically imposed by the 28-bit Sbus definition. This is done by directing normally unused MMU signals to VMEbus decoding logic, external to the VME chip. A software switch enables the standard VME 512-Mbyte address mode with window mapping registers. This 28-bit mode emulates the SPARC CPU-1E VMEbus addressing scheme, allowing customers a migration path to help preserve a previous investment in custom VMEbus drivers.

Read-modify-write cycles are supported for master accesses, and a 300 µsec VMEbus timer is included.

NOTE: Unaligned transfers are not supported by the VME chip.

#### 1.11.2 Slave Interface

Access to the on-board DRAM is allowed to a 1-Mbyte page configurable on 1-Mbyte boundaries within the local address space. Addressing is recognized for both 32- and 24-bit standard accesses, with 16-bit accesses reserved for the mail box interrupt. Address modifiers are supported, and any slave access as a Direct Virtual Memory Access (DVMA) device is set to the local supervisor mode in accordance with the Sun-4<sup>TM</sup> architecture. The 1-Mbyte VME address space selected is always mapped to the highest megabyte in the virtual address space in accordance with the Sun-4 architecture. Unaligned slave accesses are not supported by the VME chip. See the chapter on the VMEbus Interface for more details.

A mail box interrupt function allows other VMEbus devices to interrupt the SPARC CPU-2CE. This mail box detects accesses to the specific A16 address space set in the mail box register. Mail box accesses are acknowledged as standard VMEbus cycles, and trigger an on-board level 13 interrupt.

#### 1.11.3 Interrupts

The on-board interrupt handler selectively supports all seven VMEbus interrupt levels which are routed directly to the MMU interrupt logic. Control of interrupts is handled via software in the interrupt enable register.

#### 1.11.4 System Controller

The SPARC CPU-2CE is capable of providing Slot 1 system controller functions. The VMEbus requestor is a release on request (ROR) requestor. Bus requests are made on BR3.

The VMEbus arbiter function is used when the SPARC CPU-2CE is configured for system controller functions (Slot 1 jumper). Both single-level (SGL) and round robin (RRS) arbitration are provided. Bus timer logic is included to prevent a VMEbus lockup to a non-responding bus requestor or to a non-existent slave device.

Additional system controller functions are automatically activated, when the Slot 1 jumper is enabled. These capabilities include: IACK Daisy Chain Driver, SYSRESET, SYSFAIL and VMEbus system clock.

#### 1.12 Software Description

With full SPARCstation 2 architecture compatibility, the SPARC CPU-2CE runs the Solaris operating system, including enhancements specific to the a SPARCstation product line. Solaris provides an advanced development and run-time environment for the SPARC CPU-2CE. As the first "shrink-wrapped" distributed computing solution, Solaris is comprised of SunOS, ONC© networking environments, OpenWindows<sup>TM</sup>, OPEN LOOK® and DeskSet<sup>TM</sup>. SunOS is the highest quality and most widely supported enriched UNIX implementation available today.

By carefully merging the most robust functionality of UNIX System V<sup>TM</sup>, Berkeley BSD<sup>TM</sup>, and Xenix<sup>TM</sup>; SunOS offers the optimum balance of UNIX capability, reliability, and performance. Further functionality includes:

- Standards Conformance (POSIX, X/Open, XPG, SVID and FIPS)
- The OpenWindows "Look and Feel" Graphical User Interface

• Hierarchical and consistent format file system that includes support for MS-DOS®, CD-ROM and RFS, among others

- ONC networking environment for distributed computing across multivendor networks
- Enhanced UNIX kernel with internationalization, system accounting, security and redundancy

• A comprehensive range of third-party software that include databases, design automation and artificial intelligence

• VMEbus driver configured for Sun-4/SPARCserver<sup>™</sup> type expansion interface allowing the use of existing Sun-compatible VMEbus device drivers

ONC is the industry standard for heterogeneous networking. OpenWindows is the network-extensible graphical application development platform. OPEN LOOK is an intuitive graphical user interface, and Deskset is a suite of personal and workgroup productivity applications.

#### 1.13 Development

By using the SPARC CPU-2CE as both the development and the target system, equipment costs and time-to-market can be reduced. Solaris on the SPARC CPU-2CE provides all the tools necessary to take a project from conception through delivery. This includes: project planning aids (e.g. mail, diary, print facilities, etc.); design aids (e.g. compilers, assemblers, debuggers, and libraries); test facilities (e.g. compliance checkers, performance monitors, profilers, and system diagnostics); documentation tools (e.g. text formatters, print filters, and PostScript® interfaces); archiving and maintenance (e.g. source-code control systems, archivers, and backup systems); and others.

Optimizing compilers available from Sun include: C, C++, FORTRAN-77, Pascal, Modula-2, and Common Lisp. Independent software developers furnish many other languages, including Ada, APL, BASIC, COBOL, Forth, Mainsail, PL/I, and Prolog. Sun languages have full access to systems, graphics, networking, and user interface packages. Third-party cross compilers allow C, FORTRAN, or Pascal programmers to produce executable binary code for multiple architectures from a single FORCE SPARC CPU-2CE.

#### 1.14 Sun Tools

Standard software provided with Solaris includes a powerful user interface. This allows access to Solaris resource management functions, as well as industry- standard UNIX editors, command shells, and all UNIX commands for file management and manipulation, system administration, I/O system control, and other software development tools.

#### 1.15 Graphical User Interface

OpenWindows is a full-featured windowing environment based on the X-Window Standard and the Network extensible Windowing System (NeWS<sup>TM</sup>). OPEN LOOK is a graphical user interface that uses X-Windows and NeWS to provide an intuitive, "look and feel" desktop. The DeskSet is a group of personal productivity tools and system service applications which includes a File Manager, Calendar, Debugger, Mailer, and others.

#### 1.16 Real-Time

The SPARC CPU-2CE with Solaris, which supports a wide range of VMEbus and SBus-based hardware and software solutions, creates an ideal embedded system. New releases of Solaris will provide the SPARC CPU-2CE with real-time extension for use in "soft" real-time applications. These extensions include: fixed priority processes, priority manipulation, pre-emptive scheduling, process priority inheritance, guaranteed dispatch latency and memory locking.

Several hard real-time operating systems are available for or are being ported to the SPARC CPU-2CE. These typically provide high-speed multi-tasking, pre-emptive scheduling, and fast interrupt response. They include facilities for intertask communications and synchronization, efficient memory management, system clock and timing, optimized floating point support, and high-performance I/O and file systems. Real-time development tools usually include an interactive debug Shell, a linking loader, symbolic debugger, performance monitor, exception and signal handling, libraries, utility routines, extensive system and task information utilities, and source level debuggers.

#### 1.17 Networking

ONC networking environment is a suite of software modules and services that are the de facto standard for distributed computing. FORCE COMPUTERS provides a VMEbus driver utility as a standard item in conjunction with the Solaris operating system. This driver combines the standard Sun-4 SPARCserver treatment of the VMEbus expansion interface with the additional capability to run ONC over the VMEbus backplane. This provides an optimal platform for both tightly coupled networking and distributed processing applications, as well as the ability to utilize existing drivers for add-in VMEbus peripheral controllers.

The Remote Procedure Call (RPC) is the core of ONC and is used to build services such as the Network File System (NFS<sup>TM</sup>), Network Information Service (NIS) and Network System Boot.

Solaris also supports an extensive set of networking tools that allow developers to take advantage of industry standards. Solaris supports internet protocols, including raw (IP), datagram (UDP/IP) and stream (TCP/IP). User-accessible interfaces allow development of custom interfaces and protocols. Sun will also offer a Solaris Serial Line Internet Protocol (SLIP) for serial line\_based wide-area networks (WANs).

Optional software provides support for: DECnet; SNA, including IBM's Advanced Program-to-Program Communications (APPC) and Document Interchange Architecture (DIA); OSI support which adheres to MAP 2.1 and TOP 1.0 specifications, Layers 1 through 7 for MAP applications; FTAM (File Transfer Access and Management); and CASE (Common Application Services Elements).

| Central Processing Unit              | SPARC RISC                                 |
|--------------------------------------|--------------------------------------------|
| Clock Frequency                      | 40 MHz                                     |
| Integer Performance                  | 28.5 MIPS                                  |
| Floating Point                       | 4.2 MFLOPS @ 40 MHz Double Precision       |
| Block Transfer DMA                   | 50 Mbytes/sec (80 Mbyte/sec peak)          |
| Cache: Data & Instruction            | 64 Kbytes                                  |
| Basic DRAM TSOP Capacity             | 16 Mbytes                                  |
| Error Detection                      | Byte Parity                                |
| Local DRAM Expansion (Single Slot)   | 16, 32, 48 via mezzanine                   |
| Maximum On-Board DRAM                | 64 Mbytes                                  |
| SRAM (Battery Backed Up)             | 8 Kbytes                                   |
| MMU                                  | Sun-4 MMU ASIC                             |
| SBus Expansion                       | 2 Slots                                    |
| VMEbus                               | 32-bit IEEE/ANSI-standard                  |
| VMEBus Master                        | A32, A24, A16: D8, D16, D32, RMW           |
| VMEBus Slave                         | A32, A24: D8, D16, D32, RMW, BLT           |
| VMEBus Interrupt Handler             | 1 through 7 (Selectable)                   |
| VMEBus Arbiter                       | 4 level SGL                                |
| Multiprocessor Mailbox               | Yes (A16 access)                           |
| Ethernet (IEEE 802.3)                | 7990 Lance, AMD 7992B SIA                  |
| Ethernet Transfer Rate               | 10 Mbits/sec                               |
| SCSI Controller                      | NCR 53C90A and DMA+                        |
| SCSI Transfer Rate                   | ASYC 1.5 Mbyte/sec, SYNC up to 5 Mbyte/sec |
| Serial Ports                         | 2 Async/Sync; RS-232-C/RS-423              |
| Serial Data Rates                    | 64 Kbaud                                   |
| NVRAM TOD Clock/Calendar             | MK 48T08                                   |
| EPROM Size                           | 2 Mbyte, 8-bit wide                        |
| FLASH EEPROM Size (Optional Feature) | 1 Mbyte, 32-bit wide                       |
| Reset Switch                         | Yes                                        |
| Abort Switch                         | Yes                                        |

| Table: 1.1 | Board | Function | & | Specification |
|------------|-------|----------|---|---------------|
|------------|-------|----------|---|---------------|

| Hex Rotary Switch, switch input port        | 1                                |
|---------------------------------------------|----------------------------------|
| LEDs                                        | 2 (bi-color Red/Green)           |
| Programmable Timers                         | 2                                |
| Watchdog                                    | Yes                              |
| Keyboard/Mouse Port                         | Sun-4 Standard                   |
| Floppy Disk Controller                      | Intel 82072                      |
| Audio Controller                            | AMD 79C30                        |
| CD ROM Support                              | Yes                              |
| Front Panel                                 | Yes                              |
| Power Requirements + 5V                     | 4 Amps (W/O Optional SBus Cards) |
| +12 V                                       | 0.1 Amp /max .6 Amp              |
| -12 V                                       | 0.1 Amp /max 0.2 Amp             |
| 2A Minifuse                                 | Schurter P/N 3402.0012.xx        |
| 630ma Minifuse                              | Schurter P/N 3402.0008.xx        |
| Number of VME Slots Used                    | 1                                |
| Board                                       | 14 Layers                        |
| Board Dimensions                            | 6.29" X 9.18" (160 x 233 mm)     |
| SunOS or UNIX <sup>™</sup> Operating System | Solaris                          |

See the ordering information table on the next page for adapters available from FORCE. Contact your local sales office for additional options.

| Tape Drive   | Archive 2150s    | 1/2" cartridge drive      |
|--------------|------------------|---------------------------|
| Tape Drive   | Exabyte 8200     | 8mm cartridge 2.5 GB      |
| Tape Drive   | Exabyte 8500     | 8mm cartridge 5 GB***     |
| Floppy Drive | Sony F17W-FP     | 3 1/2" 1.44 MB            |
| Hard Drive   | Maxtor LXT-213SY | 210 MB 3 1/2 inch SUN 207 |
| Hard Drive   | Segate ST1480N   | 424 MB 3 1/2 inch SUN424* |
| Hard Drive   | SEgate ST4766N   | 669 MB 5 1/4 inch SUN669  |
| Hard Drive   | Segate ST41200N  | 1.GB 5 1/4 inch SUN1.0G** |
| Hard Drive   | Segate ST41600N  | 1.3 GB SUN1.3G*           |
| CDROM        | Sony CDU-8012    |                           |

#### Table: 1.2 Compatible Peripherals

\* Not in SUNOS 4.1e

**\*\*** Not in SUNOS 4.1.1b

\*\*\* Only Supported in SUNOS 4.12

## 1.18 Determining Revision Level

You can determine the revision code and serial number of a SPARC CPU-2CE by inspecting the label attached to the P1 connector of each card.

#### Section 2

#### **INSTALLATION and DIAGNOSTICS**

## WARNING

TO AVOID MALFUNCTIONS AND COMPONENT DAMAGE, PLEASE READ THE COMPLETE INSTALLATION PROCEDURE BEFORE THE BOARD IS INSTALLED IN A SYSTEM ENVIRONMENT.

# **STATIC KILLS**

#### 2.1 Power Up

This chapter will cover the instructions and considerations for powering up to insure proper operation of the CPU-2CE.

The only mechanical jumper blocks for the CPU-2CE are to configure the serial ports and to configure the VME. The serial ports are RS-232-C or RS-423 with the default being RS-232-C. If RS-423 is needed, set the block before power up. Move the jumpers position to set RS-423. Both ports must be set identical as either RS-232 or RS-423. The VME default is VME slot 1 device with the jumper installed in JMP1. Removing Jumper 1 selects the card to be non-slot 1 VME device. VME backplane must be terminated according to spec.

#### **Backplane Slot Configuration Requirements**

The SPARC CPU-2CE can be plugged into any VMEbus slot. If a SPARC CPU-2CE is installed in a slot other than 1 with empty slots between it and the slot 1 controller. Each of the empty slots must be configured as described below. See your backplane manual for documentation on the location of these jumpers.

Jumper IACKIN\* to IACKOUT\* on the backplane:

Pins A21 and A22 on the backplane must be jumpered together.

The signals Bus Grant [0:3] must be jumpered across empty slots, as follows:

BGO: jumper pins 4 and 5 Row B

BG1: jumper pins 6 and 7 Row B

BG2: jumper pins 8 and 9 Row B

BG3: jumpered pins 10 and 11 Row B

The CPU-2CE can power up without a computer terminal and keyboard, but you cannot enter the appropriate commands to test the card without a means to enter commands and view the results. FORCE recommends the initial power up to be performed with a computer terminal connected to serial port A of the CPU-2CE. By using the computer terminal, additional possible error producing factors; a nonfunctioning SBus card, SBus frame buffer ca. connector, or monitor can be detected. Connecting a terminal is simpler than connecting a frame buffer, monitor, and keyboard. The optional serial cable is available by ordering the accessories kit.

NOTE: Make sure you use a terminal type serial cable. See your terminal manual for ordering or building the proper cable.

The power-up sequence consists of a series of component functional tests and initialization, followed by booting. Turn on the power to the backplane.

In the default autoboot mode, the SPARC CPU-2CE attempts to boot SunOS from an attached SCSI disk. If a disk is not attached, the Open PROM displays an identification banner and enters the command mode of the "PROM Monitor" (a program that monitors the activity of the keyboard). The PROM displays a > prompt.





#### 2.2 Post Power Up Procedures

#### 2.2.1 How to Talk to the SPARC CPU-2CE On-Board Memory

At the > prompt type n to enter "New Mode" the FORTH/OpenBoot interpreter.

FORTH displays the ok prompt. Basic Assembly PROM commands are available to the SPARC CPU-2CE in this interpreter. Enter the following command at the OK prompt.

0 obmem 0 map-page <cr> to map in the first 4K bytes of main memory.

There is at least 16MB of onboard memory available to the SPARC CPU-2CE card. The first test of the SPARC CPU-2CE PROM validates correct operation of this memory. Use one of the three commands explained below:

#### 2.2.1.1 Memory Test Command One

Perform a LOOP/READ that validates that the on-board memory is functional:

At the ok prompt type 100 50 dump <cr>

RESULTS: If the PROM and the on-board memory are functional, the contents of the 80 bytes (50 hex) of memory starting at address 100 (hex) are displayed. If the PROM or the on-board memory is not working, you receive one of a number of possible error messages indicating a problem with the memory.

#### 2.2.1.2 Memory Test Command Two

Perform a LOOP/WRITE that writes a number pattern to memory, validating memory and memory response:

At the ok prompt type 100 50 78 fill <cr>

RESULTS: If the SPARC CPU-2CE is working correctly, the number pattern "78" is written to 80 bytes of memory starting at address 100, and you will receive the ok prompt. The fill command fills byte by byte. If the PROM or the on-board memory is not working correctly, you receive one of a number of possible error messages indicating a problem.

#### 2.2.1.3 Memory Test Command Three

Perform a memory test that exercises the on-board memory. This test does not reside in the PROM, and must be keyed in at the FORTH prompt. (Memory must be mapped according to section 2.2.1)

Key in the following program:

;

```
: memory-test ( -- )
150 100 do
                                          \from 0x100 to 0x150
                                          \longword write
       12345678
                 i 1!
                                          \longword read (result left
       i 10 dup
                                          \on stack)
                                          \compare
       12345678 <>
       if ." obs = "
          ." exp = " 12345678.
          ." adr = " i . cr
       then
       drop
     4 +loop
```

When this code has been correctly entered, you can perform the memory test:

memory-test <cr>

Also, the following command runs the Open Boot memory test:

test /memory or test-memory

This test is the same as the Open Boot POST test and will take approximately 4 minutes for 32 megabytes.

RESULTS: If the SPARC CPU-2CE is working correctly, the memory is erased and tested, and you will receive the ok prompt. If the PROM or the on-board memory is not working correctly, you receive one of a number of possible error messages indicating a problem.

Connect the cables for the additional devices you wish to test with the SPARC CPU-2CE: SCSI, Keyboard, Ethernet, Serial Ports A and B. (Make sure the power is off before connecting any cables to the CPU-2CE.)

#### 2.2.2 Test the Ethernet Port

Test the Ethernet port by connecting a MAU (Medium Access Unit) to the Ethernet port and while in Forth/OpenBoot and typing:

test net <net>

FORCE COMPUTERS

## 2.2.3 How to Talk to the SPARC CPU-2CE Buses

Access to the devices available on the SPARC buses in general requires mapping, reading, and writing the device. This test is performed only when testing an SBus memory card. The procedure below can be used to map in memory. Devices are mapped in two stages:

## 2.2.3.1 Mapping Memory

Select unused segments, virtual address range and size. Map in the segments, e.g., seg# = 0x80, va = 0x1000000, size = 0x4000.

## 80 1000000 0x4000 map-segments <cr>

Select a physical address range and space (SBus Slot2). Map in the page e.g., pa = 0xFC000000, space = SBus.

FC000000 sbus 1000000 4000 map-pages <cr>

## 2.2.3.2 Accessing Memory

To dump out memory at the ok prompt type 1000 000 50 Dump <cr>

## 2.2.4 How to Talk to the SBus

SBus devices are handled using the IDPROM onboard the SBus card. The IDPROM contains a driver for the SBus card which is read at boot time and interpreted by the Open PROM. During debug of an SBus device or it's driver a device in an SBus slot may be mapped in using map-sbus. (See the Open **PROM Toolkit User's Manual** for a description of the map-sbus).

#### 2.3 Running PROM Diagnostics

Setting the diagnostic switch and resetting the card will cause the card to come-up into the extended selftests.

# CAUTION: This command disables the monitor and keyboard and enables Serial Interface A as the I/O device.

type: setenv diag-switch? true <cr>

reset type: reset or lift the reset switch on the front panel. The board will exit automatically.

NOTE: You must have a tty device attached to Serial Port A. Setting the diag-switch to true puts messages to the serial port A console.

#### 2.4 Running Functional Tests

The following tests are available for testing functional units on the CPU-2CE. These tests are automatically run at a reset or a power-up.

The functional test can be run individually by leaving the PROM monitor and entering the FORTH/OpenBoot interpreter.

At the > prompt, enter n.

At the ok prompt, enter one of the following commands.

test /memory or test-memory test /sbus/le test net test floppy (requires floppy drive and Sun formatted FD formatted disk) watch-clock probe-scsi

NOTE: For a complete listing of diagnostics available from the PROM, type help diag or help test

#### 2.5 Returning To Monitor Mode

To return to the > prompt from the OK prompt, enter the following:

ok old-mode <CR>

#### 2.6 Diagnostics

This chapter describes the different types of diagnostic firmware and software tools available and how they are related.

#### 2.6.1 Main Categories of Diagnostics

 Boot PROM diagnostics Power-On Self-Test On-Board Diagnostics

Sundiag System Exerciser (SunOS)

This chapter will also briefly cover the Forth/OpenBoot Toolkit, which is an interactive command interpreter based on the Forth programming language. Additional information on the Sun Forth Toolkit can be found in the Open Boot PROM 2.0 Toolkit User's Guide in the SBus Developers Kit.

## 2.6.2 Diagnostic Selections

| Diagnostic Tool              | When to use                                                                                                                                                                                                                                                                                                                         |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power On Self Test<br>(POST) | The POST code resides in the boot PROM and is driven automatically by<br>a signal from the power supply when first powered on. The CPU<br>performs the self-test. POST shows if there is a failure of the main<br>components on the main logic board.                                                                               |
| On Board Diagnostics         | Individual test, ie memory, Ethernet, etc., available when in Forth<br>Toolkit. Enter n from the > prompt to enter the Forth Toolkit. The on<br>board diagnostics reside in the boot PROM.                                                                                                                                          |
| Sundiag System<br>Exerciser  | Using SunOS, it displays realtime use of system resources and peripherals. Sundiag will show if your system is functioning properly. If Sundiag fails, run the Power On Self Test.                                                                                                                                                  |
| Monitor                      | Monitor will be activated when the system crashes. Monitor is the > prompt. Typing $b$ boots, $c$ resumes or continues program halted, or $n$ to enter Forth Toolkit.                                                                                                                                                               |
| Forth Toolkit                | Performs all functions available through the Monitor, except entering the<br>Forth Toolkit i.e. changing the NVRAM parameters, resetting the system,<br>running diagnostics, displaying system information, redirecting input and<br>output, etc. There is more in this chapter and the Open Boot PROM 2.0<br>Toolkit User's Guide. |

Table: 2.1 Diagnostic Tools

# Figure: 2.2 POST



# FIGURE 2.3 Power On Self Test Flow Chart

The Forth Toolkit offers an extensive set of functions for performing the following:

- Hardware Development
- Problem Determination (fault isolation)
- Software Development
- Debugging

This section will detail how various diagnostic tools work together in different power on modes.

NOTE: A terminal is needed to view these test results.

CAUTION- To run the On-Board Diagnostics the system must be halted. When the operating system or application has been booted, do not use the L1-A keys to halt the system. L1-A abruptly halts the system and may damage data files. As root halt the system by entering /usr/etc/shutdown or /etc/fasthalt.

- When the power is turned on, the lower level Power On Self Test (POST) code is executed from the Boot PROM.
- If failure occurs in POST, the type 4 keyboard LEDs will display the failure code. See The Power On Self Test in this section for more detailed information.
- If the POST passes, the system probes for SBus devices and interprets their drivers.
- High level test are performed next.
- Specialized diagnostic test can be performed after the high level test by activating the Monitor, indicated by the > prompt. The monitor is activated by pressing the L1 and A keys simultaneously and waiting for the > prompt.
- If the autoboot switch parameter is set to false (not the default) the > or ok prompt will show.

The monitor with its prompt > is the default. It is possible to change the default to the Forth Toolkit with its prompt ok as an option, see the Open Boot PROM 2.0 Toolkit User's Guide.

• If the autoboot switch parameter is set to true (default), and the diagnostic switch parameter is set to false (default), SunOS boots from the default SCSI target 3 boot path:

#### /sbus/esp/sd@3,0

If the hard disk address is set to 0, then the boot parameter should be set to /sbus/esp/sd@0,0.

• For normal booting boot /sbus/esp will automatically find and boot the disk.

• If the autoboot switch parameter is set to true (default), and the diagnostics switch parameter is set to true (not the default), SunOS boots from the bootpath:

/sbus/le

• To boot user-specified programs, such as the SunDiagnostic Executive, you must be at the > or ok prompt. On Board Diagnostics section later in this chapter will detail how to obtain the > and ok prompts with fasthalt.

| Autoboot<br>Switch<br>Parameter | Diagnostic<br>Switch<br>Parameter | Result                                                      |
|---------------------------------|-----------------------------------|-------------------------------------------------------------|
| False                           | (Don't care)                      | > or ok prompt                                              |
| Ттие                            | False                             | boot SunOS (vmunix)<br>from SCSI ID 3<br>(/sbus/esp/sd@3,0) |
| Тгие                            | True                              | boot SunOs (vmunix) from<br>network*(/sbus/le)              |

\* The boot parameters represented here are default settings. The defaults may be changed by following the procedures listed in the Open Boot PROM 2.0 Toolkit User's Guide.

#### 2.6.3 Boot PROM Diagnostics

The diagnostics contained in the boot PROM include the following:

Power-On Self-Test

**On-Board Diagnostics** 

## 2.6.3.1 POST

The Power On Self Test (POST) is the default mode. The POST consist of a sequence of test designed to test the major hardware components of the main logic board before SunOS is booted. Only major failures can be detected by POST. For additional more thorough diagnostics run the extended on-board diagnostics for items including Memory, Ethernet, diskette drives, etc.

# Figure: 2.3 Keyboard LED Diagnostic Codes



# Sun4 Keyboard LED Diagnostic Code

| LED Display Pattern | Unit         | Meaning of Pattern                              |
|---------------------|--------------|-------------------------------------------------|
|                     |              | Unassigned. Testing completed, SunOS is booted. |
|                     | Boot<br>PROM | Bad checksum in boot PROM.                      |
|                     | NVRAM/TOD    | NVRAM/Time-of-Day Clock failed.                 |
|                     | SPARC 2      | SPARC 2 component failed.                       |

#### 2.6.3.2 On Board Diagnostics

- 1. Save all your work and quite all applications
- 2. As root, halt the system by entering

#### /usr/etc/fasthalt

The returning prompt will either be a default prompt > or the prompt ok. To change the prompt see the Open Boot PROM 2.0 Toolkit User's Guide.

If you see the > prompt, go to the next step. If you see the ok prompt go to step 4.

3. Enter n to enter the Forth/OpenBoot Toolkit.

The ok prompt signifies the Forth Toolkit mode.

- 4. Enter help diag to get a listing of on-board diagnostic test.
- 5. To return to the monitor > prompt, type the following command

old-mode

#### 2.6.4 Sundiag System Exerciser

The Sundiag System exerciser verifies that the system is functioning properly. Sundiag runs under SunOs and displays real-time use of system resources and peripheral equipment such as Desktop Storage Packs and External Storage Modules.

Exerciser is shipped with SunOS. If it was selected during SunInstall (operating system loading) procedure, it can be run at any time. The file is found in the directory /usr/diag/sundiag. The file can also be loaded from tape or CD. You must also have Sunview and the file userdiag loaded on your disk. Become root on your system then type sundiag. See the Sundiag User's Guide for further information.

#### 2.6.5 Monitor and Forth Toolkit

The Monitor is a basic diagnostic utility. If there is a problem with the operating system the Monitor will automatically start, indicated by the > prompt.

.

| Parameter Name     | Default Value |
|--------------------|---------------|
| selfest-#megs      | 1             |
| oem-logo           |               |
| oem-logo?          | false         |
| oem-banner         |               |
| oem-banner?        | false         |
| output-device      | screen        |
| input-device       | keyboard      |
| sbus-probe-list    | 0123          |
| keyboard-click?    | false         |
| keymap             |               |
| ttyb-rts-dtr-off   | false ·       |
| ttyb-ignore-cd     | true          |
| ttya-rts-dtr-off   | false         |
| ttya-ignore-cd     | true          |
| ttyb-mode          | 9600,8,n,1,-  |
| ttya-mode          | 9600,8,n,1,-  |
| diag-file          |               |
| diag-device        | net           |
| boot-file          |               |
| boot-device        | disk          |
| auto-boot?         | true          |
| watchdog-reboot    | false         |
| fcode-debug?       | false         |
| local-mac-address? | false         |
| use-nvramrc?       | false         |
| nvramrc            |               |
| screen-#columns    | 80            |
| screen-#rows       | 34            |

| Table: 2.3 | Non-Volatile System | Configuration | Parameter Defaults |
|------------|---------------------|---------------|--------------------|
|------------|---------------------|---------------|--------------------|

| sunmon-compat?        | true  |
|-----------------------|-------|
| security-mode         | none  |
| security-password     |       |
| security-initiator-id | 7     |
| hardware-revision     |       |
| last-hardware-update  |       |
| testarea              | 0     |
| mfg-switch?           | false |
| diag-switch?          | false |

# Table: 2.4 NVRAM VME Configuration Parameters

| Parameter Description |                                                 |       |
|-----------------------|-------------------------------------------------|-------|
| vme-slavemap          | Address space for system DVMA access            | 0     |
| vme-a32map            | Re-map VMe address bits A[31:29]                | 0     |
| vme-intena            | Interrupt enable register                       | 254   |
| vme-mailbox           | Select VME address for mailbox interrupt        | 0     |
| vme-buslock           | Enables atomic RMW                              | 0     |
| vm-server-slavemap    | Client's server slavemap address                | 0     |
| vm-server-addr        | Client's server internet address                | 0     |
| vm-ip-addr            | Client's internet address                       | 0     |
| vme-rerun             | rerun mailbox level register                    | 0     |
| vme-busloc            | Bus locker register                             | 0     |
| next-prom             | If true, jump to second PROM on exit from first | false |

#### 2.7 SPARC CPU-2CE NVRAM Parameters

This section lists and defines the NVRAM parameters unique to SPARC CPU-2CE architecture. Each parameter will be presented in the following format:

#### parameter [options][default]

parameter and a description of the parameter's function.

#### vme-slavemap [range:0-15][0]

vme-slavemap selects a one megabyte space for system DVMA access. vme-slavemap will select one of the first 16 MB of VME space.

#### vme-a32map [0x0,0x20,0x40,0x60,0x80,0xa0,0xc0,0xe0][0]

vme-a32map remaps VME address bits A[31:29] enabling full 4GB mapping.

#### vme-intena [0-255][254]

vme-intena selectively enables VME interrupt levels by setting a bit mask that corresponds to the Interrupt Enable Register. The default value of Oxfe enables all interrupts and disables Round-Robin Arbitration.

#### vme-mailbox [0-255][0]

vme-mailbox selects a VME address to be monitored. If enabled, generates a mailbox interrupt to the IU by way of an on-card interrupt. This mailbox detects accesses to A16 address space at a location programmed in the Mail Box register. No real memory is provided at this location, but the mailbox responds with a VME DTACK, acknowledging the access and generating a level 13 interrupt if the enable bit is set.

#### vme-buslock [0,1][0]]

vme-buslock is a bus locker function that enables the CPU to do an Atomic Read-Modify-Write (RMW) to its on-card memory without being interrupted by an incoming RMW form another VMEbus master. This parameter should only be used in a multiprocessing environment.

#### vm-server-slavemap [0-15][0]

vm-server-slavemap sets the slavemap location of the client's server. See the SunOS 4.1e Release Manual, ONC/VME and the description of vme-slavemap above.

#### vm-server-address [internet address][0]

vm-server-address is the internet address of the client's server. This address is made up of four hexadecimal numbers expressed in decimal form. For example, the number 199.9.9.1 (all decimal numbers), converts to the hexadecimal value 0xc7090901. See the SunOS 4.1e Release Manual, ONC/VME.

#### vm-ip-addr [internet address][0]

vm-ip-addr is the internet address of the client. This address is made up of four hexadecimal numbers expressed in decimal form. For example, the number 199.9.9.1 (all decimal numbers), converts to the hexadecimal value 0xc7090901.

F

| LEGEND      | DESCRIPTION                            |
|-------------|----------------------------------------|
| SWLED (A,B) | 2 software controlled LEDs             |
| Reset       | Resets the Board                       |
| Abort       | Aborts Process                         |
| ENET        | Ethernet 15 pin Micro-D connector      |
| KBD         | Keyboard, mouse circular DIN connector |
| Serial A    | 26 pin connector for serial ports      |
| Serial B    | 26 pin connector for serial ports      |
| AUDIO       | Audio circular DIN connector           |
| SCSI        | SCSI-II 50 pin Micro-D connector       |

| Table: | 2.5         | Front    | Panel   |
|--------|-------------|----------|---------|
| I anto | <b>~~</b> ~ | A I VIII | T CITCI |

 Table: 2.6
 CPU-2CE Connectors

| FUNCTION        | Board Manufactures PN<br>Front Panel | Cable Mate Mfg<br>Part #     |
|-----------------|--------------------------------------|------------------------------|
| SCSI-II         | AMP 749831-5                         | AMP 749621-5                 |
| Ethernet        | ITT CANNON MDSM-<br>15PE-Z10         | ITT CANNON MDSM-<br>15SC_Z11 |
| Serial I/O      | AMP 749830-2                         | AMP 749621-2                 |
| Audio           | AMP 749232-1                         | AMP 750208-2                 |
| Keybd,<br>Mouse | AMP 749232-1                         | AMP7502 08-2                 |

Figure: 2.4 Font Panel

# **CPU-2CE FRONT PANEL**



# Figure: 2.5 Component Side



## Figure: 2.6 Solder Side



|      | Table: 2.7   SCSI Pinout List |            |        |       |                                        |  |  |
|------|-------------------------------|------------|--------|-------|----------------------------------------|--|--|
| Туре | Pin #                         | Comment    | Туре   | Pin # | Comment                                |  |  |
| GND  | 1                             | Ground     | SD0-   | 26    | SCSI Data0-                            |  |  |
| GND  | 2                             | Ground     | SD1-   | 27    | SCSI Data1-                            |  |  |
| GND  | 3                             | Ground     | SD2-   | 28    | SCSI Data2-                            |  |  |
| GND  | 4                             | Ground     | SD3-   | 29    | SCSI Data3-                            |  |  |
| GND  | 5                             | Ground     | SD4-   | 30    | SCSI Data4-                            |  |  |
| GND  | 6                             | Ground     | SD5-   | 31    | SCSI Data5-                            |  |  |
| GND  | 7                             | Ground     | SD6-   | 32    | SCSI Data6-                            |  |  |
| GND  | 8                             | Ground     | SD7-   | 33    | SCSI Data7-                            |  |  |
| GND  | 9                             | Ground     | SDP-   | 34    | SCSI Parity-                           |  |  |
| GND  | 10                            | Ground     | GND    | 35    | Ground                                 |  |  |
| GND  | 11                            | Ground     | GND    | 36    | Ground                                 |  |  |
| NC   | 12                            | No Connect | NC     | 37    | No Connect                             |  |  |
| NC   | 13                            | No Connect | TRMPWR | 38    | Term. Power (+5V<br>DC, Fused, 3 Amps) |  |  |
| NC   | 14                            | No Connect | NC     | 39    | No Connect                             |  |  |
| GND  | 15                            | Ground     | GND    | 40    | Ground                                 |  |  |
| GND  | 16                            | Ground     | ATN-   | 41    | Attention-                             |  |  |
| GND  | 17                            | Ground     | NC     | 42    | No Connect                             |  |  |
| GND  | 18                            | Ground     | BSY-   | 43    | Busy-                                  |  |  |
| GND  | 19                            | Ground     | ACK-   | 44    | Acknowledge-                           |  |  |
| GND  | 20                            | Ground     | RST-   | 45    | Reset-                                 |  |  |
| GND  | 21                            | Ground     | MSG-   | 46    | Message-                               |  |  |
| GND  | 22                            | Ground     | SEL-   | 47    | Select-                                |  |  |
| GND  | 23                            | Ground     | CD-    | 48    | Command/Data-                          |  |  |
| GND  | 24                            | Ground     | REQ-   | 49    | Request-                               |  |  |
| GND  | 25                            | Ground     | 10-    | 50    | Input/Output-                          |  |  |

Table: 2.7 SCSI Pinout List

| Figure: 2.7 | SCSI | Connector | and | Pins | (Front | View) |
|-------------|------|-----------|-----|------|--------|-------|
|-------------|------|-----------|-----|------|--------|-------|

### **Ethernet Connector Pinout List**

The following table is a pinout of the Ethernet connector. Figure 2.8 Shows the Ethernet connector and pin numbers.

| Pin | Function       |
|-----|----------------|
| 1   | N.C.           |
| 2   | Collision+     |
| 3   | Transmit Data+ |
| 4   | N.C.           |
| 5   | Receive Data+  |
| 6   | Ground         |
| 7   | N.C.           |
| 8   | N.C.           |
| 9   | Collision-     |
| 10  | Transmit Data- |
| 11  | N.C.           |
| 12  | Receive Data-  |
| 13  | +12VDC         |
| 14  | N.C.           |
| 15  | N.C.           |

Table: 2.8 Ethernet Pinout List

Figure: 2.8 Ethernet Cable Connector and Pins (Front View)





| Pin | Transmitted Signals        | Pin | Received Signals           |  |  |  |
|-----|----------------------------|-----|----------------------------|--|--|--|
| 2   | TxD-Transmit Data          | 3   | RxD- Receive Data          |  |  |  |
| 4   | RTS-Request To Send        | 5   | CTS-Clear to Send          |  |  |  |
| 7   | Ground                     | 6   | SYNC*                      |  |  |  |
| 20  | DTR-Data Terminal<br>Ready | 8   | DCD-Data Carrier<br>Detect |  |  |  |
| 24  | TRXC-DTE Transmit<br>Clock | 15  | TRXC-DCE Transmit<br>Clock |  |  |  |
|     |                            | 17  | RTXC-DCE Receive<br>Clock  |  |  |  |

 Table: 2.9
 Serial Pinout List

\* Connector casing is also grounded



| PIN | Description |           |  |
|-----|-------------|-----------|--|
| 1   | lin1        |           |  |
| 2   | lin2        |           |  |
| 3   | ain-        | Audio in  |  |
| 4   | lout1       |           |  |
| 5   | lout2       |           |  |
| 6   | ain+        | Audio in  |  |
| 7   | shield      | Audio out |  |
| 8   | audio out   |           |  |

 Table: 2.10
 Audio Connector
 (Din 8)

\*ISDN signals not supported

Figure: 2.11 Audio Connector







# 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 FO | RCE COMPUTERS:          |
| DATE:                           |                         |
| PR#:                            | -                       |
| RESPONSIBLE DEPT .:             |                         |
| ENGINEERING                     |                         |
| MARKETING                       |                         |
| PRODUCTION                      |                         |
|                                 |                         |
| AFFECTED PRODUCT:               | AFFECTED DOCUMENTATION: |
| HARDWARE                        | HARDWARE                |
| SOFTWARE<br>SYSTEM              | SOFTWARE<br>SYSTEM      |
|                                 |                         |
| ERROR DESCRIPTION:              |                         |
|                                 |                         |
|                                 |                         |
|                                 |                         |

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

# FORCE COMPUTERS Inc.

2001 Logic Drive San Jose, CA 95124 U. S. A.

FORCE COMPUTERS FRANCE S.A.R.L. Le Volta 17-19 rue Jeanne Braconnier F-92366 Meudon La Foret Cedex

### FORCE COMPUTERS GmbH

Prof.-Messerschmitt-Str. 1 D - 85579 Neubiberg/Munich Germany

FORCE COMPUTERS UK Ltd. No. 1 Holly Court 3 Tring Road Wendover Buckinghamshire HP22 6PE England

# Reader Comment Card

| Please circle one number for each.                   | Strongly<br>Agree | Agree | Neutral | Disagree | Strongly<br>Disagree |
|------------------------------------------------------|-------------------|-------|---------|----------|----------------------|
| • The manual is well organized.                      | 1                 | 2     | 3       | 5        | 6                    |
| • Instructions are complete.                         | 1                 | 2     | 3       | 5        | 6                    |
| • The manual is clearly written.                     | 1                 | 2     | 3       | 5        | 6                    |
| • Illustrations are clear and helpful.               | 1                 | 2     | 3       | 5        | 6                    |
| • The manual contains enough illustrations.          | 1                 | 2     | 3       | 5        | 6                    |
| • Layout and format enhance the manual's usefulness. | 1                 | 2     | 3       | 5        | 6                    |
| • This manual meets my overall expectations.         | 1                 | 2     | 3       | 5        | 6                    |

Please write additional comments, particularly if you disagree with a statement above. Use additional pages if you wish. The more specific your comments, the more useful they are to us.

Comments:

| Optional Information- |
|-----------------------|
| Name :                |
| Title:                |
| Company:              |
| Address:              |
| City/State/Zip:       |
| Phone:                |

Thank You

FOLD #1

AFFIX STAMP

FORCE COMPUTERS 3165 Winchester Blvd. Campbell, CA 95008

.

.

.

FOLD #2 THEN TAPE

(TAPE CLOSE)

| Pin # | Description                                 |
|-------|---------------------------------------------|
| 1     | Ground                                      |
| 2     | Ground                                      |
| 3     | +5 VDC                                      |
| 4     | Mouse In                                    |
| 5     | Keyboard Out                                |
| 6     | Keyboard In                                 |
| 7     | Ground*                                     |
| 8 .   | +5 VDC                                      |
|       | All signals TTL Levels. +5V current-limited |

 Table: 2.11 Keyboard/Mouse Connector Pinout List

\* All signals TTL Levels. +5V current-limited. May be jumpered to Mouse Output.

Figure: 2.12 Keyboard/Mouse Connector



| Pin          | Signal    | Pin | Signal  | Pin  | Signal         |
|--------------|-----------|-----|---------|------|----------------|
| 1            | Ground    | 33  | PA[06]  | 65   | D[18]          |
| 2            | BR*       | 34  | PA[08]  | 66   | D[20]          |
| 3            | Sel*      | 35  | PA[10]  | 67   | D[22]          |
| 4            | IntReq[1] | 36  | err     | 68   | Ground         |
| 5            | D[00]     | 37  | PA[12]  | 69   | D[24]          |
| 6            | D[02]     | 38  | PA[14]  | 70   | D[26]          |
| 7            | D[04]     | 39  | PA[16]  | 71   | D[28]          |
| 8            | IntReq[2] | 40  | Ack[1]  | 72   | +5V            |
| 9            | D[06]     | 41  | PA[18]  | 73   | D[30]          |
| 10           | D[08]     | 42  | PA[20]  | 74   | Siz[1]         |
| 11           | D[10]     | 43  | PA[22]  | 75   | Rd             |
| 12           | IntReq[3] | 44  | Ack[32] | 76   | Ground         |
| 13           | D[12]     | 45  | PA[24]  | , דר | <b>PA</b> [01] |
| 14           | D[14]     | 46  | Ground  | 78   | PA[03]         |
| 15           | D[16]     | 47  | Spare   | 79   | PA[05]         |
| 16           | IntReq[4] | 48  | -12V    | 80   | +5V            |
| 17           | D[19]     | 49  | Clk     | 81   | PA[07]         |
| 18           | D[21]     | 50  | BG*     | 82   | PA[09]         |
| 19           | D[23]     | 51  | AS*     | 83   | PA[11]         |
| 20           | IntReq[5] | 52  | Ground  | 84   | Ground         |
| 21           | D[25]     | 53  | D[01]   | 85   | PA[13]         |
| 22           | D[27]     | 54  | D[03]   | 86   | PA[15]         |
| 23           | D[29]     | 55  | D[05]   | 87   | PA[17]         |
| 24           | IntReq[6] | 56  | +5V     | 88 . | +5V            |
| 25           | D[31]     | 57  | D[07]   | 89   | PA[19]         |
| 26           | Siz[0]    | 58  | D[09]   | 90   | PA[21]         |
| 27           | Siz[2]    | 59  | D[11]   | 91   | PA[23]         |
| 28           | IntReq[7] | 60  | Ground  | 92   | Ground         |
| 29           | PA[00]    | 61  | D[13]   | 93   | Ground         |
| <b>3</b> 0 · | PA[02]    | 62  | D[15]   | 94   | Ground         |
| 31           | PA[04]    | 63  | D[17]   | 95   | Reset*         |
| 32           | LEn*      | 64  | +5V     | 96   | +12V           |

| Table: 2.12 SBus Connector | Pinout |
|----------------------------|--------|
|----------------------------|--------|

.

| Table: 2.13 P1 Bus Pinout List |       |            |       |           |       |  |
|--------------------------------|-------|------------|-------|-----------|-------|--|
| Signal                         | Row A | Signal     | Row B | Signal    | ROW C |  |
| D(0)                           | 1     | BBSY*      | 1     | D(8)      | 1     |  |
| D(1)                           | 2     | BCLR*      | 2     | D(9)      | 2     |  |
| D(2)                           | 3     | ACFAIL*    | 3     | D(10)     | 3     |  |
| D(3)                           | 4     | BGIN(0)    | 4     | D(11)     | 4     |  |
| D(4)                           | 5     | BGOUT(0)   | 5     | D(12)     | 5     |  |
| D(5)                           | 6     | BGIN(1)    | 6     | D(13)     | 6     |  |
| D(6)                           | 7     | BGOUT(1)   | 7     | D(14)     | 7     |  |
| D(7)                           | 8     | BGIN(2)    | 8     | D(15)     | 8     |  |
| GND                            | 9     | BGOUT(2)   | 9     | GND       | 9     |  |
| SYSCLK                         | 10    | BGIN(3)    | 10    | SYSFAIL*  | 10    |  |
| GND                            | 11    | BGOUT(3)   | 11    | BERR*     | 11    |  |
| DS1*                           | 12    | BR(0)      | 12    | SYSRESET* | 12    |  |
| DS0*                           | 13    | BR(1)      | 13    | LWORD*    | 13    |  |
| WRITE*                         | 14    | BR(2)      | 14    | AM(5)     | 14    |  |
| GND                            | 15    | BR(3)      | 15    | A(23)     | 15    |  |
| DTACK                          | 16    | AM(0)      | 16    | A(22)     | 16    |  |
| GND                            | 17    | AM(1)      | 17    | A(21)     | 17    |  |
| AS*                            | 18    | AM(2)      | 18    | A(20)     | 18    |  |
| GND*                           | 19    | AM(3)      | 19    | A(19)     | 19    |  |
| IACK*                          | 20    | GND        | 20    | A(18)     | 20    |  |
| IACKIN*                        | 21    | SERCLK     | 21    | A(17)     | 21    |  |
| IACKOUT*                       | 22    | GNDSERDAT* | 22    | A(16)     | 22    |  |
| AM (4)                         | 23    | GND        | 23    | A(15)     | 23    |  |
| A(7)                           | 24    | IRQ(7)     | 24    | A(14)     | 24    |  |
| A(6)                           | 25    | IRQ(6)     | 25    | A(13)     | 25    |  |
| A(5)                           | 26    | IRQ(5)     | 26    | A(12)     | 26    |  |
| A(4)                           | 27    | IRQ(4)     | 27    | A(11)     | 27    |  |
| A(3)                           | 28    | IRQ(3)     | 28    | A(10)     | 28    |  |
| A(2)                           | 29    | IRQ(2)     | 29    | A(9)      | 29    |  |
| A(1)                           | 30    | IRQ(1)     | 30    | A(8)      | 30    |  |
| -12 VDC                        | 31    | +5 VSTBY   | 31    | +12 VDC   | 31    |  |
| +5 VDC                         | 32    | +5 VDC     | 32    | +5 VDC    | 32    |  |

| Signal     | Row A | Signal    | Row B | Signal | Row C |
|------------|-------|-----------|-------|--------|-------|
| SCSI_DATA0 | 1     | +5 VDC    | 1     | NC     | 1     |
| SCSI_DATA1 | 2     | GND       | 2     | fp4    | 2     |
| SCSI_DATA2 | 3     | P1_RETRY* | 3     | NC     | 3     |
| SCSI_DATA3 | 4     | P1_A(24)  | 4     | fp8    | 4     |
| SCSI_DATA4 | 5     | P1_A(25)  | 5     | drvsel | 5     |
| SCSI_DATA5 | 6     | P1_A(26)  | 6     | NC     | 6     |
| SCSI_DATA6 | 7     | P1_A(27)  | 7     | NC     | 7     |
| SCSI_DATA7 | 8     | P1_A(28)  | 8     | fp16   | 8     |
| SCSI_DATA8 | - 9   | P1_A(29)  | 9     | fp18   | 9     |
| GND        | 10    | P1_A(30)  | 10    | fp20   | 10    |
| SCSI_BP*   | 11    | P1_A(31)  | 11    | fp22   | 11    |
| GND        | 12    | GND       | 12    | fp24   | 12    |
| TERMPWR    | 13    | +5 VDC    | 13    | fp26   | 13    |
| GND        | 14    | P1_D(16)  | 14    | fp28   | . 14  |
| GND        | 15    | P1_D(17)  | 15    | fp30   | 15    |
| SCSI_CNTR2 | 16    | P1_D(18)  | 16    | fp32   | 16    |
| GND        | 17    | P1_D(19)  | 17    | fp34ct | 17    |
| SCSI_CNTR1 | 18    | P1_D(20)  | 18    | feject | 18    |
| SCSI_CNTR3 | 19    | P1_D(21)  | 19    | NC     | 19    |
| SCSI_CNTR5 | 20    | P1_D(22)  | 20    | NC     | 20    |
| SCSI_CNTR6 | 21    | P1_D(23)  | 21    | NC     | 21    |
| SCSI_CNTR0 | 22    | GND       | 22    | NC     | 22    |
| SCSI_CNTR7 | 23    | P1_D(24)  | 23    | NC     | 23    |
| SCSI_CNTR4 | 24    | P1_D(25)  | 24    | NC     | 24    |
| SCSI_CNTR8 | 25    | P1_D(26)  | 25    | NC     | 25    |
| spkr1      | 26    | P1_D(27)  | 26    | NC     | 26    |
| led_out    | 27    | P1_D(28)  | 27    | NC     | 27    |
| spkr2      | 28    | P1_D(29)  | 28    | NC     | 28    |
| NC         | 29    | P1_D(30)  | 29    | NC     | 29    |
| NC         | 30    | P1_D(31)  | 30    | NC     | 30    |
| NC         | 31    | GND       | 31    | NC     | 31    |
| NC         | 32    | +5 VDC    | 32    | NC     | 32    |

Table: 2.14 P2 Bus Pinout List

# **Expansion Connector Mechanical Layout**

The Expansion Connector is an 8-pin header on 0.1" centers with the following pinout:

| Pin # | Function | Signal Description                                                                                                                                                                           |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | Pa26     | SBus physical address line 26                                                                                                                                                                |
| 2     | ramclk1  | A 20 MHz clock for a SS-2 ram controller. It has a 25-75 duty cycle.                                                                                                                         |
| 3     | ramsel1* | Second ram controller chip select. Asserted low whenever a virtual address translates to a legal page in Type0 address space between 0x8000000 and 0xFFFFFFF (pa27 high).                    |
| 4     | Ground   | Logic ground for the system                                                                                                                                                                  |
| 5     | ParCS1*  | Parity register chip select for second ram controller. Asserted low whenever a virtual address translates to a valid page in Type1 space with a physical address of 0xF4000008 - 0xF400000F. |
| 6     | RamClk   | A 20 MHz clock for an SS-2 ram controller. It has a 75-25 duty cycle.                                                                                                                        |
| 7     | Pa25     | SBus physical address line 25.                                                                                                                                                               |
| 8     | РЕп*     | Parity Error signal. This open drain signal is similar to the SBus signal LErr* except that it must meet SBus timings with the data in error, rather than one clock later.                   |
| 9     | Pa27     | SBus physical address line 27                                                                                                                                                                |
| 10    | EXMP     | Automatically changes state of the board when a memory SRX Board is installed.                                                                                                               |
| 11    | GND      | Ground                                                                                                                                                                                       |
| 12    | VCC      | Voltage                                                                                                                                                                                      |
| 13    | GND      | Ground                                                                                                                                                                                       |
| 14    | VCC      | Voltage                                                                                                                                                                                      |
| 15    | GND      | Ground                                                                                                                                                                                       |
| 16    | VCC      | Voltage                                                                                                                                                                                      |

Table: 2.15 Expansion Connector Electrical Pinout

## Figure: 2.13 Sun Expansion Connector Pin Orientation

| 15 | 13 | 11 | 9  | 7 | 5 | 3 | 1 |
|----|----|----|----|---|---|---|---|
| 16 | 14 | 12 | 10 | 8 | 6 | 4 | 2 |

×...

#### Section 3

# HARDWARE

#### 3.1 Card Landmarks

| Figure: 3.1 | Shows the Front Panel                                                                                     |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|
| Figure: 3.2 | Shows the component-side of the SPARC CPU-2CE card with various call-outs pointing to the card landmarks. |  |  |  |  |
| Figure: 3.3 | Shows the solder side of the FORCE SPARC CPU-2CE                                                          |  |  |  |  |

# **CPU-2CE FRONT PANEL**







#### 3.1.1 Card Jumpers

The only mechanical jumper blocks for the CPU-2CE are to configure the serial ports and to configure the VME bus system controller functions. The serial ports are linked so both ports are either RS-232-C or RS-423 with the default being RS-232-C. If RS-423 is needed, set the block before power up. Move the jumpers position to set RS-423. The VME default is slot one with the jumper in. See the example below and on the next page for the CPU-2CE defaults.





Figure: 3.4 RS-232/423 Jumper Blocks (Illustrations shows the default RS-232 setting)

Figure: 3.5 SPARC/CPU-2CE ADDRESS SPACE VIRTUAL Physical Memory Map: ASI Program



SPARCengine 2 User's Guide - December 1990



Figure: 3.6 Physical Memory Map (see page 64 for LED's, Hexswitch, and (Optional Feature - Flash maps)

Address Busses & Address Spaces

Virtual memory Layout is OS dependent. For SunOS 4.1.1 the information can be obtained from the .H files included with SunOS. This SunOS 4.1.1. example is from the file machdep.c but, this information will change for Sun Solaris and other operating systems.





| Table: 5.2 Address Space Indicator Contents |                          |                    |                                    |  |
|---------------------------------------------|--------------------------|--------------------|------------------------------------|--|
| ASI#                                        | Use                      | Address Space Type | Where Defined                      |  |
| 0x0                                         | Reserved                 | Control Space      | -                                  |  |
| 0x1                                         | Reserved                 | Control Space      | -                                  |  |
| 0x2                                         | System space             | Control Space      | System Control Space               |  |
| 0x3                                         | Segment Map              | Control Space      | MMU Control Space                  |  |
| 0x4                                         | Page Map                 | Control Space      | MMU Control Space                  |  |
| 0x5                                         | High Speed Segment Flush | Control Space      | Main Memory Cache<br>Control Space |  |
| 0x6                                         | High Speed Page Flush    | Control Space      | Main Memory Cache<br>Control Space |  |
| 0x7                                         | High Speed Context Flush | Control Space      | Main Memory Cache<br>Control Space |  |
| Ox8                                         | User Instruction         | Device Space       | Device Space                       |  |
| 0x9                                         | Supervisor Instruction   | Device Space       | Device Space                       |  |
| 0xA                                         | User Data                | Device Space       | Device Space                       |  |
| 0xB                                         | Supervisor Data          | Device Space       | Device Space                       |  |
| 0xC                                         | Flush Cache by Segment   | Control Space      | Main Memory Cache<br>Control Space |  |
| 0xD                                         | Flush Cache by Page      | Control Space      | Main Memory Cache<br>Control Space |  |
| 0xE                                         | Flush Cache by Context   | Control Space      | Main Memory Cache<br>Control Space |  |
| 0xF                                         | Hardware Virtual Flush   | Control Space      | Main Memory Cache<br>Control Space |  |

Table: 3.2 Address Space Indicator Contents

## 3.1.2 Device Space

Device Space consist of MMU-mapped main memory and I/O devices that are accessed through translation physical addresses.

The CPU automatically sets the ASI bits correctly for accesses to device space user data/instruction and supervisor data/instruction.

## 3.1.3 Control Space

Control Space is all non-device spaces. Control Space is accessed <u>only</u> in supervisor mode. Control Space is sub-divided into System Control Space, Main memory Cache Control Space, Memory management Unit Control Space.

The System Control Space contains control and status registers, serial port bypass, and cache tags. The System Control Space accesses can only be done using alternative space instructions. System Control Space is not mapped.



Figure - Physical Memory Map: System Control Space

Address Busses & Address Spaces



## Figure: 3.7 Virtual/Physical Memory Map ASI Diagram



# 3.1.4 The Memory Map Page

|           |                                                          | SBus Slot ( | )                                  |
|-----------|----------------------------------------------------------|-------------|------------------------------------|
| F000000   | Keyboard/Mouse                                           | F8000000    | IDPROM                             |
|           |                                                          | F8400000    | DMA+                               |
|           |                                                          | F8800000    | NCR 53C90A<br>(SCSI)               |
| F1000000  | ТТҮА/ТТҮВ                                                | F8C00000    | AMD 7990<br>(LANCE)                |
|           |                                                          |             | SBus Slot 1                        |
|           |                                                          | FA000000    |                                    |
| F2000000  | TOD/NVRAM                                                |             |                                    |
|           |                                                          |             | SBus Slot 2                        |
| F3000000  | Counter/Timers                                           | FC000000    |                                    |
| F4000000  | Parity Ctrl                                              | -           | SBus Slot 3                        |
| 1 4000000 | RAM+Ctrl                                                 | FE000000    |                                    |
|           |                                                          |             | Flash EEPROM<br>(Optional Feature) |
| F500000   | Internal Controller                                      | FF000000    | LED and Hex<br>Switch              |
|           |                                                          | FF800000    | Reserved                           |
| F6000000  | EPROM                                                    | -           |                                    |
| F7000000  | i82072 (FLOPPY)<br>AMD 79Ca30<br>(AUDIO)<br>I/O Register |             |                                    |

Figure: 3.8 Type 1 Space (On-Board I/O) (obio)

| Figure: 3.9 Type 0 Space (Main Memory) (obmem) |                             |  |  |
|------------------------------------------------|-----------------------------|--|--|
| 00000000                                       | 16 Megabytes                |  |  |
|                                                | On-board memory             |  |  |
| 01000000                                       | 32 Megabytes - 48 Megabytes |  |  |
|                                                | Memory Expansion Board      |  |  |
| 08000000                                       | 32 MBytes                   |  |  |
|                                                | SRX Board                   |  |  |
| 0A000000                                       | 32 Mbytes                   |  |  |
|                                                | SRX Memory Expansion        |  |  |
| 01000000                                       | 48 Mbytes                   |  |  |
| SRX Memory Expansion                           |                             |  |  |
|                                                |                             |  |  |

# Figure: 3.9 Type 0 Space (Main Memory) (obmem)

## 3.1.5 Interrupt Map

The SPARC CPU-2CE interrupt map is upwards compatible with the SPARC station 2, but includes additional interrupts. The following table shows the preliminary interrupt table for the SPARC CPU-2CE. Multiple interrupt sources share some of the interrupt levels.

| Level | Source                               | Additional Source       |
|-------|--------------------------------------|-------------------------|
| 15    | Abort                                |                         |
| 15    | SYSFAIL                              |                         |
| 15    | Memory: Parity Error                 | ECC Uncorrectable Error |
| 14    |                                      | Counter/Timer 1         |
| 13    | VME Level 7<br>VME Mailbox interrupt | Audio                   |
| 12    |                                      | Serial Ports            |
| 11    | VME Level 6                          | Floppy Disk             |
| 10    |                                      | Counter/Timer 0         |
| 9.    | VME Level 5                          | SBUS 7                  |
| 8     | VME Level 4                          | SBUS 6 (Video)          |
| 7     |                                      | SBUS 5                  |
| 6     |                                      | SW IRQ6                 |
| 5     | VME Level 3                          | Ethernet, SBUS 4        |
| 4     |                                      | SCSI<br>SW IRQ4         |
| 3     | VME Level 2                          | SBUS 3                  |
| 2     | VME Level 1                          | SBUS 2                  |
| 1     |                                      | SW IRQ1<br>SBUS 1       |

| Table: 3.3 | SPARC | <b>CPU-2CE</b> | Interrupt | Priority | Levels |
|------------|-------|----------------|-----------|----------|--------|
|------------|-------|----------------|-----------|----------|--------|

NOTE: If VME interrupt level 7 or 6 is needed with VME there is a conflict of the floppy and audio ports interrupts. Either the audio or floppy driver must be commented out of the GENERIC.VME and GENERIC\_SMALL.VME to disable one. Remember to copy the files before modifying them. Search the GENERIC.VME and the GENERIC\_SMALL.VME files in the .conf directory for audioamd. Use the "#" pound symbol at the head of the line to comment out either the audio or fd line. Then rebuild the kernel. See the readme file in the .conf directory for further details.

# 3.2 Custom Chips

The new ASICs are the Cache controller, DRAM controller, DMA controller, and the MMU chip. Further details on these ASICs are available in their respective chip specifications.

# 3.2.1 Cache+

The Cache+ ASIC consolidates the original Cache, Buffer, and the cache tags, all on one 224 pin chip. The Cache+/Sunray cpu core will operate at a clock rate between 33 and 40 MHz. The SBus will run at one-half the cpu clock rate. In order to balance the system somewhat (so that cache miss performance will not be terrible) a new RAM controller provides for 1-word-per-clock burst fills. In addition, a micro-TLB eliminates or reduces MMU translation time when the segment or page portions of the virtual address do not change. The Cache+ chip does *not* do parity checking; that function is moved to the RAM+ chip.

## 3.2.2 RAM+

The RAM+ chip is a DRAM controller and datapath chip for SBus systems. It uses 80 nsec DRAMs to give burst reads and writes at one word per clock. It does parity generation and checking. It has a 2-word write buffer to provide quick response to cache write-through operations. The RAM+ has a private RAM Data bus, isolating the DRAM data from SBus data. This lowers the load on the SBData lines, in addition to allowing the RAM+ chip to do buffered writes while releasing the SBus.

## 3.2.3 DMA+

The DMA+ chip is an update of the DMA chip, with optimizations to allow full speed SCSI operation along with ethernet on a 20 MHz SBus. It has an internal line buffer and does SBus operations one line at a time (where possible) in order to minimize SBus usage.

## 3.2.4 MMU+

The MMU+ gate array contains clock generation logic, the system parallel port, and the MMU datapath/decode logic. It is changed from the MMU chip in its decodes for the iodata bus (since the parity control register is no longer on the iodata bus).

## 3.2.5 SPARC CPU-2CE CACHE Controller

The Cache Controller controls the operation of the cache memory subsystem, provides a path to the main memory of the SBus, supports a single 64 Kbyte instruction/data cache, and monitors/controls the operation of the SBus. For the SBus it handles all arbitration, SBus watch functions, and fetching data and writing data back to memory.

The Cache Controller features:

Virtual address, direct mapped instruction /data cache controller

Supports 64 Kbyte write through cache, with 32-byte line size

Integrates cache tags on-chip (2 K x 21 bits)

Micro TLB improves performance to main memory or I/O devices

Controls SBus reads and writes

Supports three (full master/slave) SBus slots

Automatically fills cache on cache misses

Integrates write buffer logic and performs buffered writes that support up to two double words

Performs cache flush comparisons

Controls CPU byte packing

Contains Virtual Address Error Latches

Maintains copy of context registers

Contains Bus Error register (both address and data)

Monitors bus for unacknowledged transfers

Generates system reset

Tag support for 16 contexts

Hardware assisted context, segment, page and virtual flushing

#### The Cache Controller functions:

The cache is organized as 2048 lines 32 bytes each. The cache tags are 21 bits wide and integrated into the cache controller chip.

## Function of Write Through Cache Control

Lines are only loaded into the cache when the IU accesses (reads) a cachable memory location (Read Miss). Data is written into the Cache by the IU <u>only</u> if the location already resides there prior to the write. In all cases writes will be sent back to the main memory. Subsequent reads to the SBus are blocked until any pending writes are completed.

The cache design is implemented as a write-through cache to avoid halting the operation of the IU while the write to main memory occurs (2-entry cache write buffer has been implemented that allows the IU to continue operation) the IU is released early from a write only, if it is a cache hit, otherwise, the IU will be held until the write access will be finished.

| Burst Length | Delays Included | Direction | Bandwidth     |
|--------------|-----------------|-----------|---------------|
| 64 Byte      | DRAM only       | write     | 75 Mbytes/sec |
| 64 Byte      | DRAM only       | read      | 67 Mbytes/sec |
| 64 Byte      | DRAM+arb+DVMA   | write     | 61 Mbytes/sec |
| 64 Byte      | DRAM only       | read      | 56 Mbytes/sec |
| 32 Byte      | DRAM only       | write     | 71 Mbytes/sec |
| 32 Byte      | DRAM only       | read      | 58 Mbytes/sec |
| 32 Byte      | DRAM+arb+DVMA   | write     | 49 Mbytes/sec |
| 32 Byte      | DRAM+arb+DVMA   | read      | 43 Mbytes/sec |
| 16 Byte      | DRAM only       | write     | 53 Mbytes/sec |
| 16 Byte      | DRAM only       | read      | 40 Mbytes/sec |
| 16 Byte      | DRAM+arb+DVMA   | write     | 32 Mbytes/sec |
| 16 Byte      | DRAM+arb+DVMA   | read      | 27 Mbytes/sec |
| 4 Byte       | DRAM+arb+DVMA   | write     | 13 Mbytes/sec |
| 4 Byte       | DRAM+arb+DVMA   | read      | 10 Mbytes/sec |

Table: 3.4 SBus Bandwidth Estimation

#### 3.3 SPARC Expansion Connector

#### 3.3.1 Overview

SPARCstation-1, SPARCstation-1+, SPARCstation IPC, SPARCstation-2 and FORCE CPU-2CE all have an additional expansion connector beyond their SBus slots. These connectors are not identical, but do have some commonality between them. These connectors are *not* part of the SBus. They have different timing and loading requirements, and they are not guaranteed to be on any future Sun SBus machines. The purpose of this document is simply to allow access to these connectors (in the spirit of Openness). But first, this warning:

The expansion connector described in this document will continue to be supported throughout the product lifetimes of the specific machines listed. It will NOT necessarily be supported on any future SPARC Boards.

#### **3.3.1.1** Intent of the Expansion Connector

The original intent of the SPARC Expansion Connector was for memory expansion without performance compromises. To this end, certain assumptions are made about devices which respond to the sel\* signal on the Expansion Connector (such as support for burst fills). These requirements will be detailed below. In addition, these connectors are not identical from machine to machine. They were intended for internal use only, with minimal compatibility between them.

#### 3.3.2 Reconciling the Differences

As there are some annoying differences between the expansion connector on various systems, this section will attempt to address methods of living with all of the flavors available.

#### 3.3.2.1 Pa26

SBus address line 26 is not available on the SPARCstation-1 version of this connector. On the other hand, it *is* available on the SBus connector itself for SPARCstation-1's. Pin 46 of SS-1's SBus connector is **pa26**. On all other SPARCstations mentioned in this document, pin 46 of their SBus connectors are ground. Since Pin 1 of the expansion connector is ground on SS-1, the same functionality (with slightly later timing) can be achieved by OR-ing together pin 46 of the SBus connector and pin 1 of the expansion connector; one of the two will always be ground on these machines.

## 3.3.2.2 Pa25

SBus address line 25 is only available on SPARCstation-2's expansion connector (although it is also available on the SPARCstation-1 SBus connector). There is no way to depend upon pa25 across all versions of the SBus-based SPARCstations.

#### 3.3.2.3 POK

Power OK is only available on SS-1, SS-1+, and SS-IPC. A better source for reset is the SBus **reset\*** signal. The major difference is that **reset\*** is asserted on watchdog and software resets, while **pok** is negated (low) only after (or during) a power failure.

#### 3.3.2.4 RamclkN

The ramclk's are intended for a SPARCstation-2 memory controller. Do not put more than one CMOS load on either clock. It is vastly preferable that only the SBus clk signal be used.

#### 3.3.2.5 Ramsel\* vs. ramsel1\*

Ramsel1\* is "safe" in that no further decoding need be done; if you see ramsel1\* and as\* asserted, you are selected. On the other hand, ramsel\* needs further decoding; you must see ramsel\* asserted, as\* asserted, and pa26 high before selecting yourself. *Ignoring pa26 will lead to bus conflicts with the on-board memory controllers*. The simplest resolution to these differences is simply to use pa26 in all cases, and specify your board's address space for software purposes as 0xC000000 - 0xFFFFFFF (pa26 and pa27 both high).

Figure: 3.10 Safe Decode Circuit



#### 3.3.2.6 ParityN vs parcs1\*, ramclk1, pa25, and perr\*

In order to work with both types of machines (SS-2's and those requiring parity) your controller board must have a mode bit which will call *ss2mode*. When not in ss2mode, the **parity**N signals must be driven on SBus reads (possibly with the value written on the last write to that address, possibly with parity values calculated on the fly with the data). On SBus writes, the **parity**N signals are driven by the cpu board, but are not intended to be used for error detection (although they could be).

When in ss2mode, (and after reset-- until you determine that you are not an SS2) you should not drive any of these pins, as you could cause a bus conflict with parcs1<sup>+</sup>, ramclk1, or pa25.

The fcode boot prom should be able to determine cpu type from the top byte of the hostid of the system. Use this information to decide how to set ss2mode.

## 3.4 SCSI Interface

## 3.4.1 SCSI Definition

The Small Computer System Interface (SCSI) uses the NCR 53C90A controller chip and is augmented by the DMA+ chip with a data path of 8 bits. It features full compatibility with SCSI Specification, ANSI x3.131/1986. This allows the SPARC CPU-2CE to directly control and access a wide variety of mass storage devices such as hard disks, tapes, and CD-ROMs.

Up to seven external SCSI devices can be connected to the SPARC CPU-2CE. The SCSI bus is buffered and terminated so SCSI device connections are simple and straightforward, fully supporting synchronous and asynchronous operations. SCSI termination is self sensing. Just plug a terminated device on and the board will adjust termination automatically. For versatility and flexibility, the SCSI bus on the SPARC CPU-2CE is routed to both the front panel via a 50-pin SCSI-II connector and to the board's P2 User I/O pins.

## 3.4.2 SCSI Performance

The NCR 53C90 Extended SCSI Processor timing is as follows:

#### Synchronous Mode Speed:

| Absolute Maximum:        | 5.0 MB per second* |
|--------------------------|--------------------|
| Typical:                 | 2.5 MB per second  |
| Asynchronous Mode Speed: |                    |
| Absolute Maximum:        | 3.0 MB per second  |
| Typical:                 | 1.75 MB per second |

\* Note: The current maximum transfer rate in synchronous mode when using SUNOS (version 4.1.1b) is 4.0 Mbytes per second.

## 3.4.3 SCSI Addresses

The following table lists the physical addresses used to access the SCSI registers for byte loads and stores.

| Table: 3.5 SCSI Register Addresses |                                                      |  |  |
|------------------------------------|------------------------------------------------------|--|--|
| Address                            | Description                                          |  |  |
| 0xF0800000                         | Transfer Count Low                                   |  |  |
| 0xF0800004                         | Transfer Count High                                  |  |  |
| 0xF0800008                         | FIFO Data                                            |  |  |
| 0xF080000C                         | Command                                              |  |  |
| 0xF0800010                         | Status/Bus ID                                        |  |  |
| 0xF0800014                         | Interrupt/Status Timeout                             |  |  |
| 0xF0800018                         | Sequential Step/Synchronization<br>Transfer Period   |  |  |
| 0xF080001C                         | FIFO Flags/Synchronization<br>Offset                 |  |  |
| 0xF0800020                         | Configuration                                        |  |  |
| 0xF0800024                         | Clock Conversion Factor (write only)                 |  |  |
| 0xF0800028                         | Chip Test (Extended SCSI<br>Processor test use only) |  |  |
| 0xF080002C                         | Chip (Extended SCSI<br>Processor) Configuration-2    |  |  |

NOTE: Byte accesses must be performed even though the addresses are all fullword-aligned.

## 3.4.4 SCSI Interrupt

The SCSI Interrupt is Level 3.

# 3.4.5 Interface Programming

Since the SCSI controller uses the DMA controller to perform the actual transfer of data to and from memory, the two devices must be programmed together. One possible algorithm is as follows:

| scsi_start()          |                                                                                                                                           |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| t                     | /*start an operation on the SCSI*/<br>lock data pages into contiguous virtual memory;<br>DMA_address_register = starting virtual address; |
|                       | <pre>setup SCSI registers (except for "go");<br/>DMA_control_status_register = (ENDMA INT_EN (other bits));<br/>start SCSI;</pre>         |
| }                     | /*The SCSI will interrupt us when it is done.*/                                                                                           |
| scsi_interrupt()<br>{ |                                                                                                                                           |
|                       | /*must drain DMA on a read from disk/write to memory*/<br>if (last operation==READ) {                                                     |
|                       | DMA_control_status_register=(DRAIN); }                                                                                                    |
| }                     |                                                                                                                                           |

For a detailed description of the SCSI registers, see the NCR 53C90 Data Sheet.

#### 3.5 Ethernet Interface

#### 3.5.1 Ethernet Interface Definition

The Ethernet controller is the AMD AM7990 LANCE chip. The data is translated for the Ethernet by the AM7992 Serial Interface Adapter (SIA). The LANCE connects directly to the DMA, over unique Ethernet interface signals. The DMA will provide all necessary buffering and arbitration functions to allow the Ethernet chip to access main memory. The DMA Ethernet interface contains a 1 word (32bit) pack/unpack register with consistency control logic. Consistency control ensures that all data written by the Ethernet chip gets to main memory in a deterministic manner.

The LANCE uses multiplexed address and data, so the DMA demultiplexes them internally. The address supported by the LANCE is 24 bits; as per the SPARCstation specification the upper 8 bits of the 32 bit virtual address are driven to 0xFF. The LANCE has a 16 bit data path which can accommodate 8 or 16 bit accesses, by the use of byte masking capabilities.

## 3.5.1.1 Ethernet Transmits and Receives

When it is in transmit mode, the AM7990 LANCE transfers data from the current buffer in LANCE to a register called a Silo. The output of the Silo is serialized and then goes to the Serial Interface Adapter (AM7992). The output of the Serial Interface Adapter is connected to the Ethernet lines through a transformer.

In the receive mode, the Serial Interface Adapter (AM7992) receives data from the Ethernet cable. It transfers the data to the Silo in the LANCE. The LANCE transfers the data from the silo to the correct buffer in local memory.

#### 3.5.1.2 Ethernet Buffer

The LANCE Controller utilizes up to 128 Kilobytes of memory for buffers. These buffers are allocated from the SPARC CPU-2CE's onboard parity memory.

#### 3.5.2 Ethernet Performance

| Maximum Transfer Rate: | 10 Mbits per second  |
|------------------------|----------------------|
| Maximum Observed Rate: | 7.5 Mbits per second |

#### **3.5.3** Ethernet Interrupt

Processor Level 5, SBus level 4

SPARC CPU-2CE can transfer data from the Ethernet into the on-card buffer memory at a maximum (theoretical) rate of 10 megabits/sec.

## 3.5.4 Ethernet Addresses

The Ethernet Controller chip is in SBus slot 0 address space at 0xF0C00000. The following table lists the address and location of its internal registers:

| Table: 3.6 Ethernet Registers |                             |  |  |
|-------------------------------|-----------------------------|--|--|
| Address                       | Description                 |  |  |
| 0xF0C00000                    | Register Data Port (RDP)    |  |  |
| 0xF0C00002                    | Register Address Port (RAP) |  |  |

For additional information, see the AMD Am7990 Data Sheet.

## 3.5.5 Ethernet Interface Programming

```
/* Initializing on-card ethernet chip
                                        */
*Abstract:
                                       Performs Lance hardware dependent
                      *
variable
                                       initialization
                                                       for
                                                             Sun
                                                                  Ethernet
diagnostic.
                      *
                                                        3
*Algorithm:
                                       Initialize CSR
                                                            (describe
                                                                       bus
acquisition
                      +
                                       procedures to the emulator).*
*
                                        Initialize global variables and i/o
data
                                        structures.*
*Routines called:
                      ini_print, ini_read*
÷
*/
long le_sys_init(argc,argv)
     int
                                        argc ;
     char
                                        *argv[] ;
ł
     extern int
                                       byteswap() ;
     extern short
                                        DSPL ON;
                                        err dsp;
     extern short
                                        home_adr[6];
     extern char
     extern short
                                        INTR ON ;
                                        myaddr ;
     extern etraddr
                                        net_data [];
     extern char
     extern short int
                                        ringsize, bufsize;
     extern int
                                        totbuf;
     u short *rdpp
                                       /* ptr to reg data port */
                      ;
     u short *rapp
                                        /* ptr to reg adr port */
                      ;
     long
                                        mrc ;
     long
                                        rc ;
                      slot;
     extern int
                                        i;
     int
     rc = PASS ;
```

Hardware

```
/* init etherbase va array */
      for (i=0; i<= NUM SLOTS; i++)</pre>
      etherbase va[i] = 0;
      ether.etherbase size = (int)ROUNDUP(sizeof(LE_BLOCK),PAGESZ);
      etherbase va[0] = ether.dvma_start ;
                                              /* Initializing on-card ethernet chip
*/
                                              /* set remaining chip/diagnostic ether
mem variables */
      ether.txbuf_n = ONE << TLENMAX ;</pre>
      ether.rxbuf_n = ONE << RLENMAX ;
ether.txbuf_size = 1024 ;
ether.rxbuf_size = 1024 ;</pre>
                                              /* may need to tweek this */
                                              /* may need to tweek this */
                                              /* map on-card ethernet control block
& buffers here */
                                              /* find the first available block for
control block */
      for(ether.etherbase va=etherbase_va[0],mrc=FAIL;
      PASSED(rc) && FAILED(mrc);)
      {
                          if (FAILED (mrc = execmap (&ether.etherbase_va,
                                              &ether.etherdum_pa,
                                              ether.etherbase size,
                                              ether.ether_flags)))
       {
                                               /* increment va by a page */
      ether.etherbase_va += PAGESZ;
                                              /* will we go beyond dvma space ? */
      if(((u long)(ether.etherbase va+ether.etherbase size))
                          >= ((u long) (ether.dvma start+ether.dvma size))
                                                                                )
       ł
      rc = mrc;
      exec_log(ERROR, ALL_DST,
                                "le_sys_init(le%d):
                                                     can
                                                              not
                                                                      map
                                                                              on-card
etherbase {%d}@0x%x\n",
                                              testing_LE, rc, ether.etherbase_va) ;
       }
       }
                                               /* for */
       }
      etherbase va[0] = ether.etherbase va;
      ether.ethermin va = ether.etherbase va + ether.etherbase size;
                                                  /* ptr to reg data port */
      rdpp = (u_short *)(ethernet_va[0]) ;
      rapp = (u_short *)(ethernet_va[0] + 2) ;/* ptr to reg adr port */
                                              /* Select CSR 0 */
      *rapp = 0;
                                              /* set the stop bit in csr0 to
inactivate the lance chip */
      *rdpp = (*rdpp) | 0x0004;
      for (i=1; i<=slots[0]; i++)</pre>
                                              /* Initializing 2nd ethernet chip. */
       Ł
                                              /* map 2nd ethernet control block &
buffers here */
                                              /* find the first available block for
control block */
      for (ether.etherbase_va=etherbase_va[i-1]+ether.etherbase_size,mrc=FAIL;
                          PASSED(rc) && FAILED(mrc);)
       ł
                           if (FAILED (mrc = execmap (&ether.etherbase_va,
                                              &ether.etherdum_pa,
ether.etherbase_size,
                                              ether.ether_flags)))
       ł
                                               /* increment va by a page */
```

```
ether.etherbase_va += PAGESZ;
                                                            /* will we go beyond dvma space ? */
        if(((u long)(ether.etherbase va+ether.etherbase size))
                                  >= ((u_long) (ether.dvma_start+ether.dvma_size)) )
         ł
                                  rc = mrc
                                  exec log(ERROR, ALL DST,
                                                            "le sys init(le%d): can not map 2nd
etherbase{%d}@0x%x\n",
                                  testing LE, rc, ether.etherbase va) ;
         }
         ł
                                                            /* for */
        }
        etherbase va[i] = ether.etherbase va;
        ether.ethermin_va += ether.etherbase_size;
        rdpp = (u_short *)(ethernet_va[i]) ;7* ptr to reg data port */
rapp = (u_short *)(ethernet_va[i] + 2) ;/* ptr to reg adr port */
        *rapp = 0;
                                                            /*Select CSR0 */
                                                                set the stop bit in csr0 to
inactivate the lance chip */
        *rdpp = (*rdpp) | 0x0004;
                                                          /* set stop bit in csr0 */
         } /* for */
        totbuf = BUFSPC ;
        bufsize = 1024;
        ringsize = TLENMAX;
                                                            /* copy ethernet address from myaddr
to home adr */
        bcopy(myaddr,home adr,sizeof(etraddr)) ;/* 1 to 1 copy */
        net_data[0] = '\0'; net_data[1] = '\0'; net_data[2] = '\0';
net_data[3] = '\0'; net_data[4] = '\0'; net_data[5] = '\0';
net_data[6] = '\0'; net_data[7] = '\0'; net_data[8] = '\0';
        net_data[9] = '\0'; net_data[10] = 'T'; net_data[11] = 'h'
        net_data[12] = 'i'; net_data[13] = 's'; net_data[14] = ' ';
net_data[15] = 'i'; net_data[16] = 's'; net_data[17] = ' ';
net_data[18] = 'a'; net_data[19] = ' '; net_data[20] = 't';
net_data[21] = 'e'; net_data[22] = 's'; net_data[23] = 't';
        net_data[24] = ' '; net_data[25] = 'o'; net_data[26] = 'f';
        net_data[27] = ' '; net_data[28] = 't'; net_data[29] = 'h';
net_data[30] = 'e'; net_data[31] = ' '; net_data[32] = 'L';
net_data[33] = 'A'; net_data[34] = 'N'; net_data[35] = 'C';
        net_data[36] = 'E'; net_data[37] = ' '; net_data[38] = 'E';
        net_data[39] = 'm'; net_data[40] = 'u'; net_data[41] = '1';
net_data[42] = 'a'; net_data[43] = 't'; net_data[44] = 'o';
        net_data[45] = 'r';
                                                            /* error display flag */
        err dsp = SET;
        DSPLON = 0;
                                                            /* By default, no debug msgs */
         INTRON = 0;
        go reset();
         return(rc) ;
                                                            /* le_sys init */
         1
```

#### 3.6 SBus Interface

#### 3.6.1 Introduction

The SBus is a non-proprietary I/O expansion bus developed by Sun Microsystems for some new Sun systems and card products. The bus resides in type 1 device space.

#### 3.6.2 SBus Connections

The SBus connector is located on the component side of the SPARC CPU-2CE card, near the P2 connector.

| Table: 3.7    SBus Interrupts |                               |              |                           |  |
|-------------------------------|-------------------------------|--------------|---------------------------|--|
| PROCESS<br>TRAP<br>LEVELS     | SOURCE                        | TRAP<br>TYPE | TRAP<br>VECTOR<br>ADDRESS |  |
| 15                            | Async SBus Error              | 31           | 1F                        |  |
| 14                            | Timer 1                       | 30           | 1E                        |  |
| 13                            | Audio Interrupt               | 29           | 1D                        |  |
| 12                            | On-board Serial Ports         | 28           | 1C                        |  |
| 11                            | Floppy Disk Controller        | 27           | 1B                        |  |
| 10                            | Timer 0                       | 26           | 1A                        |  |
| 9                             | SBus IRQ 7                    | 25           | 19                        |  |
| 8                             | SBus IRQ 6                    | 24           | 18                        |  |
| 7                             | SBus IRQ 5                    | 23           | 17                        |  |
| 5                             | Ethernet Cntrl/SBus IRQ<br>4  | 21           | 15                        |  |
| 4                             | SWI                           | 20           | 14                        |  |
| 3                             | SCSI Controller/SBus<br>IRQ 3 | 19           | 13                        |  |
| 2                             | SBus IRQ 2                    | 18           | 12                        |  |
| 1                             | SWI/SBus IRQ 1                | 17           | 11                        |  |

The column marked "Level" is the Interrupt Level which is encoded to the SPARC main processor, or Integer Unit, by the MMU. The source to the MMU is listed under "Source."

## 3.6.3 SBus Slot Addresses

Address bits PA[27:26] select one of two SBus slots, and bits PA[24:0] are available for addressing devices on the SBus card. Bit PA[25] is not used.

| Table: 3.8 SBus Slot Addresses |             |                          |
|--------------------------------|-------------|--------------------------|
| PA[27:26]                      | Slot        | Address Range            |
| 00                             | SBus slot 0 | 0xF0000000 to 0xF1FFFFF  |
| 01                             | SBus slot 1 | 0xF4000000 to 0xF5FFFFF  |
| 10                             | SBus slot 2 | 0xF8000000 to 0xF9FFFFF  |
| 11                             | SBus slot 3 | 0xFE000000 to 0xFFFFFFFF |

The following table shows how bits PA[27:26] select the SBus slots.

SBus slot 0 and 3 are not physical slots; they are occupied by devices residing on the SPARC CPU-2CE card.

SBus slot 1 and 2 on the SPARC CPU-2CE are physical slots, where cards such as the SBus video cards can be utilized.

The SBus device addresses are described in the following sections.

## 3.6.4 SBus Slot 0 Devices

The SBus Slot 0 devices are physically on the CPU card. SBus slot 0 is in type 1 space at a base address of 0xF0000000. The base address contains the card ID number, DMA registers, SCSI registers, and Ethernet registers.

| Table: 3.9 SBus Slot 0 Addresses |                                                                                                                                                                                                                                                                                                           |  |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Offset                           | Description                                                                                                                                                                                                                                                                                               |  |
| 0xF000000                        | Card ID (0xFE810101)                                                                                                                                                                                                                                                                                      |  |
| 0xF0400000                       | DMA Registers:                                                                                                                                                                                                                                                                                            |  |
|                                  | Control/Status<br>Byte Count<br>Diagnostics                                                                                                                                                                                                                                                               |  |
| 0xF0800000                       | SCSI Registers:                                                                                                                                                                                                                                                                                           |  |
|                                  | Transfer Count Register<br>FIFO Register<br>Command Register<br>Status Register<br>Select/Reselect Bus ID Register<br>Sequence Step<br>Synchronous Transfer Period Register<br>FIFO Flags Register<br>Synchronous Offset Register<br>Configuration Register<br>Clock Conversion Register<br>Test Register |  |
| 0xF0C00000                       | Ethernet Registers:                                                                                                                                                                                                                                                                                       |  |
|                                  | Data Port<br>Address Port                                                                                                                                                                                                                                                                                 |  |

NOTE: The slot 0 space from 0xF2000000 to 0xF3FFFFFF is not used.

## 3.6.4.1 Card ID

The card ID (data 0xFE810101 at location 0xF0000000) is a line of Forth code that identifies the card in SBus slot 0 to the operating system (in this case, the CPU card identifies itself).

# 3.6.4.2 DMA Registers

The DMA register space contains four registers, addressed by fullword loads and stores.

| Table: 3.10 DMA Register Addresses |                             |  |
|------------------------------------|-----------------------------|--|
| Address                            | Description                 |  |
| 0xF0400000                         | DMA Control/Status Register |  |
| 0xF0400004                         | DMA Address Register        |  |
| 0xF0400008                         | DMA Byte Count Register     |  |
| 0xF040000C                         | DMA Diagnostic Register     |  |

# DMA Control/Status Register

The DMA control/status register has the following format:

# D[31:27]- DEV\_ID

These read-only bits contain the data 0x0B1000. They identify the Ethernet device type.

# D[27:15]

These bits are unused; they read back as 0's.

# D14- TC

This read-only bit indicates the that the byte counter has expired (decremented to 0).

# D13- EN\_CNT

This read/write bit enables the DMA byte count register.

# D[12:11]- BYTE\_ADDR

These two read-only bits indicate the next byte number to be accessed.

# D10- REQ\_PEND

This read-only bit is set when the DMA interface is active. Note that RESET and FLUSH must not be asserted when this bit is active.

# D9- EN\_DMA

This read/write bit is set to enable DMA activity and reset to disable it.

# D8- WRITE

This read/write bit is set for DMA from memory to device (write) and reset for DMA from device to memory (read).

## D7- RESET

Setting this read/write bit causes a hardware reset. ERR\_PEND, PACK\_CNT, INT\_EN, FLUSH, DRAIN, WRITE, EN\_DMA, REQ\_PEND, EN\_CNT, and TC are all set to zero. RESET remains set, and must be reset to resume operation.

# D6- DRAIN

Setting this read/write bit forces remaining pack register bytes to be drained to memory. It resets itself.

# D5- FLUSH

This write-only bit forces PACK\_CNT and ERR\_PEND to zero. It always reads as zero.

# D4- INT\_EN

This read/write bit enables interrupts when it is set.

# D[3:2]- PACK CNT

This read only field provides the number of bytes in the pack register.

## D1- ERR\_PEND

This read-only bit is set when a memory exception occurs, and is reset by setting FLUSH. DMA activity stops until it is reset.

#### DO- INT PEND

This read-only bit is set when TC=1, or when an external device raises an interrupt.

#### **DMA Address Register**

The DMA address register is located at address 0xF0400004. It holds the virtual address of the DMA transfer. Initially, it should be loaded with the virtual address where the DMA will start. As the DMA proceeds, both the DMA byte count register and bits [23:0] of the DMA address register are decremented.

Bits [31:24] of the DMA address register indicate which 16-megabyte portion of virtual memory is accessed. These bits are latched; they do not change as the DMA proceeds.

#### DMA Byte Count Register

When the EN\_CNT bit in the DMA control/status register is set, bits [23:0] of this register keep a count of the number of bytes transferred by the DMA circuits. It should be loaded with the total number of bytes to be transferred; it decrements towards zero as the bytes are transferred. When it reaches zero, it sets TC and INT\_PEND in the DMA status/control register.

Note that bits [31:24] are hardwired to zero.

#### **DMA Diagnostic Register**

This register is not implemented at this time.

#### 3.6.5 SBus Slot 1 Devices and Slot 2 Devices

Any device plugged into an actual SBus connector on the CPU card is an SBus device.

As of the print date of this manual, the SPARC CPU-2CE supports two video cards, color and monochrome, that can be plugged into the SBus connector on the CPU card. These cards are interchangeable at the card level, but require different cables and monitors. The two cards have different registers. For specific information on these cards, please refer to The SBus Color & Monochrome Video Cards User's Manual.

For all other SBus cards, refer to the technical documentation and manuals provided with the card.

The Sbus supports all SBus devices that Sun's SPARCstation 2 supports.

#### 3.6.5.1 SPARC Assembly Language Example

```
/*
 * sbus.s
 */
#define sbud_id
                                            0x00010000/* sbus ID virtual address
*/
#define sbus phy
                                            0xf0000000/* sbus ID physical address
```

```
*/
                                                      0xd4000000/* valid, writable, don't
#define TYPE1 ATTRIBUTES
cache */
                    "text"
          .seq
          .global Sbus_id
!----
! Read SBus slot 0 card ID register
Sbus_id:
                               %sp, -MINFRAME, %sp! preserve calling indow
sbus id, %o0 ! Virtual address to be mapped.
       save
                               sbus_id, %00
        set
                                                                              ! Page table entry
                               TYPEI ATTRIBUTES, %02
       set
attributes.
                                                       ! Physical address to be mapped.
                               sbus phy, %03
       set
                               _pmap_memory
%00, %01
sbus_virt, %15
                                                       ! Map in specified block of memory.
       call
                                                       ! Upper virtual address to be mapped.
       mov
                                                       ! Address of SBus register.
        set
                               [%00],%14
                                                       ! Read Card ID status
       14
       nop
        ret
       restore
/*
        PMAP.S
 */
                                                       0x40000/* offset between adjacent
#define SEGINCR
segments */
                                                       18/* LOG2 (NBSG) */
#define SGSHIFT
                                                       0x3/*segment map */
#define ASI SM
                                                       0x2000/* offset between adjacent pages
#define PAGINCR
*/
                                                       13/* LOG2 (NBPG) */
#define PGSHIFT
                                                       0x4/* page map */
#define ASI PM
                  "text"
        .sea
        .global _pmap_memory
/*
 * Synopsis: status=pmap memory(low va, hi va, attributes, low_pa);
                                                       : (int) don't care
 *
        status
 ٠
        low_va
                                                       (%i0): (unsigned long) initial virtual
address
 *
                                                       (%i1): (unsigned long) final virtual
       hi va
address
                               (%i2)
                                                       : (unsigned long) page table entry
 *
        attributes
attributes
                                                       (%i3):
                                                                   (unsigned
                                                                                  long)
                                                                                             initial
 *
        low pa
physical address
 * Function "pmap_memory" (physical map memory) linearly maps the range of
 * virtual addresses specified by 'low_va' and 'hi_va', beginning at physical
* address 'low_pa', with page table entry attributes 'attributes'.
 */
_pmap_memory:
                  %sp, -MINFRAME,%sp
        save
        /*
         * Fill in segment table entries for a linear mapping of main memory.
         */
                               SEGINGE, 515 : Adjacent segment table entry offset.
%13, 0x1, %14 : Mask for segment table addressing.
%10, %14, %12 : Adjust initial virtual address.
%12, SGSHIFT, %10 : Segment table entry (pmeg number).
%10, [%12]ASI_SM : Set segment table entry.
%12, %13, %12 : Increment address by one segment.
%12, %11 : T
                                            $13
                                                       ! Adjacent segment table entry offset.
        set
                               SEGINCR,
        sub
        andn
3:
        srl
        dd
        add
                               %12, %i1
                                                       ! If current virtual address is not
        cmp
                                4f
        bgt
        nop
```

| 4:    | bleu<br>nop              | 3b                   | ! greater than the final virtual ! address, continue. |
|-------|--------------------------|----------------------|-------------------------------------------------------|
| 4:    | /*                       |                      |                                                       |
|       | * Fill in page t         | able entries for a   | linear mapping of main memory.                        |
|       | */                       |                      | 1 Idda aant maaa tabla anton affaat                   |
|       | set                      | PAGINCR, %13         | ! Adjacent page table entry offset.                   |
|       | sub                      |                      | ! Mask for page table addressing.                     |
|       | andn<br>/*               | %i0, %14, %12        | ! Adjust initial virtual address.                     |
|       | · ·                      | initial page table ( | entry                                                 |
|       | */                       | mitiai page table    |                                                       |
|       | andn                     | <b>%i3, %l4, %l1</b> | ! Adjust initial physical address.                    |
| 5:    | srl                      |                      | ! Page number of page table entry.                    |
|       | or                       |                      | ! Combine attributes and page number.                 |
|       | sta                      |                      | ! Set page table entry.                               |
|       | add                      |                      | ! Increment physical address by a                     |
| page. |                          |                      |                                                       |
|       | add                      | <b>%12, %13, %12</b> | ! Increment virtual address by a page.                |
|       | cmp                      | %12, %il             | ! If current virtual address is not                   |
|       | bgt                      | 6f                   |                                                       |
|       | nop                      |                      |                                                       |
|       | bleu                     | 5Ъ                   | ! greater than the final virtual                      |
|       | nop                      |                      | ! address, continue.                                  |
| 6:    | •                        |                      |                                                       |
|       | /*  * Mapping comple  */ | eted.                |                                                       |
|       | ret                      |                      |                                                       |
|       | restore                  |                      |                                                       |
|       |                          |                      |                                                       |
|       |                          |                      |                                                       |

#### 3.6.5.2 Forth Example

| f000.0000 constant SBUS-SLOT0    | \ physical address                   |
|----------------------------------|--------------------------------------|
| 0001.0000 constant SBUS-ID       | \ virtual address                    |
| SBUS-SLOTO obio SBUS-ID map-page | \ map into type1 (on-card I/O) space |
| SBUS-ID 10 .                     | \ fetch and display sbus-id          |

NOTE: SBus slot 0 contains the DMA, Ethernet, and SCSI chips. Slot 1 & 2 contains SBus cards.

#### 3.6.5.3 C/SunOS Example

```
* caddr t map SBus_address(u_int p_addr, u_int num_pages)
 * Inputs: Physical address and the # of pages to map.
 * Returns: Virtual address of the mapped page(s).
 */
caddr t map SBus address (p addr, num pages)
u_int p_addr;
                                            /* physical address on the SBus to map
*7
u int num_pages;
                                            /* # of pages to allocate/map */
£
      long
                         v_pgnum;
      u_int
u_int
                         v addr;
                         offset;
      u_int
                         pg_tbl_ent;
/*
 * Save the offset from the page boundary so that
 * we can apply it to the virtual address once the
 * page is mapped in.
 * /
      offset = p addr & MMU PAGEOFFSET;
/*
 * Create a page table entry that maps the physical address
 * "p_addr" into SBus space.
 * /
      pg_tbl ent = PGT OBIO | PG NC | btop(p addr);
/*
 * Allocate virtual pages that we can use from the
 * kernel map of available virtual addresses.
 */
      v_pgnum = rmalloc(kernelmap, (long)btoc(num pages));
      if (v_pgnum == 0) /* no addresses available from kernelmap */
                         return (caddr t)0;
 * Convert the virtual page # to a virtual address
      v_addr = (u int)kmxtob(v pgnum);
 * Map the physical address into our allocated virtual address.
 */
      segkmem_mapin(&kseg, v_addr, num_pages, PROT READ | PROT WRITE,
                                           pg_tbl_ent, 0);
/*
 * Return to the caller of this function the virtual address of
 * the mapped SBus physical address.
 */
      return (caddr_t) (v_addr | offset);
      /* end of map_SBus_address */
}
```

## 3.7 RAM+

#### 3.7.1 FEATURES

- Provides all DRAM timing and refresh cycles.
- Controls 64 Mbytes.
- Generates and checks byte-wide (or word-wide?) parity.
- Supports 32-byte and 8-byte SBus sizes.

#### 3.7.2 PIN DESCRIPTION

The RAM+ chip is built in a 196-pin plastic flat pack. It has X outputs, Y bidirectional pins, Z inputs, A VCC pins, and B Grounds.

#### 3.7.2.1 Sbus Interface

| clk         | (TLCHT) System clock. This signal runs at up to 20 MHz with a 50% duty cycle. (Perhaps: for clockrates greater than 20 MHz, the configuration register must be set to two-clocks-per-word mode.)                                                                                                                                                                   |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| sb_d[31:0]  | (BD8) Sbus data. On read cycles, this data is guaranteed valid 34, the clock following an "ack."                                                                                                                                                                                                                                                                   |  |
| sb_pa[27:0] | (TLCHT) SBus physical address. It is guaranteed to be valid before the clock edge in which sb_as_ is sampled low.                                                                                                                                                                                                                                                  |  |
| sb_siz[2:0] | (TLCHT) SBus size control signals. The RAM+ chip supports an exten-<br>sion of the normal SBus size codes for 8-byte and 32-byte bursts.                                                                                                                                                                                                                           |  |
| sb_rd       | (TLCHT) SBus read control signal. This signal is asserted (high) for read cycles and negated (low) for write cycles.                                                                                                                                                                                                                                               |  |
| sb_ack32_   | (BT4) SBus acknowledge for 32-bit word size. Tri-state output. It is asserted (low) for one clock for each word transferred.                                                                                                                                                                                                                                       |  |
| sb_merr_    | (BT4) SBus Memory Error. Asserted after data to report parity error.                                                                                                                                                                                                                                                                                               |  |
| sb_as_      | (TLCHT) SBus address strobe. This signal is asserted (low) by the system controller for the duration of an SBus cycle.                                                                                                                                                                                                                                             |  |
| selram_     | (TLCHT) Ram select input. This signal is asserted (low) to indicate that<br>a DRAM access is taking place. It is asynchronous when sb_as_ is not<br>asserted. (It only guarantees a setup to a clock edge when as_ is also<br>seen asserted.) As long as parity is internally enabled, all accesses are<br>checked. There is no "par_en_" signal on the RAM+ chip. |  |

|         | par_cs_                           | (TLCHT) Parity register select input. (There is a problem currently in that the MMU chip asserts ioden_during par_cs_ and pio_sel_cycles.)                                                                                                                       |
|---------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | totals:                           | inputs: 36, outputs: 2, bidirects: 32.                                                                                                                                                                                                                           |
| 3.7.2.2 | DRAM Interface                    |                                                                                                                                                                                                                                                                  |
|         | ram_d[31:0]                       | (BD4) DRAM data bus. Driven during write cycles, latched during reads<br>on the rising edge of cas Each signal drives 4 pins.                                                                                                                                    |
|         | ma[10:0]                          | (BT4) Multiplexed DRAM address bus. These 11 address lines contain<br>the addresses to be used by the DRAM at the next falling edge of ras_<br>or cas They will be buffered externally. DRAMs expect 0 nsec setup<br>time and 10 nsec hold time wrt ras_ and cas |
|         | we_                               | (BT4) Write Enable outputs to all DRAM banks. Assumed to be externally buffered                                                                                                                                                                                  |
|         | ras_[15:0]                        | (BT8) Row Address Strobe outputs to DRAM banks, one for each byte.<br>Each signal drives 9 pin.                                                                                                                                                                  |
|         | cas_[15:0]                        | (BD8) Column Address Strobe outputs to DRAM banks, one for each byte. Each signal drives 9 pins. These signals use bidirectional pads because the cas_ signal is read back in to provide the clock for the read data register.                                   |
|         | p[3:0]                            | (BD8) Parity input/output. Each signal drives 4 pins.                                                                                                                                                                                                            |
|         | totals:<br>inputs: 0, outputs 28, | bidirects: 52.                                                                                                                                                                                                                                                   |

# 3.7.2.3 Power/Ground

totals: 41 VCC: x , Ground: 41 - x.

# 3.7.2.4 LSI Logic Buffer Naming Conventions

Input pads are generally TLCHT's. Outputs are generally BTx's where x is the number of milliamps of drive capacity. BDx's are bidirectional pads with x milliamps of drive.

 Table: 3.11
 Address Ranges

| ,       |             |    |
|---------|-------------|----|
| 0000000 | RAM Bank 0  | •  |
|         |             | Ν  |
|         |             | 6  |
| 1000000 | Ram Bank 1  | •  |
|         |             | D  |
|         |             | "5 |
| 2000000 | RAM Bank 2  |    |
| 2000000 |             | tł |
|         |             | a  |
|         |             | ť  |
| 3000000 | DAM Deals 2 |    |
| 300000  | RAM Bank 3  |    |
| 4000000 | Video       | •  |
|         |             | is |

• RAM Banks may be made up of 1 Mbit or 4 Mbit DRAMs, providing up to 64 Mbytes of memory.

• When a bank is filled with 1 Mbit DRAMs, the memory contents are "shadowed" four times.

• If a bank is not populated with DRAM, the RAM+ chip still responds with an ack32\_ to all requests. No errors (other than possible parity errors) are returned.

• The base address of the Frame Buffer is programmable.

## 3.7.3 SBus INTERFACE

#### 3.7.3.1 DRAM Access

All DRAM timing diagrams assume no contention for the DRAM. If the SBus request is lower priority than another requestor, waitstates will be added. Writes will only be delayed if the Write Buffer is full. DRAM and Video Register accesses are initiated by seeing both sb\_as\_ and ramsel\_ asserted on the rising edge of an sb\_clk. In the following diagrams, the logical AND of sb\_as\_ and ramsel\_ is shown as sel\_.

## • Word Read

RAM+ reads are done in the "fast mode" of the RAM chip. sb\_rd is high:



## Figure: 3.11 Word Read

The following diagram shows the capture of data from the ram data bus to the sb data bus:

## Figure: 3.12 Word Read 2



# • Word Write - Buffered

Writes go directly into the write buffer and release the bus. sb\_rd is low:



Figure: 3.13 Word Write

The data on the sb\_d bus is sampled on the same clock as sb\_as\_ and ramsel. Data on the ram\_d bus is driven on the falling edge of sb\_clk. (It is possible that this cycle will need to be extended one clock such that the ram\_d bus is driven on the falling edge of cycle 2, rather than cycle 1. This would not slow down the ack32\_ response, however. (This would be because of writebuffer fallthrough time, and also because the burst writes must wait until cycle 2 for their first cas, as well.)

#### • Burst Read

Only an 8-byte Burst Read is shown. For a 16-byte burst, add two more clocks. For a 32-byte burst, add 6 more clocks. **sb\_rd** is high:





SBus addresses will not change during a burst access. The ma address lines must increment themselves, wrapping around mod(8) for 8-byte transfers, mod(16) for 16-bytes transfers, and mod(32) for 32-byte transfers. (In reality, no 8-byte transfer will ever take place *except* on a longword boundary. 16 and 32-byte transfers may take place on any word boundary.)

## • Burst Write

Only an 8-byte Burst Write is shown, and the write buffer is not full. sb\_rd is low:





## 3.7.3.2 Address Mapping

The row and column address bits for the RAM+ chip are compatible with the RAM chip in its 4Mbit mode. No 1Mbit mode is available.

| sb a     | ma       |
|----------|----------|
| a0       | byte     |
| a0<br>a1 | byte     |
| a1<br>a2 | col0     |
|          |          |
| a3       | col1     |
| a4       | col2     |
| a5       | col3     |
| a6       | col4     |
| a7       | col5     |
| a8       | col6     |
| a9       | col7     |
| a10      | col8     |
| a11      | col9     |
| a12      | row0     |
| a13      | row1     |
| a14      | row2     |
| a15      | row3     |
| a16      | row4     |
| a17      | row5     |
| a18      | row6     |
| a19      | row7     |
| a20      | row8     |
| a21      | row9     |
| a22      | row10    |
| a23      | col10    |
| a24      | set0     |
| a25      | set1     |
| a26      | ram_/reg |
| a27      | bank     |
|          | 244 Br   |

Byte[1:0] specifies which byte within the word will be accessed. Set[1:0] specifies which of the four ras/cas sets will be accessed. Ram\_/reg is low to access DRAM, high to access video registers. Bank is the bank strapping pin.

## 3.7.4 DETAILED TIMING

# 3.7.4.1 DRAM Timing

The ram+ chip is designed to work with 80 nsec 1Mb and 4Mb fast page mode DRAMs at 20 MHz SBus clock, and 100 nsec DRAMs at 16.67 MHz. The crossover point between the two DRAMs is tbd.

## **DRAM Errors**

When memory parity errors are reported (either as a result of processor or DVMA activity) a *physical* address is reported, along with the contents of the memory error register. The following table maps physical addresses and error register bits to SIMM locations.

## Table: 3.12 DRAM maps physical addresses to SIMM Locations

| Address Base | Error Register Bit | S                                   |
|--------------|--------------------|-------------------------------------|
|              | 8 (D[7:0])         | 4 (D[15:8])2 (D[23:16])1 (D[31:24]) |
| 0x0          | U0322              | U0307U0309U0311                     |
| 0x1000000    | U0321              | U0308U0310U0312                     |
| 0x2000000    | U0320              | U0315U0314U0313                     |
| 0x3000000    | U0316              | U0317U0318U0319                     |

#### DRAM

For further details on the DRAM subsystem of, see the RAM+ Controller Specification.

## 3.8 The MMU+

# 3.8.1 Features

- Provides data paths to Sun-4 SRAM MMU
- Updates MMU statistics word
- Provides decodes and timing strobes for Type-1 devices
- Prioritizes 15 levels of interrupts
- 4-bit context register allows 16 contexts
- Two counters generate high-resolution periodic interrupts
- Crystal oscillator for serial ports
- Assumes 20 nsec page and segment RAMS: one clock write cycles.
- Supports up to 256 PMEGS

# Figure: 3.16 Segment Map & Page Map



# 3.8.2 Pin Description

The MMU+ is built in a 160-pin plastic flat pack. It has 40 X outputs, 48 Y bidirectional pins, 36 Z inputs, 17 A VCC pins, and 19 B grounds.

## 3.8.2.1 SBus Interface

|         | sb_clk        | (DRVT4) System clock. This signal runs at up to 20 MHz with a 50%                                                                                                                                    |
|---------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 30_CIR        | duty cycle.                                                                                                                                                                                          |
|         | sb_a[3:0]     | (TLCHT) Low-order sbus address lines used for internal byte and register                                                                                                                             |
|         | —             | selects.                                                                                                                                                                                             |
|         | sb_rd         | (TLCHT) High during sbus read cycles, low during write cycles.                                                                                                                                       |
|         | sb_as_        | (TLCHT) SBus Address Strobe. Low during valid SBus cycles.                                                                                                                                           |
|         | sb_reset_     | (TLCHT) Low to reset SBus devices.                                                                                                                                                                   |
|         | sb_ack8_      | (BT4) SBus 8-bit acknowledge. Used to terminate an SBus cycle when<br>the addressed device is 8 bits wide.                                                                                           |
|         | iod[7:0]      | (BD4) 8-bit buffered extension of SBus for on-board data. Used to access on-chip registers and MMU RAMs.                                                                                             |
|         | pio[7:0]      | (BD4TOD) Pseudo-bidirectional parel port pins. to use as inputs, the controlling register should be programmed with 1's. To use as out puts, the pin should have a pullup resistor added externally. |
|         | ctl[2:0]      | (TLCHT) Encoded control space selects from Cache+ chip. Private signal from cache chip.                                                                                                              |
|         | devspc_       | (TLCHT) Low for device space accesses, High for control space accesses.<br>Private signal from cache chip.                                                                                           |
|         | user_         | (TLCHT) Low for user space accesses, high for supervisor space                                                                                                                                       |
|         | sb_bg[3:0]    | accesses.<br>(TLCHT) Any one of these signals is Low during DVMA accesses.                                                                                                                           |
|         | 30_08[3.0]    | Forces CID output to zero.                                                                                                                                                                           |
|         | devspc_       | (TLCHT) Low for device space accesses, High for control space accesses.                                                                                                                              |
|         |               | Private signal from cache chip.                                                                                                                                                                      |
|         | user_         | (TLCHT) Low for User Space accesses, High for Supervisor Space accesses. Private signal from cache chip.                                                                                             |
|         | sb_bg[3:0]_   |                                                                                                                                                                                                      |
|         |               | (TLCHT) Any one of these signals is Low during DVMA accesses.<br>Forces CID output to zero.                                                                                                          |
| 3.8.2.2 | MMU Interface |                                                                                                                                                                                                      |
|         | cid[3:0]      | (BT2) Context ID to Segment Map RAMs.                                                                                                                                                                |
|         | pmeg[7:0]     | (BD4TD) Page Map Entry Group. Data bits to/from Segment Map RAMs; used for programming Segment Map.                                                                                                  |
|         | pa[27:12]     | (BD4T) SBus Physical Address bits to/from Page Map RAMs. Used for programming Page Map and as inputs for decodes.                                                                                    |
|         | mmu[v,w,s,x]  | (BD4T) MMU Valid, Write-allowed, Supervisor-only, don't-cache bits to/from Page Map RAMs. Used to program Page Map and as inputs for permission checks.                                              |

|         | mmu_typ[1:0] | (BD4T) MMU Type bits to/from Page Map RAMs. Used to program Page Map and as inputs for decodes. The type bits are essentially extensions of the physical address output where Type 0 is on-board RAM and Type1 is IO and SBus. Types 2 and 3 are not used on this newer design, but are supported for VME-based machines. |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | mmu[a,m]     | (BD4T) MMU Accessed and Modified bits to/from Page Map RAMs.<br>Used to program Page Map and updated during all device-space accesses.<br>Any access to a page marks the <b>a</b> bit to one, while any successful write<br>to a page marks the <b>m</b> bit to one.                                                      |
|         | sm_wr_       | (BT4) Segment Map Write Enable.                                                                                                                                                                                                                                                                                           |
|         | pm_wr[2:0]_  | (BT4) Page Map Write Enables.                                                                                                                                                                                                                                                                                             |
| 3.8.2.3 | Decodes      |                                                                                                                                                                                                                                                                                                                           |
|         | ramsel_[1.0] | (BT2) DRAM select. Asynchronous Decode                                                                                                                                                                                                                                                                                    |
|         | kbm_rd_      | (BT2) Read Strobe for 85C30. Asserted during reads and during reset. Synchronization hold-off is guaranteed.                                                                                                                                                                                                              |
|         | kbm_wr_      | (BT2) Write Strobe for 85C30. Asserted during writes and during reset. Synchronization hold-off is guaranteed.                                                                                                                                                                                                            |
|         | scc_rd_      | (BT2) Read Strobe for 85C30. Asserted during reads and during reset. Synchronization hold-off is guaranteed.                                                                                                                                                                                                              |
|         | scc_wr_      | (BT2) Write Strobe for 85C30. Asserted during writes and during reset. Synchronization hold-off is guaranteed.                                                                                                                                                                                                            |
|         | tod_cs_      | (BT2) Chip-select signal (active low) for MK48T08 TOD/NVRAM chip.                                                                                                                                                                                                                                                         |
|         | par_cs_[1.0] | (BT2) Chip-select signal (active low) for parity control/status register in RAM2 chip                                                                                                                                                                                                                                     |
|         | eprom_rd_    | (BT2) Read/Output Enable for EPROM accesses.                                                                                                                                                                                                                                                                              |
|         | fd_rd_       | (BT2) Active-low floppy controller read strobe.                                                                                                                                                                                                                                                                           |
|         | rd_wr_       | (BT2) Active-low floppy controller write strobe.                                                                                                                                                                                                                                                                          |
|         | iosel_       | (BT2) Select for Type 1 device                                                                                                                                                                                                                                                                                            |
|         | sb_sel[3:0]_ | (BT2) SBus selects Asynchronous decodes.                                                                                                                                                                                                                                                                                  |
|         | iod_en_      | (BT2) iod bus enable. Asserted low whenever an access takes place on the iod bus.                                                                                                                                                                                                                                         |

| sb_merr_        | (TLCHTN) sbus memory error/async error signal. Used to generate<br>non-maskable interrupt when an async error occurs. Edge-sensitive.<br><i>External Pullup Required</i> . |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| irq[13:11,9:1]_ | (SCHMITCN) Interrupt request inputs. External Pullup Required.                                                                                                             |
| iu_irl{3:0}     | (BT2) Encoded Interrupt Requests to Integer Unit. Positive-true; zero indicates no interrupts pending, 0xF indicates a level-15 (non-maskable) interrupt is pending.       |
| Miscellaneous   |                                                                                                                                                                            |
| const_clk       | (TLCHT) x-MHz clock used for counter-timers.                                                                                                                               |
| XSO/XSI         | Oscillator input/output pins for 19.66 MHz xtal.                                                                                                                           |
| sclk4           | (BT2) Serial port clock; XSI divided by four.                                                                                                                              |
| pio[7:0]        | (BD4TOD) Pseudo-bidirectional parallel port pins. To use as inputs, the                                                                                                    |

#### 3.8.2.4

| const_clk                      | (TLCHT) x-MHz clock used for counter-timers.                                                                                                                                                           |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XSO/XSI                        | Oscillator input/output pins for 19.66 MHz xtal.                                                                                                                                                       |
| sclk4                          | (BT2) Serial port clock; XSI divided by four.                                                                                                                                                          |
| pio[7:0]                       | (BD4TOD) Pseudo-bidirectional parallel port pins. To use as inputs, the controlling register should be programmed with 1's. To use as outputs, the pin should have a pullup resistor added externally. |
| od_                            | (TLCHTU)                                                                                                                                                                                               |
| para<br>32 in, 32 out, 48 bidi | (BT1) Parametric output for testing only. rect 112 total.                                                                                                                                              |

## 3.8.3 Clock Generation

## 3.8.3.1 General Description

The MMU+ chip generates all system level clocks required for the IU, FPU, SBus and Ram+ controller. The input clock frequency is four times the desired Sbus frequency. The clock logic will generate a divide by two output for the IU and FPU. The clock is further divided (by four with respect to the input ) to provide the Sbus and ram controller clocks. While the Sbus clocks are 50-50 duty cycle, the ram controller clocks are 25-75 and 75-25.



#### 3.8.3.2 Constant Clock

A constant clock input is used to provide a 100nS clock to the counter-timers. Since the main clock and SBus clock frequencies are subject to change, this input is required.

#### 3.8.3.3 Serial Clock

The MMU+ chip has a serial clock oscillator circuit used for generation of a 4.91 Mhz, 50-50 duty cycle clock. This clock is used by the 85C30 serial chips. The primary frequency of the crystal is 19.66Mhz.



## 3.8.4 Decodes

#### 3.8.4.1 Control Space

#### • CTL mappings

The devspc\_ signal from the cache+ chip chooses between device space and control space accesses. Device space accesses are accessed with physical addresses provided by the MMU RAMs, while control space accesses are identified by virtual addresses (decoded from the IU by the cache+ chip onto the ctl[n] lines). When devspc\_ is high, the ctl lines have the following meaning:

| Table: | 3.13 | CTL | mappings |
|--------|------|-----|----------|
|--------|------|-----|----------|

| ctl | Device                       |
|-----|------------------------------|
| 0   | Cache+ internal (no action)  |
| 1   | Reserved for VME IAck        |
| 2   | Context Register             |
| 3   | Diagnostic Register (unused) |
| 4   | SCC Bypass                   |
| 5   | Segment Map                  |
| 6   | Page Map                     |
| 7   | EPROM Bypass                 |

#### Context Register Access

Writing to or reading from ASI 2, VAdr 0x3000000 causes the cache+ chip to decode for context register accesses. The MMU+ chip will reply with an **sb\_ack8**. Only byte writes or reads should be done. Only the least significant four bits of the byte are used as a context register. Writes to this address will go to both copies of the context register: in the MMU+ chip (and to the MMU SRAMs) and in the cache+ chip (to be used for cache tag comparisons). Reads from this location will come from the MMU+ chip, while reads from ASI 2, VAdr 0x30000001 will get data from the cache+ chip. This difference in read behavior is for diagnostic purposes only.

All internal register accesses use the iod[7:0] bus to transfer data. This bus is simply a buffered version of  $sb_d[31:24]$ . It is enabled with  $ioden_low$ .

An internal register cycle is shown below:

Figure: 3.17 Internal Register Cycle



## • SCC Bypass

Writing to or reading from ASI 2, VAdr 0xF0000000 will bypass the MMU and provide access to the SCC. See SCC/Keyboard-Mouse accesses for further timing details. ctl[2:0] = 0x4 for these accesses.

#### • EPROM Bypass

Supervisor Instruction accesses made while the system is in *boot* state will cause the cache+ chip to operate in control space with ctl[2:0] = 0x7. These cycles will be forced to EPROM accesses on reads, and no device will be selected on writes.

# • Segment Map Access

Writing to or reading from ASI 3 will access the segment map RAM(s). The location accessed is specified by the combination of the current context register value and virtual address lines sb a[29:18].

The cache+ chip enforces the restriction that the top three address lines, a[31:29] must either all be ones or all be zeros.

The number of contexts supported (8 or 16) is system-dependent. The mmu+ chip supports up to 16 contexts.

Segment Map write cycles cause the iod[7:0] value to be driven onto the pmeg[7:0] lines. The output of the Page Map is ignored for this (and all control space) cycle.

The sb a[29:18] and ctxt[3:0] signals are valid by the clock cycle in which sb\_as\_ is asserted:



Figure: 3.18 Clock Cycle

The sm\_wr\_signal is asserted for one clock. The first half-clock is used to allow the segment ram to get off the pmeg databus. During the second half-clock the mmu drives the value from the iodata bus onto the pmeg bus. The mmu continues to drive this data for the half-clock after sm\_wr\_ is negated to allow for hold time. During this clock, both the segment map RAM and the mmu+ will be driving the same data onto the pmeg bus. The sb\_a[29:18] lines must not change in the clock following sb\_as\_ negation on segment map access cycles.

Critical Path: ioden\_ to iod[7:0] valid to data out on pmeg[7:0]. Must all happen 40 nsec after sb\_clk rising edge.

Only byte accesses, with ls address bits zero, should be made to the Segment Map.

# • Page Map Access

Page map access is extended by 4 bits on the CPU-2CE for VME only. Writing to or reading from ASI 4 will access the Page Map RAMs. The location accessed is selected by the pmeg value (selected by the current context and sb\_a[29:18]) concatenated with sb\_a[17:12]. Timing is identical to the Segment Map cycles, except that for word accesses, four cycles will be done (because the mmu+ will respond with sb\_ack8\_). The page map value is defined as follows:

# Page Type Entry

| 31 |   |   |   |      | 24 |   | <br>19 | 0    |
|----|---|---|---|------|----|---|--------|------|
| v  | w | S | x | Туре | Α  | М |        | Page |

# • Page Type Bits

Bits 31 through 16 of the page map entry provide the following information about the page: 27 and 26 Type bits, which select device space access as shown in the following table.

# Table: 3.14 Page Type Bit Definitions

| Bit 27 | Bit 26 | Туре                  |
|--------|--------|-----------------------|
| 0      | 0      | Main memory (type 0)  |
| 0      | 1      | I/O space (type 1)    |
| 1      | 0      | VME D16 Port (type 2) |
| 1      | 1      | VME D32 Port (type 3) |

## 3.8.4.2 Device Space

| [    | Table: 3.15 Device Space   |                             |  |  |
|------|----------------------------|-----------------------------|--|--|
| Туре | Address                    | Device                      |  |  |
| 0    | 00XXXXXX<br>to<br>07XXXXXX | Ramsel [0] (on-board DRAM)  |  |  |
| 0    | 08XXXXXX<br>to<br>OFXXXXXX | Ramsel [1] (off-board DRAM) |  |  |
| 1    | F0X00XXX                   | Keyboard/Mouse              |  |  |
| 1    | F1X00XXX                   | SCC                         |  |  |
| 1    | F2X0XXXX                   | TOD, NVRAM                  |  |  |
| 1    | F3X00XXX                   | Counters                    |  |  |
| 1    | F4X00XX0                   | Parity Control/Status [0]   |  |  |
| 1    | F4X00XXX                   | Parity Control/Status [1]   |  |  |
| 1    | F5X00XXX                   | Interrupt Control           |  |  |
| 1    | F6XXXXXX                   | EPROM                       |  |  |
| 1    | F7200XXX                   | Floppy                      |  |  |
| 1    | F7201XXX                   | Audio                       |  |  |
| 1    | F7400XXX                   | Aux I/O                     |  |  |
| 1    | F8XXXXXX                   | SBSel Zero                  |  |  |
| 1    | F9XXXXXX                   |                             |  |  |
| 1    | FAXXXXXX                   | SBSel One                   |  |  |
| 1    | FBXXXXXX                   |                             |  |  |
| 1    | FCXXXXXX                   | SBSel Two                   |  |  |
| 1    | FDXXXXXX                   |                             |  |  |
| 1    | FEXXXXXX                   | FLASH (Optional Feature)    |  |  |
| 1    | FFXXXXXX                   | LED's and Hex Switch        |  |  |

SBus Select Zero is for on-board DMA on the CPU-2CE. Both Floppy and Audio use the  $fd_rd_$  and  $fd_wr_$  signals. The use of  $sb_a[12]$  to distinguish between the two devices is done at the board level, not in the mmu+ chip.

For Interrupt and Counter accesses, see the details in following chapters. **Devspc\_** is assumed low in the following diagrams.

## • SBus or DRAM Access

SBus and DRAM decodes are different from any other mmu+ decode. In these cases, the mmu+ does not provide any sbus acknowledge (the sbus device or ram controller is expected to do that) and the select signal is totally asynchronous. The sbus device or ram controller must look at both its select signal and sb\_as\_ in order to decode itself.

The following diagram shows an SBus or DRAM access:

## Figure: 3.19 SBus or DRAM Access



Sb\_ack{8,32} is not shown; it is generated by the slave device. The sb\_pa lines also include the mmu permissions and statistics bits. The ramsel\_output could as easily be an sb\_seln\_ signal. See the note on statistics updates regarding how quickly the physical address may change to guarantee correct operation on statistics update cycles.

#### • TOD, EPROM, Floppy Access

The 48T08, EPROM, and Floppy Controller/Audio chips have identical timings.

The EPROM and 48T08 are assumed to have a 200 nsec access time.

#### Figure: 3.20 Scan EPROM Access



Figure: 3.21 2nd EPROM Access



Note that the wr\_ strobe (or cs\_, in the case of the TOD chip) is asserted *before* the data is valid. The iod bus makes setup to the trailing edge of the wr\_ strobe. In addition, the minimum wr\_ low time for the Am79C30 is 200 nsec. This is guaranteed by the fact that LSI's process goes low faster than high.Writes to the EPROM will return an sb\_ack8\_ but will not enable any chip.

# • Parity Register Access

Access of the parity control register does *not* cause **ioden** to be asserted, since the register is in the ram+ gate array on the sb\_d bus, rather than the **iod** bus.





## SCC/KB Mouse Access

The 85C30 Serial Communications Controllers used for the serial ports and for the Keyboard/Mouse ports have longer access times than other 8-bit peripherals. In addition, the mmu+ chip guarantees 1 uSecond of hold-off time between accesses.

A 6 MHz 85C30 is assumed, with 180 nsec rd-datavalid delay, 200 nsec rd width, 300 use Adr-to-rd-datavalid, 200 nsec wr width, 10 nsec write-data-valid-to-write-asserted delay.





#### 3.8.5 Protection Checking

An access violation may occur on any device space cycle. When **sb\_as\_** is recognized along with any access violation, no statistics update cycle will take place, and no device will be selected. Error reporting is done by the cache+ chip. The following rules must be satisfied to allow a cycle to take place:

• if user\_ is low, mmu\_s must be low

• if sb\_rd is low or ctl[1] is high, mmu\_w must be high. ctl[0] must be low.

• Ctl[0] is used by the cache+ chip to report an address violation in which iu\_a[31:29] were not either all ones or all zeroes. Ctl[1] is used to report a load-store cycle, which must not take place if the page is not writable.

## 3.8.6 Statistics Updates

Every successful device-space access will cause a statistics update cycle to take place to the current page map entry. A read-modify-write cycle is done on the statistics byte  $(pm_wr[2])$ . The mmu\_a bit is set to one, and the mmu\_m bit is OR-ed with one if this is a read cycle. Because of this cycle, the cache+ chip must guarantee that the high-order virtual address lines  $(sb_a[29:12])$  does not change for 2 clocks after the assertion of  $sb_as_b$ .

## Figure: 3.24 Statistics Updates



As with the normal page map and segment map writes, the page map write enable signal is asserted in clock 2, and the mmu+ drives the statistics bits in the second half of clock 2 and the first half of clock 3. The write-enable signal is negated in clock 3. In order to provide address hold time, the input addresses may not change until clock 4.

~ 4

# 3.8.7 Interrupts

The Interrupt Register provides for software generation of interrupts and allows the CPU to disable all interrupts or only certain ones. It is cleared on **sb\_reset\_**, and has the following fields:

31

| 51            |          |               |              |          |          |          |               |
|---------------|----------|---------------|--------------|----------|----------|----------|---------------|
| Enabled<br>14 | Reserved | Enabled<br>10 | Enabled<br>8 | SWI<br>6 | SWI<br>4 | SWI<br>1 | Enable<br>Any |
| Address Tim   |          | Address Av    | 500 0000     |          |          |          |               |

Address Type 1, Physical Address 0xF500 0000

• All irq[13:1] inputs may be asynchronous to the system clock.

• Software interrupts may be generated on levels 6, 4, and 1 by writing a 1 into bits 27, 26, or 25 when interrupts are enabled (bit 24 high).

• Level 15 interrupts (maskable only by the Enable Any bit) are captured from the sb\_merr\_ input. sb\_merr\_ is ignored on *cpu read* cycles, when the Cache+ chip would be generating a synchronous error. These cycles are identified by all sb\_bgn\_ negated and a one-clock-delayed version of sb\_rd asserted.

• Writing a zero to the Enable Interrupts bit (24) clears any pending level 15 interrupt.

• Writing a zero to any of the Enable bits in the Interrupt Register only masks out that levels interrupt. It does not clear the source, with the exception of level 15 requests. This is different from the Sun-4 architecture, in that the periodic interrupts at levels 10 and 14 must be cleared by accessing their respective Limit Registers (see "Counters" below).

See the SUN Calvin System Specification for a list of mappings between interrupt levels and interrupting devices.

## 3.8.8 Counters

The MMU+ has two microsecond-resolution counter/timers which provide periodic interrupts at levels 10 and 14. There are two counter registers and two limit registers. Interrupts occur when they are enabled in the Interrupt Register and the counter reaches the value preset in its corresponding limit register.

• Each counter is set to 1.0 uSec on sb\_reset\_ and free-runs.

• The least significant 10 bits of each counter always read as zeroes to allow for future expansion to sub-microsecond resolution.

• When a counter reaches the value set in its limit register, it is set back to 1.0 on the following increment, and the Limit Reached bit is set.

- Counter 0 interrupts at Level 10 when enabled.
- Counter 1 interrupts at Level 14 when enabled.

Hardware

• Reading a Limit register clears its Limit Reached bit, clearing the pending interrupt. Clearing the level 10 or 14 bit in the Interrupt register does not clear a pending interrupt; it only masks it.

- Each Limit register is set to all 0's on sb\_reset\_, allowing the counter to freerun.
- Writing to a Limit Register will set its corresponding Counter back to 1.0 uSec.

• Both counters may be read at any time, and are guaranteed by hardware not to increment during a word read operation.

• Both counters are separately writable for testing purposes. They should not be written in normal operation as results would be unpredictable.

Figure: 3.25 Counter

Counter 0 0xF3000 0000 Counter 1 0xF3000 008

Limit Counter Value 0 Reached

## Figure: 3.26 2nd Counter

|                                            | 31               | 10               |   |
|--------------------------------------------|------------------|------------------|---|
| Limit 0 0xF300 0004<br>Limit 1 0xF300 000C | Limit<br>Reached | Comparator Value | 0 |

#### 3.8.9 I/O Register

An 8-bit parallel port exists at Type 1 Physical Address  $0xF740\ 0000$ . It is a pseudo-bidirectional port which can read the value at its pins and has open-drain outputs. To use an individual bit as an input, it should be always written with a "1" to avoid contention on that pin.

- All bits are set to 1's on sb\_reset\_.
- See the SUN Calvin System Specification for the functional mappings of the bits.
- Bits which may be used as outputs must have an external pullup resistor.

## 3.9 P2 Bus Interface Overview

Illustrations of the P1/P2 connectors of the SPARC CPU-2CE card can be found in Section 2. The P1 and P2 connectors are identical.

## 3.9.1 P1/P2 Connector Numbering

The CPU-2CE follows standard VME pin numbering of 3 rows of 32 pins on each connector. See section 2 for the pin signals.

## 3.10 Serial Interface A and B

## 3.10.1 Serial Interface A and B Device Address

The address of Serial Interface A is 0xE2000000.

On-Board Input/Output (OBIO)

## 3.10.1.1 RS232/RS423 Jumper Selection

The serial ports are RS-232-C or RS-423 with the default being RS-232-C. If RS-423 is needed, set the block before power up. Move the jumpers position to set RS-423. See the next page for the CPU-2CE defaults. The two ports are linked so both must be either RS-232-C or RS-423. See section 2 for pin signals.

## 3.10.2 Serial Interface A/B Definition

The A serial port interface supports asynchronous RS-423 with full modem control lines. For most applications, the interface will be directly compatible with RS-232 equipment as well. In addition to the RS-423 interface logic, four of the signals are brought out to separate connector pins via RS-423 compatible drivers and receivers. Transmit Data (TxD), Receive Data (RxD), Request to Send (RTS) and Clear to Send (CTS) signals are provided for use in electrically noisy environments or where longer cable lengths are required.

#### 3.10.3 Serial Interface A/B Performance

Asynchronous Speed: 19.2 Kbaud

The maximum baud rate supported by the Boot PROM on the SPARC CPU-2CE is 19.2K bits/second and assumes a 1/16 bit clock divisor. Faster bit rates can be programmed for custom applications. Refer to the **Z8530 SCC Technical Manuals** for more details. For reference, the clock input to the SCC for baud rate generation is 4.9152 MHz.

The A/B serial port interface does support Synchronous Serial Communications. RS-232 limits transmission rates in asynchronous mode to 20K bits/second, and RS-423 limits data rates to 100K bits/second.

Figure: 3.27 RS-232/423 Jumper Blocks



# **BOARD JUMPERS**

## 3.11 Keyboard/Mouse Interface

## 3.11.1 Keyboard/Mouse Device Address

The keyboard/mouse address is 0xF0000000.

On-Board Input/Output (OBIO)

## 3.11.2 Keyboard/Mouse Interface Definition

The keyboard/mouse serial interfaces are implemented with a Z8530 Synchronous Serial Communications Controller. The SCC features two programmable serial channels with built in baud-rate generators. The clock input to the SCC for baud-rate generation is 4.9152 MHz and is independent of the IU clock.

Reset of the keyboard/mouse SCC is forced at power-up by asserting both read and write strobes simultaneously.

Mouse and keyboard data are transmitted and received over connector J1101 (DB-15). All data signals are TTL-compatible and cannot be direct-connected to RS-232, RS-423, or other non-TTL compatible equipment.

#### 3.11.3 Specifications

The keyboard/mouse interfaces are designed to connect to Sun type-3 and type-4 keyboards. The Boot PROM will interrogate the interface upon power-up to determine if a keyboard is present. If not, the PROM expects a terminal to be connected to the Serial A port.

NOTE: The keyboard/mouse interface is intended for use with Sun keyboards only; custom serial expansion via this interface requires Boot PROM modifications.

# Section 4

# APPENDICES TO THE HARDWARE USER'S MANUAL

## The CPU Card Schematic Diagrams

This appendix provides schematic diagrams of the key interfaces in the SPARC CPU-2CE for better understanding.

All of the included schematics and drawings are listed below:

**DWG Schematics** 

Serial Cable Drawing

Ethernet Cable Drawing

Reader Comment Card

Product Error Report

| 8 | ٦                                                                  | 6                                                                                                                    | 5                  | 4                                                           | 3            | 2                                                              | 1                                                    |   |
|---|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------|--------------|----------------------------------------------------------------|------------------------------------------------------|---|
| D |                                                                    | JER                                                                                                                  |                    |                                                             | $\top$       |                                                                |                                                      | E |
|   | LEDGEND<br>3 IU &                                                  | CACHE                                                                                                                |                    |                                                             |              |                                                                |                                                      |   |
| c | 4 MMU 8<br>5 MMU 8<br>6 RAMPL<br>7 16 MB<br>8 SLOTE                | MMUPLUS<br>XTENSIONS EN<br>US & EXPANSIONS<br>YTE RAM ARRA<br>SCSI & ENE<br>II CON & VME<br>INF<br>INF<br>INF<br>INF | ON CONNS<br>Y<br>T |                                                             |              |                                                                |                                                      | c |
| в | 15 SERIA<br>16 FLOPA<br>17 RESE<br>18 SBUS<br>19 PULLU<br>20 DECOU | AL INF<br>PY / AUDIO<br>F / DIAGNOSTIO<br>CONNECTORS<br>JPS & TP'S<br>JPLERS                                         |                    | UFF ADDED AT                                                | THE LAST MIN | JTE                                                            |                                                      | в |
| A |                                                                    |                                                                                                                      |                    |                                                             |              | ·                                                              |                                                      | • |
|   |                                                                    | F                                                                                                                    | Campb              | nputers, Inc.<br>211, California 35000 USA<br>1GHT (C) 1990 | COVER S      | U2C Tue Jun 2 16:02:3<br>HEET 2<br>ANNING NO.<br>605-12357-101 | 5 1992 ENGINEER:<br>BILL MEARS<br>REU: PAGE: 2 OF 21 |   |
| 8 | 7                                                                  | 6                                                                                                                    | 5                  | 4                                                           | з            | 2                                                              | 1                                                    |   |







|   | 8 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 6 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|   | (3) Famelk 18 Ren CLK<br>(3) Famelk 18 Ren CLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | U99                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DRAM BLOCK<br>DETAILS ON PAGE 7<br>DRAMIGAT<br>X55 VCC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 8P<br>U115<br>50C0M50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
| D | (3) Factor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Image: Section of the section of t                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CCC<br>CND<br>CND<br>CND<br>CND<br>CND<br>CND<br>CND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | grid         1         00d           ramd(30)         ramd(10)         ramd(10)         ramd(10)           ramd(20)         ramd(10)         ramd(10)         ramd(10)           ramd(20)         ramd(10)         ramd(10)         ramd(10)           ramd(20)         ramd(10)         ramd(10)         ramd(10)           ramd(20)         ramd(10)         ramd(10)         ramd(10)           ramd(21)         ramd(21)         ramd(21)         ramd(21)           ramd(22)         ramd(10)         ramd(20)         ramd(21)           ramd(22)         ramd(10)         ramd(21)         ramd(22)           ramd(22)         ramd(10)         ramd(22)         ramd(21)           ramd(22)         ramd(21)         ramd(22)         ramd(22)           ramd(22)         ramd(21)         ramd(22)         ramd(22)           ramd(22)         ramd(21)         ramd(22)         ramd(22)           ramd(22)         ramd(21)         ramd(21)         ramd(22)           ramd(22)         ramd(22)         ramd(22)         ramd(22) | ם |
| с | Dat(10) <u>155</u> 308.11<br>Dat(10) <u>155</u> 308.11<br>Dat(10) <u>155</u> 308.01<br>Dat(10) <u>155</u> 308.00<br>Dat(10) <u>155</u> 308.00<br>Dat(10) <u>155</u> 308.00<br>Dat(10) <u>155</u> 308.00<br><u>155</u> 788.00<br><u>155</u> 788.00<br><u></u> | UB1<br>escape 2 be ve p33 mar(10)*<br>ma(5) 2 be ve p33 mar(10)*<br>ma(5) 4 be ve p33 mar(10)*<br>ma(7) 5 be ve p33 mar(10)*<br>ma(7) 5 be ve p33 mar(10)*<br>ma(7) 5 be ve p33 mar(10)*<br>mar(7) 5 be ve p33 mar(10)*<br>mar(10) 5 be ve p33                                                                                                                                                                                                                                                                                                                 | ramd(7) D7<br>ramd(5) D6<br>ramd(5) D5<br>ramd(4) D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | rand(20)     A(5)     A(5)       vcc     A(6)     A(7)       rand(10)     A(7)     A(7) <tr< th=""><th>c</th></tr<>                                                                   | c |
|   | 1       d(31)       1       abd31       rd31       19       rwd(31)         1       d(32)       2       abd32       rd30       19       rwd(20)         1       d(22)       2       abd29       rd29       190       rwd(20)         1       d(22)       42       abd29       rd29       190       rwd(20)         1       d(27)       40       abd27       rd27       111       rwd(27)         1       d(26)       41       abd27       rd27       111       rwd(27)         1       d(26)       41       abd27       rd27       111       wwd(27)         1       d(26)       41       abd27       rd27       111       wwd(27)         1       d(26)       31       abd27       rd27       111       wwd(27)         1       d(26)       32       abd27       rd27       111       wwd(27)         1       d(26)       32       abd27       rd27       111       wwd(27)         1       d(26)       34       abd27       rd27       111       wwd(27)         1       d(19)       36       abd18       rd19       12       wwd(28)<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Heic     T     Dis     TS     Clip     Heic       CASICAL     0     0     0     0     0       CASICAL     9     07     0     06     CASICAL       CASICAL     10     0     10     0     10       CASICAL     10     0     10     0     10       CASICAL     10     0     11     0     0       CASICAL     0     0     10     0     10       CND     2     0     1     0     10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ramd(3)<br>ramd(2)<br>D2<br>ramd(2)<br>D1<br>ramd(2)<br>D0<br>parit(3)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(2)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3)<br>parit(3) | grid     ai     bit ord       mat(1)     Ai     bit       mat(2)     Ai     bit       bit     bit     bit       bit     bit     bit                                                                                                                                                                                                                                                                                                                                                                                    |   |
| B | d(2) <u>10</u> sbd82 rd82 rd83<br>d(1) <u>79</u> sbd81 rd81 <u>10</u> rea(1)<br>d(1) <u>60</u> sbd80 rd86 <u>rd86</u> <u>11</u> rea(1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3P<br>U8<br>Memory Expansion Connector<br>PBrcs 1+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | HA<br>maa (5)3<br>maa (3)3<br>maa (3)3<br>maa (2)3<br>maa (2)3<br>maa (2)3<br>maa (2)3<br>maa (2)3<br>maa (2)3<br>Cas (3)4<br>Cas (3)4<br>C    | vcc nig = 2 3is vcc<br>Aig = 3 3is vcc                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Ъ |
| A | (1.2.4.7) 25% 57<br>(1.2.4.7) 25% 57<br>(1.2.4.7) 22<br>(1.2.4.7) 22<br>(1.2.4.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PA (27)<br>PA (27)<br>(513111 a) 7 5 3 11<br>PB (26)<br>VCC (151311 a) 7 5 3 1<br>16 14 12 10 8 6 4 2<br>PB (20)<br>PB (26)<br>PB (26) | ₩ <u>₽₽</u> ₩<br>RA5*<br>rasa< <u>0&gt;</u> *<br>BANK 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | add Power and grounds                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A |
|   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | VCC & GND on connector to respective planes<br>INTENDED FOR SRX CARD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Computer<br>Campbell, Califor<br>COPYRIGHT (c) 195                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PU2C         Mon         Jul         20         15:58:18         1992         ENGINEER:           EXPANSION         CONN'S         BILL         MEARS           RAWING NO.         REU:         PAGE:         6         0F         21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
|   | . 6 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 6 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |

























.







#### Section 5

#### **ABSTRACT COPIES OF DATA SHEETS**

SPARC Processor Weitek W8701 SCSI NCR53C90A AM7990 LANCE DRAM Audio Interface AMD 79C30 Floppy Controller INTEL 82072 FLASH INTEL 28F020 (Optional Feature) Serial I/O AMD 85C30 and Keyboard Mouse Line Driver Signetics NE5170 Receiver NE5180 NVRAM Mostek 48T08 RTC-NVRAM VME

.

## W8701 INTEGRATED SPARC PROCESSOR TECHNICAL OVERVIEW

## ADVANCE DATA February 1991

.

This technical overview gives basic technical information about WEITEK's W8701 SPARC processor, which combines an integer unit and a floating-point coprocessor on a single chip.

| Contents<br>Features | 1          |
|----------------------|------------|
| Description          | 1          |
| Signal Description   | 2          |
| DC Specifications    | 4          |
| AC Specifications    | 5          |
| Pin Configuration    | 8          |
| Package Dimensions   | 9          |
| Ordering Information | 9          |
| Sales Offices        | back cover |
|                      |            |

W8701 Integrated SPARC Processor Technical Overview Advance Data February 1991

Copyright © WEITEK Corporation 1991 All rights reserved

WEITEK Corporation 1060 East Arques Avenue Sunnyvale, California 94086 Telephone (408) 738–8400

WEITEK is a trademark of WEITEK Corporation.

WEITEK Corporation assumes no responsibility for errors in this document, and retains the right to make changes at any time, without notice. Please contact your sales office to obtain the latest specifications before placing your order.

Written by Tovye Kanter-Henderson Edited by Robert Plamondon Line drawings by Tovye Kantor-Henderson and Robert Plamondon

Printed in the United States of America 92 91 6 5 4 3 2 1 DOC 9101

| · · ·    | W8701 INTEGRATED<br>SPARC PROCESSOR<br>TECHNICAL OVERVIEW |
|----------|-----------------------------------------------------------|
|          | ADVANCE DATA<br>February 1991                             |
| Features |                                                           |

single-chip pin-compatible replacement for the Cypress CY7C601 integer unit and either the WEITEK WTL 3171 or the Cypress CY7C602 floating-point coprocessor

Lower power and real estate requirements for both current and new designs

Higher floating-point performance (comparison)

Complete binary software compatibility with the Cypress (CY7C601/602), the Cypress-WEITEK (CY7C601/WTL 3171), and the LSI Logic L64811 IU/L68414 FPU chip sets

Available for bus clock speeds of 25, 33, and 40 MHz

#### Description

The W8701 is a single-chip replacement for the Cypress CY7C601/CY7C602 SPARC<sup>TM</sup> RISC chips. It contains a SPARC processor and floating-point coprocessor on a single die. The W8701 can be used as a production upgrade to current designs by plugging the W8701 into the CY7C601 processor socket, and leaving the coprocessor socket empty. This will provide higher throughput, lower power requirements, and reduce cost while maintaining full software compatibility.

The W8701 is an implementation of the version 7.0 SPARC architecture. It provides complete compatibility with the Cypress SPARC chip set or the Cypress-WEITEK combination chip set.

This document covers the features unique to the W8701 and provides complete electrical and mechanical specifications.



Figure 1. The W8701 SPARC processor: a single-socket Chip set

## Signal Description

In this chapter we will describe the W8701's external signal interface.

Memory subsystem interface signals

Interrupt and control signals

Integer to floating-point unit signals

Power and clock signals

### NOTATIONAL CONVENTIONS

Signals that are active low will be marked with a suffixed<sup>•</sup> dash (-) after the signal name. All other signals are active high. "Active" and "asserted" are equivalent terms, as are "inactive" and "de-asserted." When signals are shown as ones and zeroes, a "1" always indicates a voltage near VCC, while a "0" indicates a voltage near GND.

| Signal    | Description                        | Туре             |
|-----------|------------------------------------|------------------|
| A[31:0]   | Address bits                       | Tri-state Output |
| AOE       | Address Output Enable              | Input            |
| ASI[17:0] | Address Space ID                   | Tri-state Output |
| BHOLD-    | Hold signal from I/O bus           | Input            |
| COE-      | Control Output Enable              | Output           |
| D[31:0]   | Data                               | Tri-state        |
| DOE-      | Data Output Enable                 | Input            |
| DXFER     | Data Transfer                      | Tri-state Output |
| FNULL     | Floating-point unit null cycle     | Output           |
| IFT-      | Instruction cycle flush trap       | Input            |
| NULL      | Integer unit null cycle            | Output           |
| LDSTO     | Load and store (atomic)            | Tri-state output |
| LOCK      | Bus lock (multi-cycle instruction) | Tri-state output |
| MAO       | Memory address Output select       | Input            |
| MDS-      | Memory data strobe                 | Input            |
| MEXC-     | Memory exception                   | Input            |
| MHOLDA-   | Hold signal from memory            | Input            |
| MHOLDB-   | Hold signal from memory            | Input            |
| RD        | Read access                        | Tri-state output |
| SIZE[1:0] | Bus transaction size               | Tri-state output |
| WE-       | Write enable                       | Tri-state output |
| WRT       | Write Tag                          | Tri-state output |

Figure 2. Memory system interface signals

#### ADVANCE DATA February 1991

# Signal Description, continued

| Signal (Pin Name) | Description                | Туре   |
|-------------------|----------------------------|--------|
| ERROR-            | Internally generated error | Output |
| INTACK            | Interrupt acknowledge      | Output |
| IRL[3:0]          | Interrupt request level    | Input  |
| RESET-            | Reset input                | Input  |
| TOE-              | Test output enable         | Input  |

Figure 3. Interrupt and control signals

| Signal (Pin Name) | Description                   | Туре   |
|-------------------|-------------------------------|--------|
| FINS1             | Floating-Point Inst. Buffer 1 | Output |
| FINS2             | Floating-Point Inst. Buffer 2 | Output |
| FLUSH             | Flush Floating-point Unit     | Output |
| FXACK             | FPU Exception Acknowledge     | Output |
| INST              | Instruction Fetch             | Output |

Figure 4. Integer unit to floating-point unit signals

| Signal (Pin Name) | Description                  | Туре   |
|-------------------|------------------------------|--------|
| FCC[1:0]          | Floating-Point CC bits       | Output |
| FCCV              | Floating-Point CC bits valid | Output |
| FEXC-             | Floating-Point Exception     | Output |
| FHOLD-            | Hold signal from FPU         | Output |

Figure 5. Floating-point unit to integer unit signals

| Signal (Pin Name) | Description       | Туре  |
|-------------------|-------------------|-------|
| CLK               | Main Clock        | Input |
| VDDI              | Main Internal VCC | Power |
| VDDO              | Output Driver VCC | Power |
| VDDT              | Input Circuit VCC | Power |
| VSSI              | Main Internal GND | Power |
| vsso              | Output Driver GND | Power |
| VSST              | Input Circuit GND | Power |

Figure 6. Power and clock signals

# DC Specifications

## ABSOLUTE MAXIMUM RATINGS

|                                                    | Range                 |  |
|----------------------------------------------------|-----------------------|--|
| Storage Temperature                                | -65 °C to + 150 °C    |  |
| Ambient Temperature with Power Applied             | -55 °C to + 125 °C    |  |
| Supply Voltage to Ground Potential <sup>1</sup>    | -0.5 VDC to +7.0 VDC  |  |
| DC Voltage Applied to Outputs in High Z state      | -0.5 VDC to +7.0 VDC  |  |
| DC Input Voltage                                   | -3.0 VDC to +7.0 VDC  |  |
| DC Output Low sink Current                         | 30 mA                 |  |
| DC Input Current                                   | -10 mA to +10 mA      |  |
| Ambient Temperature* (T <sub>a</sub> )             | 0 °C to +70 °C        |  |
| Supply Voltage ( $V_{\infty}$ )                    | +4.5 VDC to + 5.5 VDC |  |
| Power Dissipation (all outputs floating) 2.2 watts |                       |  |

Figure 7. Absolute maximum ratings

## DC CHARACTERISTICS

| Parameter       | Description            | Test Conditions                                                                 | Minimum | Maximum         | Units |
|-----------------|------------------------|---------------------------------------------------------------------------------|---------|-----------------|-------|
| V <sub>OH</sub> | Output High Voltage    | $V_{cc} = Min$ , $l_{OH} = -2.0 \text{ mA}$                                     | 2.4     |                 | V     |
| V <sub>OL</sub> | Output Low Voltage     | V <sub>cc</sub> = Min, I <sub>OH</sub> = 8.0 mA                                 |         | 0.5             | l v   |
| V <sub>IH</sub> | Input High Voltage     |                                                                                 | 2.1     | V <sub>cc</sub> | v     |
| V <sub>IL</sub> | Input Low Voltage      |                                                                                 | -3.0    | 0.8             | V     |
| l <sub>iH</sub> | Input High Current     | $V_{cc} = Max, V_{IN} = V_{CC}$                                                 |         | +10             | μΑ    |
| 1 <sub>IL</sub> | Input Low Current      | V <sub>cc</sub> = Max,V <sub>IN</sub> =V <sub>SS</sub>                          |         | -10             | μΑ    |
| l <sub>oz</sub> | Output Leakage Current | Vcc=Max,<br>V <sub>IN</sub> =V <sub>SS</sub> ≤V <sub>OUT</sub> ≤V <sub>CC</sub> | -40     | +40             | μА    |
| l <sub>cc</sub> | Supply Current         | V <sub>CC</sub> = Max, f = 40 MHz                                               |         | 450             | mA    |
| l <sub>cc</sub> | Supply Current         | V <sub>CC</sub> = Max, f = 33 MHz                                               |         | 400             | mA    |

Figure 8. DC characteristics

## PIN CAPACITANCE

| Parameter       | Parameter Description                                                              | Value         |
|-----------------|------------------------------------------------------------------------------------|---------------|
| C <sub>IN</sub> | Input Capacitance ( $V_{CC}$ = 5.0 VDC, $T_A$ = 25 °C, f = 1 MHz)                  | 10 pF maximum |
| COUT            | Output Capacitance (V <sub>CC</sub> = 5.0 VDC, T <sub>A</sub> = 25 °C, f = 1 MHz)  | 12 pF maximum |
| C <sub>vo</sub> | I/O pin Capacitance (V <sub>CC</sub> = 5.0 VDC, T <sub>A</sub> = 25 °C, f = 1 MHz) | 15 pF maximum |

Figure 9. Pin capacitance

#### ADVANCE DATA February 1991

## AC Specifications

## NOTATIONAL CONVENTIONS

The individual AC specifications are not numbered; they are identified by the signal name and a parameter type

from the table in figure 10. Future editions will use WEITEK's usual notation for AC specifications.

| Signal                                                                                                                                                                                                                                       | Definition                                                                |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--|--|
| T <sub>do</sub>                                                                                                                                                                                                                              | Propagation delay time of an output referenced to a given clock edge      |  |  |
| Tho                                                                                                                                                                                                                                          | Hold time of an output referenced to a given clock edge                   |  |  |
| Tsi                                                                                                                                                                                                                                          | Setup time of an input referenced to a given clock edge                   |  |  |
| Thi                                                                                                                                                                                                                                          | Hold time of an input referenced to a given clock edge                    |  |  |
| Toff                                                                                                                                                                                                                                         | Turn off time for a tri-state output driver after the rising edge of DOE- |  |  |
| Ton                                                                                                                                                                                                                                          | Turn on time for a tri-state output driver after the falling edge of DOE- |  |  |
| CLK+                                                                                                                                                                                                                                         | The rising edge of clock CLK                                              |  |  |
| CLK-                                                                                                                                                                                                                                         | The falling edge of clock CLK                                             |  |  |
| CLOAD                                                                                                                                                                                                                                        | Output Load Capacitance: A load capacitance of 50 pF is assumed           |  |  |
| All times are given in ns. Clock references are made with respect to the 1.5 VDC level of the clock. HOLD signal $T_{do}$ from CLK+ must be 8 ns or less @ 33 MHz and 7ns or less @ 40 Mhz. $t_i = t_i \le 3ns$ . Inputs switch 0 to 3.0 VDC |                                                                           |  |  |

Figure 10. AC timing specification conventions

### OUTPUT SIGNALS

| Pin Name    | Parameter       | Ref Clock Edge | 33 MHz |     | Ref Clock Edge 33 MHz 40 M |     | ИНz |
|-------------|-----------------|----------------|--------|-----|----------------------------|-----|-----|
|             |                 |                | MAX    | MIN | MAX                        | MIN |     |
| A[31:0]     | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| ASI[7:0]    | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| SIZE[1:0]   | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| RD          | $T_{do}'T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| LDSTO       | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| LOCK        | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| WE-         | $T_{do}'T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| WRT         | $T_{do}/T_{ho}$ | CLK+           | 24     | 7   | 20                         | 7   |     |
| D[31:0] Out | $T_{do}/T_{ho}$ | CLK+           | 15     | 4   | 13                         | 4   |     |
| DXFER       | $T_{do}/T_{ho}$ | CLK+           | 23     | 2   | 19                         | 2   |     |
| ERROR       | $T_{do}'T_{ho}$ | CLK+           | 15     | 3   | 13                         | 3   |     |
| FNULL       | $T_{do}'T_{ho}$ | CLK+           | 13     | 3   | 11                         | 3   |     |
| INTACK      | $T_{do}'T_{ho}$ | CLK+           | 15     | 3   | 13                         | 3   |     |
| INULL       | $T_{do}'T_{ho}$ | CLK+           | 13     | 3   | 11                         | 3   |     |

Figure 11. W8701 output timings, relative to CLK

# AC Specifications, continued

# OUTPUTS WITH RESPECT TO HOLD AND MAO

| Pin Name                      | Parameter                        | Ref Clock Edge             |           | 33 MHz       | 40 MHz |     |  |
|-------------------------------|----------------------------------|----------------------------|-----------|--------------|--------|-----|--|
|                               |                                  |                            | Min       | Max          | Min    | Max |  |
| A/CTL <sup>1</sup>            | T <sub>do</sub> /T <sub>ho</sub> | HOLD+/                     | 0         | 15           | 0      | 12  |  |
| A/CTL <sup>2</sup>            | T <sub>do</sub> /T <sub>bo</sub> | <sup>3</sup> MAO+/         | 2         | 14           | 2      | 12  |  |
| DXFER                         | T <sub>do</sub> /T <sub>bo</sub> | <sup>2</sup> HOLD+/-       | 0         | 15           | 0      | 12  |  |
| DXFER                         | T <sub>do</sub> /T <sub>bo</sub> | <sup>2</sup> HOLD+/-       | 0         | 0            | 0      | 0   |  |
| <sup>1</sup> A/CTL signals in | nclude: A[31:0], AS[17           | :0], SIZE[1:0], RD, LDSTO, | LOCK, WE- | , and WRT    |        |     |  |
| <sup>2</sup> The HOLD in "R   | eference Edge" abov              | e includes MHOLDA–, MHC    | LDB-, BHO | LD-, and FHO | LD     |     |  |
| <sup>3</sup> MAO may be de    | leted                            |                            |           |              |        |     |  |

Figure 12. W8701 outputs with respect to HOLD and MAO

### INPUTS WITH RESPECT TO CLK

| Pin Name                   | Parameter                        | Ref Edge                   | 33<br>MHz              | 33<br>MHz              | 33<br>MHz              | 33<br>MHz                    | 40<br>MHz              | 40<br>MHz              | 40<br>MHz              | 40<br>MHz              |
|----------------------------|----------------------------------|----------------------------|------------------------|------------------------|------------------------|------------------------------|------------------------|------------------------|------------------------|------------------------|
|                            |                                  |                            | T <sub>SI</sub><br>min | T <sub>HI</sub><br>min | T <sub>SI</sub><br>max | <b>Т<sub>ні</sub></b><br>max | T <sub>SI</sub><br>min | T <sub>HI</sub><br>min | T <sub>SI</sub><br>max | T <sub>HI</sub><br>max |
| D[31:0] In                 | T <sub>si</sub> /T <sub>hi</sub> | CLK+                       | 2                      | 5                      |                        |                              | 2                      | 4                      |                        |                        |
| MEXC-                      | Tsi                              | CLK+                       | 11                     | 1                      |                        | 1                            | 10                     | 1                      |                        |                        |
| MHOLDA-4                   | Tsi                              | CLK+                       | 4                      | 5                      |                        |                              | з                      | 4.5                    |                        |                        |
| MDS-                       | T <sub>si</sub>                  | CLK+                       | 4                      | 5                      |                        |                              | 3                      | 4.5                    |                        |                        |
| IRL[3:0]                   | T <sub>si</sub>                  | CLK+                       |                        | 1                      | 10                     | 5                            |                        |                        | 8                      | 4                      |
| RESET-                     | T <sub>si</sub>                  | CLK+                       |                        |                        | 10                     | 3                            |                        |                        | 8                      | 2                      |
| AOE-5                      | T <sub>si</sub>                  |                            |                        |                        | 11                     | 19                           |                        |                        | 9                      | 17                     |
| TOE-                       | T <sub>hi</sub>                  |                            |                        |                        |                        |                              |                        |                        |                        |                        |
| <sup>4</sup> This signal d | escription inclu                 | ides MHOLD                 | 3-, and B              | HOLD-                  |                        |                              |                        |                        |                        |                        |
| <sup>5</sup> This signal d | escription inclu                 | udes COE <mark>-, a</mark> | nd DOE-                | -                      |                        |                              |                        |                        |                        |                        |

Figure 13. W8701 inputs (setup and hold times) with respect to CLK

### ADVANCE DATA February 1991

# AC Specifications, continued

### CLOCK INPUT SPECIFICATIONS

| Parameter        | Description     | Min-Max | 33 MHz | 40 MHz | Unit |
|------------------|-----------------|---------|--------|--------|------|
| T <sub>cyl</sub> | Clock Period    | min     | 30     | 25     | ns   |
| T <sub>ơth</sub> | Clock High Time | min     | 13     | 11     | ns   |
| Tai              | Clock Low Time  | min     | 13     | 11     | ns   |
| T <sub>crt</sub> | Clock Rise Time | max     | 1      | 1      | V/ns |
| T <sub>ctt</sub> | Clock Fall Time | max     | 1      | 1      | V/ns |

Figure 14. Clock input specifications



Figure 15. W8701 output loading circuitry





# Pin Configuration

|    | A        | 8              | С        | D      | E     | F                                     | G    | Н            | J     | К            | L   | М          | N           | Ρ    | R   | Т           | U           |    |
|----|----------|----------------|----------|--------|-------|---------------------------------------|------|--------------|-------|--------------|-----|------------|-------------|------|-----|-------------|-------------|----|
| 17 | vcc      | GND            | TO2      | VDO    | FINS1 | GND                                   | D26  | D24          | D23   | D21          | D19 | D17        | DOE-        | vcc  | vœ  | GND         | GND         | 17 |
| 16 | vœ       | GND            | GND      | FINS2  | vœ    | 029                                   | D28  | 027          | D22   | D20          | D18 | D14        | D15         | vcc  | vcc | GND         | GND         | 16 |
| 15 | vcc      | ERROR-         | TOE-     | TO1    | GND   | D30                                   | ונס  | D25          | vcc   | vœ           | D16 | D13        | D12         | D11  | D10 | GND         | D9          | 15 |
| 14 | GND      | FLUSH          | IFT-     | GND    | vœ    | GND                                   | vcc  | GND          | GND   | GND          | GND | vcc        | GND         | GND  | GND | D6          | De          | 14 |
| 13 | INTACK   | ТІЗ            | TDO      | GND    |       |                                       |      |              |       |              |     |            | vcc         | D7   | D5  | D4          | 13          |    |
| 12 | FNULL    | IRL3           | TMS      | VDD    |       |                                       |      |              |       |              |     |            |             | vcc  | vcc | D3          | D2          | 12 |
| 11 | FCC0     | FCC1           | IRL1     | FXACK  |       |                                       |      |              |       |              |     |            |             | GND  | GND | Dı          | <b>A</b> 31 | 11 |
| 10 | IRLO     | NC             | FCCV     | IRL2   |       |                                       | W87  | 01 SP<br>207 | ARC F | Proces<br>GA | sor |            |             | vcc  | Do  | <b>A3</b> 0 | GND         | 10 |
| 9  | RESET-   | GND            | NC       | GND    |       | Top View<br>Cavity Down               |      |              |       |              |     |            | GND         | A29  | A28 | A26         | 9           |    |
| 8  | FHOLD-   | MHOLDB         | HOLDA    | MEXC-  |       | · · · · · · · · · · · · · · · · · · · |      |              |       |              |     |            | vcc         | A27  | A25 | A24         | 8           |    |
| 7  | BHOLD-   | MDS-           | NC       | VDD    |       |                                       |      |              |       |              |     |            |             | GND  | vcc | A23         | A22         | 7  |
| 6  | NC       | NC             | INST     | GND    |       |                                       |      |              |       |              |     |            |             | GND  | A18 | A19         | <b>A</b> 21 | 6  |
| 5  | FEXC-    | NULL           | LDSTO    | VDD    |       |                                       |      |              |       |              |     |            |             | GND  | GND | A17         | A20         | 5  |
| 4  | RD       | WE-            | GND      | LOCK   | WRT   | GND                                   | vcc  | GND          | GND   | vcc          | vcc | GND        | vcc         | GND  | A15 | A16         | vcc         | 4  |
| 3  | GND      | GND            | GND      | DXFER  | MAO   | AS10                                  | AS12 | vcc          | GND   | CLK          | A2  | <b>A</b> 8 | A12         | AOE- | A16 | vcc         | vcc         | 3  |
| 2  | vcc      | GND            | COE-     | SIZE 1 | SIZEO | <b>A</b> S11                          | AS13 | AS15         | GND   | <b>A</b> 0   | *   | A5         | <b>A</b> 6  | A10  | A14 | vcc         | GND         | 2  |
| 1  | X        | vcc            | GND      | vœ     | vcc   | GND                                   | AS14 | AS16         | AS17  | A1           | AJ  | A7         | <b>A</b> 11 | A9   | GND | GND         | GND         | 1  |
|    | A<br>Pin | B<br>1 Identif | C<br>ier | D      | E     | F                                     | G    | н            | J     | к            | L   | М          | N           | P    | R   | т           | U           | _  |

Figure 17. Pin configuration for the W8701

#### W8701 INTEGRATED SPARC PROCESSOR TECHNICAL OVERVIEW

#### ADVANCE DATA February 1991

## Package Dimensions



Figure 18. W8701 Physical Dimensions and package information

### Ordering Information

| Package Type        | Speed Grade | Temperature Range (case) | Order Number  |
|---------------------|-------------|--------------------------|---------------|
| 207-pin ceramic PGA | 25 MHz      | 0-85°C                   | W8701-025-GCD |
| 207-pin ceramic PGA | 33 MHz      | 0-85°C                   | W8701-033-GCD |
| 207-pin ceramic PGA | 40 MHz      | 0-85°C                   | W8701-040-GCD |

Figure 19. Ordering information



Figure 2. NCR 53C90 and 53C90A Pin Configurations

NCR SCSI Products

# NCR 53C90A, 53C90B

| Pin       | Signal      | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|-----------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 4-1,68-65 | 15137-15130 | В    | Active-high data bus connected to the DMA controller, CPU and buffer memory.<br>Each pad contains a pull-up to V <sub>DD</sub> (12.5K minimum).                                                                                                                                                                                                                                                                                                                                                                     |  |
| 63        | RESET       | 1    | Active-high chip reset. Reset must be asserted for two CLK periods, minimum, after the voltage on the power pins has reached $V_{\rm pp}$ min. This input must not be connected to RESETO.                                                                                                                                                                                                                                                                                                                          |  |
| 62        | RESETO      | 0    | Active-high reset output. This output is always asserted when the RESET input<br>is true OR may be asserted when the SCSI reset signal is active if bit 6 of the<br>Config 1 register is cleared and the host has not serviced the interrupt (gener-<br>ated because of SCSI reset) within 1-2 ms (depending on CLK frequency and<br>clock conversion factor). Refer to <i>Bus Initiated Reset</i> .                                                                                                                |  |
| 61        | INT/        | 0    | Active-low, open drain interrupt signal to the microprocessor. It is latched on<br>the rising edge of CLK and may be cleared by reading the interrupt register or<br>by a host hardware reset, or by a host software reset (but not by a SCSI reset).<br>This output cannot be disabled internally.                                                                                                                                                                                                                 |  |
| 60-57     | A3-A0       | I    | Active-high address bus which specifies one of the ASPs internal registers f reading or writing. Used with CS/, ignored with DACK/.                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 56        | CS/         | I    | Active-low chip-select signal that enables access to the ASPs internal registers.<br>CS/ accesses any register, including the FIFO, while DACK/ accesses only the<br>FIFO. CS/ and DACK/ must never be active at the same time.                                                                                                                                                                                                                                                                                     |  |
| 55        | RD/         | I    | Active-low read signal that enables ASP data onto DB7-DB0. CS/ or DACK/ must also be active.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 54        | W'R/        | I    | Active-low write signal that strobes DB7-DB0 data into the ASP. CS/ or DACK/<br>must also be active.                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 53        | DREQ        | 0    | Tri-state active-high DMA request to the DMA controller. DREQ will be true as<br>long as the FIFO has at least one byte to send to memory, or has room to receive<br>at least one byte from memory, depending on data direction.                                                                                                                                                                                                                                                                                    |  |
| 52        | DACK/       | I    | Active-low DMA acknowledge from the DMA controller. DACK/ accesses the FIFO only, while CS/ accesses any register, including the FIFO. CS/ and DACK/ must never be active at the same time. DACK/ must toggle true then false for every byte transfered. Refer to DREQ Hi Z Bit in Config 2.                                                                                                                                                                                                                        |  |
| 51        | CLK         | I    | Square wave clock that generates internal chip timing. The maximum frequency is 25 MHz, with a 35% to 65% duty cycle. The minimum frequency required for asynchronous SCSI transmission is 10 MHz. The minimum frequency required for synchronous transmission is 12 MHz. The synchronous transmission rate is equal to the CLK input period divided by the value in the synchronous transfer period register. The asynchronous transfer rate is indirectly affected by CLK frequency. Refer to Data Transfer Rate. |  |

# Table 1. Host Processor and DMA Interface Pins – PLCC Package

| Pin                   | Signal                | Туре   | Description                                                                                                                                                                                                                                                                                                                                                                         |  |
|-----------------------|-----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 6-13, 14              | SDI0/-SDI7/,<br>SDIP/ | В      | Schmitt trigger, active-low SCSI data/parity bus. In single-ended mode (DIFFM = 0) these inputs are SCSI data bus signals. In differential mode (DIFFM = 1) these are bi-directional data and parity signals for external SCSI bus transceivers.                                                                                                                                    |  |
| 17-20,<br>22-25<br>26 | SDO0/-SDO7/<br>SDOP   | 0<br>0 | 48 mA, open drain SCSI data parity bus. In single-ended mode (DIFFM = 0) these outputs are active-low SCSI data signals. In differential mode (DIFFM = 1) these outputs are used to control the direction of external differential transceivers, with the direction of external differential transceivers.                                                                          |  |
| 28                    | SELO/                 | 0      | high meaning output to the SCSI bus, low meaning input from the SCSI bus.<br>48 mA, open drain SCSI select signal. In single-ended mode this output is active-<br>low. In differential mode it is active-high.                                                                                                                                                                      |  |
| 29                    | BSYO/                 | 0      | 48 mA, open drain SCSI busy signal. In single-ended mode, this output is active-<br>low. In differential mode it is active-high.                                                                                                                                                                                                                                                    |  |
| 30                    | REQO/                 | 0      | 48 mA, open drain, active-low SCSI request signal. This output is only asserted when the ASP is in target mode.                                                                                                                                                                                                                                                                     |  |
| 31                    | ACKO/                 | 0      | 48 mA, open drain, active-low SCSI acknowledge signal. This output is only asserted when the ASP is in initiator mode.                                                                                                                                                                                                                                                              |  |
| 33-35                 | MSGO/,<br>C/DO, I/OO  | 0      | 48 mA, open drain, active-low SCSI phase signals. These outputs are only asserted when the ASI' is in target mode.                                                                                                                                                                                                                                                                  |  |
| 36                    | ATNO/                 | 0      | 48 mA, open drain, active-low SCSI attention signal. This output is only asserte<br>when the ASP is in initiator mode. Several ASP commands will set ATN. It is a<br>asserted when the ASP detects an incoming parity error if parity checking is<br>enabled.                                                                                                                       |  |
| 37                    | RSTO/                 | 0      | 48 mA, open drain SCSI reset signal. In single-ended mode this output is active-<br>low. In differential mode it is active-high. The ASP drives this signal true only<br>when the host writes the SCSI bus reset command to the command register. The<br>pulse length is 25-40 us, depending on CLK frequency and clock conversion factor.<br>Refer to <i>Bus Initiated Reset</i> . |  |
| 39                    | SEL1/                 | I      | Schmitt trigger, active-low SCSI select input.                                                                                                                                                                                                                                                                                                                                      |  |
| 40                    | BSY1/                 | I      | Schmitt trigger, active-low SCSI busy input.                                                                                                                                                                                                                                                                                                                                        |  |
| 41                    | REQI/                 | I      | Schmitt trigger, active-low SCSI request input.                                                                                                                                                                                                                                                                                                                                     |  |
| 42                    | ACKI/                 | I      | Schmitt trigger, active-low SCSI acknowledge input.                                                                                                                                                                                                                                                                                                                                 |  |
| 43                    | MSGI/                 | I      | Schmitt trigger, active-low SCSI message input.                                                                                                                                                                                                                                                                                                                                     |  |
| 44                    | <u>.</u> C/DI         | I      | Schmitt trigger SCSI control/data input.                                                                                                                                                                                                                                                                                                                                            |  |
| 45                    | 1/01                  | I      | Schmitt trigger SCSI input/output input.                                                                                                                                                                                                                                                                                                                                            |  |
| 46                    | ATNI/                 | I      | Schmitt trigger, active-low SCSI attention input.                                                                                                                                                                                                                                                                                                                                   |  |
| 47                    | RSTI/                 | 1      | Schmitt trigger, active-low SCSI reset signal. When this input is true, the ASP will automatically disconnect from the SCSI bus. If bit 6 in the Config I register is zero, the ASP will interrupt the host. If the interrupt is not serviced within 1-2 ms, the ASP will reset its host processor. Refer to <i>Bus Initiated Reset</i> .                                           |  |
| 50                    | IGS                   | ()     | Active-high initiator group select signal. This pin is high whenever the ASP is in initiator mode. It is used in differential mode to enable the initiator signals (ACKO/, ATNO/). When low, the ASP should be receiving these signals.                                                                                                                                             |  |

Table 2. SCSI Bus Interface – PLCC Package

| PLCC Pin Number        | QFP Pin Number                               | Signal          | Description                                    |
|------------------------|----------------------------------------------|-----------------|------------------------------------------------|
| 15, 48                 | 9, 49                                        | V <sub>DD</sub> | +5 Volt power input.                           |
| 16, 21, 27, 32, 38, 64 | 10, 11, 16, 22, 23, 29<br>30, 37, 6 <b>6</b> | V <sub>ss</sub> | Ground. NCR recommends a ground plane be used. |

# Table 3. Power and Ground Pins

# Table 4. 53C90 and 53C90A only - PLCC Package

| Pin | Signal | Type | Description                                                                                                                                                                                                                                                                                                               |
|-----|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 49  | TGS    | 0    | Active-high target group select signal. This pin is high whenever the ASP is in target mode. It is used in differential mode to enable the target signals (REQO/, MSGO/, C/DO, I/OO). When low, the ASP should be receiving these signals.                                                                                |
| 5   | DIFFM  | I    | Differential mode enable. When this pin is grounded, the ASP operates in single-ended mode, with separate SCSI data input and output buses. When this pin is high, the ASP operates in differential mode, with bi-directional SCSI data on the SDI pins and active-high differential transceiver enables on the SDO pins. |

# Table 5. 53C90B only - PLCC Package

| Ріп | Signal    | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 49  | TGS/DIFFM | В    | This pin is sampled during reset to put the chip in differential mode or single-<br>ended mode, it then switches function to become the TGS output. An internal<br>pull-up pulls it high for single-ended mode, while an external 1K pull-down will<br>place the C90B in differential mode.                                                                                                                                                                                                                                                                                                                         |
|     |           |      | There are two kinds of reset, power-up reset and running-reset. On power-up, the state of this pin is sampled as the voltage on the power pins rises through 3 volts (approximately). A running-reset is a host hardware reset that occurs sometime later. A running-reset will sample this pin until the 10th rising edge of CLK after RESET goes true (high). This is enough time for the internal pull-up to pull it high. Whatever state it's in on the 10th clock will determine the mode. The TGS function will be disabled until the 12th rising edge of CLK after RESET first goes true and RESET is false. |
|     |           |      | When RESET is false (low), and 12 clocks have occured since RESET first went<br>true, this pin becomes the TGS output, an active-high target group select signal.<br>This pin is high whenever the ASP is in target mode. It is used in differential<br>mode to enable the target signals (REQO/, MSGO/, CDO/, IOO/). When low, the<br>ASP should be receiving these signals.                                                                                                                                                                                                                                       |
| 5   | DBP       | В    | Active-high data bus parity for host, DMA, and memory data bus. Four bits in<br>Config 1 and Config 2 control parity generation and checking.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# Differences from 53C90

- Supports three-byte message exchange SCSI-2 tagged-queuing
- Added select with ATN3 command
- Added target DMA abort command
- Added interrupt polling bit
- Added second configuration register
- Improved immunity to cable impedance mismatches and improper termination
- Tri-state DMA request output
- Cut leakage current on SCSI input pins when powered off
- Relaxed register timings
- Relaxed DMA timings
- Relaxed CLK duty cycle
- Lengthened read data access time
- NOP required less often

# **Functional Description**

The ASC SCSI data bus has a set of inputs and a set of outputs. This allows the ASC to be used in either singleended mode or differential mode. In single-ended mode, the inputs are usually connected to the outputs on the circuit board. In differential mode, the SDI (SCSI Data Input) pins become bi-directional data pins, while the SDO (SCSI Data Output) pins become enable signals for the differential transceivers. Separate enables are required, because during arbitration two data bus signals must be outputs while the other six must be inputs. Two signals, TGS and IGS, control the direction of the external transceivers, allowing the ASC to dynamically switch between initiator and target roles.

The ASC has a command set that allows it to perform common SCSI sequences at hardware speed without host intervention. Its on-chip FIFO may be accessed simultaneously by the SCSI bus and either the host processor or the host DMA controller. All command, data, status, and message bytes pass through the FIFO on their way to or from the SCSI bus. Most ASC commands have two versions: DMA and non-DMA. When DMA instructions are used, data will pass between memory and the SCSI bus with the FIFO acting as temporary storage when the DMA channel is temporarily shut down by a higher priority event such as DRAM refresh.

The FIFO also helps speed execution during non-DMA transfers. For example, in initiator role, the host processor will load the CDB (Command Descriptor Block) and optionally one or three message bytes into the FIFO, issue one of several selection commands and wait for an interrupt. The ASC will wait for bus-free, arbitrate for the bus again and again until it acquires it, send the message bytes followed by the CDB, then generate an interrupt. Meanwhile, a multi-tasking host may continue with other tasks.

In target role, the host processor will enable selection, then wait for an interrupt. Eventually, an initiator will select the ASC and will then automatically step through the arbitration, selection, and command phases before generating an interrupt. When the interrupt occurs, the entire command descriptor block will be in the FIFO along with any message bytes sent by the initiator. Combination commands such as these, are identified with the sequence suffix in the Table of ASC Commands.

# NCR 53C90A, 53C90B

After selection phase has been successfully completed, the ASC may transfer bytes in any of the SCSI information phases whether operating in initiator or a target role. The ASC supports disconnect/reselect in both initiator and target roles, making high performance multi-threaded systems easy to implement.

The ASC may transfer data phase bytes across the bus synchronously, at speeds up to 5 MB/S, or asynchronously at speeds up to 6 MB/S. Refer to Data Transfer Rate. The difference between the two is transparent to the user except that the synchronous offset and the synchronous transfer period registers must be programmed prior to synchronous data transfer. The default, after hardware or software reset, is asynchronous transmission.

Data phase bytes will usually be transferred using DMA. The host processor will program an external DMA controller, program the ASC transfer count, issue an ASC data transfer command (there are several), then wait for an interrupt. The DMA controller and the ASC will transfer all the data without host processor intervention.

To end the SCSI transaction, the ASC target will place a status byte and a message byte in the FIFO, then issue a single command (there are two to chose from) which will cause the ASC to first assert status phase, send the first byte, assert message in phase, send the second byte, disconnect from the SCSI bus (after the initiator releases ACK (Acknowledge)) and interrupt the host processor.

The end of a SCSI transaction is similar for an ASC initiator except that it receives two bytes into its FIFO. The initiator prevents the target from disconnecting by holding ACK asserted on the bus while the host processor examines the status and message bytes. If both bytes are good, the message accepted command is used to instruct the ASC to release ACK, which allows the target to disconnect which causes the initiator to interrupt its host and report the disconnect. If the status and message bytes are not good, the host should first issue the set ATN (Attention) command before issuing the message accepted command. This instructs the ASC to assert ATN before releasing ACK, which should cause the target to request message out phase rather than disconnect.

# **Bus Initiated Sequences**

- Selection
- Reselection
- SCSI bus reset

Selection or reselection sequences occur in the disconnected state when the ASC is selected or reselected by another initiator or target, if the enable selection or reselection command had previously been received by the ASC.

In addition to responding to bus initiated events, the ASC may initiate a bus event by using one of several selection or reselection commands. If one of these commands starts executing, *it will clear enable selection/reselection* after arbitration has been won. Normally the host processor will have 250 ms (ANSI recommended selection time-out period) after the chip disconnects from the bus to re-enable bus initiated events. If the time-out is exceeded, an initiator or target which is attempting to connect to the ASC, may time-out and abort.

If, on the other hand, the bus initiated event occurs before the command starts executing, the FIFO and command register will be cleared, and any further writes by the host processor will be ignored until the interrupt register is read. Since a selection/reselection command requires that something be placed in the FIFO, these bytes will be lost, as will any command written to the command register. The interrupt handler that services a selection/reselection command will have to examine the bits in the interrupt register to detemine if the ASC selected another device, or if it was selected by another device. The former case will cause a function complete interrupt, the latter case will cause a selection/reselection interrupt.

| Address (hex) | Read                     | Write                   |
|---------------|--------------------------|-------------------------|
| 0             | Transfer counter LSB     | Transfer count LSB      |
| i             | Transfer counter MSB     | Transfer count MSB      |
| 2             | FIFO                     | FIFO                    |
| 3             | Command                  | Command                 |
| 4             | Status                   | Destination bus ID      |
| 5             | Interrupt                | Select/reselect timeout |
| 6             | Sequence step            | Synchronous period      |
| 7             | FIFO flags/sequence step | Synchronous offset      |
| 8             | Configuration 1          | Configuration I         |
| 9             | NCR reserved             | Clock conversion factor |
| A             | NCR reserved             | Test mode               |
| В             | Configuration 2          | Configuration 2         |

 Table 6. ASC Register Set

# **Register Set**

Some ASC registers have different meanings during reads than writes. When CS/ is true, the register being accessed is determined by either RD/ or WR/ together with the address pins A0-3. The FIFO may be accessed using either CS/ or DACK/ together with RD/ or WR/. Address pins A0-A3 are ignored when DACK/ is active, but must be driven when CS/ is active.

## Transfer Count (Write address 0,1)

These two registers together form a 16-bit transfer count for DMA operations. Transfer count specifies the number of bytes that are to be transferred over the SCSI bus. Values written to these two registers will be stored internally and loaded into the transfer counter by any DMA command. These values remain unchanged while the transfer counter decrements. Thus, successive blocks of equal size may be transferred without reprogramming the count. They may be reprogrammed any time after the previous DMA operation has started, whether it has finished or not. Zero specifies a maximum length count (65536). These registers are not changed by any reset; their states are unpredictable after power-up.

## Transfer Counter (Read address 0,1)

A read from these two addresses will return the value currently in the counter. DMA commands use the counter to terminate a transfer. Any DMA command will load count into the counter. A DMA NOP 80h will load the counter while the non-DMA NOP 00h will not.

With one exception, non-DMA commands do not use the counter. The exception is when the ASC has been selected, it decodes the group code field of the CDB (Command Descriptor Block), loads the counter with the number of bytes in the CDB, then decrements once for every byte received.

The transfer counter decrements on the leading edge of:

| Target         | Decremented by |
|----------------|----------------|
| Data in phase  | DACK/          |
| Data out phase | REQO/          |

| Initiator            | Decremented by |
|----------------------|----------------|
| Synchronous data in  | DACK/          |
| Asynchronous data in | ACKO/          |
| Data out             | DACK/          |

# NCR 53C90A, 53C90B

Note that DACK/ can decrement the counter even if RD/ or WR/ do not go true. False DACK/s can cause the counter to get out of sync with the data stream, leading to subtle errors that are difficult to trace. When false DACK/s are expected to interfere with a temporarily suspended DMA operation, the DREQ Hi-Z bit in Config 2 should be set.

### FIFO Register (Read/write address 02)

The FIFO is a 16 by 9-bit first-in-first-out buffer between the SCSI bus and memory. It is accessible by the host processor at this address. It is also accessible by an external DMA controller and by the SCSI bus. The DMA may access the FIFO by asserting DACK/ together with either RD/ or WR/. When accessed by CS/, the address bits must be valid. When accessed by DACK/, the address bits are ignored. The bottom FIFO element and the FIFO flags are initialized to zero during hardware reset, software reset chip and at the beginning of bus initiated selection or reselection. The contents of the rest of the FIFO are not changed by any reset, but when the flags are zero, successive FIFO reads will always access the bottom register.

#### Command Register (Read/write address 03)

The command register is a two deep 8-bit read/write register used to give commands to the ASC. Up to two commands may be stacked in the command register. The second command may be written before the ASC completes (or even starts) the first. Reset chip, reset SCSI bus and target stop DMA execute immediately, all others wait for the previous command to complete. The last executed (or executing) command will remain in the command register and may be read by the host processor. Reading the command register has no effect on its contents. The command register will be cleared by any of the following conditions:

- Hardware, software or SCSI bus reset
- SCSI bus disconnect
- Bus-initiated selection or reselection
- Select command
- · Reconnect command if ATN is set
- Select or reselect time-out
- Target terminate command
- · Parity error detected in target mode

- Assertion of ATN in target mode
- Any phase change in initiator mode
- Illegal command

If two commands are placed in the command register, two interrupts may result. If the first interrupt is not serviced before the second finishes, the second interrupt is stacked behind the first. When the interrupt register is read by the host to service the first interrupt, the contents status register, sequence step register, and interrupt register will change to describe the second interrupt.

#### Figure 5. Command Register (Read/write address 03)



#### Bit 7 (Enable DMA)

When bit 7 is not set, the command is a non-DMA instruction. When it is set, the command is a DMA instruction. DMA instructions will load the internal byte counter with the value in the transfer count register (without changing the count register) then transfer data until that count decrements to zero. If the transfer terminates prematurely, the bits in the status, sequence step, and interrupt registers will indicate why.

#### Bits 6-0 (Command code)

The ASC commands are shown in Table 19. Bits 4, 5 and 6 specify a mode group. Commands from the miscellaneous group may be issued at any time. Commands from the disconnected, target or initiator groups will only be accepted by the ASC if it is in the same mode as the command when it falls to the bottom of the command FIFO. Otherwise, an illegal command interrupt will be generated. For example, after hardware or software reset, the ASC will be in the disconnected state. A command from either the target group or the initiator group will cause an illegal command interrupt. An enable selection or reselection command by itself will not change modes. However, if another SCSI device then selects the ASC, it will be in the target state; if another device reselects the ASC, it will then be in the initiator state. Similarly, any select command will place the ASC in initiator mode, while the reselect sequence command will place the ASC in target mode.

## Status Register (Read address 04)

The satus register contains important flags that indicate various conditions. All but the phase bits are latched. The phase bits are live indicators of the state of the SCSI bus. All the latched bits except the terminal count are cleared by reading the interrupt register.

Figure 6. Status Register (Read address 04)



#### Bit 7 (Interrupt)

This bit is set whenever the ASC drives the INT output true. It may be polled. It is buffered from the actual output, so that in wired-OR (shared interrupt) designs, this bit will indicate whether the ASC is attempting to interrupt the host processor. This bit is reserved by NCR in the 53C90. Hardware reset or software reset chip or a read from the interrupt register will release an active INT signal and also clear this bit.

#### Bit 6 (Gross error)

This bit is set when one of the following has occurred:

- The top of the FIFO is overwritten
- The top of the command register has been overwritten
- Direction of DMA transfer is opposite to the direction of the SCSI transfer
- An unexpected phase change in initiator role during synchronous data phase

Gross error does not cause an interrupt, it may be detected only while servicing another interrupt. The bit is cleared by reading the status register if the interrupt output is asserted. It will also be cleared by hardware reset, or software reset chip (but not SCSI reset).

#### Bit 5 (Parity error)

This bit will be set if parity checking is enabled in the Config I register and the ASC detects a SCSI parity error on incoming command, data, status or message bytes. It will be cleared by reading the interrupt register if the interrupt output is asserted. Hardware reset or software reset chip will clear this bit (but not SCSI reset).

#### Bit 4 (Terminal count)

This bit is set when when the transfer counter decrements to zero. It resets when the transfer count is loaded. Since a DMA NOP 80h command will load the transfer counter, it will also clear this bit. Note that a non-DMA NOP 00h will not load the counter and will not clear this bit. Reading the interrupt register will not clear this bit. Hardware reset or software reset chip will clear it (but not SCSI reset).

#### Bit 3 (Valid group code)

The name of this bit has changed from transfer complete in the 53C90 to valid group code in the 53C90A and 53C90B; but it's function remains the same.

When the ASC is selected, it decodes the group code field in the first byte of the command descriptor block. If the group code matches one defined in ANSI X3.131-1986, this bit will be set. An undefined group code (designated reserved by the ANSI committee) leaves it not set. If the SCSI-2 bit is set in the Config 2 register, group 2 commands will be recognized as ten-byte commands and the bit will be set. If the SCSI-2 bit is cleared, group 2 commands will be treated as reserved commands. Groups 3 and 4 are always treated as reserved commands. A reserved group command will cause the ASC to request 6 command bytes. The ASC recognizes group 6 as six-byte vendor unique commands and group 7 as 10-byte vendor unique commands. The valid group code bit will be cleared by reading the interrupt register if the interrupt output is asserted. It will also be cleared by hardware reset or software reset chip (but not by SCSI reset).

# NCR 53C90A, 53C90B

# **DC Electrical Characteristics**

## Absolute Maximum Stress Ratings

| Parameter               | Symbol           | Pins       | Test Conditions       | Min                  | Max                  | Unit |
|-------------------------|------------------|------------|-----------------------|----------------------|----------------------|------|
| Storage temperature     | T <sub>sig</sub> | -          | ·-                    | - 55                 | 150                  | r:   |
| Supply voltage          | V <sub>DD</sub>  | -          |                       | - 0.5                | 7.0                  | v    |
| Input voltage           | V <sub>IN</sub>  | -          |                       | V <sub>11</sub> -0.5 | V <sub>00</sub> +0.5 | V    |
| Latch-up current        | I.p.             | -          | $-2V < V_{PIN} < +8V$ | ± 100                | -                    | mA   |
| Electrostatic discharge | ESD              | -          | Human body model      | -                    | -                    | -    |
| U U                     |                  | SCSI pins  | 100 pF at 1.5K ohms   | ± 6000               | -                    | V    |
|                         |                  | Other pins | 100 pF at 1.5K ohms   | ± <b>3</b> 000       | -                    | V    |

Conditions that exceed the absolute maximum stress limits may destroy the device.

Conditions that exceed the operating limits may cause the device to function incorrectly.

# **Operating Conditions**

| Parameter           | Symbol          | Pins | Test Conditions | Min  | Max  | Unit           |
|---------------------|-----------------|------|-----------------|------|------|----------------|
| Supply voltage      | V <sub>DD</sub> | -    | -               | 4.75 | 5.25 | v              |
| Supply current      | I <sub>DD</sub> | -    | Static*         | -    | 10   | mA             |
| Supply current      | I <sub>DD</sub> | -    | Dynamic         | -    | 50   | mA             |
| Ambient temperature | T <sub>A</sub>  | -    | -               | 0    | 70   | <del>ا</del> ر |

\* Static means: all inputs at  $V_{ss}$ , all outputs floating, and all bi-directional pins configured as inputs.

## Inputs

| Parameter             | Symbol           | Pins                                   | Test Conditions                                                        | Min                   | Max                   | Unit |
|-----------------------|------------------|----------------------------------------|------------------------------------------------------------------------|-----------------------|-----------------------|------|
| Input high voltage    | V <sub>III</sub> | -                                      | -                                                                      | 2.0                   | V <sub>DD</sub> + 0.5 | v    |
| Input low voltage     | V <sub>II.</sub> | -                                      | -                                                                      | V <sub>ss</sub> - 0.5 | 0.8                   | v    |
| Input leakage current | I <sub>IN</sub>  | Non-SCSI                               | 0 < V <sub>IN</sub> < V <sub>DD</sub><br>4.75 ≤ V <sub>DD</sub> ≤ 5.25 | - 10                  | 10                    | μA   |
| Hysteresis            | V <sub>II</sub>  | BSY1/, SEL1/,<br>REQI/,ACK1/,<br>RST1/ | -                                                                      | 400                   | -                     | mV   |
| Input low leakage     | I <sub>II.</sub> | SCSI                                   | $V_{1N} = 0.5; 0 \le V_{DD} \le 5.5$                                   | - 10                  | 0.0                   | μA   |
| Input high leakage    | I                | SCSI                                   | $V_{1N} = 2.7; 0 \le V_{100} \le 5.5$                                  | 0.0                   | 10                    | μA   |
| Capacitance           | C <sub>in</sub>  | -                                      | -                                                                      | -                     | 10                    | pF   |

# Outputs

| Parameter           | Symbol            | Pins                                                                                | Test Conditions          | Min             | Max             | Unit |
|---------------------|-------------------|-------------------------------------------------------------------------------------|--------------------------|-----------------|-----------------|------|
| Output high voltage | V <sub>on</sub>   | DREQ. IGS,                                                                          | l <sub>ou</sub> = -2 mA  | 2.4             | V <sub>DD</sub> | v    |
| Output low voltage  | V <sub>ot.</sub>  | DREQ, IGS, INT/                                                                     | i <sub>.u.</sub> = 4 mA  | V <sub>ss</sub> | 0.4             | v    |
| Output high voltage | V <sub>on</sub>   | RESTO                                                                               | I <sub>ou</sub> =-4 mA   | 2.4             | V <sub>DD</sub> | v    |
| Output low voltage  | V <sub>ot.</sub>  | RSTO/, SELO,<br>ATNO/, MSGO/,<br>ACKO/, REQO/,<br>SDOP/, BSYO/,<br>C/D, I/O, SDO7-0 | l <sub>.u.</sub> = 48 mA | V <sub>ss</sub> | 0.5             | v    |
| Hi Z state leakage  | I <sub>oz</sub>   | -                                                                                   | $0 < V_{out} < V_{ob}$   | - 10            | 10              | μA   |
| Capacitance         | C <sub>otta</sub> | -                                                                                   | -                        | -               | 10              | þl:  |

# **Bi-Directional Pins**

| Parameter            | Symbol           | Pins                              | Test Conditions          | Min                   | Max                   | Unit             |
|----------------------|------------------|-----------------------------------|--------------------------|-----------------------|-----------------------|------------------|
| Input high voltage   | V <sub>IH</sub>  | -                                 | -                        | 2.0                   | V <sub>DD</sub> + 0.5 | v                |
| Input low voltage    | V <sub>II.</sub> | -                                 | -                        | V <sub>.55</sub> -0.5 | 0.8                   | v                |
| Output high voltage  | V <sub>oir</sub> | SD17-0, DB15-0,<br>DBP1-0, PAD7-0 | l <sub>ou</sub> = - 2 mA | 2.4                   | V <sub>DD</sub>       | - X <sup>1</sup> |
| Output low voltage   | Vol              | SDI7-0, DB15-0,<br>DBP1-0, PAD7-0 | I <sub>ot</sub> = 4 mA   | V <sub>ss</sub>       | 0.4                   | V                |
| Output high voltage  | V <sub>oii</sub> | TGS                               | $I_{ou} = -4 \text{ mA}$ | 2.4                   | V <sub>DD</sub>       | v                |
| Output low voltage   | V <sub>oL</sub>  | TGS                               | $I_{or} = -8 \text{ mA}$ | V <sub>ss</sub>       | 0.4                   | V                |
| Input current, low   | I <sub>II.</sub> | TGS                               |                          | -600                  | 0                     | μA               |
| Input current, low   | I                | SD17-0                            | $0 < V_{IN} < V_{DD}$    | -10                   | 10                    | μA               |
| Input current, low   | I <sub>II.</sub> | DB15-0, DB121-0,<br>PAD7-0        | $V_{iN} = V_{iL}$        | - 400                 | 0                     | μA               |
| Input current, high  | I                | DB15-0, DBP1-0,<br>PAD7-0, TGS    | $V_{IN} = V_{III}$       | 0                     | 10                    | μA               |
| Hi Z pull-up current | I <sub>PG</sub>  | DB15-0, DBP1-0,<br>PAD7-0         | -                        | 100                   | 400                   | μA               |
| Capacitance          | C <sub>io</sub>  | -                                 | -                        | -                     | 10                    | рF               |

# NCR 53C90A, 53C90B

# **AC Electrical Characteristics**

The AC characteristics described herein apply over the voltage range  $V_{100}$ = 4.75 - 5.25 V and the temperature range 0°-70°C. Chip output timing is based on simulation under

worst case conditions (4.75 \', 70°C) and the following pad termination:

| Signal Name                                                                  | Output Load                       |
|------------------------------------------------------------------------------|-----------------------------------|
| RESETO, DREQ, TGS, IGS, SDIP/, SDI7/-SDI0/                                   | 50 pl?                            |
| DB7-0                                                                        | 85 pl <sup>;</sup>                |
| INT/                                                                         | 50 pl; IK pull-up                 |
| RSTO/, SELO/, BSYO/, ATNO/, MSGO/, CDO/<br>100/, REQO/, ACKO/, SDO7-0/, SDOP | 200 pl7, 110 pullup, 165 pulldown |

#### System Interface

All timings in this specification are taken from the 10% and 90% points with respect to the specified  $V_{\rm ou}$  and  $V_{\rm ou}$  of the waveforms.

### Clock



| Symbol           | Minimum                                                                                       | Maximum                                               | Units                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| t <sub>cr</sub>  | 40                                                                                            | 100                                                   | ns                                                                                                                                                                          |
| t <sub>cpa</sub> | 10*                                                                                           | 25                                                    | MHz                                                                                                                                                                         |
| t <sub>cps</sub> | 12*                                                                                           | 25                                                    | MHz                                                                                                                                                                         |
| t <sub>ch</sub>  | 14.58                                                                                         | -                                                     | ns                                                                                                                                                                          |
| t <sub>ci.</sub> | 14.58                                                                                         | -                                                     | ns                                                                                                                                                                          |
| t <sub>cs</sub>  | -                                                                                             | -                                                     | -                                                                                                                                                                           |
|                  | t <sub>CP</sub><br>t <sub>CPA</sub><br>t <sub>CPS</sub><br>t <sub>CH</sub><br>t <sub>CL</sub> | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{c ccccc} t_{\rm CP} & 40 & 100 \\ t_{\rm CPA} & 10^{*} & 25 \\ t_{\rm CPS} & 12^{*} & 25 \\ t_{\rm CH} & 14.58 & - \\ t_{\rm CL} & 14.58 & - \\ \end{array}$ |

\* These minimum numbers required to comply with ANSI SCSI specification. For synchronous SCSI data transfers, the clock inputs must also meet the following requirements:

 $2t_{cp} + t_{cl} \ge 97.92 \ ns$  and  $2t_{cr} + t_{cll} \ge 97.92 \ ns$ 

# **Final**

**A**m7990

# Local Area Network Controller for Ethernet (LANCE)

## DISTINCTIVE CHARACTERISTICS

- Compatible with Ethernet and IEEE-802.3 10Base5 Type A, and 10Base2 Type B, "Cheapernet")
- Easily interfaced to 8086, 68000, Z8000<sup>TM</sup>, LSI-II<sup>TM</sup> microprocessors
- On-board DMA and buffer management, 48 byte FIFO
- 24-bit wide linear addressing (Bus Master Mode)
- Network and packet error reporting

- Back-to-back packet reception with as little as 4.1 µsec interpacket gap time
- Diagnostic Routines
  - Internal/external loop back
  - CRC logic check
  - Time domain reflectometer

#### GENERAL DESCRIPTION

The Am7990 Local Area Network Controller for Ethernet (LANCE) is a 48-pin VLSI device designed to greatly simplify interfacing a microcomputer or minicomputer to an IEEE-802.3/Ethernet Local Area Network. The LANCE, in conjunction with the Am7992B Serial Interface Adapter (SIA), Am7996 Transceiver, and closely coupled local memory and microprocessor, is intended to provide the

user with a complete interface module for an Ethernet network. The Am7990 is designed using a scaled N-Channel MOS technology and is compatible with a variety of microprocessors. On-board DMA, advanced buffer management, and extensive error reporting and diagnostics facilitate design and improve system performance.



## BLOCK DIAGRAM

00002000

#### **RELATED AMD PRODUCTS**

| Part No. | Description                                     |
|----------|-------------------------------------------------|
| Am7992B  | Serial Interface Adaptor (SIA)                  |
| Am7996   | IEEE-802.3/Ethernet/Cheapernet Transceiver      |
| Am79C900 | Integrated Local Area Communications Controller |

# Advanced Micro Devices



Note: Pin 1 is marked for orientation.



### TYPICAL ETHERNET/CHEAPERNET NODE

DAL<sub>00</sub>-DAL<sub>15</sub> Data/Address Lines (Input/Output, Three-State)

The time multiplexed Address/Data bus During the address portion of a memory transfer,  $DAL_{00} - DAL_{15}$  contains the lower 16 bits of the memory address. The upper 8 bits of address are contained in  $A_{16} - A_{23}$ .

During the data portion of a memory transfer,  $DAL_{00}$  -  $DAL_{15}$  contains the read or write data, depending on the type of transfer.

The LANCE drives these lines as a Bus Master and as a Bus Slave.

A<sub>16</sub> – A<sub>23</sub> High Order Address Bus (Output Three-State)

Additional address bits to access a 24-bit address. These lines are driven as a Bus Master only.

#### READ (Input/Output, Three-State)

Indicates the type of operation to be performed in the current bus cycle. This signal is an output when the LANCE is a Bus Master.

High - Data is taken off the DAL by the LANCE.

Low - Data is placed on the DAL by the LANCE.

The signal is an input when the LANCE is a Bus Slave.

High - Data is placed on the DAL by the LANCE.

Low - Data is taken off the DAL by the LANCE.

BM<sub>0</sub>/BYTE, BM<sub>1</sub>/BUSAKO (Output, Three-state) The two pins are programmable through bit (00) of CSR<sub>3</sub>.

 $\overline{BM_0}$ ,  $\overline{BM_1}$  — If CSR<sub>3</sub> (00) BCON = 0

PIN 15 =  $\overline{BM_0}$  (Output Three-state) (48-Pin DIPs)

PIN 16 =  $\overline{BM_1}$  (Output Three-state) (48-Pin DIPs)

 $\overline{BM_0}$ ,  $\overline{BM_1}$  (Byte Mask). This indicates the byte(s) on the DAL are to be read or written during this bus transaction. The LANCE drives these lines only as a Bus Master. It ignores the Byte Mask lines when it is a Bus Slave and assumes word transfers.

Byte selection using Byte Mask is done as described by the following table.

BM1 BM0

| LOW  | LOW  | Whole Word |
|------|------|------------|
| LOW  | HIGH | Upper Byte |
| HIGH | LOW  | Lower Byte |
| HIGH | HIGH | None       |

BYTE, BUSAKO — If CSR<sub>3</sub> (00) BCON = 1 PIN 15 = BYTE (Output Three-state) (48-Pin DIPs) PIN 16 = BUSAKO (Output) (48-Pin DIPs)

Byte selection may also be done using the BYTE line and  $DAL_{00}$  line, latched during the address portion of the bus cycle. The LANCE drives BYTE only as a Bus Master and ignores it when a Bus Slave selection is done (similar to  $\overline{BM_0}$ ,  $\overline{BM_1}$ ).

Byte selection is done as outlined in the following table.

BYTE DAL00

| LOW  | LOW  | Whole Word        |
|------|------|-------------------|
| LOW  | HIGH | Illegal Condition |
| HIGH | LOW  | Lower Byte        |
| HIGH | HIGH | Upper Byte        |

BUSAKO is a bus request daisy chain output. If the chip is not requesting the bus and it receives HLDA, BUSAKO will

be driven LOW. If the LANCE is requesting the bus when it receives HLDA, BUSAKO will remain HIGH.

#### Byte Swapping

In order to be compatible with the variety of 16-bit microprocessors available to the designer, the LANCE may be programmed to swap the position of the upper and lower order bytes on data involved in transfers with the internal FIFO.

Byte swapping is done when BSWP = 1. The most significant byte of the word in this case will appear on DAL lines 7-0 and the least significant byte on DAL lines 15-8.

When BYTE = H (indicating a byte transfer) the table indicates on which part of the 16-bit data bus the actual data will appear.

Whenever byte swap is activated, the only data that is swapped is data traveling to 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 | Illegal                  | 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               |  |  |

#### CS Chip Select (Input)

through bit (01) of CSR3.

Indicates, when asserted, that the LANCE is the slave device of the data transfer.  $\overline{CS}$  must be valid throughout the data portion of the bus cycle.  $\overline{CS}$  must not be asserted when HLDA is LOW.

#### ADR Register Address Port Select (Input)

When LANCE is slave, ADR indicates which of the two register ports is selected. ADR LOW selects register data port; ADR HIGH selects register address port. ADR must be valid throughout the data portion of the bus cycle and is only used by the LANCE when  $\overline{CS}$  is LOW.

ALE/AS Address Latch Enable (Output, Three-State) Used to demultiplex the DAL lines and define the address portion of the bus cycle. This I/O pin is programmable

As ALE (CSR<sub>3</sub> (01), ACON = 0), the signal transitions from a HIGH to a LOW during the address portion of the transfer and remains LOW during the data portion. ALE can be used by a Slave device to control a latch on the bus address lines. When ALE is HIGH, the latch is open, and when ALE goes LOW, the latch is closed.

As  $\overline{AS}$  (CSR<sub>3</sub> (01), ACON = 1), the signal pulses LOW during the address portion of the bus transaction. The LOW-to-HIGH transition of  $\overline{AS}$  can be used by a Slave device to strobe the address into a register.

The LANCE drives the ALE/AS line only as a Bus Master.

#### DAS Data Strobe (Input/Output Three-State)

Defines the data portion of the bus transaction.  $\overline{DAS}$  is high during the address portion of a bus transaction and low during the data portion. The LOW-to-HIGH transition can be

used by a Slave device to strobe bus data into a register.  $\overline{\text{DAS}}$  is driven only as a Bus Master.

DALO Data/Address Line Out (Output, Three-State) An external bus transceiver control line. DALO is asserted when the LANCE drives the DAL lines. DALO will be LOW only during the address portion if the transfer is a READ. It will be LOW for the entire transfer if the transfer is a WRITE. DALO is driven only when LANCE is a Bus Master.

#### DALI Data/Address Line In (Output, Three-State)

An external bus transceiver control line. DALI is asserted when the LANCE reads from the DAL lines. It will be LOW during the data portion of a READ transfer and remain HIGH for the entire transfer if it is a WRITE. DALI is driven only when LANCE is a Bus Master.

#### HOLD/BUSRQ Bus Hold Request (Output, Open Drain)

Asserted by the LANCE when it requires access to memory. HOLD is held LOW for the entire ensuing bus transaction. The function of this pin is programmed through bit (00) of CSR<sub>3</sub>. Bit (00) of CSR<sub>3</sub> is cleared when RESET is asserted.

When  $CSR_3$  (00) BCON = 0

PIN 17 = HOLD (Output Open Drain and input sense) (48-Pin DIPs)

When  $CSR_3$  (00) BCON = 1

PIN 17 = BUSRQ (I/O Sense, Open Drain) (48-Pin DIPs)

If the LANCE wants to use the bus, it looks at  $\overline{HOLD}/\overline{BUSRQ}$ ; if it is HIGH the LANCE can pull it LOW and request the bus. If it is already LOW, the LANCE waits for it to go inactive-HIGH before requesting the bus.

#### HLDA Bus Hold Acknowledge (Input)

A response to  $\overline{HOLD}$ . When  $\overline{HLDA}$  is LOW in response to the chip's assertion of  $\overline{HOLD}$ , the chip is the Bus Master.

During bus master operation the LANCE waits for HLDA to be deasserted 'HIGH' before reasserting HOLD 'LOW'. This insures proper bus handshake under all situations.

#### **INTR** Interrupt (Output Open Drain)

An attention signal that indicates, when active, that one or more of the following  $CSR_0$  status flags is set: BABL, MERR, MISS, RINT, TINT or IDON. INTR is enabled by bit 06 of  $CSR_0$  (INEA = 1). INTR remains asserted until the source of Interrupt is removed.

RX Receive (Input) Receive Input Bit Stream.

TX Transmit (Output)

Transmit Output Bit Stream.

#### TENA Transmit Enable (Output)

Transmit Output Bit Stream enable. When asserted, it enables valid transmit output (TX).

#### RCLK Receive Clock (Input)

A 10-MHz square wave synchronized to the Receive data and only active while receiving an Input Bit Stream.

CLSN Collision (Input)

A logical input that indicates that a collision is occurring on the channel.

#### **RENA** Receive Enable (Input)

A logical input that indicates the presence of carrier on the channel.

TCLK Transmit Clock (Input)

#### 10-MHz clock.

#### READY (Input/Output, Open Drain)

When the LANCE is a Bus Master, READY is an asynchronous acknowledgement from the bus memory that it will accept data in a WRITE cycle or that it has put data on the DAL lines in a READ cycle.

As a Bus Slave, the LANCE asserts READY when it has put data on the DAL lines during a READ cycle or is about to take data off the DAL lines during a write cycle. READY is a response to DAS and will return High after DAS has gone High. READY is an input when the LANCE is a Bus Master and an output when the LANCE is a Bus Slave.

#### RESET Reset (Input)

Bus Request Signal. Causes the LANCE to cease operation, clear its internal logic, and enter an Idle state with the stop bit of CSR<sub>0</sub> set. It is recommended that a 3.3 k $\Omega$  pullup register be connected to this pin.

V<sub>CC</sub> Power supply pin +5 volts ±5%.

It is recommended that a  $0.1-\mu F$  and a  $10-\mu F$  decoupling capacitor be used between V<sub>CC</sub> and V<sub>SS</sub>.

#### V<sub>SS</sub> Ground.

Pin 1 and 24 (48-Pin DIPs) should be connected together externally, as close to the chip as possible.

#### PROGRAMMING

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 LANCE and in memory. There are four Control and Status Registers (CSRs) within the LANCE which are programmed by the HOST device. Once enabled, the LANCE 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:

- 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 comprised 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
- 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
- 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 LANCE may be summarized as:

- 1. Programming the LANCE'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 LANCE loading itself with the information contained within the initialization block.
- 3. The LANCE 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 I/O pin is provided.

#### ADR I/O Pin Port

| L | •        | Data Port (RDP)    |
|---|----------|--------------------|
| н | Register | Address Port (RAP) |

#### Register Data Port (RDP)

| 15 |          | 0        |
|----|----------|----------|
|    | CSR DATA |          |
|    | <u></u>  | 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. $CSR_1$ , $CSR_2$ and $CSR_3$ are accessible only when the STOP bit of $CSR_0$ is set. |
|       |          | If the STOP bit is not set while attempting to access $CSR_1$ , $CSR_2$ or $CSR_3$ , the LANCE will return READY, but a READ operation will return undefined data. WRITE operation is ignored.                                        |

#### Register Address Port (RAP)

|       | Ĺ        |                                                                         | CSR 1:0<br>RES<br>AF001490                                                   |
|-------|----------|-------------------------------------------------------------------------|------------------------------------------------------------------------------|
| Bit   | Name     | Description                                                             |                                                                              |
| 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<br>h 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> |

# Am7992B Serial Interface Adapter (SIA)



#### DISTINCTIVE CHARACTERISTICS

- Compatible with Ethernet/Cheapernet/IEEE-802.3 specifications
- Crystal/TTL oscillator 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</li>
- 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.



#### **RELATED PRODUCTS**

| Part No. | Description                                             |
|----------|---------------------------------------------------------|
| Am7990   | Local Area Network Controller for Ethernet (LANCE)      |
| Am7996   | IEEE-802.3/Ethernet/Cheapernet/Transceiver              |
| Am79C900 | Integrated Local Area Communications Controller (ILACC) |

Publication# 03378 Rev. G Amondmont/0 Issue Data June 1990

#### 1-109

#### CLSN Collision (Output, TTL Active HIGH)

Signals at the Collision ± terminals meeting threshold and pulse width requirements will produce a logic HIGH at CLSN output. When no signal is present at Collision±, 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.

**PF** Receive Path V<sub>CO</sub> Phase-Lock Loop Filter (Input) This loop filter input is the control for receive path loop damping. Frequency of the receive V<sub>CO</sub> is internally limited to transmit frequency  $\pm 12\%$ . Nominal receive V<sub>CO</sub> gain is 0.25 reference V<sub>CO</sub> gain MHz/V.

#### TEST Test Control (Input)

A static input that is connected to  $V_{CC}$  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.

FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT) DYNAMIC RAM

# DESCRIPTION

-s is a family of 4194304-word by 1-bit dynamic RAMs, -pricated with the high performance CMOS process, and ideal for large-capacity memory systems where high deal for large-capacity memory systems densities.

#### FEATURES

| T De name    | RAS<br>access<br>time<br>(m.ix_ns) | CAS<br>access<br>time<br>(max_ns) | Address<br>access<br>time<br>(max_ns) | Cycle<br>time<br>(min_ns) | Power<br>dissipa-<br>tion<br>(typ-mW) |
|--------------|------------------------------------|-----------------------------------|---------------------------------------|---------------------------|---------------------------------------|
| M5M44100 J-8 | 80                                 | 20                                | 40                                    | 160                       | 415                                   |
|              | 100                                | 25                                | 50                                    | 190                       | 350                                   |

- Standard 26 pin SOJ, 20 pin ZIP
- Single 5V±10% supply
- Low standby power dissipation
   5.5mW (Max) . . . . . . . . . . CMOS Input level
- Fast-page mode (2048 bits random access), Read-modifywrite, RAS-only refresh, CAS before RAS refresh, Hidden refresh capabilities
- Early-write operation gives common I/O capability
- All inputs, output TTL compatible and low capacitance
- 1024 refresh cycles every 16.4ms (A<sub>0</sub>~A<sub>9</sub>)
- 512K word x 8 bit test mode capability

#### APPLICATION

Main memory unit for computers, Microcomputer memory, Pefresh memory for CRT



M5M44100J, L-8, -10

MITSUBISHI LSIS

2

# M5M44100J, L-8, -10

#### FAST PAGE MODE 4194304-BIT (4194304-WORD BY 1-BIT) DYNAMIC RAM

#### FUNCTION

The M5M44100J, L provide, in addition to normal read, write, and read-modify-write operations, a number of other functions, e.g., fast-page mode, RAS-only refresh, and delayed-write. The input conditions for each are shown in Table 1.

#### Table 1 Input conditions for each mode

|                        |     |     | In  | puts |                |                   | Output | Refresh | Bemark         |
|------------------------|-----|-----|-----|------|----------------|-------------------|--------|---------|----------------|
| Operation              | RAS | CAS | w   | D    | Row<br>address | Column<br>address | 0      | neirean | Remark *       |
| Read                   | ACT | ACT | NAC | DNC  | APD            | APD               | VLD    | YES     |                |
| Write (Early write)    | ACT | ACT | ACT | VLD  | APD            | APD               | OPN    | YES     | Fast page mode |
| Write (Delayed write)  | ACT | ACT | ACT | VLD  | APD            | APD               | IVD    | YES     | identical      |
| Read-modify-write      | ACT | ACT | ACT | VLD  | APD            | APD               | VLD    | YES     |                |
| RAS-only refresh       | ACT | NAC | DNC | DNC  | APD            | DNC               | OPN    | YES     |                |
| Hidden refresh         | ACT | ACT | DNC | DNC  | DNC            | DNC               | VLD    | YES     |                |
| CAS before RAS refresh | ACT | ACT | DNC | DNC  | DNC            | DNC               | OPN    | YES     |                |
| Standby                | NAC | DNC | DNC | DNC  | DNC            | DNC               | OPN    | NO      |                |

Note - ACT active, NAC nonactive, DNC don't care, VLD valid, IVD invalid, APD, applied, OPN open



# Am79C30A/32A Digital Subscriber Controller (DSC) ISDN Data Controller (IDC)

- Combines CCITT I.430 S/T Interface transceiver, D-channel LAPD processor, and audio processor (DSC only) in a single chip
- Interrupt-driven microprocessor interface
- CMOS technology, TTL compatible
- S' or 'T' Interface Transceiver

Level 1 Physical Layer Controller Supports point-to-point, short or extended passive bus configurations Multiframe support

D-channel Processing Capability Flag generation/detection CRC generation/checking Zero insertion/deletion Four 2-byte address detectors Random number generation 8-byte transmit and receive FIFOs

Audio Processing Capability (DSC only)

Dual audio inputs Earpiece and loudspeaker drivers Filter/codec with A/mu selection Programmable gain and equalization filters Programmable sidetone level Programmable DTMF, single tone, and ringer tone generation



Issue Date: March 1989

1-1

#### **GENERAL DESCRIPTION**

The Am79C30A Digital Subscriber Controller (DSC) and Am79C32A ISDN Data Controller (IDC), shown in the block diagram, provide the Terminal Equipment access to the ISDN. The Am79C30A/32A is compatible with the CCITT I-Series recommendations at the 'S' reference point allowing the user of the device to design TEs which conform to the international ISDN standards.

The Am79C30A/32A provides a 192 kbps full duplex digital path between the TE located in the subscriber's premises and the NT or PABX line card over 4-wires. The Am79C30A/32A separates the bit stream into the B1- (64 kbps), B2- (64 kbps) and D- (16 kbps) channels. The B-channels are routed to different sections of the Am79C30A under user control. The D-channel is partially processed in the Am79C30A/32A and passed to the microprocessor for further processing.

The transmission rate of 192 kbps provides a 48-bit frame every 250  $\mu$ s for framing and maintenance. The frame structure provides for frame synchronization and multiple terminal contention resolution as described in the CCITT I-series recommendations. Both point-to-point and point-to-multipoint connections are supported.

The Am79C30A can be used as a voice telephone, a digital data terminal, or a voice and data terminal. The Am79C32A can be used as a digital data terminal.

The audio processor in the Am79C30A, shown in the block diagram, uses Digital Signal Processing (DSP) to implement the codec and filter functions. The audio processor interfaces to a speaker, an earpiece, and two separate audio inputs. In the receive and transmit paths the user may program gain or alter the frequency response. The audio processor is not available in the Am79C32A.

A serial port gives the user access to the B-channels of the Am79C30A/32A multiplexer. This serial port may be used by data terminals and provides, with additional circuitry, access to the CCITT 'R' reference point.

The Am79C30A/32A is controlled via an interrupt driven microprocessor bus interface by an external microprocessor. Using this interface, the microprocessor processes the D-channel information and programs the Am79C30A/32A accordingly. This includes programming a multiplexer within the Am79C30A/32A to route the B-channels as specified by the D-channel control information. The microprocessor can interrogate and program the Am79C30A/32A via its mode, status, and error registers.

#### CONNECTION DIAGRAMS Top View

LS2 C 1 40 D LSI EAR<sub>1</sub> 2 39 EAR<sub>2</sub> 38 3 AINA 4 37 AINB С 36 р нем 5 CAP<sub>1</sub> LOUT1 6 35 CAP2 С 7 34 1 LOUT DSC Vcc Г 8 33 ₽ vss RESET C 9 32 Am79C30A CS TAL1 10 31 RD 30 b XTAL2 11 PDIP WR 12 29 D WCLK vss 13 28 SFS A<sub>2</sub> 27 SCLK 14 SBOUT 26 A<sub>1</sub> D SBIN A 0 25 16 D\_7 17 24 E  $D_6$ 18 **□** D<sub>1</sub> 23 D<sub>5</sub> D<sub>4</sub> 22 D D<sub>2</sub> 21 D D<sub>3</sub> 19 20 09456-35B

40 Pin Dusi-In-Line Package





Figure 2. Am79C30A DSC Connection Diagrams

Am79C30A/32A

#### **PIN DESCRIPTION**

All signal levels are TTL compatible unless otherwise stated.

#### Line Interface Unit (LIU)

#### HSW

#### Hook-Switch (Input)

The HSW signal indicates if the hookswitch is on or off hook. This signal may be generated with a mechanical switch wired to ground with a pull-up resistor to Vcc. Any change in the HSW state causes an interrupt.

#### LIN1, LIN2

#### Subscriber Line Input (Differential Inputs)

The LIN1 and LIN2 inputs interface to the subscriber ('S' reference point) via an isolation transformer. LIN2 is the positive input, LIN1 is the negative input. These pins are not TTL compatible.

#### LOUT1, LOUT2

#### Subscriber Line Output (Differential Outputs)

The LOUT1 and LOUT2 line driver output signals interface to the subscriber line at the 'S' reference point via an isolation transformer and resistors. LOUT2 is the positive 'S' interface driver (that is, sources current during a high mark) and LOUT1 is the negative 'S' interface driver (that is, sources current during low mark). For multipoint applications, all TE's must maintain the same polarity on the 'S' interface. These pins are not TTL compatible.

#### Multiplexer (MUX)

#### SBIN

#### Serial Channel (Input)

The data rate on SBIN is 192 kbps. SBIN consists of three 64 kbps serial channels. Data bytes are received MSB first.

#### SBOUT

#### Serial Channel (Output)

The data rate on SBOUT is 192 kbps. SBOUT consists of three 64 kbps serial channels. Data bytes are transmitted MSB first.

#### SCLK

#### Serial Clock (Output)

SCLK is a 192 kbps synchronization clock which defines the position of the serial bits in the SBOUT and SBIN channels. Data at the SBIN input must be valid on the rising edge of SCLK. The data on the SBOUT pin changes on the falling edge of SCLK. SCLK powers up tri-stated, and is enabled when a MUX connection is programmed.

#### SFS

#### Serial Channel Frame Sync. (Output)

SFS is an 8 kHz signal which identifies the beginning of each frame by a low to high transition. The 192 kbps data stream on SBIN and SBOUT is referenced to SFS. SFS powers up tri-stated, and is enabled when a MUX connection is programmed.

#### Main Audio Processor (MAP)

All MAP pins are analog, and hence not TTL compatible.

#### AINA, AINB Analog (Inputs)

These analog inputs allow for two separate analog (audio) inputs to the transmit path of the codec/ filter. Input signals on either of these pins must be referenced to AREF.

#### AREF

#### Analog Reference (Output)

This is a nominal 2.4 V reference voltage output for biasing the analog inputs. Note that AREF is only available when the MAP is active.

#### CAP1, CAP2

#### Capacitor/Resistor (CAP1, Input; CAP2, Output)

An external resistor and capacitor are connected in series between these pins. These components are needed for the integrator in the Analog to Digital Converter (ADC).

#### EAR1, EAR2

#### Earplece Interface (Differential Outputs)

EAR1 and EAR2 are the outputs from the receive path of the filter codec. These differential outputs can directly drive 600 ohms.

#### LS1, LS2

#### Loudspeaker Interface (Differential Outputs)

LS1 and LS2 are push-pull outputs which can directly drive a 50 ohm budspeaker.

#### Microprocessor Interface (MPI)

#### A2-A0

#### Address Line (Inputs)

A2, A1, and A0 signals select source and destination registers for read and write operations on the data bus.

#### <u>CS</u>

#### Chip Select (Input)

CS must be low to read or write to the Am79C30A/32A. Data transfer occurs over the bidirectional data lines (D7-D0).

#### D7-D0

#### Data Bus (Bidirectional with High Impedance State)

The eight bidirectional data bus lines are used to exchange information with the microprocessor. D0 is the least significant bit (LSB) and D7 is the most signifi bit (MSB). A high on the data bus line corresponds logic '1' and low corresponds to a logic '0'. These lines act as inputs when both  $\overline{WR}$  and  $\overline{CS}$  are active and as outputs when both  $\overline{RD}$  and  $\overline{CS}$  are active. When  $\overline{CS}$  is inactive or both  $\overline{RD}$  and  $\overline{WR}$  are inactive, the D0-D7 pins are in a high impedance state.

#### INT

#### Interrupt (Output)

An active low output on the  $\overline{\text{INT}}$  pin informs the external microprocessor that the Am79C30A/32A needs interrupt service.  $\overline{\text{INT}}$  is updated once every 125 µs. The  $\overline{\text{INT}}$  pin remains active until the Interrupt Register (IR) is read or the Am79C30A/32A is reset.

#### RESET

#### Reset (Input)

Reset is an active high signal which causes the Am79C30A/32A to immediately terminate its present activity and initialize to the reset condition. When reset returns low, the Am79C30A/32A enters the idle mode.

#### RD

#### Read (Input)

The active low read signal is conditioned by  $\overline{CS}$  and indicates that internal information is to be transferred onto the data bus. A number of internal registers are user accessible. The contents of the accessed register are transferred onto the data bus after the high to low transition of the  $\overline{RD}$  input.

#### WR

#### Write (Input)

The active low write signal is conditioned by  $\overline{CS}$  and indicates that external information on the data bus is to be transferred to an internal register. The contents of the data bus are loaded on the low to high transition of the  $\overline{WR}$  input.

#### Oscillator (OSC) MCLK Master Clock (Output)

The MCLK output is available for use as the system clock for the microprocessor. It is derived from the 12.288 MHz crystal via a programmable divider in the Am79C30A/32A which provides the following MCLK output frequencies: 12.288, 6.144, 4.096, and 3.072 MHz.

#### XTAL1, XTAL2

External Crystal (Output/Input)

XTAL1 and XTAL2 are connected to an external parallel resonant crystal for the on-chip oscillator. XTAL2 can also be connected to an external source instead of a crystal, in which case XTAL1 should be left disconnected. The frequency must be 12.288 MHz, ± 80 ppm.

#### **Power Supply Pins**

#### PLCC Packages

AV $\infty$  +5V analog power supply ±5% (PLCC only)

- AVss Analog ground (PLCC only)
- DVss Digital ground (PLCC only)
- $DV\infty$  +5V digital power supply, ±5% (PLCC only)

#### **DIP Packages**

Vcc +5V power supply, ±5% (DIP only)

Vss Ground (DIP only)

Note: For best performance, decoupling capacitors should be installed between Vcc and Vss as close to the chip as possible. Do not use separate supplies for analog and digital power and ground connections.

#### **OPERATIONAL DESCRIPTION**

In order to specify the functions of the Am79C30A/32A, the device has been divided into blocks as shown in the block diagram. Each of the blocks listed below is defined separately in the Functional Description.

LIU Line Interface Unit

- MUX Multiplexer
- MAP Main Audio Processor (Am79C30A only)
- DLC Data Link Controller

MPI Microprocessor Interface

OSC Oscillator and Timing Circuitry

#### User Accessible Registers/Buffers

The microprocessor interface is used to program and control the operation of the Am79C30A/32A. The following registers/buffers are user accessible in each of the blocks listed above and are described in the respective Functional Description Sections.

| Registers                                                       | No. | Mnemonic |
|-----------------------------------------------------------------|-----|----------|
| Line Interface Unit (LIU)                                       |     |          |
| LIU Status Register                                             | 1   | LSR      |
| LIU Priority Register                                           | 1   | LPR      |
| IU Mode Registers                                               | 2.  | LMR      |
| Multiframe Register                                             | 1   | MF       |
| Multiframe S-Bit/Status Buffer                                  | 1   | MFSB     |
| Multiframe Q-Bit Buffer                                         | 1   | MFQB     |
| Multiplexer (MUX)                                               |     |          |
| MUX Control Registers                                           | 4   | MCR      |
| Main Audio Processor (MAP)<br>Am79C30A only)                    |     |          |
| K Filter Coefficient Registers                                  | 16  | x        |
| R Filter Coefficient Registers                                  | 16  | · R      |
| GX Gain Coefficient Registers                                   | 2   | GX       |
| GR Gain Coefficient Registers                                   | 2   | GR       |
| GER Gain Coefficient Registers                                  | 2   | GER      |
| Sidetone Gain Coefficient Registers                             | 2   | STGR     |
| Frequency Tone Generator Registers                              | 2   | FTGR     |
| Amplitude Tone Generator Registers                              | 2   | ATGR     |
| MAP Mode Registers                                              | 2   | MMR      |
| Data Link Controller (DLC)                                      |     |          |
| First Received Byte Address Registers                           | 4   | FRAR     |
| Second Received Byte Address Registers                          | 4   | SRAR     |
| Transmit Address Register (16 bit)                              | 1   | TAR      |
| D-channel Receive Byte Limit Register (16 bit)                  | 1   | DRLR     |
| D-channel Receive Byte Count Register (16 bit) (2 byte FIFO)    | 1   | DRCR     |
| D-channel Transmit Byte Count Register (16 bit)                 | 1   | DTCR     |
| Random Number Generator Registers                               | 2   | RNGR     |
| D-channel Mode Registers                                        | 4   | DMR      |
| D-channel Status Registers                                      | 2   | DSR      |
| Address Status Register (2 byte FIFO)                           | 1   | ASR      |
| D-channel Error Register (2 byte FIFO)                          | 1   | DER      |
| Microprocessor Interface (MPI)                                  |     |          |
| Initialization Register                                         | 1   | ' INIT   |
| Command Register                                                | 1   | CR       |
| Interrupt Register                                              | 1   | IR       |
| Data Register                                                   | 1   | DR       |
| D-channel Transmit Buffer (8 byte FIFO)                         | 1   | DCTB     |
| D-channel Receive Buffer (8 byte FIFO)                          | 1   | DCRB '   |
| Bb Transmit Buffer                                              | 1   | BBTB     |
| Bb Receive Buffer                                               | 1   | BBRB     |
| Bc Transmit Buffer                                              | 1   | BCTB     |
| Bc Receive Buffer                                               | 1   | BCRB     |
| Note: See the Microprocessor Interface section for register add |     |          |

#### Initialization

The initialization procedure is controlled via the Initialization Register (INIT) which is accessed by the microprocessor as defined in the Microprocessor Interface Initialization Register (INIT), Read/Write section. This Initialization Register (INIT) has the following format:

| Bit #      |   |   |   |   | ł |   |    |                         |                             |
|------------|---|---|---|---|---|---|----|-------------------------|-----------------------------|
| 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0  | Control                 | Function                    |
| x          | x | x | x | x | x | 0 | 0  | Power Mode Selection    | Idie Mode (default)         |
| X          | Х | Х | Х | Х | Х | 0 | 1  |                         | Active Mode (voice & data)  |
| X          | Х | Х | Х | Х | Х | 1 | 0  |                         | Active Mode (Data only)     |
| <b>X</b> : | X | X | X | Х | X | 1 | 1  |                         | Reserved                    |
| x          | х | x | x | x | 0 | x | x  | Interrupt Selection     | Enable INT pin (default)    |
| X          | X | х | x | х | 1 | x | x  | •                       | Disable INT pin             |
| x          | x | 0 | 0 | 0 | x | х | X  | ·                       | Divide by 2 (default)       |
| x z        | X | Õ | 0 | 1 | X | X | X  | Clock Divider Selection | Divide by 1                 |
| x :        | X | 0 | 1 | 0 | Х | Х | X  |                         | Divide by 4                 |
| X X        | X | 0 | 1 | 1 | Х | Х | х  |                         | Divide by 2                 |
| X X        | X | 1 | 0 | 0 | Х | Х | х  |                         | Divide by 3                 |
| x )        | X | 1 | 0 | 1 | Х | Х | Х  |                         | Divide by 2                 |
| XX         | Х | 1 | 1 | 0 | Х | Х | Х  |                         | Divide by 2                 |
| <u>x x</u> | X | 1 | 1 | 1 | X | X | X  |                         | Divide by 2                 |
| X          | 1 | x | x |   |   | x | x  | Abort Selection         | Receive abort               |
| X (        | 0 | Х |   |   | Х | Х | Χ. |                         | No Receive abort (default)  |
| 1)         | X | X | Х | Х | Х | Х | X  |                         | Transmit abort              |
| 0 >        | X | Х | Х | Х | Х | Х | х  |                         | No Transmit abort (default) |

#### Reset

The Am79C30A/32A can be reset by driving the reset pin high. When power is first supplied to the Am79C30A/32A, a reset must be asserted. This

#### **Idle Mode Operation**

To conserve power the Am79C30A/32A can be placed in the idle mode. This can be done by either asserting the RESET signal or by clearing bits 0 and 1 in the INIT initializes the Am79C30A/32A to its default values as defined in the subsequent sections. After reset, the Am79C30A/32A enters the idle mode.

register. When the Am79C30A/32A is in the idle mode, and there is no activity on any of the external interfaces, the state of the output pins are:

| idie Mode             |  |  |  |  |
|-----------------------|--|--|--|--|
|                       |  |  |  |  |
| ion section)          |  |  |  |  |
| y internal conditions |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |
|                       |  |  |  |  |

### FUNCTIONAL DESCRIPTION Microprocessor Interface (MPI)

The Am79C30A/32A can be connected to any general purpose 8-bit microprocessor via the MPI. The MCLK from the Am79C30A/32A can be used as the clock for the microprocessor. The MPI is an interrupt driven interface containing all the circuitry necessary for access to the internal programmable registers, status registers, coefficient RAM, and transmit/receive buffers.

### **MPI External Interface**

The MPI has the following external connections:

| Name         | Direction     | Function       |
|--------------|---------------|----------------|
| D7-D0        | Bidirectional | Data Bus       |
| A2, A1, & A0 | Inputs        | Address Line   |
| RD           | Input         | Read enable    |
| WR           | Input         | Write enable   |
| <u>CS</u>    | Input         | Chip Select    |
| RESET        | Input         | Initialization |
| INT          | Output        | Interrupt      |

## **Register Selection**

#### **Directly Accessed Registers/Buffers**

| Register                               | Mnemonic |
|----------------------------------------|----------|
| Command Register                       | CR       |
| Interrupt Register                     | IR       |
| Data Register                          | DR       |
| D-channel Status Register 1            | DSR1     |
| D-channel Error Register (2 byte FIFO) | DER      |
| D-channel Transmit Buffer (8 byte FIFC | ) DCTB   |
| D-channel Receive Buffer (8 byte FIFO) | DCRB     |
| Bb Transmit Buffer                     | BBTB     |
| Bb Receive Buffer                      | BBRB     |
| Bc Transmit Buffer                     | BCTB     |
| Bc Receive Buffer                      | BCRB     |
| D-channel Status Register 2            | DSR2     |

The 8-bit bidirectional data bus (D7-D0) is used to  $\infty$ municate with these registers. The selection of which register(s) is (are) accessed is controlled by the  $\overline{CS}$ ,  $\overline{RD}$ ,  $\overline{WR}$ , A2, A1, and A0 signals from the microprocessor to the Am79C30A/32A in the following manner (see Figure 4):

| CS | RD | WR | A2 | A1 | <b>A</b> 0 | Register(s) Accessed                                      |
|----|----|----|----|----|------------|-----------------------------------------------------------|
| 0  | 1  | 0  | 0  | 0  | 0          | Command Register (CR), write only                         |
| 0  | 0  | 1  | 0  | 0  | 0          | Interrupt Register (IR), read only                        |
| 0  | 1  | 0  | 0  | 0  | 1          | Data Register (DR), write only                            |
| 0  | 0  | 1  | 0  | 0  | 1          | Data Register (DR), read only                             |
| 0  | 0  | 1  | 0  | 1  | 0          | D-channel Status Register 1 (DSR1), read only             |
| 0  | 0  | 1  | 0  | 1  | 1          | D-channel Error Register (DER), read only (2 byte FIFO)   |
| 0  | 1  | 0  | 1  | Ο. | .' 0       | D-channel Transmit Buffer (DCTB), write only (8 byte FIFO |
| 0  | 0  | 1  | 1  | 0  | 0          | D-channel Receive Buffer (DCRB), read only (8 byte FIFO)  |
| 0  | 1  | 0  | 1  | 0  | 1          | Bb channel Transmit Buffer (BBTB) write only              |
| 0  | 0  | 1  | 1  | 0  | 1          | Bb channel Receive Buffer (BBRB), read only               |
| 0  | 1  | 0  | 1  | 1  | 0          | Bc channel Transmit Buffer (BCTB), write only             |
| 0  | 0  | 1  | 1  | 1  | 0          | Bc channel Receive Buffer (BCRB), read only               |
| 0  | 0  | 1  | 1  | 1  | 1          | D-channel Status Register 2 (DSR2), read only             |
| 1  | Х  | Х  | х  | Х  | х          | No access (X = logical '0' or '1')                        |

Note: The RD and WR signals must never both be low under normal operating conditions.

#### Command Register (CR), Write only

The Command Register (CR) is used to hold the index for the indirectly accessed registers. The CR is one byte wide and divided into two fields, the destination code field (DCF) and the operational code field (OCF):



The 'Y' bits in the DCF determine to which block the OCF is related. The 'Y' bits are defined below:

| Am79C30A/32A block  | ¥2 | Y1  | YO |
|---------------------|----|-----|----|
| RESERVED            | 0  | 0   | 0  |
| INIT                | 0  | 0   | 1  |
| MUX                 | 0  | 1   | 0  |
| MAP (Am79C30A only) | 0  | 1   | 1  |
| DLC                 | 1  | 0   | 0  |
| LIU                 | 1  | 0   | 1  |
| RESERVED            | 1  | . 1 | 0  |
| RESERVED            | 1  | 1   | 1  |

The 'Z' bits of the OCF contain the operation code used to address a specific register within a DCF block. For each DCF there is a different set of OCFs. Each of the OCFs and their associated data registers are defined in the following sections. When the OCF indicates a read or write operation is possible, then the appropriate access is achieved by asserting either the read or write signals to the Am79C30A/32A.

Registers within certain groups can be quickly accessed by using internal circuitry which automatically increments the indirect address (index value) contained in the OCF. The CR is first loaded with the index value, then the data bytes are transferred in sequence between the Am79C30A/32A and the microprocessor via the DR. For example, operation number 5 in the MPI-LIU definition allows operations 2 to 4 to be performed sequentially without reloading the CR. Whenever the CR register is loaded, any previous commands are automatically terminated.

In the following tables the "bytes transferred" numbers next to the OCFs are the number of bytes which are read or written to the DR after the CR has been loaded.

#### **MPI-INIT Definition**

The INIT register is used by the microprocessor to select the MCLK output frequency and the power-up/idle

states of the Am79C30A/32A. This register is accessed via the 'Z' bits in the CR as follows:

|                               |    |    | oc | F  |            |                      |
|-------------------------------|----|----|----|----|------------|----------------------|
| INIT OPERATION<br>(DCF = 001) | Z4 | Z3 | Z2 | Z1 | <b>Z</b> 0 | Bytes<br>Transferred |
| R/W INIT register             | 0  | 0  | 0  | 0  | 1          | 1                    |

#### **MPI-LIU Definition**

The LIU contains the following registers:

| LIU Registers           | No. | Mnemonic   |
|-------------------------|-----|------------|
| LIU Status Register     | 1   | LSR        |
| LIU Priority            | 1   | LPR        |
| LIU Mode Registers      | 2   | LMR1, LMR2 |
| Multiframe Register     | 1   | MF         |
| Multiframe S-bit Buffer | 1   | MFSB       |
| Multiframe Q-bit Buffer | 1   | MFQB       |

These registers are accessed via the 'Z' bits in the CR as follows:

|                              | OCF |    |    |            |            |                      |
|------------------------------|-----|----|----|------------|------------|----------------------|
| LIU OPERATION<br>(DCF = 101) | Z4  | Z3 | Z2 | <b>Z</b> 1 | <b>Z</b> 0 | Bytes<br>Transferred |
| 1. Read LSR                  | 0   | 0  | 0  | 0          | 1          | 1                    |
| 2. R/W LPR                   | Ó   | 0  | 0  | 1          | 0          | 1                    |
| 3. R/W LMR1                  | 0   | 0  | 0  | 1          | 1          | 1                    |
| 4. R/W LMR2                  | 0   | 0  | 1  | 0          | 0          | 1                    |
| 5. Perform<br>Operations 2-4 | 0   | 0  | 1  | 0          | 1          | . 3                  |
| 6. Read/Write MF             | 0   | 0  | 1  | 1          | 0          | 1                    |
| 7. Read MFSB`                | 0   | 0  | 1  | 1          | 1          | 1                    |
| 8. Write MFQB                | 0   | 1  | 0  | 0          | 0          | 1                    |

#### **MPI-MUX** Definition

The MUX contains four microprocessor read/write control registers MCR1, MCR2, MCR3, and MCR4. These registers are accessed via the 'Z' bits in the CR as follows:

|                              | F          |            |    |            |            |                      |
|------------------------------|------------|------------|----|------------|------------|----------------------|
| MUX OPERATION<br>(DCF = 010) | <b>Z</b> 4 | <b>Z</b> 3 | Z2 | <b>Z</b> 1 | <b>Z</b> 0 | Bytes<br>Transferred |
| 1. R/W MCR1                  | 0          | 0          | 0  | 0          | 1          | 1                    |
| 2. R/W MCR2                  | 0          | Ō          | Ō  | 1          | 0          | 1                    |
| 3. R/W MCR3                  | 0          | 0          | 0  | 1          | 1          | 1                    |
| 4. R/W MCR4                  | 0          | Ō          | 1  | 0          | Ó          | 1                    |
| 5. Perform<br>Operations 1-4 | 0          | 0          | 1  | 0          | 1          | 4                    |

When more than one byte is being transferred due to OCF command 5, MCR1 is always accessed first, followed by MCR2, then MCR3, and finally MCR4.

#### Main Audio Processor (MAP) (Am79C30A Only)

This block performs the digital-to-analog (DAC) and analog-to-digital (ADC) conversions of the audio signals. The codec and filter functions are implemented using digital signal processing techniques to provide substantial flexibility and programmability. Analog interfaces are provided for a handset earpiece, a handset mouthpiece, a microphone and a loudspeaker. The MAP contains the following programmable, user accessible features:

#### Multi-Tone Generator

This generator can be used to generate a signal consisting of one or two tones where the frequency and amplitude of the tone is programmable. The tone(s) can be summed into the transmit (and sidetone) path for use as a DTMF tone generator, or single tones can be injected into the receive path. The tones can be used as ringing tones (to the loudspeaker output), dial tones, busy signals, ringback tones or other call progress tones.

#### **Two Attenuation Distortion Correction Filters**

There is one attenuation distortion correction filter in the transmit path and one in the receive path. These filters can be programmed to modify the frequency characteristics of the transmit or receive paths and to equalize for the characteristics of the microphones, earpiece speaker, or loudspeaker. They can also be used to add pre and/or post emphasis to make the signals match other characteristics.

#### Three Programmable Gain Stages

There is one gain adjustment in the transmit path and two in the receive path to provide a wide range of gain control.

#### Programmable Sidetone Gain

There is a built-in sidetone path which samples the transmit signal, attenuates it by a programmable amount, then sums it into the receive path.

#### **External Interface**

#### Audio Input Port

The audio input port consists of two inputs (AINA and AINB) selectable, one at a time, by setting a bit in the MAP Mode Register 2, (MMR2 bit 0). Signals applied to these inputs must be referenced to AREF.

#### **Earpiece and Loudspeaker Drivers**

Each driver consists of push-pull amplifiers with a low impedance output. Either of these audio output ports can be selected, one at a time, via MMR2 bit 1.



\*Programmable \*\*These registers can also be programmed for inifinite attenuation to break the signal path if desired.

#### Figure 9. Main Audio Processor Block Diagram

09456-31B

#### **AC** Characteristics

 $Vcc = 5 V \pm 5\%$ , Vss = 0 V;  $TA = 0^{\circ}C \longrightarrow 70^{\circ}C$ , MCLK = 3.072 MHz

MAP Analog Characteristics (Am79C30A only)

| Parameter<br>Symbol | Parameter<br>Description                                            | Test Conditions                                                                                                | Min                  | Max | Units         |
|---------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------|-----|---------------|
| Zin                 | Analog input impedance<br>AINA or AINB to AREF                      | -1.25 V < Vin <+ 1.25 V<br>1in <4 kHz                                                                          | < 200 v              |     | Kohm          |
| Vios                | Allowable offset voltage .<br>at AINA or AINB                       | with respect to<br>AREF pin                                                                                    | -5                   | +5  |               |
| Vir                 | Analog input full scale<br>reference level AINA or AINB             | with respect to AREF pin                                                                                       | ±1.25<br>(nominal)   |     | Vpeak         |
| Vpr                 | Analog output full<br>scale reference level<br>(PCM code = +3 dBm0) | EAR1 to EAR2 with RLOAD > 540<br>and CLOAD <100 pF, or<br>LS1 to LS2 with RLOAD > 40 ohm<br>and CLOAD < 100 pF | (nominal)            |     | <b>Vp</b> eak |
| Zls                 | Allowable Load LS1 to LS2                                           |                                                                                                                | RLOAD > CLOAD        | and |               |
| Zear                | Allowable Load<br>EAR1 to EAR2                                      |                                                                                                                | RLOAD > 5<br>CLOAD < | and |               |

Am79C30A/32A

\_

# intel

# 82072 CHMOS HIGH INTEGRATION FLOPPY DISK CONTROLLER

- Integrated Analog Data Separator with Software Selectable Data Rates (250K, 300K, 500K, Bit/Sec-MFM Mode)
- 16 Byte FIFO with Programmable Threshold
- High Speed Processor Interface
   16 MHz iAPX 386— 1 Wait State
   12.5 MHz iAPX 286—1 Wait State
   8 MHz iAPX 286— 0 Wait State
- Programmable Internal Write Precompensation Delays

- Programmable Drive Motor On/Off Delays
- Addresses Up to 256 Tracks Directly, Supports Unlimited Tracks
- Implied Seek with Read/Write Disk Commands
- Software Compatible with 8272A
- Controls 8", 5¼" and 3½" Floppy Disk Drives
- Plastic 40 Pin DIP or 44 Pin PLCC Packages

(See Packaging Spec. Order #231369)

The 82072 CHMOS high integration floppy disk controller solves the many complex disk drive and microprocessor interface issues that exist today, while maintaining software compatibility with the industry standard 8272A. Features include a sophisticated on-chip analog phase lock loop with software selectable data rates, write precompensation delay, and motor on/off delays to simplify the disk drive interface. System interfacing is enhanced with the addition of a FIFO which allows a more flexible system to be designed.

The standard 82072 supports a maximum data rate of 500 Kbits per second,

The 82072 is fabricated on Intel's advanced CHMOS III technology for minimal power consumption and is available in a plastic 40 pin DIP or a plastic 44-leaded chip carrier (PLCC) package.





| Symbol    | DIP  | PLCC        | 1/0 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|-----------|------|-------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| DACK      | 1    | 2           | 1   | <b>DMA ACKNOWLEDGE:</b> DMA control line that qualifies the $\overline{RD}$ and $\overline{WR}$ inputs during DMA cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| RD        | 2    | 3           | 1   | READ: Control signal to transfer data to the data bus from the 82072.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| WR        | 3    | 4           | 1   | WRITE: Control signal to transfer data into the 82072 from the data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| <u>CS</u> | 4    | 5           | 1   | CHIP SELECT: Control signal that qualifies the $\overline{RD}$ and $\overline{WR}$ inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| A0        | 5    | 6           | 1   | ADDRESS:<br>A0 RD WR Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| DB0-7     | 6-13 | 7-11,       | 1/0 | 0       0       0       Illegal *         0       0       1       Read Main Status<br>Register         0       1       0       Write to the Data Rate Select<br>Register **         0       1       0       Write to the Data Rate Select<br>Register **         0       1       1       No Action         1       0       0       Illegal *         1       0       1       Read from FIFO         1       1       Read from FIFO         1       1       0       Write into FIFO         1       1       No Action         * User must ensure that these inputs do not occur.       **         ** Change from 8272A—was illegal.       DATA BUS: Bidirectional 8-bit data bus. A0 determines whether transfer is to (from the FIFO or Main Status Register |  |  |  |  |  |
| DRQ       | 14   | 13–15<br>16 | 0   | transfer is to/from the FIFO or Main Status Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| TC        | 14   | 17          | 1   | DMA REQUEST: Used to request service from a DMA controller.<br>TERMINAL COUNT: Control line from a DMA controller used to<br>terminate requests for data transfers. Disk read and write commands<br>complete the transfer to the current sector with valid CRC checking/<br>generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| IDX       | 16   | 18          | I   | <b>INDEX:</b> Disk drive signal that indicates the beginning of a track. It is used to count retries and delay periods for internal (i.e. Motor On/Off) timers and is rising edge triggered.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| INT       | 17   | 19          | 0   | Interrupt: Interrupt to host to indicate command completion or that a data transfer is required (depending upon the data transfer mode).<br>Command completion interrupts are cleared by reading the ST0 Status Register. Data transfer interrupts are cleared when the amount of data in the FIFO reaches the full or empty level (depending on FIFO direction) or a TC is issued.                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| RESET     | 18   | 20          |     | direction) or a TC is issued.<br><b>RESET:</b> Places the 82072 in a known idle state. All disk outputs are set<br>to a low level. All registers, except those set by the SPECIFY<br>command, are cleared.<br>From the trailing edge of Reset, there is a maximum delay of 8<br>microseconds until the Main Status register is valid.<br>Following reset, the 82072 defaults to polling enabled.<br>The default values for the new features are: internal data separator<br>enabled, write precompensation value is 125 ns, MOTOR on delay is<br>0.0 sec., MOTOR off delay is 5.2 sec., data rate is dependent on DDRE<br>setting, FIFO disabled.                                                                                                            |  |  |  |  |  |

| Table 1. 82072 Pin Description (Continued) |        |            |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|--------------------------------------------|--------|------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Symbol                                     | DIP    | PLCC       | 1/0       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| X1                                         | 19     | 21         | 1         | <b>CRYSTAL 1:</b> External connection for a fundamental mode parallel resonant 24 MHz crystal for the internal oscillator. May be driven with a MOS level clock instead of a crystal. Refer to the D.C. Specifications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| X2                                         | 20     | 22         | 1         | <b>CRYSTAL 2:</b> If an external clock is supplied on X1, this input must be left unconnected (floating).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| V <sub>SS</sub>                            | 21, 25 | 23, 24, 28 |           | LOGIC GROUND.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| DW/DDRE                                    | 22     | 25         |           | DATA WINDOW/DEFAULT DATA RATE ENABLED: Clock from<br>the external PLL logic used to sample the Read Data input. When the<br>internal PLL is used, this input pin is used to define the data rate and<br>write precompensation values after RESET. DDRE tied high will<br>cause the data rate and precompensation bits of the DSR to be<br>reinitialized to the default values of 250 Kbps and 125 ns delay when<br>a hardware/software reset is issued. DDRE tied low will cause the<br>current data rate and precompensation values in the DSR to be<br>retained when a hardware reset is issued. When a software reset is<br>issued, the DSR will contain those values written into the register.<br>DDRE tied low should be used in applications where data rate and<br>precompensation information needs to be retained regardless of chip<br>reset. |  |  |
| RDDATA                                     | 23     | 26         | Ì.        | READ DATA: Serial FM or MFM encoded data from the disk drive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| VCO/LD                                     | 24     | 27         | 0         | <b>READ DATA GATE:</b> This active high output enables an external PLL to synchronize to Read Data input from the disk drive.<br><b>LOW DENSITY:</b> This active high output is used by quad density disk drives to modify Read/Write head and data channel characteristics. This signal is activated when internal PLL is enabled and a data transfer rate of 250 or 300 Kbps is chosen.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| AVSS                                       | 26     | 29         | • •<br>•• | Analog ground for the Datà Separator. It is recommended that care<br>be taken to keep AVSS as noise free as possible. A separate<br>connection to the ground plane is suggested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| WE                                         | 27     | 30         | 0         | WRITE ENABLE: Disk drive control signal that enables the head to write onto the disk.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| MFM                                        | 28     | 31         | 0         | <b>MFM MODE:</b> When an external PLL is used, this output selects between single and double density (FM and MFM) modes. $1 = MFM$ , $0 = FM$ mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| MOTOR                                      | 29     | 32         | 0         | <b>MOTOR ENABLE:</b> Output used to activate the drive motor on the selected drive. Delays are programmable. With one output, this pin must be qualified with the drive select logic to provide motor enables for each drive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| HDSEL                                      | 30     | 33         | 0         | <b>HEAD SELECT:</b> Signal used to select one of two sides on the disk. A $0 = side 0, a 1 = side 1.$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| DS1, 0                                     | 31, 32 | 35, 36     | 0         | <b>DRIVE SELECT:</b> These outputs select one of four disk cirives. DS0, $DS1 = 0, 0$ will select drive 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| WRDATA                                     | 33     | 37         | C         | WRITE DATA: FM or MFM encoded serial data to the disk drive. No external precompensation is required.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| TRK0                                       | 34     | 38         | ľ         | <b>TRACK 0:</b> Control line from the disk drive that indicat es the head is on physical track 0 (outermost track).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| WP                                         | 35     | 39         | 1         | WRITE PROTECT: Input from the disk drive that indicates if the disk is physically write protected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |

ł

| Symbol | DIP | PLCC  | 1/0 | Function                                                                                                                         |
|--------|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------|
| RDY    | 36  | 40    | ł   | <b>READY:</b> Input from the disk drive that indicates whether the drive is ready for an operation.                              |
| HDL    | 37  | 41    | 0   | HEAD LOAD: This output loads the head onto the disk drive if required. Typically used by 8" drives.                              |
| STP    | 38  | 42    | 0   | STEP: Output used to supply step pulses to the disk drive.                                                                       |
| DIR    | 39  | 43    | 0   | <b>DIRECTION:</b> This output, in conjunction with STP, causes the drive to move the head outward if a "0", and inward if a "1". |
| VCC    | 40  | 1, 44 |     | Logic DC power supply.                                                                                                           |

Table 1. 82072 Pin Description (Continued)

#### NOTE:

. 1. Pins 12, 34 of the 44 pin PLCC package are not connected.

#### INTRODUCTION

The 82072 has integrated all of the complex circuitry required to interface microprocessor systems with disk drives that comply with the IBM System 34 Double Density (MFM) format or the IBM 3740 single density format (FM). The 82072 is a superset of the

8272A. Control over the new features was accomplished by adding extra registers and commands to the 82072. The 82072 will function like the 8272A Floppy Disk Controller (FDC) after being reset, with the added features being set to 8272A compatible default values. When accessing the disk drives, the 82072 is programmed the same as the 8272A.



Figure 2. 82072 Typical System Block Diagram

÷,

# intel

The microprocessor interface was enhanced by adding a 16 byte FIFO to reduce the timing constraints that most floppy disk controllers impose upon a system. The point at which the 82072 generates a request for a data transfer is selectable within the 16 byte range of the FIFO. The interface was further enhanced to support todays faster microprocessors (i.e., 8 MHz 80286, 10 MHz 80186) without incurring wait states. A powerdown mode has been added for low power or portable applications. With one command, the 82072 resets itself and then disconnects the power from the internal oscillator. Reset will reconnect the clock and once the 82072 is reprogrammed (if necessary), it will be ready to read and write disks again.

All of the control logic of the disk interface has been integrated into the 82072. Flexibility is maintained by allowing the user to select read and write data rates (without any external hardware); write precompensation delays; motor on/off delay; and the track to start the precompensation on. The typical design will need the 82072, a crystal and high current drivers for the signals that interface to the disk drive. The new features (when used) need only to be chosen once after reset (although they may be modified at any time). From then on, the user programs the 82072 for disk accesses in the same manner as the 8272A.

#### ARCHITECTURE

Figure 3 is a block diagram of the 82072. The highlighted blocks represent areas that are either completely new or highly enhanced. All new features were adopted with the requirement of being software compatible with the 8272A.



Figure 3. 82072 Block Diagram

1

1

# intel®

# 28F020 2048K (256K x 8) CMOS FLASH MEMORY

- Flash Electrical Chip-Erase
   2 Second Typical Chip-Erase
- Quick-Pulse Programming<sup>™</sup> Algorithm
   10 μs Typical Byte-Program
   4 Second Chip-Program
- 10,000 Erase/Program Cycles Minimum
- 12.0V ±5% VPP
- High-Performance Read
   150 ns Maximum Access Time
- CMOS Low Power Consumption — 10 mA Typical Active Current — 50 µA Typical Standby Current — 0 Watts Data Retention Power
- Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface

- Noise Immunity Features — ± 10% V<sub>CC</sub> Tolerance
  - Maximum Latch-Up Immunity through EPI Processing
- ETOX™ II Nonvolatile Flash Technology
  - EPROM-Compatible Process Base
  - High-Volume Manufacturing Experience
- JEDEC-Standard Pinouts — 32-Pin Plastic Dip
  - 32-Lead PLCC
  - 32-Lead TSOP
- Integrated Program/Erase Stop Timer (See Packaging Spec., Order #231369)

Intel's 28F020 CMOS flash memory offers the most cost-effective and reliable alternative for read/write random access nonvolatile memory. The 28F020 adds electrical chip-erasure and reprogramming to familiar EPROM technology. Memory contents can be rewritten: in a test socket; in a PROM-programmer socket; on-board during subassembly test; in-system during final test; and in-system after-sale. The 28F020 increases memory flexibility, while contributing to time- and cost-savings.

The 28F020 is a 2048-kilobit nonvolatile memory organized as 262,144 bytes of 8 bits. Intel's 28F020 is offered in 32-pin plastic DIP, 32-lead PLCC, and 32-lead TSOP packages. Pin assignments conform to JEDEC standards for byte-wide EPROMs.

Extended erase and program cycling capability is designed into Intel's ETOX<sup>TM</sup> II (EPROM Tunnel Oxide) process technology. Advanced oxide processing, an optimized tunneling structure, and lower electric field combine to extend reliable cycling beyond that of traditional EEPROMs. With the 12.0V V<sub>PP</sub> supply, the 28F020 performs a minimum of 10,000 erase and program cycles well within the time limits of the Quick-Pulse Programming<sup>TM</sup> and Quick-Erase<sup>TM</sup> algorithms.

Intel's 28F020 employs advanced CMOS circuitry for systems requiring high-performance access speeds, low power consumption, and immunity to noise. Its 150 nanosecond access time provides no-WAIT-state performance for a wide range of microprocessors and microcontrollers. Maximum standby current of 100  $\mu$ A translates into power savings when the device is deselected. Finally, the highest degree of latch-up protection is achieved through Intel's unique EPI processing. Prevention of latch-up is provided for stresses up to 100 mA on address and data pins, from -1V to  $V_{CC} + 1V$ .

With Intel's ETOX II process base, the 28F020 levers years of EPROM experience to yield the highest levels of quality, reliability, and cost-effectiveness.

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied. Information contained herein supersedes previously published specifications on these devices from Intel. November 1990 © INTEL CORPORATION, 1990 Order Number: 290245-003



:



### Figure 1. 28F020 Block Diagram

#### Table 1. Pin Description

| Symbol                           | Туре         | Name and Function                                                                                                                                                                                                                                                                            |
|----------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>17</sub>  | INPUT        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle.                                                                                                                                                                                                  |
| DQ <sub>0</sub> -DQ <sub>7</sub> | INPUT/OUTPUT | <b>DATA INPUT/OUTPUT:</b> Inputs data during memory write cycles;<br>outputs data during memory read cycles. The data pins are active high<br>and float to tri-state OFF when the chip is deselected or the outputs<br>are disabled. Data is internally latched during a write cycle.        |
| CE                               | INPUT        | CHIP ENABLE: Activates the device's control logic, input buffers,<br>decoders and sense amplifiers. CE is active low; CE high deselects the<br>memory device and reduces power consumption to standby levels.                                                                                |
| ŌĒ                               | INPUT        | <b>OUTPUT ENABLE:</b> Gates the devices output through the data buffers during a read cycle. OE is active low.                                                                                                                                                                               |
| WE                               | INPUT        | <b>WRITE ENABLE:</b> Controls writes to the control register and the array.<br>Write enable is active low. Addresses are latched on the falling edge<br>and data is latched on the rising edge of the WE pulse.<br><b>Note:</b> With $V_{PP} \leq 6.5V$ , memory contents cannot be altered. |
| V <sub>PP</sub>                  |              | ERASE/PROGRAM POWER SUPPLY for writing the command register, erasing the entire array, or programming bytes in the array.                                                                                                                                                                    |
| V <sub>CC</sub>                  |              | DEVICE POWER SUPPLY (5V ± 10%)                                                                                                                                                                                                                                                               |
| V <sub>SS</sub>                  |              | GROUND                                                                                                                                                                                                                                                                                       |







Figure 3. 28F020 in a 80C186 System

#### PRINCIPLES OF OPERATION

Flash-memory augments EPROM functionality with in-circuit electrical erasure and reprogramming. The 28F020 introduces a command register to manage this new functionality. The command register allows for: 100% TTL-level control inputs; fixed power supplies during erasure and programming; and maximum EPROM compatibility.

In the absence of high voltage on the V<sub>PP</sub> pin, the 28F020 is a read-only memory. Manipulation of the external memory-control pins yields the standard EPROM read, standby, output disable, and int<sub>e</sub>ligent Identifier<sup>TM</sup> operations.

The same EPROM read, standby, and output disable operations are available when high voltage is applied to the  $V_{PP}$  pin. In addition, high voltage on  $V_{PP}$  enables erasure and programming of the device. All functions associated with altering memory contents—int<sub>e</sub>ligent Identifier, erase, erase verify, program, and program verify—are accessed via the command register.

Commands are written to the register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for programming or erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the inteligent Identifier codes, or ou data for erase and program verification.

#### **Integrated Stop Timer**

Successive command write cycles define the durations of program and erase operations; specifically, the program or erase time durations are normally terminated by associated program or erase verify commands. An integrated stop timer provides simplified timing control over these operations; thus eliminating the need for maximum program/erase timing specifications. Programming and erase pulse durations are minimums only. When the stop timer terminates a program or erase operation, the device enters an inactive state and remains inactive until receiving the appropriate verify or reset command.

#### Write Protection

The command register is only active when V<sub>PP</sub> is at high voltage. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable—available only when memory updates are desired. When V<sub>PP</sub> = V<sub>PPL</sub>, the contents of the register default to the read comm and, making the 28F020 a read-only memory. I is mode, the memory contents cannot be altered.

| Pins       |                                              |                     | A              | Ag                             | ĈĒ              | ŌĒ              | WE  | DQ <sub>0</sub> -DQ <sub>7</sub> |  |
|------------|----------------------------------------------|---------------------|----------------|--------------------------------|-----------------|-----------------|-----|----------------------------------|--|
| Operation  |                                              | V <sub>PP</sub> (1) |                |                                |                 | 01              |     |                                  |  |
|            | Read                                         | V <sub>PPL</sub>    | A <sub>0</sub> | A <sub>9</sub>                 | VIL             | V <sub>IL</sub> | VIH | Data Out                         |  |
|            | Output Disable                               | V <sub>PPL</sub>    | х              | X                              | VIL             | VIH             | VIH | Tri-State                        |  |
| READ-ONLY  | Standby                                      | V <sub>PPL</sub>    | х              | X                              | VIH             | X               | X   | Tri-State                        |  |
|            | int <sub>e</sub> ligent Identifier™ (Mfr)(2) | V <sub>PPL</sub>    | VIL            | V <sub>ID</sub> (3)            | V <sub>IL</sub> | VIL             | VIH | Data = 89H                       |  |
|            | inteligent Identifier™ (Device)(2)           | VPPL                | VIH            | V <sub>ID</sub> <sup>(3)</sup> | VIL             | VIL             | VIH | Data = BDH                       |  |
|            | Read                                         | V <sub>PPH</sub>    | A <sub>0</sub> | Ag                             | VIL             | VIL             | VIH | Data Out <sup>(4)</sup>          |  |
| READ/WRITE | Output Disable                               | V <sub>PPH</sub>    | X              | X                              | VIL             | VIH             | VIH | Tri-State                        |  |
|            | Standby <sup>(5)</sup>                       | V <sub>PPH</sub>    | X              | X                              | VIH             | X               | Х   | Tri-State                        |  |
|            | Write                                        | V <sub>PPH</sub>    | Ao             | A <sub>9</sub>                 | VIL             | VIH             | VIL | Data In <sup>(6)</sup>           |  |

#### Table 2. 28F020 Bus Operations

#### NOTES:

1. Refer to 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 3. All other addresses low.

3. VID is the inteligent Identifier high voltage. Refer to DC Characteristics.

4. Read operations with V<sub>PP</sub> = V<sub>PPH</sub> may access array data or the int<sub>e</sub>ligent Identifier™ codes.

5. With Vpp at high voltage, the standby current equals I<sub>CC</sub> + Ipp (standby).

6. Refer to Table 3 for valid Data-In during a write operation.

7. X can be VIL or VIH.

Or, the system designer may choose to "hardwire"  $V_{PP}$ , making the high voltage supply constantly available. In this case, all Command Register functions are inhibited whenever  $V_{CC}$  is below the write lockout voltage  $V_{LKO}$ . (See Power Up/Down Protection.) The 28F020 is designed to accommodate either design practice, and to encourage optimization of the processor-memory interface.

#### **BUS OPERATIONS**

#### Read

The 28F020 has two control functions, both of which must be logically active, to obtain data at the outputs. Chip-Enable ( $\overline{CE}$ ) is the power control and should be used for device selection. Output-Enable ( $\overline{OE}$ ) is the output control and should be used to gate data from the output pins, independent of device selection. Refer to AC read timing waveforms.

When Vpp is high (VpPH), the read operation can be used to access array data, to output the int<sub>e</sub>ligent Identifier<sup>TM</sup> codes, and to access data for program/ erase verification. When Vpp is low (VppL), the read operation can **only** access the array data.

#### **Output Disable**

With Output-Enable at a logic-high level (V<sub>IH</sub>), output from the device is disabled. Output pins are placed in a high-impedance state.

#### Standby

With Chip-Enable at a logic-high level, the standby operation disables most of the 28F020's circuitry and substantially reduces device power consumption. The outputs are placed in a high-impedance state, independent of the Output-Enable signal. If the 28F020 is deselected during erasure, programming, or program/erase verification, the device draws active current until the operation is terminated.

#### int<sub>e</sub>ligent Identifier™ Operation

The inteligent Identifier operation outputs the manufacturer code (89H) and device code (BDH). Programming equipment automatically matches the device with its proper erase and programming algorithms.

# intel

١

With Chip-Enable and Output-Enable at a logic low level, raising A9 to high voltage  $V_{ID}$  (see DC Characteristics) activates the operation. Data read from locations 0000H and 0001H represent the manufacturer's code and the device code, respectively.

The manufacturer- and device-codes can also be read via the command register, for instances where the 28F020 is erased and reprogrammed in the target system. Following a write of 90H to the command register, a read from address location 0000H outputs the manufacturer code (89H). A read from address 0001H outputs the device code (BDH).

#### Write

Device erasure and programming are accomplished via the command register, when high voltage is applied to the  $V_{PP}$  pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device.

The command register itself does not occupy an addressable memory location. The register is a latch used to store the command, along with address and data information needed to execute the command.

The command register is written by bringing Write-Enable to a logic-low level ( $V_{IL}$ ), while Chip-Enable is low. Addresses are latched on the falling edge of Write-Enable, while data is latched on the rising edge of the Write-Enable pulse. Standard microprocessor write timings are used.

Refer to AC Write Characteristics and the Erase/ Programming Waveforms for specific timing parameters.

#### **COMMAND DEFINITIONS**

When low voltage is applied to the V<sub>PP</sub> pin, the contents of the command register default to 00H, enabling read-only operations.

Placing high voltage on the  $V_{PP}$  pin enables read/ write operations. Device operations are selected by writing specific data patterns into the command register. Table 3 defines these 28F020 register commands.

| Command                                                       | Bus<br>Cycles | First        | t Bus Cycle            |                     | Second Bus Cycle |                        |                     |  |
|---------------------------------------------------------------|---------------|--------------|------------------------|---------------------|------------------|------------------------|---------------------|--|
|                                                               | Req'd         | Operation(1) | Address <sup>(2)</sup> | Data <sup>(3)</sup> | Operation(1)     | Address <sup>(2)</sup> | Data <sup>(3)</sup> |  |
| Read Memory                                                   | 1             | Write        | X                      | 00Н                 |                  |                        |                     |  |
| Read int <sub>e</sub> ligent Identifier™ Codes <sup>(4)</sup> | 3             | Write        | X                      | 90H                 | Read             | (4)                    | (4)                 |  |
| Set-up Erase/Erase <sup>(5)</sup>                             | 2             | Write        | X                      | 20H                 | Write            | x                      | 20H                 |  |
| Erase Verify <sup>(5)</sup>                                   | 2             | Write        | EA                     | AOH                 | Read             | x                      | EVD                 |  |
| Set-up Program/Program <sup>(6)</sup>                         | 2             | Write        | X                      | 40H                 | Write            | PA                     | PD                  |  |
| Program Verify <sup>(6)</sup>                                 | 2             | Write        | x                      | Сон                 | Read             | x                      | PVD                 |  |
| Reset <sup>(7)</sup>                                          | 2             | Write        | x                      | FFH                 | Write            | X                      | FFH                 |  |

#### Table 3. Command Definitions

#### NOTES:

. .

1. Bus operations are defined in Table 2.

2. IA = Identifier address: 00H for manufacturer code, 01H for device code.

EA = Address of memory location to be read during erase verify.

PA = Address of memory location to be programmed.

Addresses are latched on the falling edge of the Write-Enable pulse.

3. ID = Data read from location IA during device identification (Mfr = 89H, Device = BDH).

EVD = Data read from location EA during erase verify.

PD = Data to be programmed at location PA. Data is latched on the rising edge of Write-Enable.

PVD = Data read from location PA during program verify. PA is latched on the Program command.

4. Following the Read inteligent ID command, two read operations access manufacturer and device codes.

5. Figure 6 illustrates the Quick-Erase™ Algorithm.

6. Figure 5 illustrates the Quick-Pulse Programming™ Algorithm.

7. The second bus cycle must be followed by the desired command register write.

S4-VME Revision 1.0

#### **Buffer Control**

| VMEP1_BR(3:0)_I - SCHMITTNVMEbus RequestVME_BR_O - BT1VMEbus RequestP1_BGIN(3:0)I - SCHMITTNVMEbus Bus GrantVME_BGOUT(3:0)O - BT1VMEbus Bus GrantVME_BBSY_O - BT1VMEbus Bus BusyB_BBSY_I - SCHMITTNVMEbus Bus BusyP1_AS_I - SCHMITTNVMEbus Address StrobeVME_AS_O - BT1VMEbus Address StrobeVME_DS(1:0)_I - SCHMITTNVMEbus Data StrobeP1_UW_O - BT1VMEbus Data StrobeP1_WR_I - SCHMITTNVMEbus Data StrobeP1_WW_O - BT1VMEbus Long WordVME_LW_O - BT1VMEbus Long WordVME_LW_O - BT1VMEbus Long WordVME_LACK_I - SCHMITTNVMEbus Interrupt AcknowledgeP1_IRQ(7:1)_I - SCHMITTNVMEbus Interrupt AcknowledgeVME_IACK_O - BT1VMEbus Interrupt AcknowledgeVME_IACK_I - SCHMITTNVMEbus Interrupt AcknowledgeVME_IACK_O - BT1VMEbus Interrupt AcknowledgeVME_DTACK_I - SCHMITTNVMEbus Bus ErrorVME_BERR_I - SCHMITTNVMEbus Bus ErrorP1_AM53(5:3)I - SCHMITTVMEbus Bus ErrorP1_AM53(5:3)I - SCHMITTVMEbus Address Modifier 5-3P1_AM10(1:0)I - SCHMITTVMEbus Address Modifier 5-4P1_SYSR_I - SCHMITTNVMEbus Address Modifier 5-4VME_SYSRO - BT1VMEbus System Reset | ma_aclk<br>ma_aen_<br>sl_aclk<br>sl_aen_<br>sbtP1clk<br>sbtP1enX_<br>sbtP1enM_<br>P1tsbclk<br>P1tsbenX_<br>P1tsbenL_<br>P1tsbenM_<br>pl_sel(1:0)<br>b_asen_                                                                                                                                                                                           | O - BT1<br>O - BT2<br>O - BT1<br>O - BT4<br>O - BT4<br>O - BT2<br>O - BT3<br>O - BT8<br>O - BT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Master Address Clock<br>Master Address Clock<br>Master Address Clock<br>Master Address Clock<br>S-bus to P1 latch<br>S-bus to P1 Data enable.<br>S-bus to P1 Data enable.<br>S-bus to P1 Data enable.<br>P1 to S-bus latch.<br>P1 to S-bus Data Enable.<br>P1 to S-bus Data Enable.<br>P1 to S-bus Data Enable.<br>P1 to S-bus Data Enable.<br>P1 to S-bus Data Enable.<br>Pipeline Buffer Select.<br>Address Strobe enable.                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VME_BR_O - BT1VMEbus RequestP1_BGIN(3:0)I - SCHMITTNVMEbus Bus GrantVME_BGOUT(3:0)O - BT1VMEbus Bus GrantVME_BBSY_O -BT1VMEbus Bus BusyB_BBY_I - SCHMITTNVMEbus Bus BusyP1_AS_I - SCHMITTNVMEbus Address StrobeVME_AS_O - BT1VMEbus Address StrobeVME_DS(1:0)_I - SCHMITTNVMEbus Data StrobeVME_DS(1:0)_I - SCHMITTNVMEbus Data StrobeVME_DS(1:0)_O - BT1VMEbus Data StrobeP1_WR_I - SCHMITTNVMEbus Long WordVME_LW_O - BT1VMEbus Long WordVME_LW_O - BT1VMEbus Interrupt AcknowledgeVME_IACK_I - SCHMITTNVMEbus Interrupt AcknowledgeVME_IACK_O - BT1VMEbus Interrupt AcknowledgeVME_IACK_I - SCHMITTNVMEbus Interrupt AcknowledgeVME_IACKOUTO - BT1VMEbus Interrupt AcknowledgeVME_DTACK_I - SCHMITTNVMEbus Data AcknowledgeVME_DTACK_I - SCHMITTNVMEbus Bus ErrorP1_BERR_I - SCHMITTNVMEbus Bus ErrorVME_BERR_O - BT1VMEbus Address Modifier 5-3P1_AM10(1:0)I - SCHMITTVMEbus Address Modifier 5-4P1_SYSR_I - SCHMITTNVMEbus System Reset                                                                                                            | VME                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P1_AMEG(23:20) I - SCHMITT VMEbus Address bit 23-20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | VME_BR_<br>P1_BGIN(3:0)<br>VME_BGOUT(3:0)<br>VME_BBSY_<br>B_BBSY_<br>P1_AS_<br>VME_AS_<br>P1_DS(1:0)_<br>VME_DS(1:0)_<br>P1_WR_<br>P1_LW_<br>VME_LW_<br>P1_LW_<br>VME_LW_<br>P1_IRQ(7:1)_<br>P1_IACK_<br>VME_IACK_<br>P1_IACKIN_<br>VME_IACKOUT<br>P1_DTACK_<br>VME_DTACK_<br>P1_BERR_<br>P1_AM53(5:3)<br>P1_AM10(1:0)<br>VME_SYSR_<br>P1_AMEG(23:20) | $\begin{array}{l} O - BT1 \\ I - SCHMITTN \\ O - BT1 \\ O - BT1 \\ I - SCHMITTN \\ I - SCHMITTN \\ I - SCHMITTN \\ O - BT1 \\ I - SCHMITT \\ O - BT1 \\ I - SCHMITT \\ O - BT1 \\ I - SCHMITT \\ O - BT1 \\ I - SCHMITTN \\ O - BT1 \\ I - SCHMIT \\ I - I \\ I - I \\ I $ | VMEbus Request<br>VMEbus Bus Grant<br>VMEbus Bus Grant<br>VMEbus Bus Busy<br>VMEbus Bus Busy<br>VMEbus Address Strobe<br>VMEbus Address Strobe<br>VMEbus Data Strobe<br>VMEbus Data Strobe<br>VMEbus Data Strobe<br>VMEbus Ung Word<br>VMEbus Long Word<br>VMEbus Long Word<br>VMEbus Long Word<br>VMEbus Interrupt Acknowledge<br>VMEbus Data Acknowledge<br>VMEbus Data Acknowledge<br>VMEbus Bus Error<br>VMEbus Bus Error<br>VMEbus Address Modifier 5–3<br>VMEbus Address Modifier 5–4<br>VMEbus System Reset<br>VMEbus System Reset |

S4-VME 9/21/89

Sun Microsystems S4 Chip Set

S4-VME Revision 1.0

| VME_SYSCLK                               | O – BT1                               | VMEBUS Clock                                  |
|------------------------------------------|---------------------------------------|-----------------------------------------------|
| Test                                     |                                       |                                               |
| od_<br>para                              | I – TLCHT<br>O – B1                   | Output disable<br>Parametric nand tree output |
| Signals<br>Device Type:<br>Package Type: | 136<br>LIA5530<br>PFP144 (IO:136 VDD: | 4 VSS:8)                                      |

# **Functional Description**

The S4-VME interfaces the Sbus to the VMEbus. When acting as a Sbus slave, i.e. VMEbus Master, VME is a physical device in type 2 or 3 space. During Sbus DMA Master cycles, i.e. VME Slave cycles, it will appear as an Sbus slot device. Refer to the Sbus specification for further explanation.

This chip contains the most of the functions required to implement a full VME Interface. In addition, buffers to drive VME and to interface Sbus to VME, plus some address decoding are needed. The following figure shows how the VME interface will hook up to the rest of the CPU.



## Registers

The registers can be divided into the following groups:

- 1) Registers set on system initialization, replacing board jumpers: Interrupt Enable Register: Interrupts handled Arbitration mode
- 2) Registers used for multi- or co-processing: Mail Box Interrupt Register Bus Locker Register Slave Map Register (also replacing jumper)
- 3) Others

| A32 VME Address mapping.  | Move 512 MByte window        |
|---------------------------|------------------------------|
|                           | enable diagnostic loop back. |
| Slave Map register bit 0: | enable Block Mode transfers  |

Following is a list of the VME Interface Registers:

| Туре | Name                          | Physical Base | Size              |
|------|-------------------------------|---------------|-------------------|
| 1    | VME Bus Locker                | 0xEFE00000    | byte              |
| 1    | VME IACK cycle                | 0xEFE00001    | byte, A[3:1],A0=1 |
| 1    | Mail Box register             | 0xEFE00010    | byte              |
| 1    | VME Interrupt Enable Register | 0xEFE00014    | byte              |
| 1    | A32MAP Register               | 0xEFE00018    | byte              |
| 1    | Slave Map Register            | 0xEFE0001C    | byte              |

intel

~



Figure 5. 28F020'Quick-Pulse,Programming™ Algorithm

11

. . . .

#### 28F020

#### PRELIMINARY

1



Figure 6. 28F020 Quick-Erase™ Algorithm

12

# Z85C30

# Enhanced Serial Communications Controller

Advanced Micro Devices

## DISTINCTIVE CHARACTERISTICS

- Fastest data rate of any Z8530
  - --- 8.192 MHz / 2.048 Mb/s
  - 10 MHz / 2.5 Mb/s
  - 12.5 MHz / 3 Mb/s
  - 16.384 MHz / 4.096 Mb/s
  - 20 MHz / 5 Mb/s (prelim)
- Low-power CMOS technology
- Pin and function compatible with other NMOS and CMOS Z8530s
- Easily Interfaced with most CPUs Compatible with non-multiplexed bus
- Many enhancements over NMOS Z8530H
   Allows 85C30 to be used more effectively in
  - high-speed applications
  - Improves interface capabilities

- Two independent full-duplex serial channels
- Asynchronous mode features
  - Programmable stop bits, clock factor, character length and parity
  - Break detection/generation
  - Error detection for framing, overrun, and parity
- Synchronous mode features
  - -- Supports IBM BISYNC, SDLC, SDLC Loop, HDLC, and ADCCP Protocols
  - --- Programmable CRC generators and checkers
  - SDLC/HDLC support includes frame control, zero insertion and deletion, abort, and residue handling



# DISTINCTIVE CHARACTERISTICS (continued)

- Enhanced SCC functions support high-speed frame reception using DMA
  - 14-bit byte counter
  - 10 × 19 SDLC/HDLC Frame Status FIFO
  - Independent Control on both channels
  - Enhanced operation does not allow special receive conditions to lock the 3-byte DATA FIFO when the 10 × 19 FIFO is enabled
- Local Loopback and Auto Echo modes
- Internal or external character synchronization

## **GENERAL DESCRIPTION**

AMD's Z85C30 is an enhanced pin-compatible version of the popular Z8530/Z85C30 Serial Communications Controller. The Enhanced Serial Communications Controller (ESCC) is a high-speed, low-power, multi-protocol communications peripheral designed for use with 8- and 16-bit microprocessors. It has two independent, full-duplex channels and functions as a serial-to-parallel, parallel-to-serial converter/controller. AMD's proprietary enhancements make the Z85C30 easier to interface and more effective in high-speed applications due to a reduction in software burden and the elimination of the need for some external glue logic.

The Z85C30 is easy to use due to a variety of sophisticated internal functions, including on-chip baud rate generators, digital phase-locked loops, and crystal oscillators, which dramatically reduce the need for external logic. The device can generate and check CRC codes in any SYNC mode, and can be programmed to check data integrity in various modes. The ESCC also has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O.

This versatile device supports virtually any serial data transfer application such as networks, modems, cassettes, and tape drivers. The ESCC is designed for non-multiplexed buses and is easily interfaced with most CPUs, such as 80188, 80186, 80286, 8080, Z80, 6800, 68000 and MULTIBUS.

Enhancements that allow the Z85C30 to be used more effectively in high-speed applications include:

- a 10 × 19 bit SDLC/HDLC frame status FIFO array
- a 14-bit SDLC/HDLC frame byte counter

- 2-Mb/s FM encoding transmit and receive capability using internal DPLL for 16.384-MHz product
- Internal synchronization between RxC to PCLK and TxC to PCLK
  - This allows the user to eliminate external synchronization hardware required by the NMOS device when transmitting or receiving data at the maximum rate of 1/4 PCLK frequency.
- automatic SDLC/HDLC opening frame flag transmission
- TxD pin forced High in SDLC NRZI mode after closing flag
- automatic SDLC/HDLC Tx underrun/EOM flag reset
- automatic SDLC/HDLC Tx CRC generator reset/ preset
- RTS synchronization to closing SDLC/HDLC flag
- DTR/REQ deactivation delay significantly reduced
- external PCLK to RxC or TxC synchronization requirement eliminated for PCLK. divide-by-four operation

Other enhancements to improve the Z85C30 interface capabilities include:

- write data valid setup time to falling edge of WR requirement eliminated
- reduced INT response time
- reduced access recovery time (trc) to 3 PCLK best case (3 1/2 PCLK worst case)
- improved Wait timing
- Write Registers WR3, WR4, WR5, and WR10 made readable
- Iower priority interrupt masking without INTACK
- complete SDLC/HDLC CRC character reception

| Part No.     | Description              | Part No.    | Description             |
|--------------|--------------------------|-------------|-------------------------|
| Am7960       | Coded Data Transceiver   | Am9517A     | DMA Controller          |
| 80186        | Highly Integrated 16-Bit | 5380, 53C80 | SCSI Bus Controller     |
|              | Microprocessor           | 80188       | Highly Integrated 8-Bit |
| 80286,80C286 | High-Performance 16-Bit  |             | Microprocessor          |
| ·            | Microprocessor           |             | ·                       |

#### **RELATED AMD PRODUCTS**



#### LOGIC SYMBOL



# PIN DESCRIPTION

# Bus Timing and Reset

#### Read (Input; Active Low)

This signal indicates a Read operation and, when the SCC is selected, enables the SCC's bus drivers. During the Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the bus if the SCC is the highest priority device requesting an interrupt.

## WR

#### Write (Input; Active Low)

When the SCC is selected, this signal indicates a Write operation. The coincidence of RD and WR is interpreted as a reset.

### Channel Clocks

#### RTXCA, RTXCB

#### Receive/Transmit Clocks (Inputs; Active Low)

These pins can be programmed in several different modes of operation. In each channel, RTxC may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock of the digital phaselocked loop. These pins can also be programmed for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchronous modes.

#### TRXCA, TRXCB

#### Transmit/Receive Clocks

(Inputs/Outputs; Active Low)

These pins can be programmed in several different modes of operation. TRxC may supply the receive clock or the transmit clock in the input mode or supply the output of the digital phase-locked loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode.

# Channel Controls for Modem, DMA, or Other

#### CTSA, CTSB

#### Clear to Send (Inputs; Active Low)

If these pins are programmed as Auto Enables, a Low on these inputs enables their respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The SCC detects pulses on these inputs and may interrupt the CPU on both logic level transitions.

#### DCDA, DCDB

#### Data Carrier Detect (Inputs; Active Low)

These pins function as receiver enables if they are programmed as Auto Enables; otherwise, they may be used as general-purpose input pins. Both are Schmitt-trigger buffered to accommodate slow rise-time signals. The SCC detects pulses on these pins and may interrupt the CPU on both logic level transitions.

## DTR/REQA

#### Data Terminal Ready/Request (Outputs; Active Low)

These outputs follow the inverted state programmed into the DTR bit in WR5. They can also be used as general-purpose outputs or as Request Lines for a DMA controller.

### RTSA, RTSB

#### Request to Send (Outputs; Active Low)

When the <u>Request to Send (RTS) bit in Write Register 5</u> is set, the <u>RTS</u> signal goes Low. When the RTS bit is reset in the asynchronous mode and Auto Enable is on, the signal goes High after the transmitter is empty. In SYNC mode, or in asynchronous mode with Auto Enable off, the <u>RTS</u> pins strictly follow the inverted state of the <u>RTS</u> bit. Both pins can be used as general-purpose outputs.

In SDLC mode, the AUTO RTS RESET enhancement described later in this document brings RTS High after the last 0 of the closing flag leaves the TxD pin.

#### SYNCA, SYNCB

#### Synchronization (Inputs/Outputs; Active Low)

These pins can act either as inputs, outputs, or part of the crystal oscillator circuit. In the Asynchronous Receive mode (crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In this mode, transitions on these lines affect the state of the Sync/Hunt status bits in Read Register 0 but have no other function.

In External Synchronization mode with the crystal oscillator not selected, these lines also act as inputs. In this mode, SYNC must be driven Low two receive clock cycles after the last bit in the SYNC character is received. Character assembly begins on the rising edge of the receive clock immediately preceding the activation of SYNC.

In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator not selected, these pins act as outputs and are active only during the part of the receive clock cycle in which SYNC characters are recognized. The SYNC condition is not latched, so these outputs are active each time a SYNC pattern is recognized (regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid on receipt of a flag.

#### W/REQA, W/REQB

Wait/Request (Outputs; Open drain when programmed for a Wait function, driven High or Low when programmed for a Request function)

These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the SCC data rate. The reset state is Wait.

# Control

### A/B

#### Channel A/Channel B Select (Input)

This signal selects the channel in which the Read or Write operation occurs.

### CE

#### Chip Enable (Input; Active Low)

This signal selects the SCC for a Read or Write operation.

### D/C

#### Data/Control Select (Input)

This signal defines the type of information transferred to or from the SCC. A High means data is transferred; a Low indicates a command is transferred.

#### Data Bus

#### D<sub>e</sub>-D<sub>7</sub>

#### Data Bus (Input/Output; Three State)

These lines carry data and commands to and from the SCC.

#### Interrupt

#### IEI

#### Interrupt Enable In (Input; Active High)

IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt.

#### IEO

#### Interrupt Enable Out (Output; Active High)

IEO is High only if IEI is High and the CPU is not servicing an SCC interrupt or the SCC is not requesting an interrupt (interrupt acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices.

# INT

# Interrupt Request (Output; Active Low, Open Drain)

This signal is activated when the SCC requests an interrupt.

#### INTACK

#### Interrupt Acknowledge (Input; Active Low)

This signal indicates an active interrupt acknowledge cycle. During this cycle, the SCC interrupt daisy chain settles. When RD becomes active, the SCC places an interrupt vector on the data bus (if IEI is High). INTACK is latched by the rising edge of PCLK.

### **Serial Data**

#### RxDa, RxDB

Receive Data (Inputs; Active High)

These input signals receive serial data at standard TTL levels.

#### TxDA, TxDB

#### Transmit Data (Outputs; Active High)

These output signals transmit serial data at standard TTL levels.

#### Miscellaneous

GND Ground

PCLK

Clock (Input)

This is the master SCC clock used to synchronize internal signals. PCLK is not required to have any phase relationship with the master system clock. PCLK is a TTLlevel signal. Maximum transmit rate is 1/4 PCLK.

## $V_{cc}$

#### + 5 V Power Supply

## ARCHITECTURE

The ESCC internal structure includes two full-duplex channels, two 10  $\times$  19 bit SDLC/HDLC frame status FIFOs, two baud rate generators, internal control and interrupt logic, and a bus interface to a non-multiplexed bus. Associated with each channel are a number of Read and Write registers for mode control and status information, as well as logic necessary to interface with modems or other external devices (see Logic Symbol).

The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are general-purpose in nature and can optionally be used for functions other than modem control.

The register set for each channel includes ten control (Write) registers, two SYNC character (Write) registers, and four status (Read) registers. In addition, each baud rate generator has two (Read/Write) registers for holding the time constant that determines the baud rate. Finally, associated with the interrupt logic is a Write register for the interrupt vector accessible through either channel, a Write-only Master Interrupt Control register, and three Read registers: one containing the vector with status information (Channel B only), one containing the vector without status (A only), and one containing the interrupt pending bits (A only).

The registers for each channel are designated as follows:

WR0-WR15-Write Registers 0 through 15. An additional Write register, WR7 Prime (WR7), is available for enabling or disabling additional SDLC/HDLC enhancements if bit  $D_0$  of WR15 is set.

RR0-RR3, RR10, RR12, RR13, RR15-Read Registers 0 through 3, 10, 12, 13, and 15.

If bit D<sub>2</sub> of WR15 is set, then two additional Read registers, RR6 and RR7, are available. These registers are used with the  $10 \times 19$  bit Frame Status FIFO.

Table 1 lists the functions assigned to each Read and Write register. The ESCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel).





#### - Data Path

The transmit and receive data path illustrated in Figure 2 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high-speed data. Incoming data are routed through one of several paths (data or CRC) depending on the selected mode (the character length in asynchronous modes also determines the data path). The transmitter has an 8-bit transmit data buffer register loaded from the internal data bus and a 20-bit transmit shift register that can be loaded either from the synccharacter registers or from the transmit data register. Depending on the operational mode, outgoing data are routed through one of four main paths before they are transmitted from the Transmit Data output (TxD).

#### Table 1. Read and Write Register Functions

| Read | Register Functions                                                                   | Write I     | Register Functions                                                                        |
|------|--------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------|
| RRO  | Transmit/Receive buffer status and External status                                   | WRO         | Command Register, Register Pointers CRC                                                   |
| RR1  | Special Receive Condition status<br>(also 10 × 19 bit FIFO Frame Reception Status if |             | initialize, initialization commands for the various modes, shift right/shift left command |
| RR2  | WR15 bit D <sub>2</sub> is set)<br>Modified interrupt vector                         | WR1         | Interrupt conditions and data transfer mode definition                                    |
|      | (Channel B only)                                                                     | WR2         | Interrupt vector (accessed through either channel)                                        |
|      | Unmodified interrupt vector                                                          | WR3         | Receive parameters and control                                                            |
|      | (Channel A only)                                                                     | WR4         | Transmit/Receive miscellaneous parameters and                                             |
| RR3  | Interrupt Pending bits                                                               |             | modes                                                                                     |
|      | (Channel A only)                                                                     | WR5         | Transmit parameters and controls                                                          |
| RR6  | LSB Byte Count (14-bit counter)                                                      | WR6         | Sync character or SDLC address field                                                      |
|      | (if WR15 bit D <sub>2</sub> set)                                                     | WR7         | Sync character or SDLC flag                                                               |
| RR7  | MSB Byte Count (14-bit counter)                                                      | WR7′        | SDLC/HDLC enhancements (if bit D <sub>o</sub> of WR15 is set                              |
|      | and 10 x 19 bit FIFO Status (if WR15 bit D, is set)                                  | WR8         | Transmit buffer                                                                           |
| RR8  | Receive buffer                                                                       | WR9         | Master interrupt control and reset (accessed                                              |
| RR10 | Miscellaneous XMTR, RCVR status                                                      |             | through either channel)                                                                   |
| RR12 | Lower byte of baud rate generator time constant                                      | WR10        | Miscellaneous transmitter/receiver control bits, data                                     |
| RR13 | Upper byte of baud rate generator time constant                                      |             | encoding                                                                                  |
| RR15 | External/Status interrupt information                                                | WR11        | Clock mode control, Rx and Tx clock source                                                |
| -    | ·                                                                                    | WR12        | Lower byte of baud rate generator time constant                                           |
|      |                                                                                      | <b>WR13</b> | Upper byte of baud rate generator time constant                                           |
|      |                                                                                      |             | Misselleneous enstral bits DDLL enstral                                                   |

- WR14 Miscellaneous control bits, DPLL control
- WR15 External/Status interrupt control

د . در

Z85C30



Z85C30

2-295

# **Signetics**

Linear Products

#### DESCRIPTION

The NE5170 is an octal line driver which is designed for digital communications with data rates up to 100kb/s. This device meets all the requirements of EIA standards RS-232C/RS-423A and CCITT recommendations V.10/X.26. Three programmable features: (1) output slew rate, (2) output voltage level, and (3) 3-State control (high-impedance) are provided so that output characteristics may be modified to meet the requirements of specific applications.

#### **FEATURES**

S. -)-, 2 - (- 'S

• Meets EIA RS-232C/423A and CCITT V.10/X.26

NE5170

Octal Line Driver

Preliminary Specification

- Simple slew rate programming with a single external resistor
- 0.1 to 10V/µs slew rate range
- High/Low programmable voltage output modes
- TTL compatible inputs

#### **APPLICATIONS**

- High-speed modems
- High-speed parallel communications
- Computer I/O ports
- Logic level translation





|        | ENABLE     LOGIC<br>INPUT     RS-423A <sup>1</sup> RS-2320       L     L     5 to 6V     5 to 6V | (V)       |                              |                               |
|--------|--------------------------------------------------------------------------------------------------|-----------|------------------------------|-------------------------------|
| ENABLE |                                                                                                  |           | RS-                          | 232C                          |
|        |                                                                                                  | RS-423A   | Low Output Mode <sup>1</sup> | High Output Mode <sup>2</sup> |
| L      | L                                                                                                | 5 to 6V   | 5 to 6V                      | >9∨                           |
| L      | н                                                                                                | -5 to -6V | -5 to -6V                    | <-9∨                          |
| н      | X                                                                                                | Hi-Z      | Hi-Z                         | Hi-Z                          |

NOTES:

Г

1.  $V_{CC}$  = +10V and  $V_{EE}$  = -10V;  $R_L$  = 3k $\Omega$ 2.  $V_{CC}$  = +12V and  $V_{EE}$  = -12V;  $R_L$  = 3k $\Omega$ 

#### ORDERING CODE

FUNCTION TABLE

Т

| DESCRIPTION        | TEMPERATURE RANGE | ORDER CODE |
|--------------------|-------------------|------------|
| 28-Pin Plastic DIP | 0 to +70°C        | NE5170N    |
| 28-Pin PLCC        | 0 to +70°C        | NE5170A    |
| 24-Pin SO package  | 0 to +70°C        | NE5170D    |

# Octal Line Driver

## NE5170

#### ABSOLUTE MAXIMUM RATINGS

| SYMBOL          | PARAMETER                          | RATING     | UNIT |
|-----------------|------------------------------------|------------|------|
| V <sub>CC</sub> | Supply voltage and + MODE          | 15         | v    |
| V <sub>EE</sub> | Supply voltage and - MODE          | - 15       | v    |
| lout            | Output current <sup>1</sup>        | ± 150      | mA   |
| V <sub>IN</sub> | Input voltage (ENABLE, Data)       | -1.5 to +7 | v    |
| VOUT            | Output voltage <sup>2</sup>        | ± 15       | v    |
|                 | Minimum slew resistor <sup>3</sup> | 1          | kΩ   |
| PD              | Power dissipation                  | 1200       | mW   |

#### DC ELECTRICAL CHARACTERISTICS $V_{CC}$ = 10V ± 10%; $V_{EE}$ = -10V ± 10%; ± MODES = 0V; $R_{SL}$ = 2k $\Omega$ , 0°C < T<sub>A</sub> < 70°C, unless otherwise specified.

| <b>0</b> ///00/ |                                           |                                                      | LIMITS              |                    |      |  |
|-----------------|-------------------------------------------|------------------------------------------------------|---------------------|--------------------|------|--|
| SYMBOL          | PARAMETER                                 | TEST CONDITIONS                                      | Min                 | Max                | UNIT |  |
|                 |                                           | $V_{IN} = 0.8V$<br>R <sub>L</sub> = 3k $\Omega^4$    | 5                   | 6                  |      |  |
| V <sub>OH</sub> | Output High voltage                       | R <sub>L</sub> = 450Ω <sup>4</sup>                   | 4.5                 | 6                  | v    |  |
| • • •           |                                           | $R_L = 3k\Omega^5$ , $C_L = 2500pF$                  | V <sub>CC</sub> - 3 |                    |      |  |
|                 |                                           | $V_{IN} = 2.0V$<br>$R_{L} = 3k\Omega^{4}$            | -6                  | -5                 |      |  |
| VOL             | Output Low voltage                        | R <sub>L</sub> = 450Ω <sup>4</sup>                   | -6                  | -4.5               | v    |  |
|                 |                                           | $R_{L} = 3k\Omega^{5}, C_{L} = 2500pF$               |                     | V <sub>EE</sub> +3 |      |  |
| Vou             | Output unbalance voltage                  | $V_{CC} =  V_{EE} , R_L = 450\Omega^4$               |                     | 0.4                | V    |  |
| ICEX            | Output leakage current                    | $ V_0  = 6V$ , ENABLE = 2V or $V_{CC} = V_{EE} = 0V$ | - 100               | 100                | μA   |  |
| V <sub>IH</sub> | Input High voltage                        |                                                      | 2.0                 |                    | v    |  |
| VIL             | Input Low voltage                         |                                                      |                     | 0.8                | v    |  |
| l <sub>IL</sub> | Logic "0" input current                   | V <sub>IN</sub> = 0.4V                               | -400                | 0                  | μA   |  |
| Чн              | Logic "1" input current                   | V <sub>IN</sub> = 2.4∨                               | 0                   | 40                 | μA   |  |
| los             | Output short circuit current <sup>1</sup> | V <sub>O</sub> = 0V                                  | - 150               | 150                | mA   |  |
| V <sub>CL</sub> | Input clamp voltage                       | l <sub>IN</sub> = – 15mA                             | -1.5                |                    | V    |  |
| lœ              | Supely event                              | No Load                                              |                     | 35                 | mA   |  |
| IEE             | Supply current                            | No Load                                              | -45                 |                    | mA   |  |

NOTES:

, ÷

1 Maximum current per driver. Do not exceed maximum power dissipation if more than one output is on.

2. High-impedance mode.

3. Minimum value of the resistor used to set the slew rate.

4.  $V_{OH}$ ,  $V_{OL}$  at  $R_L = 450\Omega$  will be  $\geq \geq 90\%$  of  $V_{OH}$ ,  $V_{OL}$  at  $R_L = \infty$ . 5. High Output Mode; + MODE pin =  $V_{CC}$ ; -MODE pin =  $V_{EE}$ ; 9V  $\leq V_{CC} \leq 13V$ ; -9V  $\geq V_{EE} \geq -13V$ .

# Octal Line Driver

# NE5170

|                  |                                                 |                                                                                                                             | LIMITS |      |        |  |
|------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------|------|--------|--|
| SYMBOL           | PARAMETER                                       | TEST CONDITIONS                                                                                                             | Min    | Max  | UNIT   |  |
| <sup>€</sup> PHZ | Propagation delay output high to high-impedance | R <sub>L</sub> = 450, C <sub>L</sub> = 50pF<br>or<br>R <sub>L</sub> = 3k, C <sub>L</sub> = 2500pF                           |        | 5    | μs     |  |
| <b>ί</b> ρι z    | Propagation delay output low to high-impedance  | R <sub>L</sub> = 450, C <sub>L</sub> = 50pF<br>or<br>R <sub>L</sub> = 3k, C <sub>L</sub> = 2500pF                           |        | 5    | μs     |  |
| <b>t</b> рzн     | Propagation delay high-impedance to high output | R <sub>SL</sub> = 200k<br>R <sub>L</sub> = 450, C <sub>L</sub> = 50pF<br>or<br>R <sub>L</sub> = 3k, C <sub>L</sub> = 2500pF |        | 150  | μs     |  |
| t <sub>PZL</sub> | Propagation delay high-impedance to low output  | R <sub>SL</sub> = 200k<br>R <sub>L</sub> = 450, C <sub>L</sub> = 50pF<br>or<br>R <sub>L</sub> = 3k, C <sub>L</sub> = 2500pF |        | 150  | μs     |  |
|                  |                                                 | R <sub>SL</sub> = 2k                                                                                                        | 8      | 12   | ]      |  |
| SR               | Output slew rate <sup>1</sup>                   | R <sub>SL</sub> = 20k                                                                                                       | 0.8    | 1.2  | ] V/µs |  |
|                  |                                                 | R <sub>SL</sub> = 200k                                                                                                      | 0.06   | 0.14 |        |  |

### AC ELECTRICAL CHARACTERISTICS $V_{CC}$ = + 10V; $V_{EE}$ = -10V; Mode = GND, 0°C $\leq$ T<sub>A</sub> $\leq$ 70°C

NOTE:

SR: Load condition. (A) For  $R_{SL} < 4k\Omega$  use  $R_L = 450\Omega$ ;  $C_L = 50pF$ ; (B) for  $R_{SL} > 4k\Omega$  use either  $R_L = 450\Omega$ ,  $C_L = 50pF$  or  $R_L = 3k\Omega$ ,  $C_L = 2500pF$ .

#### AC PARAMETER TEST CIRCUIT AND WAVEFORMS



# **Signetics**

Linear Products

#### DESCRIPTION

The NE5180 and NE5181 are octal line receivers designed to interface data terminal equipment with data communications equipment. These devices meet the requirements of EIA standards RS-232C, RS-423A, RS-422A, and CCITT V.10, V.11, V.28, X.26 and X.27. The NE5180 is intended for use where the data transmission rate is up to 200 kb/s. The NE5181 covers the entire range of data rates up to 10 Mb/s. The difference in data rates for the two devices results from the input filtering of the NE5180. These devices also provide a failsafe feature which protects against certain input fault conditions.

#### FUNCTION TABLE

# NE5180/NE5181 Octal Differential Line Receivers

**Preliminary Specification** 

#### FEATURES

- Meets EIA RS-232C/423A/422A and CCITT V.10, V.11, V.28
- Single +5V supply TTL compatible outputs
- Differential inputs withstand ± 25V
- Failsafe feature
- Input noise filter (NE5180 only)
- Internal hysteresis
- Available in SMD PLCC

#### **APPLICATIONS**

- High-speed modems
- High-speed parallel
   communications
- Computer I/O ports
- Logic level translation

### PIN CONFIGURATIONS





| INPUT                                 | FAILSAFE<br>INPUT | LOGIC<br>OUTPUT |
|---------------------------------------|-------------------|-----------------|
| V <sub>ID</sub> > 200mV <sup>1</sup>  | x                 | н               |
| V <sub>ID</sub> < -200mV <sup>1</sup> | x                 | L               |
| Dath insula and                       | ov                | L               |
| Both inputs open or grounded          | V <sub>CC</sub>   | н               |

NOTE:

1.  $V_{\text{ID}}$  is defined as the non-inverting terminal input voltage minus the inverting terminal input voltage.

#### ORDERING INFORMATION

| DESCRIPTION        | TEMPERATURE RANGE | ORDER CODE |
|--------------------|-------------------|------------|
| 28-Pin Plastic DIP | 0 to +70°C        | NE5180N    |
| 28-Pin Plastic DIP | 0 to +70°C        | NE5181N    |
| 28-Pin PLCC        | 0 to +70°C        | NE5180A    |
| 28-Pin PLCC        | 0 to +70°C        | NE5181A    |

# Octal Differential Line Receivers

# NE5180/NE5181

### ABSOLUTE MAXIMUM RATINGS TA = + 25°C

| SYMBOL          | PARAMETER                  | RATING                  | UNIT |
|-----------------|----------------------------|-------------------------|------|
| PD              | Power dissipation          | 800                     | mW   |
| V <sub>CC</sub> | Supply voltage             | 7                       | v    |
| V <sub>CM</sub> | Common-mode range          | ± 15                    | v    |
| V <sub>ID</sub> | Differential input voltage | ± 25                    | v    |
| ISINK           | Output sink current        | 50                      | mA   |
| V <sub>FS</sub> | Failsale voltage           | -0.3 to V <sub>CC</sub> | v    |
| los             | Output short-circuit time  | 1                       | sec  |



## DC ELECTRICAL CHARACTERISTICS $V_{CC} = +5V \pm 5\%$ , 0°C < T<sub>A</sub> < +70°C, input common-mode range $\pm 7V$

|                   |                                      |                                 |                                                                              |                         | NE5180 |      | NE5181 |      |          |  |
|-------------------|--------------------------------------|---------------------------------|------------------------------------------------------------------------------|-------------------------|--------|------|--------|------|----------|--|
| SYMBOL            | PARAMETER                            |                                 | TEST CONDITIONS                                                              |                         | Min    | Max  | Min    | Max  | UNIT     |  |
| R <sub>IN</sub>   | DC input resistance                  | $3V \leq  V_{\rm IN}  \leq 25V$ | V                                                                            |                         | 3      | 7    | 3      | 7    | kΩ       |  |
|                   |                                      | Inputs open or                  | Inputs open or<br>shorted to<br>GND $0 \le I_{OUT} \le 8mA$ , $V_{failsafe}$ |                         |        | 0.45 |        | 0.45 |          |  |
| V <sub>OFS</sub>  | Failsafe output voltage              |                                 |                                                                              |                         | 2.7    |      | 2.7    |      | V        |  |
|                   | Differential input high <sup>4</sup> | $V_{OUT} \ge 2.7V_{,}$          |                                                                              |                         |        | 0.2  |        | 0.2  | <u> </u> |  |
| V <sub>TH</sub>   | threshold                            | lout = -440μA                   |                                                                              |                         |        | 0.4  |        | 0.4  |          |  |
|                   | Differential input low <sup>4</sup>  | V <sub>OUT</sub> ≤ 0.45V,       |                                                                              | $R_S = 0^1$             | -0.2   |      | -0.2   |      |          |  |
| .V <u>t</u> i     | threshold                            | IOUT = 8mA                      |                                                                              | -0.4                    |        | -0.4 |        | v    |          |  |
| V <sub>H</sub>    | Hysteresis <sup>4</sup>              | FS = 0V or V <sub>CC</sub>      | FS = 0V or V <sub>CC</sub> (See Figure 1 )                                   |                         | 50     | 140  | 50     | 140  | m٧       |  |
| V <sub>IOC</sub>  | Open-circuit input voltage           |                                 |                                                                              |                         |        | 2    |        | 2    | V        |  |
| Cı                | Input capacitance                    |                                 |                                                                              |                         |        | 30   |        | 30   | pF       |  |
| , V <sub>OH</sub> | High level output voltage            | $V_{ID} = 1V$ , $I_{OUT} =$     | - <b>44</b> 0μA                                                              | ·······                 | 2.7    |      | 2.7    |      | v        |  |
|                   |                                      | X = 11                          |                                                                              | $l_{OUT} = 4mA^2$       |        | 0.4  |        | 0.4  | v        |  |
| «V <sub>OL</sub>  | Low level output voltage             | $V_{ID} = -1V$                  |                                                                              | $I_{OUT} = 8mA^2$       |        | 0.45 |        | 0.45 | ] `      |  |
| los               | Short-circuit output current         | V <sub>ID</sub> = 1V, Note :    | 3                                                                            |                         | 20     | 100  | 20     | 100  | mA       |  |
| lcc               | Supply current                       | $4.75V \le V_{CC} \le 5$        | 5.25V, V <sub>ID</sub> = -1V; FS                                             | S = 0∨                  |        | 100  |        | 100  | mA       |  |
| <b>I</b>          |                                      | Other inputs gro                | and ad                                                                       | V <sub>IN</sub> = + 10V |        | 3.25 |        | 3.25 | mA       |  |
| l <sub>IN</sub>   | Input current                        |                                 |                                                                              | $V_{IN} = -10V$         | -3.25  |      | -3.25  |      |          |  |

NOTES \$

1.  ${\sf R}_{\sf S}$  is a resistor in series with each input.

2. Measured after 100ms warm-up (at 0°C).

3. Only 1 output may be shorted at a time and then only for a maximum of 1 second.

4. See Figure 1 for threshold and hysteresis definitions.

## AC ELECTRICAL CHARACTERISTICS $V_{CC} = +5V \pm 5\%$ , 0°C < T<sub>A</sub> < +70°C

|                  |                                 |                                                       | NE  | NE5180 |     | NE5181 |      |
|------------------|---------------------------------|-------------------------------------------------------|-----|--------|-----|--------|------|
| SYMBOL           | PARAMETER                       | TEST CONDITIONS                                       | Min | Max    | Min | Max    | UNIT |
| <b>t</b> ₽LH     | Propagation delay - low to high | $C_L = 50 pF, V_{ID} = \pm 1V$                        |     | 500    |     | 100    | ns   |
| 1 <sub>PHL</sub> | Propagation delay — high to low | $C_L = 50 pF, V_{ID} = \pm 1V$                        |     | 500    |     | 100    | ns   |
| fa               | Acceptable input frequency      | Unused input grounded, $V_{ID} = \pm 200 \text{mV}^1$ |     | 0.1    |     | 5.0    | MHz  |
| 1,               | Rejectable input frequency      | Unused input grounded, $V_{ID} = \pm 500 \text{mV}$   | 5.5 |        | NA  |        | MHz  |

NOTE:

1.  $V_{ID} = \pm 1V$  for NE5181.

December 1987





# MK48T08 (B)-10/12/15/20

# 8K X 8 ZEROPOWER TIMEKEEPER RAM

#### ADVANCED DATA

- INTEGRATED ULTRA LOW POWER SRAM, REAL TIME CLOCK, CRISTAL, POWER-FAIL CONTROL CIRCUIT AND BATTERY
- BYTEWIDE<sup>TM</sup> RAM-LIKE CLOCK ACCESS
- BCD CODED YEAR, MONTH, DAY DATE, HOURS, MINUTES AND SECONDS
- SOFTWARE CONTROLLED CLOCK CALIBRATION FOR HIGH ACCURACY APPLI-CATIONS
- PREDICTED WORST CASE BATTERY STORAGE LIFE OF 11 YEARS @ 70°C
- PIN AND FUNCTION COMPATIBLE WITH JEDEC STANDARD 8K X8 SRAMs
- AUTOMATIC POWER-FAIL CHIP DESELECT/WRITE PROTECTION

T.





| Part Number | Access Time        | R/W Cycle Time     |  |  |  |  |
|-------------|--------------------|--------------------|--|--|--|--|
| MK48T08-10  | 100 <del>1</del> 5 | 100 ŋs             |  |  |  |  |
| MK48T08-12  | 120 ηs             | 120 ŋs             |  |  |  |  |
| MK48T08-15  | 150 ηs             | 150 ηs             |  |  |  |  |
| MK48T08-20  | 200 ŋs             | 200 <sub>7</sub> s |  |  |  |  |

#### PIN NAMES

| A0-A12                  | ADDRESS INPUTS   |
|-------------------------|------------------|
| Ē                       | CHIP ENABLE      |
| GND                     | Ground           |
| NC                      | NO CONNECTION    |
| V <sub>CC</sub>         | +5 VOLTS         |
| $\overline{\mathbf{w}}$ | WRITE ENABLE     |
| G                       | OUTPUT ENABLE    |
| DQ0-DQ7                 | DATA IN/DATA OUT |

#### June 1988

This is advance information on a new product now in development or undergoing evaluation. Details are subject to change without notice

<u>1/13</u> 337

#### TRUTH TABLE MK48T08

| v <sub>cc</sub>                                     | Ē               | Ğ               | Ŵ   | MODE     | DQ               | POWER                  |  |
|-----------------------------------------------------|-----------------|-----------------|-----|----------|------------------|------------------------|--|
|                                                     | VIH             | x               | x   | Deselect | High-Z           | Standby                |  |
| <v<sub>CC<br/>(max)</v<sub>                         | VIL             | x               | VIL | Write    | D <sub>IN</sub>  | Active                 |  |
| V <sub>CC</sub><br>(min)                            | V <sub>IL</sub> | V <sub>IL</sub> | VIH | Read     | D <sub>OUT</sub> | Active                 |  |
|                                                     | V <sub>IL</sub> | VIH             | VIH | Read     | High-Z           | Active                 |  |
| <v<sub>PFD<br/>(min)<br/>&gt;V<sub>SO</sub></v<sub> | x               | ×               | x   | Deselect | High-Z           | CMOS<br>Standby        |  |
| ≤V <sub>SO</sub>                                    | x               | x               | x   | Deselect | High-Z           | Battery<br>Back-<br>up |  |

#### DESCRIPTION

The MK48T08 combines an 8K  $\times$  8 full CMOS SRAM, a BYTEWIDE accessible real time clock, a crystal and a long life lithium carbon mono-fluoride battery, all in a single plastic DIP package. The MK48T08 is a non-volatile pin and function equivalent to any JEDEC standard 8K  $\times$  8 SRAM.

#### FIGURE 1. BLOCK DIAGRAM

It also easily fits into many EPROM and EEPROM sockets, providing the non-volatility of the PROMs without any requiremnt for special write timing, or limitations on the number of writes that can be performed.

Access to the clock is as simple as conventional BYTEWIDE RAM access because the RAM and the clock are combined on the same die. As figure 1 indicates, the TIMEKEEPER registers are located in the upper eight locations of the RAM. The registers contain, beginning at the top; year, month, date, day, hour, minutes, and seconds data in 24 hour BCD format. Corrections for 28, 29 (Leap Year), 30 and 31 day months are made automatically. The eighth location is a Control register. These registers are not the actual clock counters; they are BiPORT read/write Static RAM memory locations. The MK48T08 includes a clock control circuit that, once every second, dumps the counters into the BiPORT RAM.

Because the Clock Registers are constructed using BiPORT memory cells, access to the rest of the RAM proceeds unhindered by updates to the TI-MEKEEPER registers, even if the TIMEKEEPER registers are being updated at the very moment another location in the memory array is accessed. The MK48T08 also has its own Fower-fall Detect circuit. The circuit deselects the device when ever  $V_{CC}$  is out of range, providing a high degree of data security in the midst of unpredictable system operations brought on by low  $V_{CC}$ .



SGS-THOMSON MIGROELECTROMICS

<u>2/13</u> 338

#### READ MODE

The MK48T08 is the Read Mode whenever  $\overline{W}$  (Write Enable) is high and  $\overline{E}$  (Chip Enable) is low. The device architecture allows ripple-through access to any of the 8192 address locations in the static storage array. Valid data will be available at the Data I/O pins within t<sub>AA</sub> after the last address input signal is stable, providing that the  $\overline{E}$  and  $\overline{G}$  access times are satisfied.

If  $\overline{E}$  or  $\overline{G}$  access times are not yet met, valid data

| FIGURE 2. READ CYCL | _E | TIMING |
|---------------------|----|--------|
|---------------------|----|--------|

will be available at the latter of Chip Enable Access Time ( $t_{CEA}$ ) or at Output Enable Access Time ( $t_{OEA}$ ). The state of the eight three-state Data I/O signals is controlled by  $\overline{E}$  and  $\overline{G}$ . If the Outputs are activated before  $t_{AA}$ , the data lines will be driven to an indeterminate state until  $t_{AA}$ . If the Address inputs are changed while  $\overline{E}$  and  $\overline{G}$  remain low, output data will remain valid for Output Data Hold Time ( $t_{OH}$ ) but will go indeterminate until the next Address Access.



#### AC ELECTRICAL CHARACTERISTICS (READ CYCLE) ( $0^{\circ}C \leq TA \leq +70^{\circ}C$ , $V_{CC} = 5.0 V + 10\%/-5\%$ )

| ALT.                   | STD.              | PARAMETER                   | MK48 | T08-10 | MK48 | T08-12 | MK48 | ro8-15 | MK48 | T08-20 | UNITS | NOTE |
|------------------------|-------------------|-----------------------------|------|--------|------|--------|------|--------|------|--------|-------|------|
| SYM.                   | SYM.              | PARAMEIER                   | MIN  | MAX    | MIN  | MAX    | MIN  | MAX    | MIN  | MAX    |       |      |
| tRC                    | tAVAV             | Read Cycle Time             | 100  |        | 120  |        | ·150 |        | 200  |        | ηS    |      |
| t <sub>AA</sub>        | tAVQV             | Address Access Time         |      | 100    |      | 120    |      | 150    |      | 200    | ηS    | 3    |
| <b><sup>t</sup>CEA</b> | t <sub>ELQV</sub> | Chip Enable Access Time     |      | 100    |      | 120    |      | 150    |      | 200    | ηS    | 3    |
| <sup>t</sup> CEZ       | tehoz             | Chip Enable Data Off Time   |      | 50     |      | 60     |      | 75     |      | 100    | ηS    |      |
| <sup>1</sup> OEA       | <sup>1</sup> GLQV | Output Enable Access Time   |      | 50     |      | 60     |      | 75     |      | 100    | ηS    | 3    |
| tOEZ                   | lgнаz             | Output Enable Data Off Time |      | 40     |      | 50     |      | 60     |      | 80     | ηS    |      |
| <b>t</b> OEL           | <sup>1</sup> GLQX | Output Enable to Q Low-Z    | 5    |        | 5    |        | 5    |        | 5    |        | ηS    |      |
| t <sub>CEL</sub>       | <b>t</b> ELQX     | Chip Enable to Q Low-Z      | 10   |        | 10   |        | 10   |        | 10   |        | ηS    |      |
| tон                    | 1 <sub>DHAX</sub> | Output Hold from Address    | 5    |        | 5    |        | 5    |        | 5    |        | ηS    |      |

SGS-THOMSON

<u>3/13</u> 339

1

#### WRITE MODE

The MK48T08 is in the Write Mode whenever  $\overline{W}$ and  $\overline{E}$  control lines are low. The start of a write is referenced to the latter occurring falling edge of  $\overline{W}$  or  $\overline{E}$ . A write is terminated by the earlier rising edge of  $\overline{W}$  or  $\overline{E}$ . The addresses must be held valid throughout the cycle.  $\overline{E}$  or  $\overline{W}$  must return high for minimum of two prior to the initiation of another read or write cycle. Data-in must be valid  $t_{DS}$  prior to the end of write and remain valid for  $t_{DH}$  afterward.

Because  $\overline{G}$  is a Don't Care in the Write Mode and a low on  $\overline{W}$  will return the outputs to High-Z,  $\overline{G}$  can be tied low and two-wire RAM control can be implemented. A low on  $\overline{W}$  will disable the outputs twee after W falls. Take care to avoid bus contention when operating with two-wire control.





## AC ELECTRICAL CHARACTERISTICS (WRITE CYCLE)

 $(0^{\circ}C \le TA \le +70^{\circ}C, V_{CC} = 5.0 V + 10^{\circ}/-5^{\circ})$ 

| ALT.              | STD.              | PARAMETER                             | MK48 | T08-10 | MK48 | T08-12 | MK48 | T08-15 | MK48T08-20 |     |    | NOTE |
|-------------------|-------------------|---------------------------------------|------|--------|------|--------|------|--------|------------|-----|----|------|
| SYM.              | SYM.              | PARAMETER                             | MIN  | MAX    | MIN  | MAX    | MIN  | MAX    | MIN        | MAX |    |      |
| twc               | tAVAV             | Write Cycle Time                      | 100  |        | 120  |        | 150  |        | 200        |     | ηS |      |
| t <sub>AS</sub>   | tavwl             | Address Setup Time $\overline{W}$ Low | 0    |        | 0    |        | 0    |        | 0          |     | ηS |      |
| tas               | TAVEL             | Address Setup Time E Low              | 0    |        | 0    |        | 0    |        | 0          |     | ηS |      |
| <sup>t</sup> CEW  | tELEH             | Chip Enable to End of Write           | 80   |        | 100  |        | 130  |        | 180        |     | ηs |      |
| t <sub>AW</sub>   | tavwh             | Add. Valid to End of Write            | 80   |        | 100  |        | 130  |        | 180        |     | ηS |      |
| t <sub>AW</sub>   | tAVEH             | Add. Valid to End Write               | 80   |        | 100  |        | 130  |        | 180        |     | ηS |      |
| twew              | twlwh             | Write Pulse Width                     | 50   |        | 70   |        | 100  |        | 150        |     | ηS |      |
| t <sub>1CEZ</sub> | t <sub>EHOZ</sub> | Ē Data Off Time                       |      | 50     |      | 60     |      | 75     |            | 100 | ηS |      |
| twez              | twLQZ             | W Data Off Time                       |      | 50     |      | 60     |      | 57     |            | 100 | ης |      |



| ALT.            | STD.              | PARAMETER                                            | MK48T08-10 |     | MK48 | T08-12 | MK48 | T08-15 | MK48 | T08-20 | UNITO |      |
|-----------------|-------------------|------------------------------------------------------|------------|-----|------|--------|------|--------|------|--------|-------|------|
| SYM.            | SYM.              | PARAMETER                                            | MIN        | MAX | MIN  | MAX    | MIN  | MAX    | MIN  | MAX    |       | NOTE |
| twR             | twhax             | $\overline{W}$ High to Address Change                | 10         |     | 10   |        | 10   |        | 10   |        | ηS    |      |
| t <sub>WR</sub> | t <sub>EHAX</sub> | E High to Address Change                             | 10         |     | 10   |        | 10   |        | 10   |        | ηS    |      |
| twR             | WHWL              | $\overline{W}$ High to $\overline{W}$ Low next Cycle | 10         |     | 10   |        | 10   |        | 10   |        | ηS    |      |
| t <sub>DS</sub> | t <sub>DVWH</sub> | Data Setup Time to $\overline{W}$ High               | 50         |     | 60   |        | 70   |        | 80   |        | ηS    |      |
| t <sub>DS</sub> | t <sub>DVEH</sub> | Data Setup Time to $\overline{E}$ High               | 50         |     | 60   |        | 70   |        | 80   |        | ηS    |      |
| t <sub>DH</sub> | twhdx             | Data Hold Time $\overline{W}$ High                   | 5          |     | 5    |        | 5    |        | 5    |        | ηS    |      |
| t <sub>DH</sub> | t <sub>EHDX</sub> | Data Hold Time E High                                | 5          |     | 5    |        | 5    |        | 5    |        | ηS    |      |

# AC ELECTRICAL CHARACTERISTICS (WRITE CYCLE) (Continued) (0°C $\leq$ TA $\leq$ +70°C, V<sub>CC</sub> = 5.0 V + 10%/-5%)

#### AC TEST CONDITIONS

| Input Levels:           | 0.6V to 2.4V |  |  |  |  |  |  |  |
|-------------------------|--------------|--|--|--|--|--|--|--|
| Transition Times:       | 5 ns         |  |  |  |  |  |  |  |
| Input and Output Timing |              |  |  |  |  |  |  |  |
| Reference Levels:       | 0.8V or 2.2V |  |  |  |  |  |  |  |

--

#### FIGURE 4. OUTPUT LOAD DIAGRAM



#### CAPACITANCE

| SYMBOL | PARAMETER                           | MAX  | UNITS | NOTES |
|--------|-------------------------------------|------|-------|-------|
| Cl     | Capacitance on all pins (except DQ) | 7.0  | pF    |       |
| CDQ    | Capacitance on DQ pins              | 10.0 | pF    |       |



ALC: NO.

#### FIGURE 5. POWER-UP / POWER-DOWN CONDITIONS



# AC ELECTRICAL CHARACTERISTICS (POWER-UP/DOWN TIMING) (0°C $\leq$ TA $\leq$ + 70°C)

| SYMBOL          | PARAMETER                                                                  | MIN | MAX | UNITS | NOTES |  |
|-----------------|----------------------------------------------------------------------------|-----|-----|-------|-------|--|
| t <sub>PD</sub> | $\overline{E}$ or $\overline{W}$ at V <sub>IH</sub> before Power Down      | 0   |     | μS    |       |  |
| ۱ <sub>F</sub>  | V <sub>PFD</sub> (Max) to V <sub>PFD</sub> (Min) V <sub>CC</sub> Fall Time | 300 |     | μs    |       |  |
| t <sub>FB</sub> | V <sub>PFD</sub> (Min) to V <sub>SO</sub> V <sub>CC</sub> Fall Time        | 10  |     | μs    |       |  |
| t <sub>RB</sub> | $V_{SO}$ to $V_{PFD}$ (Min) $V_{CC}$ Rise Time                             | 1   |     | μs    |       |  |
| t <sub>R</sub>  | $V_{PFD}$ (Min) to $V_{PFD}$ (Max) $V_{CC}$ rise Time                      | 0   |     | μs    |       |  |
| tREC            | $\overline{E}$ or $\overline{W}$ at $V_{IH}$ after Power Up                | 2   |     | ms    |       |  |

# DC ELECTRICAL CHARACTERISTICS (POWER-UP/DOWN TRIP POINTS) ( $0^{\circ}C \leq TA \leq +70^{\circ}C$ )

| SYMBOL          | PARAMETER                                    | MIN | ТҮР | MAX  | UNITS    | NOTES |
|-----------------|----------------------------------------------|-----|-----|------|----------|-------|
| VPFD            | Power-fail Deselect Voltage                  | 4.5 | 4.6 | 4.75 | <b>V</b> |       |
| V <sub>SO</sub> | Battery Back-up Switchover Voltage           |     | 3.0 |      | v        |       |
| t <sub>DR</sub> | Expected Data Retention Time (Oscillator On) | 5   |     |      | YEARS    |       |

#### CAUTION Negative undershoots below – 0.3 volts are not allowed on any pin while in the Battery Back-up mode.

SGS-THOMSON

- 6/13
- 342

WIND'S X

#### **CLOCK OPERATIONS**

#### **Reading the Clock**

Updates to the TIMEKEEPER registers should be halted before clock data is read to prevent reading of data in transition. Because the BiPORT TIME-KEEPER cells in the RAM array are only data registers, and not the actual counter, updating the registers can be halted without disturbing the clock itself.

Updating is halted when a "1" is written into the "Read" bit, the seventh most significant bit in the Control Register. As long as a "1" reamins in that position, updating is halted. After a Halt is issued, the registers reflect the count, that is day, date, and time that were current at the moment the Halt command was issued.

All of the TIMEKEEPER register are updated simultaneously. A Halt will not interrupt an update in progress. Updating is within a second after the bit is reset a "0".

#### Setting the Clock

The eight bit of the Control register is the "Write" bit. Setting the Write bit to a "1", like the Read bit, halts updates to the TIMEKEEPER registers. The user can then load them with the correct day, date and time data in 24 Hour BCD format. Resetting the Write bit to a "0" then transfers those values to the actual TIMEKEEPER counters and allows normal operation to resume.

#### Stopping and Starting the Oscillator

The oscillator may be stopped at any time. If the device is going to spend a significant amount of time on the shelf, the oscillator can be turned off to minimize current drain from the battery. The "Stop" bit is the MSB for the Seconds Register. Setting it to a "1" stops the oscillator.

#### FIGURE 6. THE MK48T08 REGISTER MAP

|         |    |                |                | DA | TA             |                  |                |                | FUNCTION |               |  |
|---------|----|----------------|----------------|----|----------------|------------------|----------------|----------------|----------|---------------|--|
| ADDRESS | D7 | D <sub>6</sub> | D <sub>5</sub> | D4 | D <sub>3</sub> | D <sub>2</sub> . | D <sub>1</sub> | D <sub>0</sub> | FUNCTIO  | N             |  |
| 1FFF    |    | _              | _              | _  | -              |                  |                | -              | YEAR     | 00-99         |  |
| 1FFE    | x  | x              | x              | -  | _              |                  | -              | -              | MONTH    | 01-12         |  |
| 1FFD    | x  | . X            |                |    |                |                  | _              | -              | DATE     | 01-31         |  |
| 1FFC    | x  | FT             | ×              | x  | x              |                  | -              | -              | DAY      | 01-07         |  |
| 1FFB    | x  | x              | -              | _  | -              |                  |                | -              | HOUR     | <b>0</b> 0-23 |  |
| 1FFA    | x  | _              |                |    | -              |                  |                | -              | MINUTES  | <b>0</b> 0-59 |  |
| 1FF9    | ST | _              |                | _  | -              | -                |                | -              | SECONDS  | 00-59         |  |
| 1FF8    | w  | R              | S              |    |                |                  |                | _              | CONTROL  |               |  |

ST = STOP BIT W = WRITE BIT R = READ BITS = SIGNBIT FT = FREQUENCY TEST X = UNUSED

SGS-THOMSON

ST-12

#### **Calibrating the Clock**

The MK48T08 is driven by a quartz controlled oscillator with a nominal frequency of 32768 Hz. The crystal is mounted in the tophat along with the battery. A typical MK48T08 is accurate within  $\pm 1$  minute per month at 25°C without calibration. The devices are tested not to exceed 35 PPM (parts per million) oscillator frequency error at 25°C, which comes to about  $\pm 1.53$  minutes per month. Of course the oscillation rate of any crystal changes with temperature. Figure 6. shows the frequency error that can be expected at various temperatures.

Most clock chips compensate for crystal frequency and temperature shift error with cumbersome trim capacitors. The MK48T08 design, however, employs periodic counter correction. The calibration circuit adds or subtracts counts from the oscillator divider circuit at the divide by 128 stage, as shown in figure 7. The number of times pulses are blanked (subtracted, negative calibration) or split (added, positive calibration) depends upon the value loaded into the five bit Calibration byte found in the Control Register. Adding counts speeds the clock up, subtracting counts slows the clock down.

FIGURE 7. ADJUSTING THE DIVIDE BY 128



The Calibration byte occupies the five lower order bits in the Control register. This byte can be set to represent any value between 0 and 31 in binary form. The sixth bit is a sign bit; "1" indicates positive calibration, "0" indicates negative calibration. Calibration occurs within a 64 minute cycle. The first 62 minutes in the cycle may, once per minute, have one second either shortened or lengthened by 256 oscillator cycles, that is one tick of the divide by 128 stage of the clock chain. If a binary "1" is loaded into the register, only the first 4 minutes in the 64 minute cycle will be modified; if a binary 6 is loaded, the first 24 will be affected and so on.

Therefore, each calibration step has the effect of adding or subtracting 512 oscillator cycles for every 125,829, 120 actual oscillator cycles, that is 4.068 PPM of adjustment per calibration step gin the user 126.14 PPM calibration range. Assuming that the oscillator is in fact running at exactly 32768 Hz, each of the 31 increments in the Calibration byte would represent 10.7 seconds per month.

Two methods are available for ascertaining how much calibration a given MK48T08 may require. The first involves simply setting the clock, letting it run for a month and comparing it to a known accurate reference (like WWV broadcasts). While that may seem crude, it allows the designer to give the end user the ability to calibrate his clock as his environment may require, even after the final product is packaged in a non-user serviceable enclosure. All the designer has to do is provide a simple utility that accessed the Calibration byte. The utility could even be menu driven and made foolproof.

The second approach is better suited to a manufacturing environment, and involves the use of some test equipment. When the Frequency Test (FT.) bit, the seventh-most significant bit in the day Register, is set to a "1", and the oscillator is running at 32768 Hz, the LSB (DQ0) of the Seconds Register will toggle at a 512 Hz. Any deviation from 512 Hz indicates the degree and direction of oscillator frequency shift at the test temperature. For example, a reading of 512.01024 Hz would indicate a + 20 PPM oscillator frequency error, requiring a -5 (000101) to be loaded into the Calibration Byte for correction. Note that setting or changing the Calibration Byte does not affect the Frequency Test output frequency. The device must be selected and addresses must stable at Address 1FF9 when reading the 512 Hz on DQ0.

The FT. bit must be set using the same method used to set the clock, using the Write bit. The LSB of the Seconds Register is monitored by holding the MK48T08 in an extended read of the Seconds Register, without having the Read bit set. The FT. bit MUST be reset to a "0" for normal clock operations to resume.

- SGS-THOMSON -

<u>8/13</u> 344

#### FIGURE 8. FREQUENCY ERROR WITHOUT CALIBRATION



#### DATA RETENTION MODE

With V<sub>CC</sub> applied, the MK48T08 operates as a conventional BYTEWIDE static RAM. Should the supply voltage decay, the RAM will automatically power-fail deselect, write protecting itself when V<sub>CC</sub> falls within the V<sub>PFD</sub>(max), V<sub>PFD</sub>(min) window. The MK48T08 has a V<sub>PFD</sub>(max)-V<sub>PFD</sub>(min) window of 4.75 volts to 4.5 volts, allowing users constrained to a 10% power supply specification to use the device.

Note: A mid-write cycle power failure may corrupt data at the currently addressed location, but does not jeopardize the rest of the RAM's content. At voltages below VPFD(min), the user can be assured the memory will be in a write protected state, provided the V<sub>CC</sub> fall time does not exceed tF. The MK48T08 may respond to transient noise spikes that reach into the deselect window if this should occur during the time the device is sampling V<sub>CC</sub>. Therefore decoupling of the power supply lines is recommended.

The power switching circuit connects external V<sub>CC</sub> to the RAM and disconnects the battery when V<sub>CC</sub> rises above V<sub>SO</sub>. Normal RAM operation can resume t<sub>REC</sub> after V<sub>CC</sub> exceeds V<sub>PFD</sub>(max). Caution should be taken to keep  $\overline{E}$  or  $\overline{W}$  high as V<sub>CC</sub> rises past V<sub>PFD</sub>(min) as some systems may perform

inadvertent write cycles after  $V_{CC}$  rises but before normal system operation begins.

#### PREDICTING BACK-UP SYSTEM LIFE

The useful life of the battery in the MK48T08 is expected to ultimately come to an end for one of two reasons; either because it has been discharged wile providing current to an external load; or because the effects of aging render the cell useless before it can actually be discharged. Fortunately, these two effects are virtually unrelated, allowing discharge, or Capacity Consumption and the effects of aging, or Storage Life to be treated as two independent but simultaneous mechanisms, the earlier of which defines Back-up System life.

The current drain that is responsible for Capacity Consumption can be reduced either by applying  $V_{CC}$  or turning off the oscillator. With the oscillator off, only the leakage currents required to maintain data in the RAM are flowing. With  $V_{CC}$  on, the battery is disconnected from the RAM. Because the leakage currents of the MK48T08 are so low, then can be neglected in practical Storage Life calculations.

Therefore, to extent the life of components that are just sitting on the shelf (not in system use) the oscillator should be turned off.





SGS-THOMSON

#### Predicting Storage Life

Figure 9 illustrates how temperature affects Storage Life of the MK48T08 battery. As long as V<sub>CC</sub> is applied or the oscillator is turned off, the life of the battery is controlled by temperature and is virtually unaffected by leakage currents drawn by the MK48T08.

Storage Life predictions presented in Figure 9 are extrapolated from temperature accelerated life-test data collected in over 100 million device hours of continuing bare cell and encapsulated cell battery testing by SGS-THOMSON. Obviously, temperature accelerated testing cannot identify nontemperature dependent failur mechanisms. However, in view of the fact that no random cell failures have been recorded in any of SGS-THOMSON's on going battery testing since it began in 1982, we believe the chance of such failure mechanisms surfacing is extremely small.

For the purpose of the testing, a cell failure is defined as the inability af a cell stabilized a 25°C to produce a 2.0 volt closed-circuit voltage across a 250K load resistance. A Special Note: The summary presented in Figura 9 represents a conservative analysis of the data presently available. While SGS-THOMSON is most likely in possession of the largest collection of battery life data of this kind in the world, the results presented should not be considered absolute or final; they can be expected to change as yet more data becomes available. We believe that future read points of life test presently under way and improvements in the battery technology itself will result in a continuing improvement of these figures.

Two end of life curves are presented in Figure 9. They are labeled "Average" ( $t_{50\%}$ ) and ( $t_{1\%}$ ). These terms relate to the probability that a given number of failure will have accumulated by a particular point in time. If, for example, expected life at 70°C is at issue, Figure indicates that a particular MK48T08 has a 1% chance of having a battery failure 11 years into its life and a 50% chance of failure at the 20 year mark. Conversely, given a sample of device, 1% of them can be expected to experience battery failure within 11 years; 50% of them can be expected fail within 20 years.

<u>10/13</u> 346

The  $t_{1\%}$  figure represents the practical onset of wear out, and is therefore suitable for use in what would normally be thought of as a worst-case analysis. The  $t_{50\%}$  figure represents "normal" or "average" life. It is, therefore, accurate to say that the average device will last " $t_{50\%}$ ".

Battery life is defined as beginning at the date of manufacture. Each MK48T08 is marked with a four digit manufacturing date code in the form YYWW (example: 8625 = 1986, week 25).

Calculating Predicted "Storage Life of the Battery

As Figure 9 indicates, the predicted Storage Life on the battery in the MK48T08 is a function of temperature.

Because the ambient temperature profile is dependent upon application controlled variable, only the user can estimate predicted Storage Life in a given design. As long as ambient temperature is held reasonably constant, expected Storage Life can be read directly from Figure 9. If the MK48T08 spends an appreciable amount of time at a variety of temperatures, the following equation should be used to estimate Storage Life.

Predicted Storage Life =  $1 + \{ [(TA_1 \div TT) \div SL_1] + [TA_2 \div TT) \div SL_2] + ... + [(TA_N \div TT) \div SL_N] \}$ 

Where  $TA_1$ ,  $TA_2$ ,  $TA_N$  = Time at Ambient Temperature 1, 2, ect

 $TT = Total Time = TA_1 + TA_2 + ... + TA_N$ 

 $SL_1$ ,  $SL_2$ ,  $SL_N =$  Predicted Storage Life at Temp. 1, Temp. 2, ect. (See Figure 9)

#### Example Predicted Storage Life Calculation

A cash register/terminal operates in an environment where the MK48T08 is exposed to temperatures of

30°C (86°F) or less 4672 hrs./yr.: temperatures greater than 25°C, but less than 40°C (104°F), for 3650 hrs./yr.; and temperatures greater than 40°C, but less than 70°C (158°F), for the remaining 438 hrs./yr.

11/13

347

Reading Predicted  $t_{1\%}$  values from Figure 10;  $SL_1 = 456$  yrs.,  $SL_2 = 175$  yrs.  $SL_3 = 11.4$  yrs.

Total Time (TT) = 8760 hrs./yr.  $TA_1 = 4672$  hrs./yr.  $TA_2 = 3650$  hrs./yr.  $TA_3 = 438$  hrs./yr.

Predicted Typical Storage Life  $\geq 1 \div \{ [(4672 \div 8760) \div 465] + [3650 + 8760) \div 175] + [(438 \div 8760) \div 11.4] \}$ 

Predicted Typical Storage Life  $\geq$  126 years

ATT. SGS-THOMSON

÷

#### ABSOLUTE MAXIMUM RATINGS\*

| Voltage On Any Pin Relative to GND                                   | -0.3 V to +7.0V |
|----------------------------------------------------------------------|-----------------|
| Ambient Operating (V <sub>CC</sub> On) Temperature (T <sub>A</sub> ) | 0°C to +70°C    |
| Ambient Storage (V <sub>CC</sub> Off, Oscillator Off) Temperature    | -20°C to +70°C  |
| Total Device Power Dissipation                                       | 1 Watt          |
| Output Current Per Pin                                               | 20 mA           |

\* Stresses grater than those under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operional section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods of time may affect reliability.

#### **RECOMMENDED DC OPERATING CONDITIONS**

| SYMBOL          | PARAMETER                    | MIN   | MAX                  | UNITS | NOTES |
|-----------------|------------------------------|-------|----------------------|-------|-------|
| V <sub>CC</sub> | Supply voltage               | 4.75  | 5.5                  | v     |       |
| GND             | Supply Voltage               | 0     | 0                    | v     |       |
| V <sub>IH</sub> | Logic "1" Voltage All Inputs | 2.2   | V <sub>CC</sub> +0.3 | v     |       |
| VIL             | Logic "0" Voltage All Inputs | - 0.3 | 0.8                  | v     |       |

 $(0^{\circ}C \leq TA \leq +70^{\circ}C)$ 

### DC ELECTRICAL CHARACTERISTICS

÷.,

 $(0^{\circ}C \leq TA \leq +70^{\circ}C) (V_{CC} (Max) \leq V_{CC} \leq V_{CC}(Min))$ 

.

| SYMBOL           | PARAMETER                                              | MIN | MAX | UNITS | NOTES |
|------------------|--------------------------------------------------------|-----|-----|-------|-------|
| ICC1             | Average V <sub>CC</sub> Power Supply Current           |     | 80  | mA    |       |
| I <sub>CC2</sub> | TTL Standby Current (E = V <sub>IH</sub> )             |     | 5   | mA    |       |
| I <sub>CC3</sub> | CMOS Standby Current ( $\tilde{E} = V_{CC} - 0.2V$ )   |     | 3   | mA    |       |
| l <sub>IL</sub>  | Input Leakage Current (Any Input)                      | - 1 | +1  | μA    |       |
| IOL              | Output Leakage Current                                 | - 5 | +5  | μA    |       |
| V <sub>OH</sub>  | Output Logic "1" Voltage (I <sub>OUT</sub> = - 1.0 mA) | 2.4 |     | v     |       |
| V <sub>OL</sub>  | Output Logic "0" Voltage (I <sub>OUT</sub> =2.1 mA)    |     | 0.4 | v     |       |

2

SGS-THOMSON

<u>12/13</u> 348

÷

# **Pin Description**

| Symbol                                                                                                                                                                                        | Type<br>I/O/BD - cell                                                                                                                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IU Interface                                                                                                                                                                                  |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| iu_clk<br>ctl1                                                                                                                                                                                | I – DRVT8<br>Input– TLCHT<br>cycles.                                                                                                                                                               | Integer Unit Clock.Main system clock.<br>Atomic load-store indication during device                                                                                                                                                                                                                                                                                                                                              |
| SBus Interface                                                                                                                                                                                |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>sb_br_<br/>sb_bg_<br/>sb_as_<br/>sb_siz(2:0)<br/>sb_ack8_<br/>sb_ack32_<br/>sb_err_<br/>sb_merr_<br/>sb_rd<br/>sb_a(4:0)<br/>sb_d(31:24)<br/>sb_reset_<br/>b_irq(7:1)_<br/>mb_irq_</pre> | O - BT4 $I - TLCHN$ $I - TLCHN$ $BD - BD4TU$ $BD - BD4TU$ $BD - BD4TU$ $BD - BD4TU$ $I - TLCHT$ $BD - BD4TU$ $I - TLCHT$ $BD - BD4TU$ $I - TLCHT$ $BD - BD4TU$ $I - TLCHN$ $O - BT1OD$ $O - BT1OD$ | S-bus Bus request.<br>S-bus Grant.<br>S-bus address strobe<br>S-bus Size.<br>S-bus 8-bit Acknowledge.<br>S-bus 32-bit Acknowledge.<br>S-bus Error. Failed transfer.<br>S-bus Late Error. Failed transfer.<br>S-bus Late Error. Failed transfer.<br>S-bus read, High for Read cycles.<br>S-bus Address bits 4-0.<br>S-bus data.<br>S-bus reset.<br>S-bus interrupts = VME interrupts<br>Interrupt Request for mail box interrupt. |
| MMU                                                                                                                                                                                           |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| io_sel_<br>type(1:0)<br>B_A31_29L<br>B_A28_26L<br>B_A25_24L<br>pa(28:20)<br>pa19_16H_                                                                                                         | I – TLCHN<br>I – TLCHT<br>I – TLCHN<br>I – TLCHN<br>I – TLCHN<br>I – TLCHT<br>I – TLCHT                                                                                                            | Non-type 0 space strobe.<br>MMU type bits.<br>Decoding of P1_A(31:29)<br>Decoding of P1_A(28:26)<br>Decoding of P1_A(25:24)<br>Physical address bits.<br>Decoding of pa(19:16)= 0xF.                                                                                                                                                                                                                                             |
| Misc                                                                                                                                                                                          |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| pur_<br>gen_por_<br>ureson_<br>uresoff_<br>sysclkxin<br>sysclkxout<br>slot1_                                                                                                                  | I - TLCHT $O - BT1$ $I - TLCHT$ $I - TLCHT$ $I - OSCIM$ $O - OSCIM$ $I - TLCHN$                                                                                                                    | Power-up reset<br>Generate Power on reset.<br>User reset on<br>User rest off<br>Xtal in, VME system clock<br>Xtal out VME system clock<br>Slot Indicator.                                                                                                                                                                                                                                                                        |

S4-VME 9/21/89



# Master Interface:

A full 32 bit Master Interface is provided. Complete mapping of 512 MByte is possible all the time, but this 512 MByte window can be moved through all 4 GByte through a VME Mapping register.

A32, A24, A16 Address Modes, D32, D16, D8(EO) Data Sizes are supported.

On Master cycles, RMW, i.e. atomic load-store cycles are implemented according to the VME spec. The VME data strobe will be asserted two times as the VME address strobe is asserted. This differs from other Sun boards, where instead the ownership of VME is kept while a read and a write takes place. The problem with this is that if the access is to a board with several devices competing for an onboard bus, there is no way this board can recognize the access as a RMW. For example.: a disk board with multiple on board devices would not be able to prevent a shared resource to be stolen in between what looks like a standard Read and Write even though the VMEbus is hold.

Block mode transfers are not supported. They are only supported by the Slave interface.

Unaligned transfers (UAT) are not supported. Accesses of this kind, i.e. 16-bit accesses to base addr. + 1 or addr. + 3, or 32 bit accesses to base addr. + 1, base addr. + 2 or base addr. + 3 will not be recognized, resulting in a Bus error time out.

| A32 | Map | Register |
|-----|-----|----------|
|-----|-----|----------|

| Туре<br>1 | Device Addr<br>0xEFE00018 |    | Device<br>A32 Map Reg. |    |    | Physical Space<br>1 byte |       |    |
|-----------|---------------------------|----|------------------------|----|----|--------------------------|-------|----|
|           | 31                        | 30 | 29                     | 28 | 27 | 26                       | 25    | 24 |
|           | VME Master Addr           |    | 0                      | 0  | 0  | 0                        | LoopB |    |

This register can re-map VME Address bits A[31:29] to enable full 4 Gbyte mapping. Only 8-bit accesses should be used, 16- or 32-bit accesses will not be acknowledged, resulting in a bus error time out.

Initialization: The register will be cleared to 0's on resets, thus mapping the 512 MByte MMU mapping to 0-512 MByte and disabling loopback mode.

Bit:

| 31:29 | 0x0 map VME Master range        | 0x0000000-0x1FFFFFF   | 0-512 MByte |
|-------|---------------------------------|-----------------------|-------------|
|       | 0x1 - " - "                     | 0x2000000-0x3FFFFFF   | 512-1 GByte |
|       | 0x2 - " - "                     | 0x40000000-0x5FFFFFF  | 1-1.5 "     |
|       | 0x3 - " - "                     | 0x60000000-0x7FFFFFF  | 1.5-2 "     |
|       | 0×4 – " – "                     | 0x8000000-0x9FFFFFF   | 2-2.5 "     |
|       | 0x5 - " - "                     | 0xA0000000-0xBFFFFFF  | 2.5-3 "     |
|       | 0×6 - " - "                     | 0xC0000000-0xDFFFFFF  | 3-3.5 "     |
|       | 0×7 – " – "                     | 0xE0000000-0xFFFFFFFF | 3.5-4 "     |
| 28:25 | Not used, always read back as 0 |                       |             |

24 This bit set will enable VME loopback mode, used for diagnostics.

S4-VME 9/21/89

Page 7

# Slave Interface:

#### A32, A24 address mode.

1 MByte of memory is accessible, normally the lowest MByte on VME, but this can be changed to be in the 1-16 MByte range to support multi CPU board implementations. The address range will be incremented in 1 MByte steps.

VME defined Read-Modify-Write cycles is guaranteed to be atomic with respect to other VME Masters. Atomicity between VMEbus Slave accesses and CPU/Ethernet accesses to main memory, however, is not guaranteed. To guarantee this, the VME Bus Locker should be used, see the section about the Bus Locker register.

Unaligned accesses to the Slave Interface range will return a Bus Error back to the external VME Master.

The address modifiers on VME are used to define Address mode (A32/A24/A16), privilege, and data/program/block-transfer access. The Slave decoder and Mail Box Interrupter will monitor all address modifier bits with the exception of AM2, the access privilege bit. All slave accesses as a DVMA device will be set to supervisor mode, which is in accordance with the Sun-4 Architecture.

The 1 MByte VME address space selected will always be mapped to the highest megabyte in the Virtual Address Space, again in accordance with the Sun-4 Architecture.

#### Single Transfers/Block Mode Transfers

The DMA enable bit in the System Enable Register can disable SDVMA and therefore all Slave cycles. If this bit is set, single slave cycle can take place.

Block Mode transfers are enabled if the corresponding bit in the Slave Map Register is set. Only blocks of 4 transfers of aligned 32-bit words are supported. Longer blocks will result in a Bus Error from the fifth transfer and on. Accesses with other data sizes will get a Bus Error returned.

#### Slave Map Register

| Туре | Device Addr | Device |      | Physical Space |
|------|-------------|--------|------|----------------|
| 1    | 0xEFE0001C  | SMAP   | Reg. | 1 byte         |

|   | 31  | 30 | 29 | 28 | 27    | 26         | 25        | 24 |
|---|-----|----|----|----|-------|------------|-----------|----|
| ſ | BLM | 0  | 0  | 0  | VME S | ilave Addı | ress base | )  |

Sun Microsystems S4 Chip Set Sun SPARC(TM) Support System

S4-VME **Revision 1.0** 

The address space for System DVMA accesses is 1 MByte, normally the lowest Megabyte in accordance with the Sun-4 Architecture, but bits 28:25 can be used to re-map the SDVMA address space. Slave Block Mode transfers can also be enabled by setting bit 31. This lowest 1 MByte on VME is mapped to the highest 1 MByte within the Virtual Address space. During register accesses, only 8-bit accesses should be used. 16- or 32-bit accesses will not be acknowledged, resulting in a bus error time out.

Initialization: The register will be reset to all 0's on resets. Thus, the mapping will default to 0-1 MByte and block mode transfers will be disabled.

| Bit:  |                                                |              |                       |           |  |  |  |  |  |
|-------|------------------------------------------------|--------------|-----------------------|-----------|--|--|--|--|--|
| 31:   | This bit set will enable Block Mode Transfers. |              |                       |           |  |  |  |  |  |
| 30:28 | Not used, read back as 0                       |              |                       |           |  |  |  |  |  |
| 27:24 | 0x0 map SDV                                    | /MA space to | 0x0000000-0x000FFFFF  | 0-1 MByte |  |  |  |  |  |
|       | 0x1 – "                                        | - "          | 0x00100000-0x001FFFFF | 1-2 *     |  |  |  |  |  |
|       | 0×2 – "                                        | - "          | 0x00200000-0x002FFFFF | 2-3 "     |  |  |  |  |  |
|       | 0x3 – "                                        | - "          | 0x00300000-0x003FFFFF | 3-4 "     |  |  |  |  |  |
|       | 0×4 – "                                        | - "          | 0x00400000-0x004FFFFF | 4-5 "     |  |  |  |  |  |
|       | 0×5 – "                                        | - "          | 0x00500000-0x005FFFFF | 5-6 "     |  |  |  |  |  |
|       | 0×6 – "                                        | - *          | 0x00600000-0x006FFFFF | 6-7 *     |  |  |  |  |  |
|       | 0×7 – "                                        | - "          | 0x00700000-0x007FFFFF | 7-8 "     |  |  |  |  |  |
|       | 0×8 – "                                        | - "          | 0x00800000-0x008FFFFF | 8-9 "     |  |  |  |  |  |
|       | 0x9 – "                                        | - "          | 0x00900000-0x009FFFFF | 9–10 "    |  |  |  |  |  |
|       | 0xA – "                                        | - *          | 0x00A00000-0x00AFFFFF | 10-11 "   |  |  |  |  |  |
|       | 0xB - "                                        | - "          | 0x00B00000-0x00BFFFFF | 11-12 "   |  |  |  |  |  |
|       | 0×C – "                                        | - "          | 0x00C00000-0x00CFFFFF | 12-13 "   |  |  |  |  |  |
|       | 0xD - "                                        | - "          | 0x00D00000-0x00DFFFFF | 13-14 "   |  |  |  |  |  |
|       | 0xE - "                                        | - "          | 0x00E00000-0x00EFFFFF | 14-15 "   |  |  |  |  |  |
|       | 0×F - "                                        | _ *          | 0x00F00000-0x00FFFFFF | 15-16 "   |  |  |  |  |  |

# Mail Box

A Mail Box interrupt function is provided. This mail box interrupt will detect accesses to the A16 address space to a location programmed into the mail box register. No real memory is provided at the location, but the mail box will respond with a VME DTACK, acknowledging the access and generate an on board interrupt if the Enable bit is set. VME Address bits A(15:14, 3:1)) will be checked and compared to the contents of the bits in the Mail Box Register. This corresponds to programming the location to one of the first 16-bit words at one of the four 16 KByte blocks of the address range. Any VME A16 address space, 8-bit or 16-bit read or write to the location programmed into the Mail Box Register will generate an onboard interrupt on level 8 if enabled. 32-bit wide access are not allowed and will not be acknowledged, resulting in a Time out Bus Error for the other accessing VME Master.





### Mail Box Register

| .,,, |       | Device Addr<br>0xEFE00010 |    | -    | Device<br>Mail Box Reg. |     | Physical Space<br>1 byte |    |
|------|-------|---------------------------|----|------|-------------------------|-----|--------------------------|----|
|      | 31    | 30                        | 29 | 28   | 27                      | 26  | 25                       | 24 |
|      | I-flg | En l                      | 0  | Comp | A(15:14)                | Com | p A(3:1)                 |    |

This register will set the VME address that will be monitored and will, if enabled, interrupt the IU via an on-board interrupt. Only 8-bit accesses to the register should be used, 16- or 32-bit accesses will not be acknowledged, resulting in a bus error time out. For mail box cycles, the VME bus will only be monitored for A16, D8 or D16 accesses.

Initialization: All bits will be initialized to 0's.

-

Interrupt:

level 1.

Bit: Note

- This bit set indicates that a mailbox interrupt is pending. A read of this register will reset the interrupt on the trailing edge of the read pulse. A write to this bit is ignored.
  This bit set will enable the mail box interrupt.
- 29 This bit is ionored, read back as 0

| 23 | 11113 011 | , is ignor | 60, 10ac | Dack as U   |    |
|----|-----------|------------|----------|-------------|----|
| 28 | To com    | npare wi   | th VME   | Address bit | 15 |
| 27 | -         |            | -        | •           | 14 |
| 26 | -         |            | -        |             | 3  |
| 25 | -         | *          | -        | -           | 2  |
| 24 | -         |            | -        |             | 1  |

# VME Bus Locker

A Bus locker function is provided to enable the CPU to do an atomic Read-Modify-Write (RMW) to its onboard memory without interrupting an incoming RMW from the VME Slave interface. This function is only to be used when the board is running together with one or more external CPU boards (Multiprocessing). In these cases, message passing is done through shared memory locations that need to be accessed in a defined way.

## VME Bus Locker Register

In a Non-Multiprocessing application, this register should be left alone. When used, bit 24 of the register should ALWAYS be SET for each update, to guarantee a consistent bus arbitration behavior.

| Тур<br>1 | -    | Device A |    |    | e <b>vice</b><br>Is Locke | r. Reg. | <b>Physical Space</b><br>1 byte |            |  |  |
|----------|------|----------|----|----|---------------------------|---------|---------------------------------|------------|--|--|
|          | 31   | 30       | 29 | 28 | 27                        | 26      | 25                              | 24         |  |  |
|          | Ownd | 0        | 0  | 0  | 0                         | 0       | Req Bus                         | Use locker |  |  |

Initialization:

All bits will be initialized to 0's.

Thus, the VME bus locker will be inactive and not affecting the board's bus arbitration.

Bit:

31 This bit indicates that the VME Bus is owned. No external VME board can access memory. Bit is read only, a write to this bit will be ignored.

| 30 | This bit | is | ignor | ed, re | ead I | back | as | 0. |
|----|----------|----|-------|--------|-------|------|----|----|
| 29 | -        | •  | - '   | ' -    | •     | -    | M  | -  |

| 28 | - |    | - | Ħ | - | • | - | •  | - |
|----|---|----|---|---|---|---|---|----|---|
| 27 | - | ** | - | • | - | • | - | •• | - |
| 26 | - | *  | - | * | - | - | - | •• | - |

- 25 This bit initiates a VME Bus request. Once owned, it will be held.
- 24 This bit set will enable the Bus request function. It should only be set for multiprocessing applications. If set, it should never be changed (unless system is restarted).

In multiprocessing applications, update register at system initialization time by writing 0x01 to the register. The procedure for accessing an onboard memory location is:

- 1 Disable VME Interrupts to prevent deadlock. (VME Interrupts need to acquire VME)
- 2. Request VME bus locking by writing 0x3 to the register.
- 3. Read register and check bit 31 to until VME bus is owned and locked.
- 4. Do RMW (atomic Load-Store) to onboard memory.
- 5. Unlock VME by writing 0x1 to register.
- 6. Enable VME Interrupts

Thus bit 24 is kept set.

Note ! Note that if VME is not unlocked in time, other accesses might time out causing a system crash. Always unlock VME ASAP after the RMW is completed !

# Interrupt Handler

The interrupt handler can selectively support all interrupt levels. These are enabled through the VME Interrupt/Bus Arbiter register. Note that this register is a replacement for a jumper and should normally be fixed depending on the VME Interrupt handler configuration. Run-time enabling of the interrupts are normally done with the Interrupt Enable register, see the System Specification.

Single level arbitration is normally used. If some VME boards do not get enough access to the bus, round robin select can be used. In that case the arbiter will give equal priority to all four levels. See the VMEbus spec.

## Interrupt Enable/ Bus Arbiter Mode Register

The Interrupt Enable Register can selectively enable all VME interrupt levels.

| Тур<br>1 |      | Device A<br>DxEFE000 |      |      | evice<br>AE Int. R | eg.  | Physical Space<br>1 byte |       |  |  |
|----------|------|----------------------|------|------|--------------------|------|--------------------------|-------|--|--|
|          | 31   | 30                   | 29   | 28   | 27                 | 26   | 25                       | 24    |  |  |
|          | En 7 | En 6                 | En 5 | En 4 | En 3               | En 2 | En 1                     | RRARB |  |  |

This Register enables VME interrupts to be fed to the Interrupt logic in the S-4 MMU chip. This register replaces 8 jumpers on the board. Only 8-bit accesses should be used, 16- or 32-bit accesses will not be acknowledged, resulting in a bus error time out.

Initialization:

bits 31:25 will be set and bit 24 reset.

Thus, VME interrupts will be enabled and the arbiter mode will be SGL, single level arbitration.

| Bit: |      |       |    |      |      |       |    |       |      |     |     |    |    |       |    |              |
|------|------|-------|----|------|------|-------|----|-------|------|-----|-----|----|----|-------|----|--------------|
| 31   | This | ; bit | se | t wi | l er | nable | ٧M | IE In | terr | upt | 7/S | un | -4 | level | 13 | to Int.logic |
| 30   |      | -     | •  | -    | *    | -     |    | -     | •    | -   | 6/  | -  | •  | -     | 11 | -            |
| 29   |      | -     |    | -    |      | -     |    | -     |      | -   | 5/  | -  | •  | -     | 9  | -            |
| 28   |      | -     | •  | -    |      | -     | *  | -     | •    | -   | 4/  | -  |    | -     | 8  | -            |
| 27   |      | -     | •  | -    | ۳    | -     | *  | -     | *    | -   | 3/  | -  |    | -     | 5  | -            |
| 26   |      | -     | -  | -    | *    | -     |    | -     | *    | -   | 2/  | -  | •  | -     | 3  | -            |
| 25   |      | -     | •  | _    | •    | -     | •  | _     | •    | -   | 1/  | _  |    | -     | 2  | -            |

24 This bit set will set the bus arbiter into a RRS mode (Round Robin Select). This bit reset will set the bus arbiter into a SGL level bus arbiter (arbitration level 3 only).

Note that enabling of the bus arbiter function is done via a jumper (Slot1 jumper).

Note! This register replaces onboard jumpers. Changes to this register should only be done at system initialization time not to be changed later (unless system is restarted).

# VME IACK Cycles

Interrupting devices out on the VMEbus require an interrupt acknowledge cycle to obtain an interrupt vector. A device space operation is used by the interrupt handler to run the acknowledge cycle and obtain the vector. The operation is Device space byte read with A[3-1] set to the VMEbus interrupt level being acknowledged. This location should only be accessed with 8-bit reads, 16- or 32-bit accesses will not be acknowledged, resulting in a bus error time out.

Note that an access to these seven addresses are not to an on chip register, but instead to execute a VME Interrupt Acknowledge cycle, acquiring the Interrupt Vector from the interrupting device.

| Type<br>1 |       | <b>Device Ad</b><br>0xEFE0000 | -      | -       | evice<br>ME Int.Vec | tor    | Physical Space<br>A[3:1]=VME Int. level,<br>A0=1, Read, only 8-bit<br>accesses should be used. |          |  | used. |
|-----------|-------|-------------------------------|--------|---------|---------------------|--------|------------------------------------------------------------------------------------------------|----------|--|-------|
|           | 31    | 30                            | 29     | 28      | 27                  | 26     | 25                                                                                             | 24       |  |       |
|           | 8-bit | Interrupt                     | Vector | from ir | nterrupting         | VME De | vice Leve                                                                                      | I A(3:1) |  |       |

This translates into the following interrupt responses:

| Acknowledging | VME interrupt | Device Address |
|---------------|---------------|----------------|
| 1             |               | 0xEFE00003     |
| 2             |               | 0xEFE00005     |
| 3             |               | 0xEFE00007     |
| 4             |               | 0xEFE00009     |
| 5             |               | 0xEFE0000B     |
| 6             |               | 0xEFE0000D     |
| 7             |               | 0xEFE0000F     |
|               |               |                |

Initialization: Not applicable.

# IACK Daisy Chain Driver

Active if Board is located in slot one, indicated by the Slot1 jumper.



# **Bus Requester**

The Bus requester is an ROR requester. It releases the bus when other VME Masters/Requesters requests the bus.

# **Bus Arbiter**

Two types of arbiters are provided, a Single Level Arbiter or a Round Robin Select Arbiter. They are selected through the VME Interrupt/Bus Arbiter register. Note that the arbiters will only be enabled if the board resides in slot 1. (Slot1 jumper)

In arbitration mode, locked arbitration will be detected and released by the arbiter after 3.3 ms. The Bus arbiter will then drive BBSY active for the minimum period required by the VMEbus spec. This is to prevent requesters that in the mean time have decided to withdraw their requests to be able to do so. Note that a withdrawal of a VME Request normally is in violation of the VME Specification. (Rule 3.11)

# Bus Time Out Period

There are two time out parameters in a VME cycle in addition to the On Board Bus arbitration timer: Rerun Time Out and Abort.

Rerun time out: If the time from the Master cycle starts until the VME slave responds with a DTACK exceeds 1.6 us, the cycle will be rerun by the IU so high-priority devices can get on the Sbus. In the mean time, the Master cycle and all output signals will be frozen, ignoring any DTACK coming in. When the cycle is rerun it will be reconnected again.

Abort: Two stages of the access exists. If the bus is not owned, it has to be acquired. Then the actual VMEbus cycle can start. A Master cycle will time out after 300 us. That means, the response time from another VME slave including the time for acquiring the bus must be less than 300 us.

If the VMEbus is not owned when an abort occurs, the bus requster will keep the VME Bus Request asserted even though the CPU cycles has been aborted. It will then assert a dummy Bus Busy (BBSY) when the Bus Grant is received. This is to comply with VME rule 3.11.

If the bus is owned when the abort takes place, a Bus Error will be generated. This Bus Error would normally be generated by an accessed VME slave. This is to comply with VME rule 2.48.

# System Reset

On power up, the CPU board will generate SYSRESET for a minimum of 200 ms, if the Slot1 jumper indicates the boards resides in slot 1. Incoming VMEbus resets will always generate an on board reset.

S4-VME 9/21/89

### Jumper

Only one jumper is required for the VME Interface: Slot1, thereby replacing numerous other jumpers. These other settings will be defined be by software register settings.

| Function<br>SYSTEM CLOCK    | "slot 1" position<br>enabled                                      | "not in slot 1" VME<br>tri-state           |
|-----------------------------|-------------------------------------------------------------------|--------------------------------------------|
| VME IACK Daisy-chain Driver | enabled                                                           | IACKIN drives IACKOUT                      |
| SYSRESET                    | sb_reset will generate<br>VME SYSRESET.                           | sb_reset will not<br>generate VME SYSRESET |
| BUS ARBITER                 | enabled (type deter-<br>mined by disabled<br>Interrupt reg bit 0) | disabled                                   |

## Programmable settings

The following registers include settings otherwise often provided by jumpers.

 Slave Map Register
 Defines the memory address space of the 1MByte on board VME Slave (System DVMA).

 VME Interrupt Handler Register
 Defines which interrupt levels to handle. Defines what type of VME Bus arbiter (If board resides in slot 1)

 A32 Map Register
 Defines where to map the CPU Master Address Space of 512 MByte.



# Performance:

The VME Gate Array logic will be designed to meet the Sbus and VMEbus specifications at a 20 MHz clock, correlating to a 50 ns clock cycle.

Bus arbitration for other VMEbus masters will take place faster thanks to the Early Release feature.

System DVMA can offer a higher bandwidth with the VME Block Mode transfer.

Note that these numbers are given only as a way to describe the VME performance. Since the overall bandwidth depends on the other board's response time, the application code, amount of other tasks running concurrently, other concurrent DMA activity, cache hit/miss ratio etc. these figures should NOT be expected to on a running system.

# Master Cycles

Conditions: Ideal VME slave accessed (30 ns DS to DTACK response). Bus already owned. No lingering DTACK or AS.

A Master cycle will be 9 cycles, corresponding to a theoretical 9 MByte/s bandwidth for back-to-back cycles.

# Slave Cycles

Conditions: Ideal VME master (0 ns DTACK to DS response). Fast Sbus grant (two clock periods).

| Cycle        | duration [ns] | theoretical bandwidth |
|--------------|---------------|-----------------------|
| Single read  | 560-630 ns    | 6.9-7.9 MByte/s       |
| Single write | 510-580 ns    | 6.3-7.2 MByte/s       |
| Block read   | 950-1250 ns   | 12.7-17.7 MByte/s     |
| Block write  | 920-1160 ns   | 13.7-17.4 MByte/s     |

# **Bus Arbitration**

Single level Arbiter: Conditions: No VME master owns the bus, Bus Locker disabled.

VME Bus Request to VME Bus Grant: 2 Cycles

Conditions: No VME master owns the bus, Bus Locker enabled

VME Bus Request to VME Bus Grant: 3 Cycles

Round Robin Arbiter: Conditions: No VME master owns the bus, Bus Locker disabled.

VME Bus Request to VME Bus Grant: 2-5 Cycles

Conditions: No VME master owns the bus, Bus Locker enabled

VME Bus Request to VME Bus Grant: 3-6 Cycles

# **Timing Specification**

| Symt     | ool From          | To (note1)         | Min | Max      | unit | Note |
|----------|-------------------|--------------------|-----|----------|------|------|
| St       | ous signals       |                    |     |          |      |      |
| t1       | clk high          | clk high           | 50  | 50       | ns   |      |
| t2       | clk high          | sb_ack valid       | 3   | 33       | กร   | 2    |
| t3       | clk high          | sb_d valid         | 3   | 34       | ns   |      |
| t4       | clk high          | sb_rd valid        | 3   | 30       | ns   |      |
| t5       | clk high          | sb_siz valid       | 3   | 26       | ns   |      |
| 6        | clk high          | sb_br_             | 3   | 24       | ns   |      |
| IA       | CK Daisy Chain    |                    |     |          |      |      |
| t7       | p1_ds(1:0)_ ass   | . vme_iackout ass. | 43  | 155      | ns   | 3,7  |
| 8        | p1_as_ neg.       | vme_iackout neg.   |     | 15       | ns   | 3, 7 |
|          | equester/Arbiter  |                    |     |          |      |      |
| 19       | clk high          | vme_bbsy_          |     | 26       | ns   |      |
| 10       | clk high          | vme_bgout          |     | 25       | ns   |      |
| 11       | clk high          | vme_br             |     | 25       | ns   |      |
| 12       | clk high          | b_asen_ ass.       |     | 29       | ns   |      |
| 13       | clk high          | b_asen_ neg.       |     | 38       | ns   |      |
| 14       | vme_as_ neg.      | b_asen_ neg.       |     | 12       | ns   |      |
|          | aster             |                    |     |          |      |      |
| 115      | clk high          | vme_am             |     | 28       | ns   | 4    |
| 116      | clk low           | vme_as ass.        |     | 21       | ns   |      |
| 17       | clk high          | vme_as neg.        |     | 25       | ns   |      |
| 18       | clk low           | vme_ds ass.        |     | 23       | ns   |      |
| 19       | clk high          | vme_ds neg.        |     | 20       | ns   |      |
| 20<br>21 | clk high          | ma_aclk            |     | 24<br>19 | ns   |      |
| 21       | clk high          | ma_aen_            |     | 19       | ns   |      |
|          | ave cycles        |                    |     |          |      |      |
| t22      | clk high          | sl_acik            |     | 23       | ns   |      |
| 23       | clk high          | sl_aen_            |     | 14       | ns   |      |
| 24       | clk low           | SbtP1clk           | 6   | 19       | ns   |      |
| 25       | clk high          | P1tSbclk           |     | 21       | ns   |      |
| 26       | clk high          | P1tSben_           |     | 20       | ns   |      |
|          | ave single cycles |                    |     |          |      |      |
| 27       | clk high          | vme_dtack          |     | 20       | ns   |      |
| t28      | clk high          | vme_berr           |     | 20       | ns   |      |

S4-VME 9/21/89

Sun Microsystems S4 Chip Set

S4–VME Revision 1.0

| t29   | clk high            | SbtP1en_        |        | 20  | ns |   |
|-------|---------------------|-----------------|--------|-----|----|---|
| Sia   | ave Block Mode Re   | eads            |        |     |    |   |
| t30   | P1_DS_ ass.         | vme_dtack_      | 37     | 719 | ns | 7 |
| t31   |                     |                 | 37     | 719 | ns | 7 |
| t32   | Plen_ass            | vme_dtack_ ass. | 28     | 103 | ns | 7 |
| t33   | Pien neg            | vme_dtack_ neg. | 30     | 108 | ns | 7 |
| t34   | P1_DS_ ass.         | SbtP1en_ass.    | 8      | 616 | ns | 7 |
| t35   | P1_DS_ neg.         | SbtP1en_neg.    | 6      | 28  | ns | 7 |
| t36   | P1_DS_ ass.         | pl_sel valid    | 6      | 29  | ns | 7 |
| Sla   | ave Block Mode W    | rites           |        |     |    |   |
| t37   | P1_DS_ ass.         |                 | 35     | 659 | ns | 7 |
|       | P1_DS_ ass.         |                 | 35     | 659 | ns | 7 |
|       | P1_DS_ ass.         |                 | 7      | 37  | ns | 7 |
| t40   | clk high            |                 | 5      | 15  | ns |   |
| t41   | clk high            | pl_sel valid    |        | 20  | ns |   |
| mi    | sc. VME             |                 |        |     |    |   |
| t42   | vme_sysr_ ass.      | vme_sysr_ neg.  | 200    |     | ms | 5 |
| Setup |                     |                 |        |     |    | _ |
|       | signals, ctl1, type | (1:0)           | 15 ns. |     |    | 6 |
| pa(28 |                     |                 | 23 ns  |     |    |   |
| b_axx | _xxl                |                 | 19 ns  |     |    |   |

Hold time for all the above signals is 0 ns except for sb\_err\_ which is 1 ns.

1) If signal direction is not specified, both high and low delays are included.

2) sb\_ack: sb\_ack8\_, sb\_ack32\_, sb\_err\_, sb\_merr\_.

3) IACK D.C. driver, slot1\_asserted

4) the clock following sb\_as assertion

5) When chip is in test mode, i.e. P1\_BGIN\_.0 = low and slot1\_ = low the vme\_sysr counter and the Bus grant counter will be preset to 32 clocks from their max value.

6) Sbus signals: sb\_as\_, sb\_a, sb\_ack8\_, sb\_ack32\_, sb\_err\_, sb\_merr\_sb\_rd, sb\_siz, sb\_br\_.

7) This timing is not related to clock

**Revision History** 

3/7/89 First release.

9/21/89 Revision 1.0 release

sb\_merr\_ changed from BD-BD4TU to I-TLCHT (Page 2) P1 inputs changed from SCHMITC to SCHMITT (Page 3) LSI device type changed from LMA9239 to LIA5530 (Page 4) VDD increased from 3 pins to 4 pins (Page 4) VSS increased from 4 pins to 8 pins (Page 4)

# Section 6

# **PROGRAMMING & FIRMWARE MANUAL**

# 6.0 Programming

Address Spaces Memory Management Cache Control System Control and Error Handling Memory Onboard Peripherals Interrupts LED's

# 6.1 Address Spaces

The SPARC architecture defines several different address spaces. A user program can only access two of them: User Data and User Instruction spaces. When the processor is in supervisor mode additional address spaces are available (even beyond the obvious Supervisor Instruction and Supervisor Data) using the load and store alternate instructions. The User and Supervisor Instruction and Data spaces make up Device space (for memory and peripherals). The other ASIs make up Control space, intended for use by system functions, such as cache and MMU control.

# 6.1.1 Control Space

The CPU-2CE supports System Space, Segment Map, Page Map, and various cache Flush spaces.

|      | Table: 6.1 Address Space Indicato | r Contents         |                                    |
|------|-----------------------------------|--------------------|------------------------------------|
| ASI# | Use                               | Address Space Type | Where Defined                      |
| 0x0  | Reserved                          | Control Space      | -                                  |
| 0x1  | Reserved                          | Control Space      | -                                  |
| 0x2  | System space                      | Control Space      | System Control Space               |
| 0x3  | Segment Map                       | Control Space      | MMU Control Space                  |
| 0x4  | Page Map                          | Control Space      | MMU Control Space                  |
| 0x.5 | High Speed Segment Flush          | Control Space      | Main Memory Cache<br>Control Space |
| 0x6  | High Speed Page Flush             | Control Space      | Main Memory Cache<br>Control Space |
| 0x7  | High Speed Context Flush          | Control Space      | Main Memory Cache<br>Control Space |
| Ox8  | User Instruction                  | Device Space       | Device Space                       |
| 0x9  | Supervisor Instruction            | Device Space       | Device Space                       |
| 0xA  | User Data                         | Device Space       | Device Space                       |
| 0xB  | Supervisor Data                   | Device Space       | Device Space                       |
| 0xC  | Flush Cache by Segment            | Control Space      | Main Memory Cache<br>Control Space |
| 0xD  | Flush Cache by Page               | Control Space      | Main Memory Cache<br>Control Space |
| 0xE  | Flush Cache by Context            | Control Space      | Main Memory Cache<br>Control Space |
| 0xF  | Hardware Virtual Flush            | Control Space      | Main Memory Cache<br>Control Space |

# 6.1.2 System Space (ASI = 2)

System Space can only be accessed by using load and store alternate instructions while the processor is in supervisor mode. It is used to access various system control registers as well as for direct access to cache tags and data for diagnostic purposes.

| Address   | Use                    | Comment                  |
|-----------|------------------------|--------------------------|
| 0000 0000 | ID PROM                | Not available on CPU-2CE |
| 3000 0000 | Context Register       |                          |
| 4000 0000 | System Enable Register |                          |
| 6000 0000 | Bus Error Register     |                          |
| 7000 0000 | Diagnostic Register    | Unused; no timeout       |
| 8000 0000 | Cache Tags             | Diagnostic use           |
| 9000 0000 | Cache Data             | Diagnostic use           |
| F000 0000 | Serial Port            | MMU Bypass               |

 Table: 6.2
 System Space (ASI=2)

## **ID PROM**

The ID PROM is unused on the CPU-2CE. The equivalent function is provided in the NVRAM, located in Device Space.

## **Context Register**

The Context Register is a 4-bit read/write register which controls which of 16 MMU contexts are in current use. Writes to this register have an immediate effect, subject to the normal pipelining imposed by the SPARC processor. The context register should be written and read as a byte only. The context Register is cleared on Reset.

# System Enable Register

The System Enable register controls the cache and SBus as follows:

# Table: 6.3 System Enable Register System Enable Register: ASI=2, Address=0x40000000)

| BOOT  | Zero | DMA_EN | CACHE                                                             | Zero                         | RESET                      | Zero            | TLBDis     |  |  |
|-------|------|--------|-------------------------------------------------------------------|------------------------------|----------------------------|-----------------|------------|--|--|
| 7     |      |        |                                                                   |                              |                            |                 | 0          |  |  |
| BOOT/ |      |        | All Supervi<br>Normal ope                                         | isor Reference<br>eration (M | nces go to I<br>MU Enabled | EPROM (MI<br>I) | MU bypass) |  |  |
|       | Zero | Alv    | Always reads as zero; unused                                      |                              |                            |                 |            |  |  |
|       | DMA  | _EN 1= | 1 = SBus DMA allowed.                                             |                              |                            |                 |            |  |  |
| CACHE |      |        | 1 = Enables cache. (Cache tags should be cleared before enabling) |                              |                            |                 |            |  |  |
|       | RESE | ET 1 = | System Res                                                        | set                          |                            |                 |            |  |  |

TLBDis 1 = MicroTLB disabled. For hardware debugging only; should be zero.

The System Enable register is cleared on Reset, leaving the system in Boot state with DMA and cache disabled.

# Synchronous Error Register

There are six Error Registers in control space: two address and two status registers for Synchronous and Asynchronous errors. (In addition to these registers, the parity control/status register exists in Device space.)

# Table: 6.4 Synchronous Error Register

| Synchronous Error Register | ASI=2, Address=0x6000 0000 | WORD ACCESS ONLY: |
|----------------------------|----------------------------|-------------------|
|----------------------------|----------------------------|-------------------|

| Write<br>15  | Zero       | Zero    | Zero                                | Zero     | Zero | Zero | Zero<br>8 |
|--------------|------------|---------|-------------------------------------|----------|------|------|-----------|
| Invalid<br>7 | Protection | Timeout | SBError                             | MEMError | Zero | Zero | Watchdog  |
|              |            |         | 1990 - A. 1997 - Marcine Street - 1 |          |      |      | 0         |

|            | Table: 6.5 Synchronous Error Register                                                             |
|------------|---------------------------------------------------------------------------------------------------|
| Write      | 1 = Error occurred during a write cycle                                                           |
| Invalid    | 1 = Valid bit was zero in a page map entry or top 3 adr<br>bits differ.                           |
| Protection | 1 = Protection error, write to read-only page, or user access of supervisor-or <sup>1</sup> page. |
| Timeout    | 1 = Non-existent device was accessed.                                                             |
| SBError    | 1 = SBus device returned error-ack (device-dependent).                                            |
| MEMError   | 1 = Memory (parity) error. (LErr on SBus) See parity register                                     |
| Watchdog   | 1 = Restart due to IU error. (Trap while traps disabled.)                                         |

In certain circumstances the IU will be given a memory exception which it ignores (such as when an annulled instruction falls on an invalid page). In this case, the Invalid error bit would be set in the synchronous error register, but the IU did not take a trap. The result is that later, more than one bit may be set in the Error Register and software must determine which is correct from the address in the Synchronous Error Address Register. Synchronous Error Address Register

# Table: 6.6 Synchronous Error Register: ASI=2, Address=0x6000 0004 WORD ACCESS ONLY:

Virtual Address of last synchronous error (A31:0))

The Synchronous error registers will always hold information about the last synchronous error which occurred.

The SEVAR is cleared on power-on or programmer-initiated reset. Synchronous error registers are not cleared on a watchdog reset.

## Asynchronous Error Register

The Asynchronous Error register reports buffered write errors and SBus-Controller detected DVMA Errors.:

# Table: 6.7 Synchronous Error Register: ASI=2, Address=0x6000 0008 WORD ACCESS ONLY:

| 15   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |                                                                                                                 |         |         |        |      |      |       |          |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------|---------|---------|--------|------|------|-------|----------|
|      | Size 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Size 0 | Invalid                                                                                                         | Proterr | Timeout | DVMAEn | Zero | Zero | SBErr | Multiple |
| - 64 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |                                                                                                                 |         |         |        |      |      |       |          |
| - 6  | and the second sec |        | the second se |         |         |        |      |      |       |          |

|           | Table: 6.8 Synchronous Error Register                               |  |  |  |  |  |
|-----------|---------------------------------------------------------------------|--|--|--|--|--|
| Multiple  | 1 = More than one Async Error since AER last cleared.               |  |  |  |  |  |
| SBErr     | 1 = IU Writing to a Slave device resulted in an Error Ack.          |  |  |  |  |  |
| DVMAErr   | 1 = Error during DVMA access.                                       |  |  |  |  |  |
| Timeout   | 1 = SB_AS_ asserted for more than 256 clocks, or DVMA illegal adrs. |  |  |  |  |  |
| Proterr   | 1 = DVMA attempted write to read-only page.                         |  |  |  |  |  |
| Invalid   | 1 = MMU Valid bit not set for DVMA access.                          |  |  |  |  |  |
| Size[1:0] | Copy of IU Size bits for failing writeback operation.               |  |  |  |  |  |

Error Acknowledges during DVMA are not reported to the IU. It is the responsibility of the DVMA master to report errors to the IU.

Reading the Asynchronous Error register clears it. SB\_Reset\_clears it. Any asynchronous error freezes both Async error registers until read (with the exception of the Multiple bit).

## Asynchronous Error Address Register

(Word access only)

| Size 1 | Size 0 | Invalid | Proterr | Timeout | DVMAEn | Zero | Zero | SBErr                                 | Multiple |
|--------|--------|---------|---------|---------|--------|------|------|---------------------------------------|----------|
| 9      |        | 7       |         |         |        |      |      |                                       | 0        |
|        |        |         |         |         |        |      |      | · · · · · · · · · · · · · · · · · · · | ·        |

| Table: 6.9 | Asynchronous Error | Register : ASI=2, | Address=0x6000 0008 | WORD ACCESS ONLY: |
|------------|--------------------|-------------------|---------------------|-------------------|
|------------|--------------------|-------------------|---------------------|-------------------|

Bits 31:10 are read-only zeros.

#### Asynchronous Error Data Registers

Data from the first asynchronous write error since the AER was last cleared is stored at ASI=2, Address 0x6000 0010 and 0x6000 0014. Word accesses only, please. These registers are cleared on reset. The data at 0x6000 0014 is only valid if the Size code is 11, indicating a doubleword store was taking place. Cleared to zeroes on power-on reset, software-reset, and watchdog reset.

## Cache Tags and Data

The Cache Tags are located in ASI 2 with the most significant four bits of the virtual address 8. Tags are unique every 32 bytes for 64K bytes (in other words, there is a 64 K Cache, which uses a 32-byte linesize; there are 2K tags). Each tag is 32 bits wide and should be accessed only as a full word. Tags are formatted as follows:

## Table: 6.10Cache Tags

| 31   | 25  | 21 | 20 | 19 | 18   | 15     | 1 0  |
|------|-----|----|----|----|------|--------|------|
| Zero | CID | W  | S  | V  | Zero | Tag ID | Zero |

Cache Data is located in ASI 2 with the most significant four bits of the virtual address = 0x9. It is significant for 64K Bytes.

## Serial Port Bypass

The Serial Port at ASI = 2, Address 0xF000 0000 is intended as an MMU bypass to allow the boot PROM to give messages even though the MMU and DRAM are not functioning or verified.

## Segment Map

ASI = 3 gives access to the MMU segment map. Only bits 18 through 29 of the address are significant in this address space. See the MMU section for details.

## Page Map

ASI = 4 gives access to the MMU page map. Only bits 12 through 29 are significant in this address space (bits 18 through 29 are mapped through the segment map). See the MMU section for details.

ን

## Flush Cache Segment

A write to an address in ASI = 0xC will cause the cache line corresponding to that address to be flushed (marked invalid) if:

• Cache Tag address (29:18) matches virtual address (29:18) and

• [that page is marked supervisor-only or the cache tag context matches the current context id]

#### Flush Cache Page

A write to an address in ASI = 0xD will cause the cache line corresponding to that address to be flushed (marked invalid) if:

• Cache Tag address (29:16) matches virtual address (29:16)

and

• [that page is marked supervisor-only or the cache tag context matches the current context id]

#### Add Hardware Cache Flushes!! Flush Cache Context

A write to an address in ASI = 0xE will cause the cache line corresponding to that address to be flushed (marked invalid) if:

The cache tag context matches the current context and the supervisor-only bit for that cache tag is *not* set. Cache context flushes will not invalidate supervisor-only pages. (All supervisor-only pages are assumed to be mapped throughout all contexts.)

#### 6.1.3 Device Space

Device Space corresponds to memory and peripherals. In general, memory is located in Type Zero space, on board and SBus IO devices are located in Type 1 space, and VME devices are located in type 2 or 3 space, (this space indicator is part of the MMU page table entry, and could be thought of as just an extension to the physical address).

### **Type Zero Space**

The CPU-2CE supports up to 64 MBytes of DRAM on-board, and up to 128 MBytes with the optional SRX board.

#### **Type One Space**

Type 1 Space contains on-board IO devices and SBus slots. It is distinguished from Type Zero space by the MMU Page Table Entry. By convention all addresses have the MS-Address bits are set to 1 (PA28-31.)

# Table: 6.11Type One Space

| Address                | Device                                            |
|------------------------|---------------------------------------------------|
| F000 0000              | Keyboard and Mouse serial ports                   |
| F100 0000              | TTYA and B serial ports                           |
| F200 0000              | TOD Clock and NVRAM                               |
| F300 0000              | Counter-Timer Registers                           |
| F400 0000              | Memory Error Register (Parity) (On-board memory)  |
| F400 0004              | Memory Control Register (On-board memory)         |
| F400 0008              | Memory Error Register (Parity) (Off-board memory) |
| F400 000C              | Memory Control Register (Off-board memory)        |
| F500 0000              | Interrupt Control Register                        |
| F600 0000              | EPROM                                             |
| F720 0000              | Floppy Controller                                 |
| F720 1000              | ISDN/Audio chip                                   |
| F740 0000              | Auxiliary IO register                             |
| F800 0000              | SBus Slot Zero (Onboard)*                         |
| FA00 0000              | SBus Slot One*                                    |
| FC00 0000              | SBus Slot Two*                                    |
| FE00 0000              | SBus Slot Three*                                  |
| * All Sbus Slots occup | y 25 bits of Address Space.                       |
|                        |                                                   |

# Serial Ports

The serial port controller used for both the Keyboard/Mouse and the general-purpose TTY serial ports is the Zilog 85C30 Serial Communications Controller. For further information see the Zilog datasheet. The sub-addresses for the SCC's are:

| F000 0000 | Mouse Control Port    |
|-----------|-----------------------|
| F000 0002 | Mouse Data Port       |
| F000 0004 | Keyboard Control Port |
| F000 0006 | Keyboard Data Port    |
| F100 0000 | TTY B Control Port    |
| F100 0002 | TTY B Data Port       |
| F100 0004 | TTY A Control Port    |
| F100 0006 | TTY A Data Port       |

• Interrupts occur at level 12.

• The serial ports use a 4.915 MHz clock as a base for baud rate generation.

• There is no need for software to provide timing loops between accesses to the serial ports. Hardware will guarantee the required recovery time of the SCCs.

### TOD/NVRAM

The Time-of-Day clock and Non-Volatile RAM is implemented in a Thomson Mostek MK48T08 RAM with the following address map:

Note: To insure proper SunOS bootup FORCE uses only 2 Kbytes of the 8 Kbyte chip. Through an invertor in a pal, FORCE modifies the base address to be the last 2 Kbytes of the NVRAM. A12:13 are inverted on the TOD.

| Table: 6.12 TOD/NVRAM |                         |  |  |
|-----------------------|-------------------------|--|--|
| F200 0000             | -NVRAM                  |  |  |
| F200 07F7             | Reserved, do not<br>use |  |  |
| F200 07F8             | TOD Control             |  |  |
| F200 07F9             | Seconds (00-59)         |  |  |
| F200 07FA             | Minutes (00-59)         |  |  |
| F200 07FB             | Hour (00-23)            |  |  |
| F200 07FC             | Day (01-07)             |  |  |
| F200 07FD             | Date (00-31)            |  |  |
| F200 07FE             | Month (01-12)           |  |  |
| F200 07FF             | Year (00-99)            |  |  |

## **Counter-Timer Registers**

Two 21-bit microsecond resolution counters can provide interrupts at levels 10 and 14. They are at the following addresses:

| Table: 6.13 Counters timers           |                            |  |  |  |
|---------------------------------------|----------------------------|--|--|--|
| F300 0000                             | Counter 0                  |  |  |  |
| F300 0004                             | Limit 0 Interrupt Level 10 |  |  |  |
| F300 0008                             | Counter 1                  |  |  |  |
| F300 000C Limit 1 Interrupt Level 14. |                            |  |  |  |

- Interrupts are enabled or disabled in the Interrupt Control Register.
- Each counter starts at a value of "one microsecond" (0x400)

• When a counter reaches the value in its corresponding Limit register the Limit bit is set (L) and an interrupt (if enabled) is generated.

- The Limit registers initialize on reset to zero.
- Reading the Limit Register clears its L bit. Reading the Counter does not.
- Read counters as a word to guarantee that they do not increment during the read.

## Memory Error Registers

The Parity Control/Status register for the bottom 64 MBytes of DRAM is at F400 0000 in Type 1 space. The Parity Control/Status register for the top 64 MBytes of DRAM is at F400 0008 in Type 1 space:

| Table: 6.14 PError                                 |  |  |  |
|----------------------------------------------------|--|--|--|
| Perror Set on any parity error                     |  |  |  |
| 2ndError Set when parity error occurs and PError=1 |  |  |  |
| PTest Set to invert parity for testing.            |  |  |  |
| PEnable Set to enable checking                     |  |  |  |
| Perr[24-0] Set to indicate which byte failed.      |  |  |  |

The bits that indicate errors (Perror, 2ndError, Perrn) are cleared when the register is read. All bits are cleared on reset.

The Perrn bits have the same meaning as on older hardware (note that early older documentation was incorrect).

In word-parity mode, all four Perr bits will be set on any parity error.

#### **Memory Control Register**

The RAM+ control register is at 0xF4000004 in Type 1 space for the on-board DRAM and at 0xF400 000C in Type 1 space for off-board DRAM:

## Table: 6.15 Type 1 Space for off Board DRAM

| - 5 |        |        |        |        |        |        |         |          |
|-----|--------|--------|--------|--------|--------|--------|---------|----------|
|     | Unused | Unused | Unused | Unused | Unused | Unused | Dis Ref | Parity33 |
|     | 7      |        |        |        |        |        |         | 0        |

Dis Ref when set will stop refresh. This is for manufacturing test only.

Parity when set will use word-wide parity. It should remain cleared on CPU-2CE.

The Memory Control Register is cleared on Reset.

## **Interrupt Control Register**

The Interrupt Control Register is at F500 0000:

| Table: 6.16 Interrupt Control Register     |                            |  |  |  |
|--------------------------------------------|----------------------------|--|--|--|
| Enx Enable Interrupt Level x.              |                            |  |  |  |
| SWLx                                       | Force interrupt at Level x |  |  |  |
| Master Enable Set to allow any interrupts. |                            |  |  |  |

Clear bit 0, the Master Enable bit, to reset level 15 interrupts.

## **Floppy Controller**

The Intel 82072 Floppy Disk Controller is at F720 0000. It should be accessed in byte mode only. See the Intel datasheet for details of the register bits.

| F720 0000 | MSR (reads), DRS (writes) |
|-----------|---------------------------|
| F720 0001 | FIFO (reads and writes)   |

#### ISDN/Audio

The AMD 79C30 ISDN/Audio chip is at F720 1000. See the AMD datasheet for details. The ISDN portions of this chip are not utilized on CPU-2CE hardware or software.

## Aux I/O Register

The Auxiliary I/O register is at F740 0003 as a byte-only device. It has eight bits which may be used as inputs or outputs. Only six of these bits are used on the CPU-2CE. To use a bit as an input, it should be written as a "1" (it will read back as whatever value is driven onto it). This register is set to all 1's on reset.

11

# Table: 6.17 Aux I/O Register

| LED      | 1 = Front-panel LED On                                                                                                                                                                   |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Eject    | Transition from 0 to 1 to 0 ejects floppy. DriveSel must be set for eject to take place.                                                                                                 |
| тс       | 1 = Terminal Count. Must be driven for specific amount of time,<br>dependent upon floppy data rate. (See 82072 Users Manual for timing<br>constraints.)                                  |
| DriveSel | 1 = Select Floppy Drive.                                                                                                                                                                 |
| DiskChg  | (Input) Reads as one if drive is selected and no disk is present in the drive.                                                                                                           |
| Density  | (Input) Reads as one if floppy drive detects high-density floppy inserted.<br>(Current floppy drives do not support this signal; software must determine<br>density by trial and error.) |

# 6.2 Memory Management

The CPU-2CE provides a standard two-level MMU, identical to older designs except for sizes and performance.

- 16 MMU contexts (up from 8 on older)
- 30 Virtual Address bits in
- 32 Physical Address bits out to VME (28 bits to SBus and onboard devices)
- 256 Page Map Entry Groups (up from 128 on older)
- 4K Byte Page Size
- 256K Byte Segment Size

Figure: 6.1 Illustration Memory Management



i

# 6.2.1 Address Translation

As long as the system is not in Boot state (system enable register bit 7 not zero), all virtual addresses put out by the CPU in Supervisor and User Instruction and Data spaces are translated through the MMU. The upper 12 significant virtual address lines, along with the current context number, select one of 256 Page Map Entry Groups. This value, along with the lower 6 significant virtual address lines, selects a Page Map Entry which returns a Physical Address and the permission and statistics bits for the 4KByte page.

Exception: The lower address bits of EPROM accesses are not translated. The EPROM should always be mapped into contiguous virtual memory locations on a EPROM-sized boundary.

# 6.2.2 Modifying the MMU

In order to store a new value into the Segment map, simply write a byte to ASI=3. Only virtual address bits [29:18] along with the current context ID [3:0] are significant for this operation. PMEG values may be read as well. Use only byte loads and stores for segment map operations.

In order to store a new value into the Page map, the segment map must first have been initialized for the high-order address bits to choose a Page Map Entry Group in the current context. Then a *word* may be stored to ASI=4 to set the page map value:

Changing the MMU for a virtual address which was marked cacheable requires that the cache be flushed of that address range.

## 6.2.3 MMU Protection Criteria

All Device Space accesses (when the system is not in Boot mode) are subject to address translation (with the exception of the EPROM, as listed above), and are subject to MMU protection checks. These checks basically validate whether a given access is allowed for the current user. Using the bits in the Page Map entry given above, access is allowed if:

- The V bit is set and
- The S bit is cleared or the CPU is in Supervisor state and
- The W bit is set or this is a read operation (not a store and not a ldst).

• The X bit in the Page Map entry is set to cause this page to not be cached.

• The Type bits are effectively extensions to the physical address; only values of 0 and 1 are used on the CPU-2CE.

0- Onboard memory 1- Onboard I/O 2- VME D16 3- VME D32

• The A bit is set if this page has been accessed. The bit is cleared by software and used in least-recently-used algorithms.

7

• The M bit is set if this page has been modified.

In addition, the most significant three virtual address bits must all be one or all be zero, or an error will be reported in the AER as a DVMA Timeout, when accessing Type 0 or 1 Space.

The statistics bits are not modified in the event of any protection or illegal address violations. Accesses which result in Error Ack or timeouts from the SBus will have modified their MMU entries as if the access had been successful.

All DVMA activity takes place in Context Zero as Supervisor.

# 6.3 Programming LED's

| Bit # | RO                              | WO                                   |
|-------|---------------------------------|--------------------------------------|
| 31    | SW3 bit 3                       | L11                                  |
| 30    | SW2 bit 2                       | L10                                  |
| 29    | SW1 bit 1                       | L21                                  |
| 28    | SW0 bit 0                       | L20                                  |
| 27    | VME Sysfail* from S4VME<br>asic | R15*                                 |
| 26    | P1_Sysfail* (from p1)           | Init Enable<br>Sysfail and Abort SW1 |
| 25    | abort                           | MAR Enable for 32 Bit Mode           |
| 24    | N/C (undefined)                 |                                      |

# Table: 6.18 LED/SW3 Register (Longword access only)

Table is from page 17 of the schematics. L is LED

# 6.3.1 SPARC CPU-2CE LED Programming Example

Programming examples for CPU-2CE front panel LED's

```
#include <asm linkage.h>
#include <cpu_addrs.h>
#include <mmu.h>
#include <scc.h>
#include <map.h>
#include <misc.h>
#include <ce_misc.h>(SEE BELOW FOR EXAMPLE OF THIS FILE)
extern
             map_memory();
             unmap memory();
extern
                                               /* hold current value of ledsw */
static byte shadow_reg;
/*
 *
             Set and leave LEDs continuously on.
 */
set leds (pattern)
byte pattern;
             byte *ledsw = (byte*)LEDSW_LOC;
             byte
                      temp;
             map_memory(ledsw, LEDSW_PADDR, VW1_ATTRIBUTES, PSIZE);
             shadow_reg &= LEDMASK; /* clear LED field */
             shadow_reg |= pattern;
             shadow_reg &= ~RUNMODE;
ledsw[0] = shadow_reg;
                                                   /* enable LED function */
             unmap memory (ledsw, PSIZE);
ł
/*
 *
         Set Run-Mode
 */
set runmode()
ł
             byte
                    *ledsw = (byte*)LEDSW_LOC;
             byte
                      temp;
             map_memory(ledsw, LEDSW PADDR, VW1 ATTRIBUTES, PSIZE);
             shadow_reg != RUNMODE;
ledsw[0] = shadow_reg;
             unmap_memory(ledsw, PSIZE);
}
/*
 *
             Read the rotary switch.
 */
byte read_sw()
             byte
                   *ledsw = (byte*)LEDSW_LOC;
             byte
                      temp;
             map_memory(ledsw, LEDSW_PADDR, VW1_ATTRIBUTES, PSIZE);
temp = ~(ledsw[0] >> 4);
             unmap_memory(ledsw, PSIZE);
             return
                          (temp & Oxf);
}
```

```
6.3.1.1 Example of the ce-misc.h file
* file: ce_misc.h
/* CPU-2CE front panel LED definitions */
#define LEDSW LOC 0x1fa00000
#define LEDSW_PADDR
                        0xff000000
                                        /* Slot 3, offset +0x1000000 */
                        0x0f
                                         /* LED field mask */
#define LEDMASK
#define INTENABLE
                                         /* Interrupt enable: Set/Clear IL15 */
                        0x02
                        0x08
                                         /* Run-mode: enable LEDS */
#define RUNMODE
#define DIAGMODE
                        0x00
                                         /* Diagnostic mode: disable LEDS */
6.4 Additional Forth Commands for LEDs/Hexswitch and (Optional Feature Flash
EEprom)
These are added to the CPU-2CE OBP:
  1. LEDS/HXSW:
                        ( -- )
     a. set-diagmode
        Let user changes mode to DIAGNOSTIC MODE or turn off RUN MODE.
                       ( -- )
    b. set-runmode
        Let user changes mode to RUN MODE.
     c. .hexswitch
                        ( -- value )
       Display value of on board hexswitch.
     d. leds!
                        (value -- )
        Set color combination for front panel LEDs. Bit combination
        for LEDS is as follows (in Hex):
             00 : Red 01 : Green 10 : Yellow 11 : Blank
       Example:
           Value = LED2 LED1
                             00 --> 0x0 --> RED RED
                        00
                                                       ( will generate sysfail
                         01 --> 0x1 --> RED GREEN
                    00
                         01 --> 0x5
11 --> 0xF
                                      --> GREEN GREEN
--> BLANK BLANK
                    01
                    11
     e. .leds
                         ( -- value )
        Display value of front panel LEDS.
     f. p2led-on
                         ( -- )
        Turn on P2 LED.
     g. p2led-off
                         ( -- )
        Turn off P2 LED.
  2. FLASH EEPROM:
     j. erase-flash
                         (--)
        Erase Flash EEPROM.
     k. burn-flash
                         ( bvadr size -- )
            Given the virtual address of the buffer and the size in-byte of the
            user program, this command will burn that program into the Flash
            EEPROM.
```

Section 7

# VME

# 7.0 VMEbus Interface

# 7.1 Features of the SPARC CPU-2CE VMEbus Interface

The features of the SPARC CPU-2CE VMEbus interface are listed below:

- A32/A24/A16 Master (Sun-4 VME Device) and A24/A32 Slave DVMA device as SBus DMA device
- Single-level and round-robin arbitration with bus arbiter timer
- VME Interrupt Handler with IACK Daisy Chain Driver
- Clock driver
- System resetter
- Full 4-gigabyte VME addressing with mapping register
- Simple user-setup provided, only one jumper is required (slot one). All other options are selected through register settings, stored in EEPROM.
- A special loopback cycle is provided to enable stand-alone testing of the interface.
- Watchdog Timer for VME System Bus which issues a VMEbus error.
- Fair Requester option provides all VME Masters along the bus grant daisy chain with equal access to the VMEbus, independent of the Master's slot location.
- Programmable Mailbox Interrupt Level
- Adjustable Rerun Counter allows for longer rerun intervals during VME access
- VME Interrupt Monitor Register provides ability to monitor VME Interrupt lines in real time
- Multiprocessing support with Mail Box Interrupts, programmable slave base address ranges, true Read Modify Write (RMW) to local memory and to shared VME resource with the use of the VME Bus Locker
- VME DVMA can be disabled via the DVMA Disable Bit. This can be done without affecting the SPARC CPU-2CE's Ethernet or SCSI ports.
- Bus Locker provides the ability to perform Read-Modify-Write (RMW) cycles on the VMEbus.

All of the features listed above (except Watchdog Timer) require SunOS 4.1.1 (or newer). Each of the features is optional in that each can be enabled or disabled.

The Watchdog Timer feature works with any SPARC CPU-2CE-compatible release of SunOS and is enabled when the CPU is configured as a Slot 1 Controller.

The VME Chip includes all VME logic on a 7000 gate CMOS LMA9K 1.5 m-second Gate Array. Address and data paths are external, using 29FCT521, 29FCT52, 29821 and 29FCT821 registers. Decoding of VME address A(31:24) is done externally using AS27 gates. Decoding of Physical address PA(19:16) is done externally using an F20. All VMEbus outputs are driven through bipolar drivers using AS641, LS04 and F125.

# 7.2 VMEbus Basics - An Introduction

The VMEbus is an asynchronous 32 bit bus, with multi master, multi level arbitration specifying Single Cycles, Block Mode Cycles and Read-Modify-Write Cycles. Table 7.1 defines certain conceptual logical units.

| Concept                                                                                                                                                                                                                                           | Definition                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| Master                                                                                                                                                                                                                                            | accesses Slaves.                                                                                         |
| Slave                                                                                                                                                                                                                                             | responds with [DTACK/BERR] to Master.                                                                    |
| BUS Requester                                                                                                                                                                                                                                     | Requests and keeps the bus on order from a Master.                                                       |
| BUS ARBITERS                                                                                                                                                                                                                                      | Grants bus to Requesters through [BG] daisy chain. Must be in slot 1.                                    |
| Interrupter                                                                                                                                                                                                                                       | Interrupts bus, responds to Interrupt handlers<br>with [DTACK/BERR] and supplies an Interrupt<br>Vector. |
| IACK DAISY CHAIN Drive                                                                                                                                                                                                                            | Drives [IACKIN/IACKOUT] chain when<br>[IACK] and [DS(1:0)] are asserted. Must be in<br>slot 1.           |
| SYS Clock Driver                                                                                                                                                                                                                                  | Drives [SYSCLK]. Must be in slot 1.                                                                      |
| Sysfail is generated by writing red red to the LED port. See the LED programming example.                                                                                                                                                         | Asserts Sysfail                                                                                          |
| An on card Voltage Supervisor asserts<br>SYSRESET for a minimum of 200 ms after<br>+5V DC has reached 4.5 Volts, if the slot 1<br>jumper is inserted. The ACFAILL is not driven<br>or monitored. Incoming SYSRESET generates<br>an on-card reset. | Asserts [SYSRESET].                                                                                      |

| Table: 7.1 | VME | Concept | Definitions |
|------------|-----|---------|-------------|
|------------|-----|---------|-------------|

## 7.3 VME Performance

The timing for the VMEbus interface is as follows:

- 8 Bit Transfers 1.6 MB per second
- 16 Bit Transfers 3.2 MB per second
- 32 Bit Transfers 6.4 MB per second

The VME Gate Array logic meets the Sbus and VMEbus specifications at a 20 MHz clock, correlating to a 50 ns clock cycle.

Bus arbitration for other VMEbus masters takes place faster by using the Early Release feature.

NOTE: These numbers are given only as a way to describe the SPARC CPU-2CE CPU performance. The overall bandwidth depends on the other card's response time, the application code, amount of other tasks running concurrently, other concurrent DMA activity, cache hit/miss ratio, etc. These figures should NOT be expected in a real world system.

# 7.4 VME Addresses

Two Address Modifier bits (AM[5:4]) define three address spaces.

Table 7.2 shows how these address spaces are defined.

| Table: 7.2 VME Addresses |                                                   |                           |  |  |  |  |
|--------------------------|---------------------------------------------------|---------------------------|--|--|--|--|
| Concept                  | Definition                                        | Address Modifier Bits 5:4 |  |  |  |  |
| A16                      | 16 address bits are needed.<br>Can address 64 KB. | 10                        |  |  |  |  |
| A24                      | 24 address bits are needed.<br>Can address 16 MB. | 11                        |  |  |  |  |
| Ă32                      | 32 address bits are needed.<br>Can address 4 GB.  | 00                        |  |  |  |  |

Three Address modifier bits (AM[2:0]) indicate privilege and type of access: Supervisor, Non-Privileged, Program Data or Block Transfer access. Data transfers can be D32/D16/D8 (quad-byte, double-byte or single-byte size). Unaligned transfer means that a quad-byte or a double-byte transfer takes place on a non-even boundary. Unaligned transfers are not supported by the SPARC CPU-2CE card. Table 7.3 lists the supported VME address spaces.

| Addresses | Comments                                                        |
|-----------|-----------------------------------------------------------------|
| A16       | Master accesses are possible.                                   |
| A24       | Master accesses are possible.                                   |
| A32       | Master accesses are possible.                                   |
| D16       | Master accesses are possible.                                   |
| D32       | Master accesses are possible.                                   |
| A16       | Mailbox cycles are monitored<br>and can generate the interrupt. |
| D8 (only) | Mailbox cycles are monitored<br>and can generate the interrupt. |
| A24       | Slave cycles are supported.                                     |
| A32       | Slave cycles are supported.                                     |
| D8        | Slave cycles are supported.                                     |
| D16       | Slave cycles are supported.                                     |
| D32       | Slave cycles are supported.                                     |

| Table: 7.3 | VME | Address | Spaces |
|------------|-----|---------|--------|
|------------|-----|---------|--------|

## 7.5 VME Implementation

The VME Interface adheres to the VMEbus Specification Rev C.1. A later version of the specification, released by ANSI, the ANSI/IEEE 1014-1987, has changed some optional features to mandatory. The new rules are: 2.61-68 and 4.49. The SPARC CPU-2CE VME Interface follows all these new rules except for 2.67 requiring ALL D32 slaves to include Unaligned Transfer capability. The following VMEbus features are implemented:

- A 300 micro-second VMEbus timer. Master cycles time out after 300 micro-second generating a Bus Error on VMEbus. This is with onboard master setup in slot 1.
- Single-level VMEbus arbitration (SGL) and round-robin arbitration (RRS).
- Read-Modify-Write accesses to local and VME memory are supported via the bus locker.
- Unaligned transfers are not implemented nor supported. Unaligned accesses get a Bus error returned. Unaligned transfers are 32-bit accesses not to address (1:0)=00 and 16-bit accesses not to address (0)=0. See the ANSI/IEEE change described above.

FORCE COMPUTERS

- Address only cycles are not decoded, an active data strobe is required for the start of any DVMA access.
- The VME Interface allow Address pipe-lining during Slave accesses, but do not utilize the function on VME Master cycles.
- Early release of bus is possible. Other masters can arbitrate getting bus mastership while VME Master access is finishing (Address Strobe still asserted). The VME Interface is also prepared for other cards early release of the bus, by awaiting the negation of the Address Strobe.
  - The VME Interface requests VME mastership on bus level 3 as an ROR (Release On Request).
  - Bus Clear is not monitored.
- An Interrupt handler that can serve any of the seven interrupts is available. A selection of which levels to serve is done by programming a SW register. The Interrupt handler is a D08(0), handling only 8-bit interrupt vectors.
- No Interrupter function is provided. Signaling between CPU cards in multiprocessor configurations is done through the Mail Box Interrupt.
- An IACK Daisy Chain function is provided when the card is in slot one.
- A System Clock Driver is active, if the card is in slot one.
- No Serial Clock Driver is implemented.
- An on card Voltage Supervisor asserts SYSRESET for a minimum of 200 ms after +5V
   DC has reached 4.5 Volts, if the slot 1 jumper is inserted. The ACFAILL is not driven or monitored. Incoming SYSRESET generates an on-card reset.
- Sysfail is generated on the bus by writing red red to LEDs.

#### 7.6 Major VME Register Groups

This section lists the major groups of VME registers. The registers can be divided into the following groups:

1. Registers set on system initialization, replacing card jumpers:

Interrupt Enable Register.

Interrupts handled.

Arbitration mode.

2. Registers used for multi-processing or co-processing:

Interrupt Monitor Register

Mailbox Interrupt Register

Rerun/Mailbox Level Register

Slave Map Register (also replacing jumper).

# 3. Others:

A32 VME Address mapping.

Move 512 MB window.

Enable diagnostic loop back.

Slave Map register bit0.

Enable Block Mode transfers.

Table 7.4 lists the VME registers, their physical base, and size.

| Name                          | Туре | Physical<br>Base | Size              |
|-------------------------------|------|------------------|-------------------|
| VME Bus Locker                | 1    | 0xEFE00000       | byte              |
| VME IACK cycle                | 1    | 0xEFE00001       | byte A[3:1], A0=1 |
| Mail Box Register             | 1    | 0xEFE00010       | byte              |
| VME Interrupt Enable Register | 1    | 0xEFE00014       | byte              |
| A32MAP Register               | 1    | 0xEFE00018       | byte              |
| Slave Map Register            | 1    | 0xEFE0001C       | byte              |
| Rerun/Mailbox Level Register  | 1    | 0xEFE00008       | byte              |
| Interrupt Monitor Register    | 1    | 0xEFE00004       | byte              |

Table: 7.4 VME Registers

## 7.6.1 Accesses To Byte Registers

A byte access to a register involves a data transaction on the eight most significant data lines (D[31:24]). The information on the rest of the data lines (D[23:0]) is ignored. This applies to all byte register accesses listed in this chapter.

# 7.7 Master Interface

In compatibility mode a full 32-bit Master Interface is provided. Complete mapping of 512 MB is possible all the time, but this 512 MB window can be moved through all 4 GB through a VME Mapping register.

In enhanced mode the additional MMU address bits are supplied to the VMEbus allowing complete access to any addresses on the VMEbus. No window limitations exist.

A32, A24, A16 Address Modes, D32, D16, D8(EO) Data Sizes are supported.

# Master Cycles (RMW) Atomic load-store

On Master cycles atomic load-store cycles are implemented according to the VME spec. The VME data strobe asserts two times as the VME address strobe is held asserted. This differs from other Sun cards, where instead the ownership of VME is kept while a read and a write takes place. The problem with this is that if the access is to a card with several devices competing for an on-card bus, there is no way this card can recognize the access as a RMW. For example: a disk card with multiple on card devices would not be able to prevent a shared resource to be stolen in between what looks like a standard Read and Write even though the VMEbus is locked.

# **Block Mode Transfers**

Block mode transfers are not supported. (They are only supported by the Slave interface.)

# Unaligned Transfers

Unaligned transfers (UAT) are not supported. The following access types are not supported and result in a bus error timeout:

- 16-bit access to base address plus one or three
  24-bit access
  32-bit access to base address plus one, two, or three
- 32-bit access to type two space

The CPU-2CE can directly map 4 GB with software switch enabled.

# 7.7.1 A32 Map Register Base Location

This register can re-map VME Address bits A[31:29] to enable accesses to any 512 MByte range of VME addresses. Only 8-bit accesses should be used; 16- or 32-bit accesses are not acknowledged, resulting in a bus error time out. This register is only needed when operating the CPU-2CE in compatibility mode.

# 7.7.2 A32 Map Register Initialization

The register is cleared to zeroes on reset, thus mapping the 512 MB MMU mapping to 0-512 MB and disabling loopback mode.

Table 7.5 provides a breakdown of the A32 Map register. Table 7.6 provides a breakdown of the A32 Map register bits. Table 7.7 defines the functions of various bit values.

| Туре | Device Address | Device           | Physical Space |
|------|----------------|------------------|----------------|
| 1    | 0xEFE00018     | A32 Map Register | 1 byte         |

Table: 7.5 A32 Map Register

| 31 | 30          | 29    | 28 | 27 | 26 | 25 | 24    |
|----|-------------|-------|----|----|----|----|-------|
|    | E Master Ad | dress | 0  | 0  | 0  | 0  | LoopB |

Table: 7.6 A32 Map Register Address Bits

|       | Table: 7.7 A32 Map Registe           |                           |                |              |
|-------|--------------------------------------|---------------------------|----------------|--------------|
| Bit   | Range                                | Value                     | Range<br>Start | Range<br>End |
| 31:29 | 0x0 Maps VME Master Range to:        | 0x0000000-0x1<br>FFFFFF   | 0 MB           | 512 MB       |
| 31:29 | 0x1 Maps VME Master Range to:        | 0x2000000-0x3<br>FFFFFFF  | 512 MB         | 1 MB         |
| 31:29 | 0x2 Maps VME Master Range to:        | 0x40000000-0x5<br>FFFFFFF | 1 GB           | 1.5 GB       |
| 31:29 | 0x3 Maps VME Master Range to:        | 0x6000000-0x7<br>FFFFFFF  | 1.5 GB         | 2 GB         |
| 31:29 | 0x4 Maps VME Master Range to:        | 0x8000000-0x9<br>FFFFFF   | 2 GB           | 2.5 GB       |
| 31:29 | 0x5 Maps VME Master Range to:        | 0xA0000000-0xB<br>FFFFFF  | 2.5 GB         | 3 GB         |
| 31:29 | 0x6 Maps VME Master Range to:        | 0xC0000000-0xD<br>FFFFFF  | 3 GB           | 3.5 GB       |
| 31:29 | 0x7 Maps VME Master Range to:        | 0xE0000000-0xF<br>FFFFFF  | 3.5 GB         | 4 GB         |
| 28:25 | These bits are not used, ar          | nd always read back a     | s 0.           |              |
| 24    | This bit enables the VME loopback mo | de (LoopB), used for      | diagnostics o  | nly.         |

# Table: 7.7 A32 Map Register Bit Definitions

## 7.7.3 VME Registers Programming Example

The following code fragment shows how to handle a VME interrupt. The system interrupt handler, when it determines that an interrupt originates on an IU level which corresponds to a VME interrupt, calls one of the entry points defined below (\_vmelevel1-7). We then attempt to obtain the actual VME vector by reading the VME IACK register appropriate to our VME interrupt level. If the vector obtained is a valid VME vector, we use the vector as an index into the table "vme\_vector." "Vme\_vector" is a table of pointers to interrupt handlers for various VME devices.

```
* Handle the 7 levels of VME interrupts:
                  Read the VME IACK register appropriate to
                  the VME level. This will:
 ٠

    Perform an interrupt acknowledge cycle
    Get the VME vector of the interrupting

 *
 •
                                device.
 */
                           _vmelevel1, _vmelevel2, _vmelevel3
_vmelevel4, _vmelevel5, _vmelevel6
_vmelevel7
                  .globl
                  .globl
vmelevel1:
                           VME_IACK1, %g1
_vme_read_vector
                                                       ! %g1 = address of IACK register
                  set
                  Ъ
                                                       ! go read the VME vector
                  nop
vmelevel2:
                           VME_IACK2, %g1
                  set
                                                       ! %g1 = address of IACK register
                           _vme_read_vector
                                                       ! go read the VME vector
                  h
                  nop
vmelevel3:
                  set
                           VME IACK3, %gl
                                                       ! %g1 = address of IACK register
                           _vme_read_vector
                                                       ! go read the VME vector
                  nop
vmelevel4:
                           VME_IACK4, %g1
_vme_read_vector
                  set
                                                       ! %gl = address of IACK register
                  ь
                                                       ! go read the VME vector
                  nop
_vmelevel5:
                           VME_IACK5, %g1
                  set
                                                       ! %gl = address of IACK register
                  ь
                           _vme_read_vector
                                                       ! go read the VME vector
                  nop
vmelevel7:
                  set
                           VME_IACK7, %g1
                                                       ! %g1 = address of IACK register
                  ь
                           _vme_read_vector
                                                       ! go read the VME vector
                  nop
/*
 * This entry is called directly from interrupt.
vmelevel6:
                           VME_IACK6, %g1
                  set
                                                       ! %g1 = address of IACK register
                  ь
                           _vme_read_vector
                                                       ! go read the VME vector
                  nop
 * VME interrupt. Do vectoring.
 * The VME vector is read off the VME bus. If this fails (data fault),
* _trap will check the PC of the fault and jump to _spurious.
 * The vmelevel# code sets up %gl to contain the address of the 
* appropriate VME IACK register before it branches here.
 */
                  .global
                                     _vme_read_vector
#define
                  VEC MAX
                                              255
#define
                  VEC MIN
                                              64
_vme_read_vector:
                           [%g1], %16
%16, VEC_MAX
                  ldub
                                                       ! read vector #, acknowledge int.
                  cmp
                                                       ! check vector limits
                           spurious_vme
%16, VEC_MIN,
                  bg
                                            %q3
                  subcc
                                                       ! normalize vector
                  Ы
                           spurious_vme
```

! scale for interrupt counting ! scale vector **s**11 **s**11 ! per-device interrupt counts table
! interrupt count set 1d ! table of interrupt vectors ! count interrupt set vme\_vector, %g2 %g1 %g2, {%g5 + %g4} [%g2 + %g3], %g1 %g2, 4, %g2 [%g2 + %g3], %o0 %g1 inc 1 and store result st 1 get handler address 1d get menuter address 1 generate address of arg ptr 1 delay slot, get arg ptr 1 call handler 1 call bandler add 14 **ca**11 ld [\$00], \$00 1 read arg ptr b,a int\_rtt
/\* end \_vme\_read\_vector \*/
/\* ! restore previous stack pointer 1+ \* Vme vectors are compatible with the sun3 family in which \* there were possible valid vectors from 64 to 255 inclusive. \* This requires 192 vectors, each vector is two words long \* the first word being the interrupt routine address and the \* second word is the arg. \* Vectors 0xC8-0xFF (200-255) are reserved for customer use. +/ 1\* \* The vme vectoring uses the following table of routines \* and arguments. The values for the vectors in the following \* table are loaded by autoconf at boot time. define ERRV .word spurious, 0 "data" .seg .align 4 vme\_vector I vector numbers .clobal \_wme\_vector: ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV sc0 | sc? xdc0 | xdc1 | xdc2 | xdc3 xyc0 | xyc1 | xyc? future disk controllers future disk controllers ! 0x40 - 0x43! 0x44 - 0x470x48 - 0x4B1 ERRV; ERRV; ERRV; ERRV 1 0x4C - 0x4F 10x50 - 0x53ERRV; ERRV; ERRV; ERRV 0x54 - 0x57ERRV; ERRV; ERRV; ERRV 1 future disk controllers ERRV; ERRV; 0x58 -ERRV; ERRV; ERRV; ERRV; ERRV 0x5B future disk controllers future disk controllers 1 ERRV 0x5C - 0x5F 0x60 - 0x63 tm0 | tm1 | tm? xtc0 | xtc1 | xtc? ERRV; ERRV; ERRV; ERRV 1 0x64 - 0x67 ERRV; ERRV; ERRV; ERRV 1 ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV 0x68 - 0x6B future tape controllers future tape controllers 1 0x6C - 0x6F ! 0x70 - 0x73ERRV; ERRV; ERRV; ERRV 1 ec? ERRV; ERRV; ERRV; ERRV 0x74 - 0x77ie0 | ie1 | ie? future ethernet devices future ethernet devices ERRV; ERRV; ERRV; ERRV 0x78 - 0x7B1 ERRV; ERRV; ERRV; ERRV 1  $0 \times 7C - 0 \times 7F$ ERRV; ERRV; ERRV; ERRV; ERRV; ERRV; ERRV  $0 \times 80 - 0 \times 83$ 1 vpc0 | vpc1 | vpc? vpcu | vpcu | tpcu | tpcu vp? mti0 | mti1 | mti2 | mti3 SunLink SCP (Systech DCP-8804) Sun-3 zs0 (8 even vectors) Sun-3 zs1 (8 odd vectors) Sun-3 zs1 (8 odd vectors) Sun-3 zs1 (8 odd vectors) 0x87 0x84 -ERRV 1 ERRV; ERRV; ERRV; 0x88 -ERRV 0x8B 1 ERRV; ERRV; ERRV; ERRV 0x8C - 0x8F 0x90 - 0x93 ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV 0x94 - 0x97١ ERRV; ERRV; ERRV; ERRV 0x98 - 0x9B 1 ERRV; ERRV; ERRV; 0x9C - 0x9F ERRV 1 ERRV; ERRV; ERRV; ERRV; ERRV; ERRV; 0xA0 - 0xA3 ERRV future serial 1 0xA4 -0xA7 pc0 | pc1 | pc2 | pc3 cg2 | future frame buffers gp1 | future graphics processors ERRV ERRV; ERRV; ERRV; OXA8 - OXAB ERRV ERRV; ERRV; ERRV; ERRV 1 OXAC - OXAF 0xB0 - 0xB3 ERRV; ERRV; ERRV; ERRV sky0 | 1 ? SunLink / channel attach (token bus) tbi0 | tbi1 | ? ERRV; ERRV; ERRV; ERRV; ERRV; ERRV; ERRV 0xB4 - 0xB7t 0xB8 -ERRV 0xBB 1 Reserved for Sun Reserved for Sun - OxBF ERRV; ERRV; ERRV; ERRV 0xBC 0xC0 - 0xC3 ERRV; ERRV; ERRV; ERRV Reserved for Sun Reserved for User Reserved for User ERRV; ERRV; ERRV; ERRV 0xC4 - 0xC7 1 ERRV; ERRV; ERRV; ERRV 0xC8 - 0xCB 1 ERRV; ERRV; ERRV; 0xCC - 0xCF ERRV 1 ERRV; ERRV; ERRV; ERRV; ERRV; ERRV; 0xD0 - 0xD3 ERRV 1 Reserved for User 0xD4 - 0xD7 ERRV Reserved for User Reserved for User Reserved for User 1 ERRV; ERRV; ERRV; ERRV 0xD8 - 0xDB 1 ERRV; ERRV; ERRV; ERRV 0xDC - 0xDF OxEO - OxE3 ERRV; ERRV; ERRV; ERRV Reserved for User ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV Reserved for User Reserved for User 1 0xE4 - 0xE7OxE8 - OxEB 1 ERRV; ERRV; ERRV OXEC - OXEF ERRV: Reserved for User 1 ERRV; 0xF0 -ERRV; ERRV; ERRV 0xF3 Reserved for User 1 Reserved for User Reserved for User ERRV; ERRV; ERRV; ERRV 0xF4 - 0xF71 ! 0xF8 - 0xFB ! 0xFC - 0xFF ERRV; ERRV; ERRV; ERRV ERRV; ERRV; ERRV; ERRV Reserved for User

FORCE COMPUTERS

-

# 7.8 Slave Interface

The slave interfaces operate in A32 and A24 address mode.

1 MB of memory is accessible, normally the lowest MB on VME, but this can be changed to be in the 1-16MB range to support multi-CPU card implementations. The address range is adjustable in 1MB steps.

Unaligned accesses to the Slave Interface range returns a Bus Error back to the external VME Master.

The address modifiers on VME are used to define Address mode (A32/A24/A16), privilege, and data/program/block-transfer access. The Slave decoder and Mail Box Interrupter monitors all address modifier bits with the exception of AM2, the access privilege bit.

All slave accesses as a DVMA device are set to supervisor mode, which is in accordance with the Sun-4 Architecture.

The 1 MB VME address space selected is always mapped onboard to the highest megabyte in the Virtual Address Space, again in accordance with the Sun-4 Architecture.

# 7.8.1 Slave Transfer Control

A bit in the cache System Enable Register can disable SDVMA and therefore all Slave cycles. If this bit is set, slave cycle can take place.

## 7.8.2 Slave Map Register

The address space for System DVMA accesses is 1 MB, normally the lowest Megabyte in accordance with the Sun-4 Architecture, but bits 27:24 can be used to re-map the SDVMA address space. The 1 MB address space on VME is mapped to the highest 1 MB within the Virtual Address space. During register accesses, only 8-bit accesses should be used. 16- or 32-bit accesses are not acknowledged, resulting in a bus error time out.

If a slave access occurs to a page within 1 MByte address space that does not have physical memory mapped to it then the VME BERR signal will be asserted. Therefore to properly utilize the slave feature, the programmer must insure that the slave map ...gister is properly set to the correct 1 MByte VME address range, and that the physical memory pages are mapped into the DVMA space where Slave accesses are expected.

NOTE: Enabling Slave accesses from VME gives any VMEbus Master access to the entire DVMA virtual address range. It is possible that erroneous accesses to this space will affect the operation of the SCSI and/or ethernet controllers since their buffers are kept within the DVMA space.

# 7.8.2.1 Slave Map Register Initialization

The register is reset to all zeroes on resets. Thus, the mapping defaults to 0-1MB and block mode transfers are disabled.

Tables 7.8 and 7.9 provide more information about the Slave Map Register and bit assignments. Table 7.10 defines the bit configurations.

| Туре | Device Address | Device             | Physical Space |
|------|----------------|--------------------|----------------|
| 1    | 0xEFE0001C     | Slave Map Register | 1 byte         |

Table: 7.8 Slave Map Register Address

|    |      |    |    | 8  |         |    |      |
|----|------|----|----|----|---------|----|------|
| 31 | 30   | 29 | 28 | 27 | 26      | 25 | 24   |
| 0  | DVMA | 0  | 0  | VM | E Slave |    | base |

Table: 7.9 Slave Map Register Address Bits

NOTE: The VME-4 gate array uses bit 30 of the Slave Map Register for DVMA. Bit 30, when set, disables any access to the local DVMA by other VME Masters and disables mailbox interrupts.

## 7.8.3 CPU-2CE Slave Memory Example

This example requires a CPU-2CE as a slave board and another VMEbus master that can generate an extended address modifier code. To setup a slave window on the CPU-2CE type the following lines of code.

30 fff00000 100000 map-segments <cr> 0 obmem fff00000 100000 map-pages <cr> 0 map-slave <cr>

The description of the above two lines is as follows:

<Segment Number> <Virtual Address> <Length> <Map Segments> <Physical Address> <obmem> <Virtual Address> <Length> <Map Pages>

Once these lines are typed in, it is possible to use the slave memory from a master at location 0 using an extended address modifier code.

To verify that the CPU-2CE received the correct data type the following on the slave.

fff00000 100 dump <cr>

FORCE COMPUTERS

| Bit   | Description                             | VMEbus Address        | Range<br>Start | Range<br>End |
|-------|-----------------------------------------|-----------------------|----------------|--------------|
| 31    | This bit is not used and must be 0.     |                       |                |              |
| 30    | This bit when set disables VME slave    | accesses              |                |              |
| 29:28 | This bit is not used and is read back a | us 0.                 |                |              |
| 27:24 | 0x0 Maps System DVMA Space to:          | 0x0000000-0x000FFFFF  | 0 MB           | 1 MB         |
| 27:24 | 0x1 Maps System DVMA Space to:          | 0x00100000-0x001FFFFF | 1 MB           | 2 MB         |
| 27:24 | 0x2 Maps System DVMA Space to:          | 0x00200000-0x002FFFFF | 2 MB           | 3 MB         |
| 27:24 | 0x3 Maps System DVMA Space to:          | 0x00300000-0x003FFFFF | 3 MB           | 4 MB         |
| 27:24 | 0x4 Maps System DVMA Space to:          | 0x00400000-0x004FFFFF | 4 MB           | 5 MB         |
| 27:24 | 0x5 Maps System DVMA Space to:          | 0x00500000-0x005FFFFF | 5 MB           | 6 MB         |
| 27:24 | 0x6 Maps System DVMA Space to:          | 0x00600000-0x006FFFFF | 6 MB           | 7 MB         |
| 27:24 | 0x7 Maps System DVMA Space to:          | 0x00700000-0x007FFFFF | 7 MB           | 8 MB         |
| 27:24 | 0x8 Maps System DVMA Space to:          | 0x00800000-0x008FFFFF | 8 MB           | 9 MB         |
| 27:24 | 0x9 Maps System DVMA Space to:          | 0x00900000-0x009FFFFF | 9 MB           | 10 MB        |
| 27:24 | 0xA Maps System DVMA Space to:          | 0x00A00000-0x00AFFFFF | 10 MB          | 11 MB        |
| 27:24 | 0xB Maps System DVMA Space to:          | 0x00B00000-0x00BFFFFF | 11 MB          | 12 MB        |
| 27:24 | 0xC Maps System DVMA Space to:          | 0x00C00000-0x00CFFFFF | 12 MB          | 13 MB        |
| 27:24 | 0xD Maps System DVMA Space to:          | 0x00D00000-0x00DFFFFF | 13 MB          | 14 MB        |
| 27:24 | OxE Maps System DVMA Space to:          | 0x00E00000-0x00EFFFFF | 14 MB          | 15 MB        |
| 27:24 | 0xF Maps System DVMA Space to:          | 0x00F00000-0x00FFFFFF | 15 MB          | 16 MB        |

| Table: 7.10 Slave Master | Register | Bit | Definitions |
|--------------------------|----------|-----|-------------|
|--------------------------|----------|-----|-------------|

# 7.9 Mail Box

A Mail Box interrupt function is provided to allow other devices to interrupt the SPARC CPU-2CE. This mail box detects accesses to the A16 address space to a location programmed in the mail box register.

No real memory is provided at this location, but the mail box responds with a VME DTACK, acknowledging the access and generate an on card interrupt Level 13 if the Enable bit is set. VME Address bits A(15:14, 3:1) are in the Mail Box Register. This corresponds to programming the location

to one of the eight 16-bit words in one of the four 16K blocks of the address range. Any VME A16 address space, 8-bit or 16-bit read or write to the location programmed into the Mail Box Register generates an on-card interrupt on level 13 if enabled. 32-bit wide accesses are not allowed and will not be acknowledged, resulting in a Bus Error Time out to the accessing VME Master.

Since the address mapping of the location monitor compares only the address bits A15, A14 and A3, A2, A1 (Bits A13 up to A4 are NOT compared at all), the location monitor address is mirrored 1023 times in the selected 16K range. The user is advised to use addresses with address bits A13 to A4 set to zero.

## 7.9.1 Mail Box Register Base Location

This register is used to program the VME address to be monitored and, if enabled, mailbox interrupts the IU via an on-card interrupt. Only 8-bit accesses to the register should be used, 16- or 32-bit accesses are not acknowledged, resulting in a bus error time out. For mail box cycles, the VME bus is only monitored for A16, D8 or D16 accesses.

## 7.9.1.1 Mail Box Register Initialization

All bits are initialized to zeroes.

Tables 7.11, 7.12, and 7.13 provide more information about the meaning of the Mail Box Register and its bits.

## Table: 7.11 Mail Box Register Address

| Туре | Device Address Space | Device            | Physical Space |  |
|------|----------------------|-------------------|----------------|--|
| 1    | 0xEFE00010           | Mail Box Register | 1 byte         |  |

## Table: 7.12 Mail Box Register Address Bits

| 31    | 30   | 29 | 28                   | 27 | 26                 | 25 | 24 |
|-------|------|----|----------------------|----|--------------------|----|----|
| I-fig | En I | 0  | Comp Address (15:14) |    | Comp Address (3:1) |    |    |

## 7.9.1.2 Mail Box Register Interrupt Level

SPARC CPU-2CEs have programmable interrupt levels of 2, 3, 5, 8, 9, 11, and 13.

Hardware

| Bit | Description                                                                                                                                                                            |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | This bit set indicates that a mailbox interrupt is pending.<br>A read of this register resets the interrupt on the trailing edge of the read pulse.<br>A write to this bit is ignored. |
| 30  | This bit set enables the mail box interrupt.                                                                                                                                           |
| 29  | This bit is ignored, and is read back as 0.                                                                                                                                            |
| 28  | Compared with VME Address Bit 15.                                                                                                                                                      |
| 27  | Compared with VME Address Bit 14.                                                                                                                                                      |
| 26  | Compared with VME Address Bit 3.                                                                                                                                                       |
| 25  | Compared with VME Address Bit 2.                                                                                                                                                       |
| 24  | Compared with VME Address Bit 1.                                                                                                                                                       |

## 7.10 Mailbox Interrupt Level - Rerun Length Register

This register sets the interrupt level that a mailbox interrupts on. A default Interrupt level uses pin MB\_IRQ (level 13 on SBus), but any of the VME interrupt lines, pins B\_IRQ*n*, could be used instead by setting the appropriate level. Only 8-bit accesses to the register should be used. Accesses of 16 or 32 bits are not acknowledged, resulting in a bus error time out.

By default, the Mailbox Interrupt level is set to level 13. On SPARC CPU-2CEs the Mailbox Interrupt register (bits 29:31) is used to set the interrupt level associated to the Mailbox interrupt. Then the user can program which Processor Interrupt will be generated when a Mailbox Interrupt is initiated.

| 31   | 30   | 29   | 28 | 27    | 26    | 25    | 24    |
|------|------|------|----|-------|-------|-------|-------|
| MB 2 | MB 1 | MB 0 |    | Rer 3 | Rer 2 | Rer 1 | Rer 0 |

Long VME Master cycles (more than 16 clocks) are normally interrupted and frozen. They will be run at a later time, letting other SBus masters access the bus. By increasing the value of the rerun counter, longer cycles are possible, increasing the chance of getting a VME slave Acknowledgement avoiding the delay of a rerun cycle.

On SPARC CPU-2CEs the VME gate array can be tuned to increase the VME system throughput using the Mailbox Interrupt level Rerun Register bits [28:24]. By increasing the rerun interval, you can reduce the number of reruns the IU has to perform before an acknowledge is generated by a VME slave, increasing VME system throughput.

By default, the rerun interval is set to 16 clocks. For example, it takes 18 clocks to get an acknowledge from a slave. If the rerun register is set to 3 (rerun interval is 19 clocks), the IU can finish a VME transfer with just one cycle. However, if the default setting is used (16 clocks), it may take at least 20 to 21 clock cycles (requiring two rerun cycles) to finish the transaction.

Initialization: All bits are initialized to zero.

| "Bits                                                                                                                                        | Note"                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits 31:29 = 0<br>Bits 31:29 = 1<br>Bits 31:29 = 2<br>Bits 31:29 = 3<br>Bits 31:29 = 4<br>Bits 31:29 = 5<br>Bits 31:29 = 6<br>Bits 31:29 = 7 | Mail box interrupt on pin MB_IRQ_ or _int13<br>Mail box interrupt on pin B_IRQ1_ or _int2<br>Mail box interrupt on pin B_IRQ2_ or _int3<br>Mail box interrupt on pin B_IRQ3_ or _int5<br>Mail box interrupt on pin B_IRQ4_ or _int8<br>Mail box interrupt on pin B_IRQ5_ or _int19<br>Mail box interrupt on pin B_IRQ6_ or _int11 |
| Bits 31:29 = 7<br>Bits 28:24 = 0<br>Bits 28:24 = 1<br>Bits 28:24 = 2<br>Bits 28:24 = 3<br>Bits 28:24 = 4                                     | Mail box interrupt on pin B_IRQ7_ or _int13<br>Default rerun, cycle 16 states<br>cycle 17 states<br>cycle 18 states<br>cycle 19 states<br>cycle 20 states                                                                                                                                                                         |
|                                                                                                                                              | cycle 47 states                                                                                                                                                                                                                                                                                                                   |

#### 7.11 Bus Locker

÷.

A bus lock function provides a way to enable the CPU to do an atomic Read-Modify-Write (RMW) to its on-board memory without being interrupted by an incoming RMW from another VME Master. This function is only used when the card is running together with one or more external CPU cards (multiprocessing). In these cases, message passing is done through shared memory locations that need to be accessed in a defined way.

The bus locker is used to lock the VMEbus before a VME RMW cycle is executed to prevent a deadlock situation between two VME Masters. A deadlock situation can occur when two VME Masters want to perform RMW cycles at the same time.

#### 7.11.1 VME Bus Locker Register

In a non-multiprocessing application, this register should be left alone. When used, bit 24 of the register should ALWAYS be SET for each update, to guarantee a consistent bus arbitration behavior.

## 7.11.2 Initialization

All bits are initialized to 0's. Thus, the VME bus locker is inactive and does not affect the card's bus arbitration.

| Bit             | Description                                                                                                                                                               |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -31             | This bit indicates the VMEbus is owned.<br>No external VME card can access memory.<br>Bit is read only, a write to this bit is ignored.                                   |
| 30              | This bit is ignored, and is read back as 0.                                                                                                                               |
| 29              | This bit is ignored, and is read back as 0.                                                                                                                               |
| 28              | This bit is ignored, and is read back as 0.                                                                                                                               |
| 27              | This bit is ignored, and is read back as 0.                                                                                                                               |
| <sup>:</sup> 26 | This bit is ignored, and is read back as 0.                                                                                                                               |
| 25              | This bit initiates a VMEbus request.<br>Once owned, it is held.                                                                                                           |
| 24              | This bit enables the Bus request function.<br>It should only be set for multiprocessing applications.<br>If set, it should never be changed (unless system is restarted). |

## Table: 7.14 Bus Locker Register Bit Definitions

In multiprocessing applications, update the register at the system initialization time by writing 0x01 to the register. The procedure for accessing an on-card memory location is:

- 1. Disable all interrupts. (VME IACK cycles need to acquire control of VME.)
- 2. Request VMEbus locking by writing 0x3 to the register.
- 3. Read register and check bit 31 to until VMEbus is owned and locked.
- 4. Do Read-Modify-Write (RMW) (atomic Load-Store) to on-card memory.
- 5. Unlock VME by writing 0x1 to register.
- 6. Enable all interrupts.

NOTE: If the VME is not unlocked in time, other accesses might time out causing a system crash. Always unlock VME as soon as possible after the RMW is completed!

NOTE: VME interrupts must be disabled during the bus locking procedure to prevent potential deadlock, since VME IACK cycles requires access to VME. Interrupts could otherwise cause a deadlock situation if it happens while the bus is locked.

#### 7.12 Interrupt Handler

The interrupt handler can selectively support all interrupt levels. These are enabled through the VME Interrupt/Bus Arbiter register. Note that this register is a replacement for a jumper and should normally be fixed depending on the VME Interrupt handler configuration. Run-time enabling of the interrupts are normally done with the Interrupt Enable register, see the System Specification.

#### 7.12.1 Interrupt Enable/Bus Arbiter Mode Register

This register enables VME interrupts to be fed to the Interrupt logic in the S-4 MMU chip. Only 8-bit accesses should be used, 16- or 32-bit accesses are not acknowledged, resulting in a bus error time out. The Interrupt Enable Register can selectively enable all VME interrupt levels.

#### 7.12.1.1 Interrupt Enable Register Initialization

At initialization of the Interrupt Enable register, bits 31:25 are set and bit 24 is reset, enabling VMEbus interrupts and setting arbiter mode to single level arbitration (SGL). Tables 7-15, 7-16, and 7-17 provide more detailed information about the Interrupt Enable register.

NOTE: This register replaces on-card jumpers. Changes to this register should only be done at system initialization time, and should not be changed at a later time unless the system is restarted.

| Туре | Device Address | Device                        | Physical<br>Space |
|------|----------------|-------------------------------|-------------------|
| 1    | 0xEFE00014     | VME Interrupt Enable Register | 1 byte            |

| <b>Table: 7.15</b> | Interrupt | Enable | Register | Address |
|--------------------|-----------|--------|----------|---------|
|--------------------|-----------|--------|----------|---------|

| Bit | Description                                                        |
|-----|--------------------------------------------------------------------|
| 31  | This bit enables VME Interrupt 7/Sun-4 level 13 to Internal Logic. |
| 30  | This bit enables VME Interrupt 6/Sun-4 level 11 to Internal Logic. |
| 29  | This bit enables VME Interrupt 5/Sun-4 level 9 to Internal Logic.  |
| 28  | This bit enables VME Interrupt 4/Sun-4 level 8 to Internal Logic.  |
| 27  | This bit enables VME Interrupt 3/Sun-4 level 5 to Internal Logic.  |
| 26  | This bit enables VME Interrupt 2/Sun-4 level 3 to Internal Logic.  |
| 25  | This bit enables VME Interrupt 1/Sun-4 level 2 to Internal Logic.  |
| 24  | This bit enables FAIR Arbitration.                                 |

#### Table: 7.16 Interrupt Enable Register Bit Definitions

**FORCE COMPUTERS** 

NOTE: If VME interrupt level 7 or 6 is needed with VME there is a conflict of the floppy and audio ports interrupts. Either the audio or floppy driver must be commented out of the GENERIC.VME and GENERIC\_SMALL.VME to disable one. Remember to copy the files before modifying them. Search the GENERIC.VME and the GENERIC\_SMALL.VME files in the .conf directory for audioamd. Use the "#" pound symbol at the head of the line to comment out either the audio or fd line. Then rebuild the kernel. See the readme file in the .conf directory for further details.

NOTE: Enabling the bus arbiter function is done via a jumper (Slot 1 jumper).

## 7.13 Bus Requester

The Bus requester is an ROR requester. It releases the bus when other VME Masters/Requesters requests the bus. The SPARC CPU-2CE can only request on Bus Request level 3.

## 7.13.1 Bus Arbiter

A Single Level Arbiter (level 3) and a FAIR Arbiter are provided. Note that the arbiter should be enabled only if the card resides in slot 1. (Slot1 jumper.)

In arbitration mode, locked arbitration is detected and released by the arbiter after 3.3 ms. The Bus arbiter then drives BBSY active for the minimum period required by the VMEbus spec. This is to prevent requesters that in the mean time have decided to withdraw their requests to be able to do so. Note that a withdrawal of a VME Request normally is in violation of the VME Specification. (Rule 3.11).

## 7.14 Bus Time Out Period

There are two time out parameters in a VME cycle in addition to the On Board Bus arbitration timer: Rerun Time Out and Abort.

## 7.14.1 Rerun Time Out

If the time from the onboard Master cycle starts until the VME slave responds with a DTACK exceeds 1.6 us, the cycle is rerun by the IU so high-priority devices can get on the Sbus. In the mean time, the Master cycle and all output signals is frozen, ignoring any DTACK coming in. When the cycle is rerun, it is reconnected again.

## 7.14.2 Abort

With the onboard master setup in slot 1, two stages of the access exists. If the bus is not owned, it has to be acquired. Then the actual VMEbus cycle can start. A onboard or offboard Master cycle times out after 300 us. That means, the response time from another VME slave including the time for acquiring the bus must be less than 300 us.

If the VMEbus is not owned when an abort occurs, the bus requester keeps the VMEbus Request asserted even though the CPU cycles has been aborted. It then asserts a dummy Bus Busy (BBSY) when the Bus Grant is received. This is to comply with VME rule 3.11.

If the bus is owned when the abort takes place, a Bus Error is generated. This Bus Error would normally be generated by an accessed VME slave. This is to comply with VME rule 2.48.

## 7.15 VMEbus Watchdog Timer

The SPARC CPU-2CE has a VMEbus watchdog timer to monitor the operation of the VMEbus. This function prevents the VMEbus from being locked when a Master accesses a nonexisting VME slave and when the master doesn't have its own bus time-out circuit. A VMEbus error occurs if a DTACK is not generated within 300 microseconds (fixed) after a Data Strobe is asserted on the VMEbus. This is only active if Slot 1 function is enabled.

## 7.16 System Reset and the Reset Switch

On power up, the CPU card generates SYSRESET for a minimum of 200 ms, if the Slot1 jumper indicates the card resides in slot 1. Incoming VMEbus resets always generate an on-card reset.

## 7.16.1 Sources for a System Reset

The sources of a system reset are listed below:

- Power-on Reset.
- Watchdog Reset.
- Software Reset.

NOTE: When the SPARC CPU-2CE is reset, the "daisy-chained" VME signals are not passed on for the duration of the reset cycle, regardless of the SPARC CPU -2CE's configuration (Slot 1 or non-Slot1 device).

## "The Power-On Reset"

On power-up, the SPARC CPU-2CE Board generates a sysreset on the VMEbus for a minimum of 200 ms if it is configured as the slot 1 (VMEbus system controller) CPU. All SPARC CPU-2CEs on the VMEbus are reset in a system reset.

## "The Reset Switch"

The Reset is located on the front panel of the card, labeled Reset. The switch rests in a null position. When it is activated, a reset procedure is activated that is performed by the VME Gate Array. If the board is configured as the slot 1 CPU, a VMEbus reset will be generated to reset all other non-slot 1 SPARC CPU-2CEs. For additional information, see the chapter VMEbus Interface in this manual.

## "The Watchdog Reset"

The watchdog error is the result of a double bus error as detected by the SBus Controller on a SPARC CPU-2CE. If this occurs, an on-board reset is generated, and if the SPARC CPU-2CE is configured as the slot 1 controller, a VMEbus reset will be generated to reset all other non-slot 1 devices on the VMEbus.

### "The Software Reset"

As the name implies, this reset is generated by a SPARC CPU-2CE through a software trap which generates an on-board reset. If the board is configured as the slot 1 CPU, a VMEbus systest signal will be generated to reset all other non-slot 1 SPARC CPU-2CEs.

#### 7.17 Jumper

A jumper is used to set the VME Interface for slot 1. The default sets the board as a VME slot 1 card. If jumpered, the SPARC CPU-2CE operates as the VME system arbiter and slot 1 card.

Table 7.17 lists the function of the various jumper settings.

| Function                    | Slot 1 Position         | Not in Slot 1                      |  |
|-----------------------------|-------------------------|------------------------------------|--|
| VME System Clock            | Enabled.                | Tri-state.                         |  |
| VME IACK Daisy-chain Driver | Enabled.                | IACKIN drives IACKOUT.             |  |
| SYSRESET                    | Generates VME SYSRESET. | Does not generate VME<br>SYSRESET. |  |

#### Table: 7.17 Slot 1 Jumper & Functions

## 7.18 Programmable Register Settings

| Table: 7.18 Program | nable Register Settings |
|---------------------|-------------------------|
|---------------------|-------------------------|

| Register                          | Setting Definition                                                                                                         |  |  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|
| VME Interrupt Handler<br>Register | Defines which interrupt levels to handle.<br>Defines what type of VME Bus arbiter (only if the card resides<br>in slot 1). |  |  |
| A32 Map Register                  | Defines where to map the CPU Master Address Space of 512 MB.                                                               |  |  |

## 7.19 VME Interrupt Monitor Register

SPARC CPU-2CE features a VMEbus Interrupt Monitor Register which provides a quick way to determine the source of the interrupt on the IU. The Monitor register is a direct status of the VME interrupt lines. Only byte reads to this register are permitted. The VMEbus Interrupt status is contained in bits 31:25. Other operations to this register result in a bus error time-out.

Tables 7-19 and 7-20 list more detailed information about the Interrupt Monitor register.

| Table: 7.19 | VME Interrupt | Monitor Register | Address |
|-------------|---------------|------------------|---------|
|             |               |                  |         |
|             |               |                  |         |

| Туре | Device Address | Device                | Physical Space |
|------|----------------|-----------------------|----------------|
| 1    | 0xEFE00004     | VME Interrupt Monitor | 1 byte         |

Initialization: Bit 24 is reset (zero). Bits 31:25 are read-only.

 Table: 7.20 Interrupt Monitor Register Address Definitions

| 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24   |
|-------|-------|-------|-------|-------|-------|-------|------|
| IRQ 7 | IRQ 6 | IRQ 5 | IRQ 4 | IRQ 3 | IRQ 2 | IRQ 1 | FAIR |

NOTE: Bit 24 set to a one sets the requestor to Fair Mode. A bit set among bits 31:25 indicates a pending interrupt.

## 7.19.1 Fair Mode Requester

The SPARC CPU-2CE includes an optional fair mode requester bit (Bit 24 of the Interrupt Monitor register) to allow Bus Fairness operations when the CPU is used in a multiprocessor environment. This allows VMEbus masters in the system to have equal access to the VMEbus.

With the Fair bit set, the VME interface controller asserts a VME request only when no other bus request is pending. Resetting bit 24 of the Monitor register disables this feature.

## 7.20 VME IACK Cycles

When the SPARC CPU-2CE is set up to respond to vectored VME interrupt requests, it drives the IACK line to acquire the interrupt vector from interrupting devices though software routines. A device space operation is used by the Interrupt handler to generate an Interrupt Acknowledge cycle. The operation is done only by doing a Device Space byte read at location 0xEFE0000X with Address bits 3 to 1 set to the VMEbus interrupt level being acknowledged. A 16- or 32-bit access is not acknowledged and results in a bus error time-out. By doing this, an acknowledge process is started by first acquiring the bus, then by driving the IACK signal at the same time as with other control lines such as AS\*, DS\*, A1-3, etc.

NOTE: An access to these seven addresses are not to an on chip register, but instead to execute a VME Interrupt Acknowledge cycle, acquiring the Interrupt Vector from the interrupting device.

4

Ì

Tables 7-21, 7-22, and 7-23 provide more detailed information about the VME mail box register, IACK cycles registers, and responses.

| Туре | Device Address | Device          | Physical Space                                                                  |
|------|----------------|-----------------|---------------------------------------------------------------------------------|
| 1    | 0xEFE0000      | VME Int. Vector | 1<br>A[3:1]=VME Int. level.<br>A0=1, Read, only 8-bit<br>access should be used. |

| Table: 7.21 | Mail | Box | Register | Address |
|-------------|------|-----|----------|---------|
|-------------|------|-----|----------|---------|

| Table: 7.22 | VME IACK | <b>Cycles Register</b> | Address Bits |
|-------------|----------|------------------------|--------------|
|-------------|----------|------------------------|--------------|

| 31 | 30    | 29       | 28       | 27        | 26        | 25        | 24           |
|----|-------|----------|----------|-----------|-----------|-----------|--------------|
|    | 8-bit | Interrup | Vector f | rom inter | rupting V | ME Device | Level A(3:1) |

This translates into the following interrupt responses:

| Acknowledging VME Interrupt | Device Addres |
|-----------------------------|---------------|
| 1                           | 0xEFE00003    |
| 2                           | 0xEFE00005    |
| 3                           | 0xEFE00007    |
| 4                           | 0xEFE00009    |
| 5                           | 0xEFE0000B    |
| 6                           | 0xEFE0000D    |
| 7                           | 0xEFE0000F    |

# Table: 7.23 VME IACK Cycles Interrupt Responses

## 7.20.1 Daisy Chain IACK Driver

Since the SPARC CPU-2CE does not have the capability to interrupt the VMEbus through the VME interrupt request lines, it does not provide interrupt vectors at all. Thus, it drives the daisy chain IACKOUT when an IACKIN is active. When set up as a slot 1 card, it drives the IACKOUT as soon as the non-daisy chain IACK signal is active.

## 7.20.2 Master Cycles

Ideal VME slave accessed (30 ns DS to DTACK response). Bus already owned. No lingering DTACK or AS. A Master cycle is 9 cycles, corresponding to a theoretical 9 MB/s bandwidth for back-to-back cycles.

## 7.20.3 Slave Cycles

Ideal VME master (0 ns DTACK to DS response). Fast Sbus grant (two clock periods).

Table 7.24 provides more information about the duration of slave cycles and the theoretical bandwidth.

| Cycle        | Duration (ns) | Theoretical<br>Bandwidth |
|--------------|---------------|--------------------------|
| Single Read  | 560-630 ns    | 6.9 to 7.9 MB            |
| Single Write | 510-580 ns    | 6.3 to 7.2 MB            |

| Table: 7.24 Slave Cycles Duration and Theoretica | l Bandwidth |
|--------------------------------------------------|-------------|
|--------------------------------------------------|-------------|

## 7.21 Bus Arbitration

Table 7.25 lists the characteristics for single-level and Fair arbitration.

| Table: | 7.25 | Bus | Arbitration |
|--------|------|-----|-------------|
|--------|------|-----|-------------|

| Arbiter              | Conditions                                                                                                                                         |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Single Level Arbiter | No VME master owns the bus, Bus Locker disabled.<br>VME Bus Request to VME Bus Grant: 2 Cycles.<br>No VME master owns the bus, Bus Locker enabled. |
| Round-Robin Arbiter  | VME Bus Request to VME Bus Grant: 3 Cycles.<br>No VME master owns the bus, Bus Locker disabled.<br>VME Bus Request to VME Bus Grant: 2-5 Cycles.   |
|                      | No VME master owns the bus, Bus Locker enabled.<br>VME Bus Request to VME Bus Grant: 3-6 Cycles.                                                   |

# 7.22 Interrupts

Table 7-26 defines the interrupt sources and their levels:

| Level | Source                               | Additional Source       |
|-------|--------------------------------------|-------------------------|
| 15    | Abort                                |                         |
| 15    | SYSFAIL                              |                         |
| 15    | Memory: Parity Error                 | ECC Uncorrectable Error |
| 14    |                                      | Counter/Timer 1         |
| 13    | VME Level 7<br>VME Mailbox interrupt | Audio                   |
| 12    |                                      | Serial Ports            |
| 11    | VME Level 6                          | Floppy Disk             |
| 10    | :                                    | Counter/Timer 0         |
| 9     | VME Level 5                          | SBUS 7                  |
| 8     | VME Level 4                          | SBUS 6 (Video)          |
| 7     |                                      | SBUS 5                  |
| 6     |                                      | SW IRQ6                 |
| 5     | VME Level 3                          | Ethernet, SBUS 4        |
| 4     |                                      | SCSI<br>SW IRQ4         |
| 3     | VME Level 2                          | SBUS 3                  |
| 2     | VME Level 1                          | SBUS 2                  |
| 1     |                                      | SW IRQ1<br>SBUS 1       |

Table: 7.26 VME Interrupt Levels and Sources

All type 1 devices defined in the architecture, including the serial ports, use autovectored interrupts.

The interrupt register in device space enables all interrupts, causes software interrupts, and enables specified interrupts. It is described in the chapter *Device Space*. The memory error registers in system space, provide information about any memory errors that occur. They are described in the chapter *System Space*.

×

ι.

## 7.23 Example of a VME System

Figure 7-1 is a diagram of a sample VME system with two SPARC CPU-2CE cards, a third-party Ethernet card, and a third-party SCSI card. The text below describes how this system configuration should be defined and implemented. This example is generic and is provided only as a guide for understanding the SPARC CPU-2CE VMEbus.





Board A in slot 1 is a SPARC CPU-2CE with the slot 1 functions enabled (Arbiter, IACK Daisy Chain driver, SYS Clock Driver). It is an Interrupt Handler for level 1-3. Board B is also a SPARC CPU-2CE with the slot 1 functions disabled. It is an Interrupt Handler for level 4-7. Board C is an Ethernet card with a Slave and an Interrupter. Board D is a SCSI card with DMA capabilities. It has a Master, a Slave and an Interrupter.

Board A needs to start a disk transfer by writing to command registers in card D. But first he has to acquire the bus. His Master orders the on card Requester to get the bus. The Requester asserts [BR]. If no one owns the bus, indicated by an inactive [BBSY], the arbiter grants the bus with [BG]. Board A's Requester receives this, assert [BBSY] and allow his Master to start a bus cycle.

If another card 's Requester was requesting the bus at the same time with a [BR], card A would still get it since the bus grant from the arbiter in slot 1 is passed from card to card via a Daisy Chain [BGIN,BGOUT] and card A is the first card in the Chain.

Board A's Master asserts addresses, data and then strobe [AS] and [DS(1:0)].

Next, card D's Slave detects that the cycle is aimed at him and respond with a [DTACK] once the data has been captured (the write to the command register). The SCSI card starts the disk access and when he has filled his buffer with data, activate his Master. The Master requests the bus via it's on-card Requester.

The SPARC CPU-2CE requester is of Release On Request type, so he keeps the bus with [BBSY] until someone else asks for it. When Board D's Requester requests the bus, Board A's Requester drops [BBSY]. Now the Arbiter can grant the bus to card D with a [BG].

Board D acquires the bus asserting [BBSY] and the Master can start a DMA transfer to card A's on card memory via A's Slave. the Slave responds with a DTACK for every cycle. Once the whole transfer is complete, card D asserts interrupt 3 via his interrupter signaling he's finished.

Board A's interrupt handler is activated and does an Interrupt Acknowledge cycle. This cycle is almost identical to a Master read, but instead of reading data, the interrupt vector is read. [IACK] is asserted to signal an IACK cycles, and address bits 1-3 indicates what level the IACK cycle is responding to.

[IACK] from any interrupt handler is passed to slot1, where the back plane directly connects it to the start of the [IACKIN/IACKOUT] daisy-chain. This is done to enable interrupt handlers to be spread out on different cards if needed. The IACK Daisy Chain Driver in slot 1 drives the chain. Board B is not an interrupter and therefore always passes [IACKIN] to [IACKOUT].

Board C passes the incoming [IACKIN] to its [IACKOUT], unless he is interrupting on the same level at the same time. If so, he does not pass the [IACKIN] signal, but instead respond to the IACK cycle with a DTACK and his vector, different from card D's. In the mean time, card D would not see any [IACKIN] and therefore just keep his interrupt asserted until card C passes it on.

Board D's interrupter responds to an IACK cycle with the corresponding bits set to the level he is interrupting on. Board A jumps to the disk card interrupt routine, with the understanding that the disk transfer has finished and now is ready and stored in the DVMA buffer. The transfer is complete.

## 7.24 VMEbus Device Driver

## 7.24.1 VMEbus Device Driver System Calls

The VMEbus Device Driver supports the "usual" system calls: open(), close(), read(), write(), ioctl() and mmap(). Consult your SunOS documentation for detailed information regarding the general use of these functions.

When making calls to these functions (in reference to the memory/devices managed by the VMEbus Device Driver) the following points are of interest:

open () verifies that the minor device number, of the file you are opening, is one of the following:

| VME16D16 | VME16D32 |
|----------|----------|
| VME24D16 | VME24D32 |
| VME32D16 | VME32D32 |

These constants are defined in the header file vme.h.

.

read() and write() will not attempt to read past the end of the valid space defined by the minor number of the "file" you are attempting to read. In other words, attempts to read() or write() past the address Oxffff when using a file handle opened in A16 space will not be attempted by the VMEbus Device Driver. Likewise, read() and write() will not read past the address Oxffffff in A24 space.

The following operations are defined for an ioctl() call:

| VME_SET_REG       | Write to a VME interface specific register.                                                  |
|-------------------|----------------------------------------------------------------------------------------------|
| VME_GET_REG       | Read from a VME interface specific register.                                                 |
| VME_RDSWITCH      | Read the current state of the HEX switch.                                                    |
| VME_WRLEDS        | Write to the front-panel LED's.                                                              |
| VME_ENA_DIS_VME32 | Enable full 32-bit address access or place the VME interface into CPU-1E compatibility mode. |
| VME_GET_PHYS      | Translate a DVMA address into its corresponding VME physical address.                        |

The labels described above are defined in *vme.h* supplied with the VMEbus Device Driver. A sample application, called  $v_rw.c$ , that uses each of these ioctl() calls is also supplied with the VMEbus Device Driver. Please refer to these files for detailed information.

The S4-VME interface device has limitations when used to access the A32 space which must be taken into account when assigning addresses to VME peripheral devices on the VMEbus. These limitations are associated with hardware and cannot be fixed by software (either the VMEbus Device Driver or the application software).

The VMEbus interface chip on the CPU-2CE directly decodes only 29 address bits resulting in what can be described as decoding a series of eight 512 megabyte "windows" (there is additional hardware to assist in distinguishing which "window" is being used). The VMEbus interface chip always interprets the upper 16 megabytes of each of these "windows" as A24 and A16 space. Thus, one cannot map the following VMEbus addresses into A32 space:

#### FORCE COMPUTERS

. . .

;-

Æ

-

| Start Address | End Address |
|---------------|-------------|
| 0x1FFF.0000   | 0x1FFF.FFFF |
| 0x3FFF.0000   | 0x3FFF.FFFF |
| 0x5FFF.0000   | 0x5FFF.FFFF |
| 0x7FFF.0000   | 0x7FFF.FFFF |
| 0x9FFF.0000   | 0x9FFF.FFFF |
| 0xBFFF.0000   | 0xBFFF.FFFF |
| 0xDFFF.0000   | 0xDFFF.FFFF |
| 0xFFFF.0000   | 0xFFFF.FFFF |

Table 7.27 A16 - Only Access

Table 7.28 A24 - Access

| Start Address | End Address |
|---------------|-------------|
| 0x1F00.0000   | 0x1FFE.FFFF |
| 0x3F00.0000   | 0x3FFE.FFFF |
| 0x5F00.0000   | 0x5FFE.FFFF |
| 0x7F00.0000   | 0x7FFE.FFFF |
| 0x9F00.0000   | 0x9FFE.FFFF |
| 0xBF00.0000   | 0xBFFE.FFFF |
| 0xDF00.0000   | 0xDFFE.FFFF |
| 0xFF00.0000   | 0xFFFE.FFFF |

## 7.24.2 VMEbus Address Modifiers

## Program/Data/Block Transfer Address Modifiers

The CPU-2CE will generate only the Data Address Modifier Code. The Program and Block Transfer Address Modifier Codes are not supported.

## Supervisory/Non-Privileged Address Modifiers

The CPU-2CE can generate either the Supervisory or the Non-Privileged Address Modifier Codes. This is controlled by the Integer Unit's (IU) Processor Stat Register (PSR).

Typically a user's application will operate at a "non-privileged" level resulting in the assertion of the User Address Modifier Code when the users's application access VMEbus addresses that have been allocated by the mmap() system call. If the user's application is a driver that operates at the same privilege level as the kernel the Supervisor Address Modifier Code will be asserted when that driver accesses VMEbus addresses.

Accesses to the VMEbus made within the kernel operate at a "privileged" level and will result in assertion of the Supervisor Address Modifier Code. This is the case when one uses the read() and write() system calls to access a VMEbus device. If the user uses the mmap call to create a pointer the VME AM code issued will reflect the current privilege level of the calling program.

## Extended/Standard/Short Address Modifiers

The CPU-2CE may generate the Extended, Standard or Short Address Modifier Codes with the following restrictions:

| Address Modifier | Value      | Description                        |
|------------------|------------|------------------------------------|
| Extended (A32)   | 0x09, 0x0D | No Unaligned transfers are allowed |
| Standard (A24)   | 0x39, 0x3D | No Unaligned transfers are allowed |
| Short (A16)      | 0x29, 0x2D | No Unaligned transfers are allowed |

## Table: 7.29 Address Modifier Codes

## 7.24.3 VMEbus Device Driver Limitations

## Floppy and Audio Interrupt Conflicts

VMEbus IRQ6 and the standard SunOS floppy disk device driver cannot be used simultaneously. Likewise, VMEbus IRQ7 and the standard SunOS audio device driver cannot be used simultaneously.

The floppy and audio device drivers will not share their respective interrupts with other device drivers because they use Programmed I/O to complete their tasks, rather than DMA. Programmed I/O is relatively slow, therefore, these device drivers reserve their corresponding interrupt levels for exclusive use. Thus, if either of these devices is configured as part of the kernel their respective VMEbus IRQ cannot be used.

Potential for SunOS Patches to Conflict

Because several of the files supplied as a part of the VMEbus Device Driver are modifications of standard SunOS files there is a potential for SunOS patches to conflict with the VMEbus Device Driver. In general, it is best to consult FORCE COMPUTERS' Technical Support to verify if a patch can be made to the SunOS kernel without interfering with the VMEbus Device Driver.

If FORCE COMPUTERS has incorporated a specific SunOS patch there will be additional files supplied with the VMEbus Device Driver that should be used instead of the SunOS patch files. Using the FORCE COMPUTERS supplied files will insure that the patch is installed in a way that is compatible with the VMEbus Device Driver. The standard files supplied with the VMEbus Device Driver are based on the original, unpatched SunOS sources and do not incorporate any SunOS patches that have occurred since the specific release on which the VMEbus Device Driver is based.

## GENERIC.VME versus GENERIC\_SMALL.VME

Two kernel configurations are supplied with the VMEbus Device Driver. The GENERIC.VME configuration assumes all devices will be configured (including the floppy and audio device drivers) except for the ONC/VME Device Driver (see Section 8).

When installing or configuring the VMEbus device driver using the GENERIC.VME configuration file you must ALWAYS ensure the file /etc/hostname.vm0 is created and contains the name of the VME node. This is similar to adding a second ethernet card.

## 7.25 VME Programming Examples

Two code examples are presented below, one written in FORTH, and the other written in C. These examples provide an indication to you on how to program for the VMEbus.

Additional reference material required for a complete definition of the FORTH and C words used in the following code examples: SBUS Developer's Kit, Sun Part No. 825-1219-xx, (Sun SBUS Information).

## 7.25.1 FORTH Programming Examples

## Map the VMEbus to a Virtual Address

The first FORTH example illustrates how to gain access to a known range of physical addresses on the VMEbus by mapping the desired VME address-range to a virtual address-range allocated from the Virtual Address Pool.

The routine memmap maps a range of physical addresses within the specified "space" to a range of virtual addresses allocated from the Virtual Pool and returns the base virtual address which was allocated.

The "space" parameter can refer to On-Board Memory, On-Board I/O, or any combination of VME-Bus Data-widths and Address-widths from among the following: D16 or D32, and A16, A24, or A32

| \ Initializatio<br>hex \ Set t                                                                                                       | n and constants.<br>he numeric base for subsequent interpretation                                                                     |  |
|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| 100.0000 constant my-v<br>2.0000 constant my-s                                                                                       |                                                                                                                                       |  |
| 0 value my-virt                                                                                                                      | Place-holder for the virtual address                                                                                                  |  |
| \ Now map the a                                                                                                                      | ddress-range:                                                                                                                         |  |
| my-vme-phys-addr                                                                                                                     | <ul> <li>First parameter for memmap is the base-address</li> <li>(physical address) of the desired address-range</li> </ul>           |  |
| vmed32a32                                                                                                                            | <pre>\ Second parameter for memmap is the "space". For</pre>                                                                          |  |
| my-size                                                                                                                              | \ Third parameter for memmap is the size of the<br>\ desired address-range.                                                           |  |
| memmap                                                                                                                               | ackslash The allocated virtual address is now on the stack.                                                                           |  |
| is my-virt                                                                                                                           | \ Save it in the place-holder.                                                                                                        |  |
| \ range on                                                                                                                           | ead from and write to any address in your specified<br>the VMEbus, simply by reading from or writing to the<br>nding virtual address. |  |
| \ When you are done with the range, unmap the VMEbus address-range<br>\ and return the virtual address-range to the Allocation Pool: |                                                                                                                                       |  |
| my-virt my-size free-vi                                                                                                              | rtual                                                                                                                                 |  |

#### Map Local Memory to the VMEbus

The next FORTH example illustrates how to map a range of your local memory to the VME slave port, allowing other VMEbus masters to obtain read/write access to your local memory in a DMA mode. This operation is normally undertaken by a device-driver under the /VME device-node, and, in fact requires the services of certain words which are methods within that node, so this example will also illustrate various ways to arrange the required set-up for different situations.

```
Common part of the set-up: Setting this CPU2CE's slave-port. There is configuration-variable called vme-slavemap whose value is 0 to
                                                                                      There is a
١.
          (decimal) 15 (or Of hex) which identifies the slave-port number of the CPU2CE. If there is more than one CPU2CE, or other device capable
١
١
          of acting as a VME-slave, on the VME-bus, then each one must have a
١
          different and unique value for its slave-port number. If your board
١
          already has its vme-slavemap configuration-variable set to the prope
value, then you will not need to repeat this sequence. We will assume
١
                                                  configuration-variable set to the proper
١
          that we are setting this CPU2CE's slave-port number to 2.
setenv vme-slavemap 2
                                             Set the configuration-variable
                                                    to the proper value.
vme-slavemap vme-slavemap!
                                             Load the slave-port register with the
                                                    value in the configuration-variable.
                                          ١
                                          ١
                                                    Normally, this is done at startup time.
```

-

| <pre>\ Set-up example 1: A device-driver under the /VME device-node, whose<br/>\ base-address is at 0c0.0000 and which operates with 16-bit data-width<br/>\ and 24-bit address-width</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0 " vmed16a24,0c0.0000" " /vme" begin-package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <pre>\ The above begins the definition of a new device-driver package<br/>under the /VME device-node. It would normally precede the<br/>instructions which lead to the interpretation of the FCode<br/>for the device-driver in question. It supplies the essential<br/>information about the address and space at which the device<br/>is configured. The interpretation of the device-driver FCode<br/>would then be followed by the end-package command; however,<br/>those considerations are beyond the scope of this example.</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| \ We will skip over such preliminaries as supplying the device's<br>\ name or specifying the structure of its control registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <pre>\ Since the present device is an offspring of the /VME node, it does not automatically have access to the required /VME methods. For convenience, we will define them here, as calls to the methods of the same name in the parent's node i.e., in the /VME node:</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <pre>: map-in ( phys space size virt ) : map-out ( virt size ) : dma-alloc ( n vaddr ) : dma-free ( vaddr n ) : dma-map-in ( vaddr n cache? devaddr ) : dma-map-out ( vaddr devaddr n ) : dma-map-out ( vaddr devaddr n</pre> |
| <pre>my-address \ This will be the second value given in the second<br/>\ string parameter to begin-package prior to<br/>\ probing; in this example 0c0.0000</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <pre>constant dev-address \ Make it a constant, to be consistent with</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <pre>my-space \ This will be the first value given in the second</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| constant dev-space \ Make it a constant, to be consistent with \ the second set-up example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <pre>\ Set-up example 2: The operator is doing some on-the-fly experimentation \ and merely wants to have the /VME device-node's methods available:</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <pre>cd /vme \ Make the /VME device-node the top of the vocabulary<br/>\ context, and also the current vocabulary where<br/>\ definitions will be placed. The latter is not<br/>\ desirable, because words defined here will become<br/>\ methods of the /VME device-node, and OpenBoot<br/>\ does not permit you to forget a device's methods.<br/>\ Since you are experimenting, you will likely want<br/>\ to forget and re-define your definitions as your<br/>\ experimentation progresses.</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| also forth definitions \ This will leave the /VME device-node in<br>\ your vocabulary search-order, but put<br>\ the forth vocabulary back as the top<br>\ of the context and as the current<br>\ vocabulary for definitions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <pre>\ When you are finished, you can restore the normal search-<br/>\ order with the command-sequence:<br/>\ only forth also definitions</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

```
Hardware
```

Again, we skip over preliminaries such as specifying the structure of the device's control registers. 0c0.0000 constant dev-address vmed16a24 constant dev-space \ The body of the example follows: V Place-holder for the allocated virtual base-address 0 value dev-reg-base of the device's control registers structure. ١. Place-holder for the virtual address we will use to 0 value my-DMA-addr access our slave port memory. Place-holder for the address that the device, acting 0 value dev-DMA-addr ١ as Bus-Master, will use to access our slave port memory in DMA mode. ١ \ Map-in the device's control registers dev-address dev-space \ First two parameters for map-in Hypothetical constant specifying the size of reg-size ١ the device's control registers structure. map-in ١. The allocated virtual address is now on the stack. \ Save it in the place-holder. is dev-reg-base Now we will allocate and map some memory for our slave port, "on the fly". dev-DMA-size Hypothetical constant specifying the size of our slave ١ port memory. \ Allocate the memory; virtual address is now on the stack. dma-alloc is my-DMA-addr \ Save it in the place-holder. my-DMA-addr First parameter for dma-map-in is the virtual ١ address which was allocated by dma-alloc Second parameter for dma-map-in is the size of the range to map to the VME slave port dev-DMA-size ١ The third parameter for dma-map-in specifies false ١ whether caching should be enabled, if available ١ The address that the device, acting as Bus-Master, will use to access our slave port memory, dma-map-in ١ is now on the stack is dev-DMA-addr \ Save it in the place-holder. Load the address that the device, acting as Bus-Master, will use ١. to access our slave port memory, into its appropriate control register. dev-DMA-addr Address the device should use... dev-reg-base \ Base-address of the device's control registers Hypothetical word to adjust the base address to >dev-addr ١ the offset for the Device-Address Register. ١ \ Store the address in the Device-Address Register 1

| <pre>\ The device can now read from and write to the VME-bus address held in<br/>\ dev-DMA-addr (and copied to its Device-Address Register) to access<br/>\ the CPU2CE's slave port memory. The CPU2CE can access the same memory<br/>\ by using the virtual address held in my-DMA-addr When you are done<br/>\ with this device's access to the VME slave port, unmap things and<br/>\ return the virtual address-range to the Allocation Pool:</pre> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| my-DMA-addr dev-DMA-addr dev-DMA-size dma-map-out                                                                                                                                                                                                                                                                                                                                                                                                       |
| my-DMA-addr dev-DMA-size dma-free                                                                                                                                                                                                                                                                                                                                                                                                                       |
| \ Map-out the device's control registers, now that you're done                                                                                                                                                                                                                                                                                                                                                                                          |
| dev-reg-base reg-size map-out<br>0 is dev-reg-base                                                                                                                                                                                                                                                                                                                                                                                                      |

#### Map an SBUS Address to a Virtual Address

The third FORTH example illustrates how to gain access to a known range of physical addresses within the SBUS (actually, an known offset from the start of the SBUS) by mapping the desired address-range to a virtual address-range allocated from the Virtual Address Pool.

0010.0000 constant my-SBUS-offset Base-address of the desired SBUS range 0000.4000 constant my-SBUS-size Size of the desired SBUS address-range 0 value my-virt \ Place-holder for the virtual address my-SBUS-offset sbus my-SBUS-size memmap is my-virt memmap can also be used with the following non-VME spaces: ١ obmem obio You can now read from and write to any address in your specified range on the SBUS, simply by reading from or writing to the ١ corresponding virtual address. ١ When you are done with the range, unmap the SBUS address-range and return the virtual address-range to the Allocation Pool: my-virt my-SBUS-size free-virtual

#### 7.25.2 C Programming Example

The C example below shows how to open a VME space and obtain a virtual pointer so that the VME space can be read/written to.

In the Unix environment several options are available to the programmer. The VME-bus supports 16, 24, and 32 bit addressing, along with 8, 16, and 32 bit data transfers. In /dev several special files are provided that allow for the different configurations. For example, vme24d32 provides a 24 bit address with 32 bit data transfers. These special files can be opened and seeks performed. (See MEM in section 4S of the manual pages) However it is usually more efficient to use pointers. A pointer to an opened special VME file can be obtained using mmap(). (See MMAP in section 2 of the manual pages)

#include <stdio.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/mman.h>

Hardware

```
/* important VME driver definitions
                                                                                      */
#include <vme.h>
main(argn, argv)
int argn ;
char **argv ;
£
    int fd, i, len, off ;
off_t addr ;
    caddr_t ptr ;/
    unsigned short *p ;
    unsigned short pat ;
    if (argn < 3) {
    printf("usage: %s addr len [pat]\n", argv[0]) ;</pre>
         return ;
    ъ
    pat = 0xaaaa ;
                                                                                      */
                                    /* assign a default pattern to be used
 * Get "addr" from the argument list. Convert that address to a 32k aligned * base address plus an offset ("addr" and "off").
    */
    off = (addr & 0x7fff) >> 1 ;
                                                                                       */
                                                           /* align base address
    addr &= 0xffff8000 ;
                                                                                      */
    len = (int)strtol(argv[2], (char **)NULL, 0) ; /* get length of trnsfr */
                                                           /* get data pattern
                                                                                      * /
    if (argn == 4)
        pat = (short)strtol(argv[3], (char **)NULL, 0);
    printf("addr = 0x%x\n", addr) ;
printf("off = 0x%x\n", off*sizeof(pat)) ;
printf("len = %d\n", len) ;
printf("pat = 0x%x\n", pat) ;
                                                          /* display the values */
/* we are going to use */
 * Now open VME space as address 24 data 16 (VME24D16).
    if((fd = open("/dev/vme24d16", O RDWR)) == -1) {
        printf("error opening vme bus\n") ;
         return ;
    3
 * Use mmap to obtain a virtual pointer to VME space. Then, convert the * pointer to an unsigned short for 16 bit reads and writes.
    return ;
    }
    p = (unsigned short *)ptr ;
1+
 * Write VME memory with the specified data pattern. Then, read the data
 * back and compare to the specified data pattern.
 * /
    for (i=0 ; i<len/2 ; i++)
                                             /* write "pat" to the VME space
                                                                                      */
          (p+i+off) = pat;
    for (i=0 ; i<len/2 ; i++) {</pre>
                                             /* read VME space, look for "pat"
                                                                                      */
         if (*(p+i+off) != pat) {
    printf("fail location %x read %x exp %x\n", p+i+off,
                       *(p+i+off), pat) ;
                                             /* break out of read loop
             break ;
                                                                                      */
         }
    }
}
```

- --

- .

- Page 7-38

Section 8

**ONC/VME** 

The VMEbus provides facilities for data sharing between multiple processors on the same backplane, but custom programming is usually required to make use for those facilities. None of the standard commands for inter-processor communication (e.g. rlogin) are of any help without a separate network connection.

ONC/VME corrects that problem by defining a way in which two or more machines on the same VME backplane can use the backplane as if it were an IP network interface. All of the standard TCP/IP networking facilities, including NFS, can then be used by any of the machines on that backplane without an Ethernet or other secondary interconnection between hosts. Any facilities specific to a particular sort of network (for instance, the UNIX etherfind utility) will not operate on an ONC/VME interface.

ONC/VME allows you to connect multiple processors residing in the same cardcage without having to use the usual network equipment such as thick-wire Ethernet or a multiplexing device.

ONC/VME uses the VME backplane as the network device. The processors share memory across the bus. A host leaves an internet protocol (IP) packet in a known location in a processor's memory, then signals the destination host that a packet is waiting.

The processors must be able to *export* a section of local memory to an arbitrary VME address that is megabyte-aligned. Efficiency of the protocol is maximized if the processors are able to send and receive VME mailbox interrupts.

## 8.1 Capabilities

ONC/VME supports most TCP/IP applications. These include:

- remote programs such as rsh, rcp, rlogin
- telnet
- ftp
- spray
- nfs

## 8.2 Using ONC/VME

Once the configuration has been completed and the ONC backplane driver (vm0) is active, you can use this device as you would an Ethernet interface. Section 8.3 describes the steps required to set up and boot one or more client SPARC CPU-2CEs over the VMEbus backplane. Section 8.4 describes the steps required for two or more SPARC CPU-2CEs to communicate over the VMEbus.

## 8.3 Booting Over the VMEbus Backplane

This section describes the steps required to set up and boot one or more client SPARC CPU-2CE's over the VMEbus backplane. It also describes the required configurations for hardware, software, and the PROM/NVRAM.

CAUTION If ypbind is desired, add the server and client CPU's hostname to the Master YP Map or disable ypbind by entering:

kill -9 <PID>

You can find out the **<PID>** by entering:

## ps -axj | grep YP

In the latter case, ypbind must be disabled because the server and the client CPUs are not known over the NIS Master database and when add\_client (8) is run, the ethemet address of the client(s) will not be used correctly.

## 8.3.1 Installation Example

This installation example lists the variables that must be setup prior to server and client ONC/VME operation.

- Each SPARC CPU-2CE must be assigned an Internet address for vm0 and a corresponding *hostname*. This is a different address than that of *ethernet le0*.
- Each SPARC CPU-2CE must be assigned a unique slave map address space in the range of 0-15 (*vme-slavemap*).

Table 8.1 lists the names, values, and variables for the server CPU. Table 8.2 lists the names, values, and variables for the client CPU.

| Hostname:            | server-vm |
|----------------------|-----------|
| Internet Address:    | 199.9.9.1 |
| Server vme-slavemap: | 0         |

| <b>Table: 8.1</b> | Example Serve | r Configuration |
|-------------------|---------------|-----------------|
|-------------------|---------------|-----------------|

| Hostname:                | client-vm    |
|--------------------------|--------------|
| Internet Address:        | 199.9.9.2    |
| Client vme-slavemap:     | 1            |
| Client Ethernet Address: | 8:0:50:1:0:3 |

## Table: 8.2 Example Client Configuration

#### 8.3.2 Hardware Configuration

Install two or more SPARC CPU-2CE cards into a VMEbus card cage. Make sure no CPU is plugged into a slot reserved for the P2 extended bus of another CPU (i.e. VSB).

## 8.3.3 Software Configuration

The SPARC CPU-2CE designated as the server must have server software installed when SunOS/Solaris software was loaded.

Power cycle the system and put each SPARC CPU-2CE at the OK prompt.

#### 8.3.4 PROM/NVRAM Configuration

The CPU-2CE must contain version 2.3.6 or higher ROM to work properly with ONCVVME. To determin your ROM's version number do the following:

- enter the forthmon monitor
- type .version at the ok prompt

Several variables in the PROM/NVRAM must be set up in order to boot over the VME backplane. The (server CPU) must set *vme-slavemap*.

Each client CPU must set the following NVRAM variables:

- boot-device
- vm-server-slavemap
- vm-server-addr
- vm-ip-addr

The sections that follow list the PROM/NVRAM variables and show examples of how to set them. See section 2 for more detailed information about these parameters.

## 8.3.4.1 vme-slavemap

Each SPARC CPU-2CE must be assigned a unique slave map address space (vme-slavemap) in the range of 0-15.

Set the server's NVRAM vme-slavemap variable to zero, as shown below:

```
OK setenv vme-slavemap 0
```

Set the client's NVRAM vme-slavemap variable to a value between 1 and 15. The example below shows how to set the example client's vme-slavemap:

```
OK setenv vme-slavemap 1
```

## 8.3.4.2 boot-device

Set the client's NVRAM boot-device variable to vmnet.

```
OK setenv boot-device vmnet
```

## 8.3.4.3 vm-server-slavemap

Set the client's NVRAM vm-server-slavemap variable to zero, as shown below:

```
- OK setenv vm-server-slavemap 0
```

8.3.4.4 vm-server-addr

Set the client's NVRAM vm-server-addr variable to the Internet address of the client's server.

The Internet address is made up of four hexadecimal numbers expressed in decimal form. For example, the Internet address 199.9.9.1 converts to the hexadecimal value 0xc7090901.

OK setenv vm-server-addr 0xc7090901

## 8.3.4.5 vm-ip-addr

Set the client's NVRAM vm-ip-addr variable to the Internet address of the client. This entry also requires a hexadecimal form.

OK setenv vm-ip-addr 0xc7090902

## 8.3.5 Initializing the System

Reboot the system. The clients will be in a loop requesting a rarp address, is a normal condition prior to installation completion.

## **8.3.6** Files To Edit on the Server

When the server is booted and running vmunix, edit or create the following files. You must become root to make these changes. The following changes assume you have installed the VME/ONC driver onto your system according to the insulation instructions provided with the driver.

## 8.3.6.1 /sys/sun4c/conf/GENERIC.VME

Edit the /sys/sun4c/conf/GENERIC.VME file and uncomment the entry for the ONC/VME driver, as follows:

device vm0

Uncommenting this line in the GENERIC.VME file causes the ONC/VME driver to be included in the kernel. The kernel must be reconfigured for this change to have effect

## 8.3.6.2 /etc/hosts

Edit the /etc/hosts file and add the Internet address. This should be the same address set into NVRAM *vm-server-addr* (0xc7090901 in our example below).

| 120.40.35.3 | server loghost |   |     |      |      |
|-------------|----------------|---|-----|------|------|
| 199.9.9.1   | server-vm      | < | add | this | line |
| 199.9.9.2   | client-vm      | < | add | this | line |

Use the banner word at the prompt to determine your ethernet address.

## 8.3.6.3 /etc/ethers

Edit the /etc/ethers file and add an entry for the client's ethernet address (8:0:50:1:0:3 in our example below).

8:0:50:1:0:3 client-vm <-- add this line

## 8.3.6.4 ONC Driver Interrupt Conflict with the Audio and Floppy Divers

The ONC/VME driver uses the VME Mailbox interrupt as part of the communication protocol. The VME Mailbox interrupt level, by default, is set to level 13 and may conflict with the Audio driver.

The ONC/VME driver is not automatically configured in the GENERIC.VME or GENERIC\_SMALL.VME files. If you wish to use the ONC/VME driver you must uncommente it from the GENERIC.VME or GENERIC\_SMALL.VME files. Then you must to run the config utility using either GENERIC.VME or GENERIC\_SMALL.VME to rebuild the kernel.

If the ONC/VME driver is configured to include the Floppy or the Audio device drivers, then the Open Boot **vme-rerun** variable needs to be set. The VME Mailbox interrupt must be set at an IPL, Interrupt Process Level, level other than level 11 or 13. Interrupt levels 11 and 13 are reserved exclusively for the Floppy and Audio drivers.

For example, to set the VME/ONC driver to use IPL level 9 type the following in Open Boot.

```
setenv vme-rerun 0xa0
```

## 8.3.7 Adding a Client

The next step requires you to run add\_client and answer the questions. Refer to the Networking and Communications Administration section for more detailed information. Enter the following:

#### > /usr/etc/install/add\_client -i

Once the clients have been added, edit the following files on the server.

#### 8.3.7.1 /etc/hostname.vm0

Edit or create the file /etc/hostname.vm0.

.

server-vm <-- add this line

## 8.3.7.2 /etc/bootparams

Edit the file /etc/bootparams and substitute the server mount points with the correct server name (the one used in hostname.vm0). In each line of this file, change server to server-vm.

client-vm root=server:/export/root/client-vm <-- Change this line client-vm root=server-vm:/export/root/client-vm <-- To this .

#### 8.3.7.3 /export/root/client-vm/etc/fstab

Edit the file /export/root/client-vm/etc/fstab and substitute server-vm for each occurrence of server.

```
server:/export/root/client-vm / nfs rw 0 0 <-- Change this line
server-vm:/export/root/client-vm / nfs rw 0 0 <-- To this
.
.
.</pre>
```

#### 8.3.7.4 /export/root/client-vm/etc/hosts

Create the file hosts in the directory /export/root/client-vm/etc and add the Internet addresses of the server and client(s).

| 199.9.9.2 | client-vm | < | Add | this | line |
|-----------|-----------|---|-----|------|------|
| 199.9.9.1 | server-vm | < | Add | this | line |

8.3.7.5 /export/root/client-vm/etc/hostname.vm0

Create the file hostname.vm0 in the directory /export/root/client-vm/etc and add the line shown in the example below:

```
client-vm <-- Add this line
```

Delete the file /etc/hostname.le0.

cp /vmunix /export/root/client-vm/vmunix

#### 8.3.8 System Start-Up

;

2

After performing all of the configuration and setup tasks, it is time to start up the system.

• fasthalt the server

• When the server displays the OK prompt, enter reset, and reboot the system.

The server should boot, and when it starts the network daemons, the slave CPUs should boot over the VME backplane.

#### 8.4 Activating ONC/VME

This section describes the steps required to activate ONC/VME for communicating between two or more SPARC CPU-2CEs sharing the same VMEbus backplane.

Refer to Section 7, for detailed information on configuring multiple CPUs in the same VMEbus backplane.

## 8.4.1 Setting Up a Private Network

This section shows the steps necessary to set up a private network that allows two SPARC CPU-2CEs to communicate using ONC/VME. For our example, the *host:1* CPU shall be called *ravel* and the *host:2* CPU shall be called *pink*.

Each SPARC CPU-2CE must be assigned a unique slave map address space (vme-slavemap) in the range of 0-15. Set the NVRAM variable vme-slavemap for each CPU. Set ravel's vme-slavemap to zero and pink's to one. At the OK prompt of ravel (host:1), enter the following:

OK setenv vme-slavemap 0

At the OK prompt of pink (host:2), enter the following:

OK setenv vme-slavemap 1

1. If ypbind is desired, add each host to the Master YP map or disable ypbind by entering

kill -9 <PID>

You can find out the <PID>, by entering:

ps -axj |grep yp

In the latter case, ypbind must be disabled because the private network is not known over the NIS master database, only locally.

2. Edit the /etc/hosts files on ravel and pink to include the following:

 199.9.9.1
 ravel\_vmip
 <-- unique hostname</th>

 199.9.9.2
 pink\_vmip
 <-- for each CPU</td>

3. Edit or create the *letc/hostname.vm0* file on *ravel* to have the following line:

ravel\_vmip

And on pink edit or create the /etc/hostname.vm0 file to have the following line:

pink\_vmip

4. Activate vm0, VME-IP service, on ravel and pink by entering the following:

| ifconfig vm0 | ravel-vm | ip execute | this | line on | a ravel |
|--------------|----------|------------|------|---------|---------|
| ifconfig vm0 | pink-vmi | execute    | this | line on | a pink  |

Verify that vm0 is active by entering ifconfig vm0 on each of the SPARC CPU-2CEs.

Now that vm0 is active, functions such as spray, rlogin, ftp, rsh, and rcp can be performed as if on an ethernet network interface.

#### 8.5 Theory of Operation

The heart of the ONC/VME protocol is a region of memory, exported by a processor to a well-known address in VME space. Other hosts may examine and modify this memory region, which is in a predefined format. Packets are transmitted by copying them into the source host's ONC/VME region, then notifying the destination host that a packet is ready. The destination host copies the packet into its own local memory (not its ONC/VME region) and acknowledges receipt of the packet.

Whenever a host modifies another host's ONC/VME region, it sends a VME mailbox interrupt to that host to signal that the host should examine its region and act on the changes.

The ONC/VME protocol is defined for IP (Internet Protocol) packets only. No other protocols (ARP, XNS, LocalTalk, etc.) may transmit packets over an ONC/VME network interface.

An ONC/VME network, from a high-level point of view, looks like any other network interface, with the exception of the protocol restriction above. Broadcast packets are transmitted by sending them individually to all other active hosts on the backplane.

#### 8.6 Memory Usage

÷

The following subsections detail the layout and addressing of the data structures defined by the ONC/VME protocol.

## 8.6.1 Addressing Scheme

ONC/VME memory regions are accessible in VME 32-bit data, 24-bit address space. Each host is assumed to occupy 1 megabyte in this space. The first three-quarters of that megabyte are unused by ONC/VME, and can be used by individual systems for their own purposes. The ONC/VME memory region starts at the last quarter-megabyte (i.e., at offset \$C0000) of each megabyte in VME A24D32 space. Since A24D32 space contains 16 megabytes, a maximum of 16 hosts are allowed in an ONC/VME network.

Each host has a host number, unrelated to its IP address. A host number determines which megabyte contains that host's ONC/VME region. The host number also determines the host's VME mailbox address. VME mailboxes occupy VME A16D16 space. The first 16 bytes of that space contain the first 8 mailboxes, at 2-byte intervals starting at location 0. The other 8 mailboxes are at location \$8000 in the A16D16 space, also at 2-byte intervals. Hosts numbered 0 through 7 use the first set of mailboxes (multiplying their host numbers by 2 to get the address is A16D16 space,) while hosts numbered 8 through 16 use the second set of addresses, multiplying the lower three bits of their host number by 2 and adding to \$8000 to obtain the mailbox address.

-

# 8.6.2 ONC/VME Region Layout

Table 8.3 shows the layout of the ONC/VME memory region (also called VMIP space, for historical reasons). Brief descriptions of the fields follow.

|    | Offset | Size | Contents                       |
|----|--------|------|--------------------------------|
| 7  | 0      | 2    | Magic number (\$3D26)          |
| :. | 2      | 2    | Reserved                       |
|    | 4      | 4    | Packet-ready flag from host 0  |
|    | 8      | 4    | Packet-ready flag from host 1  |
|    |        |      |                                |
|    | 64     | 4    | Packet-ready flag from host 15 |
|    | 68     | 4    | State of host 0                |
|    | 72     | 4    | State of host 1                |
|    | •••    |      |                                |
|    | 128    | 4    | State of host 15               |
|    | 132    | 4    | IP address of host 0           |
|    | 136    | 4    | IP address of host 1           |
|    |        |      |                                |
| \$ | 192    | 4    | IP address of host 15          |
|    | 196    | 4    | Valid-host flag for host 0     |
|    | 200    | 4    | Valid-host flag for host 1     |
|    | •••    |      |                                |
|    | 256    | 4    | Valid-host flag for host 15    |
|    | 260    | 4    | Length of packet from host 0   |
|    | 264    | 4    | Length of packet from host 1   |
|    | •••    |      | •••                            |
|    | 320    | 4    | Length of packet from host 15  |
|    | 324    | 1152 | Contents of packet for host 0  |
|    | 1476   | 1152 | Contents of packet for host 1  |
|    |        |      |                                |
|    | 17604  | 1152 | Contents of packet for host 15 |

| Table: 8.3 | <b>ONC/VME</b> | Region | Layout |
|------------|----------------|--------|--------|
|------------|----------------|--------|--------|

## 8.6.2.1 Magic Number

The magic number must be placed at the beginning of a host's ONC/VME memory region, so that other hosts can probe to determine whether or not ONC/VME is active. The magic number also serves to identify the revision of the ONC/VME protocol. \$3D26 is the magic number for version 1 of the protocol.

## 8.6.2.2 Packet-Ready Flags

When a source host is ready to send a packet, it sets a packet-ready flag in the destination host's region. A packet-ready flag is set if it's nonzero.

## 8.6.2.3 Host States

A local host's notion of a remote host's state can have one of three values. State 0 means that the local host has sent a packet to the remote, but the remote hasn't yet processed the packet. State 1 is set by the remote when it's done copying the packet from the local host's region. State 2 indicates that the local host knows that the remote has finished processing the most recent packet, and is ready to receive another. The host state is in network byte order.

## 8.6.2.4 IP Addresses

ONC/VME uses standard four-byte IP addresses.

## 8.6.2.5 Valid-Host Flags

The valid-host flags are provided as shortcuts for source hosts. They allow a host to quickly determine which of its peers are running the ONC/VME protocol.

## 8.6.2.6 Packet Lengths

When a source host has determined the length of the packet it wishes to transmit, it sets the destination host's packet-length field to the size, including headers, of the packet. The packet-length fields are in network byte order.

## 8.6.2.7 Packet Contents

There is one packet buffer for each of the 16 hosts allowed by the protocol. The packet data, including headers, are copied into one of these buffers for transmission.

## 8.7 Protocol Operation

The following sections describe the operation of the ONC/VME protocol.

## 8.7.1 Initialization

ONC/VME initialization occurs in three stages.

## 8.7.1.1 Initializing the Hardware

First, any hardware-specific initialization, such as memory allocation and mapping, is performed. This usually includes allocating memory for the ONC/VME region and performing whatever MMU-specific functions are necessary to export the region to the appropriate location in VME space. Mailboxes should also be allocated, if necessary.

## 8.7.1.2 Initializing the Local Region

Once memory has been allocated for the local ONC/VME memory region, the region must be initialized. The packet-ready, state, valid-host, and length fields are zeroed out. The IP address of the local host is placed in the appropriate place in the region (*appropriate* meaning the IP address field whose number equals the local host number, host number 5 would set IP address number 5.) The host sets its own valid-host flag, in the same way.

At this point, the region is ready to be accessed by other hosts, so the magic number is set. The magic number should *not* be set until the IP address field is initialized.

## 8.7.1.3 Probing for Remote Hosts

For each of the other 15 possible hosts, the local host tries to read the start of the remote's ONC/VME region. If the magic number is present, the local host copies the remote host's IP address to the appropriate slot in its own region, and sets the remote host's valid-host flag in the local region. The local host sets its notion of the remote's state (i.e., the "state" entry in the local host's region whose number corresponds to the remote's host number) to two. The local host also places its own IP address into its slot in the remote host's region, and sets its valid-host flag in the remote region.

## 8.7.2 Sending a Packet

When a host has a packet to send, it looks through its list of valid hosts. For each host marked as valid, the local host checks the remote host's IP address against the packet's destination address. If no addresses match, the local host should indicate to the process sending the packet that the destination host doesn't exist.

Assuming a match is found, the following steps are taken. Assume that "X" is the host number of the remote host.

- 1. If the remote's state (according to its state entry in the local region) is zero, queue the packet up for later transmission or discard it.
- 2. Set the remote's state to zero.

- 3. Copy the packet, including IP headers, into the local packet buffer corresponding to the remote's host number. If there is non-IP header material at the beginning of the packet, it is not copied; only IP packets are placed in the packet buffers.
- 4. Set the local length entry corresponding to the remote's host number to the size of the packet.
- 5. Set the packet-ready flag corresponding to the *local* host number in the remote's ONC/VME region.

Send a VME mailbox interrupt to the remote host. The contents of the mailbox are ignored.

At this point, the first stage of packet transmission is finished. It is usual to exit the network driver, though the protocol allows for synchronous operation if desired.

Assuming the protocol is running asynchronously, when a mailbox interrupt is received by the local host, it does the following:

- 1. Check its local packet-ready flags. If any are set, a remote host has a packet for the local host. See "Receiving a Packet," below.
- 2. Check the states in its local region. If a state is 1, set it to 2, and send the next queued packet, if any, for the appropriate remote host.

## 8.7.2.1 Broadcast Packets

If a packet's destination address indicates that it should be broadcast to the entire ONC/VME network, simply send the packet separately to each host marked as valid in the local region.

## 8.7.3 Receiving a Packet

Packet receipt is initiated by the mailbox interrupt. When a mailbox interrupt is received, the local host does the following:

- 1. Check its local packet-ready flags. If none are set, the mailbox interrupt is an acknowledgement of packet receipt; see the previous section.
- 2. For each packet-ready flag, copy the packet from the local host's packet buffer in the remote ONC/VME region. The length of the packet is, of course, determined by reading the local host's packet length entry from the remote's memory.
- 3. Set the local host's state in the remote region to 1, meaning that the local host has received the packet and will no longer examine the remote's region.
- 4. Send a mailbox interrupt to the remote.
- 5. Process the packet appropriately for the local operating system.

Note that with the exception of setting the packet-ready flag, the sending side does not access the receiving side's ONC/VME memory region. The receiver performs almost all the VME memory accesses.

It is convenient, though not required, to set the remote's valid-host flag in the local region whenever a packet is received, in case the remote was marked invalid temporarily (see "Error Handling" and "Shutting Down" below.)

## 8.7.3.1 Shutting Down

To remove a host from a ONC/VME network, set its valid-host entry in all remote hosts' regions to zero. Set the local magic number to an invalid value.

## 8.7.3.2 Error Handling

If a host is removed from the network, remote systems will not be able to access its memory properly. This will usually result in a data access exception such as a timeout. The local operating system should handle such exceptions, noting when they occur during the processing of an ONC/VME packet. When an exception occurs during ONC/VME processing, set the valid-host flag of the offending host to zero, so that no further packets can be sent to that host.

2