

Programmable System<sup>™</sup> Devices

PSD

*Design and Applications Handbook* 1990



3350 Scott Blvd. Bldg. #44 • Santa Clara, CA 95054-3120



## **Programmable System<sup>™</sup> Devices** (PSD) Design and Applications Handbook

*1990* 

Copyright © 1990 WaferScale Integration, Inc. (All rights reserved.)

47280 Kato Road, Fremont, California 94538 415-656-5400 Facsimile: 415-657-5916 Telex: 289255

Printed in U.S.A.

. .



# **General Information PSD Product Specifications PSD Development Systems** 5 **PSD** Applications Article Reprint Package Information 6 Sales Representatives and Distributors

## Section Index

| General     | Table of Contents      | 1-1 |
|-------------|------------------------|-----|
| Information | Introduction to PSDs 1 | 1-3 |
|             | Company Profile        | 1-5 |
|             | Ordering Information   | 1-9 |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.

WAFERSCALE INTEGRATION, INC.



Table of Contents

## General Information Table of Contents 1-1 Introduction to PSDs 1-3 Company Profile 1-5 Ordering Information 1-9

| <b>PSD Product</b><br>Specifications | MAP168/PSD301<br>Introduction | User-Configurable Peripheral with Memory2-1 |
|--------------------------------------|-------------------------------|---------------------------------------------|
|                                      | MAP168                        | User-Configurable Peripheral with Memory2-5 |
|                                      | PSD301                        | User-Configurable Peripheral with Memory    |
|                                      | PAC1000 Introduction          | User-Configurable Microcontroller           |
|                                      | PAC1000                       | User-Configurable Microcontroller           |
|                                      | SAM448 Introduction           | User-Configurable Microsequencer            |
|                                      | SAM448                        | User-Configurable Microsequencer            |

|         | MAP168 — PSD Development Systems                             | 3-1 |
|---------|--------------------------------------------------------------|-----|
| Systems | SAM448 — PSD Development Systems3                            | -5  |
|         | PAC1000 — PSD Development Systems                            | -9  |
|         | WS6000 MagicPro <sup>™</sup> Programmer and Package Adaptors | 13  |

| <b>PSD</b> Applications | Application Note 002 | Introduction to the MAP168 User-Configurable Mappable Memory Subsystem4-1 |
|-------------------------|----------------------|---------------------------------------------------------------------------|
|                         | Application Note 010 | PAC1000 Introduction4-13                                                  |
|                         | Application Note 005 | PAC1000 as a High-Speed Four-Channel DMA Controller4-39                   |

| Table of Contents                            |                       |                                                                                    |
|----------------------------------------------|-----------------------|------------------------------------------------------------------------------------|
| PSD Applications<br>(Cont.)                  | Application Brief 006 | PAC1000 as a 16 Bi-Directional Serial<br>Channel Controller                        |
|                                              | Application Note 008  | PAC1000 User-Configurable Microcontroller with a Built-In-Self-Test Capability4-75 |
|                                              | Application Note 009  | In-Circuit Debugging for the PAC1000 User-Configurable Microcontroller4-83         |
|                                              | Application Brief 007 | Hardware Interfacing`the PAC1000 as a<br>Micro Channel Bus Controller4-99          |
|                                              | Application Note 003  | High-End SAM Applications Using Microassembler Design Entry4-105                   |
|                                              | Application Note 004  | SAM Applications Using State Machine Design Entry4-127                             |
| Article Reprint                              | Microprogram an Embe  | edded Controller — PAC10005-1                                                      |
| Package<br>Information                       |                       |                                                                                    |
| Sales<br>Representatives<br>and Distributors |                       |                                                                                    |



### Introduction to Programmable System<sup>™</sup> Devices (PSD)

Programmable System Devices, or PSDs, are user-configurable system level building blocks on-a-chip enabling quick implementation of application specific controllers and peripherals.

WSI PSDs are ideal for designers who require fast time-to-market, low risk, greater system integration and lower power consumption. PSDs enable designers to configure their microcontroller/peripheral to meet exact design requirements. WSI's PSDs are unique in that they are the only VLSI devices available today that provides a user-configurable off-the-shelf solution at the system level.

The user-configurability of PSDs enables them to be used in many different applications, including:

- Computers (Workstations and PCs) Fixed Disk Control, Modem, Imaging, Laser Printer Control
- Telecommunications Modem, Cellular Phone, Digital PBX, Digital Speech, FAX, Digital Signal Processing
- Industrial Robotics, Power Line Access, Power Line Monitor
- Medical Instrumentation Hearing Aids, Monitoring Equipment, Diagnostic Tools
- Military Missile Guidance, Radar, Sonar, Secure Communications, RF Modems

PSDs are available in a variety of space saving surface mount and through-hole package configurations for commercial, industrial, and military applications. WSI offers windowed package options for prototyping and low cost OTP (one-time programmable) packages for high volume applications. PSDs utilize WSI's proprietary split-gate CMOS EPROM technology for low power consumption.

There are currently four PSD family devices in production. These include the PAC1000, MAP168, PSD301, and SAM448.

- The PAC1000 is a user-configurable microcontroller. It may be used as a stand-alone microcontroller or as a peripheral to microprocessors. It is ideal for embedded control applications, including graphics, local area network, and disk drive control in both military and commercial applications.
- The MAP168 is a user-configurable peripheral. It is used in DSP applications including modems, motor control and medical instrumentation. The MAP168 is ideal for DSP based applications where fast time-to-market, small form factor and low power consumption are essential. When combined together in an 8- or 16-bit system, virtually any DSP chip (TMS320 series, etc.) and the MAP168 work together to create a very powerful 2-piece chip-set. This combination provides essentially all of the required control and peripheral element of a DSP system.
- □ The PSD301 is a user-configurable peripheral for microcontroller applications including disk drives, low cost modems, and mobile phones. The PSD301 is ideal for microcontroller based applications where fast time-to-market, small form factor and low power consumption are essential. When combined together in an 8- or 16-bit system, virtually any microcontroller (8051, 8096, 16000, etc.) and the PSD301 work together to create a very powerful 2-piece chip-set. This implementation provides the required control and peripheral element of a microcontroller based system peripheral with no external "glue" logic required.
- The SAM448 is a user-configurable sequencer for state machine and bus interface applications. Its flexible I/O and architecture make it ideal for use in interfacing to both existing bus architectures (AT, VME, MCA-bus), and evolving bus standards (EISA, NuBUS).

Application specific features can be easily programmed into the PSD EPROM array for quick design implementation. Unlike the current generation of programmable gate arrays, which require the use of unpredictable, and often time unavailable routing resources, all PSD logic is fully connected internally. This means that all timing is predictable ahead of design implementation, and routing is assured. This greatly simplifies and reduces the design implementation and simulation process, and provides designers with a significantly more reliable. lower risk path to market, WSI PSDs also eliminate the NRE, turn-around-time, and risks associated with gate arrays and other ASIC solutions.

As product life cycles continue to shrink, designers can win the race from idea to marketable product with WSI PSDs. PSDs are quickly configured and programmed by the designer by using low cost, easy-touse WSI PC-based development tools. The user-friendly menu-driven software includes high level design entry, simulation and programming packages for rapid system development.

WSI supports its PSD product family with an applications hotline and bulletin board, as well as highly trained, technical Field Applications Engineers. As standard products, WSI PSDs are available from WSI's franchised world-wide distribution network.

## **Company Profile**



#### Introduction

WaferScale Integration, Inc. (WSI) designs and produces the world's broadest and fastest families of CMOS PROMs, RPROMs, EPROMs, and Programmable System<sup>™</sup> Devices (PSD). These product families target the needs of system designers who must reduce system development time and deliver market competitive products in continuously shorter periods of time. WSI's programmable VLSI products additionally enable higher system performance from smaller, more compact end products due to higher levels of system integration at the chip level.

WSI's mission is clear — to build a great company by serving its customers with a portfolio of high-performance programmable VLSI products that enable designers to achieve faster time to market with new, advanced electronic systems.

The company's patented self-aligned, splitgate EPROM technology forms the core of WSI's programmable products and delivers higher performance and greater density than competing "stacked gate" EPROM technologies. This core technology has enabled WSI to be first in the industry with numerous breakthroughs in speed, density, process and packaging. WSI has leveraged this technology into the broadest family of CMOS PROMs, RPROMs, and EPROMs available. WSI's new "off the shelf" user-configurable PSDs provide system level building blocks on a single chip that enable quick implementation of application specific controllers and peripherals. They are the first to integrate high-performance EPROM, SRAM and logic and deliver a performance and integration breakthrough to the programmable products market. PSDs are user-configurable on a PC or compatible and can be tailored for use in a variety of system applications. As a result, WSI has established itself as a leading supplier of high-performance programmable VLSI solutions to a broad customer base that includes some of the world's largest and most technologically advanced electronics companies.

Founded in 1983, WSI is headquartered in a 66,000 square foot facility in Fremont, California and has more than 125 employees. Through a long-term equity, manufacturing and technology license agreement with Sharp Corporation of Japan, WSI produces its products in a world-class products in facility that guarantees the highest quality at competitive costs.

#### Markets and Applications

WSI's high-performance non-volatile memory and PSD products are used by the world's leading suppliers of highperformance electronic systems in communications, data processing, military and industrial markets. Customer end products cover a broad spectrum and typically include cellular telephones, workstations, DSP computers, navigation controllers, T1 multiplexers, modems, image processors, missiles, LAN controllers, high density disk drives and the like. Customer applications include image processing, digital signal processing, bus control, LAN data and file control, real time process control, graphics processing, hard disk control, flight simulators, DMA control, and others. WSI products are ideally suited for these applications where designers are faced with increasingly shorter product life cycles and must develop new, competitive high-performance products in short periods of time.

1-5

#### **Products**

#### Memory Products

#### **EPROM**s

WSI offers the broadest line of CMOS EPROM products available featuring architectures ranging from  $8K \times 8$  to  $128K \times 8$ , plus several  $\times 16$  products, with speeds ranging from 40 to 200 ns. Commercial, industrial and MIL-STD-883C/ SMD products are available. A wide variety of package selections are available including plastic and hermetic, throughhole and surface mount types.

#### "L' Family

WSI's "L" family memory products are the industry's fastest, low power JEDEC pinout EPROMs and meet the requirements of many mainstream system applications. With speeds ranging from 90 to 200 ns and architectures from 8K × 8 to 128K × 8 including several ×16 products, "L" family EPROMs are ideal for high-performance personal computers and workstations. Taking advantage of its split-gate EPROM technology, WSI uses a conservative 1.2 micron lithography to achieve world-class memory densities that traditionally require lower yielding sub-micron technologies.

#### "F" Family

The "F" family is WSI's fastest line of EPROMs, featuring speeds ranging from 40 to 110 ns and architectures from  $8K \times 8$  to  $32K \times 8$ , plus several  $\times 16$  products. The high speed and word width options of the "F" family EPROMs make them attractive for use in high-end engineering and scientific workstations, data communications and other high-performance applications.

#### **RPROM**s

RPROMs provide bipolar PROM pin-out with matching speed and CMOS low power operation. The RPROM (Re-Programmable Read Only Memory) product series includes architectures ranging from  $2K \times 8$  to  $32K \times 8$  with speeds ranging from 25 to 70 ns.

Commercial, industrial and MIL-STD-883C/ SMD configurations are available in a variety of hermetic and plastic package styles.

#### Programmable System<sup>™</sup> Devices (PSDs)

WSI's family of Programmable System Devices (PSDs) represent a new class of programmable VLSI products, achieving unparalleled levels of performance, configurability and integration. Offering a significantly higher level of integration over programmable logic, PSDs are the first programmable VLSI products to integrate high-speed EPROM. SRAM and logic on a single chip thereby providing complete system solutions to the design engineer. PSDs are off-the-shelf system building elements that can be quickly configured and programmed for a variety of system applications thus enabling system designers to shorten system development time.

The PSD is a new solution for system designers who build high-end systems around embedded controllers and advanced microprocessors. These new systems require faster, more highly integrated and lower cost VLSI solutions as well as rapid design cycles. WSI's new PSD family meets this demanding set of needs.

The initial members of WSI's PSD family includes:

- The PAC1000 User-Configurable Microcontroller
- The MAP168 User-Configurable Peripheral with Memory
- The PSD301 User-Configurable Peripheral with Memory
- The SAM448 User-Configurable Microsequencer

| Products                   | –<br>Design Tools and Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Custom Circuits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Cont.)                    | WSI's development tools minimize the time<br>required for designers to program PSDs<br>for use in a variety of system applications.<br>PSDs are supported with complete easy-<br>to-use program development, simulation<br>and programming software, the PC hosted<br>MagicPro <sup>™</sup> Memory and PSD Programmer,<br>a dial-in applications bulletin board and<br>WSI's team of factory and field<br>applications engineers. As a result, WSI<br>customers achieve their goal of shorter<br>system development time and reach new<br>markets sooner.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | To serve the needs of its customers with<br>unique requirements, WSI offers its custom<br>circuit capability using its cell based library<br>of EPROM, static RAM and logic functions.<br>Standard products described in this catalog<br>can usually be modified on a custom basis<br>to serve particular requirements. New<br>customer defined custom products that<br>incorporate high-performance non-volatile<br>memory, SRAM and logic can be<br>produced that deliver significant speed or<br>system integration advantages. Contact<br>your local WSI sales office for additional<br>information.                                                                                                                                                                                                                                                       |
| Manufacturing              | A key ingredient for success in leading-<br>edge semiconductors is a world-class<br>fabrication facility that ensures high<br>volume capacity and prompt delivery of<br>highly reliable and high yielding VLSI<br>circuits. To this end, WSI has licensed its<br>proprietary CMOS EPROM and logic<br>process technology to Sharp Corporation<br>of Osaka, Japan. This long term alliance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ensures high quality, high-volume<br>production, competitive costs and fast<br>delivery. The Sharp facility in Fukuyama,<br>Japan employs the most advanced sub-<br>micron VLSI integrated circuit manufacturing<br>equipment available including ion<br>implantation, reactive ion etch, and wafer<br>stepper lithographic systems.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Quality and<br>Reliability | WSI is deeply committed to product<br>excellence. This begins with proper<br>management attitude and direction and<br>with this focus, the Quality and Reliability<br>Program is able to operate efficiently. As a<br>result, product quality becomes part of<br>each employee's responsibility.<br>Quality and Reliability begin with the<br>proper product and process designs and is<br>supported by material and process controls.<br>Examples are products manufactured on<br>an epitaxial silicon layer to reduce latch-up<br>sensitivity, all pins are designed to<br>withstand >2,000 volts ESDS, numerous<br>ground taps are used which increases<br>product noise immunity, metal traces are<br>designed to carry a current density of<br>>2.0 × 10 <sup>5</sup> amps/cm <sup>2</sup> , top passivation<br>extends over into the scribe lane to seal<br>the die edges, data retention is performed<br>100% on re-programmable products (T <sub>A</sub> =<br>+225°C, T = 72 hours), automated die<br>attach and bonding is used extensively,<br>wafers are fabricated in a Class 10 clean | are inspected before use, and statistical controls are used to keep the process on course.<br>Product and process introductions or changes are routinely evaluated for worthiness. Life tests are conducted at higher than typical stress levels ( $T_A = +150^{\circ}$ C, $V_{CC} = +6.5V$ ) and even at these stress levels, WSI products have demonstrated low failure rates (see the Quality and Reliability section in the WSI 1990 databook).<br>WSI is active in Military programs and its Quality and Reliability System supports Compliant Non-Jan products. WSI also supports DESC's (Defense Electronics Supply Center) Standardized Military Drawings (SMD) program. As of October, 1989, WSI has eighteen products on SMDs with additional products not on SMDs are available per MIL-STD-883C. See Section 7 (Military Products) in the WSI 1990 |

room, raw materials, chemicals and gases

Sales Network

WSI's international sales network includes regional sales managers, field applications engineers, manufacturers representatives and many of the leading component distributors in the United States, Europe and Asia. See Section 7.

#### **United States**

Direct sales and field applications engineering offices in Boston, Chicago, Huntsville, Philadelphia, Los Angeles areas and Fremont, CA; more than 25 manufacturers' representatives for major national accounts; national distributors including Schweber Electronics, Time Electronics and Wyle Laboratories; and regional distributors.

#### International

Distributors in West Germany, England, France, Italy, Sweden, Finland, Denmark, Norway, Spain, Belgium, Luxembourg, the Netherlands, and Israel. Distributors for the Asia/Pacific Rim region in Japan, Korea, Taiwan, Hong Kong and Australia.



## **Ordering Information**

## High-Performance CMOS Products







## Section Index

| PSD Product<br>Specifications | MAP168/PSD301<br>Introduction | User-Configurable Peripheral with Memory2-1   |
|-------------------------------|-------------------------------|-----------------------------------------------|
|                               | MAP168                        | User-Configurable Peripheral with Memory      |
|                               | PSD301                        | User-Configurable Peripheral with Memory 2-23 |
|                               | PAC1000 Introduction          | User-Configurable Microcontroller             |
|                               | PAC1000                       | User-Configurable Microcontroller             |
|                               | SAM448 Introduction           | User-Configurable Microsequencer              |
|                               | SAM448                        | User-Configurable Microsequencer              |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.

WAFERSCALE INTEGRATION, INC.



## Programmable System™Device

MAP168/PSD301 Introduction

#### User-Configurable Peripheral with Memory

Overview

In 1988 WSI introduced a new concept in programmable VLSI: the Programmable System<sup>™</sup> Device (PSD). The PSD is defined as a family of *User-configurable* system level building blocks on-a-chip enabling quick implementation of application specific controllers and peripherals. The first generation PSD series includes the MAP168, a User-Configurable Peripheral with Memory; the SAM448, a User-Configurable Microsequencer; and the PAC1000, a User-Configurable Microcontroller.

The MAP168 is a high-performance, userconfigurable peripheral with memory. It is used in DSP applications including modems, motor control and medical instrumentation. The MAP168 is ideal for DSP based applications where fast time-tomarket, small form factor and low power consumption are essential. When combined together in an 8- or 16-bit system, virtually any DSP chip (TMS320 series, etc.) and the MAP168 work together to create a very powerful 2-piece chip-set. This implementation provides the core of the required control and peripheral elements of a DSP system. The MAP168 contains three elements normally associated with discrete solutions to system memory requirements. It incorporates EPROM and SRAM plus a Programmable Address Decoder (PAD), all on the same die. The MAP168 is ideal for the systems designer who wishes to reduce the board space of his final design. By using the MAP168 in a system, five or six EPROM, SRAM and decode logic chips may be reduced into a single 44 pin PLDCC, CLDCC or PGA package.

The second generation PSD301 is a userconfigurable peripheral for microcontroller applications including disk drives, low cost modems, and mobile phones. The PSD301 is ideal for microcontroller based applications where fast time-to-market, small form factor and low power consumption are essential. When combined together in an 8- or 16-bit system, virtually any microcontroller (8051, 8096, 16000, etc.) and the PSD301 work together to create a very powerful 2-piece chip-set. Together, this implementation provides all the required control and peripheral elements of a microcontroller based system peripheral with no external "glue" logic required.

#### Architecture

The MAP168 and PSD301 products incorporate the flexibility of using discrete memory addressing and decoding. With the support of WSI's user friendly PSD software called MAPLE, designers may configure their MAP168/PSD301 subsystems for 8 or 16 bit data paths. If the host system uses an 8051 microcontroller, the MAP168/PSD301 can be programmed with an eight bit data path. A sixteen bit data path can be programmed for microcontrollers like Intel's 80196. The depth of the memory organization will be modified accordingly to accept the different data path widths. The low cost MAPLE software package will handle the data path width adjustment automatically. The user can select either 16K bytes of EPROM and 4K bytes of SRAM or 8K words of EPROM

and 2K words of SRAM. The flexibility of the MAP168/PSD301 products enables two devices to be cascaded in width. It is possible to double the memory size of a sixteen bit system by using two MAP168 products in parallel but programmed in a byte-wide configuration. For example, with two MAP168 devices, 16K words of EPROM and 4K words of SRAM may be organized as upper and lower data bytes of a 16 bit word. Alternately, two MAP168 chips may expand the system memory vertically as two word organized memory devices. A block diagram of the MAP168 is shown in Figure 1.

An important feature of the MAP168/PSD301 products is their ability to incorporate the memory address decoding on-chip. One

Architecture (Cont.)

MAP168 memory peripheral can reside with other MAP168 devices in the same memory addressing scheme, with the onchip decoder allocating the memory blocks to different non-conflicting segments of the entire memory area. The decoding function is achieved by an on-chip feature called a Programmable Address Decoder (PAD), which is similar to a single fuse array programmable logic device supporting one product term (AND gate) per output in the MAP168 and four product terms per output in the PSD301.

In the MAP168, eighteen standard chip select outputs from the PAD are available with one fast chip select output generally used to select other external high speed memory devices. The chip select lines may be subdivided into ES0–ES7, active low internal EPROM chip selects, and two internal RAM chip selects RS0 and RS1. In byte-wide applications, eight chip select outputs drive external pins CS0–CS7. These can be used as external chip selects for other MAP168 devices or system memory. These outputs are not available for word-wide MAP168 configurations because the CS0–CS7 output pins carry the higher order data byte. Only FCS0 is available for external chip selection.

Figure 1 shows the organization of the EPROM and SRAM in relation to the PAD, for the MAP168 device.



#### Important Features:

- 40 ns EPROM/SRAM Access Time.
- Byte or Word Operation, Mappable into 1M Word or 2M Byte Address Space
- 22 ns Chip-Select 8 Outputs, 17 ns Fast Chip Select Output.
- 128K EPROM Bits, 32K SRAM Bits, On-Chip Programmable Decoder, Security Bit.

#### Figure 2. PSD301 Family Architecture



|                                   | By 8 Co                                                                                                             | nfiguration                                                                       | By 16 Con                                                                                                           | figuration                                                           |                                                                                    |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------------|
|                                   | Port A                                                                                                              | Port B                                                                            | Port A                                                                                                              | Port B                                                               | Port C                                                                             |
| Non-MUX Address Data <sup>5</sup> | D <sub>0</sub> –D <sub>7</sub>                                                                                      | CS <sub>0</sub> –CS <sub>7</sub> or<br>PB <sub>0</sub> –PB <sub>7</sub>           | D <sub>0</sub> -D <sub>7</sub> <sup>4</sup>                                                                         | D <sub>8</sub> –D <sub>15</sub>                                      | CSCS6                                                                              |
| MUX Address Data                  | A <sub>0</sub> -A <sub>7</sub> <sup>4</sup><br>PA <sub>0</sub> -PA <sub>7</sub><br>AD <sub>0</sub> -AD <sub>7</sub> | CS <sub>0</sub> -CS <sub>7</sub> <sup>4</sup><br>PB <sub>0</sub> -PB <sub>7</sub> | A <sub>0</sub> -A <sub>7</sub> <sup>4</sup><br>PA <sub>0</sub> -PA <sub>7</sub><br>AD <sub>0</sub> -AD <sub>7</sub> | CS <sub>0</sub> –CS <sub>7</sub><br>PB <sub>0</sub> –PB <sub>7</sub> | CS <sub>8</sub> –CS <sub>10</sub> <sup>6</sup><br>A <sub>16</sub> –A <sub>18</sub> |

#### NOTES:

1. Three MAP300 EPROM densities.

2. Internal signal can be set during programming.

3. Latch B can be set to be transparent (not dependent on ALE).

4. Each I/O pin can be individually set to perform one of the two functions.

5. The non-MUX configuration is compatible to MAP168 pinout.

6. Port C is independent of any configuration and can be chip select out or address in.

#### Software Support

The object code generated for the support microprocessor/microcontroller is generated by an assembler. This code, when generated as an Intel MCS file, may be easily programmed into the EPROM section of the MAP168/PSD301 device because the MAPLE software has been designed to accept this standard format.

The programmable address decoder is used to define the mapping of the various

EPROM and SRAM memory blocks. This mapping is achieved by the designer in the MAPLE environment. The software provides a safeguard that prevents the designer from inadvertently overlapping the address selection. After selecting the memory block assignments, the MAP168/PSD301 device may be programmed by the WSI MagicPro<sup>™</sup> memory and PSD programmer.



WAFERSCALE INTEGRATION, INC.

## Programmable System<sup>™</sup> Device

### MAP168 User-Configurable Peripheral with Memory

| Features                             | <ul> <li>First-generation Programmable System<br/>Device (PSD)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <ul> <li>Programmable Security</li> <li>Protects memory map</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                      | User-Configurable Peripheral with<br>Memory<br>16Kx8 EPROM<br>4Kx8 SRAM<br>Programmable address decoder<br>Byte or Word Memory Configurations<br>16Kx8 or 8Kx16 EPROM<br>4Kx8 or 2Kx16 SRAM<br>2Mbyte or 1 Mword address range<br>High-Speed Operation<br>40-nsec memory access<br>17-nsec fast chip select output<br>External Chip Select Outputs<br>8 external chip selects<br>1 fast chip-select output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <ul> <li>Protects program code</li> <li>Programming Support Tools</li> <li>PSD integrated software environment</li> <li>PC-XT/AT/PS2 platform support</li> <li>MAPLE location entry Software</li> <li>MAPPRO device programming Software</li> <li>MagicPro device programmer (PC-XT, AT)</li> <li>Military and Commercial Specifications</li> <li>44-pin Ceramic Leaded Chip Carrier</li> <li>package</li> <li>44-pad Ceramic Leadless Chip Carrier</li> <li>package</li> <li>44-pin Ceramic Leadless Chip Carrier</li> <li>package</li> <li>Plastic Leadless Chip Carrier</li> <li>package</li> <li>Plastic Leadless Chip Carrier</li> <li>package</li> <li>Plastic Leadless Chip Carrier</li> <li>Plastic Leadless Chip Carrier</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                               |
| <i>General</i><br><i>Description</i> | In 1988 WSI introduced a new concept in<br>programmable VLSI, Programmable System<br>Devices (PSD). The PSD family consists of<br>user-configurable system-level building<br>blocks on-a-chip, enabling quick implementa-<br>tion of application-specific controllers and<br>peripherals. The first generation PSD series<br>includes the MAP168 User-Configurable<br>Peripheral with Memory; the SAM448, a<br>User-Configurable Microsequencer; and the<br>PAC1000, a User-Configurable Microcon-<br>troller.<br>The MAP168 is the first of WSI's Program-<br>mable System Devices (PSD) product line.<br>The device integrates high performance,<br>user-configurable blocks of EPROM, SRAM,<br>and logic in a single circuit. The major<br>functional blocks include a Programmable<br>Address Decoder (PAD), 16K bytes of high<br>speed EPROM, and 4K bytes of high speed<br>SRAM. A block diagram is given in Figure 1.<br>The MAP168 device is a complete memory<br>subsystem that can be mapped anywhere in<br>a 2M-byte address space of a microproces-<br>sor or microcontroller system. The EPROM<br>and SRAM memory blocks can be user-<br>configured in either byte-wide or word-wide | cantly reduces the board space and power<br>necessary to implement memory subsys-<br>tems, increases system performance, and<br>provides for secure data or program storage.<br>The device's high level of integration and<br>flexibility make it ideal for high-speed micro-<br>processors, microcontrollers, and Digital<br>Signal Processors like the TMS320XX family<br>The EPROM can be configured either as<br>16Kx8 or 8Kx16. The SRAM can be config-<br>ured either as 4Kx8 or 2Kx16. Individual<br>memory blocks of 2Kx8 or 1Kx16 can be<br>selectively mapped anywhere in the address<br>space. Since the Chip Select Input (CSI) car<br>be programmed as A20, the highest-order<br>address bit, the device's address range can<br>extend from 1M byte with CSI to 2M byte<br>without CSI.<br>For 16-bit microprocessors capable of byte<br>operations, the MAP168 device provides a<br>Byte High Enable input for accessing bytes<br>on any address boundary.<br>Pinout is compatible with the JEDEC<br>WS27C257 256K high-speed EPROM. This<br>pinout provides for memory expansion with<br>future WSI EPROM and PSD products. |

WAFERSCALE INTEGRATION, INC. 2-5



#### 2-6 WAFERSCALE INTEGRATION, INC.

2

| General<br>Description<br>(Con't) | programmed usi<br>programmer use<br>devices. Two so<br>Location Entry a<br>gramming Softw<br>menu-driven WIS<br>on an IBM® PC ><br>platform.                                                                                                                | d to program of<br>ftware package<br>nd MAPPRO D<br>are are availabl<br>SPER software | her WSI<br>s, MAPLE<br>evice Pro-<br>e in the<br>environment | For additional information on the MAP168<br>device, refer to <i>Application Note No. 002,</i><br><i>Introduction to the MAP168 User-Configur-<br/>able Peripheral with Memory.</i> For additional<br>information on development and program-<br>ming software for the MAP168 device, refer<br>to the <i>MAP168 User-Configurable Peripheral</i><br><i>with Memory Software User's Manual.</i> |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functional<br>Description         | The user-configurable architecture of the<br>MAP168 consists of an EPROM memory<br>block, an SRAM memory block, and a fast<br>Programmable Address Decoder (PAD) that<br>can be configured to select 2K-byte memory<br>blocks anywhere in a 2M-byte address |                                                                                       | l memory<br>and a fast<br>er (PAD) that<br>cyte memory       | range. The device can be programmed to<br>operate with memory configured either in a<br>byte or word organization (bytes can be<br>addressed in word mode). A programmable<br>security bit prevents access to the PAD<br>address-decode configuration table.                                                                                                                                  |
| Table 1.<br>Pin Description       | Signal                                                                                                                                                                                                                                                      | 1/0                                                                                   | Description                                                  | ·                                                                                                                                                                                                                                                                                                                                                                                             |

| Signal                                  | I/O | Description                                                                                                                                                                                                                                                 |
|-----------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0-19</sub>                       | I   | Address Lines. For access to EPROM or SRAM.                                                                                                                                                                                                                 |
| FCSO                                    | 0   | Fast Chip-Select Output (active low). Used by the Pro-<br>grammable Address Decoder (PAD).                                                                                                                                                                  |
| BHE                                     | I   | Byte High Enable (active low). Selects the high-order byte when writing to SRAM.                                                                                                                                                                            |
| WE/V <sub>pp</sub>                      | I   | <i>Write Enable (active low) or Programming Voltage.</i> In normal mode, this pin causes data on the I/O pins to be written into SRAM. In programming mode, the pin supplies the programming voltage, V <sub>pp</sub> .                                     |
| ŌĒ                                      | I   | Output Enable (active low). Enable the I/O pins to drive the external bus.                                                                                                                                                                                  |
| CSI/A <sub>20</sub>                     | I   | Chip Select Input (active low) or High-Order Address.<br>This pin can be programmed as the bus-access chip<br>select or as an additional high-order address bit $(A_{20})$ .                                                                                |
| I/O <sub>0-7</sub>                      | I/O | Low-Order Byte of EPROM or SRAM.                                                                                                                                                                                                                            |
| I/O <sub>8-15,</sub> CSO <sub>0-7</sub> | I/O | High-Order Byte or Chip-Select Outputs. In word mode, these pins serve as the high-order byte $(I/O_{8-15})$ of EPROM or SRAM. In byte mode, the bits serve as Chip-Select Out signals $(\overline{CSO}_{0-7})$ for the Programmable Address Decoder (PAD). |

#### Programmable Address Decoder

The MAP168 device has a minimum of 20 address inputs  $A_0-A_{19}$  allowing the EPROM and SRAM memory blocks to reside anywhere in a 1M-byte address space. If the  $\overline{CSI}/A_{20}$  input is user-configured as an address line, the maximum addressable space increases to 2M bytes, as shown in the Configurations table.

The 16K bytes of EPROM and 4K bytes of SRAM, can be configured into eight independent 2K-byte blocks and two 2K-byte blocks respectively, as shown in the Memory Architecture figure. The PAD is a userconfigurable address decoder that compares input addresses to the 2K-byte address range selected for each of the eight EPROM blocks and two SRAM blocks. When the input address A<sub>0</sub>-A<sub>20</sub> is detected to be within one of the EPROM or SRAM address ranges, the PAD enables an internal chip select (ES<sub>0</sub>-ES<sub>7</sub> or RS<sub>0</sub>-RS<sub>1</sub>) to the selected block. If no block is selected, both the EPROM and SRAM memories remain in a power-down mode and the outputs are disabled allowing other devices to drive the

data bus. The SRAM retains its data in the power-down mode. The 2K-byte address ranges for any of the eight EPROM or two SRAM blocks may not overlap.

The PAD can also be user-configured to generate up to eight external chip selects,  $\overline{CS}_0-\overline{CS}_7$ . These outputs can be used to decode the input address lines  $A_0-A_{20}$  and to select other devices in the system. The outputs  $\overline{CS}_0-\overline{CS}_7$  are available on the eight higher-order  $I/O_{0.5}$  lines but only when the MAP168 device is configured in the byte mode; the lines are not available as chipselect outputs when the device is configured in the word mode.

The  $\overline{\text{CSI}}/\text{A}_{20}$  input is user-configurable as the most-significant address line or as an active-low chip enable. Its function is programmed as part of the PAD programming cycle.

The PAD also provides  $\overline{FSCO}$ , a single, fast chip-select output configurable by the user for any address. It can overlap with any of the internal EPROM, SRAM or external  $\overline{CSO}$  addresses.

#### Memory Subsystem EPROM Memory

The memory configuration of the MAP168 device includes 128K bits of WSI's patented high-speed, split-gate, UV-erasable EPROM. The EPROM is configured in byte mode as 16Kx8 and in word mode as 8Kx16. The memory is organized as eight 2Kx8 or 1Kx16 blocks, as shown in the Block Diagram figure. Each block has a separate and independent address range that cannot overlap. Each block is individually selected by one of the ES\_-ES, internal chip selects generated by the PAD when an input address is detected within its designated address range, as shown in the Memory Architecture figure. If not selected, each block of EPROM remains in a power-down mode.

For programming, the EPROM memory requires the  $\overline{WE}/V_{_{PP}}$  input to maintain the programming voltage  $V_{_{PP}}$ .

#### SRAM Memory

The device also includes 32K bits of highspeed SRAM. The SRAM is configured in byte mode as 4Kx8 and in word mode as 2Kx16. The memory is organized as two 2Kx8 or one 2Kx16 block(s), each with a separate and independent address range that cannot overlap. Each SRAM block is individually selected by one of the RS<sub>0</sub>–RS<sub>1</sub>, shown in the Memory Architecture figure, when an input address is detected by the PAD within its designated address range. When not selected, each of the SRAM memory blocks remains in a power down mode but does retain all data stored.

Data can be written into the SRAM only when the  $\overline{WE}/V_{_{PP}}$  input is active low.

| Memory<br>Subsystem<br>EPROM Memory | Byte/Word Mode<br>The PAD can be programm<br>the MAP168 device for eithe                                                                                                                                                                    |                                                                                          | output lines I                                                                   | e on the eight high-o<br>/O <sub>8</sub> –I/O <sub>15</sub> and enable<br>hen the OE input is I                                                                                       | d onto the                                                       |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| (Con't)                             | memory architecture. This a<br>to be used conveniently with<br>16-bit microcontrollers, micr<br>digital signal processor (DS<br>the Configurations table.                                                                                   | h either 8-bit or<br>oprocessors or                                                      | 8Kx16 and th<br>of both are tid                                                  | e, the EPROM is org<br>le SRAM as 2Kx16.<br>ed to the 16 input/ou<br>d enabled onto the b                                                                                             | The output<br>tput lines                                         |
|                                     | In byte mode, the EPROM i<br>16Kx8 and the SRAM as 4<br>of both are tied to the eight<br>output lines I/O <sub>0</sub> –I/O <sub>7</sub> and e<br>output bus when the OE inp<br>Only when configured in by<br>eight external chip selects p | X8. The outputs<br>low-order input/<br>nabled onto the<br>out is low.<br>te mode are the | address inpu<br>16-bit word o<br>be selected a<br>Selection tab<br>16-bit proces | e, the BHE input alor<br>t A0 allows the eight<br>n an even or odd bo<br>is shown in the High<br>le. This is a useful fe<br>sors that are not res<br>iting memory only on<br>ndaries. | bits of any<br>undary to<br>-Low Byte<br>ature for<br>tricted to |
| Mode Selection                      | The device's operational mode is controlled are ten separate modes of operation, all of by three inputs, $\overline{CSI}$ , $\overline{OE}$ , and $\overline{WE}/V_{PP}$ . There which are shown the Mode Selection table                   |                                                                                          |                                                                                  |                                                                                                                                                                                       |                                                                  |
| Table 2.<br>Configurations          | F                                                                                                                                                                                                                                           |                                                                                          |                                                                                  |                                                                                                                                                                                       |                                                                  |
| Configurations                      |                                                                                                                                                                                                                                             | v& Configura                                                                             | tion                                                                             | v16 Configura                                                                                                                                                                         | tion                                                             |
| oomiyurations                       |                                                                                                                                                                                                                                             | x8 Configura<br>CSI                                                                      | tion<br>A <sub>20</sub>                                                          | x16 Configurat<br>CSi                                                                                                                                                                 | tion<br>A <sub>20</sub>                                          |
| oomyurations                        | Address Space<br>words                                                                                                                                                                                                                      |                                                                                          | -                                                                                |                                                                                                                                                                                       | -                                                                |
| oomiyurations                       |                                                                                                                                                                                                                                             | CSI                                                                                      | A_20                                                                             | CSI                                                                                                                                                                                   | <b>A</b> <sub>20</sub>                                           |
| oonnyurations                       | words<br>Block Size                                                                                                                                                                                                                         | <b>CSI</b><br>1M bytes                                                                   | A <sub>20</sub><br>2M bytes                                                      | <b>CSI</b><br>512K words                                                                                                                                                              | <b>Α</b> <sub>20</sub><br>1Μ                                     |
| oonnyurations                       | words<br>Block Size<br>words                                                                                                                                                                                                                | <b>CSI</b><br>1M bytes<br>2K bytes                                                       | A <sub>20</sub><br>2M bytes<br>2K bytes                                          | <b>CSI</b><br>512K words<br>1K words                                                                                                                                                  | <b>А</b> <sub>20</sub><br>1М<br>1К                               |
| oomiyu atons                        | words<br>Block Size<br>words<br>Addressable Blocks                                                                                                                                                                                          | <b>CS</b> I<br>1M bytes<br>2K bytes<br>512                                               | A <sub>zo</sub><br>2M bytes<br>2K bytes<br>1024                                  | <b>CSI</b><br>512K words<br>1K words<br>512                                                                                                                                           | <b>Α</b> <sub>20</sub><br>1Μ<br>1Κ<br>1024                       |

16Kx8

4Kx8

8

yes

yes

yes

16Kx8

4Kx8

8

no

yes

yes

EPROM Configuration

SRAM Configuration

Low-power Standby

Protected Mode

Byte Operations

I/O Pins

8Kx16

2Kx16

16

yes

yes

yes

8Kx16

2Kx16

16

no

yes

yes

2

| Table 3.<br>Mode Selection | Mode/Pin                | CSI             | ŌĒ              | WE/V <sub>pp</sub> | Address                    | x16 (I/O <sub>0-15</sub> )<br>x8 (I/O <sub>0-7</sub> ) | x16 (FCSO)<br>x8 FCSO, CSO <sub>0-7</sub> |
|----------------------------|-------------------------|-----------------|-----------------|--------------------|----------------------------|--------------------------------------------------------|-------------------------------------------|
|                            | Read EPROM/SRAM         | ۷ <sub>L</sub>  | V <sub>iL</sub> | V <sub>IH</sub>    | EPROM/SRAM<br>Selected     | D <sub>OUT</sub>                                       | CS <sub>OUT</sub>                         |
|                            | Read External           | V <sub>IL</sub> | V <sub>⊫</sub>  | V <sub>IH</sub>    | EPROM/SRAM<br>Not Selected | High Z                                                 | CS <sub>OUT</sub>                         |
|                            | Output Disable          | х               | V <sub>IH</sub> | х                  | х                          | High Z                                                 | CS <sub>out</sub>                         |
|                            | Stand-By                |                 | X               | Х                  | х                          | High Z                                                 | CS <sub>OUT</sub>                         |
|                            | Write SRAM              | V <sub>IL</sub> | Х               | V <sub>IL</sub>    | SRAM Selected              | D <sub>IN</sub>                                        | CS <sub>OUT</sub>                         |
|                            | Write External          | V <sub>IL</sub> | х               | V <sub>IL</sub>    | No SRAM<br>Selected        | Х                                                      | CS <sub>OUT</sub>                         |
|                            | Program EPROM           | V <sub>IL</sub> | V <sub>IH</sub> | $V_{PP}$           | EPROM<br>Program Address   | D <sub>IN</sub>                                        | D <sub>IN</sub>                           |
|                            | Program Verify<br>EPROM | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub>    | EPROM<br>Program Address   | D <sub>OUT</sub>                                       | CS <sub>OUT</sub>                         |
|                            | Program PAD             | V <sub>IL</sub> | $V_{\rm IH}$    | $V_{PP}$           | PAD Program<br>Address     | D <sub>IN</sub>                                        | D <sub>IN</sub>                           |
|                            | Program Verify PAD      | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub>    | PAD Program<br>Address     | D <sub>OUT</sub>                                       | CS <sub>OUT</sub>                         |

| Table 4.<br>High/Low Byte | x16 Configuration Only     |              |                                   |                                            |  |  |  |
|---------------------------|----------------------------|--------------|-----------------------------------|--------------------------------------------|--|--|--|
| Selection                 | BHE (Pin 1) A <sub>a</sub> |              | Write Operation                   | <b>Read Operation</b>                      |  |  |  |
|                           | 0                          | 0            | Whole word                        | Whole word                                 |  |  |  |
|                           | 0                          | 1            | Upper byte from/to<br>odd address | Upper byte = Data Out<br>Lower byte = 'FF' |  |  |  |
|                           | 1                          | 0            | Lower byte from/to even address   | Whole word                                 |  |  |  |
|                           | 1                          | 1            | None                              | Upper byte = Data Out<br>Lower byte = 'FF' |  |  |  |
|                           | WR and BHE a               | are used for | SRAM functions                    |                                            |  |  |  |

| <i>Table 5. Product Selection Guide</i> | Parameter                          | MAP168-40 | MAP168-45 | MAP168-55 | Units |
|-----------------------------------------|------------------------------------|-----------|-----------|-----------|-------|
|                                         | Address Access Time (max)          | 40        | 45        | 55        | ns    |
|                                         | Chip-Select Access Time (max)      | 40        | 45        | 55        | ns    |
|                                         | Output Enable Time (max)           | 18        | 21        | 23        | ns    |
|                                         | Chip-Select Output Time            | 22        | 25        | 27        | ns    |
|                                         | Fast Chip-Select Output Time (max) | 17        | 20        | 22        | ns    |

#### Table 6. DC Characteristics

| Parameter                                                                                                                                                 | Symbol                                | Test Conditions                  | Min | Max      | Units    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------------|-----|----------|----------|
| Output Low Voltage                                                                                                                                        | V <sub>ol</sub>                       | l <sub>oL</sub> =8 mA            |     | 0.5      | V        |
| Output High Voltage                                                                                                                                       | V <sub>OH</sub>                       | l <sub>он</sub> =–2 mA           | 2.4 |          | V        |
| CMOS Standby<br>Current<br>—Commercial<br>—Military                                                                                                       | I <sub>SB1</sub>                      | notes 1, 3                       |     | 20<br>30 | mA<br>mA |
| TTL Standby<br>Current<br>—Commercial<br>—Military                                                                                                        | I <sub>SB2</sub>                      | notes 2, 3                       |     | 30<br>40 | mA<br>mA |
| CMOS Active Current<br>No Blocks Selected<br>—Commercial<br>—Military                                                                                     | I <sub>cc</sub> 1A                    | notes 1, 4                       |     | 20<br>30 | mA<br>mA |
| CMOS Active Current<br>EPROM Block Selected<br>—Commercial<br>—Military                                                                                   | I <sub>cc</sub> 1B                    | notes 1, 4                       |     | 35<br>45 | mA<br>mA |
| CMOS Active Current<br>SRAM Block Selected<br>—Commercial<br>—Military                                                                                    | I <sub>cc</sub> 1C                    | notes 1, 4                       |     | 55<br>65 | mA<br>mA |
| TTL Active Current<br>No Blocks Selected<br>—Commercial<br>—Military                                                                                      | I <sub>cc</sub> 2A                    | notes 2, 4                       |     | 30<br>40 | mA<br>mA |
| TTL Active Current<br>EPROM Block Selected<br>—Commercial<br>—Military                                                                                    | I <sub>cc</sub> 2B                    | notes 2, 4                       |     | 40<br>50 | mA<br>mA |
| TTL Active Current<br>SRAM Block Selected<br>—Commercial<br>—Military                                                                                     | I <sub>cc</sub> 2C                    | notes 2, 4                       |     | 65<br>75 | mA<br>mA |
| Input Load Current                                                                                                                                        | l <sub>u</sub>                        | V <sub>IN</sub> =5.5V<br>or GND  | -10 | 10       | μA       |
| Output Leakage Current                                                                                                                                    | I <sub>LO</sub>                       | V <sub>out</sub> =5.5V<br>or GND | -10 | 10       | μΑ       |
| Notes:<br>1. CMOS inputs: GND $\pm$ 0<br>2. TTL inputs: V <sub>IL</sub> $\leq$ 0.8V, <sup>1</sup><br>3. Add 1.5 mA/MHz for AC<br>4. Add 3.5 mA/MHz for AC | V <sub>H</sub> ≥ 2.0V.<br>C power com | ± 0.3V.<br>ponent.               |     |          |          |

2

#### Table 7. AC Characteristic

| Parameter                          | Symbol            | MAP1<br>Min | 168-40<br>Max | MAP:<br>Min | 68-45<br>Max | MAP1<br>Min | 68-55<br>Max | Units |
|------------------------------------|-------------------|-------------|---------------|-------------|--------------|-------------|--------------|-------|
| Read Cycle Time                    | t <sub>RC</sub>   | 40          |               | 45          |              | 55          |              | ns    |
| Address to Output Delay            | t <sub>ACC</sub>  |             | 40            |             | 45           |             | 55           | ns    |
| CSI to Output Delay                | t <sub>ce</sub>   |             | 40            |             | 45           |             | 55           | ns    |
| OE to Output Delay                 | t <sub>oe</sub>   |             | 18            |             | 21           |             | 23           | ns    |
| Output Disable to Output Float     | t <sub>oef</sub>  |             | 15            |             | 18           |             | 20           | ns    |
| Chip Disable to Output Float       | t <sub>csF</sub>  |             | 15            |             | 18           |             | 20           | ns    |
| Address to Output Hold             | t <sub>он</sub>   | 10          |               | 10          |              | 10          |              | ns    |
| Address to CSO <sub>0-7</sub> True | t <sub>cso</sub>  |             | 22            |             | 25           |             | 27           | ns    |
| Address to FCSO True               | t <sub>FCSO</sub> |             | 17            |             | 20           |             | 22           | ns    |
| SRAM Write Cycle Time              | t <sub>wc</sub>   | 40          |               | 45          |              | 55          |              | ns    |
| Chip Enable to Write End           | t <sub>csw</sub>  | 40          |               | 45          |              | 55          |              | ns    |
| Address Setup Time                 | t <sub>as</sub>   | 0           |               | 0           |              | 0           |              | ns    |
| Address Hold Time                  | t <sub>an</sub>   | 0           |               | 0           |              | 0           |              | ns    |
| Address Valid to Write End         | t <sub>aw</sub>   | 40          |               | 45          |              | 55          |              | ns    |
| SRAM Write Enable Pulse Width      | t <sub>ewe</sub>  | 25          |               | 30          |              | 35          |              | ns    |
| Data Setup Time                    | t <sub>os</sub>   | 20          |               | 20          |              | 30          |              | ns    |
| Data Hold Time                     | t <sub>DH</sub>   | 0           |               | 0           |              | 0           |              | ns    |
| Write Enable to Data Float         | t <sub>weF</sub>  |             | 18            |             | 21           |             | 23           | ns    |
| Write Disable to Data Low Z        | t <sub>welz</sub> | 3           |               | 3           |              | 3           |              | ns    |
| BHE Setup Time                     | t <sub>BHES</sub> | 0           |               | 0           |              | 0           |              | ns    |
| BHE Hold Time                      | t <sub>BHEH</sub> | 10          |               | 10          |              | 10          |              | ns    |

*Table 8. Data Retention Characteristics* 

| Parameter                           | Symbol            | Test Conditions                                   | Min             | Max | Units |
|-------------------------------------|-------------------|---------------------------------------------------|-----------------|-----|-------|
| Minimum $V_{cc}$ for Data Retention | V <sub>DR</sub>   | V <sub>cc</sub> =2.0V,                            | 2.0             |     | v     |
| Current in Data Retention Mode      |                   | $\overline{\text{CSI}} \ge V_{\text{cc}} - 0.2V,$ |                 | 1   | mA    |
| Chip Deselect to Data Retention     | t <sub>CSDR</sub> | $V_{IN} \ge V_{CC} - 0.2V$                        | 0               |     | ns    |
| Recovery Time from Data Retention   | t <sub>RDR</sub>  | or $V_{IN} \le 0.2V$                              | t <sub>RC</sub> |     | ns    |

2

| Absolute<br>Maximum Ratings               | Storage Temperature<br>Voltage to any pin with<br>respect to GND<br>V <sub>PP</sub> with respect to GND<br>ESD Protection<br>Stresses above those listed I<br>permanent damage to the de | -0.6V to +7V<br>0.6 V to +14.0V<br>               | stress rating only and functional operation of<br>the device at these or any other conditions<br>above those indicated in the operational<br>sections of this specification is not implied.<br>Exposure to absolute maximum rating<br>conditions for extended periods of time may<br>affect device reliability.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Table 9. Operating<br>Range               | <b>Range</b><br>Commercial<br>Military                                                                                                                                                   | <i>Temperature</i><br>0° to +70°C<br>–55° to +125 | <i>V<sub>cc</sub></i><br>+5V ± 5%<br>°C +5V ± 10%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Figure 3.<br>Read Cycle<br>Timing Diagram | ADDRESSES                                                                                                                                                                                |                                                   | <sup>t</sup> RC<br>ACC<br>t CE<br>t |  |  |





*Table 11. MAP168 Pin Assignments* 

| 44-pin CLDC<br>44-pin PLDC<br>44-pad CLLC | C Package                                                     |                      |  |
|-------------------------------------------|---------------------------------------------------------------|----------------------|--|
| Pin No.                                   | x8                                                            | x16                  |  |
| 1                                         | GND                                                           | BHE                  |  |
| 2                                         | WE/V <sub>PP</sub>                                            | WE/V <sub>PP</sub>   |  |
| 3                                         | CSI/A <sub>20</sub>                                           | CSI/A <sub>20</sub>  |  |
| 4                                         | $\frac{\overline{\text{CSO}}_{7}}{\overline{\text{CSO}}_{7}}$ | I/O <sub>15</sub>    |  |
| 5                                         |                                                               | I/O <sub>14</sub>    |  |
| 6                                         | CSO <sub>5</sub>                                              | I/O <sub>13</sub>    |  |
| 7                                         | CSO <sub>4</sub>                                              | I/O <sub>12</sub>    |  |
| 8                                         | CSO <sub>3</sub>                                              | I/O <sub>12</sub>    |  |
| 9                                         |                                                               | 1/O <sub>11</sub>    |  |
| 9<br>10                                   | $\overline{CSO}_{1}$                                          | I/O <sub>10</sub>    |  |
|                                           | $\frac{CSO_1}{CSO_0}$                                         | 1/O,                 |  |
| 11                                        |                                                               |                      |  |
| 12                                        | GND                                                           | GND                  |  |
| 13                                        | FCSO                                                          | FCSO                 |  |
| 14                                        | I/O <sub>7</sub>                                              | I/O <sub>7</sub>     |  |
| 15                                        | 1/0 <sub>6</sub>                                              | 1/O <sub>6</sub>     |  |
| 16                                        | 1/0 <sub>5</sub>                                              | I/O <sub>5</sub>     |  |
| 17                                        | I/O <sub>4</sub>                                              | I/O <sub>4</sub>     |  |
| 18                                        | I/O <sub>3</sub>                                              |                      |  |
| 19                                        | I/O <sub>2</sub>                                              | I/O <sub>2</sub>     |  |
| 20                                        |                                                               | I/O <sub>1</sub>     |  |
| 21                                        | I/O <sub>0</sub>                                              | I/O <sub>0</sub>     |  |
| 22                                        | ŌĒ                                                            | ŌĒ                   |  |
| 23                                        | A <sub>0</sub>                                                | A <sub>o</sub>       |  |
| 24                                        | A <sub>1</sub>                                                | A <sub>1</sub>       |  |
| 25                                        | $A_2$                                                         | A <sub>2</sub>       |  |
| 26                                        | A <sub>3</sub>                                                | A <sub>3</sub>       |  |
| 27                                        | A <sub>4</sub>                                                | A <sub>4</sub>       |  |
| 28                                        | A <sub>5</sub>                                                | A <sub>5</sub>       |  |
| 29                                        | A <sub>6</sub>                                                | A <sub>6</sub>       |  |
| 30                                        | Å <sub>7</sub>                                                | Å <sub>7</sub>       |  |
| 31                                        | A <sub>8</sub>                                                | A <sub>8</sub> '     |  |
| 32                                        | A <sub>9</sub>                                                | A <sub>9</sub>       |  |
| 33                                        | A <sub>10</sub>                                               | A <sub>10</sub>      |  |
| 34                                        | GND                                                           | GND                  |  |
| 35                                        | A <sub>11</sub>                                               | A <sub>11</sub>      |  |
| 36                                        | Δ                                                             | Δ                    |  |
| 37                                        | Α <sub>12</sub><br>Δ                                          | Α <sub>12</sub><br>Δ |  |
| 38                                        | Α <sub>13</sub><br>Δ                                          | Α <sub>13</sub><br>Δ |  |
| 39                                        | A <sub>14</sub>                                               | Α <sub>14</sub><br>Δ |  |
|                                           | A <sub>15</sub>                                               | A <sub>15</sub>      |  |
| 40                                        | A <sub>16</sub>                                               | A <sub>16</sub>      |  |
| 41                                        | A <sub>17</sub>                                               | A <sub>17</sub>      |  |
| 42                                        | A <sub>18</sub>                                               | A <sub>18</sub>      |  |
| 43                                        | A <sub>19</sub>                                               | A <sub>19</sub>      |  |
| 44                                        | V <sub>cc</sub>                                               | V <sub>cc</sub>      |  |
| WE and BH                                 | E are for SRAM fun                                            | ctions.              |  |

#### *Table 12. MAP168 Pin Assignments*

| 44-pin CPGA    | l Package        |                   |  |
|----------------|------------------|-------------------|--|
| Pin No.        | x8               | x16               |  |
| $A_5$          | GND              | BHE               |  |
| $A_4$          |                  |                   |  |
| B <sub>4</sub> | CSI/A            | CSI/A             |  |
| A <sub>3</sub> | CSO,             | I/O <sub>15</sub> |  |
| B <sub>3</sub> | CSO <sub>c</sub> | I/O <sub>14</sub> |  |
| A <sub>2</sub> | CSO <sub>5</sub> | I/O <sub>13</sub> |  |
| ₿ <sub>2</sub> | <b>CSO</b> ₄     | I/O <sub>12</sub> |  |
| B              | CSO <sub>3</sub> | I/O,,             |  |
| C <sub>2</sub> | CSO <sub>2</sub> | I/O <sub>10</sub> |  |
|                | CSO,             | I/O               |  |
| D <sub>2</sub> | CSO              | I/O <sub>8</sub>  |  |
|                | GND              | GND               |  |
| E              | FCSO             | FCSO              |  |
| E2             | I/O <sub>7</sub> | I/O <sub>7</sub>  |  |
| F,             | I/O <sub>e</sub> | I/O <sub>6</sub>  |  |
| F <sub>2</sub> | I/O <sub>5</sub> | I/O <sub>5</sub>  |  |
| G <sub>1</sub> | I/O₄             | I/O <sub>4</sub>  |  |
| G <sub>2</sub> | I/O,             | I/O,              |  |
| H <sub>2</sub> | I/O,             | I/O <sub>2</sub>  |  |
| G_3            | I/O,             | I/O <sub>1</sub>  |  |
| H <sub>3</sub> | I/O <sub>o</sub> | I/O <sub>0</sub>  |  |
| $\tilde{G_4}$  | ŌĒ               | ŌĔ                |  |
| H <sub>4</sub> | A <sub>0</sub>   | A                 |  |
| H <sub>5</sub> | A,               | A,                |  |
| $G_5$          | A,               | A <sub>2</sub>    |  |
| H <sub>6</sub> | A <sub>3</sub>   | A <sub>3</sub>    |  |
| $\tilde{G_6}$  | A                | A                 |  |
| H <sub>7</sub> | A <sub>5</sub>   | A <sub>5</sub>    |  |
| G <sub>7</sub> | A <sub>6</sub>   | A <sub>6</sub>    |  |
| G <sub>8</sub> | A <sub>7</sub>   | A <sub>7</sub>    |  |
| F <sub>7</sub> | A <sub>e</sub>   | A <sub>8</sub>    |  |
| F <sub>8</sub> | Ag               | A <sub>9</sub>    |  |
| E <sub>7</sub> | A <sub>10</sub>  | A <sub>10</sub>   |  |
| E <sub>8</sub> | GND              | GND               |  |
| D <sub>8</sub> | A <sub>11</sub>  | A <sub>11</sub>   |  |
| D <sub>7</sub> | A <sub>12</sub>  | A <sub>12</sub>   |  |
| C <sub>8</sub> | A <sub>13</sub>  | A <sub>13</sub>   |  |
| C <sub>7</sub> | A.,              | A.,               |  |
| B <sub>8</sub> | A.c              | A.c               |  |
| B <sub>7</sub> | A <sub>10</sub>  | A.,               |  |
| A <sub>7</sub> | A.,              | A.,               |  |
| B <sub>6</sub> | A.               | A.,               |  |
| A <sub>6</sub> | A <sub>10</sub>  | A <sub>10</sub>   |  |
| B <sub>5</sub> | V <sub>cc</sub>  | V <sub>cc</sub>   |  |
| -              |                  |                   |  |

2



To clear all locations of their programmed contents, expose the device to an ultra-violet light source. A dosage of 15W-second/cm<sup>2</sup> is required. This dosage can be obtained with exposure to a wavelength of 2537Å and intensity of 1200µW/cm<sup>2</sup> for 15 to 20 minutes. The device should be about one inch from the source and all filters should be removed from the UV light source prior to erasure. The device by an opaque label or substance.

System<br/>Development<br/>ToolsMAP168 System Development Tools are a<br/>complete set of PC-based development<br/>tools. Installed on an IBM PC or compatible<br/>computer, these tools provide an integrated,<br/>easy-to-use software and hardware environ-<br/>ment to support MAP168 device develop-ment. The tools run on an IBM-XT, AT, or<br/>compatible computer running MS-DOS<br/>version 3.1 or later. The system must be<br/>equipped with 640K bytes of RAM and a hard<br/>disk.

#### System Development Tools (Con't)

#### Hardware

The MAP168 System Programming Hardware consists of:

- WS6000 MagicPro Memory and PSD Programmer
- WS6003 44-pin LCC Package Adaptor (for 44-pin CLLCC, CLDCC, and PLDCC packages)
- □ WS6011 44-pin CPGA Package Adaptor

The MagicPro Programmer is the common hardware platform for programming all WSI programmable products. It consists of the IBM-PC plug-in Programmer Board and the Remote Socket Adaptor Unit.

#### Software

The MAP168 System Development Software consists of the following:

- WISPER Software—PSD Software Environment
- MAPLE Software—MAP168 Location Editor
- MAPPRO Software—Device Programming Software

The configuration of the MAP168 device is entered using MAPLE software. MAPRO software configures MAP168 devices by using the MagicPro programmer and the socket adaptor. The programmed MAP168 is then ready to be used. The development cycle is depicted in Figure 8.



| System<br>Development<br>Tools (Con't) | <ul> <li>Support</li> <li>WSI provides a complete set of quality support services to registered System</li> <li>Development Tools owners. These support services include the following:</li> <li>12-month Software Updates.</li> <li>Hotline to WSI Application Experts—<br/>For direct design assistance.</li> <li>24-Hour Electronic Bulletin Board—<br/>For design assistance via dial-up modem.</li> </ul> |               |                 | <b>Training</b><br>WSI provides in-depth, hands-on workshops<br>for the MAP168 device and System Develop-<br>ment Tools. Workshop participants learn how<br>to program their own high-performance, user-<br>configurable mappable memory subsystems.<br>Workshops are held at the WSI facility in<br>Fremont, California. |                          |                            |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------|
| Ordering<br>Information                |                                                                                                                                                                                                                                                                                                                                                                                                                | Speed<br>(ns) | Package<br>Type | Package<br>Drawing                                                                                                                                                                                                                                                                                                        | Operating<br>Temperature | Manufacturing<br>Procedure |
|                                        | MAP168-40C*                                                                                                                                                                                                                                                                                                                                                                                                    | 40            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-40J*                                                                                                                                                                                                                                                                                                                                                                                                    | 40            | 44-pin PLDCC    | J2                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-40L*                                                                                                                                                                                                                                                                                                                                                                                                    | 40            | 44-pin CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-45C                                                                                                                                                                                                                                                                                                                                                                                                     | 45            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-45CM*                                                                                                                                                                                                                                                                                                                                                                                                   | 45            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-45CMB*                                                                                                                                                                                                                                                                                                                                                                                                  | 45            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |
|                                        | MAP168-45J                                                                                                                                                                                                                                                                                                                                                                                                     | 45            | 44-pin PLDCC    | J2                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-45L                                                                                                                                                                                                                                                                                                                                                                                                     | 45            | 44-pin CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-45LM*                                                                                                                                                                                                                                                                                                                                                                                                   | 45            | 44-pad CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-45LMB*                                                                                                                                                                                                                                                                                                                                                                                                  | 45            | 44-pad CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |
|                                        | MAP168-45X                                                                                                                                                                                                                                                                                                                                                                                                     | 45            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-45XM*                                                                                                                                                                                                                                                                                                                                                                                                   | 45            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-45XMB*                                                                                                                                                                                                                                                                                                                                                                                                  | 45            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |
|                                        | MAP168-55C                                                                                                                                                                                                                                                                                                                                                                                                     | 55            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-55CM                                                                                                                                                                                                                                                                                                                                                                                                    | 55            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-55CMB                                                                                                                                                                                                                                                                                                                                                                                                   | 55            | 44-pad CLLCC    | C3                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |
|                                        | MAP168-55J                                                                                                                                                                                                                                                                                                                                                                                                     | 55            | 44-pin PLDCC    | J2                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-55L                                                                                                                                                                                                                                                                                                                                                                                                     | 55            | 44-pin CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-55LM                                                                                                                                                                                                                                                                                                                                                                                                    | 55            | 44-pin CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-55LMB                                                                                                                                                                                                                                                                                                                                                                                                   | 55            | 44-pin CLDCC    | L4                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |
|                                        | MAP168-55X                                                                                                                                                                                                                                                                                                                                                                                                     | 55            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Commercial               | Standard                   |
|                                        | MAP168-55XM                                                                                                                                                                                                                                                                                                                                                                                                    | 55            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Military                 | Standard                   |
|                                        | MAP168-55XMB                                                                                                                                                                                                                                                                                                                                                                                                   | 55            | 44-pin CPGA     | X2                                                                                                                                                                                                                                                                                                                        | Military                 | MIL-STD-883C               |

\*These products are advanced information.

| Ordering<br>Information | System Development                | Tools                                                                                                                                                                                          |
|-------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <i>Part Number</i><br>MAP168-GOLD | <i>Contents</i><br>WISPER Software<br>MAPLE Software<br>User's Manual<br>WSI-SUPPORT<br>WS6000 MagicPro Programmer                                                                             |
|                         | MAP168-SILVER                     | WISPER Software<br>MAPLE Software<br>User's Manual<br>WSI-SUPPORT                                                                                                                              |
|                         | WS6000                            | MagicPro Programmer<br>IBM PC plug-in Adaptor Card<br>Remote Socket Adaptor                                                                                                                    |
|                         | WS6003                            | 44-pin LCC Package Adaptor for<br>44-pin CLLCC, CLDCC, and PLDCC Packages.<br>Used with the WS6000 MagicPro Programmer.                                                                        |
|                         | WS6011                            | 44-pin CPGA Package Adaptor.<br>Used with the WS6000 MagicPro Programmer.                                                                                                                      |
|                         | WSI-SUPPORT                       | <ul> <li>Support Services including:</li> <li>12-month Software Update Service</li> <li>Hotline to WSI Application Experts</li> <li>24-hour access to WSI Electronic Bulletin Board</li> </ul> |
|                         | WSI-TRAINING                      | Workshops at WSI, Fremont, CA.<br>For details and scheduling, call PSD Marketing, (415) 656-5400.                                                                                              |



Preliminary

# **Programmable System™Device**

# **PSD301**

# User-Configurable Peripheral with Memory

| •                   |                                                                                                               | •                                                                                       |
|---------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| Key Features        | Second Generation Programmable<br>System Device                                                               | <ul> <li>Multiplexed or Non-Multiplexed</li> <li>Address/Data Buses</li> </ul>          |
|                     | User-Configurable Peripheral for<br>Microcontroller Based Applications —                                      | <ul> <li>— Selectable 8- or 16-Bit Bus Width</li> <li>— Power-Down</li> </ul>           |
|                     | Enables rapid design implementation and fast time to market                                                   | <ul> <li>Address Inputs Can Be Latched or<br/>Transparent</li> </ul>                    |
|                     | Available in space saving surface mount<br>and through-hole packages                                          | <ul> <li>Latched Low-Order Address Byte<br/>Available as Output</li> </ul>              |
|                     | Windowed package option for prototyping                                                                       | <ul> <li>High-Density UV EPROM</li> <li>256K Bits Configurable as 32K × 8 or</li> </ul> |
|                     | Low cost OTP (one-time programmable)<br>package for high volume applications                                  | as 16K × 16<br>— Divided Into Eight Equal Mappable                                      |
|                     | CMOS for low power consumption                                                                                | Blocks                                                                                  |
|                     | <ul> <li>User-Configurable to Interface with Any</li> </ul>                                                   | <ul> <li>EPROM Block Resolution of 4K Byte<br/>or 2K Words</li> </ul>                   |
|                     | 8- or 16-Bit Microcontroller                                                                                  | <ul> <li>EPROM: Up to 120 ns Access Time<br/>(Including PAD Decoding Time)</li> </ul>   |
|                     | — Programmable Address Decoder (PAD)                                                                          |                                                                                         |
|                     | - Programmable Control Signals                                                                                | Static RAM                                                                              |
|                     | <ul> <li>Programmable Polarity</li> <li>Built-In Address Latches</li> </ul>                                   | <ul> <li>— 16K Bits Configurable as 2K × 8 or<br/>as 1K × 16</li> </ul>                 |
|                     | <ul> <li>Port Expansion/Reconstruction of Up to<br/>16 I/O Lines</li> </ul>                                   | <ul> <li>— SRAM: Up to 120 ns Access Time<br/>(Including PAD Decoding Time)</li> </ul>  |
|                     | <ul> <li>Individually Configurable as Output</li> </ul>                                                       | Addressable Range                                                                       |
|                     | or Input                                                                                                      | - 1 MByte or 0.5 MWords                                                                 |
|                     | Highly Configurable, Many Operational<br>Modes                                                                | Low Power TTL-Compatible CMOS Device                                                    |
| <b>Applications</b> | Computers (Workstations and PCs) —<br>Fixed Disk Control, Modem, Imaging,<br>Laser Printer Control            | Medical Instrumentation — Hearing Aid<br>Monitoring Equipment, Diagnostic Tool          |
|                     | Telecommunications — Modem,<br>Cellular Phone, Digital PBX, Digital<br>Speech, FAX, Digital Signal Processing | Military — Missile Guidance, Radar, Sona<br>Secure Communications, RF Modems            |
|                     | Industrial — Robotics, Power Line<br>Access, Power Line Monitor                                               |                                                                                         |
|                     |                                                                                                               |                                                                                         |

# Product Description

In 1988 WSI introduced a new concept in programmable VLSI, Programmable System Devices. The PSD family consists of userconfigurable system-level building blocks on-a-chip, enabling quick implementation of application-specific controllers and peripherals. The first generation PSD series includes the MAP168, a User-Configurable Peripheral, which is ideal for DSP applications; the SAM448, a User-Configurable Microsequencer for control and interface applications, and the PAC1000, a User-Configurable Microcontroller.

The PSD301 is a second generation PSD. The PSD301 is ideal for microcontroller based applications where fast time-tomarket, small form factor and low power consumption are essential. When combined together in an 8- or 16-bit system, virtually any microcontroller (8051, 8096, 16000, etc.) and the PSD301 work together to create a very powerful 2-piece chip-set. This implementation provides all the required control and peripheral elements of a microcontroller based system peripheral with no external "glue" logic required.

The PSD301 integrates high performance user-configurable blocks of EPROM, SRAM, and logic in a single circuit. The major functional blocks include a Programmable Address Decoder (PAD), 256K bits of high speed EPROM, 16K bits of high speed SRAM, input latches, and output ports. The PSD301 is ideal for applications requiring high performance, low power, and very small form factors. These include fixed disk control, modem, cellular telephone, instrumentation, computer peripherals, military and similar applications.

The PSD301 is an optimal solution for microcontrollers that need:

- I/O reconstruction (microcontrollers lose at least two I/O ports when accessing external resources).
- More EPROM and SRAM than the microcontroller's internal memory.
- Chip-select, control, or latched address lines that are otherwise implemented discretely.
- □ An interface to shared external resources.

The PSD301 (shown in Figure 1) can efficiently interface with, and enhance, any 8- or 16-bit microcontroller system. No other solution provides microcontrollers with port expansion, latched addresses, a programmable address decoder (PAD), an interface to shared resources, 256 kbit EPROM, and 16 kbit SRAM on a single chip. The PSD301 does not require glue logic for interfacing to any 8- or 16-bit microcontrollers.

The 8051 microcontroller family can take full advantage of the PSD301's separate program and address spaces. Users of the 68HCXX family of microcontrollers can change the functionality of the control signals and directly connect the R/W and E signals. Users of 16-bit microcontrollers (including the 80186, 8096, 80196, 16XXX) can use the PSD301 in a 16-bit configuration. Address and data buses can be configured to be separated or multiplexed, whichever is required by the host processor.

The flexibility of the PSD301 I/O ports permit interfacing to shared resources. The user can assign the following functions to these ports: standard I/O pins, chip select outputs from the PAD, latched address or multiplexed low-order address/data byte. This enables users to design add-on systems such as disk drives, modems, etc., that easily interface to the host bus (e.g., IBM PC, SCSI).

The PSD301's on-chip programmable address decoder (PAD) enables the user to map the I/O ports, eight segments of EPROM (as  $4K \times 8$ , or as  $2K \times 16$ ), SRAM (as  $2K \times 8$  or as  $1K \times 16$ ), and chip select outputs anywhere in the address space of the microcontroller. The PAD can implement up to 4 sum-of-product expressions based on address inputs and control signals. This further facilitates the interface to microcontrollers with different boot-up locations and I/O address mappings, e.g., the 8051 and 8096 microcontrollers have the boot-up addresses in the lower half of their memory maps; the 80186 and 68HCXX use high memory boot-up addresses.



NOTES: 1. RESET and CSI are not available as programmable options in the PAD. An active RESET ensures that the PAD deselects all of its outputs, and a high level on CSI ensures that the PAD is in power-down mode.

2. Details of the PAD as a programmable array decoder are given in Figure 3.

#### **PSD301**

# Figure 2. PSD301 Port Configurations

Figure 2 shows the PSD301's I/O port configurations.



## Legend:

 $AD_0-AD_7$  = addresses  $A_0-A_7$  multiplexed with data lines  $D_0-D_7$ .  $AD_8-AD_{15}$  = addresses  $A_8-A_{15}$  multiplexed with data lines  $D_8-D_{15}$ .

# Table 1. PSD301Pin Descriptions

| Name                                         | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BHE/PSEN                                     | I    | When the data bus width is 8 bits (CDATA = 0), this pin is $\overrightarrow{PSEN}$ . In this mode, $\overrightarrow{PSEN}$ is the active low EPROM read pulse. The SRAM and I/O ports read signal is generated when $\overrightarrow{RD}$ is low (CRRWR = 0), or when E and $\overrightarrow{RW}$ are high (CRRWR = 1). If the host processor is a member of the 8031 family, $\overrightarrow{PSEN}$ must be connected to the corresponding host pin. In other 8-bit host processors that do not have a special EPROM-only read strobe, $\overrightarrow{PSEN}$ should be tied to V <sub>CC</sub> . In this case, $\overrightarrow{RD}$ or E and $\overrightarrow{R/W}$ provide the read strobe for the SRAM, I/O ports, and EPROM. When the data bus width is configured as 16 (CDATA = 1), this pin is $\overrightarrow{BHE}$ . When $\overrightarrow{BHE}$ is low, a high-order byte is read from, or written into the PSD301, depending on the operation being read or write, respectively. In programming mode, this pin is pulsed between V <sub>PP</sub> and 0. |
| WR/V <sub>PP</sub> or<br>R/W/V <sub>PP</sub> | I    | In the operating mode, this pin's function is $\overline{WR}$<br>(CRRWR = 0) or $\overline{R/W}$ (CRRWR = 1). When configured as<br>$\overline{WR}$ , a write operation is executed during an active low<br>pulse. When configured as $\overline{R/W}$ , with $\overline{R/W} = 1$ and $\overline{E} = 1$ ,<br>a read operation is executed; if $\overline{R/W} = 0$ and $\overline{E} = 1$ , a<br>write operation is executed. In programming mode, this pin<br>must be tied to V <sub>PP</sub> voltage.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RD/E                                         | I    | When configured as $\overline{RD}$ (CRRWR = 0), this pin provides<br>an active low $\overline{RD}$ strobe. When configured as E (CRRWR<br>= 1), this pin becomes an active high pulse, which,<br>together with R/W defines the cycle type. Then, if R/W = 1<br>and E = 1, a read operation is executed. If R/W = 0 and<br>E = 1, a write operation is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CSI/A19                                      | I    | This pin has two configurations. When it is $\overline{CSI}$ (CA19/ $\overline{CSI}$ = 0) and the pin is asserted high, the device is deselected and powered down. (See Tables 12 and 13 for the chip state during power-down mode.) If the pin is asserted low, the chip is in normal operational mode. When it is A19, (CA19/ $\overline{CSI}$ = 1), this pin can be used as an additional input to the PAD. In this mode, there is no power-down capability.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RESET                                        | Ι    | This user-programmable pin can be configured to reset on high level (CRESET = 1) or on low level (CRESET = 0). It should remain active for at least 100 ns. See Tables 10 and 11 for the chip state after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ALE or<br>AS                                 | I    | In the multiplexed modes, the ALE pin functions as an Address Latch Enable or as an Address strobe and can be configured as an active high or active low signal. The ALE or AS trailing edge latches lines AD15/A15–AD0/A0, A16–A19, and BHE, depending on the PSD301 configuration. See Table 8. In the non-multiplexed modes, it can be used as a general-purpose PAD input signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Legend: The I/O column abbreviations are: I = input; I/O = input/output; P = power.

NOTE: 3. All the configuration bits mentioned in Table 1 appear in parentheses and are explained in the Configuration Register section.

| Table 1. PSD301<br>Pin Descriptions | Name                                                                                     | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------|------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Cont.)                             | PA7<br>PA6<br>PA5<br>PA4<br>PA3<br>PA2<br>PA1<br>PA0                                     | I/O  | PA7-PA0 is an 8-bit port that can be configured to track AD7/A7-AD0/A0 from the input (CPAF2 = 1). Otherwise (CPAF2 = 0), each bit can be configured separately as an I/O or lower-order latched address line. When configured as an I/O (CPAF1 = 0), the direction of the pin is defined by its direction bit, which resides in the direction register. If a pin is an I/O output, its data bit (which resides in the data register) comes out. When it is configured as a low-order address line (CPAF1 = 1), A7-A0 can be made the corresponding output through this port (e.g., PA6 can be configured to be the A6 address line). Each port bit can be a CMOS output (CPACOD = 0) or an open drain output (CPACOD = 1). When the chip is in non-multiplexed mode (CADDRDAT = 0), the port becomes the data bus lines (D0-D7). See Figure 4.                       |
|                                     | PB7<br>PB6<br>PB5<br>PB4<br>PB3<br>PB2<br>PB1<br>PB0                                     | I/O  | PB7–PB0 is an 8-bit port for which each bit can be<br>configured as an I/O (CPBF = 1) or chip-select output<br>(CPBF = 0). Each port bit can be a CMOS output<br>(CPBCOD = 0) or an open drain output (CPBCOD = 1).<br>When configured as an I/O, the direction of the pin is<br>defined by its direction bit, which resides in the direction<br>register. If a pin is an I/O output, its data (which resides in<br>the data register) comes out. When configured as a chip-<br>select output, $\overline{CS0-CS3}$ are a function of up to four<br>product terms of the inputs to the PAD; $\overline{CS4-CS7}$ then are<br>each a function of up to two product terms. When the chip<br>is in non-multiplexed mode (CADDRAT = 0) and the data<br>bus width is 16 (CDATA = 1), the port becomes the most<br>significant byte of the data bus (D8–D15). See Figure 6. |
|                                     | PC0<br>PC1<br>PC2                                                                        | I/O  | This is a 3-bit port for which each bit is configurable as a PAD input or output. When configured as an input (CPCF = 0), the bits can be latched with ALE (CADDHLT = 1) or be transparent inputs to the PAD (CADDHLT = 0). When a pin is configured as an output (CPCF = 1), it is a function of one product term of all PAD inputs. See Figure 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                     | AD0/A0<br>AD1/A1<br>AD2/A2<br>AD3/A3<br>AD4/A4<br>AD5/A5<br>AD6/A6<br>AD7/A7             | I/O  | In multiplexed mode, these pins are the multiplexed low-<br>order address/data byte. After ALE latches the addresses,<br>these pins input or output data, depending on the settings<br>of the RD/E, WR/V <sub>PP</sub> or R/W, and BHE/PSEN pins. In<br>non-multiplexed mode, these pins are the low-order<br>address input byte.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                     | AD8/A8<br>AD9/A9<br>AD10/A10<br>AD11/A11<br>AD12/A12<br>AD13/A13<br>AD14/A14<br>AD15/A15 | I/O  | In 16-bit multiplexed mode, these pins are the multiplexed<br>high-order address/data byte. After ALE latches the<br>addresses, these pins input or output data, depending on<br>the settings of the RD/E, WR/V <sub>PP</sub> or R/W, and BHE/PSEN<br>pins. In all other modes, these pins are the high-order<br>address input byte.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                     | GND                                                                                      | Р    | V <sub>SS</sub> (ground) pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                     | V <sub>CC</sub>                                                                          | Р    | Supply voltage input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

# **Operating Modes**

The PSD301's four operating modes allow it to interface directly to 8- and 16-bit microcontrollers and microprocessors with multiplexed and non-multiplexed address/data buses. These operating modes are:

- Multiplexed 8-bit address/data bus
- Multiplexed 16-bit address/data bus
- Non-multiplexed address/data, 8-bit data bus
- Non-multiplexed 16-bit address/data bus

#### Multiplexed 8-Bit Address/Data Bus

This mode is used to interface to microcontrollers with an 8-bit data bus and a 16-bit or larger address bus. The low-order address/data bus (AD0/A0–AD7/A7) is bi-directional and permits the latching of the address when the ALE signal is active. On the same pins, the data is read from or written to the device; this depends on the state of the RD/E, BHE/PSEN, and  $WR/V_{PP}$  or R/W pins. The high-order address/data bus (AD8/A8–AD15/A15) contains the high-order address bus byte. Ports A and B can be configured as in Table 2.

#### Multiplexed 16-Bit Address/Data Bus

This mode is used to interface to microcontrollers with a 16-bit data bus and a 16-bit or larger address bus. The low-order address/data bus (AD0/A0–AD7/A7) is bi-directional and permits the latching of the address when the ALE signal is active. On the same pins, the data is read from or written to the device; this depends on the state of the  $\overline{RD/E}$ ,  $\overline{BHE/PSEN}$ , and  $\overline{WR}/V_{PP}$  or R/W pins. The high-order

address/data bus (AD8/A8–AD15/A15) is bidirectional and permits latching of the high-order address when the ALE signal is active on the same pins. The high-order data bus is read from or written to the device, depending on the state of the  $\overline{\text{RD}}/\text{E}$ ,  $\overline{\text{BHE}}/\overline{\text{PSEN}}$ , and  $\overline{\text{WR}}/\text{V}_{\text{PP}}$  or  $\overline{\text{R/W}}$ pins. Ports A and B can be configured as in Table 2.

#### Non-Multiplexed Address/Data, 8-Bit Data Bus

This mode is used to interface to nonmultiplexed 8-bit microcontrollers with an 8-bit data bus and a 16-bit or larger address bus. The low-order address/data bus (AD0/A0–AD7/A7) is the low-order address input bus. The high-order address/data bus (AD8/A8–AD15/A15) is the high-order address bus byte. Port A is the low-order data bus. Port B can be configured as shown in Table 2.

#### Non-Multiplexed 16-Bit Address/Data Bus

This mode is used to interface to nonmultiplexed 16-bit microcontrollers with a 16-bit data bus and a 16-bit or larger address bus. The low-order address/data bus (AD0/A0-AD7/A7) is the low-order address input bus. The high-order address/ data bus (AD8/A8-AD15/A15) is the highorder address bus byte. Port A is the loworder data bus. Port B is the high-order data bus.

Table 2 summarizes the effect of the different operating modes on ports A, B, and the address/data pins. The configuration of Port C is independent of the four operating modes.

#### **PSD301**

| <i>Table 2. PSD301<br/>Bus and Port<br/>Configuration<br/>Options</i> |                 | Multiplexed Address/Data                                                               | Non-Multiplexed Address/Data |  |  |
|-----------------------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------|------------------------------|--|--|
|                                                                       | 8-Bit Data Bus  |                                                                                        |                              |  |  |
|                                                                       | Port A          | I/O and/or low-order address<br>lines or<br>Low-order multiplexed<br>address/data byte | D0-D7 data bus lines         |  |  |
|                                                                       | Port B          | I/O and/or CS0-CS7                                                                     | I/O and/or CS0-CS7           |  |  |
|                                                                       | AD0/A0-AD7/A7   | Low-order multiplexed address/data byte                                                | Low-order address bus byte   |  |  |
|                                                                       | AD8/A8-AD15/A15 | High-order address bus byte                                                            | High-order address bus byte  |  |  |
|                                                                       | 16-Bit Data Bus |                                                                                        |                              |  |  |
|                                                                       | Port A          | I/O and/or low-order address<br>lines or<br>Low-order multiplexed<br>address/data byte | Low-order data bus byte      |  |  |
|                                                                       | Port B          | I/O and/or CS0-CS7                                                                     | High-order data bus byte     |  |  |
|                                                                       | AD0/A0-AD7/A7   | Low-order multiplexed address/data byte                                                | Low-order address bus byte   |  |  |
|                                                                       | AD8/A8-AD15/A15 | High-order multiplexed address/data byte                                               | High-order address bus byte  |  |  |

## Programmable Address Decoder (PAD)

The PSD301's programmable address decoder (PAD) has 14 inputs and 24 outputs. All its I/O functions are listed in Table 3 and shown in Figure 3.

The PAD is used to select all chip internal parts and to generate external chip-selects (see Figure 3). Pins A11–A15,  $\overline{\text{RD}}/\text{E}$ ,  $\overline{\text{WR}}/\text{V}_{\text{PP}}$  or  $\text{R}/\overline{\text{W}}$ , Reset, and ALE are fixed functions. A16–A19 can be address inputs or general purpose inputs to the PAD for implementing logic functions. Internal and

external PAD select signals can override EPROM memory whose addresses overlap. This lets the user make more efficient use of the address space. For example, if the EPROM is not used completely for program storage, the unused EPROM address space can be allocated to I/O ports, SRAM, or other PAD select signals. Using WSI's MAPLE software, any input function to the PAD can be selected as active low, active high, or don't care.

# *Table 3. PSD301 I/O Functions*

|             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAD Inputs  |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CSI or A19  | In $\overline{\text{CSI}}$ mode (when high), PAD deselects all of its outputs and enters a power-down mode (see Tables 12 and 13). In A19 mode, it is another input to the PAD.                                                                                                                                                                                                                                                                          |
| A16-A18     | These are general purpose inputs from Port C. See Figure 3, note 4.                                                                                                                                                                                                                                                                                                                                                                                      |
| A11-A15     | These are address inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RD or E     | This is the read pulse or enable strobe input.                                                                                                                                                                                                                                                                                                                                                                                                           |
| WR or R/W   | This is the write pulse or $R/\overline{W}$ select signal.                                                                                                                                                                                                                                                                                                                                                                                               |
| ALE         | This is the ALE input to the chip.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RESET       | This deselects all outputs from the PAD; it can not be used in product term equations. See Tables 10 and 11.                                                                                                                                                                                                                                                                                                                                             |
| PAD Outputs |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CS0-CS3     | These chip-select outputs can be routed through Port B. Each of them is a function of up to four product terms of the PAD inputs.                                                                                                                                                                                                                                                                                                                        |
| CS4-CS7     | These chip-select outputs can be routed through Port B. Each of them is a function of up to two product terms of the PAD inputs.                                                                                                                                                                                                                                                                                                                         |
| CS8–CS10    | These chip-select outputs can be routed through Port C. See Figure 3, note 4. Each of them is a function of one product term of the PAD inputs.                                                                                                                                                                                                                                                                                                          |
| ES0-ES7     | These are internal chip-selects to the 8 EPROM banks. Each bank<br>can be located on any boundary that is a function of one product<br>term of the PAD address inputs.                                                                                                                                                                                                                                                                                   |
| RS0         | This is an internal chip-select to the SRAM. Its base address location is a function of one term of the PAD address inputs.                                                                                                                                                                                                                                                                                                                              |
| CSIOPORT    | This internal chip-select selects the I/O ports. It can be placed on any boundary that is a function of one product term of the PAD inputs. See Tables 6 and 7.                                                                                                                                                                                                                                                                                          |
| CSADIN      | This internal chip-select, when Port A is configured as a low-order address/data bus in the track mode (CPAF2 = 1), controls the input direction of Port A. CSADIN is gated externally to the PAD by the internal read signal. When CSADIN and a read operation are active, data presented on Port A flows out of AD0/A0–AD7/A7. This chip-select can be placed on any boundary that is a function of one product term of the PAD inputs. See Figure 5.  |
| CSADOUT1    | This internal chip-select, when Port A is configured as a low-order address/data bus in track mode (CPAF2 = 1), controls the output direction of Port A. CSADOUT1 is gated externally to the PAD by the ALE signal. When CSADOUT1 and the ALE signal are active, the address presented on AD0/A0–AD7/A7 flows out of Port A. This chip-select can be placed on any boundary that is a function of one product term of the PAD inputs. See Figure 5.      |
| CSADOUT2    | This internal chip-select, when Port A is configured as a low-order address/data bus in the track mode (CPAF2 = 1), controls the output direction of Port A. CSADOUT2 must include the write-cycle control signals as part of its product term. When CSADOUT2 is active, the data presented on AD0/A0–AD7/A7 flows out of Port A. This chip-select can be placed on any boundary that is a function of one product term of the PAD inputs. See Figure 5. |

PSD301

Figure 3. PSD301 PAD Description



NOTES: 4. CSI is a power-down signal. When high, the PAD is in stand-by mode and all its outputs become non-active. See Tables 12 and 13.

- 5. RESET deselects all PAD output signals. See Tables 10 and 11.
- 6. Maximum PAD latency is 35 ns.
- 7. A18, A17, and A16 are internally multiplexed with CS10, CS9, and CS8, respectively. Either A18 or CS10, A17 or CS9, and A10 or CS8 can be routed to the external pins of Port C.

# **Configuration** Bits

The configuration bits shown in Table 4 are non-volatile cells that let the user set the device, I/O, and control functions to the proper operational mode. Table 5 lists all configuration bits. The configuration bits are programmed and verified during the

programming phase. In operational mode, they are not accessible. To simplify implementing a specific mode, use the WSI's PSD301 MAPLE software to set the bits.

| Table 4. PSD301               | Use This Bit | То                                                                                                                                                         |
|-------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Non-Volatile<br>Configuration | CDATA        | Set the data bus width to 8 or 16 bits.                                                                                                                    |
| Bits                          | CADDRDAT     | Set the address/data buses to multiplexed or non-multiplexed mode.                                                                                         |
|                               | CRRWR        | Set the $\overline{RD}/E$ and $\overline{WR}/V_{PP}$ or $R/\overline{W}$ pins to $\overline{RD}$ and $\overline{WR}$ pulse, or to E strobe and R/W status. |
|                               | CA19/CSI     | Set A19/CSI to CSI (power-down) or A19 input.                                                                                                              |
|                               | CALE         | Set the ALE polarity.                                                                                                                                      |
|                               | CPAF2        | Set Port A either to track the low-order byte of the address/data multiplexed bus or to select the I/O or address option. <sup>8</sup>                     |
|                               | CSECURITY    | Set the security on or off.                                                                                                                                |
|                               | CRESET       | Set the RESET polarity.                                                                                                                                    |
|                               | COMB/SEP     | Set $\overline{\text{PSEN}}$ and $\overline{\text{RD}}$ for combined or separate address spaces (see Figures 8 and 9).                                     |
|                               | CPAF1        | Configure each pin of Port A in multiplexed mode to be an I/O or address out.                                                                              |
|                               | CPACOD       | Configure each pin of Port A as an open drain or active CMOS pull-<br>up output.                                                                           |
|                               | CPBF         | Configure each pin of Port B as an I/O or a chip-select output.                                                                                            |
|                               | CPBCOD       | Configure each pin of Port B as an open drain or active CMOS pull-<br>up output.                                                                           |
|                               | CPCF         | Configure each pin of Port C as an address input or a chip-select output.                                                                                  |
|                               | CADDHLT      | Configure pins A16–A19 to go through a latch or to have their latch transparent.                                                                           |

NOTE: 8. CPAF1 determines whether the output is I/O or address.

#### **PSD301**

Table 5. PSD301 Configuration Bits

| Configuration<br>Bits   | No.<br>of Bits | Description                                                                                                                                                                   |
|-------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CDATA                   | 1              | 8-bit or 16-bit data bus width<br>CDATA = 0, 8-bit data bus<br>CDATA = 1, 16-bit data bus                                                                                     |
| CADDRDAT                | 1              | Address/data multiplexed or non-multiplexed (separate buses)<br>CADDRDAT = 0, non-multiplexed address/data bus<br>CADDRDAT = 1, multiplexed address/data bus                  |
| CRRWR                   | 1              | CRRWR = 0, $\overline{\text{RD}}$ and $\overline{\text{WR}}$ active low strobes<br>CRRWR = 1, R/W status and E active high pulse                                              |
| CA19/CSI                | 1              | A19 or $\overline{CSI}$<br>CA19/ $\overline{CSI}$ = 0, enable power-down mode<br>CA19/ $\overline{CSI}$ = 1, A19 input to PAD                                                 |
| CALE                    | 1              | Active high or active low<br>CALE = 0, active high<br>CALE = 1, active low                                                                                                    |
| CRESET                  | 1              | Active high or active low<br>CRESET = 0, active low reset signal<br>CRESET = 1, active high reset signal                                                                      |
| COMB/SEP                | 1              | Combined or separate memory space for EPROM and SRAM<br>COMB/SEP = 0, combined<br>COMB/SEP = 1, separate                                                                      |
| CPAF1                   | 8              | Port A I/Os or A0–A7<br>CPAF1 = 0, Port A pin = I/O<br>CPAF1 = 1, Port A pin = Ai $(0 \le i \le 7)$                                                                           |
| CPAF2                   | 1              | Port A AD0-AD7 (address/data multiplexed bus)<br>CPAF2 = 0, address or I/O on Port A (according to CPAF1)<br>CPAF2 = 1, address/data multiplexed on Port A (track mode)       |
| CPBF                    | 8              | Port B I/Os or $\overline{CS0}$ - $\overline{CS7}$<br>CPBF = 0, Port B Pin = $\overline{CSi}$ (0 $\leq i \leq 7$ )<br>CPBF = 1, Port B Pin = I/O                              |
| CPCF                    | 3              | Port C A16–A18 or $\overline{CS8}$ – $\overline{CS10}$<br>CPCF = 0, Port C Pin = Ai (16 $\leq$ i $\leq$ 18)<br>CPCF = 1, Port C Pin = $\overline{CSi}$ (8 $\leq$ i $\leq$ 10) |
| CPACOD                  | 8              | Port A CMOS or open-drain outputs<br>CPACOD = 0, CMOS output<br>CPACOD = 1, open-drain output                                                                                 |
| CPBCOD                  | 8              | Port B CMOS or open-drain outputs<br>CPBCOD = 0, CMOS output<br>CPBCOD = 1, open-drain output                                                                                 |
| CADDHLT                 | 1              | A16-A19 latched or latch transparent<br>CADDHLT = 0, address latch transparent<br>CADDHLT = 1, address latched (ALE dependent)                                                |
| CSECURITY               | 1              | Security on or off<br>CSECURITY = 0, no security<br>CSECURITY = 1, secured part (cannot be copied)                                                                            |
| Total Number<br>of Bits | 45             |                                                                                                                                                                               |

**NOTES:** 9. WSI's MAPLE software will guide the user to the proper configuration choice. 10 In an unprogrammed or erased part, all configuration bits are 0.

# **Port Functions**

The PSD301 has three I/O ports (Ports A, B, and C) that are configurable at the bit level. This permits great flexibility and a high degree of customization for specific

applications. The following is a description of each port. Figure 4 shows the pin structure of Port A.



NOTE: 11. CMOS/OD determines whether the output is open drain or CMOS.

#### Port A in Multiplexed Address/Data Mode

The default configuration of Port A is I/O. In this mode, every pin can be set as an input or output by writing into the respective pin's direction flip flop (DIR FF, in Figure 4). As an output, the pin level can be controlled by writing into the respective pin's data flip flop (DFF, in Figure 4). When DIR FF = 1, the pin is configured as an output. When DIR FF = 0, the pin is configured as an input. The controller can read the DIR FF bits by accessing the READ DIR register; it can read the DFF bits by accessing the READ DATA register. Port A pin levels can be read by accessing the READ PIN register. Individual pins can be configured as CMOS or open drain outputs. Open drain pins require external pull-up resistors. For addressing information, refer to Tables 6 and 7.

Alternatively, each bit of Port A can be configured as a low-order latched address bus bit. The address is provided by the port address latch, which latches the address on the trailing edge of ALE. PA0–PA7 can become A0–A7, respectively. This feature of the PSD301 lets the user generate low-order address bits to access external peripherals or memory that require several low-order address lines.

#### PSD301

# Port Functions (Cont.)

Another mode of Port A (CPAF2 = 1) sets the entire port to track the inputs AD0/A0-AD7/A7, depending on specific address ranges defined by the PAD's CSADIN, CSADOUT1, and CSADOUT2 signals. This feature lets the user interface the microcontroller to shared external resources without requiring external buffers and decoders. In this mode, the port is effectively a bi-directional buffer. The direction is controlled by using the input signals ALE, RD/E, WR/VPP or R/W, and the internal PAD outputs CSADOUT1. CSADOUT2 and CSADIN (see Figure 5). When CSADOUT1 and ALE are true, the address on the input AD0/A7-AD7/A7 pins flows out through Port A. (Carefully check the generation of CSADOUT1, and ensure that it is stable during the ALE pulse; see Figures 22 and 23). When CSADOUT2 is

active, a write operation is performed (see note to Figure 5). The data on the input AD0/A7–AD7/A7 pins flows out through Port A. When CSADIN and a read operation is performed (depending on the mode of the RD/E and WR/V<sub>PP</sub> or R/W pins), the data on Port A flows out through the AD0/A7–AD7/A7 pins. In this operational mode, Port A is tri-stated when none of the above-mentioned three conditions exist.

#### Port A in Non-Multiplexed Address/ Data Mode

In this mode, Port A becomes the low order data bus byte of the chip. When reading an internal PSD301 location, data is presented on Port A pins. When writing to an internal PSD301 location, data present on Port A pins is written to that location.



NOTE: 12. The expression for CSADOUT2 must include the following write operation cycle signals:
 For CRRWR = 0, CSADOUT2 must include WR = 0.
 For CRRWR = 1, CSADOUT2 must include E = 1 and R/W = 0.

### Port B in Multiplexed Address/Data and in 8-Bit Non-Multiplexed Modes

The default configuration of Port B is I/O. In this mode, every pin can be set as an input or output by writing into the respective pin's direction flip flop (DIR FF, in Figure 6). As an output, the pin level can be controlled by writing into the respective pin's data flip flop (DFF, in Figure 6). When DIR FF = 1, the pin is configured as an output. When DIR FF = 0, the pin is configured as an input. The controller can read the DIR FF bits by accessing the READ DIR register; it can read the DFF bits by accessing the READ DATA register. Port B pin levels can be read by accessing the READ PIN register.

# Port Functions (Cont.)

Individual pins can be configured as CMOS or open drain outputs. Open drain pins require external pull-up resistors. For addressing information, refer to Tables 6 and 7.

Alternatively, each bit of Port B can be configured to provide a chip-select output signal from the PAD. PB0–PB7 can provide  $\overline{CS0}-\overline{CS7}$ , respectively. Each of the signals  $\overline{CS0}-\overline{CS3}$  is comprised of four product terms. Thus, up to four ANDed expressions can be ORed while deriving any of these signals. Each of the signals  $\overline{CS4}-\overline{CS7}$  is comprised of two product terms. Thus, up to two ANDed expressions can be ORed while deriving any of these signals.

## Port B in 16-Bit Non-Multiplexed Address/Data Mode

In this mode, Port B becomes the highorder data bus byte of the chip. When reading an internal PSD301 high-order data bus byte location, the data is presented on Port B pins. When writing to an internal PSD301 high-order data bus byte location, data present on Port B is written to that location. See Table 9.

#### Accessing the I/O Port Registers

Tables 6 and 7 show the offset values with the respect to the base address defined by the CSIOPORT. They let the user access the corresponding registers.



NOTE: 13 CMOS/OD determines whether the output is open drain or CMOS.

| <i>Table 6. I/O Port<br/>Addresses in an</i> | Register Name                | Byte Size Access of the I/O Port Registers<br>Offset from the CSIOPORT |  |
|----------------------------------------------|------------------------------|------------------------------------------------------------------------|--|
| R-bit Data<br>Bus Mode                       | Pin Register of Port A       | +2 (accessible during read operation only)                             |  |
| ous moue                                     | Direction Register of Port A | +4                                                                     |  |
|                                              | Data Register of Port A      | +6                                                                     |  |
|                                              | Pin Register of Port B       | +3 (accessible during read operation only)                             |  |
|                                              | Direction Register of Port B | +5                                                                     |  |
|                                              | Data Register of Port B      | +7                                                                     |  |

# *Table 7. I/O Port Addresses in a 16-bit Data Bus Mode*

| Register Name                       | Word Size Access of the I/O Port<br>Registers Offset from the CSIOPORT |  |
|-------------------------------------|------------------------------------------------------------------------|--|
| Pin Register of Ports B and A       | +2 (accessible during read operation only)                             |  |
| Direction Register of Ports B and A | +4                                                                     |  |
| Data Register of Ports B and A      | +6                                                                     |  |

NOTES: 14. When the data bus width is 16, Port B registers can only be accessed if the BHE signal is low. 15. When accessing words, the high-order byte is connected to Port B, and the low-order byte is connected to Port A.

16. I/O Ports A and B are still byte-addressable, as shown in Table 6. For I/O Port B register access, BHE must be low.

#### Port C in All Modes

Each pin of Port C (shown in Figure 7) can be configured as an input or output from the PAD. As inputs, the pins are named A16–A18. Although the pins are given names of the high-order address bus, they can be used for any other logic inputs to the PAD. For example, A8–A10 can also be connected to those pins, reducing the boundaries of  $\overline{CS0}$ - $\overline{CS7}$  resolution to 256 bytes. Port C address latches can be programmed to latch the inputs by the trailing edge ALE or to be transparent.

Alternatively, PC0–PC2 can become  $\overline{CS8}$ – $\overline{CS10}$  outputs, respectively, providing the user with more external chip-select PAD outputs. Each of the signals  $\overline{CS8}$ – $\overline{CS10}$  is comprised of one product term.



NOTE: 17. The CADDHLT configuration bit determines if A18–A16 are transparent via the latch, or if they must be latched by the trailing edge of the ALE strobe.

| EPROM           | The PSD301 has 256K bits of EPROM.<br>Depending on the configuration of the data<br>bus, the EPROM can be organized as<br>$32K \times 8$ (8-bit data bus) or as $16K \times 16$<br>(16-bit data bus). The EPROM has 8 banks<br>of memory. Each bank can be placed in | any address location by programming the PAD. Bank0–Bank7 can be selected by PAD outputs ES0–ES7, respectively. The EPROM banks are organized as $4K \times 8$ (8-bit data bus) or as $2K \times 16$ (16-bit data bus). |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRAM            | The PSD301 has 16K bits of SRAM.<br>Depending on the configuration of the data<br>bus, the SRAM organization can be 2K × 8                                                                                                                                           | (8-bit data bus) or $1K \times 16$ (16-bit data bus). The SRAM is selected by the RS0 output of the PAD.                                                                                                               |
| Control Signals | The PSD301 control signals are WR/V <sub>PP</sub><br>or R/W, RD/E, ALE, BHE/PSEN, Reset,<br>and A19/CSI. Each of these signals can be                                                                                                                                | falling edge of ALE latches the information<br>into the latches. When ALE is programmed<br>to be active low, a low on the pin causes                                                                                   |

WR/V<sub>PP</sub> or R/W

In operational mode, this signal can be configured as  $\overline{WR}$  or  $\overline{R/W}$ . As  $\overline{WR}$ , all write operations to the PSD301 are activated by an active low signal on this pin. As  $\overline{R/W}$ , the pin works with the E strobe of the  $\overline{RD/E}$ pin. When  $\overline{R/W}$  is high, an active high signal on the  $\overline{RD/E}$  pin performs a read operation. When  $\overline{R/W}$  is low, an active high signal on the  $\overline{RD/E}$  pin performs a write operation.

configured to meet the output control signal requirements of various microcontrollers.

#### RD/E

In operational mode, this signal can be configured as  $\overline{\text{RD}}$  or E. As  $\overline{\text{RD}}$ , all read operations to the PSD301 are activated by an active low signal on this pin. As E, the pin works with the R/W strobe of the WR/V<sub>PP</sub> or R/W pin. When R/W is high, an active high signal on the  $\overline{\text{RD}}/\text{E}$  pin performs a read operation. When R/W is low, an active high signal on the  $\overline{\text{RD}}/\text{E}$  pin performs a write operation.

#### ALE or AS

ALE polarity is programmable. When programmed to be active high, a high on the pin causes the input address latches, Port A address latches, and Port C address latches to be transparent. The taining edge of ALE laches the information into the latches. When ALE is programmed to be active low, a low on the pin causes the input address latches, Port A address latches, Port C, and A19 address latches to be transparent. The rising edge of ALE latches the appropriate information into the latches. ALE is active only in the multiplexed modes.

#### BHE/PSEN

This pin's function depends on the PSD301 data bus width. If it is 8, the pin is PSEN; if it is 16, the pin is BHE. In 8-bit mode, the PSEN function lets the user work with two address spaces: program memory and data memory (if COMB/SEP = 1). In this mode, an active low signal on the PSEN pin causes the EPROM to be read. The SRAM and I/O ports read operation are done by  $\overline{RD}$  low (CRRWR = 0), or by E and R/W high (CRRWR = 1).

Whenever a member of the 8031 family (or any other similar microcontroller) is used, the PSD301's  $\overrightarrow{\text{PSEN}}$  pin must be connected to the  $\overrightarrow{\text{PSEN}}$  pin of the microcontroller.

If COMB/SEP = 0, the address spaces of the program and the data are combined. In this configuration (except for the 8031-type case mentioned above), the PSEN pin must be tied high to  $V_{CC}$ , and the EPROM, SRAM, and I/O ports are read by  $\overline{RD}$  low (CRRWR = 0), or by E and R/W high (CRRWR = 1). See Figures 8 and 9.

# PSD301 Table

| <i>Table 8. Signal Latch Status in</i> | Signal Name         | Configuration Bits         | <b>Configuration Mode</b>                        | Signal Latch<br>Status |
|----------------------------------------|---------------------|----------------------------|--------------------------------------------------|------------------------|
| All Operating<br>Modes                 | AD8/A8-<br>AD15/A15 | CDATA = 0,<br>CADDRDAT = 0 | 8-bit data, non-multiplexed                      | Transparent            |
|                                        |                     | CDATA = 0,<br>CADDRDAT = 1 | 8-bit data, multiplexed                          | Transparent            |
|                                        |                     | CDATA = 1,<br>CADDRDAT = 0 | 16-bit data, non-multiplexed                     | Transparent            |
|                                        |                     | CDATA = 1,<br>CADDRDAT = 1 | 16-bit data, multiplexed                         | ALE dependent          |
|                                        | AD0/A0-             | CADDRDAT = 0               | Non-multiplexed modes                            | Transparent            |
|                                        | AD7/A7              | CADDRDAT = 1               | Multiplexed modes                                | ALE dependent          |
|                                        | BHE/PSEN            | CDATA = 0                  | 8-bit data, PSEN is active                       | Transparent            |
|                                        |                     | CDATA = 1,<br>CADDRDAT = 0 | 16-bit data, non-multiplexed mode, BHE is active | Transparent            |
|                                        |                     | CDATA = 1,<br>CADDRDAT = 1 | 16-bit data, multiplexed mode, BHE is active     | ALE dependent          |
|                                        | A19 and             | CADDHLT = 0                | A16-A19 can become logic inputs                  | Transparent            |
|                                        | PC2-PC0             | CADDHLT = 1                | A16-A19 can become multiplexed<br>address lines  | ALE dependent          |



#### **PSD301**

Figure 9. 8031-Type Separate Code and Data Address Spaces



In BHE mode, this pin enables accessing of the upper-half byte of the data bus. A low on this pin enables a write or read operation to be performed on the upper half of the data bus (see Table 9).

| Table 9.<br>High/Low Byte | BHE | A <sub>0</sub> | Operation                       |
|---------------------------|-----|----------------|---------------------------------|
| Selection Truth           | 0   | 0              | Whole Word                      |
| Table (in 16-Bit o        |     | 1              | Upper Byte From/To Odd Address  |
| Configuration             | 1   | 0              | Lower Byte From/To Even Address |
| Only)                     | 1   | 1              | None                            |

# RESET

This is an asynchronous input pin that clears and initializes the PSD301. Reset polarity is programmable (active low or active high). Whenever the PSD301 reset input is driven active for at least 100 ns, the chip is reset. The PSD301 must be reset before it can be used. Tables 10 and 11 indicate the state of the part during and after reset.

Table 10. Signal States During and After Reset

| Signal              | Configuration Mode                                        | Condition                   |
|---------------------|-----------------------------------------------------------|-----------------------------|
| AD0/A0-AD15/A15     | All                                                       | Input                       |
| PA0-PA7<br>(Port A) | I/O<br>Tracking AD0/A0-AD7/A7<br>Address outputs A0-A7    | Input<br>Input<br>Low       |
| PB0–PB7<br>(Port B) | I/O<br>CS7-CS0 CMOS outputs<br>CS7-CS0 open drain outputs | Input<br>High<br>Tri-stated |
| PC0-PC2<br>(Port C) | Address inputs A16–A18<br>CS8–CS10 CMOS outputs           | Input<br>High               |

#### **PSD301**

# *Table 11. Internal States During and After Reset*

| Component            | Signals                                                  | Contents               |
|----------------------|----------------------------------------------------------|------------------------|
| PAD                  | CS0-CS10                                                 | $AII = 1^{18}$         |
|                      | CSADIN, CSADOUT1,<br>CSADOUT2, CSIOPORT,<br>RS0, ES0–ES7 | All -= 0 <sup>18</sup> |
| Data register A      | n/a                                                      | 0                      |
| Direction register A | n/a                                                      | 0                      |
| Data register B      | n/a                                                      | 0                      |
| Direction register B | n/a                                                      | 0                      |

NOTE: 18. All PAD outputs are in a non-active state.

## A19/CSI

When configured as  $\overline{CSI}$ , a high on this pin deselects, and powers down, the chip. A low on this pin puts the chip in normal

operational mode. For PSD301 states during the power-down mode, see Tables 12 and 13.

| Table 12. Signal<br>States During | Signal          | Configuration Mode                                                                                      | Condition                          |
|-----------------------------------|-----------------|---------------------------------------------------------------------------------------------------------|------------------------------------|
| States During<br>Power-Down       | AD0/A0-AD15/A15 | All                                                                                                     | Input                              |
| Mode                              | PA0-PA7         | I/O<br>Tracking AD0/A0-AD7/A7<br>Address outputs A0-A7                                                  | Unchanged<br>Input<br>All 1's      |
|                                   | PB0-PB7         | $\frac{I/O}{CS7 - \overline{CS0}}$ CMOS outputs<br>$\overline{CS7 - \overline{CS0}}$ open drain outputs | Unchanged<br>All 1's<br>Tri-stated |
|                                   | PC0-PC2         | Address inputs A16–A18<br>CS8–CS10 CMOS outputs                                                         | Input<br>All 1's                   |

| Table 13.<br>Internal States | Component                                                                          | Signals                                                  | Contents             |
|------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------|
| During                       | PAD                                                                                | CS0-CS10                                                 | All 1's (deselected) |
| Power-Down                   |                                                                                    | CSADIN, CSADOUT1,<br>CSADOUT2, CSIOPORT,<br>RS0, ES0–ES7 | All 0's (deselected) |
|                              | Data register A<br>Direction register A<br>Data register B<br>Direction register B | n/a<br>n/a<br>n/a<br>n/a                                 | All<br>unchanged     |

In A19 mode, the pin is an additional input to the PAD. It can be used as a high-order address line or as a general-purpose logic input. A19 can be configured as ALE dependent or as transparent input (see Table 8). In this mode, the chip is always enabled.

# System Applications

In Figure 10, the PSD301 is configured to interface with Intel's 80C31, which is a 16-bit address/8-bit data bus microcontroller. Its data bus is multiplexed with the low-order address byte. The 80C31 uses signals RD to read from data memory and PSEN to read from code memory. It uses WR to write into the data memory. It also uses active high reset and ALE signals. The rest of the configuration bits as well as the unconnected signals (not shown) are application specific and, thus, user dependent.

The configuration bits for Figure 10 are:

| CRESET   | 1                   |
|----------|---------------------|
| CALE     | 0                   |
| CDATA    | 0                   |
| CADDRDAT | 1                   |
| COMB/SEP | 0 or 1 (both valid) |
| CRRWR    | 0                   |
|          |                     |

All other configuration bits may vary according to the application requirements.



# *System Applications (Cont.)*

In Figure 11, the PSD301 is configured to interface with Motorola's 68HC11, which is a 16-bit address/8-bit data bus microcontroller. Its data bus is multiplexed with the low-order address byte. The 68HC11 uses E and R/W signals to derive the read and write strobes. It uses the term AS (address strobe) for the address latch pulse. RESET is an active low signal. The rest of the configuration bits as well as the unconnected signals (not shown) are application specific and, thus, user dependent. The configuration bits for Figure 11 are:

| CRESET   | 0 |
|----------|---|
| CALE     | 0 |
| CDATA    | 0 |
| CADDRDAT | 1 |
| COMB/SEP | 0 |
| CRRWR    | 1 |
|          |   |

All other configuration bits may vary according to the application requirements.



In Figure 12, the PSD301 is configured to work directly with Intel's 80C196KB microcontroller, which is a 16-bit address/ 16-bit data bus processor. Address and data lines multiplexed. In the example shown, all configuration bits are set. The PSD301 is configured to use PC0, PC1, PC2, and CSI/A19 as A16, A17, A18, and A19 inputs, respectively. These signals are independent of the ALE pulse (latchtransparent). They are used as four general-purpose logic inputs that take part

## Figure 11. PSD301 Interface with Motorola's 68HC11

# *System Applications (Cont.)*

in the PAD equations implementation.

Port A is configured to work in the special track mode, in which (for certain conditions) PA0–PA7 tracks lines AD0/A0–AD7/A7. Port B is configured to generate  $\overline{CS0}$ –CS7. In this example, PB2 serves as a WAIT signal that slows down the 80C196KB during the access of external peripherals. These 8-bit wide peripherals are connected to the shared bus of Port A. The WAIT signal also drives the buswidth input of the microcontroller, so that every external peripheral cycle becomes an 8-bit data bus cycle. PB3 and PB4 are open-drain output signals; thus, they are pulled up externally.





WAFERSCALE INTEGRATION, INC. 2-45

# Absolute Maximum Ratings

| Symbol           | Parameter                  | Conditions          | Min  | Max   | Unit |
|------------------|----------------------------|---------------------|------|-------|------|
| T <sub>STG</sub> | Storage temperature        |                     | -65  | +150  | °C   |
|                  | Voltage on Any Pin         | With Respect to GND | -0.6 | +7    | V    |
| V <sub>PP</sub>  | Programming Supply Voltage | With Respect to GND | -0.6 | 14    | V    |
| V <sub>CC</sub>  | Supply Voltage             | With Respect to GND | -0.6 | +7    | V    |
|                  | ESD Protection             |                     |      | >2000 | V    |

**NOTE:** 19. Stresses above those listed under Absolute Maximum Ratings 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 above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods of time may affect device reliability.

# **Operating Range**

| Range      | Temperature     | V <sub>CC</sub> | Tolerance   |
|------------|-----------------|-----------------|-------------|
| Commercial | 0°C to +70°C    | +5V             | ±5% or ±10% |
| Industrial | -40°C to +85°C  | +5V             | ±10%        |
| Military   | -55°C to +125°C | +5V             | ±10%        |

| Recommended<br>Operating | Symbol          | Parameter                | Conditions              | Min | Тур | Max | Unit |
|--------------------------|-----------------|--------------------------|-------------------------|-----|-----|-----|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           |                         | 4.5 | 5   | 5.5 | V    |
|                          | V <sub>IH</sub> | High Level Input Voltage | $V_{CC} = 4.5V$ to 5.5V | 2   |     |     | V    |
|                          | V <sub>IL</sub> | Low Level Input Voltage  | $V_{CC}$ = 4.5V to 5.5V | 0   |     | 0.8 | V    |

| DC<br>Characteristics | Symbol             | Parameter                       | Condit                                             | ions     | Min        | Тур  | Max  | Units |
|-----------------------|--------------------|---------------------------------|----------------------------------------------------|----------|------------|------|------|-------|
| Unaracteristics       | V <sub>OL</sub>    | Output Low Voltage              | $I_{OL} = 20 \ \mu/V_{CC} = 5.5V$                  |          |            | 0.01 | 0.1  | v     |
|                       | VOL                | Culput Low Voltage              | $I_{OL} = 8 \text{ mA}$<br>$V_{CC} = 5.5 \text{V}$ |          |            | 0.15 | 0.45 | v     |
|                       | Varia              | Output High Voltage             | $I_{OH} = -20$<br>$V_{CC} = 4.5V$                  |          | 4.4        | 4.49 |      | v     |
|                       | V <sub>он</sub>    |                                 | $I_{OH} = -2 r$<br>$V_{CC} = 4.5V$                 |          | 2.4        | 3.9  |      |       |
|                       |                    | V <sub>CC</sub> Standby Current | Notes 20                                           | Comm'l   |            | 80   | 150  | μΑ    |
|                       | I <sub>SB1</sub>   | CMOS                            | and 22                                             | Military |            | 120  | 250  |       |
|                       |                    | V <sub>CC</sub> Standby Current | Notes 21                                           | Comm'l   |            | 0.8  | 1.5  |       |
|                       | I <sub>SB2</sub>   | TTL                             | and 22                                             | Military |            | 1.0  | 2    | mA    |
|                       |                    | Active Current (CMOS)           | Notes 20                                           | Comm'l   | omm'l 35 5 | 55   |      |       |
| I <sub>CC1</sub>      | No Blocks Selected | and 23                          | Military                                           |          | 40         | 65   | mA   |       |
|                       |                    | Active Current (CMOS)           | Notes 20                                           | Comm'l   |            | 35   | 55   |       |
|                       | I <sub>CC2</sub>   | EPROM Block Selected            | and 23                                             | Military |            | 40   | 65   | mA    |

2

DC Characteristics (Cont.)

| Symbol           | Parameter                                    | Condi                  | Min      | Тур  | Max | Units |    |
|------------------|----------------------------------------------|------------------------|----------|------|-----|-------|----|
| I <sub>CC3</sub> | Active Current (CMOS)<br>SRAM Block Selected | Notes 20               | Comm'l   |      | 65  | 105   | mA |
|                  |                                              | and 23                 | Military |      | 75  | 120   |    |
| I <sub>CC4</sub> | Active Current (TTL)<br>No Blocks Selected   | Notes 21               | Comm'l   |      | 50  | 80    | mA |
|                  |                                              | and 23                 | Military |      | 60  | 95    |    |
| I <sub>CC5</sub> | Active Current (TTL)<br>EPROM Block Selected | Notes 21               | Comm'l   |      | 50  | 80    | mA |
|                  |                                              | and 23                 | Military |      | 60  | 95    |    |
| I <sub>CC6</sub> | Active Current (TTL)<br>SRAM Block Selected  | Notes 21               | Comm'l   |      | 80  | 130   | mA |
|                  |                                              | and 23                 | Military |      | 90  | 150   |    |
| ILI              | Input Load Current                           | $V_{IN} = 5.5V$        | -1       | ±0.1 | 1   | μA    |    |
| ILO              | Output Leakage Current                       | V <sub>OUT</sub> = 5.5 | -10      | 5    | 10  | μA    |    |

## 23 AC power component is 35 mA/MHz (power = AC + DC).

# AC Characteristics

| Symbol | Parameter                                                   | -12 |     | -15 |     | -20 |     | Units  |
|--------|-------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--------|
|        |                                                             | Min | Max | Min | Max | Min | Max | UIIIIS |
| T1     | ALE or AS pulse width                                       | 30  |     | 40  |     | 50  |     | ns     |
| T2     | Address set-up time                                         | 15  |     | 20  |     | 25  |     | ns     |
| Т3     | Address hold time                                           | 10  |     | 15  |     | 20  |     | ns     |
| T4     | ALE or AS trailing edge to leading edge of Read             | 12  |     | 15  |     | 20  |     | ns     |
| T5     | ALE or AS leading edge to data valid                        |     | 140 |     | 170 |     | 220 | ns     |
| T6     | Address valid to data valid                                 |     | 120 |     | 150 |     | 200 | ns     |
| T7     | CSI active to data valid                                    |     | 130 |     | 160 |     | 210 | ns     |
| T8     | Leading edge of Read to data valid                          |     | 40  |     | 55  |     | 60  | ns     |
| Т9     | Read data hold time                                         | 0   |     | 0   |     | 0   |     | ns     |
| T10    | Trailing edge of Read to data high-Z                        |     | 35  |     | 40  |     | 45  | ns     |
| T11    | Trailing edge of ALE or AS to leading edge of Write         | 12  |     | 15  |     | 20  |     | ns     |
| T12    | RD, E, PSEN, or WR pulse width                              | 45  |     | 60  |     | 75  |     | ns     |
| T13    | Trailing edge of Write or Read to leading edge of ALE or AS | 20  |     | 30  |     | 40  |     | ns     |
| T14    | Address valid to trailing edge of Write                     | 120 |     | 150 |     | 210 |     | ns     |
| T15    | CSI active to trailing edge of Write                        | 130 |     | 160 |     | 200 |     | ns     |
| T16    | Write data set-up time                                      | 20  |     | 30  |     | 40  |     | ns     |
| T17    | Write data hold time                                        | 10  |     | 15  |     | 20  |     | ns     |
| T18    | Port input set-up time                                      | 10  |     | 15  |     | 20  |     | ns     |
| T19    | Port input hold time                                        | 10  |     | 20  |     | 30  |     | ns     |

AC **Characteristics** (Cont.)

| Symbol | Parameter                                                                                                       | -12 |     | -15 |     | -20 |     | 11    |
|--------|-----------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-------|
|        |                                                                                                                 | Min | Max | Min | Max | Min | Max | Units |
| T20    | Trailing edge of Write to port output valid                                                                     | 40  |     | 50  |     | 60  |     | ns    |
| T21    | ADi <sup>24</sup> or control <sup>27</sup> to CSOi <sup>25</sup> valid                                          | 20  | 35  | 25  | 45  | 30  | 55  | ns    |
| T22    | ADi <sup>24</sup> or control <sup>27</sup> to CSOi <sup>25</sup> invalid                                        | 20  | 35  | 25  | 45  | 30  | 55  | ns    |
| T23    | Track mode address propagation delay:<br>• CSADOUT1 already true or:                                            |     | 20  |     | 30  |     | 40  | ns    |
|        | <ul> <li>CSADOUT1 becomes true<br/>during ALE or AS</li> </ul>                                                  |     | 40  |     | 50  |     | 60  | ns    |
| T24    | Track mode address hold time                                                                                    | 10  |     | 15  |     | 20  |     | ns    |
| T25    | Track mode Read propagation delay                                                                               |     | 20  |     | 30  |     | 40  | ns    |
| T26    | Track mode Read hold time                                                                                       | 10  | 20  | 15  | 30  | 20  | 40  | ns    |
| T27    | Track mode Write cycle data propagation delay                                                                   |     | 20  |     | 30  |     | 40  | ns    |
| T28    | Track mode Write cycle write to data propagation delay                                                          | 20  | 40  | 25  | 50  | 30  | 60  | ns    |
| T29    | Hold time of Port A valid during write to CSOi trailing edge                                                    | 2   |     | 4   |     | 6   |     | ns    |
| T30    | CSI active to CSOi <sup>25</sup> active                                                                         | 25  | 45  | 30  | 55  | 35  | 65  | ns    |
| T31    | CSI inactive to CSOi <sup>25</sup> inactive                                                                     | 25  | 45  | 25  | 55  | 35  | 65  | ns    |
| T32    | Control <sup>27</sup> signal inactive to data invalid                                                           | 5   |     | 10  |     | 15  |     | ns    |
| T33    | $R/\overline{W}$ active to E high                                                                               | 20  |     | 30  |     | 40  |     | ns    |
| T34    | E low to $R/\overline{W}$ inactive                                                                              | 20  |     | 30  |     | 40  |     | ns    |
| T35    | AS inactive to E high                                                                                           | 15  |     | 20  |     | 25  |     | ns    |
| T36    | Direct PAD input <sup>26</sup> stable to leading edge of $\overline{\text{RD}}$ , $\overline{\text{WR}}$ , or E | 15  |     | 20  |     | 25  |     | ns    |

**NOTES:** 24. ADI = any address line. 25.  $\overrightarrow{\text{CSOI}}$  = any of the chip-select output signals coming through Port B ( $\overrightarrow{\text{CSO}}$ - $\overrightarrow{\text{CS7}}$ ) or through Port C (CS8-CS10).

26. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0-PC2, ALE (or AS).

27. Control signals RD/E or WR or R/W

Figure 13. Timing of 8-Bit Multiplexed Address/Data Bus, CRRWR = 0



See referenced notes on page 2-58.

Figure 14. Timing of 8-Bit Multiplexed Address/Data Bus, CRRWR = 1



See referenced notes on page 2-58.

Figure 15. Timing of 16-Bit Multiplexed Address/Data Bus, CRRWR = 0



See referenced notes on page 2-58.

Figure 16. Timing of 16-Bit Multiplexed Address/Data Bus, CRRWR = 1





# Figure 17. Timing of 8-Bit Data, Non-Multiplexed Address/Data Bus, CRRWR = 0



See referenced notes on page 2-58.

Figure 18. Timing of 8-Bit Data, Non-Multiplexed Address/Data Bus, CRRWR = 1



See referenced notes on page 2-58.

Figure 19. Timing of 16-Bit Non-Multiplexed Address/Data Bus, CRRWR = 0



See referenced notes on page 2-58.

# Figure 20. Timing of 16-Bit Non-Multiplexed Address/Data Bus, CRRWR = 1



See referenced notes on page 2-58.



Figure 23. Port A as ADO-AD7 Timing (Track Mode), CRRWR = 1



NOTES: 28. Direct PAD input = any of the following direct PAD input lines: CSI/A19 as transparent A19, RD/E, WR or R/W, transparent PC0-PC2, ALE in non-multiplexed modes.

- Multiplexed inputs: any of the following inputs that are latched by the ALE (or AS): A0/AD0-A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0-PC2.
- CSOi = any of the chip-select output signals coming through Port B (CS0-CS7) or through Port C (CS8-CS10).
- CSADOUT1, which internally enables the address transfer to Port A, should be derived only from direct PAD input signals, otherwise the address propagation delay is slowed down.
- 32 CSADIN and CSADOUT2, which internally enable the data-in or data-out transfers, respectively, can be derived from any combination of direct PAD inputs and multiplexed PAD inputs.
- 33. The write operation signals are included in the  $\overline{\text{CSOi}}$  expression.
- Multiplexed PAD inputs: any of the following PAD inputs that are latched by the ALE (or AS) in the multiplexed modes: A11/AD11–A15/AD15, CSI/A19 as ALE dependent A19, ALE dependent PC0–PC2.
- CSOi product terms can include any of the PAD input signals shown in Figure 3, except for reset and CSI.

# *Table 14. Pin Capacitance*<sup>36</sup>

| Symbol           | Parameter                           | <b>Conditions</b> | Typical 37 | Max | Units |
|------------------|-------------------------------------|-------------------|------------|-----|-------|
| CIN              | Capacitance (for input pins only)   | $V_{IN} = 0V$     | 4          | 6   | pF    |
| Cout             | Capacitance (for input/output pins) | $V_{OUT} = 0V$    | 8          | 12  | pF    |
| C <sub>VPP</sub> | Capacitance (for WR/VPP or R/W/VPP) | $V_{PP} = 0V$     | 18         | 25  | pF    |

NOTES: 36. This parameter is only sampled and is not 100% tested.

37. Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltages



# Erasure and Programming

To clear all locations of their programmed contents, expose the device to ultra-violet light source. A dosage of 15 W-second/cm<sup>2</sup> is required. This dosage can be obtained with exposure to a wavelength of 2537Å and intensity of 1200  $\mu$ W/cm<sup>2</sup> for 15 to 20 minutes. The device should be about 1 inch from the source, and all filters should be removed from the UV light source prior to erasure.

The PSD301 and similar devices will erase with light sources having wavelengths shorter than 4000Å. Although the erasure times will be much longer than with UV sources at 2537Å, exposure to fluorescent light and sunlight eventually erases the device. For maximum system reliability, these sources should be avoided. If used in such an environment, the package windows should be covered by an opaque substance.

Upon delivery from WSI, or after each erasure, the PSD301 device has all bits in the PAD and EPROM in the "1" or high state. The configuration bits are in the "0" or low state. The code, configuration, and PAD MAP data are loaded through the procedure of programming

Information for programming the device is available directly from WSI. Please contact your local sales representative.

| PSD301<br>Pin<br>Assignments | 44-Pin<br>PLDCC/<br>CLDCC<br>Package | Name                      | 44-Pin<br>CPGA<br>Package | 44-Pin<br>PLDCC/<br>CLDCC<br>Package | Name            | 44-Pin<br>CPGA<br>Package |
|------------------------------|--------------------------------------|---------------------------|---------------------------|--------------------------------------|-----------------|---------------------------|
|                              | 1                                    | BHE/PSEN                  | A <sub>5</sub>            | 23                                   | AD0/A0          | H <sub>4</sub>            |
|                              | 2                                    | WR/V <sub>PP</sub> or R/W | A <sub>4</sub>            | 24                                   | AD1/A1          | H <sub>5</sub>            |
|                              | 3                                    | RESET                     | B <sub>4</sub>            | 25                                   | AD2/A2          | G <sub>5</sub>            |
|                              | 4                                    | PB7                       | A <sub>3</sub>            | 26                                   | AD3/A3          | H <sub>6</sub>            |
|                              | 5                                    | PB6                       | B <sub>3</sub>            | 27                                   | AD4/A4          | G <sub>6</sub>            |
|                              | 6                                    | PB5                       | A <sub>2</sub>            | 28                                   | AD5/A5          | H <sub>7</sub>            |
|                              | 7                                    | PB4                       | B <sub>2</sub>            | 29                                   | AD6/A6          | G7                        |
|                              | 8                                    | PB3                       | B <sub>1</sub>            | 30                                   | AD7/A7          | G <sub>8</sub>            |
|                              | 9                                    | PB2                       | C <sub>2</sub>            | 31                                   | AD8/A8          | F <sub>7</sub>            |
|                              | 10                                   | PB1                       | C1                        | 32                                   | AD9/A9          | F <sub>8</sub>            |
|                              | 11                                   | PB0                       | D <sub>2</sub>            | 33                                   | AD10/A10        | E <sub>7</sub>            |
|                              | 12                                   | GND                       | D <sub>1</sub>            | 34                                   | GND             | E <sub>8</sub>            |
|                              | 13                                   | ALE or AS                 | E1                        | 35                                   | AD11/A11        | D <sub>8</sub>            |
|                              | 14                                   | PA7                       | E <sub>2</sub>            | 36                                   | AD12/A12        | D <sub>7</sub>            |
|                              | 15                                   | PA6                       | F <sub>1</sub>            | 37                                   | AD13/A13        | C <sub>8</sub>            |
|                              | 16                                   | PA5                       | F <sub>2</sub>            | 38                                   | AD14/A14        | C <sub>7</sub>            |
|                              | 17                                   | PA4                       | G1                        | 39                                   | AD15/A15        | B <sub>8</sub>            |
|                              | 18                                   | PA3                       | G <sub>2</sub>            | 40                                   | PC0             | B <sub>7</sub>            |
|                              | 19                                   | PA2                       | H <sub>2</sub>            | 41                                   | PC1             | A7                        |
|                              | 20                                   | PA1                       | G₃                        | 42                                   | PC2             | B <sub>6</sub>            |
|                              | 21                                   | PA0                       | H <sub>3</sub>            | 43                                   | A19/CSI         | A <sub>6</sub>            |
|                              | 22                                   | RD/E                      | G <sub>4</sub>            | 44                                   | V <sub>CC</sub> | B <sub>5</sub>            |

| Ordering<br>Information | Part Number  | Speed<br>(ns) | Package<br>Type | Package<br>Drawing | Operating<br>Temperature<br>Range | WSI<br>Manufacturing<br>Procedure |
|-------------------------|--------------|---------------|-----------------|--------------------|-----------------------------------|-----------------------------------|
|                         | PSD301-12J   | 120           | 44-pin PLDCC    | J2                 | Comm'l                            | Standard                          |
|                         | PSD301-12L   | 120           | 44-pin CLDCC    | L4                 | Comm'l                            | Standard                          |
|                         | PSD301-12X   | 120           | 44-pin CPGA     | X2                 | Comm'l                            | Standard                          |
|                         | PSD301-15J   | 150           | 44-pin PLDCC    | J2                 | Comm'l                            | Standard                          |
|                         | PSD301-15L   | 150           | 44-pin CLDCC    | L4                 | Comm'l                            | Standard                          |
|                         | PSD301-15LM  | 150           | 44-pin CLDCC    | L4                 | Military                          | Standard                          |
|                         | PSD301-15LM  | 150           | 44-pin CLDCC    | L4                 | Military                          | MIL-STD-883C                      |
|                         | PSD301-15X   | 150           | 44-pin CPGA     | X2                 | Comm'l                            | Standard                          |
|                         | PSD301-15XM  | 150           | 44-pin CPGA     | X2                 | Military                          | Standard                          |
|                         | PSD301-15XMB | 150           | 44-pin CPGA     | X2                 | Military                          | MIL-STD-883C                      |
|                         | PSD301-20J   | 200           | 44-pin PLDCC    | J2                 | Comm'l                            | Standard                          |
|                         | PSD301-20L   | 200           | 44-pin CLDCC    | L4                 | Comm'l                            | Standard                          |
|                         | PSD301-20LM  | 200           | 44-pin CLDCC    | L4                 | Military                          | Standard                          |
| ,                       | PSD301-20LMB | 200           | 44-pin CLDCC    | L4                 | Military                          | MIL-STD-883C                      |
|                         | PSD301-20X   | 200           | 44-pin CPGA     | X2                 | Comm'l                            | Standard                          |
|                         | PSD301-20XM  | 200           | 44-pin CPGA     | X2                 | Military                          | Standard                          |
|                         | PSD301-20XMB | 200           | 44-pin CPGA     | X2                 | Military                          | MIL-STD-883C                      |

**PSD301** 



PSD301\_\_\_\_\_

System Development Tools

| System<br>Development<br>Tools | The PSD301 features a complete set of<br>System Development Tools. These tools<br>provide an integrated, easy-to-use software<br>and hardware environment to support                                                     | PSD301 device development. To run these<br>tools requires an IBM-XT, -AT, or<br>compatible computer, MS-DOS 3.1 or<br>higher, 640K byte RAM, and a hard disk.                                                                                                         |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware                       | <ul> <li>The PSD301 System Programming<br/>Hardware consists of:</li> <li>WS6000 MagicPro Memory and PSD<br/>Programmer</li> <li>WS6013 44-pin LCC Package Adaptor<br/>(for CLDCC and PLDCC packages)</li> </ul>         | ❑ WS6014 44-pin CPGA Package Adaptor<br>The MagicPro Programmer is the common<br>hardware platform for programming all WSI<br>programmable products. It consists of an<br>IBM-PC plug-in programmer board and a<br>remote socket adaptor.                             |
| Software                       | <ul> <li>The PSD301 System Development Software consists of:</li> <li>WISPER, WSI's Software Environment</li> <li>MAPLE, the PSD301 Location Editor Software</li> <li>MAPPRO, the Device Programming Software</li> </ul> | The configuration of the PSD301 device is<br>entered using MAPLE software. MAPPRO<br>software uses the MagicPro programmer<br>and the socket adaptor to configure the<br>PSD301 device, which then can be used.<br>The development cycle is depicted in<br>Figure 26. |
| Support                        | WSI provides a complete set of quality support services to registered System Development Tools owners, including:                                                                                                        | <ul> <li>Design assistance from WSI field<br/>application engineers and application<br/>group experts</li> <li>24-hour electronic bulletin board for<br/>design assistance via dial-up modem.</li> </ul>                                                              |
| Training                       | WSI provides in-depth, hands-on workshops<br>for the PSD301 device and System<br>Development Tools. Workshop participants<br>learn how to program high-performance,                                                      | user-configurable mappable memory<br>subsystems. Workshops are held at the WSI<br>facility in Fremont, California.                                                                                                                                                    |

# Ordering Information — System Development Tools

- PSD301-GOLD
- WISPER Software
- MAPLE Software
- User's Manual
- WSI Support
- ❑ WS6000 MagicPro<sup>™</sup> Programmer
- US6013 44-pin LCC Package Adaptor
- Two PSD301-15L Samples

# PSD301-SILVER

- WISPER Software
- MAPLE Software
- User's Manual
- WSI Support

# WS6000

- MagicPro Programmer
- □ IBM-PC© plug-in Adaptor Card
- Remote Socket Adaptor

# WS6013

- 44-pin LCC Package Adaptor for CLDCC and PLDCC Packages
- Used with the WS6000 MagicPro Programmer

# WS6014

44-Pin CPGA Package Adaptor, Used with WS6000 MagicPro Programmer

# WSI Support

Support services include:

- 12-month Software Update Service
- Hotline to WSI Application Experts
- 24-hour access to WSI Electronic Bulletin Board

# WSI Training

- U Workshops at WSI, Fremont, CA
- ➡ For details and scheduling, call PSD Marketing (415) 656-5400





# Programmable System™ Device

PAC1000 Introduction

# User-Configurable Microcontroller

**Overview** 

In 1988 WSI introduced a new concept in programmable VLSI: the Programmable System<sup>™</sup> Devices (PSD). The PSD is defined as a family of *User-configurable* system level building blocks on-a-chip enabling quick implementation of application specific controllers and peripherals. The first generation PSD series includes the MAP168, a User-Configurable Peripheral with Memory; the SAM448, a User-Configurable Microsequencer; and the PAC1000, a User-Configurable Microcontroller.

The PAC1000 user-configurable highperformance microcontroller is the first of a generation of products intended for applications in high-end embedded control where high-speed data processing, interface or control is needed. The PAC1000 replaces a board full of discrete components such as standard logic, FIFO, EPROM for microcode store, ALU, SEQUENCER, register files and PAL/PLD/PGA. To shorten the time-to-market for the system designer, a high-level software development language is used. This contrasts with the myriad state-machine entry, schematic entry, and place and route tools that would be needed for a discrete design using PAL, PLD, PGA or gate arrays.

The PAC1000 architecture is flexible and enables the system designer to customize the PAC1000 to optimize application performance. The PAC1000 is composed of three basic sections: a CPU for data processing, a programmable instruction control unit that determines the next address to the microcode store through polling condition codes or responding to interrupts, and a host interface to asynchronously load data from the host. Registered input/outputs are used to synchronize with the system.

As a result of integrating logic and EPROM memory into the PAC1000 and defining a high-level language for programming both, time-to-market and board space is reduced and reliability increased. The PAC1000 is currently used in applications such as Intelligent DMA controller, FDDI buffer controller, Frame buffer controller, LAN communications controller, disk controller, and I/O controller. For further details on the PAC1000 see Application Note 10.

| Co | nte | nts |
|----|-----|-----|
|    |     |     |

| Features                                      |         | 2-65  |
|-----------------------------------------------|---------|-------|
| General Description                           |         | 2-66  |
| Architectural Overview                        |         | 2-68  |
| Operational Modes                             |         | 2-70  |
| Host Interface                                |         | 2-71  |
| FIFO                                          |         | 2-71  |
| Data I/O Registers                            |         | 2-73  |
| Program Counter                               |         |       |
| Status Register                               |         | 2-73  |
| Control Section                               |         |       |
| Parallel Operations                           |         |       |
| Program Memory                                |         |       |
| Security                                      |         |       |
| 15-Level Stack                                |         |       |
| Program Counter                               |         |       |
| Loop Counter                                  |         |       |
| Debug Capabilities                            |         |       |
| Breakpoint Register                           |         |       |
| Single Step                                   |         |       |
| Condition Codes                               |         |       |
| User-Specified Conditions                     |         |       |
|                                               |         |       |
| CPU Flags                                     |         |       |
|                                               |         |       |
| Stack-Full Flag                               |         |       |
| Interrupt Flag                                |         |       |
| Data Register Read Flag                       |         |       |
| Counter Flag                                  |         |       |
| Case Logic                                    |         |       |
| Case Instructions                             |         |       |
| Priority Case Instructions                    |         |       |
| Interrupt Logic                               |         |       |
| Interrupt Mask Register                       |         |       |
| Output Control                                |         |       |
| Counters                                      |         |       |
| Address Counter                               |         |       |
| Block Counter                                 |         |       |
| Central Processing Unit                       |         |       |
| Arithmetic Operations                         |         |       |
| Logic Operations                              |         |       |
| Shift Operations                              |         | 2-8   |
| Shift Right                                   |         | 2-8   |
| Shift Left                                    |         | 2-8   |
| Rotate Operations                             |         | 2-86  |
| Multiple Precision Operations                 |         | 2-86  |
| I/O and Special Functions                     |         | 2-86  |
| Configuration Registers                       |         | 2-88  |
| Control Register                              |         | 2-88  |
| I/O Configuration Register                    |         | 2-90  |
| Mode Register                                 |         |       |
| State Following Reset                         |         |       |
| Electrical and Timing Specifications          |         |       |
| Pin Assignments                               |         |       |
| Instruction Set Overview                      |         |       |
| System Development Tools                      |         |       |
| Hardware                                      |         |       |
| Software                                      |         |       |
| Support                                       |         |       |
| Support                                       |         |       |
| Ordering Information—PAC1000                  |         |       |
| Ordering Information—PAC1000                  |         |       |
| Ordening information—System Development Tools | ····· 2 | 2-111 |



**Preliminary** 

# Programmable System<sup>™</sup> Device

# PAC1000 User-Configurable Microcontroller

| Features | First Generation Programmable System<br>Device (PSD)                                                                  | Address Generation—Up To 4 Mbytes<br>Address Space                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
|          | High-Performance User-Configurable<br>Microcontroller—20 MHz Instruction Exe-<br>cution, Output Port, and Address Bus | High-Level Development Tools—System<br>Entry Language, Functional Simulator,<br>and Device Programmer |
|          | Single-Cycle Control Architecture—One<br>Cycle Per Instruction                                                        | Re-Programmable Program Store—<br>On-Board 1Kx64-Bit EPROM                                            |
|          | 16-bit CPU—Arithmetic Operations,<br>Logic Operations, 33 General-Purpose                                             | Two Operating Modes—Host Processor<br>Peripheral or Stand-alone Controller                            |
|          | Registers                                                                                                             | Security—For EPROM Program Memory                                                                     |



#### General Description

In 1988 WSI introduced a new concept in programmable VLSI, Programmable System Devices (PSD). The PSD family consists of user-configurable system-level building blocks on-a-chip, enabling quick implementation of application-specific controllers and peripherals. The first generation PSD series includes the MAP168, a User-Configurable Peripheral with Memory; the SAM448, a User-Configurable Microsequencer; and the PAC1000, a User-Configurable Microcontroller.

The PAC1000 User-Configurable Microcontroller is based upon an architecture that enables it to execute complex instructions in a single clock cycle. Each PAC1000 instruction can perform three simultaneous operations: Program Control, CPU functions, and Output Control, as shown in Figure 2. The PAC1000 can also perform address generation or event counting simultaneously with instruction execution. The PAC1000 is also capable of performing a conditional test on up to four separate conditions and multi-way branching in a single cycle.

The PAC1000, with its System Development Tools, matches the development cycle and ease of use of any standard microcontroller. The high performance and flexibility of the PAC1000 were previously available only to designers who could afford the long development cycle, high cost, high power, and large board space requirements of a building-block solution (i.e., Sequencer, Microcode Memory, ALU, Register File, PALs, etc.)

The unique capabilities of PAC1000 are easily utilized with System development tools, which include a PACSEL C-like System Entry Language, a PACSIM Functional Simulator, and a MagicPro<sup>™</sup> Device Programmer. All System Development Tools are PC-based and will operate on an IBM-XT, AT, PS2 or compatible machine. For more information, contact your nearest WSI sales office or representative.



# Table 1. Pin Description

| Signal        | I/O | Description                                                                                                                                                                                                                                                                                                                                     |  |
|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| HD[15:0]      | I/O | Host Data. PAC1000 Data I/O Port via the Host Inter-<br>face. Can also be configured to generate 16-bit ad-<br>dress or status. Can serve as a general-purpose Data<br>I/O Port.                                                                                                                                                                |  |
| HAD[5:0]      | I/O | Host Address. Can be configured to output the lower<br>six bits of the 22-bit Address Counter; can be used as<br>Host Interface function address, or as a general-<br>purpose 16-bit port.                                                                                                                                                      |  |
| CS            | I   | Chip Select (active low). Used with $\overline{RD}$ and $\overline{WR}$ to access the device via the Host Interface.                                                                                                                                                                                                                            |  |
| RD            | I   | Read Enable (active low). Used with $\overline{\text{CS}}$ to output Pro-<br>gram Counter, Status Register, or Data Output Regis-<br>ter to HD[15:0] bus lines.                                                                                                                                                                                 |  |
| WR            | I   | Write Enable (active low). Used with $\overline{\text{CS}}$ to write HD Bus data via the Host Interface into the PAC1000 FIFO.                                                                                                                                                                                                                  |  |
| СК            | 1   | Clock.                                                                                                                                                                                                                                                                                                                                          |  |
| CC[7:0]       | I   | Condition Codes. Condition-code inputs for use with Call, Jump, and Case instructions.                                                                                                                                                                                                                                                          |  |
| INT[3:0]      | Ι   | Interrupts. General-purpose, positive-edge-triggered interrupt inputs.                                                                                                                                                                                                                                                                          |  |
| RESET         | I   | Asynchronous Reset (active low). Resets Input/Output registers and counters, tri-states all I/O, and sets the Program Counter to 0.                                                                                                                                                                                                             |  |
| OUTCNTL[15:0] | 0   | Output Control. User-defined Output Port. May be pro-<br>grammed to change value every cycle.                                                                                                                                                                                                                                                   |  |
| ADD[15:0]     | I/O | Address Port. Outputs data from Address Counter or<br>Address Output Register when configured as an<br>output. When configured as an input, reads data to<br>Address Input Register.                                                                                                                                                            |  |
| I/O[7:0]      | I/O | Input or Output Port. Individually configurable bidirec-<br>tional bus. As simple I/O, outputs come from the I/O<br>Output Register, and inputs appear in the I/O Input<br>Register. As special I/O functions, provides status,<br>handshaking, and serial I/O. Alternatively, these signals<br>can be used to extend the OUTCNTL or ADD lines. |  |

#### Architectural Overview

The PAC1000 is a user-configurable microcontroller optimized for high-performance control systems. The primary architectural elements, shown in Figure 3, are the Control Section, 16-bit CPU, Host Interface, 16-bit Address Port, 16-bit Output Control, 8-bit I/O Port, and Configuration Registers.

The PAC1000 can be used as a stand-alone microcontroller or as a peripheral to a host. In the latter case, the Host Data (HD) and Host Address (HAD) buses, together with the  $\overline{CS}$ ,  $\overline{RD}$ , and  $\overline{WR}$  pins allow for direct connection to a host bus. User-defined commands to the Control Section or data to the CPU can be loaded through the Host Interface.

In the stand-alone mode, the Host Interface ports can be used as additional address, data or I/O ports using the Data Output Register (DOR) and Data Input Register (DIR). The ADD port can be used to generate addresses through the Address Output Register (AOR) or the Address Counter. A DMA channel can be formed on the Host Interface using these and the Block Counter (BC) register. In addition, the ADD port can be used as a data bus or an I/O port, depending on how the chip is configured. Each pin in the I/O port can be configured individually as input. output, or special function. The special functions allow the control of internal PAC1000 elements (counters, I/O buffers) by other board elements.

The 16-bit CPU is highly parallel and can operate on operands from the 32x16-bit

register file, miscellaneous register (AOR, AIR, DOR, DIR, Q, etc.), or constants loaded from the internal program-store EPROM.

The internal and external operations of the PAC1000 are controlled by the Control Section. The 16 Output Control (OC) lines are general-purpose outputs. Each of them can be changed independently every clock cycle. They provide a very fast means to control various processes outside the chip.

In every clock cycle, one instruction is executed. Each instruction consists of up to three operations in parallel:

- Instruction Fetch—the next instruction is fetched from the 1Kx64 EPROM by the Program Control.
- Execution—the CPU executes an instruction.
- Output—placed on the Output Control (OC) lines.

Program flow can be changed through the condition-code inputs in one clock cycle or through the interrupt inputs after two clock cycles. Single-cycle 16-way branches can be done using the Case instruction, which samples four condition codes per cycle. Nested loops and subroutines can be carried out with the 15-level stack and the loop counter. The chip configuration can be changed in any cycle by loading the Configuration Register using the Program Control instruction portion.





# Operational Modes

The two basic modes of operation for the PAC1000 are either as a memory-mapped peripheral (Figure 4) or as a stand-alone controller (Figure 5).

In the peripheral mode, the host processor can asynchronously interface with the PAC1000.





# **Host Interface**

The Host Interface section of the PAC1000, shown in Figure 6, includes the Input Command/Data FIFO, Input/Output Data Registers, and the Status Register.

#### FIF0

When the PAC1000 serves as a peripheral to a host, the FIFO is used to asynchronously load commands or data into the PAC1000. In order to write into the FIFO,  $\overline{CS}$  and  $\overline{WR}$ must have low-to-high transitions. The information written into the FIFO is specified by the 16-bit Interface Data bus (HD) and the 6-bit Host Address bus (HAD). Since the FIFO is used only to buffer data and commands from a host, it is inoperative when the PAC1000 is in stand-alone mode. Bit five of the HAD bus specifies whether the input to the FIFO is command (HAD5=1) or data (HAD5=0). HAD5 is connected to the FICD internal Condition Code that can be sampled by the Control Section. If a command is written, then the lower 10 bits of the HD bus are used as the branch address for one of the 1024 locations in the Program Memory EPROM. At that location a user defined command or subroutine should exist which executes the needed operation. If the information is data, then the lower 5 bits of the HAD bus specify which CPU register is to be loaded from the HD bus.

This method of operation allows the host to access the PAC1000 as a memory-mapped peripheral.



# *Figure 6. Host Interface Architecture*

#### PAC1000

# Host Interface

(Con't)

An example of FIFO usage is shown in Figure 7. When command or data information is available in the FIFO, the FIFO Output Ready (FIOR) interrupt (interrupt 5) triggers. If the FIOR interrupt is masked, then the FIOR status may be polled under program control. If HAD5 equals 1, the branch address location specified by MOVE is the Program Memory Address which contains the user specified instruction or sub-routine which executes the command. A JUMP or CALL FIFO control instruction performs a jump or call to the location specified by MOVE. If HAD5 equals 0, an RDFIFO instruction can transfer the FIFO contents into the register specified by HAD[4:0].

For further explanation, refer to the diagram below. Beginning at the location specified by MOVE, a user defined program exists which is going to load data into CPU registers 0,1,2, and 3 in four consecutive cycles from the next four FIFO locations. If one of the four FIFO locations contains a command (FICD=1), interrupt level 7 occurs (highest level). Loading a command into a CPU or other data register is not allowed. If this occurs, FIXP (FIFO exception) will be generated.

Following the execution of this routine, the Control Section is ready for its next instruction.

The FIFO drives three internal flags which can also be programmed to interrupt the PAC1000. They are:

- FIIR (FIFO full) and FIXP (FIFO exception), which drive INT7.
- FIOR (FIFO output ready), which drives INT5.

| Table 2.<br>Host Interface | CS | RD | WR | HAD5 | HAD[4:0]            | HD[15:0] | Function                  |
|----------------------------|----|----|----|------|---------------------|----------|---------------------------|
| Functions                  | 0  | 1  | 0  | 0    | Register<br>Address | Data     | Write data to FIFO        |
|                            | 0  | 1  | 0  | 1    | Х                   | Command  | Write command to FIFO     |
|                            | 0  | 0  | 1  | 0    | 00100               | х        | Reset FIFO                |
|                            | 0  | 0  | 1  | 0    | 00011               | х        | Reset status register     |
|                            | 0  | 0  | 1  | 0    | 00010               | Data     | Read program counter      |
|                            | 0  | 0  | 1  | 0    | 00001               | Data     | Read status register      |
|                            | 0  | 0  | 1  | 0    | 00000               | Data     | Read data output register |

### Host Interface (Con't)

#### Data I/O Registers

Input and Output Data Registers are used to communicate with the Host Data (HD) bus. CPU Registers may be loaded directly from the Data Input Register (DIR) without passing through the FIFO. Similarly, the PAC1000 may be read via the Data Output Register (DOR).

#### **Program Counter**

The Program Counter may be read via the Host Data bus. This allows a host to monitor

the Program Memory address bus. It can also be used to drive external memory devices for expansion of the Control Port.

#### Status Register

The Status Register (SR), shown in Figure 8, monitors all internal status. Status bits can be set only by program execution. The SR can be read or cleared as specified in the Host Interface Functions table.

All SR flags are active high (1) and are latched at the rising edge of the clock.



### PAC1000

| Host Interface<br>(Con't) | STAT11—(DBB) <i>Security Bit</i> , set when<br>security is active:                                                 | STAT4—(S) <i>Sign Bit</i> , set when the most<br>significant bit of the result of the previous          |  |  |  |  |
|---------------------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|
|                           | 1= Security active.                                                                                                | CPU operation is negative:                                                                              |  |  |  |  |
|                           | 0= No security.                                                                                                    | 1= Result is negative.                                                                                  |  |  |  |  |
|                           | STAT10—WSI Reserved.                                                                                               | 0= Result is positive.                                                                                  |  |  |  |  |
|                           | STAT9—(FIXP) FIFO Exception, set when<br>the CPU receives a command or Control                                     | STAT3—(STKF) <i>Stack Flag</i> , set when the stack is full:                                            |  |  |  |  |
|                           | Section receives data:                                                                                             | 1= Stack is full.                                                                                       |  |  |  |  |
|                           | 1= Command or data received.                                                                                       | 0= Stack is not full.                                                                                   |  |  |  |  |
|                           | 0= No exception occurred.                                                                                          | STAT2—(BRKPNT) Breakpoint Flag, set                                                                     |  |  |  |  |
|                           | STAT8—(FIIR) FIFO-Input Ready, set when<br>there is at least one vacant location in the                            | when the address in the breakpoint<br>register is equal to the EPROM address<br>1= Breakpoint occurred. |  |  |  |  |
|                           | FIFO:                                                                                                              |                                                                                                         |  |  |  |  |
|                           | 1= FIFO ready for input.                                                                                           | 0= No breakpoint occurred.                                                                              |  |  |  |  |
|                           | 0= FIFO not ready for input.                                                                                       | STAT1—(BCZ) Block Counter Zero, set<br>when the counter decrements to all 0s:                           |  |  |  |  |
|                           | STAT7—(CY) <i>Carry Flag</i> , set when a carry<br>(addition) or borrow (subtraction) occurs<br>in CPU operations: | 1= Block Counter reached zero.                                                                          |  |  |  |  |
|                           |                                                                                                                    | 0= Block Counter is not zero.<br>STAT0—(ACO) <i>Address Counter Ones</i> , set                          |  |  |  |  |
|                           | 1= Carry occurred.                                                                                                 |                                                                                                         |  |  |  |  |
|                           | 0= No carry occurred.                                                                                              | when the counter increments to all 1s:                                                                  |  |  |  |  |
|                           | STAT6—(Z) Zero Flag, set when the result of                                                                        | 1= Address Counter reached all ones.                                                                    |  |  |  |  |
|                           | a CPU operation is zero:                                                                                           | 0= Address Counter is not all ones.                                                                     |  |  |  |  |
|                           | 1= Zero occurred.                                                                                                  |                                                                                                         |  |  |  |  |
|                           | 0= No zero occurred.                                                                                               |                                                                                                         |  |  |  |  |
|                           | STAT5—(O) <i>Overflow Flag</i> , set when an<br>overflow occurs during a two's comple-<br>ment operation:          |                                                                                                         |  |  |  |  |
|                           | 1= Overflow occurred.                                                                                              |                                                                                                         |  |  |  |  |
|                           | 0= No overflow occurred.                                                                                           |                                                                                                         |  |  |  |  |



# **Control Section**

The control section, shown in Figure 9, consists of a number of blocks which are concerned with the sequencing of the control programs in the PAC1000. These are:

- Program Memory
- Security
- 15-Level Stack
- Program Counter
- Loop Counter
- Breakpoint Register
- Condition Codes

- Case Logic
- Interrupt Logic
- Output Control

Each block is described in detail below.

#### Parallel Operations

The PAC1000 can perform three simultaneous operations within a single instruction cycle, as shown in Figure 10. The ability to fetch an instruction from the Program Memory, execute it, and output a result within 50 nsec is due to a highly parallel structure.



| Control Section                      | Program Memory                                                                    |                                                                                                                                                                                | Thereafter, the EPROM contents cannot be                                                                                                                                                                                                                                                                                                                                                      |  |  |
|--------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| (Con't)                              | •                                                                                 | mory is a 1Kx64 high-speed                                                                                                                                                     | read externally. When the EPROM is erased the security bit is cleared.<br>15-Level Stack                                                                                                                                                                                                                                                                                                      |  |  |
|                                      |                                                                                   | rate in embedded control                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                      | external memory<br>erasable memor<br>modified for deb<br>The Program Me           | eliminates the need for<br>components. Using an<br>y allows program code to be<br>ug and/or field upgrades.<br>emory is easily programmed<br>agicPro™ (Memory and<br>mer).     | The 15-level Stack stores the return address<br>following subroutine calls, interrupt service<br>routines and the contents of the Loop<br>Counter inside nested loops. When the stact<br>is full, the STKF condition becomes true, an<br>an interrupt (INT7) will occur. The interrupt<br>service routine will overwrite the top of the                                                       |  |  |
|                                      |                                                                                   | gram Memory locations are<br>st of the 1024 locations are<br>lications.                                                                                                        | stack.<br>Popping from an empty stack produces the                                                                                                                                                                                                                                                                                                                                            |  |  |
|                                      | ••                                                                                | y is segmented as follows:                                                                                                                                                     | previous top of stack value; pushing on a full<br>stack overwrites the top of the stack.                                                                                                                                                                                                                                                                                                      |  |  |
|                                      | Address                                                                           | Function                                                                                                                                                                       | Program Counter                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                      | 000H                                                                              | Reset pointer program to here                                                                                                                                                  | The 10-bit Program Counter (PC) generates sequential addressing to the 1K word Pro-                                                                                                                                                                                                                                                                                                           |  |  |
|                                      | 000H–007H                                                                         | User Defined<br>Initialization Routine                                                                                                                                         | gram Memory. Upon reset the PC is loaded<br>with a 000H. From this point the value of the<br>Program Counter is determined by program                                                                                                                                                                                                                                                         |  |  |
|                                      | 008H-00FH                                                                         | Interrupt Vector<br>Locations                                                                                                                                                  | execution or interrupts.<br>Any JUMP or Case instruction that is exe-                                                                                                                                                                                                                                                                                                                         |  |  |
|                                      | 010H–3FFH                                                                         | User-Defined<br>Application Programs                                                                                                                                           | cuted loads the Program Counter with the<br>destination address. CALL instructions or<br>interrupts cause PC + 1 to be pushed onto<br>the stack. The RETURN instruction loads the<br>Program Counter from the stack with the<br>value of the return address. This value may<br>have previously been placed on the stack by<br>a CALL or interrupt.<br>The PC can also be loaded from the Com- |  |  |
|                                      | is forced to addr<br>contain a jump o<br>initialization rout<br>eight locations o | a reset, the Program Counter<br>ess 000H. This location may<br>r call which branches to an<br>ne. Alternatively, the first<br>f memory may be used as an<br>iguration routine. |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                      | Security                                                                          | -                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                      |                                                                                   | nay be protected by setting a generating be protected by setting a generating.                                                                                                 | mand/Data FIFO causing program executio<br>to commence at an address provided by the<br>host.                                                                                                                                                                                                                                                                                                 |  |  |
| Figure 10.<br>Parallel<br>Operations |                                                                                   |                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| operations                           |                                                                                   | I<br>I<br>Part of Control St                                                                                                                                                   | l<br>I<br>I                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                      |                                                                                   | Fait of Control Si                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                      |                                                                                   | Program N                                                                                                                                                                      | rogram<br>Aemory<br>Κ × 64Κ<br>EPROM                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                                      |                                                                                   | ,20                                                                                                                                                                            | ¢64                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                                      |                                                                                   |                                                                                                                                                                                | Output CPU<br>Control Instruction                                                                                                                                                                                                                                                                                                                                                             |  |  |

16

OC[0 15]

28

To the CPU

1738 10

# Control Section (Con't)

#### Loop Counter

The Loop Counter (LC) has two functions:

- 10-bit down counter that supports the LOOP instruction.
- Branch Register that can be loaded from the CPU Register File or Program Memory and used as an additional source of branching to Program Memory.

The LC can be loaded with values up to 1023. Loop initialization code places a value in LC. Loop termination code tests the counter for a zero value and then decrements LC. The loop count can be a constant, or it can be computed at execution time and loaded into LC from the CPU. The LC register can also be used as a CALL or JUMP execution vector. The content of the LC is automatically saved on (or retrieved from) the Stack when the program enters (or leaves) a nested loop.

A loop count will be loaded into the LC when a FOR instruction is encountered. This count can be a fixed value or it can be calculated and loaded from the CPU. The ENDFOR instruction will test the Loop Counter for a zero value. If this condition is not met, then the LC will be decremented by one. The program loop will continue until the count value equals zero. In a nested loop, the FOR instruction will load a new value to the LC and push the previous value to the stack.

#### **Debug Capabilities**

The PAC1000 provides breakpoint and single step capabilities for debugging application programs.

#### Breakpoint Register

The Breakpoint Register (BR) is a 10-bit register used for real time debug of the PAC1000 application program.

The Breakpoint Register can be loaded from one of two sources, either a constant value specified in the Program Memory or a calculated value loaded from the CPU. When the Program Memory address matches the contents of the Breakpoint Register an interrupt (INT 6) occurs. A service routine should exist in Program Memory which then performs the required procedure.

#### Single Step

Single step is a debugging mode in which the currently-executing program is interrupted by interrupt 6 after the execution of every instruction. The interrupt 6 service routine should reside in Program Memory.

Bit 8 in the Mask Register determines whether the PAC1000 is in a breakpoint mode (mask-bit 8 equals 0) or in a single step mode (mask-bit 8 equals 1).

Both breakpoint and single step use interrupt 6. The interrupt 6 service routine will typically dump the contents of the PAC1000 internal registers into external SRAM devices for examination by the user.

#### **Condition Codes**

The Condition Code (CC) logic operates on 21 individual program test conditions. Each condition can be tested for true or not true. The PAC1000 can also test up to four conditions simultaneously. For this feature refer to the section titled *Case Logic*.

| PAG 1000                   |                                                                                                                                                                                           |                                                                                                                            |                                                                                                                                                                                                                                                                                                             |  |  |  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Control Section<br>Con't)  | User-Specified Condition<br>User-Specified Conditi<br>same manner as intern                                                                                                               | ions are treated in the                                                                                                    | FIFO Input Ready (FIIR)—FIFO is not full<br>(FIIR=1). This flag can also be connected<br>to the host through I/07.                                                                                                                                                                                          |  |  |  |
|                            | conditions. CC0—CC7<br>directly to the correspo                                                                                                                                           | 7 should be connected<br>onding PAC1000 input<br>ust satisfy the required                                                  | FIFO Command/Data (FICD)—This flag<br>indicates if the contents of the FIFO is a<br>command or a data. This flag is gener-<br>ated directly from HAD5 (FICD=1 com-<br>mand, FICD=0 data).                                                                                                                   |  |  |  |
|                            | CPU flags are internal<br>reflect the status of the<br>metic operation. These<br>latched and are valid of<br>(the instruction followin<br>The flags for arithmetic<br>defined as follows: | e previous CPU arith-<br>e signals are internally<br>only for one instruction<br>ng their generation).<br>c operations are | <ul> <li>FIFO Exception (FIXP)—This flag indicates that one of two events occurred: (a) FIFO data has been read as a command, or (b) a command has been read as data.</li> <li>Stack-Full Flag</li> <li>STACK FULL flag (STKF=1) indicates that the stack is 15 levels full. This condition will</li> </ul> |  |  |  |
|                            | Zero (Z)—The result o<br>operation is zero (                                                                                                                                              |                                                                                                                            | also generate an interrupt (INT7) if not masked.                                                                                                                                                                                                                                                            |  |  |  |
|                            | Carry (CY)—The resu<br>operation generate<br>borrow (subtractio<br>Overflow (O)—The pre                                                                                                   | ed a carry (addition) or<br>n) (CY=1).                                                                                     | Interrupt Flag<br>INTERRUPT flag (INTR =1) indicates that<br>there is a masked interrupt pending. This flag<br>is cleared when the interrupt is cleared.<br>Data Register Read Flag                                                                                                                         |  |  |  |
|                            | ment CPU operati<br>overflow (O=1).                                                                                                                                                       |                                                                                                                            |                                                                                                                                                                                                                                                                                                             |  |  |  |
|                            | negative (S=1).<br><i>FIFO Flags</i><br>FIFO flags allow the u                                                                                                                            | ous CPU operation is ser to synchronize and                                                                                | DATA REGISTER READ flag (DOR) is a<br>handshake flag between the host and the<br>PAC1000, accessible only to the PAC1000.<br>The flag is reset (DOR=0) when the<br>PAC1000 writes into the Data Output Regis-<br>ter. The flag is set (DOR=1) after the host<br>has performed a read on the Data Output     |  |  |  |
|                            | monitor the operations<br>the FIFO by the host o                                                                                                                                          | s that are performed on<br>or by user's program.                                                                           | Register.                                                                                                                                                                                                                                                                                                   |  |  |  |
|                            | Upon reset the FIFO f<br>signifying an empty sta<br>flags are as follows:                                                                                                                 | lags are cleared,<br>ate. The meaning of the                                                                               | Counter Flag<br>Counter flags reflect the status of their<br>respective counters. The PAC1000 utilizes                                                                                                                                                                                                      |  |  |  |
|                            | FIFO Output Ready (F<br>one word in the FI                                                                                                                                                | FIOR)—There is at least<br>IFO (FIOR=1).                                                                                   | two counters; the Address (A) counter is a 16/22-bit auto-incrementing up counter; the                                                                                                                                                                                                                      |  |  |  |
| Table 3.<br>Condition-Code | Test Group                                                                                                                                                                                | Source                                                                                                                     | Conditions and Flags                                                                                                                                                                                                                                                                                        |  |  |  |
| Logic                      | User-Specified                                                                                                                                                                            | External                                                                                                                   | CC0–CC7                                                                                                                                                                                                                                                                                                     |  |  |  |
|                            |                                                                                                                                                                                           | Late of the                                                                                                                |                                                                                                                                                                                                                                                                                                             |  |  |  |

| <br>•              |                   |                                                                                                          |
|--------------------|-------------------|----------------------------------------------------------------------------------------------------------|
| User-Specified     | External          | CC0–CC7                                                                                                  |
| CPU                | Internal          | Carry (CY), Zero (Z), Overflow (O),<br>Sign (S)                                                          |
| FIFO               | Internal          | FIFO Command/Data (FICD), FIFO Output<br>Ready (FIOR), FIFO Input Ready (FIIR),<br>FIFO Exception (FIXP) |
| Counters           | Internal          | Address Counter Ones (ACO), Block<br>Counter Zero (BCZ)                                                  |
| Stack              | Internal          | Stack Full (STKF)                                                                                        |
| Interrupt          | External/Internal | Interrupt (INTR) is pending                                                                              |
| Data register read | Internal          | Data Output Register(DOR) has been read                                                                  |
|                    |                   |                                                                                                          |

# **Control Section** (Con't)

Block (B) counter is an auto-decrementing 16-bit down counter. The counters' clock input signal is the same as the PAC1000's clock signal. Each counter can be individually enabled or disabled. When disabled, the output retains the last count. The counter flags are defined as follows:

- ACO-A Counter Ones, set when the A counter has reached the value FFFFH, in the 16-bit mode, or the value 3FFFFFH in the 22-bit mode.
- BCZ-B Counter Zero, set when the B counter has reached the value 0000H.

#### **Case Logic**

THE PAC1000 hardware implements two basic types of Case instructions: Case and Priority Case.

#### Case Instructions

Case instructions operate on any one of four different Case groups. Each Case group consists of a combination of four test conditions which can be tested in a single cycle. In that same cycle the PAC1000 will branch to one of the addresses contained in the sixteen memory locations following the instruction, depending on the status of the four inputs to the Case group being tested.

There are four Case Groups (sets of Case Conditions):

Case Group 0 (CG0): CC0-CC3.

Case Group 1 (CG1): CC4-CC7.

Case Group 2 (CG2):

Z-Zero O-Overflow S—Sian CY-Carry

Case Group 3 (CG3): INTR-Interrupt BCZ-B Counter Zero FIOR—FIFO output Ready FICD-FIFO Command/Data

(The FIXP, ACO, STKF, FIIR, and DOR condition codes do not fall into any of the four Case groups.)

#### Priority Case Instructions

Priority Case instructions operate on the four internal and the four external interrupt inputs. In this mode of operation, interrupts are treated as prioritized test conditions and the priority encoder is used to generate a branch to the highest priority condition. The branch address is located in one of the nine memory locations following the Priority Case instruction. Priorities in this mode of operation are the same as in the Interrupt mode of operation. Once a Priority Case instruction is executed, the occurrence of a higher priority condition will not affect program execution until another Priority Case instruction is executed. For a Priority Case instruction to be executed. MODE0 of the Mask Register must be equal to zero (MODE0=0).

#### Interrupt Logic

The Interrupt Logic accepts eight inputs, four of them are generated externally and four are dedicated for internal conditions. The four external, user defined, inputs (INT0-INT3) are connected to pins INT0, INT1, INT2, and INT3. These are positive, rising-edgetriggered signals that have a maximum latency of two cycles. Each interrupt has a reserved area in memory that should contain a branch to an interrupt service routine.

| Table 4.    |           |          |          |                          |                  |
|-------------|-----------|----------|----------|--------------------------|------------------|
| nterrupt    | Interrupt | Priority | Effect   | Trigger Condition        | Reserved Address |
| Assignments | INT7      | Highest  | Internal | FIXP+ACO+STKF+FIIR       | 00FH             |
|             | INT6      |          | Internal | BRKPT                    | 00EH             |
|             | INT5      |          | Internal | FIOR                     | 00DH             |
|             | INT4      |          | Internal | Software Interrupt (SWI) | 00CH             |
|             | INT3      |          | External | INT3                     | 00BH             |
|             | INT2      |          | External | INT2                     | 00AH             |
|             | INT1      |          | External | INT1                     | 009H             |
|             | INTO      | Lowest   | External | INT0                     | 008H             |
|             |           |          |          |                          |                  |

# Ta In A

| Control Section<br>(Con't) | Clearing a serviced interrupt is performed<br>automatically. When the interrupt is serviced,<br>the internally generated vector is decoded to<br>clear the serviced interrupt. In addition, the<br>user can clear any pending interrupt by using<br>the Clear Interrupt Instruction (CLI). | When the PAC1000 is reset, the Mask Regis-<br>ter will mask all interrupts and the Mode<br>Register will select the non-interrupt mode.<br>To select the interrupt mode the MODE0 bit<br>(see Configuration Register section in this<br>document) should be set to 1 (MODE0=1). |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Interrupt Mask Register<br>The Interrupt Mask Register, shown in Figure<br>11, allows individual interrupts to be masked.<br>Setting a Mask Register bit to a 1 masks the<br>associated interrupt. To unmask an interrupt,<br>the appropriate Mask Register bit must be<br>reset to 0.     | Mask8 is used to select INT6 to be either a<br>single-step interrupt (when Mask8=1) or a<br>breakpoint interrupt (when Mask8=0) .See<br>the section on Debug Capabilities for further<br>details.                                                                               |

| nterrupt    | Interrupt         | Triggered By                                                |
|-------------|-------------------|-------------------------------------------------------------|
| Definitions | INT7 <sup>1</sup> | FIFO Exception (FIXP)                                       |
|             |                   | Address Counter contains all Ones (ACO)                     |
|             |                   | Stack Full (STKF)                                           |
|             |                   | FIFO Full (Not FIFO Input Ready, FIIR)                      |
|             | INT6 <sup>2</sup> | Breakpoint or Single Step occurrence                        |
|             | INT5              | FIFO Output Ready (FIOR)                                    |
|             | INT4              | Always pending; triggers when unmasked by program execution |
|             | INT3              | User-defined                                                |
|             | INT2              | User-defined                                                |
|             | INT1              | User-defined                                                |
|             | INTO              | User-defined                                                |

Notes:

- 1. The INT7 interrupt handler checks the source of the interrupt by testing the condition code.
- 2. See Interrupt Mask Register, Mask8.



|                            |                                                                                                                                                                                                                                                                                                                                                    | PAC1000                                                                                                                                                                                                                                                                                                                                    |  |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Control Section<br>(Con't) | <b>Dutput Control</b><br>The Output Control bus (OUTCNTL) consists<br>of 16 latched Output Control signals. These<br>signals can be changed on a clock to clock<br>basis. For every Program Memory location                                                                                                                                        | OUTCNTL Operation places this value on the<br>Output Control bus. The OUTCNTL Opera-<br>tion can be performed in parallel with any<br>other PAC1000 instructions.<br>The OUTCNTL bus can be used to control<br>external events on a clock to clock basis.                                                                                  |  |  |
|                            | there is a dedicated field which specifies the value of the Output Control bus. The                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                            |  |  |
| Counters                   | The PAC1000 contains a 16 or 22-bit Ad-<br>dress Counter and a 16-bit Block Counter.<br>Each of these counters can change count on<br>a clock to clock basis or can be internally or<br>externally enabled or disabled on a clock to<br>clock basis. These counters are in addition to<br>the Loop and Program Counters of the<br>Control Section. | until the counter is loaded with a new value.<br>The counter will continue to count until<br>disabled. ACO is a condition code and a<br>member of a Case Group; see the Control<br>Section description for more details. ACO can<br>also generate an internal interrupt 7, if<br>enabled.<br>In the 16-bit mode, the counter outputs (ACH) |  |  |
|                            | Address Counter                                                                                                                                                                                                                                                                                                                                    | are available through the ADD bus. The                                                                                                                                                                                                                                                                                                     |  |  |
|                            | The Address Counter (AC), shown in Figure                                                                                                                                                                                                                                                                                                          | count is gated to the ADD bus by setting the ASEL bit (CTRL9) of the Control Register.                                                                                                                                                                                                                                                     |  |  |
|                            | 12, is a 16- or 22-bit ascending counter that<br>can be loaded or read by the CPU and                                                                                                                                                                                                                                                              | In the 22-bit mode, the higher 16 bits (ACH)<br>are available through the ADD bus and the<br>six low order bits (ACL) are available through<br>the Host Address (HAD) bus. These low                                                                                                                                                       |  |  |
|                            | enabled/disabled with the ACEN bit of the<br>Control Register. (This control is also avail-                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                            |  |  |
|                            | able externally through the I/01 pin; see I/O                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                            |  |  |
|                            | and Special Functions). While enabled, the<br>counter will increment by one every rising                                                                                                                                                                                                                                                           | order bits are multiplexed with the host                                                                                                                                                                                                                                                                                                   |  |  |
|                            | edge of the clock.                                                                                                                                                                                                                                                                                                                                 | address lines. The address lines from the<br>host which drives the HAD bus must be                                                                                                                                                                                                                                                         |  |  |
|                            | The ACO flag indicates that the value of the counter is all ones. This flag stays latched                                                                                                                                                                                                                                                          | placed in the high impedance state before the<br>lower 6-bits (ACL) of the Address Counter<br>can be read.                                                                                                                                                                                                                                 |  |  |
| Figure 12.<br>Address and  | Interna                                                                                                                                                                                                                                                                                                                                            | al Bus                                                                                                                                                                                                                                                                                                                                     |  |  |
| Block Counter              |                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                            |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    | 16 16 6                                                                                                                                                                                                                                                                                                                                    |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                            |  |  |
|                            | IBCEN Block<br>Counter Swap                                                                                                                                                                                                                                                                                                                        | Address<br>Count<br>High<br>AOR                                                                                                                                                                                                                                                                                                            |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                            |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    | Host Interface                                                                                                                                                                                                                                                                                                                             |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    | MUX ASEL                                                                                                                                                                                                                                                                                                                                   |  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                    | 1                                                                                                                                                                                                                                                                                                                                          |  |  |

1738 12

IADOE

Į16 ¥ ADD[0.15]

| PAC1000                    |                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Counters<br>(Con't)        | Selecting the 16- or 22-bit count mode is performed by setting or resetting the ACS22 bit in the I/O Configuration Register.                                                                                                                                                                                                                                                                          | ally) available externally through the I/O0 bit<br>(see I/O and Special Functions). While<br>enabled, the counter will decrement by one<br>every rising edge of the clock. The BCZ flag<br>indicates that the counter reached the zero<br>value. After the occurrence of an all 0s<br>condition the Block Counter will continue<br>down counting until disabled. The flag is<br>latched and can be cleared by loading a new<br>value into the Block Counter. BCZ is a<br>condition code and a member of a Case<br>Group; see the Control Section description<br>for more details. |  |  |
|                            | The address Output Register is an alternate<br>source of address outputs; it is selected by<br>resetting the ASEL bit of the Control Regis-<br>ter. In this mode the CPU can be used to<br>provide address generation and the Address<br>Counter can be used as an event counter.<br><b>Block Counter</b><br>The Block Counter (BC) is a 16-bit down<br>counter. It is enabled by the BCEN bit of the |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                            | Control Register. It is useful as a counter for DMA transfers. The BCEN signal is (option-                                                                                                                                                                                                                                                                                                            | Both counters may be read without disabling the count operation and loaded via the CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Central<br>Processing Unit | The CPU, shown in Figure 13, performs<br>16-bit operations in a single clock cycle. It<br>contains 33 general purpose registers<br>(R0R31, and Q). The Q register can be<br>used in conjunction with any of the R0R31<br>registers to perform double precision shift                                                                                                                                  | operations. The main building blocks are the<br>register bank (R0R31), Q register, ALU,<br>Y-bus devices, and D-bus devices. The<br>register bank supplies up to two 16-bit<br>registers, one of which is always the destina-<br>tion register.                                                                                                                                                                                                                                                                                                                                   |  |  |

Figure 13. CPU Block Diagram



2

#### PAC1000

Central The ALU operates on up to two external latched carry-out (adequate for multiple **Processina Unit** operands that are selected by its input MUX. precision operations). (Con't) In every instruction, 1 of the 10 D-bus de-The ALU's output or a selected register can vices (AOR, SWAP, ACL, ACH, BC, FIFO, be loaded into one of the seven Y-bus DIR, AIR, IIR, and Program Store) or a devices (IOR, AOR, LC, DOR, ACL, ACH, or member of the register bank or the Q register BC) every instruction cycle. This can happen outputs, can be selected as an operand in parallel with the feedback path from the source to the ALU. The possibilities are ALU's output that is directed either to the Q shown in Figure 14. During ALU operations, register or to the destination register of the three options can be selected to provide the register bank. carry-in (Cin) input: 0, 1, or the previous



*Table 6. CPU Operand Mnemonics* 

| Mnemonic              | Description                                                           |
|-----------------------|-----------------------------------------------------------------------|
| ACH or ACH/ACL        | 16- or 22-bit Auto-incrementing Counter, or General Purpose Registers |
| AIR                   | Address Input Register                                                |
| AOR                   | Address Output Register                                               |
| BC                    | Block Counter (16-bit auto-decrementing), or General Purpose Register |
| <constant></constant> | Constant values in Program Storage                                    |
| DIR                   | Data Input Register                                                   |
| DOR                   | Data Output Register                                                  |
| FIFO                  | Input Data from FIFO                                                  |
| liR                   | I/O Input Register                                                    |
| IOR                   | I/O Output Register                                                   |
| LC                    | Program Loop Counter                                                  |
| Q                     | 16-bit CPU Register                                                   |
| R0R31                 | 16-bit CPU Registers                                                  |
| SWPV                  | Byte Swap version of AOR                                              |

# Central Processing Unit (Con't)

CPU operations can be performed on one, two or three operands. Each operation is performed in a single clock cycle. In two- or three-operand instructions, one of the operands must be a CPU internal register (R0...R31, or Q).

CPU operations are performed independently of operations in the counters, Host Interface, Output Control, and Program Control.

#### Arithmetic Operations

The CPU can perform the following arithmetic operations:

- Addition
- Subtraction
- Increment
- Decrement
- Compare

#### **Logic Operations**

The CPU can perform the following logic operations:

- AND
- OR OR
- Invert
- Exclusive OR
- Exclusive NOR

#### Shift Operations

Single shift operations, shown in Figure 15, can occur either to the left or to the right, with or without the Q register. Shift instructions specify the sources that are shifted into the corresponding registers.

All shift operations can be executed in the same clock cycle as an arithmetic or logic operation. The arithmetic or logic operation is executed first; the result is shifted and then stored in the register file. The shift can be either left or right.

The CPU can perform the following shift operations:

- Single-precision, left or right, within a general-purpose register (R0...R31, or Q).
- Double-precision, left or right, between an R0...R31 register and the Q register.

The LSB and MSB of the general-purpose registers are each fed by an eight-to-one multiplexer.

The sources and destinations for shift operation are given below:

Shift Right

Zero Flag (Z)

- Carry Flag (CY)
- Sign Flag (S)
- Binary 0 (0)

Binary 1 (1)

Least-significant bit of this register (RLSB) Least-significant bit of the Q register (QLSB) Serial I/O port (SDATM)

Shift Left

- Zero Flag (Z)
- Carry Flag (CY)
- Sign Flag (S)
- Binary 0 (0)
- Binary 1 (1)

Most-significant bit of this register (RMSB) Most-significant bit of the Q register (QMSB) Serial I/O port (SDATL)



| Central<br>Processing Unit<br>(Con't) | <b>Rotate Operations</b><br>The CPU can perform the following rotate op-<br>erations, as shown in Figure 16: | <b>Multiple Precision Operations</b><br>The carry-out in each instruction can be used<br>in the next instruction for multiple precision<br>operations (e.g., ADDC). This feature en-<br>ables the user to implement complex arith-<br>metic operations such as division or multipli- |  |  |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| (                                     | <ul> <li>Single-precision, left or right, within a general-purpose register (R0R31, or Q).</li> </ul>        |                                                                                                                                                                                                                                                                                      |  |  |
|                                       | <ul> <li>Double-precision, left or right, between<br/>an R0R31 register and the Q register.</li> </ul>       | cation in several clock cycles.                                                                                                                                                                                                                                                      |  |  |
| Figure 16.<br>Pototo Operatione       |                                                                                                              |                                                                                                                                                                                                                                                                                      |  |  |
| nulais uperaliuns                     | Bn 4                                                                                                         |                                                                                                                                                                                                                                                                                      |  |  |
| Rotate Operations                     |                                                                                                              |                                                                                                                                                                                                                                                                                      |  |  |

#### *I/O and Special Functions*

The I/O bus, shown in Figure 17, consists of eight lines which can be individually programmed as inputs or outputs. These lines can also be programmed to perform Special Functions. The functions of these pins are defined by the Mode Register and I/O Configuration Register (see Configuration Register Section). The I/O and Special Functions map according to the table. The I/O lines must first be configured as inputs or outputs via the I/O Configuration Register; the Special Function option can then be enabled via the Mode Register. Individual special

function control is shown in the accompanying table.

Once a Special Function has been enabled, the corresponding internal control function is automatically disabled. Conversely, when a Special Function is disabled, control of the corresponding internal control function is returned to the Control Register (see Configuration Register). Because the Inputs in the I/O Register are clocked on each cycle, the status of the special function can also be read to the CPU. *Figure 17. I/O and Special Function Bus* 



2

| Configuration<br>Registers                    | The Configuration Registers all<br>control and configure different of<br>modes of the PAC1000. The th<br>Configuration Registers are the<br>Register, I/O Configuration Reg<br>Mode Register. Each register h<br>ated instruction which allows in<br>register bits to be modified. |                                                            | operating The Coree 10-bit provide<br>Control within<br>jister, and function<br>as an associ- externatividual Specia |                                                                        | vides for intention the PAC ctions can a constant constant of the part of the | I <b>Register</b><br>ontrol Register, shown in Figure 18,<br>es for internal control of key functions<br>the PAC1000 . Several of these<br>ons can alternatively be controlled<br>ially through the I/O bus (see I/O and<br>al Functions). The Control Register is<br>ed on the falling edge of the clock. |                                                                                                       |  |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|
| Table 7.<br>I/O Pins and<br>Special Functions | <i>Pin</i><br>I/O7<br>I/O6<br>I/O5<br>I/O4<br>I/O3                                                                                                                                                                                                                                 | <i>Special Fu</i><br>FIIR<br>ADOE<br>HADOE<br>HDOE<br>QMSB | nction                                                                                                               | <i>Direction</i><br>output<br>input<br>input<br>input<br>bidirectional |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Address Ou<br>Host Addre                                                                                                                                                                                                                                                                                   | Ready. FIFO not full.<br>htput Enable<br>ss Output Enable<br>Dutput Enable<br>MSB                     |  |
|                                               | I/O2<br>I/O1<br>I/O0                                                                                                                                                                                                                                                               | QLSB<br>ACEN<br>BCEN                                       |                                                                                                                      | bidirectional<br>input<br>input                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Q Register<br>Address Co<br>Block Coun                                                                                                                                                                                                                                                                     | ounter Enable                                                                                         |  |
| Table 8.<br>Special-Function<br>Control       | Special Fu<br>FIIR<br>ADOE<br>HADOE<br>HDOE<br>QMSB<br>QLSB<br>ACEN<br>BCEN                                                                                                                                                                                                        |                                                            | <i>in Name</i><br>D7<br>D6<br>D5<br>D4<br>D3<br>D2<br>D2<br>D2<br>D1<br>D0                                           | 0001<br>0001<br>0001<br>0001<br>0001<br>0001<br>0001<br>000            | onfigurat<br>37=1 (ou<br>36=0 (in<br>35=0 (in<br>33=1 (ou<br>33=1 (ou<br>33=0 (in<br>32=1 (ou<br>32=0 (in<br>31=0 (in<br>30=0 (in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | itput)<br>put)<br>put)<br>put)<br>put)<br>put)<br>put)<br>put)                                                                                                                                                                                                                                             | <i>Mode</i><br>MODE8=1<br>MODE7=1<br>MODE6=1<br>MODE5=1<br>MODE4=1<br>MODE4=1<br>MODE3 =1<br>MODE2 =1 |  |

Configuration ASEL (CTRL9)-Address Select. Selects the ADOE (CTRL4)-Address Output Enable. Registers source that will write to the Address bus: Selects direction of Address bus (ADD) for next clock cycle: 1= Address Counter. 1= Output (see ASEL). 0= Address Output Register (AOR). 0= Input (see AIREN). AIREN (CTRL8)-Address Input Register Enable. Enables and disables writing to HADOE (CTRL3)—Host Address Output the Address Input Register from the ADD Enable. Selects direction of Host Address Port: (HAD) bus for next clock cycle: 1= Enable writing to Address Input 1= Output (driven from ACL Register). Register (AIR). 0= Input (into the FIFO). 0= Disable writing to Address Input HDOE (CTRL2)-Host Data Output Enable. Register (AIR). Selects Direction of Host Data (HD) bus DIREN (CTRL7)-Data Input Register for next clock cycle: Enable. Enables and disables writing to 1= Output (See HDSEL0 and HDSEL1). the Data Input Register (DIR) from the 0= Input (See DIREN). HD Port: BCEN (CTRL1)-Block Counter Enable. 1= Enable writing to Data Input Register Enables and disables Block Counter: (DIR). 1= Enable Counting on next rising clock 0= Disable writing to Data Input Register edae. (DIR). 0= Disable Counting on next rising edge. HDSEL1 (CTRL6) and HDSEL0 (CTRL5)-Host Data Select. Select the source to be ACEN (CTRL0)-Address Counter Enable. Enables and disables Address Counter: connected to Host Data (HD) bus: HDSEL1 HDSEL0 Selection 1= Enable Counting on next rising clock (CTRL6) (CTRL5) edge. 0 0 FIFO---0= Disable Counting on next rising clock Peripheral edae. Mode 0 Data Output 1 Register

0 1 Status Register 1 1 Program Counter

(Con't)

Figure 18. **Control Register** MSB LSB CTRL9 (ASEL) CTRL0 (ACEN) CTRL8 (AIREN) CTRL1 (BCEN) CTRL7 (DIREN) CTRL2 (HDOE) CTRL6 (HDSEL1) CTRL3 (HADOE) CTRL5 (HDSEL0) CTRL4 (ADOE) Note: After Reset, All Bits Are Cleared to Zero. 1738 18

| Configuration   | I/O Configuration Register                                                                    | <ul> <li>I/O5 (IOCG5)—Selects direction of I/O5 pin:</li> <li>1= Output.</li> <li>0= Input.</li> <li>I/O4 (IOCG4)—Selects direction of I/O4 pin:</li> <li>1= Output.</li> <li>0= Input.</li> <li>I/O3 (IOCG3)—Selects direction of I/O3 pin:</li> </ul> |  |  |
|-----------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Registers       | The I/O Configuration Register, shown in                                                      |                                                                                                                                                                                                                                                         |  |  |
| 'Con't)         | Figure 19, controls the direction of the individual lines of the I/O bus as well as con-      |                                                                                                                                                                                                                                                         |  |  |
|                 | figuring the Address Counter. Each I/O pin                                                    |                                                                                                                                                                                                                                                         |  |  |
|                 | can be configured independently to be a                                                       |                                                                                                                                                                                                                                                         |  |  |
|                 | general purpose input or output, or each can<br>serve a special function (see I/O and Special |                                                                                                                                                                                                                                                         |  |  |
|                 | Function). The I/O Configuration Register is                                                  |                                                                                                                                                                                                                                                         |  |  |
|                 | also used to configure the Address Counter                                                    | 1= Output.                                                                                                                                                                                                                                              |  |  |
|                 | as a 16-bit counter with a maximum count of                                                   | 0= Input.                                                                                                                                                                                                                                               |  |  |
|                 | FFFFH or as a 22-bit counter with a maxi-<br>mum count of 3FFFFFH. The I/O Configura-         | I/O2 (IOCG2)—Selects direction of I/O2 pin                                                                                                                                                                                                              |  |  |
|                 | tion Register is modified on the falling edge                                                 | 1= Output.                                                                                                                                                                                                                                              |  |  |
|                 | of the clock.                                                                                 | 0= Input.                                                                                                                                                                                                                                               |  |  |
|                 | ACS22 (IOCG9)—Configures Address                                                              | I/O1 (IOCG1)—Selects direction of I/O1 pin                                                                                                                                                                                                              |  |  |
|                 | Counter as a 22- or 16-bit counter:                                                           | 1= Output.                                                                                                                                                                                                                                              |  |  |
|                 | 1= 22-bit counter.                                                                            | 0= Input.<br>I/O0 (IOCG0)—Selects direction of I/O0 pin:<br>1= Output.                                                                                                                                                                                  |  |  |
|                 | 0= 16-bit counter.                                                                            |                                                                                                                                                                                                                                                         |  |  |
|                 | I/O7 (IOCG7)—Selects direction of I/O7 pin:                                                   |                                                                                                                                                                                                                                                         |  |  |
|                 | 1= Output.                                                                                    | •                                                                                                                                                                                                                                                       |  |  |
|                 | 0= Input.                                                                                     | 0= Input.                                                                                                                                                                                                                                               |  |  |
|                 | I/O6 (IOCG6)—Selects direction of I/O6 pin:                                                   |                                                                                                                                                                                                                                                         |  |  |
|                 | 1= Output.                                                                                    |                                                                                                                                                                                                                                                         |  |  |
|                 | 0= Input.                                                                                     |                                                                                                                                                                                                                                                         |  |  |
| igure 19.       |                                                                                               |                                                                                                                                                                                                                                                         |  |  |
| O Configuration | MSB                                                                                           | LSB                                                                                                                                                                                                                                                     |  |  |
| Register        |                                                                                               |                                                                                                                                                                                                                                                         |  |  |
|                 |                                                                                               |                                                                                                                                                                                                                                                         |  |  |
|                 | IOCG8 (Reserved)                                                                              |                                                                                                                                                                                                                                                         |  |  |
|                 | IOCG7 (I/O7)                                                                                  | IOCG2 (I/O2)                                                                                                                                                                                                                                            |  |  |
|                 | IOCG6 (1/O6)                                                                                  | IOCG3 (I/O3)                                                                                                                                                                                                                                            |  |  |
|                 | IOCG5 (I/O5)                                                                                  | IOCG4 (I/O4)                                                                                                                                                                                                                                            |  |  |
|                 | Note: After Reset,                                                                            | All Bits Are Cleared to Zero.                                                                                                                                                                                                                           |  |  |
|                 |                                                                                               |                                                                                                                                                                                                                                                         |  |  |

1738 19

## Configuration Registers (Con't)

#### Mode Register

The Mode Register, shown in Figure 20, allows the user to externally control and monitor key elements within the PAC1000 which would (alternatively) be controlled internally through the Control Register. Enabling a Special Function in the Mode Register disables the corresponding function in the Control Register. The Special Function input pins are shared with the general purpose I/O pins. The direction of the appropriate pin must be set in the I/O Configuration Register prior to programming the Mode Register.

The Mode Register can also be used to reset the FIFO as well as program the interrupt controller to generate either interrupts or Priority Test Conditions. See the discussion on "Priority Case" in the *Condition Code* section, above.

After Reset, all Mode Register bits equal zero. The Mode Register is modified on the falling edge of the clock.

The use of the Mode Register and I/O Configuration register for Special Functions is shown in the Special Function Settings table.

FIRST (MODE9)—*FIFO Reset.* (If held high, FIFO cannot receive information):

- 1= Initiate FIFO Reset (FIRST).
- 0= Complete FIFO Reset (FINRST).

FIIR (MODE8)-FIFO Input Ready:

- 1= I/O7 becomes output for the FIFO Input Ready (FIIR) flag.
- 0= I/O7 becomes general purpose I/O (IO7).

ADOE (MODE7)—Address Output Enable:

- 1= I/O6 becomes input for the Address Output Enable (AOE).
- 0= I/O6 becomes general purpose I/O (IO6).
- HADOE (MODE6)—Host Address Output Enable:
  - 1= I/O5 becomes input for Host Address Output Enable (HADOE).
  - 0= I/O5 becomes general purpose I/O (IO6).

#### HDOE (MODE5)—Host Data Output Enable:

- 1= I/O4 becomes input for Host Data bus Output Enable HDOE).
- 0= I/O4 becomes general purpose I/O (IO4).

SIOEN (MODE4)-Serial I/O Enable:

- 1= I/O3 and I/O2 become MSB and LSB (respectively) of the CPU's Q register (SIO).
- 0= I/O3 and I/O2 become general purpose I/O ACEN(MODE3).

ACEN (MODE3)—Address Counter Enable:

- 1= I/O1 becomes input for Address Counter Enable (ACEN).
- 0= I/O1 becomes general purpose I/O.

#### BCEN (MODE2)—Block Counter Enable:

- 1= I/O0 becomes input for Block Counter Enable (BCEN).
- 0= I/O0 becomes general purpose I/O.

#### Reserved (MODE1)

INTR (MODE0)—Interrupt/Priority-Case Mode:

- 1= Select Interrupt mode (INTR).
- 0= Selects Priority Case mode (PCC).



| PAC1000         |                             |
|-----------------|-----------------------------|
| State Following | Whenever the PAC1000        |
| Reset           | driven low for at least two |

Whenever the PAC1000 RESET input is driven low for at least two processor clocks, the chip goes through reset. The next two

tables describe the PAC1000 signal and internal register states following reset.

| Table 9.<br>Special Function | Mode Bit | I/O Configuration Bit | Function                                                              |
|------------------------------|----------|-----------------------|-----------------------------------------------------------------------|
| Settings                     | MODE8=1  | IOCG7=1               | FIIR flag output on I/O7                                              |
|                              | MODE7=1  | IOCG6=0               | ADOE provided by I/O6                                                 |
|                              | MODE6=1  | IOCG5=0               | HADOE provided by I/O5                                                |
|                              | MODE5=1  | IOCG4=0               | HDOE provided by I/O4                                                 |
|                              | MODE4=1  | IOCG3=1               | MSB of Q register output on I/O3                                      |
|                              | MODE4=1  | IOCG3=0               | I/O3 can be shifted into MSB of Q register<br>or destination register |
|                              | MODE4=1  | IOCG2=1               | LSB of Q register output on I/O2                                      |
|                              | MODE4=1  | IOCG2=0               | I/O2 can be shifted into LSB of Q register<br>or destination register |
|                              | MODE3=1  | IOCG1=0               | ACEN provided by I/O1                                                 |
|                              | MODE2=1  | IOCG0=0               | BCEN provided by I/O0                                                 |

| Signal States<br>Following Reset | <i>Signal</i><br>HAD[5:0]<br>HD[15:0]<br>IO[7:0] | <i>Condition</i><br>Input<br>Input<br>Input |  |
|----------------------------------|--------------------------------------------------|---------------------------------------------|--|
|                                  | ADD[15:0]<br>OC[15:0]                            | Input<br>0000H                              |  |

*Table 11. Internal States Following Reset* 

| Component                     | Contents  |
|-------------------------------|-----------|
| ACH Register                  | 0         |
| ACL Register                  | 0         |
| AOR Register                  | 0         |
| AIR Register                  | 0         |
| DOR Register                  | 0         |
| DIR Register                  | 0         |
| IOR Register                  | 0         |
| IIR Register                  | 0         |
| STATUS Register               | 0         |
| I/O Configuration Register    | 0         |
| CONTROL Register              | 0         |
| Breakpoint Register           | 0         |
| Mode Register                 | 0         |
| PC Register (Program Counter) | 0         |
| MASK Register                 | 01111111B |
| BC Register                   | FFFFH     |
| R31-R0 Registers              | Unknown   |
| Q Register                    | Unknown   |
| LC Register                   | Unknown   |
| FIFO Locations                | Unknown   |
| FIFO Flags                    | Empty     |
|                               |           |

# Electrical and Timing Specifications

| Table 12.<br>Absolute<br>Maximum Ratings | Storage Temperatu<br>Voltage to any pin<br>$V_{PP}$ with respect to<br>ESD Protection<br>Stresses above those<br>permanent damage to<br>stress rating only and<br>the device at these or | with resp<br>GND<br>listed h<br>the dev<br>functior<br>any oth | ere may cause<br>rice. This is a<br>nal operation of<br>er conditions | -65°C to +150°C<br>-0.6V to +7V<br>-0.6 V to +14.0V<br>>2000V<br>sections of this specification is not implie<br>Exposure to absolute maximum rating<br>conditions for extended periods of time r<br>affect device reliability. |                      |                 |          |  |  |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------|----------|--|--|
| Table 13.                                | above those indicated                                                                                                                                                                    | i in the c                                                     | operational                                                           |                                                                                                                                                                                                                                 |                      |                 |          |  |  |
| Operating Range                          | Range                                                                                                                                                                                    | •                                                              | erature                                                               | V <sub>cc</sub>                                                                                                                                                                                                                 |                      |                 |          |  |  |
|                                          | Commercial                                                                                                                                                                               | 0°C t                                                          | o +70°C                                                               | +5V ± 5%                                                                                                                                                                                                                        | •                    |                 |          |  |  |
|                                          | Industrial                                                                                                                                                                               | -40°0                                                          | C to +85°C                                                            | +5V ± 109                                                                                                                                                                                                                       | %                    |                 |          |  |  |
|                                          | Military                                                                                                                                                                                 | –55°(                                                          | C to +125°C                                                           | +5V ± 109                                                                                                                                                                                                                       | %                    |                 |          |  |  |
| Table 14.                                |                                                                                                                                                                                          | •••••••••••••••••••••••••••••••••••••••                        |                                                                       |                                                                                                                                                                                                                                 |                      |                 |          |  |  |
| DC                                       | Parameter                                                                                                                                                                                |                                                                | Symbol                                                                | Test Conditions                                                                                                                                                                                                                 | Min                  | Max             | Units    |  |  |
| Characteristics<br>Over operating range  | Output Low Voltage                                                                                                                                                                       | e                                                              | V <sub>OL</sub>                                                       | I <sub>oL</sub> =8 mA                                                                                                                                                                                                           |                      | 0.4             | v        |  |  |
| with V <sub>pp</sub> =V <sub>cc</sub>    | Output High Voltag                                                                                                                                                                       | e                                                              | V <sub>OH</sub>                                                       | I <sub>он</sub> =–4 mA                                                                                                                                                                                                          | 2.4                  |                 | V        |  |  |
| FF 66                                    | V <sub>cc</sub> Standby<br>Current CMOS                                                                                                                                                  |                                                                | I <sub>SB1</sub>                                                      | note 1                                                                                                                                                                                                                          |                      | 65              | mA       |  |  |
|                                          | V <sub>cc</sub> Standby<br>Current TTL                                                                                                                                                   |                                                                | I <sub>SB2</sub>                                                      | note 2                                                                                                                                                                                                                          |                      | 65              | mA       |  |  |
|                                          | Active Current (CM<br>—Commercial<br>—Military                                                                                                                                           | IOS)                                                           | I <sub>CC1</sub>                                                      | notes 1, 3                                                                                                                                                                                                                      |                      | 130<br>150      | mA<br>mA |  |  |
|                                          | Active Current (TT<br>—Commercial<br>—Military                                                                                                                                           | L)                                                             | I <sub>CC2</sub>                                                      | notes 2, 3                                                                                                                                                                                                                      |                      | 160<br>180      | mA<br>mA |  |  |
|                                          | V <sub>PP</sub> Supply Current                                                                                                                                                           | t                                                              | I <sub>PP</sub>                                                       | V <sub>PP</sub> =V <sub>CC</sub>                                                                                                                                                                                                |                      | 100             | μA       |  |  |
|                                          | V <sub>PP</sub> Read Voltage                                                                                                                                                             |                                                                | V <sub>PP</sub>                                                       | notes 1, 2                                                                                                                                                                                                                      | V <sub>cc</sub> –0.4 | V <sub>cc</sub> | V        |  |  |
|                                          | Input Load Current                                                                                                                                                                       |                                                                | ILI                                                                   | V <sub>IN</sub> =5.5V<br>or GND                                                                                                                                                                                                 | -10                  | 10              | μA       |  |  |
|                                          | Output Leakage C                                                                                                                                                                         | urrent                                                         | ILO                                                                   | V <sub>out</sub> =5.5V<br>or GND                                                                                                                                                                                                | -10                  | 10              | μA       |  |  |

Notes:

1. CMOS inputs: GND  $\pm$  0.3V or V<sub>cc</sub>  $\pm$  0.3V. 2. TTL inputs: V<sub>IL</sub>  $\leq$  0.8V, V<sub>IH</sub> $\geq$  2.0V. 3. Active current is an AC test and uses AC timing levels.

#### *Table 15. AC Timing Levels*

Inputs: Outputs: 0 to 3V Reference 1.5V 0.4 to 2.4V

JIS: 0.4

*Table 16. AC Characteristics* 

| Parameter                                              | Symbol             | 12N<br>Min | 1Hz 1<br>Max | 16N<br>Min | IHz <sup>1</sup><br>Max | 20M<br>Min | /Hz²<br>Max |
|--------------------------------------------------------|--------------------|------------|--------------|------------|-------------------------|------------|-------------|
| CLOCK CYCLE                                            |                    |            |              |            |                         |            |             |
| Cycle Time                                             | t <sub>ск</sub>    | 84         |              | 62.5       |                         | 50         |             |
| Clock Pulse Width High                                 | t <sub>скн</sub>   | 26         |              | 24         |                         | 21         |             |
| Clock Pulse Width Low                                  | t <sub>ckl</sub>   | 26         |              | 24         |                         | 21         |             |
| HOST READ CYCLE                                        |                    |            |              |            |                         |            |             |
| Read Cycle Time                                        | t <sub>RC</sub>    | 50         |              | 40         |                         | 30         |             |
| Address to Data Valid                                  | t <sub>ACC</sub>   |            | 45           |            | 35                      |            | 30          |
| CS to Data Valid                                       | t <sub>cs</sub>    |            | 45           |            | 35                      |            | 30          |
| CS to tristate                                         | t <sub>csz</sub>   | 0          | 45           | 0          | 35                      | 0          | 30          |
| HOST WRITE CYCLE                                       |                    |            |              |            |                         |            |             |
| Pulse width of $\overline{CS}$ and $\overline{WR}$ LOW | t <sub>PWL</sub>   | 20         |              | 15         |                         | 15         |             |
| Pulse width of CS and<br>WR High                       | t <sub>PWH</sub>   | 15         |              | 10         |                         | 10         |             |
| Data setup to WR                                       | t <sub>sD</sub>    | 10         |              | 10         |                         | 5          |             |
| Data hold to WR                                        | t <sub>HD</sub>    | 10         |              | 10         |                         | 5          |             |
| RESET CYCLE                                            |                    |            |              |            |                         |            |             |
| RESET setup                                            | t <sub>sr</sub>    | 10         |              | 10         |                         | 5          |             |
| RESET to tristate of ADD, HAD, HD, I/O                 | t <sub>ez</sub>    | 25         |              | 25         |                         | 20         |             |
| RESET clocked to<br>OUTCNTL low                        | t <sub>ROL</sub>   | 30         |              | 30         |                         | 25         |             |
| ADDRESS TIMING                                         |                    |            |              |            |                         |            |             |
| Address/Data setup                                     | t <sub>sadd</sub>  | 10         |              | 10         |                         | 10         |             |
| Address/Data hold                                      | t <sub>hadd</sub>  | 8          |              | 8          |                         | 5          |             |
| Clocked Counter to<br>Address output                   | t <sub>cadd</sub>  |            | 43           |            | 35                      |            | 30          |
| Clocked Address Register to Address                    | t <sub>RADD</sub>  |            | 43           |            | 35                      |            | 30          |
| ADOE enable to data valid                              | t <sub>ADOE</sub>  |            | 50           |            | 40                      |            | 30          |
| HADOE enable to                                        |                    |            |              |            |                         |            |             |
| data valid                                             | t <sub>hadoe</sub> |            | 50           |            | 40                      |            | 30          |
| Address output disable                                 | t <sub>скz</sub>   | 0          | 25           | 20         |                         | 0          | 16          |

2

Table 16. AC **Characteristics** (Con't)

| Parameter                                   | Symbol                   |     | 1Hz 1 |     | 1Hz 1 |     | 1Hz² |
|---------------------------------------------|--------------------------|-----|-------|-----|-------|-----|------|
| DATA AND I/O TIMING                         |                          | Min | Max   | Min | Max   | Min | Max  |
| Clock to I/O Output Valid                   | t <sub>скіо</sub>        |     | 35    |     | 30    |     | 30   |
| Clock to HD Output                          | скю<br>t <sub>скно</sub> |     | 35    |     | 30    |     | 30   |
| IO data setup                               | t <sub>sio</sub>         | 10  |       | 10  |       | 10  |      |
| IO data hold                                | t <sub>HIO</sub>         | 8   |       | 8   |       | 5   |      |
| HD data setup                               | t <sub>shD</sub>         | 10  |       | 10  |       | 10  |      |
| HD data hold                                | t <sub>HHD</sub>         | 8   |       | 8   |       | 5   |      |
| HDOE enable to data valid                   | t <sub>HDOE</sub>        |     | 50    |     | 40    |     | 30   |
| Bus Output Disable                          | t <sub>ckz</sub>         | 0   | 25    | 0   | 20    | 0   | 16   |
| TEST AND INTERRUPT TIMING                   |                          |     |       |     |       |     |      |
| Condition Code setup                        | t <sub>scc</sub>         | 60  |       | 50  |       | 40  |      |
| Condition Code hold                         | t <sub>HCC</sub>         | 0   |       | 0   |       | 0   |      |
| Clock to OUTCNTL Valid                      | t <sub>cov</sub>         | -   | 33    | -   | 33    | -   | 25   |
| Minimum interrupt pulse                     | -000                     |     |       |     |       |     |      |
| for acceptance                              | t <sub>IPWA</sub>        | 15  |       | 10  |       | 10  |      |
| SPECIAL FUNCTION TIMING (1/                 | O Bus)                   |     |       |     |       |     |      |
| SQ15 setup                                  | t <sub>SSQ15</sub>       | 15  |       | 10  |       | 10  |      |
| SQ15 hold                                   | t <sub>HSQ15</sub>       | 0   |       | 0   |       | 0   |      |
| SQ0 setup                                   | t <sub>ssq0</sub>        | 15  |       | 10  |       | 10  |      |
| SQ0 hold                                    | t <sub>HSQ0</sub>        | 0   |       | 0   |       | 0   |      |
| Clock to Q0 output                          | t <sub>ckQ0</sub>        |     | 35    |     | 30    |     | 30   |
| Clock to Q15 output                         | t <sub>CKQ15</sub>       |     | 35    |     | 30    |     | 30   |
| Address Counter<br>enable setup             | t <sub>sacen</sub>       | 20  |       | 15  |       | 10  |      |
| Address Counter                             | SACEN                    |     |       |     |       |     |      |
| enable hold                                 | t <sub>hacen</sub>       | 10  |       | 5   |       | 5   |      |
| Block Counter enable setup                  | t <sub>sbcen</sub>       | 20  |       | 15  |       | 10  |      |
| Block Counter enable hold                   | t <sub>HBCEN</sub>       | 10  |       | 5   |       | 5   |      |
| External output enable to<br>data valid     | t <sub>sfv</sub>         |     | 30    |     | 25    |     | 20   |
| External output enable to<br>high impedance | t <sub>sFZ</sub>         |     | 30    |     | 25    |     | 20   |

Notes:

Operating temperature range: Commercial, Industrial, Military
 Operating temperature range: Commercial









| <b>Ceramic</b> /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                         |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            |                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------|------------------------|------------------------|-----------------------------------------|-------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| in 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2                                                                                                                                       | 3                                                                                       | 4                    | 5                      | 6                      | 7                                       | 8                       | 9                                                                                           | 10                                                                                          | 11                   | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 13                                                                                                                                                         |                                           |
| iments A O NOS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | О<br>0С8                                                                                                                                | O<br>GND                                                                                | 0<br>0C5             | 0<br>0C3               | 0<br>0C2               | 0<br>0C1                                | O<br>INT3               | O<br>INT1                                                                                   | 0<br>607                                                                                    | O<br>Vcc             | O<br>CC4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | О<br>ссз                                                                                                                                                   | A                                         |
| B O VOT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | O<br>CC2                                                                                                                                | 0<br>007                                                                                | 0<br>0C6             | 0<br>0C4               | O<br>/RESET            | 000                                     | O<br>INT2               | O<br>INTO                                                                                   | O<br>CC6                                                                                    | O<br>CC5             | 0<br>601                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                          | в                                         |
| C O HD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                       |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      | O<br>ADD15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | O<br>5 ADD14                                                                                                                                               | ₄c                                        |
| D O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0<br>1/04                                                                                                                               |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      | O<br>ADD13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | O<br>ADD12                                                                                                                                                 | 2 D                                       |
| E O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                       |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            |                                           |
| F NO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | O<br>/cs                                                                                                                                |                                                                                         |                      |                        | /                      | $\frown$                                |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O<br>ADD9                                                                                                                                                  |                                           |
| G O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                         |                                                                                         |                      |                        | (                      |                                         |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O<br>ADD8                                                                                                                                                  |                                           |
| H ORD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                         | ,                                                                                       |                      |                        | $\langle$              |                                         |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O<br>ADD6                                                                                                                                                  |                                           |
| J DO L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                         |                                                                                         |                      |                        | Р                      | AC100                                   | 0                       |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O<br>ADD4                                                                                                                                                  |                                           |
| K OCT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                         |                                                                                         | L                    |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O<br>ADD2                                                                                                                                                  |                                           |
| L GU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                         |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             |                                                                                             |                      | O<br>HAD5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                            | L                                         |
| M <sub>O</sub> G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                         | 0<br>1 HD2                                                                              | O<br>HD4             | O<br>HD6               | O<br>HD8               | O<br>HD10                               | O<br>v∝                 | O<br>HD14                                                                                   | O<br>HAD0                                                                                   | O<br>HAD1            | O<br>HAD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                            | м                                         |
| N O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                         |                                                                                         |                      | O<br>HD7               | O<br>HD9               |                                         | O<br>HD12               |                                                                                             |                                                                                             |                      | O<br>HAD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                            |                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2                                                                                                                                       | 3                                                                                       | 4                    | 5                      | 6                      | 7                                       | 8                       | 9                                                                                           | 10                                                                                          | 11                   | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 13                                                                                                                                                         |                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 12                                                                                                                                      | 11                                                                                      | 10                   | 9                      | 8                      | 7                                       | 6                       | 5                                                                                           |                                                                                             |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            | < l>                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                         |                                                                                         |                      |                        |                        |                                         |                         |                                                                                             | 4<br>0                                                                                      | 3<br>0               | 2<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1<br>0                                                                                                                                                     | A                                         |
| A O CC3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | O<br>CC4                                                                                                                                | O<br>Vcc                                                                                | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | 0<br>0C8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1/05                                                                                                                                                  | A                                         |
| A O CC3<br>B O CC0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0<br>CC4<br>O<br>CC1                                                                                                                    | O<br>Vcc<br>O<br>CC5                                                                    |                      | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | O<br>0C8<br>O<br>CC2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0<br>1/05<br>0<br>1/07                                                                                                                                     | A<br>B<br>C                               |
| A CC3<br>B CC0<br>C ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | O<br>CC4<br>O<br>CC1<br>O<br>14 ADD                                                                                                     | O<br>Vcc<br>O<br>CC5                                                                    | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | 0<br>0C8<br>0<br>CC2<br>0<br>1/06                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0<br>1/05<br>1/07<br>HD3                                                                                                                                   | с                                         |
| A CC3<br>B CC0<br>C ADD<br>D ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | O<br>CC4<br>O<br>CC1<br>14 ADD<br>12 ADD                                                                                                | O<br>Vcc<br>CC5<br>15                                                                   | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | O<br>OC8<br>O<br>CC2<br>I/O6<br>I/O4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | O<br>1/05<br>1/07<br>HD3<br>J/03                                                                                                                           |                                           |
| A CC3<br>B OC0<br>C ADD<br>D ADD<br>E ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | O<br>CC4<br>O<br>CC1<br>14 ADD<br>12 ADD<br>10 ADD                                                                                      | O<br>Vcc<br>CC5<br>15<br>13                                                             | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | O C C C C C C C C C C C C C C C C C C C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0105<br>0107<br>HD 013<br>010<br>101                                                                                                                       | C<br>D                                    |
| A C3<br>B CCC<br>C ADD<br>D ADD<br>E ADD<br>F ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | O<br>CC4<br>O<br>CC1<br>14 ADD<br>12 ADD<br>12 ADD<br>10 ADD<br>9 GND                                                                   | O<br>Vcc<br>CC5<br>15<br>13                                                             | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | O C8<br>O C2<br>O C2<br>O C2<br>O C2<br>O C2<br>O C2<br>O C2<br>O C2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | O 105<br>O 107<br>O HD 3<br>O 100<br>I 0 01<br>O 100                                                                                                       | C<br>D<br>E                               |
| A C3<br>B C00<br>C ADD<br>D ADD<br>F ADD<br>G ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0<br>CC4<br>0<br>CC1<br>14 ADD<br>12 ADD<br>10 ADD<br>9 GND<br>8 ADD                                                                    | O<br>Vcc<br>0<br>CC5<br>11<br>11<br>11                                                  | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            | C<br>D<br>E<br>F<br>G                     |
| A C3<br>B CCC<br>C ADD<br>D ADD<br>E ADD<br>F ADD<br>G ADD<br>H ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | O<br>CC4<br>O<br>CC1<br>14 ADD<br>12 ADD<br>10 ADD<br>9 GND<br>9 GND<br>8 ADD<br>8 ADD<br>6 ADD                                         | O<br>Vcc<br>CC5<br>115<br>113<br>111<br>7<br>5                                          | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            | C<br>D<br>F<br>G<br>H                     |
| A CC3<br>B CC4<br>C ADD<br>D ADD<br>E ADD<br>F ADD<br>F ADD<br>G ADD<br>H ADD<br>J ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | O<br>CC4<br>O<br>CC1<br>14 ADD<br>12 ADD<br>10 ADD<br>9 GND<br>8 ADD<br>8 ADD<br>6 ADD<br>6 ADD<br>4 ADD                                | O<br>Vcc<br>0<br>CC5<br>115<br>113<br>11<br>7<br>5<br>3                                 | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                            | C<br>D<br>F<br>G<br>H<br>J                |
| A C3<br>B CC0<br>C ADD<br>D ADD<br>E ADD<br>F ADD<br>G ADD<br>J ADD<br>J ADD<br>K ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CC4<br>CC4<br>CC1<br>14 ADD<br>12 ADD<br>10 ADD<br>10 ADD<br>9 GND<br>8 ADD<br>6 ADD<br>4 ADD<br>2 ADD                                  | O<br>Vcc<br>CC5<br>15<br>13<br>11<br>7<br>5<br>3<br>0                                   | O<br>CC7             | O<br>INT1              | O<br>INT3              | 0<br>001                                | O<br>OC2                | 0<br>0C3                                                                                    | 0<br>0C5                                                                                    | O<br>GND             | O C8<br>O C2<br>D O C2 | O<br>1/05<br>07<br>07<br>07<br>07<br>07<br>00<br>07<br>00<br>00<br>07<br>00<br>00<br>00                                                                    | C<br>D<br>F<br>G<br>H<br>J                |
| A C3<br>B C00<br>C ADD<br>D ADD<br>E ADD<br>F ADD<br>G ADD<br>H ADD<br>J ADD<br>K ADD<br>C Vec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | O CC4<br>O CC1<br>14 ADD<br>12 ADD<br>12 ADD<br>10 ADD<br>9 GND<br>8 ADD<br>6 ADD<br>4 ADD<br>2 ADD<br>2 ADD<br>2 ADD<br>4 ADD<br>2 ADD | O<br>Vcc<br>CC5<br>115<br>113<br>111<br>7<br>5<br>3<br>3<br>0<br>5                      | O<br>CC7<br>O<br>CC6 | O<br>INT1<br>O<br>INT0 |                        | 80 <u>8</u> 0                           | O<br>OC2<br>Ø<br>Ø      | O<br>0C3<br>O<br>0C4                                                                        | O<br>0C5<br>O<br>0C6                                                                        | O<br>GND<br>O<br>OC7 | O<br>O<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 01/05<br>01/07<br>01/07<br>01/0<br>01/0<br>01/0<br>01/0<br>0/12<br>00<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | C<br>D<br>F<br>G<br>H<br>J<br>K           |
| A CC3<br>B CC4<br>C ADD<br>D ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>C ADD<br>F ADD<br>C ADD | CC4<br>CC4<br>CC1<br>CC1<br>CC1<br>CC1<br>CC1<br>CC1<br>CC1<br>CC1                                                                      | O<br>CC5<br>115<br>11<br>7<br>5<br>5<br>3<br>8<br>0<br>5<br>5<br>3<br>4<br>AD1          | O<br>CC7<br>O<br>CC6 | O<br>INTO<br>INTO      | O<br>INT3<br>O<br>INT2 | 0 10 0 00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O<br>OC2<br>O<br>/RESET | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | O G ND<br>O 0007     | $\begin{array}{c} O\\ O\\ O\\ C\\ C\\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 010 010 010 010 010 010 010 010 010 010                                                                                                                    | C<br>D<br>F<br>G<br>H<br>J<br>K<br>L      |
| A CC3<br>B CC4<br>C ADD<br>D ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>F ADD<br>C ADD<br>F ADD<br>C ADD | CC4<br>CC4<br>CC4<br>CC4<br>CC4<br>CC4<br>CC4<br>CC4<br>CC4<br>CC4                                                                      | O<br>Vcc<br>O<br>CC5<br>115<br>113<br>11<br>7<br>7<br>5<br>3<br>3<br>HAD1<br>2<br>2 GND | O<br>CC7<br>O<br>CC6 | O<br>INTO<br>INTO      | O<br>INT3<br>O<br>INT2 | 0 10 0 00 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | O<br>OC2<br>O<br>/RESET | O<br>0C3<br>O<br>0C4                                                                        | O<br>0C5<br>O<br>0C6                                                                        | O<br>GND<br>O<br>OC7 | O<br>O<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C<br>C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 01/05<br>01/07<br>01/07<br>01/0<br>01/0<br>01/0<br>01/0<br>0/12<br>00<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | C<br>D<br>F<br>G<br>H<br>J<br>K<br>L<br>M |

Pin Assignments

Table 17. PGA Pin Assignments

| Name    | Pin | Name | Pin | Name | Pin        |
|---------|-----|------|-----|------|------------|
| CS      | F2  | GND  | H2  | I/O0 | F1         |
| RD I    | H1  | GND  | L1  | I/O1 | E1         |
| RESET I | B6  | GND  | A3  | I/O2 | E2         |
| WR      | G1  | GND  | F12 | I/O3 | D1         |
| ADD0 I  | K12 | GND  | N3  | I/O4 | D2         |
| ADD1 I  | N13 | GND  | N11 | I/O5 | A1         |
| ADD10 I | E13 | HAD0 | M10 | I/O6 | C2         |
| ADD11   | E12 | HAD1 | M11 | I/O7 | B1         |
| ADD12   | D13 | HAD2 | N12 | INT0 | B9         |
| ADD13 I | D12 | HAD3 | M12 | INT1 | A9         |
| ADD14   | C13 | HAD4 | M13 | INT2 | B8         |
| ADD15   | C12 | HAD5 | L12 | INT3 | A8         |
| ADD2 I  | K13 | HD0  | N1  | OC0  | B7         |
| ADD3 .  | J12 | HD1  | N2  | OC1  | <b>A</b> 7 |
| ADD4    | J13 | HD10 | M7  | OC10 | L2         |
| ADD5 I  | H12 | HD11 | N7  | OC11 | M2         |
| ADD6 I  | H13 | HD12 | N8  | OC12 | K1         |
| ADD7    | G12 | HD13 | N9  | OC13 | K2         |
| ADD8    | G13 | HD14 | M9  | OC14 | J2         |
| ADD9 I  | F13 | HD15 | N10 | OC15 | J1         |
|         | B13 | HD2  | M3  | OC2  | A6         |
| CC1 I   | B12 | HD3  | C1  | OC3  | A5         |
| CC2 I   | B2  | HD4  | M4  | OC4  | B5         |
| CC3     | A13 | HD5  | N4  | OC5  | A4         |
| CC4     | A12 | HD6  | M5  | OC6  | B4         |
| CC5 I   | B11 | HD7  | N5  | OC7  | B3         |
| CC6 I   | B10 | HD8  | M6  | OC8  | A2         |
| CC7 /   | A10 | HD9  | N6  | OC9  | M1         |
| СК      | G2  |      |     | VCC  | A11        |
|         |     |      |     | VCC  | L13        |
|         |     |      |     | VCC  | M8         |









Table 18. Plastic or Ceramic Quad Flatpack (Gullwing) Pin Assignments

| Pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Name | Pin | Name | Pin | Name  | Pin | Name  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|------|-----|-------|-----|-------|
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RD   | 26  | HD11 | 51  | ADD7  | 76  | OC1   |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GND  | 27  | HD12 | 52  | ADD8  | 77  | OC2   |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GND  | 28  | VCC  | 53  | ADD9  | 78  | RESET |
| 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | OC15 | 29  | VCC  | 54  | GND   | 79  | N/C   |
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | OC14 | 30  | HD13 | 55  | GND   | 80  | OC3   |
| 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | OC12 | 31  | HD14 | 56  | ADD10 | 81  | OC4   |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | OC13 | 32  | HD15 | 57  | ADD11 | 82  | OC5   |
| 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GND  | 33  | HAD0 | 58  | ADD12 | 83  | OC6   |
| 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GND  | 34  | GND  | 59  | ADD13 | 84  | GND   |
| 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | OC10 | 35  | GND  | 60  | ADD14 | 85  | GND   |
| 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | OC9  | 36  | HAD1 | 61  | ADD15 | 86  | OC7   |
| 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | OC11 | 37  | HAD2 | 62  | CC0   | 87  | OC8   |
| 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | N/C  | 38  | N/C  | 63  | CC1   | 88  | CC2   |
| 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD0  | 39  | HAD3 | 64  | CC3   | 89  | 105   |
| 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD1  | 40  | ADD1 | 65  | CC4   | 90  | 107   |
| 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD2  | 41  | HAD4 | 66  | CC5   | 91  | IO6   |
| 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | GND  | 42  | HAD5 | 67  | VCC   | 92  | HD3   |
| 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | GND  | 43  | VCC  | 68  | VCC   | 93  | IO4   |
| 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD4  | 44  | VCC  | 69  | CC6   | 94  | IO3   |
| 20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD5  | 45  | ADD0 | 70  | CC7   | 95  | 102   |
| 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD6  | 46  | ADD2 | 71  | INT0  | 96  | IO1   |
| 22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD7  | 47  | ADD3 | 72  | INT1  | 97  | CS    |
| 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD8  | 48  | ADD4 | 73  | INT2  | 98  | 100   |
| 24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD9  | 49  | ADD5 | 74  | INT3  | 99  | СК    |
| 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | HD10 | 50  | ADD6 | 75  | 0C0   | 100 | WR    |
| Longer and the second s |      |     |      |     |       |     |       |

2

#### Instruction Set Overview

The PAC1000 architecture can perform three operations simultaneously in each instruction cycle. The operations are specified in the System Entry Language (PACSEL) using a single statement. PACSEL instructions can perform three operations:

- Program Control (PROGCNTL)
- 🗆 CPU
- Output Control (OUTCNTL)

Each *instruction* is executed in a single cycle; the three *operations* are executed in parallel.

The syntax of a PACSEL statement has a label and three components:

[label:] PROGCNTL, CPU, OUTCNTL;

The PROGCNTL component determines program flow and determines the next statement to be executed; the CPU component determines which operation is to be performed by the CPU; the OUTCNTL component determines the state of the control outputs.

A comma (, ) is used to separate the instructions and a semi-colon marks the end of a statement. In general, each statement is executed in a single cycle.

In PACSEL statements, the PROGCNTL, CPU, OUTCNTL components can come in any order or any combination of Macro or Assembler operators. That is, you may mix Assembler operators among Macro operators. Tables at the end of this section summarize the Macro and Assembler operators. In some cases, the same mnemonic is used to specify identical operations in both Macro and Assembler level.

You may:

Specify all the components in the same statement in order to perform the operations in parallel:

PROGCNTL, CPU, OUTCNTL;

 Specify components one at a time: CPU;

PROGCNTL;

OUTCNTL;

Use components in any combination:

PROGCNTL, CPU;

PROGCNTL, OUTCNTL;

CPU, OUTCNTL;

WSI recommends that, in general, you maintain a consistent ordering of these components and consistent groupings of Assembler-level and Macro operators, e.g. in separate files. This manual uses the PROGCNTL, CPU, OUTCNTL ordering.

When PROGCNTL is omitted, the implied instruction is CONTinue, that is, proceed to the next control instruction. When CPU is omitted, the implied instruction is NOP. When OUTCNTL is omitted, the implied instruction is MAINTain, that is, maintain the most recent OUTCTL, in Assembler order.

A summary of PACSEL Assembler and Macro statements follows.

Table 19. PACSEL Assembler Language Summary

| Mnemonic<br>The PROGCNTL Ope | Arguments<br>rators                        | Meaning                  |
|------------------------------|--------------------------------------------|--------------------------|
| ACSIZE                       | <16/22>                                    | SET A COUNTER SIZE       |
| CALL                         | <label fifo="" lcptr=""  =""></label>      | UNCOND BRANCH SUBRTN     |
| CALLC                        | <cond> <label fifo=""  =""></label></cond> | COND BRANCH SUBRTN       |
| CALLNC                       | <cond> <label fifo=""  =""></label></cond> | INV COND BRANCH SUBRTN   |
| CCASE                        | <cg> <value></value></cg>                  | BRANCH SUBRTN CASEBLK    |
| CLI                          | <mask></mask>                              | CLEAR INTERRUPT          |
| CONT(D)                      |                                            | CONTINUE                 |
| CPI                          | <value></value>                            | PRIORITIZED SUB RTN      |
| DI                           | <mask></mask>                              | DISABLE INTERRUPT        |
| DSS                          |                                            | DISABLE SINGLE STEP MODE |
| El                           | <mask></mask>                              | ENABLE INTERRUPT         |
| ESS                          |                                            | ENABLE SINGLE STEP MODE  |
| JCase                        | <cg> <value></value></cg>                  | UNCOND BRANCH CaseBLK    |
| JMP                          | <label fifo="" lcptr=""  =""></label>      | UNCONDITIONAL BRANCH     |
| JMPC                         | <cond> <label fifo=""  =""></label></cond> | CONDITIONAL BRANCH       |
| JMPNC                        | <cond> <label fifo=""  =""></label></cond> | INVERT COND BRANCH       |
| JPI                          | <value></value>                            | PRIORITIZED BRANCH       |
| LDBP                         | <value></value>                            | LOAD BP REG              |
| LDBPD                        |                                            | LOAD BP COMP VALUE       |
| LDLC                         | <value></value>                            | LOAD COUNTER             |
| LDLCD                        |                                            | LOAD CTR COMPUTED VAL    |
| LOOPNZ                       | <label></label>                            | REPEAT BRANCH, CNTRNZ    |
| PLDLC                        | <value></value>                            | PUSH VALUE & LDCTR       |
| PLDLCD                       |                                            | PUSH VAL&LDCTR CM VL     |
| POP                          |                                            | POP STACK                |
| POPLC                        |                                            | POP STACK TO CNTR        |
| PUSHLC                       |                                            | PUSH CNTR                |
| RESTART                      |                                            | BRANCH TO 0              |
| RET                          |                                            | RETURN                   |
| RC                           | <cond></cond>                              | CONDITIONAL RETURN       |
| RNC                          | <cond></cond>                              | INV COND RETURN          |
| RSTCON                       | <mask></mask>                              | RESET CONTROL REG        |
| RSTIO                        | <mask></mask>                              | RESET I/O CONFIG REG     |
| RSTMODE                      | <mask></mask>                              | RESET MODE REG           |
| SETCON                       | <mask></mask>                              | SET CONTROL REG          |
| SETIO                        | <mask></mask>                              | SET I/O CONFIG REG       |
| SETMODE                      | <mask></mask>                              | SET MODE REG             |

# 2

Table 19. PACSEL Assembler Language Summary (Con't)

| Mnemonic<br>The CPU Operators | Arguments                                   | Meaning               |
|-------------------------------|---------------------------------------------|-----------------------|
| ADC                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | ADD WITH CARRY        |
| ADD                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | ADD                   |
| AND                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | BITWISE AND           |
| СМР                           | <arg1> <arg2></arg2></arg1>                 | COMPARE               |
| DEC                           | <arg1> [<arg2>]</arg2></arg1>               | DECREMENT             |
| INC                           | <arg1> [<arg2>]</arg2></arg1>               | INCREMENT             |
| INV                           | <arg1> [<arg2>]</arg2></arg1>               | INVERT                |
| MOV                           | <dest> <src></src></dest>                   | MOVE SRC TODEST       |
| NOP(D)                        |                                             | NO OPERATION          |
| OR                            | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | BITWISE OR            |
| RDFIFO                        |                                             | READ FIFO DATA TO REG |
| SBC                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | SUB WITH CARRY        |
| SHLRQ                         | <reg> <rarg> <qarg></qarg></rarg></reg>     | SHIFT LEFT REG & Q    |
| SHLR                          | <reg> <rarg></rarg></reg>                   | SHIFT LEFT REG        |
| SHRRQ                         | <reg> <rarg> <qarg></qarg></rarg></reg>     | SHIFT RIGHT REG & Q   |
| SHRR                          | <reg> <rarg></rarg></reg>                   | SHIFT RIGHT REG       |
| SUB                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | SUBTRACT              |
| XOR                           | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | EXCLUSIVE OR          |
| XNOR                          | <arg1> <arg2> [<arg3>]</arg3></arg2></arg1> | EXCLUSIVE NOR         |
| The MACRO Operato             | ors                                         |                       |
| DIV                           | <arg1> <arg2> <arg3></arg3></arg2></arg1>   | DIVISION              |
| MUL                           | <arg1> <arg2> <arg3></arg3></arg2></arg1>   | 2'S COMP MULTIPLY     |
| The OUTCNTL Opera             | tors                                        |                       |
| MAINT(D)                      |                                             | MAINTAIN PREV VALUE   |
| OUT                           | <value></value>                             | OUTPUT                |

*Table 20. PACSEL Macro Language Summary* 

#### The PROGCNTL Operators

ACSIZE <16/22> CALL <label | LCPTR | FIFO> [ON] [NOT] [<cond>] CASE n, PROGCNTL, CPU, OUTCNTL; CLEAR <int level> [...<int level>] CONFIGURE <pm1> [<pm2>...<pm10>] CONT DISABLE <int level> [<int level>...<int level>] ELSE ENABLE <int level> [<int level>...<int level>] ENDFOR ENDIF ENDPSWITCH ENDSWITCH ENDWHILE FOR <value> GOTO <label | LCPTR | FIFO> [ON] [NOT] [<cond>] IF [NOT] <cond> INPUT <i/o pin> [<i/o pin>...<i/o pin>] LOADBP <value> OUTPUT <i/o pin> [<i/o pin>...<i/o pin>] PRIORITY m, PROGCNTL, CPU, OUTCNTL; PSWITCH RESET <p1> [<p2>...<p10>] RETURN [ON] [NOT] [<cond>] SET <p1> [<p2>...<p10>] SWITCH <case group> WHILE [NOT] <cond>

2

| ble 20.<br>CSEL Macro | The CPU-Operator Assignment                                                                            |
|-----------------------|--------------------------------------------------------------------------------------------------------|
| nguage                | move                                                                                                   |
| mmary (Con't)         | <dest> := <src></src></dest>                                                                           |
|                       | arithmetic expression                                                                                  |
|                       | <dest> := <arg1> &lt;+/-&gt; <arg2> &lt;+/-&gt; <arg3></arg3></arg2></arg1></dest>                     |
|                       | logical expression                                                                                     |
|                       | <dest> := <arg1> <logical operator=""> <arg3></arg3></logical></arg1></dest>                           |
|                       | increment, decrement, invert, unary minus                                                              |
|                       | <dest> := <opr> <src></src></opr></dest>                                                               |
|                       | macro expression                                                                                       |
|                       | <dest> := <arg1> [*   /] <arg2></arg2></arg1></dest>                                                   |
|                       | shift RAM                                                                                              |
|                       | <rx> = Rx <shft opr=""> <shft arg=""></shft></shft></rx>                                               |
|                       | shift RAM and q                                                                                        |
|                       | <qrx> = Q <shft opr=""> <shft arg=""> Rx <shft opr=""> <shft arg=""></shft></shft></shft></shft></qrx> |
|                       |                                                                                                        |
|                       | The OUTCNTL Operator                                                                                   |
|                       | OUT <arg1> [<arg2><arg16>]</arg16></arg2></arg1>                                                       |

#### System Development Tools

PAC1000 System Development Tools are a complete set of PC-based development tools. They provide an integrated easy-to-use software and hardware environment to support PAC1000 development and programming.

The tools run on an IBM-XT, AT, PS2 or compatible computer running MS-DOS version 3.1 or later. The system must be equipped with 640 Kbytes of RAM and a hard disk.

#### Hardware

The PAC1000 System Programming Hardware consists of:

- WS6000 MagicPro Memory and PSD Programmer (XT, AT only)
- Package Adaptors (88-Pin Ceramic Pin-Grid Array and 100-Pin Ceramic Quad Flatpack—Gullwing) for the MagicPro Remote Socket Adaptor Unit

The MagicPro Programmer is the common hardware platform for programming all WSI programmable products. It consists of the IBM-PC plug-in Programmer Board and the Remote Socket Adaptor Unit.

#### Software

The PAC1000 System Development Software consists of the following:

- WISPER Software—PSD Software Interface
- IMPACT Software—Interface Manager for PAC1000
- PACSEL Software—System Entry Language
- PACSIM Software—Functional Simulator
- PACPRO Software—Device Programming Software

WISPER and IMPACT software provide a menu-driven user interface enabling other

tools to be easily invoked by the user.

The system design is entered into PACSEL source program files using an editor chosen by the user. PACSEL supports assemblylevel and high-level Macro programming.

The PACSEL Assembler produces object code format in single or multiple modules, which are then linked by the PACSEL Linker into a single load file with a format suitable for PACSIM and PACPRO.

The PACSIM functional simulator enables the user to test and debug programs by examining the state of PAC1000 internal registers before and during a complete functional simulation of the device.

PACPRO software programs PAC1000 devices by using the MagicPro hardware and the socket adapter.

The programmed PAC1000 is then ready to be used.

#### Support

WSI provides a complete set of quality support services to registered owners. These support services include the following:

- 12-month Software Updates.
- Hotline to WSI Application Experts—For direct design assistance.
- 24-Hour Electronic Bulletin Board—For design assistance via dial-up modem.

#### Training

WSI provides in-depth, hands-on workshops for the PAC1000 and the System Development Tools. Workshop participants will learn how to develop and program their own highperformance microcontrollers. Workshops are held at the WSI facility in Fremont, California.

# Ordering Information— PAC1000

| Part Number    | Speed<br>(MHz) | Package<br>Type                               | Package<br>Drawing | Operating<br>Temperature | Manufacturing<br>Procedure |
|----------------|----------------|-----------------------------------------------|--------------------|--------------------------|----------------------------|
| PAC1000-12F*   | 12             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Commercial               | Standard                   |
| PAC1000-12FI*  | 12             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Industrial               | Standard                   |
| PAC1000-12FM*  | 12             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Military                 | Standard                   |
| PAC1000-12FMB* | 12             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Military                 | MIL-STD-883C               |
| PAC1000-12Q*   | 12             | 100-Pin Plastic<br>Quad Flatpack,<br>Gullwing | Q1                 | Commercial               | Standard                   |
| PAC1000-12X    | 12             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Commercial               | Standard                   |
| PAC1000-12XI   | 12             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Industrial               | Standard                   |
| PAC1000-12XM   | 12             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Military                 | Standard                   |
| PAC1000-12XMB  | 12             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Military                 | MIL-STD-883C               |
| PAC1000-16F*   | 16             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Commercial               | Standard                   |
| PAC1000-16FI*  | 16             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Industrial               | Standard                   |
| PAC1000-16FM*  | 16             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Military                 | Standard                   |
| PAC1000-16FMB* | 16             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Military                 | MIL-STD-883C               |
| PAC1000-16Q*   | 16             | 100-Pin Plastic<br>Quad Flatpack,<br>Gullwing | Q1                 | Commercial               | Standard                   |
| PAC1000-16X    | 16             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Commercial               | Standard                   |
| PAC1000-16XI*  | 16             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Industrial               | Standard                   |
| PAC1000-16XM*  | 16             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Military                 | Standard                   |
| PAC1000-16XMB* | 16             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Military                 | MIL-STD-883C               |
| PAC1000-20F*   | 20             | 100-Pin Ceramic<br>Quad Flatpack,<br>Gullwing | F3                 | Commercial               | Standard                   |
| PAC1000-20X*   | 20             | 88-Pin Ceramic<br>Pin-Grid Array              | X1                 | Commercial               | Standard                   |
| PAC1000-20Q*   | 20             | 100-Pin Plastic<br>Quad Flatpack,<br>Gullwing | Q1                 | Commercial               | Standard                   |

\*: These products are advanced information.

| Part Number    | Contents                                         |
|----------------|--------------------------------------------------|
| PAC1000-GOLD   | WISPER Software                                  |
|                | IMPACT Software                                  |
|                | PACSEL Software                                  |
|                | PACSIM Software                                  |
|                | PACPRO Software                                  |
|                | User's Manual                                    |
|                | WSI-Support                                      |
|                | WS6000 MagicPro Programmer                       |
| PAC1000-SILVER | WISPER Software                                  |
|                | IMPACT Software                                  |
|                | PACSEL Software                                  |
|                | PACSIM Software                                  |
|                | PACPRO Software                                  |
|                | User's Manual                                    |
|                | WSI-Support                                      |
| WS6000         | MagicPro Programmer                              |
|                | IBM PC plug-in Adaptor Card                      |
|                | Remote Socket Adaptor                            |
| WS6010         | 88-Pin CPGA Adaptor                              |
|                | Used with the WS6000 MagicPro Programmer         |
| WS6012         | 100-Pin Ceramic Quad Flatpack (Gullwing) Adaptor |
|                | Used with the WS6000 MagicPro Programmer         |
| WSI-Support    | Support Services, including:                     |
|                | 12-month Software Update Service                 |
|                | Hotline to WSI Application Experts               |
|                | 24-hour access to WSI Electronic Bulletin Board  |
| WSI-Training   | Workshops at WSI, Fremont, CA                    |
|                |                                                  |

Ordering Information— System Development Tools

2

For details and scheduling, call PSD Marketing, (415) 656-5400



Programmable System<sup>™</sup> Device

SAM448 Introduction

#### **User-Configurable Microsequencer**

#### **Overview**

In 1988 WSI introduced a new concept in programmable VLSI: the Programmable System<sup>™</sup> Device (PSD). The PSD is defined as a family of *User-configurable system level building blocks on-a-chip enabling quick implementation of application specific controllers and peripherals*. The first generation PSD series includes the MAP168, a User-Configurable Peripheral with Memory; the SAM448, a User-Configurable Microsequencer; and the PAC1000, a User-Configurable Microsentone M

The SAM448 is a microsequencer intended for use in digital systems that require events to be controlled at high speed. A microsequencer is basically an instruction oriented device executing one internal instruction on each system cycle. This can be done in a linear flow or the sequencer can test the state of logic inputs or internal events and respond to program branching on a result. In addition, it has the capability of driving output signals on a cycle by cycle basis.

The SAM448 can operate at a high clock speed (30 MHz) so sequential operations can be performed much faster than with lower end microcontrollers. A classic application of the SAM448 would be in the generation of pulse waveforms for video line and frame synchronization with blanking output controls for both line and frame flyback. The device could also control the load and shift activity in the video output registers and supervise the video memory address counters. All these activities are sequential in nature so microcode could be developed for the SAM device and programmed into the device's on-chip EPROM.

Prior to the development of the SAM448 Microsequencer, a designer would most likely develop a system from discrete EPROM or ROM plus 74LS TTL logic with dedicated LIFO and registers. The actual development of such a design would escalate in chip count to eventually cover an entire printed circuit card. With the advent of Programmable Logic Devices (PLDs), the development of a microsequencing circuit became simpler. However, a typical system still required five to six PLDs. In addition, and EPROM was needed to hold the microcode. Because microcode is usually rather wide, a number of EPROMs were needed.

The SAM448 provides the optimum solution when implementing a microsequencer of medium complexity. It has been designed to be cascadable in width and depth so more complex microsequencer designs may be achieved.

#### *Microcode EPROM Architecture*

The core of the SAM448 is a microcode EPROM organized as a 448 locations deep and 36 bits wide. On each clock cycle, the current 32 bit wide instruction is clocked into the pipeline register. The 32 bit word is split into a number of fields. The F field consists of 16 bits and drives the output lines as user defined output pins. The remaining 20 bits are subdivided into one 8-bit Q field which generally directs processing to the next address of the EPROM. The 8-bit D field can be used to hold a constant or direct value but it can also be used for next address generation. The OP field is three bits in width and contains the current instruction to be executed. The remaining field is the

#### SAM448 Introduction

| Microcode<br>EPROM<br>Architecture<br>(Cont.) | E field and performs a 3-State control<br>function on the pipeline register. When<br>HIGH, the output pins are enabled and<br>when LOW the outputs are in a high<br>impedance state. This feature enables one<br>SAM448 device to share the same outputs<br>with a second for vertical cascading.<br>The EPROM locations are connected such<br>that the first 192 locations (0 to 191) are in | a linear sequence. The remaining locations<br>are organized in four rows of 192 to 255.<br>This permits a one of four branch control.<br>The internal branch control logic will make<br>the decision as to which branch to take<br>depending on the state of the user defined<br>inputs and the value of the next state<br>address. |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Branch<br>Control Logic                       | The branch control logic determines the location from where the next instruction will be fetched. The next address can come from the Q or D field of the instruction currently in the pipeline register, the top of                                                                                                                                                                           | the stack or LIFO or the Branch Select<br>EPLD. The Branch Select EPLD can be<br>programmed to view inputs or the logical<br>combination of inputs to invoke a branch<br>when a logic state becomes true.                                                                                                                           |
| Stack                                         | The stack or Last In First Out (LIFO)<br>memory is 15 locations deep and 8 bits<br>wide and can be used to hold the value of<br>a return address so successful CALL to<br>and RETURN from subroutines may be<br>invoked. A loop counter is included in the                                                                                                                                    | SAM448 architecture and the stack can be<br>used to hold the contents of this loop<br>counter when nested loops are invoked.<br>The eight input lines may also be pushed<br>onto the stack to externally load the counter.                                                                                                          |
| Loop Counter                                  | To make provision for a number of<br>operations to be repeated a defined<br>number of times, a loop counter called<br>CREG has been included in the design.<br>This eight bit counter is loaded from the D                                                                                                                                                                                    | field by a dedicated instruction LOADC or<br>from the stack in the case of nested loops.<br>The counter decrements to zero and then<br>holds at zero. So repetitive routines may<br>be achieved by a LOOPNZ instruction.                                                                                                            |
| Instruction Set                               | The instruction set for the SAM448 consists<br>of 12 instructions to handle multiway<br>branching, subroutines, nested for-next<br>loops and dispatch functions. With only 12<br>instructions a designer can become familiar                                                                                                                                                                  | with creating SAM448 designs very quickly.<br>The WSI State Machine Input Language<br>(ASMILE) support software enables designs<br>to be generated quickly and efficiently.                                                                                                                                                         |



WAFERSCALE INTEGRATION, INC.

### Programmable System<sup>™</sup> Device

SAM448

#### **User-Configurable Microsequencer**

| Features    | <ul> <li>First Generation Programmable System<br/>Device</li> <li>User-Programmable Microsequencer for<br/>Implementing High-Performance State<br/>Machines</li> <li>On-Chip Reprogrammable EPROM<br/>Microcode Memory Up to 448</li> </ul>                                                                                                                                                                                                                                           | <ul> <li>Cascadable to Expand Outputs or States</li> <li>Low-Power CMOS Technology</li> <li>Footprint Efficient 28 Pin 300 Mil Dip or<br/>28 Lead CLDCC/PLDCC Package</li> <li>30 MHz Minimum Clock Frequency</li> <li>High Level PC-XT/AT, PS2 or Compatible<br/>Design Support Software (SAM+PLUS):</li> </ul>                                                                                                                                                                         |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <ul> <li>Words Deep</li> <li>15 × 8 Stack</li> <li>Loop Counter</li> <li>Prioritized, Multi-Way Control Branching</li> <li>8 General-Purpose Branch Control Inputs</li> <li>16 General-Purpose Control Outputs</li> </ul>                                                                                                                                                                                                                                                             | <ul> <li>WSI PSD Integrated Software<br/>Environment</li> <li>State Machine Input Language</li> <li>Microcode Assembler</li> <li>Functional Simulator</li> </ul>                                                                                                                                                                                                                                                                                                                         |
| Description | In 1988 WSI introduced a new concept in programmable VLSI, Programmable System <sup>™</sup> Devices (PSD). The PSD is defined as a family of <i>User-configurable</i> system level building blocks on-a-chip enabling quick implementation of application specific controllers and peripherals. The first generation PSD series includes the MAP168, a User-Configurable Peripheral with Memory; the SAM448, a User-Configurable Microsequencer; and the PAC1000, a User-Configurable | words) is integrated with Branch Control<br>Logic, Pipeline Register, Stack, and Loop<br>Counter. This generic microcoded architecture<br>provides an efficient vehicle for implementing<br>a broad range of high performance controllers<br>spanning the spectrum from basic state<br>machines to traditional bit-slice controller<br>applications.<br>The SAM448 has eight general purpose<br>input pins, a clock pin and a reset pin.<br>It has 16 user-definable outputs packaged in |

Microcontroller.

The SAM448 is a first generation PSD and is WSI's first user programmable microsequencer. On-chip EPROM (up to 448 The SAM448 has eight general purpose input pins, a clock pin and a reset pin. It has 16 user-definable outputs packaged in a 28-pin 300 mil Dip or 28 Lead CLDCC/ PLDCC package. One-Time-Programmable plastic versions are available to minimize volume production costs.



#### Description (Cont.)

Functional

Description

Programming the SAM448 device is accomplished on a standard WSI PSD WISPER development system installed with the optional SAM+PLUS software package and device adapters. New users can purchase a separate WISPER-SAM development system with programming hardware included. SAM+PLUS allows designs to be entered in either state machine or microcoded formats. SAM+PLUS automatically performs logic minimization and design fitting for the device. The design may then be simulated or programmed directly to achieve customized working silicon within minutes.

Using WSI's proprietary high performance CMOS EPROM technology allows SAM448 to operate at a 25-MHz typical clock frequency while still enjoying the benefits of low CMOS power consumption. This technology also facilitates 100% generic testability which eliminates the need for post-programming testing.

Ideal application areas for SAM448 include programmable sequence generators (state machines), bus and memory control functions, graphics and DSP algorithm controllers, and other complex, high performance machines. The devices may be cascaded easily to obtain greater output requirements (horizontal cascade) or greater microcode memory depth (vertical cascade) or both.

#### SAM as a State Machine

The SAM448 architecture allows easy implementation of synchronous state

machines. SAM's internal EPROM memory together with its Pipeline Register allows storage of up to 448 unique states. SAM's Branch Control Logic allows single clock, multi-way branching in response to the eight inputs, current device state, and user-defined transition conditions. Design entry is simplified with WSI's State Machine Input Language (ASMILE) supported by the SAM+PLUS development system. This high level language uses IF-THEN-ELSE statements to define state transitions and a truth table to define or tri-state the outputs on a state-by-state basis.

#### SAM as a Microcoded Sequencer

SAM's architecture has several advanced features that enable it to be used as a sophisticated microcoded sequencer. SAM's on-chip EPROM (448 words) is integrated with a microcoded sequencer consisting of Branch Control Logic, Stack, and Loop Counter. The eight general-purpose inputs, the Counter, the Stack, and the Pipeline Register feed the Branch Control Logic. The Branch Control Logic gives flexible multi-way microcode branch capability in a single clock, enhancing throughput beyond that of conventional controllers or sequencers.

SAM+PLUS development software offers high level microcode entry featuring a compact assortment of powerful instructions (OP-codes) allowing easy implementation of conditional branches, subroutine calls, multiple level for-next loops, and dispatch functions (branching to an externally specified address).

The SAM architecture is shown in Figure 1. The primary elements are the Microcode EPROM, 36-bit Pipeline Register, Branch Control Logic,  $15 \times 8$ -bit Stack, and 8-bit Loop Counter.

> The Branch Control Logic generates the address of the next state and applies this address to the Microcode Memory. The outputs of the Microcode Memory represent the user-defined outputs and internal control values associated with the next state. On the leading edge of the clock these new values are clocked into the Pipeline Register and become the current state. The new values in the Pipeline Register—along with the Counter, Stack and Inputs—are used by the Branch

Control Logic to generate the new nextstate address.

#### Microcode EPROM and Pipeline Register

The Microcode EPROM is organized into 448, 36-bit words or locations, each of which can be viewed as a single state. 16 of these bits (the F-field) are available at device pins as user-defined outputs.

The other 20 bits are internal control signals that are divided into 4 fields: the 8-bit Q-field normally provides the nextstate address; the 8-bit D-field is a general purpose field used either as a constant or as an alternative next-state address; the OP-field contains the instruction; and, the Functional Description (Cont.)

E-field contains a single bit which enables or tri-states the device outputs.

As shown in Figure 2, the Microcode Memory is organized as 256 rows or addresses. Addresses 0 through 191 contain a single 36-bit word which is associated with the desired next-state. This state information will be clocked into the Pipeline Register on the next rising edge of the clock and the outputs will become valid one  $T_{CO}$  (clock to output delay) later.

Addresses 192–255, on the other hand, access four unique 36-bit words which correspond to four possible next states. (The extension .0, .1, .2, and .3 are used to distinguish those four states.) These 64 addresses are known as Multi-Way Branch locations and are used to perform single clock 4-way branches. Whenever the nextstate address falls within the Multi-Way Branch locations, the Branch Control Logic will make the necessary 1-of-4 selection based on the next-state address and userdefined input conditions.





2

#### Figure 3. SAM Branch Control Logic



#### Branch Control Logic Block

At the heart of the high-performance sequencing ability of the SAM family is the Branch Control Logic. This block determines the next-state to be clocked into the Pipeline Register based on the current status of the Pipeline Register, the Counter, the Stack, and the eight input pins.

The Branch Control Logic is divided into two segments: the Address Multiplexer and the Branch Select EPLD.

The Address Multiplexer provides the nextstate address to the Microcoded Memory. The next-state address can come from the Q-field, the D-field, or the Top-of-Stack. The selection between these three resources is based on the instruction in the Pipeline Register and the condition of the Zero Flag from the Counter.

The Branch Select EPLD is used to perform up to a 4-way branch based on user-defined input conditions. This block is a 768 product-term programmable logic device with 16 inputs and four outputs. When the next-state address falls within the multi-way branch block of memory (any address greater than 191) the Branch Select EPLD performs the necessary 1-of-4 selection. When the next-state address is less than 192, the Branch Select EPLD is turned off since no selection is required.

The conditions controlling the multi-way branch are defined by the user with a simple IF, THEN, ELSE format like the following:

> IF (cond3) THEN select 201.3 ELSEIF (cond2) THEN select 201.2 ELSEIF (cond1) THEN select 201.1 ELSE select 201.0

The conditions are prioritized so that if the first condition is not met (cond3), then microword 201.3 will be selected and clocked into the Pipeline Register regardless of the results of cond2 and cond1. If none of the three conditions are met, then the microword 201.0 will be clocked into the Pipeline Register.

The three conditional expressions are user defined and may contain any logical equation based on the inputs that can be reduced to four product-terms. For example, the expression

contains four product-terms and is a valid condition. There is a unique set of 12 product-terms for each of the 64 multi-way branch locations for a total of 768 productterms. (See Figure 4.)

The SAM448 has been designed so that the number of available product-terms should never be the limiting factor on a design. Prioritization provides an effective product-term count of more than 12 per location. A trade-off between number of product-terms and number of possible branches can be made by simply placing identical state information in two locations as shown in Figure 5.





WAFERSCALE INTEGRATION, INC. 2-119

| Functional                              | Stack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Loop Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description<br>(Cont.)                  | The Stack of the SAM448 is a Last In First<br>Out (LIFO) arrangement consisting of 15<br>8-bit words. The Top-of-Stack may be used<br>as the next-state address or popped into<br>the Counter. Values may be pushed onto<br>the stack either from the D-field in the<br>Pipeline Register or from the Counter<br>enabling efficient implementation of<br>subroutines, nested loops, and other<br>iterative structures. The eight input lines<br>may also be pushed onto the stack to<br>allow external address specification in a<br>dispatch function or to externally load the<br>counter. | The SAM448 contains an 8-bit Loop<br>Counter, referred to as the Count Register<br>(CREG), which is useful for controlling<br>timing loops and affecting a variety of<br>branch operations. The CREG is a down<br>counter and may be loaded directly from<br>the D-field of the Pipeline Register or from<br>the Top-of-Stack. The value of the CREG<br>may be saved and restored by pushing<br>and popping it to and from the Stack.<br>The CREG is loaded or decremented on<br>the leading edge of the clock. It is<br>designed so that it will not decrement<br>once it reaches zero to prevent roll-over. A |
|                                         | The PUSHing or POPing of the stack<br>occurs on the leading edge of the clock.<br>The stack is "zero filled" so that a POP<br>from an empty stack will return all eight<br>bits set to zero. On the other hand, a push<br>to an already full stack will write over the<br>Top-of-Stack leaving the other 14 values<br>unchanged.                                                                                                                                                                                                                                                             | Zero Flag indicates zero to prevent follower. A<br>zero Flag indicates when the counter has<br>reached zero and is used with the<br>LOOPNZ command to control program<br>flow (see Instruction Set Description).<br>Single instruction delay loops are easily<br>constructed and, in combination with the<br>Stack, nested loops or delays of arbitrary<br>length may be generated.                                                                                                                                                                                                                             |
| Instruction Set                         | The instruction set of the SAM448 consists<br>of a compact assortment of powerful<br>commands. Assembly language constructs<br>allow efficient implementation of multi-way<br>branching, subroutines, nested for-next<br>loops, and dispatch functions. The complete                                                                                                                                                                                                                                                                                                                         | instruction set is described at the end of<br>this data sheet. These instructions are<br>only used with assembly language design<br>entry and are automatically supplied when<br>using the WSI State Machine Input<br>Language (ASMILE).                                                                                                                                                                                                                                                                                                                                                                        |
| Output Enable<br>Control                | Each microcode word contains an OE bit<br>(the E-field) which enables the outputs<br>when $E = 1$ and causes a high-impedance<br>when $E = 0$ . These bits are accessible                                                                                                                                                                                                                                                                                                                                                                                                                    | through high-level constructs in the WSI<br>Development Software. This capability<br>allows the vertical cascading of SAM448<br>devices to increase the number of states.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| nRESET Pin                              | The nRESET pin acts as a master reset<br>for the SAM448 causing it to empty the<br>Stack, clear the Counter, and load the<br>microword found at address 0 into the<br>Pipeline Register. The nRESET signal is<br>useful for system reset or for synchronizing<br>several SAMs that are cascaded vertically<br>or horizontally.<br>The nRESET signal must be held low for<br>at least three clock rising edges to perform                                                                                                                                                                     | a valid clear. A nRESET of one clock<br>rising edge causes the SAM448 to enter<br>into a supervisor mode and a nRESET of<br>two clock edges results in an undefined<br>state.<br>The outputs of the boot address (00 Hex)<br>will appear at the pins from the fourth<br>clock edge after nRESET goes low, until<br>the third clock edge after nRESET returns<br>to high.                                                                                                                                                                                                                                        |
| Horizontal and<br>Vertical<br>Cascading | Just as with memory and bit slice devices,<br>the SAM devices can be cascaded to<br>provide greater functionality. If an application<br>requires more output lines, two or more<br>SAMs can be cascaded horizontally.<br>Likewise, if an application requires more                                                                                                                                                                                                                                                                                                                           | states, two or more SAMs can be cascaded<br>vertically. In either case, no speed penalty<br>is incurred. Designs utilizing horizontal<br>cascading are fully supported by the<br>SAM+PLUS development software. Vertical<br>cascading requires the designer to make<br>certain tradeoffs to split the design.                                                                                                                                                                                                                                                                                                   |



#### Functional Testing

The SAM448 is fully functionally tested and guaranteed through complete testing of each programmable EPROM bit and all internal logic elements thus ensuring 100% programming yield.

The erasable nature of the SAM448 allows test programs to be used and then erased during early stages of production flow. This

facility to use application-independent, general purpose tests is called generic testing and is unique among user-defined LSI logic devices. The devices also contain on board test circuitry to allow verification of function and AC specification once encapsulated in non-windowed packages.

| Recommended<br>Operating | Symbol          | Parameter                | Conditions | Min        | Max             | Unit |
|--------------------------|-----------------|--------------------------|------------|------------|-----------------|------|
| Conditions               | V <sub>cc</sub> | Supply Voltage           | Note 6     | 4.75 (4.5) | 5.25 (5.5)      | V    |
|                          | Vi              | Input Voltage            |            | 0          | V <sub>cc</sub> | V    |
|                          | Vo              | Output Voltage           |            | 0          | V <sub>cc</sub> | V    |
|                          | T <sub>R</sub>  | Input Rise Time (Note 6) |            |            | 500 (100)       | ns   |
|                          | Τ <sub>F</sub>  | Input Fall Time (Note 6) |            |            | 500 (100)       | ns   |

#### SAM448

#### DC Operating Characteristics

 $\begin{array}{l} V_{CC} = 5V \pm 5\%, \ 0^{\circ}C \ to \ +70^{\circ}C \ for \ Commercial \\ V_{CC} = 5V \pm 10\%, \ -40^{\circ}C \ to \ +85^{\circ}C \ for \ Industrial \\ V_{CC} = 5V \pm 10\%, \ -55^{\circ}C \ to \ +125^{\circ}C \ for \ Military \end{array}$ 

| Symbol           | Parameter                                           | Conditions                                                    | Min  | Тур | Max                  | Unit |
|------------------|-----------------------------------------------------|---------------------------------------------------------------|------|-----|----------------------|------|
| V <sub>IH</sub>  | High Level Input Voltage                            |                                                               | 2.0  |     | V <sub>CC</sub> +0.3 | ۷    |
| V <sub>IL</sub>  | Low Level Input Voltage                             |                                                               | -0.3 |     | 0.8                  | V    |
| V <sub>OH</sub>  | High Level TTL Output<br>Voltage                    | I <sub>OH</sub> = -8 mA DC                                    | 2.4  |     |                      | v    |
| V <sub>он</sub>  | High Level CMOS<br>Output Voltage                   | $I_{OH} = -4 \text{ mA DC}$                                   | 3.84 |     |                      | v    |
| V <sub>OL</sub>  | Low Level TTL Output<br>Voltage                     | $I_{OL} = 8 \text{ mA} (4 \text{ mA}) \text{ DC}$             |      |     | 0.45                 | v    |
| I <sub>I</sub>   | Input Leakage Current                               | $V_1 = V_{CC}$ or GND                                         |      |     | ±10                  | μA   |
| I <sub>oz</sub>  | 3-State Output Off-State<br>Current                 | $V_0 = V_{CC}$ or GND                                         |      |     | ±10                  | μA   |
| I <sub>CC1</sub> | V <sub>CC</sub> Supply Curent<br>(Standby) (Note 6) | $V_1 = V_{CC} \text{ or } GND$ $I_0 = 0 \text{ CLK} = V_{CC}$ |      | 30  | 65 (90)              | mA   |
| I <sub>CC2</sub> | V <sub>CC</sub> Supply Current<br>(Active) (Note 6) | No Load 50% CLK<br>f = 20 MHz                                 |      | 55  | 120 (170)            | mA   |

| Absolute<br>Maximum | Symbol                                                                                                   | Parameter                         | Conditions | Min  | Max  | Unit |
|---------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------|------------|------|------|------|
| Ratings             | V <sub>cc</sub>                                                                                          | Supply Voltage                    |            | -2.0 | 7.0  | V    |
| (See Design         | esign V <sub>PP</sub> Programming Supply Voltage (Note 2)<br>mendations) V <sub>1</sub> DC Input Voltage | -2.0                              | 14.0       | V    |      |      |
| Recommendations)    |                                                                                                          | -2.0                              | 7.0        | V    |      |      |
|                     | I <sub>CCMAX</sub>                                                                                       | DC V <sub>CC</sub> or GND Current |            | -250 | 250  | mA   |
|                     | Ι <sub>ουτ</sub>                                                                                         | DC Output Current, per Pin        |            | -25  | 25   | mA   |
|                     | PD                                                                                                       | Power Dissipation                 |            |      | 1200 | mW   |
|                     | T <sub>STG</sub>                                                                                         | Storage Temperature               | No Bias    | -65  | 150  | °C   |
|                     | T <sub>AMB</sub>                                                                                         | Ambient Temperature               | Under Bias | -10  | 85   | °C   |

# Capacitance (Note 3)

| Symbol           | Parameter              | Conditions                           | Тур | Unit |
|------------------|------------------------|--------------------------------------|-----|------|
| C <sub>IN</sub>  | Input Capacitance      | $V_{IN} = 0V$<br>f = 1.0 MHz         | 10  | pF   |
| С <sub>ОՍТ</sub> | Output Capacitance     | V <sub>OUT</sub> = 0V<br>f = 1.0 MHz | 15  | pF   |
| C <sub>CLK</sub> | Clock Pin Capacitance  | $V_{IN} = 0V$<br>f = 1.0 MHz         | 10  | pF   |
| C <sub>RST</sub> | nRESET Pin Capacitance |                                      | 75  | pF   |

Unit

MHz ns ns

ns

ns

ns

ns

ns

ns

ns

22

22

#### AC Characteristics

 $V_{CC} = 5V \pm 5\%$ , 0°C to +70°C for Commercial  $V_{CC} = 5V \pm 10\%$ , -40°C to +85°C for Industrial

| Cumhal           | Deremator           | Conditions            | SAM448-30 |      | SAM448-25 |     | SAM448-20 |     |
|------------------|---------------------|-----------------------|-----------|------|-----------|-----|-----------|-----|
| Symbol           | Parameter           | Conditions            | Min       | Max  | Min       | Max | Min       | Max |
| f <sub>CYC</sub> | Maximum Frequency   | C = 25 pE             | 30        |      | 25        |     | 20        |     |
| t <sub>CYC</sub> | Minimum Clock Cycle | $C_1 = 35 \text{ pF}$ |           | 33.3 |           | 40  |           | 50  |
| t <sub>SU</sub>  | Input Setup Time    |                       | 16.5      |      | 20        |     | 22        |     |
| t <sub>H</sub>   | Input Hold Time     |                       | 0         |      | 0         |     | 0         |     |

 $C_1 = 35 \, pF$ 

2

NOTES: 1. Typical values are for T<sub>A</sub> = 25°C, V<sub>CC</sub> = 5V.

nRESET Setup Time

nRESET Hold Time

Clock to Output Delay

Clock to Output

Low Time Minimum Clock

**High Time** 

Disable or Enable Minimum Clock

t<sub>co</sub>

t<sub>CZ</sub>

t<sub>CL</sub>

t<sub>CH</sub>

t<sub>SUR</sub>

t<sub>HR</sub>

2. Minimum DC input is -0.3V. During transitions, the inputs may undershoot to -2.0V for periods less than 20 ns.

16.5

16.5

11

11

16.5

5

20

20

15

15

18

5

12

12

18

5

3. Capacitance measured at 25°C. Sample tested only.

4. If the nRESET is held low for more than 3 clock edges, then the outputs associated with the boot address (00 Hex) will remain at the pins until the third clock edge after nRESET goes high.

5. For 1.0 < V  $_{1}$  < 3.8, the nRESET pin will source up to 200  $\mu A.$ 

6. Figures in ( ) pertain to military and industrial temperature versions.

7. The specifications noted above apply to military operating range devices. MIL-STD-883 compliant product specifications are provided in military product drawings available on request from WSI marketing at Tel. 415-656-5400. These military product drawings should be used for the preparation of source control drawings.







# **Design Security** The SAM448 contains a programmable design security feature that controls the access to the data programmed into the device. If this programmable feature is used, a proprietary design implemented in the device cannot be copied nor retrieved.

This enables a high level of design control to be obtained since programmed data within EPROM cells in invisible. The bit that controls this function, along with all other program data, may be reset simply by erasing the device.

#### Design Recommendations

Operation of the SAM448 with conditions above those listed under "Absolute Maximum Ratings" 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 above those indicated in the operational sections of this data sheet is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. These devices contain circuitry to protect the input against damage to high static voltages or electric fields: however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high-impedance circuit.

For proper operation, it is recommended that opaque labels be placed over the device window. Input and output pins must be constrained to the range GND  $\leq$  (V<sub>IN</sub> or V<sub>OUT</sub>)  $\leq$  V<sub>CC</sub>. Unused inputs must always be tied to an appropriate logic level (e.g., either V<sub>CC</sub> or GND). A power supply decoupling capacitor of at least 0.1  $\mu$ F must be connected directly between the V<sub>CC</sub> pin and GND.

When operating in noisy environments it is possible that a glitch on the nRESET pin one  $T_{SUR}$  before the clock edge could initiate a supervisor mode. To prevent this possibility, it is recommended to connect a capacitor of at least 0.1  $\mu$ F from the nRESET input to ground.

All general purpose inputs to the SAM448 should be synchronized to be guaranteed to meet the setup time. Input transitions which occur less than one  $T_{SU}$  before the leading clock edge can cause the SAM448 to enter an undefined state.

## *Figure 9. Output Drive Current*



#### Instruction Set Description

Following is a description of the instruction set available with the SAM448. These instructions can be used in conjunction with the Assembly Language entry to access the various features of the SAM448. They are automatically supplied when using the WSI State Machine Input Language (ASMILE).

In the following description label1 and label2 indicate arbitrary labels located in the assembly (.ASM) file. These labels will be converted by the software into the 8-bit address of that label. The parameter constant is any 8-bit number (0–255 Decimal, 0–FF Hex) representing an address, a mask, or a constant.

The instructions influence the control of the Stack, the Counter, and the Address

Multiplexer. These effects are summarized in the Instruction Table. Throughout the examples it is assumed for simplicity that the destination labels do not lie within the Multi-Way Branch Block of memory so that branching based on inputs is not performed. It is valid, however, for any of these labels to lie within the Multi-Way Branch Block so that 4-way branching based on the inputs can be performed. See the MULTI-WAY BRANCH section at the end of this data sheet for more details.

The SAM+PLUS development system allows the designer to use the high level Assembly Language without worrying about the actual values that are placed in the various fields.

CONTINUE simply causes execution to continue with the next sequential instruction found in the Assembly Language file (.ASM).





Instruction Set Description (Cont.) The JUMP instruction causes execution to branch to the indicated location. If address 44 contains the instruction 'JUMP label1,' then the next state will come from label1 which in this case is located at address 73.

JUMP label1



#### The CALL/RETURNTO instruction is typically used to call a subroutine. In general it will push the address of label2 onto the Stack and cause label1 to be the next-state address. Leaving the RETURNTO designation off will cause label2 to default to the next instruction in the .ASM file. In the example, address 44 contains the command 'CALL label1' where label1 is located at address 73. This causes the address of the following instruction, in this case 45, to be pushed onto the Stack, and the next state to come from address 75. The RETURN command at address 45.

#### CALL label1 RETURNTO label2



The RETURN command is used to return from a subroutine call or in general to cause the next-state address to come from the top of the Stack. In the example, the command at address 44 CALLed the subroutine at address 73 and PUSHed the value 45 onto the Stack. The RETURN command at address 75 will transfer execution to address 45 and POP that value off the Stack.

RETURN



Instruction Set Description (Cont.)

The LOAD Counter command loads the Counter with the value specified and transfers execution to label1. The LOADC command is typically used to initialize the Counter for a repetitive loop. In the example, address 44 has the command 'LOADC 73D GOTO label1' which causes the decimal value 73 to be loaded into the Counter and the next state to come from label1. In this case label1 is located at address 73. If the GOTO designation is left off label1 will default to the next instruction in the .ASM file.

LOADC constant GOTO label1



The LOOP on Non-Zero/ON ZERO goto command jumps to one of two addresses based on the value of the Zero Flag and decrements the Counter if not zero. This instruction is typically used to implement for-next loops. In the example, address 44 has the command 'LOOPNZ label1 ONZERO label2' where label1 is located at address 42 and label2 is located at address 73. If the Counter is not at zero then the next state will come from address 42 and the Counter will be decremented. If the Counter is already at zero then the instruction at address 73 will be executed and the Counter will stay at zero. If the ONZERO designation is left off, the default for label2 will be the next instruction in the .ASM file.

The DEcrement Counter on Non-Zero GOTO command will decrement the Counter if it is non-zero and jump to label1. In the example, address 44 has the command 'DECNZ GOTO label1' where label1 is located at address 73. The Counter is decremented and the next instruction comes from address 73. The default for label1 is the next instruction in the .ASM file.

#### LOOPNZ label1 ONZERO label2





## SAM448

Instruction Set Description (Cont.)

The PUSH Counter LOAD Counter command will push the current value of the Counter onto the Stack, load a constant into the Counter, and jump to label1. This instruction is useful for implementing nested for-next loops. In the example, the instruction at address 44 is 'PUSHLOADC 153D GOTO label1' where label1 is located at address 73. The value in the Counter will be pushed onto the Stack, the decimal value 153 will be loaded into the Counter, and the next instruction will come from address 73. The default for label1 is the next instruction in the .ASM file.

# PUSHLOADC constant GOTO label1



The POP Stack to Counter GOTO command will pop the top of Stack into the Counter and jump to label1. This command is typically used in conjunction with the PUSHLOADC to implement nested for-next loops. In the example, address 44 has the command 'POPC GOTO label1' where label1 is located at address 73. The default for label1 is the next instruction in the .ASM file.





The PUSH constant to Stack GOTO command will push the value constant onto the Stack and jump to label1. In the example, address 44 has the command 'PUSH 34D GOTO label1' where label1 is located at address 73. The decimal value 34 is pushed onto the Stack and the next state comes from address 73. The default for label1 is the next instruction in the .ASM file.

## PUSH constant GOTO label1



# Instruction Set Description (Cont.)

The PUSH Input GOTO command will push the eight inputs (I7-I0) onto the Stack. In the example address 44 has the instruction 'PUSHI GOTO label1' where label1 is located at address 73. At the leading edge of the clock the eight inputs are pushed onto the Stack. In a typical example, address 73 would have a RETURN instruction which would cause execution to jump to the address represented by the recently PUSHed input pins. This implements a dispatch function. The default for label1 will be the next instruction in the .ASM file. This instruction can also be used to load the Counter with an externally specified variable. In this case address 73 would have a POPC instruction.

# PUSHI GOTO label1



2

The AND PUSH Input GOTO command is identical to the PUSHI command except the inputs are first bit-wise ANDed with a constant. This allows the masking of irrelevant inputs before PUSHing an address for a dispatch routine.

# ANDPUSHI constant GOTO label1



The POP and XOR Stack to Counter GOTO command will pop the top of Stack, bitwise XOR it with a constant, load the result into the Counter, and jump to label1. In the example, address 44 has the command 'POPXORC 25D GOTO label1' where label1 is located at address 73. The top of Stack is POPed off the Stack. XORed with the decimal number 25, and loaded into the Counter. The next state comes from address 73. Since a XOR function does a comparison, this command can be used to compare the input to a constant and then branch based on the result with a LOOPNZ command. If the GOTO designation is left off the default for label1 will be the next instruction in the .ASM file.

POPXORC constant GOTO label1



# Figure 10. Instruction Set Summary

| Instruction | Definition                                         | Next-State<br>Address | Stack       | Counter               |
|-------------|----------------------------------------------------|-----------------------|-------------|-----------------------|
| CONTINUE    | Continue with Next Instruction                     | label1                | None        | HOLD                  |
| JUMP        | Jump to a Label                                    | label1                | None        | HOLD                  |
| CALL        | Call Subroutine                                    | label1                | label2      | HOLD                  |
| RETURN      | Return From Subroutine                             | STACK                 | POP         | HOLD                  |
| LOADC       | Load CREG                                          | label1                | None        | Constant              |
| LOOPNZ      | Loop/Dec. on Non-Zero                              | label 1 or 2          | None        | DECREMENT             |
| DECNZ       | Decrement CREG on Non-Zero                         | label1                | None        | DECREMENT             |
| PUSHLOADC   | Push CREG to Stack and<br>Load CREG                | label1                | CREG        | Constant              |
| POPC        | Pop Stack to CREG                                  | label1                | POP         | STACK                 |
| PUSH        | Push Constant to Stack                             | label1                | Constant    | HOLD                  |
| PUSHI       | Push Inputs to Stack                               | label1                | INPUTS      | HOLD                  |
| ANDPUSHI    | Push Masked Inputs to Stack                        | label1                | INP * const | HOLD                  |
| POPXORC     | XOR Stack with Constant<br>and Send Result to CREG | label1                | POP         | STACK (+)<br>Constant |

NOTE: The value label1 is placed in the Q-field. The values label2 and constant are placed in the D-field.

# Multi-Way Branching

The multi-way branching capability can be super imposed upon the instruction set providing another dimension of capability. Figure 11 shows how this translates into the flow diagrams. If location 44 had the instruction 'JUMP label1' where label1 is located at address 201, then the next-state would come from address 201. But address 201 is within the Multi-Way Branch Block so the Branch Select EPLD must decide which of the four words to send to the pipeline register. This selection is based on user-defined functions of the inputs.

Similarly, location 44 could contain any of the 13 available commands so that the

multi-way branch capability can enhance each instruction. If location 44 was a CALL to a subroutine, then address 201 could contain the starting instruction for 4 unique subroutines. The actual routine executed would depend on the condition of the inputs as defined by the user.

The actual Assembly Language code required to implement this example is as follows:

44D: [Output Spec] CALL label1;

201D: IF cond1 THEN [out 1] JUMP 102D; ELSEIF cond2 THEN [out 2] JUMP 73D; ELSEIF cond3 THEN [out 3] JUMP 53D; ELSE [out 4] JUMP 34D;







Power supply transients can affect AC measurements; simultaneous transitions of multiple outputs should be avoided for accurate measurement. Do not attempt to perform threshold tests under AC conditions. Large amplitude, fast ground current transients normally occur as the device outputs discharge the load capacitances. These transients flowing through the parasitic inductance between the device ground pin and the test system ground can create significant reductions in observable input noise immunity.



# **Product Grades**

| Application           | Temperature Range | Marking Designator |
|-----------------------|-------------------|--------------------|
| Commercial            | 0°C to +70°C      |                    |
| Industrial            | -40°C to +85°C    | 1                  |
| Military              | -55°C to +125°C   | М                  |
| MIL-STD-883C, Class B | -55°C to +125°C   | МВ                 |



SAM448\_\_\_\_\_

System Development Tools

|                      | SAM system development tools are a<br>complete set of PC-based development<br>tools for the SAM448. Installed on an IBM-<br>XT, AT or compatible computer, these tools<br>provide an integrated easy-to-use software<br>and hardware environment to support<br>SAM448 development. These tools may be                                                                                                                                                                                                                                                                                                                                | purchased as a complete development<br>system or as individual software and<br>hardware products. SAM system<br>development tools contain all necessary<br>programming hardware and software<br>required to build high-performance state<br>machines.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Host<br>Requirements | The host system requirements for installing<br>and using the SAM448 system development<br>tools are an IBM-XT, AT, or compatible                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | computer running MS-DOS version 3.1 or<br>later. The system must be equipped with<br>640 Kbytes of RAM and a hard disk.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Hardware             | <ul> <li>The SAM448 system programming<br/>hardware consists of the following:</li> <li>MagicPro — Memory and System<br/>Programmer</li> <li>WS6008 — 28 Pin Dip Socket Adaptor for<br/>MagicPro Remote Socket Adaptor Unit</li> <li>WS6009 — 28 Pin LCC Socket Adaptor<br/>for MagicPro Remote Socket Adaptor<br/>Unit</li> </ul>                                                                                                                                                                                                                                                                                                   | The MagicPro Programmer is the common<br>hardware platform for programming all WSI<br>programmable products. It consists of the<br>IBM-PC <sup>®</sup> plug-in Programmer Board and<br>the Remote Socket Adaptor Unit.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Software             | <ul> <li>The SAM448 System Development<br/>Software consists of the following:</li> <li>WISPER Software — WSI Integrated<br/>Software and Programming Environment</li> <li>SAMPLUS Software — Interface<br/>Manager for SAM Tools</li> <li>ASMILE Software — System Entry<br/>Language</li> <li>SAMSIM Software — Functional Simulator</li> <li>SAMPRO Software — Device<br/>Programming Software</li> <li>The complete SAM448 development cycle<br/>is illustrated in Figure 1.</li> <li>WISPER and SAMPLUS software provide<br/>a menu-driven user interface enabling other<br/>tools to be easily invoked by the user.</li> </ul> | The system design is entered into ASMILE<br>(WSI State Machine Input Language)<br>source program files using an editor<br>chosen by the user. ASMILE supports<br>Microcode entry and State Machine entry.<br>The ASMILE produces object code format<br>which can be loaded to SAMSIM and<br>SAMPRO<br>The SAMSIM functional simulator enables<br>the user to test and debug programs by<br>examining the state of SAM448 internal<br>states before and during a complete<br>functional simulation of the device.<br>SAMPRO software programs SAM448<br>devices by using the MagicPro hardware<br>and the socket adaptor.<br>The programmed SAM448 is then ready to<br>be used. |



| WSI-Support           | WSI provides a complete set of quality<br>support services (WSI-Support) to<br>registered system development tools                                        | <ul> <li>12-Month Software update service — Up-<br/>to-date software maintenance, access to<br/>latest software and product information.</li> </ul>                                           |  |  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                       | owners. These services include the following:                                                                                                             | Hotline to WSI Application Experts — Direct<br>system development assistance                                                                                                                  |  |  |
|                       |                                                                                                                                                           | <ul> <li>24-Hour Electronic Bulletin Board Service<br/>— Design assistance via our auto-answer<br/>dial-up modem service.</li> </ul>                                                          |  |  |
| Training<br>Workshops | WSI provides "Do-It-Yourself Systems"<br>Technical Training Workshops that provide<br>an in-depth tutorial on SAM448 and SAM<br>system development tools. | Workshop participants will learn how to<br>build their own high-performance state<br>machine using the SAM448. SAM<br>Development Training Workshops are<br>held at the WSI Fremont facility. |  |  |

SAM448 Software User's Manual.

Documentation

Ordering Information — System Development Tools

Ordering Information **SAM448-Gold** package consists of the following:

## Software

- WISPER Software
- SAMPLUS Software
- ASMILE Software
- SAMSIM Software
- SAMPRO Software
- User's Manual
- WSI-Support
- Hardware
  - WS6000 MagicPro Programmer

**SAM448-Silver** package consists of the following:

- Software
  - WISPER Software
  - SAMPLUS Software
  - ASMILE Software
  - SAMSIM Software
  - SAMPRO Software
  - User's Manual
  - WSI-Support

**WS6000 MagicPro™** Memory and PSD Programmer

 Includes IBM PC plug-in adaptor card and Remote Socket Adaptor

## **Adaptors**

- WS6008 28 Pin Dip Socket Adaptor
- WS6009 28 Pin CLLCC/CLDCC/PLDCC Socket Adaptor

## WSI-Support

- Includes 12-month Software Update Service to registered system owners
- Includes Hotline to WSI Application experts
- Includes 24-hour access to WSI's Electronic Bulletin Board Service

## SAM Training Workshops

 Includes SAM448 Training Workshops at the WSI Fremont facility. For details and scheduling, contact PSD Marketing at (415) 656-5400.

| Part Number  | Speed<br>(MHz) | Package<br>Type          | Package<br>Drawing | <i>Operating<br/>Temperature<br/>Range</i> | WSI<br>Manufacturing<br>Procedure |
|--------------|----------------|--------------------------|--------------------|--------------------------------------------|-----------------------------------|
| SAM448-20J   | 20             | 28 Pin PLDCC             | J3                 | Comm'l                                     | Standard                          |
| SAM448-20L   | 20             | 28 Pin CLDCC             | L2                 | Comm'l                                     | Standard                          |
| SAM448-20LI  | 20             | 28 Pin CLDCC             | L2                 | Industrial                                 | Standard                          |
| SAM448-20LM  | 20             | 28 Pin CLDCC             | L2                 | Military                                   | Standard                          |
| SAM448-20LMB | 20             | 28 Pin CLDCC             | L2                 | Military                                   | MIL-STD-883C                      |
| SAM448-20S   | 20             | 28 Pin Plastic Dip, 0.3" | S2                 | Comm'l                                     | Standard                          |
| SAM448-20T   | 20             | 28 Pin CERDIP, 0.3"      | T2                 | Comm'l                                     | Standard                          |
| SAM448-20TI  | 20             | 28 Pin CERDIP, 0.3"      | T2                 | Industrial                                 | Standard                          |
| SAM448-20TM  | 20             | 28 Pin CERDIP, 0.3"      | T2                 | Military                                   | Standard                          |
| SAM448-20TMB | 20             | 28 Pin CERDIP, 0.3"      | T2                 | Military                                   | MIL-STD-883C                      |
| SAM448-25J   | 25             | 28 Pin PLDCC             | J3                 | Comm'l                                     | Standard                          |
| SAM448 25L   | 25             | 28 Pin CLDCC             | L2                 | Comm'l                                     | Standard                          |
| SAM448-25S   | 25             | 28 Pin Plastic Dip, 0.3" | S2                 | Comm'l                                     | Standard                          |
| SAM448-25T   | 25             | 28 Pin CERDIP, 0.3"      | T2                 | Comm'l                                     | Standard                          |
| SAM448-30J   | 30             | 28 Pin PLDCC             | J3                 | Comm'l                                     | Standard                          |
| SAM448-30L   | 30             | 28 Pin CLDCC             | L2                 | Comm'l                                     | Standard                          |
| SAM448-30S   | 30             | 28 Pin Plastic Dip, 0.3" | S2                 | Comm'l                                     | Standard                          |
| SAM448-30T   | 30             | 28 Pin CERDIP, 0.3"      | T2                 | Comm'l                                     | Standard                          |





# Section Index

| PSD Development | MAP168 — PSD Development Systems                             | . 3-1 |
|-----------------|--------------------------------------------------------------|-------|
| Systems         | SAM448 — PSD Development Systems                             | . 3-5 |
|                 | PAC1000 — PSD Development Systems                            | . 3-9 |
|                 | WS6000 MagicPro <sup>™</sup> Programmer and Package Adaptors | 3-13  |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.



WAFERSCALE INTEGRATION, INC.

**Programmable System™Device** 

MAP168

# PSD Development System

| Description                       | MAP168-GOLD/MAP168-SILVER is a complete set of IBM-PC-based development tools. They provide the integrated easy-to-use environment to support the MAP168 program development and device programming.                                                                                                                                           | The tools run on an IBM-PC XT, AT or compatible computer running MS-DOS version 3.1 or later.                                                                                                                                                                                                       |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAPLE                             | <ul> <li>MAPLE is the MAP168 Locator Editor. It has the following features:</li> <li>Simple Menu Driven Commands for selecting different configurations of the MAP168: <ul> <li>Byte wide or word wide operation.</li> <li>Address or Chip Select Input (CSI) Mode.</li> <li>PAD security option.</li> </ul> </li> </ul>                       | <ul> <li>Generating the PAD programming data that maps the 8 segments of EPROM, two segments of SRAM and eight Chip Selects Outputs to the user's address space.</li> <li>Combining all the different files to be programmed into the EPROM segments.</li> </ul>                                    |
| MAPPRO                            | <ul> <li>MAPPRO is the interface software that enables the user to program a MAP168 device on the WS6000 MagicPro<sup>™</sup> programmer. The MAPPRO enables the user to load the program into the programmer and to execute the following operations:</li> <li>□ Help</li> <li>□ Upload RAM from MAP</li> <li>□ Load RAM from disk</li> </ul> | <ul> <li>Write RAM to FILE</li> <li>Display MAP data</li> <li>Blank test MAP</li> <li>Verify MAP</li> <li>Program MAP</li> <li>Configuration</li> <li>Quit</li> </ul>                                                                                                                               |
| WS6000<br>MagicPro™<br>Programmer | The WS6000 MagicPro Programmer is an<br>engineering development tool designed to<br>program all WSI programmable products<br>(EPROMs, RPROMs, PAC1000, MAP168,<br>PSD301 and SAM448). It is used within<br>the IBM-PC and compatible environment.<br>The MagicPro consists of a short plug-in                                                  | board and a Remote Socket Adaptor<br>(RSA). It occupies a short expansion slot<br>in the PC. The RSA has two ZIF-DIP<br>sockets that will support WSI's 24, 28, 32<br>and 40 pin standard 600 mil or slim 300<br>mil DIP packages without adaptors. Other<br>packages are supported using adaptors. |
| WS6003<br>Socket Adaptor          | The WS6003 is a socket adaptor that mounts on the MagicPro RSA and adapts                                                                                                                                                                                                                                                                      | the MAP168 in 44-pin CLDCC, PLDCC or CLLCC packages to the programmer.                                                                                                                                                                                                                              |

| MAP168                   |                                                                                                          |                                                                     |                                                                                                        |
|--------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| WS6011<br>Socket Adaptor | The WS6011 is a socket mounts on the MagicPro                                                            | •                                                                   | the MAP168 in a 44-pin PGA package to the programmer.                                                  |
| WSI-Support              | WSI provides on-going s<br>MAP168-GOLD/MAP168-<br>first year, software and p<br>are included at no charg | -SILVER. For the rogrammer updates                                  | user may purchase the WSI-Support<br>agreement to continue to receive the latest<br>software releases. |
| Ordering                 | Product                                                                                                  | 1                                                                   | Description                                                                                            |
| Information              | MAP168-SILVER                                                                                            |                                                                     | 58 Software (MAPLE-MAP and MAPPRO),<br>Manual, WSI-Support.                                            |
|                          | MAP168-GOLD                                                                                              | Contains MAP168-SILVER, WS6000 MagicPro<br>Programmer, WSI-Support. |                                                                                                        |
|                          | WSI-Support                                                                                              |                                                                     | are Update Service, Access to WSI's<br>nic Bulletin Board, and Hotline to WSI<br>tion Experts.         |

# MAP168-GOLD



# Contents

MAPLE-MAP Locator editor.

■ MAPPRO Interface software to MAP168 device programmer (MagicPro<sup>™</sup>).

- □ Software user's manual.
- □ WSI-SUPPORT agreement.
- G WS6000 MagicPro Programmer.





# **Contents**

- MAPLE-MAP Locator editor.
- MAPPRO Interface software to MAP168 device programmer (MagicPro<sup>™</sup>).
- Generation Software user's manual.
- □ WSI-SUPPORT agreement.



WAFERSCALE INTEGRATION, INC.

Programmable System<sup>™</sup> Device

SAM448

# **PSD Development System**

| Description | SAM448-GOLD/SAM448-SILVER is a complete set of IBM-PC-based development tools. They provide the integrated easy-to-use environment to support the SAM448 program development and device programming.                                                                                                | The tools run on an IBM-PC XT, AT or<br>compatible computer running MS-DOS<br>version 3.1 or later.                                                                                                                                                                                                                |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ASMILE      | ASMILE is the SAM448 system entry language. It has the following features:                                                                                                                                                                                                                          | <ul> <li>Assembly Design Entry Language.</li> <li>User Definable Macros</li> </ul>                                                                                                                                                                                                                                 |
| SAMSIM      | <ul> <li>SAMSIM is an interactive functional simulator with Virtual Logic Analyzer Interface:</li> <li>Clock driven functional simulator.</li> <li>Provides trace capabilities on internal states (Registers, Flags, Pins and more).</li> </ul>                                                     | <ul> <li>Displays input and output waveforms interactively providing such features as multiple zoom levels, split screens and differential time display.</li> <li>Line disassembler converts the actual code back into the original Assembly source code.</li> <li>On-line HELP available at any level.</li> </ul> |
| SDP         | The SAM Design Processor (SDP) takes<br>an assembly file and creates an optimized<br>JEDEC file for the SAM448. The SDP first<br>expands macros that have been defined<br>by the user. It then parses the design,                                                                                   | listing any syntax or correction errors in an<br>Error Log file. Next it minimizes the Boolean<br>expressions that define the transition<br>conditions. Finally, it fits the design into<br>the SAM448, generating a JEDEC file.                                                                                   |
| SAMPRO      | SAMPRO is the interface software that<br>enables the user to program a SAM448<br>device on the WS6000 MagicPro <sup>™</sup><br>programmer. The SAMPRO enables the<br>user to load the program into the<br>programmer and to execute the following<br>operations:<br>☐ Help<br>☐ Upload RAM from SAM | <ul> <li>Load RAM from disk</li> <li>Write RAM to FILE</li> <li>Display SAM data</li> <li>Blank test SAM</li> <li>Verify SAM</li> <li>Program SAM</li> <li>Configuration</li> <li>Quit</li> </ul>                                                                                                                  |
| SAMPLUS     | SAMPLUS is the interface manager to the<br>SAM448 software tools. SAMPLUS enables<br>the user to access ASMILE, SAMSIM, SDP,<br>SAMPRO, DOS and an editor with a menu<br>driven interface. File specification can be                                                                                | done without extension enabling the user<br>to use the same name throughout the<br>design. A HELP window is available on-<br>line giving information on all the needed<br>steps at each level.                                                                                                                     |

| SAM448                            |                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                         |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WS6000<br>MagicPro™<br>Programmer | MagicPro is an engineering development<br>tool designed to program all WSI<br>programmable products (EPROMs,<br>RPROMs, PAC1000, MAP168, PSD301 and<br>SAM448). It is used within the IBM-PC and<br>compatible environment. The MagicPro<br>consists of a short plug-in board and a | Remote Socket Adaptor (RSA). It occupies<br>a short expansion slot in the PC. The RSA<br>has two ZIF-DIP sockets that will support<br>WSI's 24, 28, 32 and 40 pin standard 600<br>mil or slim 300 mil DIP packages without<br>adaptors. Other packages are supported<br>using adaptors. |
| WS6008<br>Socket Adaptor          | The WS6008 is a socket adaptor that mounts on the MagicPro RSA and adapts                                                                                                                                                                                                           | the SAM448 in a 28 pin DIP package to the programmer.                                                                                                                                                                                                                                   |
| WS6009<br>Socket Adaptor          | The WS6009 is a socket adaptor that mounts on the MagicPro RSA and adapts                                                                                                                                                                                                           | the SAM448 in a 28-pin PLDCC/CLDCC/<br>CLLCC package to the programmer.                                                                                                                                                                                                                 |
| WSI-Support                       | WSI provides on-going support for users of<br>SAM448-GOLD/SAM448-SILVER. For the<br>first year, software and programmer updates<br>are included at no charge. After that, the                                                                                                       | user may purchase the WSI-Support<br>agreement to continue to receive the latest<br>software releases.                                                                                                                                                                                  |

| Ordering<br>Information | Product       | Description                                                                                                                               |
|-------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|                         | SAM448-SILVER | Contains SAM448 Software (ASMILE, SAMSIM, SDP,<br>SAMPRO and SAMPLUS), Software User's Manual,<br>WSI-Support.                            |
|                         | SAM448-GOLD   | Contains SAM448-SILVER, WS6000 MagicPro<br>Programmer, WSI-Support.                                                                       |
|                         | WSI-Support   | 12-Month Software Update Service, Access to WSI's<br>24-Hour Electronic Bulletin Board, and Hotline to WSI<br>System Application Experts. |

# SAM448-GOLD



# **Contents**

ASMILE

SAM design entry language.

## 

Interactive Functional simulator with Virtual Logic Analyzer user interface.

SDP

SAM Design Processor Compiles the User's program to fit into the SAM448 Device.

- SAMPRO Interface software to SAM448 device programmer (MagicPro<sup>™</sup>).
- SAMPLUS Interface manager to SAM448 development tools.
- Generation Software user's manual.
- USI-SUPPORT agreement.
- UWS6000 MagicPro Programmer.

#### SAM448

# SAM448-SILVER



# Contents

## ASMILE

SAM design entry language.

## SAMSIM Interactive Functional simulator with Virtual Logic Analyzer user interface.

SDP SAM Design Processor Compiles the User's program to fit into the SAM448 Device.

## SAMPRO

Interface software to SAM448 device programmer (MagicPro).

- SAMPLUS Interface manager to SAM448 development tools
- Generation Software user's manual.
- G WSI-SUPPORT agreement.



Programmable System<sup>™</sup> Device

PAC1000

# **PSD Development System**

| Description | PAC1000-GOLD/PAC1000-SILVER is a complete set of IBM-PC-based development tools. They provide the integrated easy-to-use environment to support the PAC1000 program development and device programming.                                                                                                                                                         | The tools run on an IBM-PC XT, AT or<br>compatible computer running MS-DOS<br>version 3.1 or later.                                                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PACSEL      | <ul> <li>PACSEL is the PAC1000 system entry language. It has the following features:</li> <li>Enables specification of up to three parallel operations: <ul> <li>Program control operation</li> <li>CPU operation</li> <li>Out Control operation</li> </ul> </li> <li>General Syntax: <ul> <li>Label: Program Control, CPU, Out Control;</li> </ul> </li> </ul> | <ul> <li>Enables mixing of three source<br/>language types in one instruction:         <ul> <li>High Level Language</li> <li>Assembler</li> <li>Microcode</li> </ul> </li> <li>Specific instructions support unique<br/>PAC1000 architecture features available<br/>in all three source language types.</li> <li>Links unlimited amounts of modules.</li> </ul> |
| PACSIM      | <ul> <li>PACSIM is a functional simulator and software debugger. It has the following features:</li> <li>Clock driven functional simulator.</li> <li>Provides trace capabilities on internal states (Registers, Flags, Pins and more).</li> </ul>                                                                                                               | <ul> <li>Provides breakpoint capabilities on any internal state of the PAC1000.</li> <li>Supports batch mode simulation.</li> <li>Provides waveform analysis.</li> <li>On-line HELP available at any level.</li> </ul>                                                                                                                                          |
| PACPRO      | PACPRO is the interface software that<br>enables the user to program a PAC1000<br>microcontroller on the WS6000 MagicPro <sup>™</sup><br>programmer. The PACPRO enables the<br>user to load the program into the<br>programmer and to execute the following<br>operations:<br>☐ Help<br>☐ Upload RAM from PAC<br>☐ Load RAM from disk                           | <ul> <li>Write RAM to FILE</li> <li>Display PAC data</li> <li>Blank test PAC</li> <li>Verify PAC</li> <li>Program PAC</li> <li>Configuration</li> <li>Quit</li> </ul>                                                                                                                                                                                           |
| IMPACT      | IMPACT is the interface manager to the<br>PAC1000 tools. IMPACT enables the user<br>to access PACSEL, PACSIM, PACPRO,<br>DOS and an editor with a menu driven<br>interface. File specification can be done                                                                                                                                                      | without extension enabling the user to use<br>the same name throughout the design. A<br>HELP window is available on-line giving<br>information on all the needed steps at<br>each level.                                                                                                                                                                        |

PAC1000

| WS6000<br>MagicPro™<br>Programmer                                                                                                                                   | MagicPro is an engineering development<br>tool designed to program all WSI<br>programmable products (EPROMs,<br>RPROMs, PAC1000, MAP168, PSD301 and<br>SAM448). It is used within the IBM-PC and<br>compatible environment. The MagicPro<br>consists of a short plug-in board and a | Remote Socket Adaptor (RSA). It occupies<br>a short expansion slot in the PC. The RSA<br>has two ZIF-DIP sockets that will support<br>WSI's 24, 28, 32 and 40 pin standard<br>600 mil or slim 300 mil DIP packages<br>without adaptors. Other packages are<br>supported using adaptors. |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <b>WS6010</b> The WS6010 is a socket adaptor that mounts on the MagicPro RSA and adapts                                                                             |                                                                                                                                                                                                                                                                                     | the PAC1000 in an 88-pin CPGA package to the programmer.                                                                                                                                                                                                                                |  |  |
| WS6013<br>Socket Adaptor                                                                                                                                            | The WS6013 is a socket adaptor that mounts on the MagicPro RSA and adapts                                                                                                                                                                                                           | the PAC1000 in a 100-pin QFP package to the programmer.                                                                                                                                                                                                                                 |  |  |
| WSI-Support WSI provides on-going support for use PAC1000-GOLD/PAC1000-SILVER. For first year, software and programmer upo are included at no charge. After that, t |                                                                                                                                                                                                                                                                                     | user may purchase the WSI-Support<br>agreement to continue to receive the latest<br>software releases.                                                                                                                                                                                  |  |  |

| Ordering<br>Information | Product        | Description                                                                                                                         |
|-------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|
|                         | PAC1000-SILVER | Contains PAC1000 Software (PACSEL, PACSIM,<br>PACPRO, and IMPACT), Software User's Manual,<br>WSI-Support.                          |
|                         | PAC1000-GOLD   | Contains PAC1000-SILVER, WS6000 MagicPro<br>Programmer, WSI-Support.                                                                |
|                         | WSI-Support    | 12-Month Software Update Service, Access to WSI's 24-Hour Electronic Bulletin Board, and Hotline to WSI System Application Experts. |

# PAC1000-GOLD



# Contents

## PACSEL

System design entry language and program linker.

- PACSIM Functional simulator and software debugger.
- PACPRO Interface software to PAC1000 device programmer (MagicPro<sup>™</sup>).

# IMPACT

Interface manager for PAC1000 microcontroller development tools.

- Software user's manual.
- G WSI-SUPPORT agreement.
- UWS6000 MagicPro Programmer.

## PAC1000

PAC1000-SILVER



# **Contents**

# PACSEL

System design entry language and program linker.

- PACSIM Functional simulator and software debugger.
- PACPRO Interface software to PAC1000 device programmer (MagicPro<sup>™</sup>).

#### IMPACT

Interface manager for PAC1000 microcontroller development tools.

- Software user's manual.
- □ WSI-SUPPORT agreement.

# WS6000

WAFERSCALE INTEGRATION, INC.

# MAGICPRO<sup>™</sup> MEMORY AND PSD PROGRAMMER

**KEY FEATURES** 

- Programs All WSI CMOS Memory and PSD Products and All Future Programmable Products
- Programs 24, 28, 32 and 40 Pin Standard 600 Mil or Slim 300 Mil Dip Packages Without Adaptors
- Programs LCC, PGA and QFP Packaged Product by Using Adaptors
- Easy-to-Use Menu-Driven Software
- Compatible with IBM PC/XT/AT Family of Computers (and True Plug-Compatible)

# **GENERAL DESCRIPTION**

MAGICPRO<sup>™</sup> is an engineering development tool designed to program existing WSI EPROMs, RPROMs, Programmable System Devices, and future WSI programmable products. It is used within the IBM-PC<sup>®</sup> and compatible computers. The MAGICPRO<sup>™</sup> is meant to bridge the gap between the introduction of a new WSI programmable product and the availability of programming support from programmer manufacturers (e.g., Data I/O, etc.). The MAGICPRO<sup>™</sup> programmer and accompanying software enable quick programming of newly released WSI programmable products, thus accelerating the system design process.

The MAGICPRO<sup>™</sup> plug-in board is integrated easily into the IBM-PC<sup>®</sup>. It occupies a short expansion slot and its software requires only 256K bytes of computer memory. The two external ZIF-Dip sockets in the Remote Socket Adaptor (RSA) support 24, 28, 32 and 40 pin standard 600 mil or slim 300 mil Dip packages without adaptors. LCC, PGA and QFP packages are supported using adaptors.





Many features of the MAGICPRO<sup>™</sup> Programmer show its capabilities in supporting WSI's future products. Some of these are:

- 24 to 40 pin JEDEC Dip pinouts
- 1 Meg. address space (20 address lines)
- 16 data I/O lines

The MAGICPRO<sup>™</sup> menu driven software makes using different features of the MAGICPRO<sup>™</sup> an easy task. Software updates are done via floppy disk which eliminates the need for adding a new memory device for system upgrading. Please call 800-TEAM-WSI for information regarding programming WSI products not listed herein. The MAGICPRO<sup>™</sup> reads Intel Hex format for use with assemblers and compilers.

WSI PRODUCTS

## MAGICPRO<sup>™</sup> COMMANDS

| — Help                                     | WS57C191/191B/291/291B | 2K × 8       | RPROM      |
|--------------------------------------------|------------------------|--------------|------------|
| <ul> <li>Upload RAM from device</li> </ul> | WS57C43/43B            | 4K × 8       | RPROM      |
| - Load RAM from disk                       | WS57C49/49B            | 8K × 8       | RPROM      |
| <ul> <li>Write RAM to disk</li> </ul>      | WS57C51/51B            | 16K × 8      | RPROM      |
| <ul> <li>Display RAM data</li> </ul>       | WS27C64F/L             | 8K × 8       | EPROM      |
| – Edit RAM                                 | WS57C64F               | 8K × 8       | EPROM      |
| <ul> <li>Move/copy RAM</li> </ul>          | WS57C65                | 4K × 16      | EPROM      |
| - FIII RAM                                 | WS57C66                | 4K × 16      | EPROM      |
| <ul> <li>Blank test device</li> </ul>      |                        | (Mux I/O, 28 | B Pin DIP) |
| - Verify device                            | WS27C128F/L            | 16K × 8      | EPROM      |
| - Program device                           | WS57C128F              | 16K × 8      | EPROM      |
| Select device                              | WS27C256F/L            | 32K × 8      | EPROM      |
| - Configuration                            | WS57C256F              | 32K × 8      | EPROM      |
| - Quit MagicPro™                           | WS57C257F              | 16K × 16     | EPROM      |
| 8                                          | WS27C512F/L            | 64K × 8      | EPROM      |
|                                            | WS27C010L              | 128K × 8     | EPROM      |
|                                            | MAP168                 |              |            |
|                                            | PAC1000                |              |            |
|                                            | SAM448                 |              |            |
|                                            | PSD301                 |              |            |

## **TECHNICAL INFORMATION**

- Size: IBM-PC® short length card
- Port Address Location: 100H to 1FFH—default 140H (If a conflict exists with this address space, the address location can be changed in software and with the switches on the plug-in board.)
- System Memory Requirements: 256K bytes of RAM
- Power: +5 Volts, 0.03 Amp.; +12 Volts, 0.04 Amp.
- Remote Socket Adaptor (RSA): The RSA contains two ZIF-Dip sockets that are used to program and read WSI
  programmable products. The 32 pin ZIF-Dip socket supports 24, 28 and 32 pin standard 600 mil or slim 300 mil
  Dip packaged product. The 40 pin ZIF-Dip socket supports all 40 pin Dip packages. Adaptor sockets are available
  for LCC, PGA and QFP packages.

# **ORDERING INFORMATION**

# The WS6000 MAGICPRO<sup>™</sup> System contains:

- MAGICPRO<sup>™</sup> IBM-PC<sup>®</sup> plug-in programmer board
- MAGICPRO<sup>™</sup> Remote Socket Adaptor and cable
- MAGICPRO<sup>™</sup> Operating System Floppy Disk and Operating Manual

## MAGICPRO<sup>™</sup> Adaptors include:

- WS6001 28 Pin CLLCC Package adaptor for memory.
- WS6003 44 Pin PLDCC/CLDCC/CLLCC package adaptor for MAP168.
- WS6008 28 Pin 0.3" wide DIP adaptor for SAM448.
- WS6009 28 Pin PLDCC/CLDCC/CLLCC package adaptor for SAM448.
- WS6010 88 Pin PGA package adaptor for PAC1000.
- WS6011 44 Pin PGA package adaptor for MAP168.
- WS6012 32 Pin CLDCC package adaptor for memory.
- WS6013 100 Pin QFP package adaptor for PAC1000.
- WS6014 44 Pin CLDCC/PLDCC package adaptor for MAP168 and PSD301.
- WS6015 44 Pin PGA package adaptor for MAP168 and PSD301.





# Section Index

| PSD Applications | Application Note 002  | Introduction to the MAP168 User-Configurable<br>Mappable Memory Subsystem4-1       |
|------------------|-----------------------|------------------------------------------------------------------------------------|
|                  | Application Note 010  | PAC1000 Introduction4-13                                                           |
|                  | Application Note 005  | PAC1000 as a High-Speed Four-Channel DMA Controller4-39                            |
|                  | Application Brief 006 | PAC1000 as a 16 Bi-Directional Serial Channel Controller4-71                       |
|                  | Application Note 008  | PAC1000 User-Configurable Microcontroller with a Built-In-Self-Test Capability4-75 |
|                  | Application Note 009  | In-Circuit Debugging for the PAC1000 User-Configurable Microcontroller             |
|                  | Application Brief 007 | Hardware Interfacing the PAC1000 as a Micro Channel Bus Controller                 |
|                  | Application Note 003  | High-End SAM Applications Using Microassembler Design Entry4-105                   |
|                  | Application Note 004  | SAM Applications Using State Machine Design Entry4-127                             |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.

WAFERSCALE INTEGRATION, INC.



# Programmable System™Device

Application Note 002

Introduction to the MAP168 User-Configurable Mappable Memory Subsystem

## **Memory Structure**

Memory configurations in microprocessor and microcontroller systems have similar structure, irrespective of the application. (see Figure 1.) They share basic components, such as an EPROM (for program storage), and an SRAM (for data storage). In addition, a decoder circuit is required to select blocks of memory from the address inputs applied by the processor. A common implementation of address decoding originally used MSI building blocks, such as 74xx138 devices. Memoryconfiguration changes and expansions in a fixed-logic solution required jumpers on the printed circuit board. More recently, decoders based on PAL® devices have provided a more compact and flexible solution. PAL devices allow configuration changes to be implemented by insertion of a programmed device and avoid jumper changes.



Both solutions involve compromises that affect system performance, board space, power and cost. Since the decoder is in the memory access path, the total memory access time is the sum of the decoder delay and the access time of the memory itself. For example, a 40ns total access time can be achieved with a 12ns decoder and a 25ns memory. This allows 3ns for on-board interconnect delay. Memory products in the 25ns range are expensive and therefore such a performance entails additional cost. To be able to integrate the programmable address decoder with system memory, EPROM and static RAM would offer a more flexible approach. The resulting device would provide board-space economy, higher performance and less overall power consumption without the cost of a multichip solution.

#### MAP168 — Application Note 002

#### Memory Structure (Con't)

The WSI-MAP family of user-configurable mappable memory subsystem products has been developed to significantly enhance system performance by integrating high density EPROM for program store, high density SRAM for data store and high performance logic in the form of a Programmable Address Decoder (PAD) on one chip. (See Figure 2.) The first of these devices, with 128K bits of EPBOM and 32K bits of SBAM. is the MAP168 device. These devices are

ideally suited for a number of common design applications:

- High-speed Digital Signal Processor applications (modems, analog data filtering or analysis)
- Expanding memory systems for microprocessors and microcontrollers
- Space- and power-sensitive applications (plug-in cards, avionics, portable systems)

## Figure 2. Memory Subsystem Usina the MAP168 Device



## Features of the MAP168 Device

The MAP168 device offers significant design advantages through integration, performance and user-configurability. It integrates both volatile and non-volatile memory on the same chip, along with a flexible decoding system. The memory is structured as a series of blocks to achieve a highly configurable circuit for general purpose applications. The device operates in one of several modes, one of which is for normal operation and the rest are for device configuration. At the heart of all MAP168 device is a Programmable Address Decoder (PAD), which is programmed during the PAD programming mode through the circuit's address and I/O pins. The PAD offers the following features:

- Flexible EPROM/SRAM location within the address space
- Memory array power-down when not being accessed
- Security protection of memory configuration data to inhibit copying

Integrated external device mapping through Chip Select Outputs

### Memory Architecture And Technology

The memory in the MAP168 device consists of non-volatile EPROM and volatile SRAM. (See Figure 3.) The EPROM is subdivided into 8 blocks and the SRAM into 2 blocks. The blocks may be configured in either a 2Kx8 or a 1Kx16 format, allowing optimal interaction with both 8- and 16-bit systems. These memory blocks can be considered as separate memories with dedicated internal chip selects. The PAD selects the appropriate block, decoded from the incoming address provided at the device inputs. This architecture enables the product to be configured and compatible with virtually any system address map. Complicated address maps of microcontroller systems can be fully realized by programming blocks of EPROM and SRAM in the memory-mapping scheme of the system.

## Features of the MAP168 Device (Con't)

In addition to having fine control of memory allocation, software updates which require changes in the address map boundaries can be easily accomplished by simply reprogramming the PAD at the same time as the EPROM code. This means only one part need be sent to the end-product customer to accommodate field software changes. This becomes a user-transparent method that requires no change of PC board jumpers.

The EPROM is based on WSI's patented split-gate EPROM technology for high density and very high speed. It is also used in the reconfigurable PAD section, permitting both fast decode and reconfiguration of the same device. The MAP168 device contains a 128Kbit UV erasable EPROM which can be organized as 16Kx8 (byte-wide) or as 8Kx16 (word-wide).

The SRAM is based on the industry standard full CMOS 6-transistor cell. The advantages of this cell are high speed, very low stand-by power, high noise immunity and good data retention when disturbed by alpha particles. In the MAP168 device, the SRAM contains 32K bits which can be configured as 4Kx8 in the byte mode or 2Kx16 in the word-wide mode.



Features of the MAP168 Device (Con't)

## PAD Logic Implementation

The PAD uses the same non-volatile EPROM cells as the EPROM array. (See Figure 4.) It can be erased and configured at the same time as the EPROM. After UV erase or with new parts, the EPROM cells in the MAP168 device normally connect between the address inputs and the select outputs. The EPROM cells are disconnected by selective programming.

The PAD performs as an address comparator. When the address configuration previously programmed into the PAD is detected, the internal chip-select signal to the memory block selected by that address is enabled. If no block is selected by the address, neither the EPROM nor the SRAM arrays are enabled and other devices may drive the data bus. Independent of internal block selection, external chip-select decoding (known as CSOs) are programmable in the same block resolution as the internal memory.

Actual implementation of the PAD is similar to that of a PAL device. (See Figure 5.) In the erased state, all the block decode addresses are connected to the AND plane. There is only one output per AND gate and there is no OR plane. Each AND gate output either selects a block of internal memory or a number of blocks of external memory for the external CSOs. Only addresses  $A_{11}-A_{20}$  are used as block decode address. Lower-order address lines are used only for addressing within the internal memory arrays.

EPROM select outputs  $ES_0-ES_7$  (ES outputs) select 1 of the 8 available EPROM blocks. SRAM select outputs  $RS_0-RS_1$  (RS outputs) select one of the 2 available SRAM blocks. Because only one EPROM or SRAM block can be active at a particular time, only one line from either  $ES_0-ES_7$  or  $RS_0-RS_1$  is allowed to be active at one time. The CSOs are independent of the ES and RS outputs and therefore any one address can be programmed to select one or more of the CSOs, even simultaneous to the selection of one of the ES or RS outputs. This is particularly useful for I/O control or address decode for wait state generation.

Programming the decoder is similar to programming a PAL device that has only one product term (AND gate) per output. To enable an output  $S_1$  as shown in Figure 4, fuse locations  $A_{11}$  and  $A_{12}$  are left intact while  $\overline{A}_{11}$  and  $\overline{A}_{12}$  are programmed. Conversely, if  $A_{11}$  and  $A_{12}$  are programmed. Conversely, if  $A_{11}$  and  $A_{12}$  are programmed while their complements are left intact, then the select S function is active when  $\overline{A}_{11} = \overline{A}_{12} = 0$ . If all fuse locations are programmed on a product term, the inputs are pulled HIGH and no select output can take place. If all fuse locations are left intact, the S output is permanently LOW, always selected.



# Features of the MAP168 Device (Con't)

Figure 5.

## **Device Array Power-Down**

Power dissipation on the chip is minimized through logic in the PAD. It selectively powers up the EPROM or SRAM arrays only when they are being accessed. If the EPROM is selected through the decoder, it will draw power while the SRAM stavs powered down and vice versa. When neither the EPROM or the SRAM is selected, both are powered down. Note that data integrity in a "powered down" SRAM is maintained. A Chip Select Input (CSI) to the device is

provided for a very low-power guiescent mode. With  $\overline{CSI}=1$ , the EPROM and SRAM are powered down but the PAD is powered up, independent of the incoming address signals. The CSI input pin can be connected to a system power-down signal. If such a signal is unavailable, addressing a location in memory that does not select either the EPROM or the SRAM also reduces power drain. In this case, only the PAD is powered up and draws a small fraction of the active power.



## Features Of The MAP168 Device (Con't)

The  $\overline{\text{CSI}}/\text{A}_{20}$  input is actually a dual function pin. It can be an address (MSB) input, or it can be programmed to be a chip select input as well. As a chip select input, it will enable the EPROM and SRAM memory when active (LOW). If the address option  $\text{A}_{20}$  is chosen the chip is always enabled.

### Address Map Security

Upon entering the PAD programming mode, the contents of the PAD are fully accessible through the I/O pins. After programming is completed, it is possible to render the PADs programmed configuration invisible by programming the security (SEC) bit. This disables external access to the PAD and ensures that the PAD configuration can not be copied. To further aid in securing data in the MAP product, it is suggested that memory blocks that are addressed in a linear block placement be programmed in the PAD as chip selects from product terms that are randomly placed.

### **Chip Select Outputs**

The MAP168 device can be user-configured for 8-bit or 16-bit systems. In the former case, eight unused data lines ( $\overline{CSO}_{0-7}$ ) are available as chip select outputs, driven by the address decoder section of the PAD. This provides the

ability to integrate external devices into the address map with no hardware overhead. Unlike the internal memory blocks, a  $\overline{\text{CSO}}$  can be active for more than one address combination or block. Also, groups of blocks may overlap both each other and the internal memory. By deselecting both the true and the complement it is possible to make an address line "don't care".

An external memory can therefore be selected with only one  $\overline{CSO}$ . It is possible to enable another external 128K byte memory by programming a single  $\overline{CSO}$  to be active for that entire address range.

A  $\overline{\text{CSO}}$  can be programmed to function as a configuration bit which is always deselected (e.g.,  $\overline{\text{CSO}}_{0}=1$ ) or always selected (e.g.,  $\overline{\text{CSO}}_{0}=0$ ) by programming the addresses with "hard deselect" or with the "don't care" patterns, respectively. This is similar in function to a PC-board wire jumper. If unused  $\overline{\text{CSOs}}$  are programmed with all addresses "don't care", then switching is eliminated and power consumption reduced for those lines.

Since the PAD is always powered up when the device is selected ( $\overline{CSI}$ =0),  $\overline{CSOs}$  are always active and their state is a direct function of the PAD configuration and current address line inputs.

## System Applications

The MAP168 device is designed to reduce memory access time and board area utilization in high performance digital signal processor, microcontroller and microprocessor systems. These systems typically have the following requirements:

- 16-bit data path
- 64K to 1 Meg address space
- Fast memory access time (100ns to 40ns)
- Decoding for I/O and memory
- Printed circuit board area limitations
- Multiple types of memory, including EPROMs and SRAMs for program and data store.

The DSP System Architecture shown in Figure 6 illustrates a typical system based

upon a 40MHz TMS320C25 digital signal processor. Such a system allows only 40ns for memory access time. The access time must be broken down into decoding time and memory-access time. The fastest decoders available today require approximately 10ns to complete their decode function. Due to this decoding time, memory access time for both the EPROM and SRAM must be 30ns or less. The WSI-MAP family of products performs decoding on-chip with no speed penalty. As a result, the performance of a 40ns MAP168 device in the above example is equivalent to a 10ns decoder and a 30ns EPROM and SRAM memory. In addition, the package equivalent of two fast EPROMs, two fast SRAMs and at least one decoder are combined into one MAP168 chip resulting in at least a 5-to-1 component count reduction.



### High-Speed, Word-Oriented Application

The MAP168 device is especially suited for high-speed word-only microprocessors. The TMS320C20/25 DSP family is an example of such a microprocessor. Interfacing the MAP168 device to a TMS320C25 operating at 40MHz with no wait states is illustrated in Figure 7. The TMS320C25 has two pins for selecting Program Memory (PS) and Data Memory (DS). These functions are connected to the higher order address of the MAP168 device. PS is connected to  $A_{18}$ and DS is connected to  $A_{17}$ . Usually PS will select the EPROM and DS will select the SRAM. The PAD permits partitioning of the MAP168 memory to accommodate virtually any system address map. Figure 8 shows two possibilities.



System Applications (Con't) When in a word-wide (x16) configuration, the total memory available on the MAP168 device is 8Kx16 of EPROM and 2Kx16 of SRAM. The implementation shown in Figure 7 replaces at least five circuits:

One high-speed decoder (10ns)

- Two 8Kx8 EPROMs (30ns)
- Two 2Kx8 SRAMs (30ns)

If the system was previously implemented using a boot EPROM, the MAP168 device replaces ten circuits:

- One high-speed decoder (10ns)
- Two 8Kx8 EPROMs (30ns)
- Two 2Kx8 SRAMs (30ns)
- Two 8Kx8 slow EPROMs
- Three ICs for Wait-State generation

For expanded memory requirements in a word-wide (x16) configuration, two MAP168 devices can be interfaced directly with a TMS320C25, as shown in Figure 9. The two MAP168 devices provide the total system memory. Key features of this system are:

- 40ns access time
- 16Kx16 EPROM
- 4Kx16 EPROM
- 16 general purpose programmable chip selects

The general-purpose programmable chip select outputs can be mapped to any location in the address space via the PAD. These chip selects can be used to access I/O ports, select additional memory or control other system functions.



### Microcontroller Application

The MAP168 device has two basic configurations. They are a word-wide (x16) configuration with byte operation capability and a bytewide (x8) configuration with 8 chip select outputs.

The 128K address space (during byte operations in the word-wide mode) makes the MAP168 device especially suited for microcontroller applications. Figure 10 illustrates a simple interconnection of the MAP168 device to a microcontroller. The HPC16040 operating without wait states requires a memory access time of 65ns or better. This makes the MAP168 device a good fit, since it offers an access time of 40ns, leaving a 25ns margin.

The MAP168 device can be configured in a byte-wide (x8) mode and can also be doubled-up with a second device.





cludes extensive documentation on installa-



representative.



·····



# Programmable System™ Device

**Application Note 010** 

**PAC1000 Introduction** By Chris Jay and David Fong

# Abstract

The PAC1000 user configurable high performance microcontroller, from WaferScale Integration, is the first of a generation of devices intended for applications in high end embedded control. Understanding the device architecture and using its support tools require some practical experience before a full system design is attempted. This application note is intended to introduce the device and its architecture along with the support software tools to the systems designer. Finally to develop some simple applications leveled at common problems found in system design.

#### Introduction

The PAC1000 has many applications in digital systems where high speed processing, interface or control is required. The two roles of the device are in a standalone mode where the PAC1000 is programmed to control data flow to or from other systems, or as a high speed peripheral working with a host microprocessor. Frequently, many systems designers cannot find the ideal solution to their requirements in a standard chip. The designer may look at creating the required function from discrete logic, a combination of a number of PAL/EPLD devices, Programmable Gate Array (PGA) products or standard gate array. In each alternative, the designer is trying to reduce the chip count of the system solution and hence increase its reliability and reduce assembly costs.

The discrete TTL or CMOS logic solution to a systems design is considered by some to be an old fashioned approach but still popular with many digital design engineers. However, designs using this technology can quickly escalate in chip count as the development progresses and once a system is designed it is very difficult to modify because the finished printed circuit board contains devices that cannot be re-programmed or altered in any way. Also, a revision or system upgrade will require a new printed circuit board design.

The PAL/EPLD solution reduces the chip count over a solution that uses discrete logic but still many devices are used because the PAL/EPLD products are not very register intensive. Small subsystems such as FIFO or a STACK require a number of PAL/EPLD devices and additionally

require some additional chips. An alternative solution would be to use additional dedicated chips like FIFO. ALU and SRAM. leaving the PLD/EPLD devices to handle the glue, interface and small state machine functions. The Programmable Gate Array brings the system down to a possible acceptable level but system logic still has to be defined and routed in the logic cells and a number of PGA devices have to be designed such that they all work together. Nevertheless, in the case of the programmable solution, subsystems such as STACK, ALU, REGISTER FILES etc., might still need to be configured in the gates and registers of these devices. This can cause an escalation in the quantity of these chips used in the final system, because PLDs and PGAs are not good vehicles for integration at the subsystem to system level. In a gate array design the turn-around time is longer than the programmable solution, and because the device is not re-programmable there is a high level of risk in going to a gate array solution. Also, the high 'up front' Non Recurring Engineering charges NRE can rule out the use of gate array.

The Programmable Standalone Controller offers the most likely solution to the problem facing the systems designer. Very often both the PAC1000 is used withprogrammable logic devices to effect an overall solution. For example in some modes of operation PLDs are used for address decoders to select and gate the host interface control lines such as CSB, RDB, and WRB. By bringing the package count of the system down to its lowest

| Introduction<br>(Cont.)        | level the design cycle time reduces, so<br>minimizing the overall time to market of<br>the final product. The reason for this is<br>that the PAC1000 already contains the<br>subsystems necessary for a fully functional<br>system design, and being programmable, it<br>can be adapted to perform most functions<br>required from systems devices.<br>The PAC1000 comprises elements such<br>as FIFO, ALU, register files, STACK,<br>microcode store, loop and breakpoint<br>counters, special registers and interface<br>logic all interconnected by a general<br>purpose internal bus structure. The<br>instructions that control data flow are<br>contained in the EPROM section of the<br>microcontrol store. These instructions are<br>entered into the system by the designer as<br>assembly or high level language code.<br>There also exists a microcode entry level<br>for those designers who are used to                                                                         | microprogrammable designs. Designing<br>with the PAC's software support tools is very<br>similar to writing code for microprocessors.<br>The end result is an assembled listing which<br>can be simulated prior to programming<br>into the PAC1000 device's on chip EPROM.<br>The difference between microprocessors,<br>conventional microcontrollers and the<br>PAC1000 device is found its ability to<br>execute instructions in parallel, and to<br>offer the designer a flexible architecture.<br>Microcontrollers and microprocessors<br>function on single operations of execution,<br>but the PAC1000 executes three instructions<br>in parallel during the current clock cycle.<br>In this way the PAC1000 device needs<br>fewer EPROM locations to store the code<br>which performs a given function. In addition<br>high functional speeds can be obtained<br>because the device can execute those<br>instructions at the clock rate of the system.                   |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAC1000 Device<br>Architecture | The PAC1000 device architecture can be<br>divided into three subsystems, see Figure<br>1a; a CPU section that is similar to those<br>found in microprocessors, a host interface,<br>and a programmable instruction control<br>unit. The instruction register can be clearly<br>identified with its three output sections of<br>control, output and CPU Operation<br>Definition. Figure 1b illustrates a more<br>detailed diagram of the system than                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Figure 1a, clearly identifying the sub<br>structures of the three subsystems. The<br>different sections of the PAC1000 are<br>interconnected to each other by internal<br>buses and convey data and instructions to<br>and from each other. Communication to<br>and from the outside world is achieved<br>through various input and output registers,<br>and a Command/Data FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| The Control Unit               | The control unit is constructed around a<br>1K deep 64-bit wide EPROM, see Figure<br>1b. The 64-bit wide instructions are<br>programmed in the EPROM section and<br>are accessed and executed on each clock<br>cycle. The input RESET causes the<br>PAC1000 to access and execute the first<br>instruction at location 000H of EPROM.<br>On each execution cycle, the Instruction<br>Register shown in Figure 1a will contain<br>three control operatives, a next address<br>instruction to the control section, an output<br>instruction and CPU instruction. The other<br>inputs to the control unit include interrupts<br>and condition codes. There are four external<br>and four internal interrupts that can be<br>enabled under programmed control. These<br>can generate a branch to an interrupt<br>service routine that results from a rising<br>edge applied to the external interrupt<br>input. For interrupts INT0, INT1, INT2, and<br>INT3 there are four locations 008H, 009H | 00AH and 00BH respectively. These are<br>the vectored addresses at which processing<br>will continue in the presence of one of<br>these active interrupts. At the interrupt<br>location a jump to an interrupt service<br>routine should be inserted. For example,<br>the occurrence of INTO will divert<br>processing to location 008H, that location<br>may contain a JMP 100H, where 100H is<br>the address where the service routine for<br>INTO should reside. The internally<br>generated interrupts are INT4, INT5, INT6<br>and INT7 which divert processing to<br>locations 0CH, 0DH, 0EH and 0FH<br>respectively. Details of their allocated<br>function is given in the PAC1000 data<br>sheet. In addition there are eight condition<br>code inputs CC[7:0], shown alongside the<br>INT[3:0] inputs in Figure 1b. These inputs<br>can be tested individually under program<br>control. The combination of Next Instruction<br>Definition, Interrupt and Condition Code |

# The Control Unit (Cont.)

input direct the flow of the program and hence the execution of instructions contained in the EPROM section. The CASE logic is used in the controller section to enable CASE statements to be executed on condition code groups. The eight condition code inputs may be divided into two four bit groups. Case group zero CG0 comprises CC0, CC1, CC2 and CC3. Case group 1 CG1 comprises CC4, CC5, CC6 and CC7. A further two case groups CG2 and CG3 test flag registers (see Table 1). These condition code inputs may be tested individually or tested in a group. When tested in a four bit group, a one-ofsixteen branch will occur, as specified by the CASE instruction.

The current status of the PAC1000 is kept in the sixteen bit status register. STAT0– STAT11 give twelve status bits with four extra bit locations for future development. Table 2 shows the assignment of each register.



WAFERSCALE INTEGRATION, INC. 4-15

| Table 1.                    | Condition Code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                         | CASE                                                                                                                                                                         |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                            |                                                                                                                                    |                                                   |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| CASE Group<br>Assignments   | CC0, CC1, CC2, CC3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                         |                                                                                                                                                                              | CASE Group 0                                                                                                                                                 |                                                                                                                                                |                                                                                                                                            |                                                                                                                                    |                                                   |
| nssignillents               | CC4, CC5, CC6, CC7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                         | C                                                                                                                                                                            | ASE C                                                                                                                                                        | aroup                                                                                                                                          | 1                                                                                                                                          |                                                                                                                                    |                                                   |
|                             | S, O, Z, CY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                         |                                                                                                                                                                              | C                                                                                                                                                            | ASE G                                                                                                                                          | àroup                                                                                                                                      | 2                                                                                                                                  |                                                   |
|                             | INTR, BCZ, FIOR, FICD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                         |                                                                                                                                                                              | C                                                                                                                                                            | ASE G                                                                                                                                          | àroup                                                                                                                                      | 3                                                                                                                                  |                                                   |
|                             | FIXP, ACO, STKF, FIIR, DOR, INTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ł                                                                                                                                                                                                                       |                                                                                                                                                                              |                                                                                                                                                              | N                                                                                                                                              | Ά                                                                                                                                          |                                                                                                                                    |                                                   |
|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                         |                                                                                                                                                                              |                                                                                                                                                              |                                                                                                                                                |                                                                                                                                            |                                                                                                                                    |                                                   |
| Table 2. Status<br>Register | 0 0 WSI<br>Reserved S11 S10 S9 S8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | S7 Se                                                                                                                                                                                                                   | 5 S5                                                                                                                                                                         | S4                                                                                                                                                           | S3                                                                                                                                             | S2                                                                                                                                         | S1                                                                                                                                 | SO                                                |
|                             | <ul> <li>S10 — Scan Mode, High is Active On, Low</li> <li>S9 — FIXP FIFO Exception Occurs When Exception.</li> <li>S8 — FIIR FIFO Input Ready When There</li> <li>S7 — CY Set High When the Result of a C</li> <li>S5 — O Set When an Overflow Has Occurs</li> <li>S4 — S Sign Bit Set to One When the Reiser Sign Bit Set When the State</li> <li>S2 — Breakpoint Flag. Set When the A to the Address in the Program Cours</li> <li>S1 — BCZ is Set When the Block Counter</li> <li>S0 — ACO Address Counter All Ones Flate</li> <li>The Maximum Count.</li> </ul>                                                                                                                                                                                                                                                 | a Comm<br>e is at Lea<br>CPU Opera<br>PU Opera<br>urred Duri<br>esult is a<br>ck is Full.<br>ddress in<br>nter.<br>er Reache                                                                                            | and is<br>ration (<br>ation is<br>ng a Tv<br>Negativ<br>the Bre<br>s Zero.                                                                                                   | Writter<br>Loca<br>Genera<br>Zero.<br>vo's Co<br>ve Nur<br>eakpoi                                                                                            | tion V<br>ated a<br>omple<br>nber.<br>nt Reg                                                                                                   | acant<br>Carr<br>ment<br>gister                                                                                                            | y.<br>Opera<br>is Eq                                                                                                               | ation.<br>ual                                     |
| The Control Unit<br>(Cont.) | A single internal counter is provided for<br>loop control, this is part of the control<br>section, and is shown in Figure 1b. If a<br>FORLOOP is executed the loop counter is<br>loaded and the instructions within that<br>loop are executed until the counter has<br>decremented to zero. The loading of this<br>counter is transparent to the designer in<br>the respect that the FORLOOP instruction<br>automatically performs loading and counting.<br>A fifteen level stack is incorporated to hold<br>the return address of the main program<br>when a subroutine call or interrupt service<br>routine is being executed. The address of<br>the next sequential instruction to be<br>executed is pushed onto the stack. The<br>stack is also used for LOOP NESTING.<br>There is only one loop counter in the | are poss<br>of the lo<br>when th<br>is enteres<br>stack is<br>back int<br>its origin<br>become<br>the sixte<br>interrup<br>To enab<br>called th<br>in the m<br>contents<br>to that of<br>interrup<br>debuggi<br>service | op cou<br>e next<br>ad. Whe<br>popped<br>to the lo<br>al cont<br>s full a<br>en bit<br>level 7<br>le a de<br>the brea<br>icrocod<br>of the b<br>f the b<br>level s<br>ng pur | nter is<br>subse-<br>en lea<br>d to re<br>oop co<br>ents. '<br>status<br>status<br>' is ge<br>buggin<br>kpoint<br>le sec<br>progr<br>reakpo<br>six is gooses | s save<br>quent<br>ving til<br>turn t<br>unter<br>When<br>flag<br>regis<br>enerate<br>regis<br>tion. V<br>am co<br>pint re<br>genera<br>a leve | d in t<br>loop<br>he loc<br>thus<br>the s<br>STKF<br>ter an<br>ed.<br>illity a<br>ter is<br>When<br>punter<br>egister<br>ated. I<br>el six | he sta<br>in the<br>pp the<br>d cour<br>prese<br>ttack<br>is se<br>d an<br>regis<br>incluc<br>the<br>is eq<br>an<br>For<br>interru | ick<br>next<br>rving<br>t in<br>ter<br>led<br>ual |
| Host Interface              | PAC1000 but nested FORLOOP instructions<br>The host interface section has been<br>designed to easily integrate into a CPU<br>based system. When the PAC1000 is used<br>in the peripheral mode, the flow of data or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | comma<br>achieve<br>micropr<br>read RI                                                                                                                                                                                  | nds to<br>d throu<br>ocesso                                                                                                                                                  | its inte<br>gh an<br>r signa                                                                                                                                 | ernal r<br>intern<br>als of                                                                                                                    | egiste<br>al FIF<br>chip                                                                                                                   | ers ma<br>O. Sta<br>select                                                                                                         | ay be<br>Indaro<br>CSB                            |

# *Host Interface (Cont.)*

RD and WR) are accompanied by a sixteen bit Host Data and a six bit Host Address bus. Table 3 gives the conditions governing the mode setting for both standalone and peripheral mode. The logic condition of HDSEL0 and HDSEL1 in the control register will determine the mode of the PAC1000 operation. Bit positions in this register can be set or reset under program control.

A detailed block diagram of the PAC1000 is given in Figure 2 which illustrates the internal structure of the control section, processor section and interface. Data flow from the host processor data inputs HD0-HD15 to the internal 16-bit bus can be achieved through the FIFO section. The FIFO is eight locations deep and twentytwo bits wide. To transfer data words to the registers in the CPU section the host processor uses the chip select, write and HAD inputs. The address of the register is set up on the five HAD lines (this selects one of 32 registers) then the write and chip select lines are driven LOW. The data on the HD lines plus the register address is loaded into the FIFO. An additional bit called the FICD bit is loaded through HAD5 at the same time as address HAD[0-4] and the host data lines HD[0-15]. This is the FIFO Command/Data bit and must be LOW to signify that the sixteen bit word on HD[0-15] is data. If it is set HIGH, the least significant ten bits of that data will be used as an address pointer to the microcoded EPROM. In this way the host system can direct PAC1000 processing to a defined microcoded address. This is a

powerful feature that enables dynamic context switching of PAC1000 under supervision of the host processor. The FIFO exception flag FIXP will be set if the information residing in the FIFO was misdirected (if it were treated as a control word when the FICD flag labeled it as data or if the opposite condition prevailed).

Using the FIFO is the only method in which the host can communicate with the PAC1000 using the active LOW chip select CSB and the write input WRB. The DOR and DIR are Data Output and Data Input registers and are available to convey data to and from the internal sixteen bit bus but do not respond to CSB and WRB. The DIR would be used in a synchronous system because, when it is enabled by setting the DIREN flag (see Table 4), data is latched on the rising edge of each clock signal. The data contents of the DOR register may be directed to the host data outputs if all inputs CSB, WRB and RDB are inactive and HDSEL0 and HDSEL1 are 1 and 0 respectively, see Table 3. The use of the DIR and DOR register is intended more for synchronous communication whereas the FIFO is intended primarily for asynchronous systems or synchronous peripheral interface. The flags FIIR and FIOR are the FIFO Input Ready and FIFO Output Ready respectively, these flags can be tested so no overwriting of data will occur. Figure 3 shows the I/O Port and Special Functions. The FIIR register can be directed to the output I/O7 through a multiplexer so it can be tested externally by the host system.

| HDSELO | HDSEL1 | <u>CS</u> | RD | WR | HAD5 | HAD[0-4]            | HD[15-0] | <b>OPERATION</b>             |
|--------|--------|-----------|----|----|------|---------------------|----------|------------------------------|
| 0      | 0      | 0         | 1  | 0  | 0    | Register<br>Address | Data     | Write Data to FIFO           |
| 0      | 0      | 0         | 1  | 0  | 1    | х                   | Command  | Write Command<br>to FIFO     |
| 0      | 0      | 0         | 0  | 1  | 0    | 00100               | Х        | Reset FIFO                   |
| 0      | 0      | 0         | 0  | 1  | 0    | 00011               | Х        | Reset Status Register        |
| 0      | 0      | 0         | 0  | 1  | 0    | 00010               | x        | Read Program<br>Counter      |
| 0      | 0      | 0         | 0  | 1  | 0    | 00001               | Х        | Read Status Register         |
| 0      | 0      | 0         | 0  | 1  | 0    | 00000               | x        | Read Data Output<br>Register |
| 1      | 0      | 1         | 1  | 1  | Х    | Х                   | Х        | Data Output Register         |
| 0      | 1      | 1         | 1  | 1  | Х    | Х                   | Х        | Status Register              |
| 1      | 1      | 1         | 1  | 1  | Х    | Х                   | Х        | Program Counter              |

*Table 3. Host Interface Function Table* 

# Figure 2. PAC1000

# Detailed

Block Diagram







4

| Table 4.       |          |
|----------------|----------|
| <b>Control</b> | Register |

| CTRL9                                                                 | CTRL8                                                                                                            | CTRL7      | CTRL6       | CTRL5      | CTRL4 | CTRL3 | CTRL2 | CTRL1 | CTRL0 |
|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------|-------------|------------|-------|-------|-------|-------|-------|
| ASEL                                                                  | AIREN                                                                                                            | DIREN      | HDSEL1      | HDSEL0     | ADOE  | HADOE | HDOE  | BCEN  | ACEN  |
|                                                                       |                                                                                                                  |            |             |            |       |       |       |       |       |
| ASEL                                                                  | ASEL — Selects Which Source Will Write to the Address Bus<br>1 = Address Counter. 0 = Address Output Register.   |            |             |            |       |       |       |       |       |
| AIREN                                                                 | AIREN — Enables/Disables Writing to the Address Input Register by the Address Bus.<br>1 = Enabled. 0 = Disabled. |            |             |            |       |       |       |       |       |
| DIREN                                                                 | DIREN — Enables/Disables Writing to the Data Input Register.<br>1 = Enabled. 0 = Disabled.                       |            |             |            |       |       |       |       |       |
|                                                                       | HDSEL1<br>HDSEL0 — Decoded to Select Which Source Will be Connected to the Host Data Bus<br>(See Table 3.).      |            |             |            |       |       |       |       |       |
| ADOE — Selects Direction of the Address Bus<br>1 = Output. 0 = Input. |                                                                                                                  |            |             |            |       |       |       |       |       |
| наро                                                                  | E 94                                                                                                             | alacte Dir | oction of I | Host Addre |       |       |       |       |       |

| HADOE | <br>Selects Direction of Host Address Bus (HAD).<br>1 = Output. 0 = Input.                 |
|-------|--------------------------------------------------------------------------------------------|
| HDOE  | <br>Selects Direction of Host Data Bus for Next Clock Cycle.<br>1 = Output. 0 = Input.     |
| BCEN  | <br>Enables/Disables Block Counter Before Next Clock Edge.<br>1 = Enabled. 0 = Disabled.   |
| ACEN  | <br>Enables/Disables Address Counter Before Next Clock Edge.<br>1 = Enabled. 0 = Disabled. |

# Central Processing Unit

The section that deals with data processing is the central processing unit. This comprises a sixteen bit wide ALU with a 32 × 16 bit register file. One other special purpose register Q and an R shifter circuit make up this section. The Q register is sixteen bits wide and can be used for data shifting. Figure 4 shows the ALU and register structure of the CPU section. The ALU is in the path of the register outputs such that arithmetic and logic functions may be executed on the contents of any one of the 32 general registers. The output of the ALU passes data back to the selected register through the R shifter. In this logic circuit, data may be shifted either left or right, one position, before being written back into the register file. The output of the ALU can also drive data to registers such as the DOR register. A multiplexer can select either the ALU or the R0-R31 register output. The loop counter LC can be loaded from this multiplexer enabling the contents of a register to determine how many program loops are to be executed. This loop counter can be loaded from the EPROM to

give a fixed number of loops or from a register at program 'run time.' In this event, the number of times a loop is executed can be made programmable. Other registers on this bus are AOR. Address Output Register, the IOR, Input Output Register, the ACL and ACH low and high address counters and the BC Block Counter. The ACL counter has a six bit resolution and the ACH counter has sixteen. When enabled by ACEN, the ACH counter will increment on the rising edge of each clock cycle. The default value is for a sixteen bit count. To enable a twentytwo bit count where the ACL takes on the six least significant of the twenty-two bits. The ACS22 flag must be set, to enable the clocking of these counters. This is transparent to the software because once enabled the counters will clock at the system clock rate. However, they can be turned on and off from the microcoded instruction of enable SET ACEN, or disable RESET ACEN, also counting can be influenced by register loading.



#### PAC1000 — Application Note 010

# Support Software

The PAC1000 device is supported with development software that can run in an IBM PC/XT or AT computer. The main tools that the designer will use are the assembler, the linker and the simulator. These support programs are run from a WSI menu called WISPER that has been designed to make software development a simple process. The designer can select the assembler from the menu and assemble his source program. After assembly the program must be linked. The linker program is designed for those system designers who build their software up from a number of modules. Figure 5 illustrates the flow from original source code entry through the linker to a simulated output. The linker will take these modules and combine them into one object program. On completion of assembly and linking the program may be checked by the simulator. The use of the simulator removes the need for EPROM programming and in-circuit testing during the design cycle and gives the designer a fairly high level of confidence that the program will function as intended. The simulator will take the bit pattern format that was generated during assembly and apply a command and stimulus file to the program. The result will be a series of waveforms that appear on the screen of the PC and is similar to that of a logic analyzer display. A table of vectors is also generated for those signals that are traced from the command file. These vectors can be printed out for analysis and verification.



# Microcoded EPROM Section

A further aid to the design entry is the ability to mix high level, assembler and microcode mneumonics so designers can use the entry level that they feel the most comfortable with. Most of the applications example given below are written in a high level 'C' like language but some assembler instructions are also incorporated.

In systems applications such as Direct Memory Access (DMA), it is required to output the contents of a counter to address memory and then increment it. This is implemented in the PAC1000 high level language syntax as:

AOR := R0 ; /\*CONTENTS OF R0 GOES INTO THE AOR\*/

R0 := ++R0 ; /\*REGISTER R0 IS INCREMENTED BY ONE\*/

For efficiency these two instructions may be combined into one line of code, which is executed in one clock cycle:

AOR := R0 := ++ R0 ; /\*COMBINING THE TWO OPERATIONS\*/

The contents of R0 will be passed to the Address Output Register and will be incremented by the ALU.

Where AOR is the address output register and R0 is one of the thirty-two, 16-bit general purpose registers. The '/\*' symbol delimits the comment field boundary.

With a PAL/EPLD/PGA approach the designer would be required to spend much valuable time configuring a loadable binary counter, with a 3-State output capability.

In applications such as digitizer/plotter systems, x,y coordinates have to be quickly summed or subtracted many times to register cursor movements and position. This requires repetitive arithmetic operations. In this application vector addition on two or more sixteen bit words can be defined as two instructions:

R0 := R0 + R1; AOR := R0;

Combining these instructions together: AOR := R0 := R0 + R1 ; With conventional programmable logic an ALU function would have to be designed or a dedicated custom chip used with the programmable logic part used as the data I/O controller. The key point of this issue is that complex logic functions are simply written as a few single lines of statements. Moreover, a combination of functions may be grouped in a single line. These include a microcontrol directive such as a branch, call to subroutine or JUMP on condition. an ALU function such as increment or add, and an output control command. There are sixteen output control lines which can be driven active on each clock cycle. The composite of the three commands are:

LABEL: JMPNC CC7 LABEL , R0 := R0 + 1 , OUT 'HOLD' ;

The function of this line of code would be to wait until the condition code input of CC7 went active before the next instruction is executed. At the same time the contents of R0 would be incremented and the output control lines would be driven with a sixteen bit code called HOLD. An equates option 'equ' is used to define uniquely a sixteen bit pattern called HOLD. The assembler encodes an equate statement to allow meaningful words to be used in output control statements. Some examples of this are:

HOLD equ H'FFFF' ; /\* HOLD IS SET AS HEX FFFF \*/

ENBL equ H'EFFF' ; /\* ENBL IS SET AS HEX EFFF \*/

The equates directive should be declared at the start of the program before any actual code is written.

| Applications<br>Programs | The depth of the microcontrol sto<br>of 64-bit wide words. One 64-bit i<br>is executed on each clock cycle.<br>instruction word is subdivided into<br>command to the processor section<br>next address command to the mi<br>memory. Figure 1a shows the Ins<br>Register with its contents of control<br>and CPU commands. The control<br>also respond to condition code in<br>interrupts. An example of output of<br>and response to condition codes<br>handshake loop. The output stimu<br>be to set one of the control output | nstruction condition code input CC[7:0]. Under<br>The program control a conditional JUMP to a<br>location could result if the bit tested were<br>set. Otherwise linear programming could<br>continue.<br>The first applications program below<br>demonstrates the use of condition code<br>zero CC0 to test for a start condition.<br>Unit will<br>puts and<br>control<br>is in a<br>Jus can |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| segme                    | nt pacdes01 :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                              |
| /* CO<br>/* WO           | NTENTS OF R1.RO: R3.R2 T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PRECISION ADDITION ON THE REGISTER*/<br>HE CARRY OF THE LEAST SIGNIFICANT */<br>IN THE CP REGISTER AND IS USED IN*/<br>BIT ADDITION. */<br>*/                                                                                                                                                                                                                                                |
| /*                       | PIN FUNCTIONA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | L DESIGNATIONS. */                                                                                                                                                                                                                                                                                                                                                                           |
| /*                       | INPUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                              |
| /*<br>/*                 | CCO - ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | */<br>HIGH - START 32-BIT ADDITION */                                                                                                                                                                                                                                                                                                                                                        |
| /*                       | /CS - ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LOW - PAC1000 CHIP SELECT */                                                                                                                                                                                                                                                                                                                                                                 |
| /*<br>/*                 | /RD - ACTIVE<br>HAD[5:0] - IN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                              |
| /*                       | HOST INTERFAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                              |
| /*                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | */                                                                                                                                                                                                                                                                                                                                                                                           |
| HOLD:                    | JMPNC CCO HOLD :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /*WAIT FUR START CONDITION */                                                                                                                                                                                                                                                                                                                                                                |
|                          | RO := H'F830' ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | /*LOAD REGISTERS WITH DATA */                                                                                                                                                                                                                                                                                                                                                                |
|                          | R1 := H'982F' :<br>R2 := H'A309' :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | /*RO AND R2 CONTAIN THE */<br>/*LEAST SIGNIFICANT WORD OF */                                                                                                                                                                                                                                                                                                                                 |
|                          | R3 := H'4500' ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | /*THE 32 BIT LONG WORD AND */                                                                                                                                                                                                                                                                                                                                                                |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | /*R1 AND R3 CONTAIN THE MOST*/<br>/*SIGNIFICANT WORD */                                                                                                                                                                                                                                                                                                                                      |
|                          | R5 := R1 ;<br>R4 := R0 :<br>DOR := R0 :=<br>R1 := R1 + R3                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R0 + R2 : /*LOAD DOR REGISTER*/                                                                                                                                                                                                                                                                                                                                                              |
| LOCF 1                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <pre>+ CF : /* WAIT FOR HOST TO READ DOR */</pre>                                                                                                                                                                                                                                                                                                                                            |
| _                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | /* LOAD MOST SIG WORD INTO DOR */                                                                                                                                                                                                                                                                                                                                                            |
| LOOP2                    | : JMPNC DOR LOOP2 :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | /* WAIT FOR HOST TO READ DATA */                                                                                                                                                                                                                                                                                                                                                             |
| FIN:                     | JMP HOLD :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | /*END OF THE CYCLE*/                                                                                                                                                                                                                                                                                                                                                                         |
| end ;                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                              |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                              |

4-24 WAFERSCALE INTEGRATION, INC.

4

| Applications<br>Programs<br>(Cont.) | The program adds the contents of R0 and<br>R2, then R1 and R3 and the CARRY bit.<br>In the next design example, double                                                                                                 | into the registers by the series of<br>instructions:<br>FOR 3 ; /*EXECUTE THE LOOP                                                                                                                                                             |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (cont.)                             | precision subtraction is performed and this                                                                                                                                                                            | FOUR TIMES*/                                                                                                                                                                                                                                   |
|                                     | time the CY flag will hold the borrow bit.<br>This design example is more practical than<br>the example above because instead of                                                                                       | RdFifo ; /*UNPACK DATA FROM<br>THE FIFO*/                                                                                                                                                                                                      |
|                                     | performing arithmetic on fixed values the register file may be loaded from a source.                                                                                                                                   | ENDFOR ; /*END THE FORLOOP */                                                                                                                                                                                                                  |
|                                     | The configuration of the PAC1000 is in the<br>peripheral mode and data is loaded into<br>the FIFO. CC0 is monitored and, when<br>active, is a signal to the PAC1000 that data<br>has been loaded. The FIFO is unloaded | This section of the program performs a read operation on the FIFO four times. In any FORLOOP N, where N is an integer value, the number of times the loop is executed is $N + 1$ times.                                                        |
| segmen                              | t pacdes02 :                                                                                                                                                                                                           |                                                                                                                                                                                                                                                |
| /*CONT                              | RAM TO PERFORM DOUBLE PRECISIO<br>ENTS R1, R0 ; R3, R2 THE BORRO<br>EGISTER DURING THE SECOND HALF                                                                                                                     | W FLAG IS CONTAINED IN THE */                                                                                                                                                                                                                  |
| /*                                  | PIN FUNCTIONAL DESIGNATIONS                                                                                                                                                                                            | */                                                                                                                                                                                                                                             |
| /*<br>/*                            | INPUTS                                                                                                                                                                                                                 | */                                                                                                                                                                                                                                             |
| /*<br>/*                            | CCO - ACTIVE HIGH - START PR<br>/CS - ACTIVE LOW - PAC1000                                                                                                                                                             |                                                                                                                                                                                                                                                |
| /*                                  | /WR - ACTIVE LOW - FIFO WRI                                                                                                                                                                                            |                                                                                                                                                                                                                                                |
| /*<br>/*                            | <pre>/RD - ACTIVE LOW - READ A F<br/>HAD[5:0] - INPUTS TO SELECT</pre>                                                                                                                                                 | REGISTER FROM HOST INTERFACE*/<br>A REGISTER FROM THE HOST */                                                                                                                                                                                  |
| /*                                  | INTERFACE                                                                                                                                                                                                              |                                                                                                                                                                                                                                                |
| /*<br>/*                            | HD[15:0] — DATA INPUTS TO FI                                                                                                                                                                                           | FO THROUGH HOST INTERFACE */<br>*/                                                                                                                                                                                                             |
| HOLD:                               | FOR 3 : /*THE FOU<br>RDFIFO : /*LOADED<br>ENDFOR : /*SECTION<br>R5 := R1 :<br>R4 := R0 :                                                                                                                               | DR START CONDITION EMPTY */<br>JR LOCATIONS OF THE FIFO */<br>THROUGH THE HOST INTERFACE */<br>OF THE PAC1000 */<br>/*SAVE R1 CONTENTS IN R5*/<br>/*SAVE R0 CONTENTS IN R4*/<br>2 : /*SUBTRACT LSW PROPAGATE*/<br>* /*THE BORROW INTO THE CF*/ |
|                                     | DOR := RO :                                                                                                                                                                                                            | /*LOAD DOR WITH MSW */                                                                                                                                                                                                                         |
| L00P1:                              | JMFNC DOR LOOF1 :                                                                                                                                                                                                      |                                                                                                                                                                                                                                                |
|                                     | DOR := R1 :                                                                                                                                                                                                            | /*LOAD DOR WITH MSW */                                                                                                                                                                                                                         |
| L00P2:                              | JMPNC DOR LOOP2 :                                                                                                                                                                                                      |                                                                                                                                                                                                                                                |
| end:                                | JMP HOLD :                                                                                                                                                                                                             | /*END OF PROGRAM */                                                                                                                                                                                                                            |

#### PAC1000 — Application Note 010

| Applications<br>Programs<br>(Cont.) | The next program shows a multiply routin.<br>Although there is no dedicated multiplier<br>in the PAC1000, multiplication can be<br>achieved by shifting and adding. The MU<br>instruction is a MACRO command that is<br>expanded when assembled into a loop of<br>shift and add instructions. The RDFIFO                                                                                                             | the host to the PAC, which is configured<br>as a peripheral. In the example the contents<br>of R0 and R1 are multiplied and the product<br>is available in registers R1 and R2, where                      |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| segment                             | pacdes03 :                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                            |
| HOLD:                               | FOR 1 : /*THE TW<br>RDFIFO : /*LOADED                                                                                                                                                                                                                                                                                                                                                                                | OR START CONDITION EMPTY*/<br>D LOCATIONS OF THE FIFO */<br>THROUGH THE HOST INTER-*/<br>SECTION OF THE PAC1000 */                                                                                         |
| LOOP1:                              |                                                                                                                                                                                                                                                                                                                                                                                                                      | STER. THE PRODUCT IN THE */<br>OUTPUT REGISTER */<br>/* */                                                                                                                                                 |
| SELF:<br>end:                       | JMP HOLD ;                                                                                                                                                                                                                                                                                                                                                                                                           | /*END OF PROGRAM */                                                                                                                                                                                        |
|                                     | In the following example, the contents of registers R2 and R1 is divided by the contents of register R0. The most significat word of the 32-bit long word is held in                                                                                                                                                                                                                                                 | register R2 and the least significant 16 bits<br>are stored in R1. The result of the divide<br>operation leaves the quotient in the Q<br>register and any remainder in register R2.                        |
| segment                             | pacdes04 ;                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                            |
| HOLD:                               | FOR 1 :       /*THE 1         RDF1F0 :       /*LOADE         ENDF0R :       /*-FACE         DIV R2 R1 R0 :       .                                                                                                                                                                                                                                                                                                   | FOR START CONDITION EMPTY*/<br>TWO LOCATIONS OF THE FIFO */<br>ED THROUGH THE HOST INTER-*/<br>E SECTION OF THE PAC1000 */                                                                                 |
| LOOP1:                              | DOR := Q ;<br>JMPNC DOR LOOP1 ;<br>DOR := R2 :                                                                                                                                                                                                                                                                                                                                                                       | /*OUTPUT THE REMAINDER*/ /*OUTPUT THE QUOTIENT. */                                                                                                                                                         |
| SELF:<br>end;                       | JMP SELF ;                                                                                                                                                                                                                                                                                                                                                                                                           | /*END OF PROGRAM */                                                                                                                                                                                        |
|                                     | The files generated so far can be entered<br>into the assembler and two files<br><filename>.LIS and <filename>.OB may<br/>be generated as shown in Figure 5. The<br/>latter object file must be linked before the<br/>final object file is available for programmir<br/>into the PAC1000's EPROM. The link<br/>program <filename>.ML performs this<br/>function and is shown below.</filename></filename></filename> | <filename>.STL and <filename>.CMD. The<br/>latter two files are the input stimulus file<br/>and the input command file (see Figure 5).<br/>The stimulus file is used to drive inputs</filename></filename> |

load pacdes04 ; place pacdes04; end :

This design example only used one program but many sub-modules may be linked together to form a single executable program. It is possible to simulate the design after linking. The necessary inputs

of the stimulus file and command file are given below. The command file shown below will instruct

the simulator to set an output trace on the Current value of the Program Counter, CPC. The Condition Code zero input, the write, and the chip select lines are also traced. The simulator also enables a trace to be invoked on registers as well as input

**Applications** Programs (Cont.)

or output pins. The Q register is traced along with host data. loop counter, and registers R0, R1, and R2. The final trace is set on the host data output register. At the end of the stimulus file, the run instruction

informs the simulator to run the driving signals for 140 cycles. The final instruction invokes a View Trace Waveform instruction. so the waveforms may be observed on the PC screen.

OPEN STIMULUS PACDES04 SET TRACE CPC SET TRACE CCO SET TRACE WRB SET TRACE CSB SET TRACE RDB SET TRACE 0 SET TRACE HD SET TRACE LC SET TRACE RO SET TRACE R1 SET TRACE R2 SET TRACE HDOR OPEN TRACE PACDES04 **RUN 140** VTW

The stimulus file is used to apply active signals to inputs of the design. At specific time points conditions are established. For example the statement:

.S CC0 0@1 1 @40

means that the input condition code zero

.S RESETB 0 @ 1 1 @ 2 :

CC0 should become a logic state LOW at time point one and a logic HIGH condition 40 cycles later. A three-state condition can be applied by typing the letter Z in place of logic '1' or '0.' The stimulus file is completed to drive all inputs and applied to the simulator during run time.

.S CCO 0@1 1@40 : .S WRB 1@1 0@2 1@8 0@12 1 @19 ; .S CSB 101 002 109 0011 1018 00120 10129 00131 10139 ; .S RDB 101 00121 10129 00131 10139 : .S HADO 0@1 1@10 0@24 : .S HAD1 0@1 : .S HAD2 0@1 : .S HAD3 0@1 : .S HAD4 0@1 : .S HAD5 0@1 : # WRITE A 7 INTO RO AND 31 INTO R1 .S HDO 0@1 1@10 Z@70 : .S HD1 1@1 Z@70 ; .5 HD2 0@1 1@10 Z@70 ; .S HD3 0@1 1@10 Z@70 : .S HD4 0@1 1@10 Z@70 : .S HD5 0@1 Z@70 : .5 HD6 0@1 Z@70 ; .S HD7 0@1 Z@70 : .S HD8 0@1 Z@70 : .S HD9 0@1 Z@70 : .S HD10 0@1 Z@70 ; .S HD11 0@1 Z@70 : .S HD12 0@1 Z@70 : .S HD13 0@1 Z@70 : .S HD14 0@1 Z@70 2 .5 HD15 0@1 Z@70 ;

The comment field is denoted by a '#' sign.

| Case Statement<br>Logic | The ability of the PAC1000 to perform case<br>statement logic has already been discussed<br>but the following program excerpt illustrates<br>how to encode the case statement. The<br>program will execute when condition code<br>7 is active high, then case group CG0 is<br>tested for one of sixteen possible states. CG0 comprises CC0, CC1, CC2 and CC3.<br>Sixteen registers are initialized and the<br>output code is driven with zero. When CC7<br>goes HIGH the CG0 input is tested and<br>the register contents that are equal to the<br>state of the CG0 input is transferred to the<br>AOR outputs. |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | segment pacdes05 :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                         | /* illustrate the use of multiway branching */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                         | R0 := 0 :<br>R1 := 1 :<br>R2 := 2 :<br>R3 := 3 :<br>R4 := 4 :<br>R5 := 5 :<br>R6 := 6 :<br>R7 := 7 :<br>R8 := 8 :<br>R9 := 9 :<br>R10 := 10 :<br>R11 := 11 :<br>R12 := 12 :<br>R13 := 13 :<br>R14 := 14 :<br>R15 := 15 :<br>WHILE CC7 :<br>SWITCH CG0 :<br>CASE 0 , GOTO NEXT . AOR := R0 :<br>CASE 1 . GOTO NEXT . AOR := R1 :<br>CASE 2 . GOTO NEXT . AOR := R2 :<br>CASE 3 . GOTO NEXT . AOR := R3 ;<br>CASE 4 . GOTO NEXT . AOR := R4 ;<br>CASE 5 . GOTO NEXT . AOR := R5 ;<br>CASE 6 . GOTO NEXT . AOR := R6 ;                                                                                             |
|                         | CASE 7 , GOTO NEXT , ADR := R7 ;<br>CASE 8 , GOTO NEXT , ADR := R8 ;<br>CASE 9 , GOTO NEXT , ADR := R9 ;<br>CASE 10 , GOTO NEXT , ADR := R10 ;<br>CASE 11 , GOTO NEXT , ADR := R11 ;<br>CASE 12 , GOTO NEXT , ADR := R12 ;<br>CASE 13 , GOTO NEXT , ADR := R13 ;<br>CASE 14 , GOTO NEXT , ADR := R14 ;                                                                                                                                                                                                                                                                                                          |
|                         | CASE 15 . GOTO NEXT , AOR := R15 ;<br>ENDSWITCH ;<br>NEXT : OUT O ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                         | ENDWHILE ;<br>OUT h'FFFF' ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                         | LOOPX :<br>GOTO LOOPX ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                         | end ;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*Simple DMA Controller for Memory to Memory Transfer* 

The software designs discussed so far have been based on arithmetic functions but an important feature of how to use the FIFO in the host interface section of the PAC1000 for the communication of data will enable the reader to develop ideas into more complex programs. The FIFO Output Ready flag is used in a loop to read the data into the registers. The output codes are used to create signals to control read, write, latch, output enable and bus acknowledge signals. A summary of these signals is given in Table 5 each time an instruction is executed. These signals are generated to accompany the memory addresses which control the DMA cycle.

Figure 6a shows a generic system solution where the PAC1000 sits on the address and data bus of a microprocessor and memory interface. The PAC1000 is mapped into the system with a PLD decoder and an external latch is used to catch data on read and write cycles. It is possible to use the internal DIR and DOR for this purpose but a faster solution would use an external component. Also, if the bus were greater than sixteen bits, an external latch would be required. This mode where data does not enter the PAC1000 device is called the 'fly by' mode.

Figure 6b shows the timing waveform derived from the program simulation. Active LOW WRB and CSB inputs to ADD1, ADD2 and ADD3 will write to the registers. The Source Address Register R0, the Destination Address Register R1 and the transfer counter R2 are all loaded through the FIFO. At time point 1, the registers become loaded. At time 2, CC7 is set HIGH to indicate transfer can commence. The response from the PAC1000 is an active LOW output from output control OC14 to inform the microprocessor that DMA activity is taking place. This occurs at time point 3. OC14 stays LOW during DMA activity but goes HIGH after the transfer is complete (at time point 4). Three transfers have taken place and the microprocessor is free to regain control of the bus.

segment pacdes06;

/\*THE PROGRAM ILLUSTRATES A SIMPLE DMA DESIGN WHICH \*/ /\*READS THE DATA FROM SUCCESSIVE MEMORY LOCATIONS \*/ /\*ADDRESSED BY THE CURRENT CONTENTS OF RO THEN WRITES\*/ /\*THAT DATA TO LOCATIONS ADDRESSED BY THE CONTENTS \*/ \*/ /\*OF R1. BOTH REGISTERS ARE INCREMENTED AFTER THE /\*READ/WRITE CYCLE. R2 IS A TRANSFER COUNTER THAT IS **\*/** /\*DECREMENTED AFTER EACH TRANSFER. WHEN R2 IS ZERO **\*/** /\*ALL TRANSFER ACTIVITY CEASES AND A NEW DEVICE WAITS\*/ /\*FOR A NEW DMA CYCLE. \*/

| /*<br>/*                   | PIN FUNCTIONAL DESIGNATIONS.<br>OUTPUTS.                                                                                                                                                                                                             | */<br>*/                   |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| /*<br>/*<br>/*<br>/*<br>/* | OC15 - LATCH ENABLEACTIVE LOW.<br>OC14 - BUS TAKENACTIVE LOW.<br>OC13 - WRITE ENABLEACTIVE LOW.<br>OC12 - READ ENABLEACTIVE LOW.<br>OC11 - LATCH OUTPUT ENABLEACTIVE LOW.<br>AOR - 16 BIT ADDRESS OUTPUTACTIVE TRUE.                                 | */<br>*/<br>*/<br>*/<br>*/ |
| /*                         | INPUTS.                                                                                                                                                                                                                                              | */                         |
| /*<br>/*<br>/*<br>/*       | CC7 - ACTIVE HIGH - INITIATE DMA ACTIVITY.<br>HD - ACTIVE TRUE - 16 DATA INFUTS.<br>HAD - ACTIVE TRUE - REGISTER ADDRESS INFUTS<br>/CS - ACTIVE LOW - PAC1000 SELECT<br>/WR - ACTIVE LOW - WRITE TO PAC1000 FIFD<br>/RD - ACTIVE LOW - READ NOT USED | */<br>*/<br>*/<br>*/       |
| /*                         | LIST OF EQUATES.                                                                                                                                                                                                                                     | */                         |
| READ                       | equ H'AFFF'; /*ACTIVE LOW READ,TRANSFER<br>/*ENABLE,AND BUS BUSY                                                                                                                                                                                     | */<br>*/                   |

4





Table 5. OutputConditionAssignmentCodes for theDMA ControllerApplication

|                                                                                                                                                                        | 0C15 | 0C14 | 0C13 | 0C12 | <b>OC11</b> | 0C10-0C0 |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|-------------|----------|--|
| INIT                                                                                                                                                                   | 1    | 1    | 1    | 1    | 1           | All High |  |
| READ                                                                                                                                                                   | 1    | 0    | 1    | 0    | 1           | All High |  |
| OENBL                                                                                                                                                                  | 1    | 0    | 1    | 1    | 0           | All High |  |
| WRITE                                                                                                                                                                  | 1    | 0    | 1    | 0    | 0           | All High |  |
| ENBLE                                                                                                                                                                  | 1    | 0    | 1    | 1    | 1           | All High |  |
| LATCH                                                                                                                                                                  | 0    | 0    | 1    | 0    | 1           | All High |  |
| OC15 = Active Low Latch Command<br>OC14 = Active Low DMA in Progress<br>OC13 = Active Low Write SignalOC12 = Active Low Read Signal<br>OC11 = Active Low Output Enable |      |      |      |      |             |          |  |

| LATCH         | equ                                                                     | H'2FFF';                                                                             | /*ACTIVE LOW READ,TRANSFER<br>/*ENABLE,LATCH ENABLE,AND                                                                                                                                                                                                                                                                  | */<br>*/                  |  |  |  |  |
|---------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|
| OENBL         | equ                                                                     | H'B7FF':                                                                             | /* BUS BUSY<br>/*ACTIVE LOW TRANSFER ENABLE<br>/*OUTPUT ENABLE,AND BUS<br>/* BUSY                                                                                                                                                                                                                                        | */<br>*/<br>*/            |  |  |  |  |
| WRITE         | equ                                                                     | H'97FF';                                                                             |                                                                                                                                                                                                                                                                                                                          |                           |  |  |  |  |
| INIT<br>ENBLE | equ                                                                     | H'FFFF':<br>H'BFFF':                                                                 | /*INITALIZE ALL OUTPUTS HIGH<br>/*ACTIVE LOW ENABLE TRANSFER<br>/*SIGNAL,AND BUS BUSY                                                                                                                                                                                                                                    | */<br>*/<br>*/            |  |  |  |  |
| /*            | PROGRAM START                                                           |                                                                                      |                                                                                                                                                                                                                                                                                                                          |                           |  |  |  |  |
|               | FOR 2 ;                                                                 | IOR HOLDO ;                                                                          | /*INITALIZE OUTPUT CODES TO CCO-1<br>/*SET THE ADDRESS BUFFERS INPUTS<br>/*SET READ FIFO LOOP TO 3<br>/*WAIT FOR ACTIVE FIOR FLAG<br>/*READ FIFO INTO THE REGISTER FILL<br>/*ALL THREE WORDS READ END LOOP                                                                                                               | */<br>*/<br>E*/           |  |  |  |  |
| HOLD1:        | JMPNC C<br>SET ADO                                                      | C7 HOLD1 ;<br>E ;                                                                    | /*ACTIVE CC7 BUSACK SIGNAL INPUT<br>/*SET ADDRESS BUFFER AS OUTPUT<br>/*FOR DMA CYCLES                                                                                                                                                                                                                                   |                           |  |  |  |  |
|               | AOR :=<br>RO := +<br>OUT LAT<br>OUT REA<br>AOR :=<br>R1 := +<br>OUT WRI | RO :<br>+ RO . OUT RE<br>CH :<br>D :<br>R1:<br>+ R1 , OUT OE<br>TE :<br>BL :<br>LE : | ENBLE :/*START DATA TRANSFERS<br>/*OUTPUT SOURCE ADDRESS<br>AD : /*OUTPUT ACTIVE READ<br>/*AND LATCH DATA ON READ<br>/*HOLD READ LINE ACTIVE<br>/*OUTPUT DESTINATION ADDRESS<br>NBL : /*ENABLE LATCH OUTPUT<br>/*PERFORM WRITE CYCLE<br>/*DISABLE WRITE BEFORE OE<br>/*END OF SINGLE TRANSFER<br>/*END OF TRANSFER CYCLE | */<br>*//<br>**//<br>**// |  |  |  |  |
| HALT:<br>end; | GOTO LO                                                                 | OP1 . OUT INI                                                                        | T : /*RETURN TO PROGRAM START                                                                                                                                                                                                                                                                                            | */                        |  |  |  |  |

FIFO DRAM Controller The next PAC1000 design example illustrates how to use the device as a FIFO DRAM Controller. See Figure 7a for device implementation.

If the DRAMs are 64K devices, only the least significant byte of the AOR register need be used (that is ADD0-ADD7). The system could easily be upgraded to handle 256K or 1M bit DRAMs by wiring in address bits A8 and A9 but additional PAC1000 software would need to be written to accommodate the FIFO status counter. About 45 lines of code are used to enable the PAC1000 to handle REFRESH, READ and WRITE activity. The design uses the output control lines to provide RAS, CAS and WRITE signals to the DRAM and additional signals to give busy status during read, write and refresh activity. The whole system responds to input condition codes CC0 and CC1 as RQWRITE request to write and RQREAD request to read respectively. During active read, write and refresh cycles, three signals BUSYWR. BUSYRD and BUSYRFSH which go active LOW an additional composite signal which

goes LOW when the FIFO is in any of these conditions. The system design also incorporates an UP/DOWN status counter which increments on write activity and decrements on read activity. This counter is tested to provide information to the outside world that the FIFO is full, empty or neither full or empty. The FULL, EMPTY and ACTIVE flags can be read from the IO0 and IO1 and give information to the outside world about the status of the FIFO.

The waveforms associated with read, write and refresh activity are shown in Figures 7b, 7c and 7d respectively. These waveforms were created from the PACDES08.OUT vector tables generated from the simulator. Table 6 illustrates the assignment of the output conditions which drive the various functions RAS, CAS, RFSH WR etc., It is recommended that high current buffer circuits be used to interface the outputs of the PAC1000 to the inputs of the memory chips used in both the DMA and FIFO applications.

segment pacdes08 :

#### /\*LIST OF EQUATES.\*/ /\*CONDITTION CODE OUTPUTS\*/

| RASW<br>RASR<br>RFSH<br>CASW<br>CASR<br>ENDWR<br>INIT | equ<br>equ<br>equ<br>equ<br>equ | H'55FF'<br>H'79FF'<br>H'7CFF'<br>H'15FF'<br>H'39FF'<br>H'35FF'<br>H'FFFF' | <br>/*WRITE RAS OUTPUT */<br>/*READ RAS OUTPUT */<br>/*REFRESH OUTPUT */<br>/*WRITE CAS OUTPUT */<br>/*READ CAS OUTPUT */<br>/*END OF WRITE OUPUT*/ |
|-------------------------------------------------------|---------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| ZERO<br>FULL<br>EMPTY<br>ACTVE<br>MAX                 | equ<br>equ                      | H'0000'<br>H'FD'<br>H'FE'<br>H'FF'<br>H'FFFF'                             | <br>/*ZERO COUNT*/<br>/*FULL FLAG */<br>/*EMPTY FLAG*/<br>/*ACTIVE */<br>/*MAX COUNT */                                                             |
| RQWRITE<br>RQREAD                                     | equ<br>equ                      | CCO :<br>CC1 :                                                            | /*REQUEST TO WRITE*/<br>/*REQUEST TO READ */                                                                                                        |

#### /\*PROGRAM START\*/

| START: OUT INIT; |   | /*INITALIZE OUTPUT CODES | 3 <b>*</b> / |
|------------------|---|--------------------------|--------------|
|                  |   | /*INITALIZE REGISTERS    | */           |
| R0 := H'0000'    | ; | /*ROW ADDRESS WRITE      | */           |
| R1 := H'0000'    | : | /*COLUMN ADDRESS WRITE   | <b>*/</b>    |
| R2 := H'0000'    | 7 | /*ROW ADDRESS READ       | */           |
| R3 := H'0000'    | Ę | /*COLUMN ADDRESS READ    | */           |
|                  |   |                          |              |

| FIFO DRAM<br>Controller | R4 := H'FFFF' ;<br>R5 := H'0000' :                                                                        | /*REFRESH COUNTER */<br>/*STATUS COUNTER */                                                                                                                                                                                        |
|-------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Cont.)                 | OUTPUT IOO IO1 :<br>SET ADOE , OUT INIT :                                                                 | /*SER IOO AND IO1 TO */<br>/*OUTPUT, ADOE INPUT */                                                                                                                                                                                 |
| L00P:                   | AOR := R4 ;<br>DUT RFSH ;<br>R4 := ++ R4 , OUT INIT ;                                                     | /*OUTPUT REFRESH CTR */<br>/*PERFORM REFRESH */<br>; /*INCREMENT RFSH CTR */<br>/*CLEAR OUTPUT */                                                                                                                                  |
| TEST:                   | ADR := RO , DUT INIT ;<br>R5 := ++ R5 ;<br>DUT RASW ;<br>ADP P1 ;                                         | /*IF REQUEST TO WRITE */<br>/*OUTPUT WRITE ADDR */<br>/*INCREMENT STATUS */<br>/*OUTPUT RAS WRITE */<br>/*OUTPUT CAS ADDR */<br>/*INCREMENT CAS ADDR */<br>/*OUTPUT CAS ADDR */<br>/*END WRITE CYCLE */<br>/*FINISH WRITE CYCLE */ |
|                         | IF R1 == 256 ;<br>R0 := ++ R0 ;<br>ENDIF ;                                                                | /*TEST FOR 256 COLUMNS*/<br>/*INCREMENT ROW */<br>/*IF 256 */                                                                                                                                                                      |
|                         | AOR := R2 , OUT INIT :<br>R5 := R5 ;<br>OUT RASR ;<br>AOR := R3 ;<br>R3 := ++ R3 . OUT CASR<br>OUT CASR ; | /*IF REQUEST TO READ */<br>/*OUT ROW READ ADDRESS*/<br>/*DECREMENT STATUS */<br>/*OUTPUT RAS READ */<br>/*OUTPUT CAS ADDRESS */<br>;/*INCREMENT CAS ADD */<br>/*STRETCH CAS */<br>/*FINISH READ CYCLE */                           |
|                         | R2 := ++ R2 :                                                                                             | /*TEST FOR 256 COLUMNS*/<br>/*INCREMENT ROW */<br>/*IF EQUAL TO 256 */                                                                                                                                                             |
|                         | IF Z ;<br>IOR := FULL ;                                                                                   | /*SAVE STATUS COUNTER */<br>/*TEST FOR MAX COUNT */<br>/*IF MAXIMUM */<br>/*SET OUTPUT FULL FLAG*/<br>/*GOTO REFRESH LOOP */<br>/*END TEST */                                                                                      |
|                         | R6 := R5 ;<br>R6 := ZERO - R6 ;<br>IF Z ;<br>IOR := EMPTY ;<br>GOTO START;<br>ENDIF ;                     | /*SAVE STATUS COUNTER */<br>/*TEST FOR ZERO COUNT */<br>/*IF ZERO */<br>/*SET EMPRY FLAG */<br>/*RESTART PROGRAM */<br>/*ELSE */                                                                                                   |
| end;                    | IOR := ACTVE ;<br>GOTO LOOP ;                                                                             | /*THE SYSTEM IS NOT */<br>/*FULL OR EMPTY */                                                                                                                                                                                       |

#### PAC1000 — Application Note 010

| Table 6. Output          |                                               | 0C15                              | 0C14                                     | 0C13      | 0C11 | 0C10 | 0C9 | 0C8 | <i>0C12, 0C7-0C0</i> |
|--------------------------|-----------------------------------------------|-----------------------------------|------------------------------------------|-----------|------|------|-----|-----|----------------------|
| Condition<br>Assignment  | INIT                                          | 1                                 | 1                                        | 1         | 1    | 1    | 1   | 1   | All High             |
| Codes for the            | RASW                                          | 0                                 | 1                                        | 0         | 1    | 0    | 1   | 0   | All High             |
| PAC FIFO DRAM            | CASW                                          | 0                                 | 0                                        | 0         | 0    | 1    | 0   | 1   | All High             |
| <b>Controller Design</b> | ENDW                                          | 0                                 | 0                                        | 1         | 0    | 1    | 0   | 1   | All High             |
| ·                        | RASR                                          | 0                                 | 1                                        | 1         | 1    | 0    | 0   | 1   | All High             |
|                          | CASR                                          | 0                                 | 0                                        | 1         | 1    | 0    | 0   | 1   | All High             |
|                          | RFSR                                          | 0                                 | 1                                        | 1         | 1    | 1    | 0   | 0   | All High             |
|                          | OC14 =<br>OC13 =<br>OC11 =<br>OC10 =<br>OC9 = | Active L<br>Active L<br>Active Lo | ow CAS<br>ow Write<br>ow BUSN<br>ow BUSN | WR<br>(RD |      |      |     |     |                      |



# Figure 7b.



In response to a request to read one early write cycle will take place.  $\overline{RAS}$  will latch in the row address and the WE line goes low. The column address is set up followed by the falling edge of  $\overline{CAS}$ . The WE input is taken inactive followed by  $\overline{RAS}$  and  $\overline{CAS}$ . During the whole cycle the busy signal is active.





| Programmable ,<br>UART | The PAC1000 contains no UART for serial data but parallel to serial conversion is possible through the Q register and I/O Port 2 and 3. The following program illustrates the designer how to create a UART function in the PAC1000 with about 40 lines of instructions. The PAC1000 device will receive data in parallel from the host system. The FIFO is used to interface to the host and transfer data into the                                                                                                                                                                                                                                                                                                                                                          |                                       |  |  |  |  |  |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|--|--|--|--|--|
|                        | segment pacdes09 :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                       |  |  |  |  |  |  |
|                        | /*THIS PROGRAM ILLUSTRATES THE PARALLEL TO SERIAL<br>/*CHANNEL CONVERSION OF THE PAC1000 TO THE PERIPHERAL<br>/*BUS OF THE SYSTEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | */<br>*/<br>*/                        |  |  |  |  |  |  |
|                        | /* PIN FUNCTIONAL DESIGNATIONS.<br>/* OUTPUTS.<br>/*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | */<br>*/<br>*/                        |  |  |  |  |  |  |
|                        | /*       OC12 - DTR - DATA TERMINAL READYACTIVE LOW.         /*       OC13 - RHD - RECEIVED HOST DATAACTIVE LOW.         /*       OC14 - DONEACTIVE LOW.         /*       OC15 - ABORTACTIVE LOW.         /*       IO3 - TxD - TRANSMITTED DATAACTIVE LOW.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | */<br>*/<br>*/<br>*/                  |  |  |  |  |  |  |
|                        | /* */<br>/* INPUTS. */<br>/* */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                       |  |  |  |  |  |  |
|                        | <pre>/* CCO - DSR - DATA SET READYACTIVE HIGH.<br/>/* CC1 - START TRANSMITTINGACTIVE HIGH.<br/>/* HD - ACTIVE TRUE - 16 DATA INPUTS.<br/>/* HAD - ACTIVE TRUE - REGISTER ADDRESS INPUTS<br/>/* /CS - ACTIVE LOW - PAC1000 SELECT<br/>/* /WR - ACTIVE LOW - WRITE TO PAC1000 FIFD<br/>/*</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | */<br>*/<br>*/<br>*/                  |  |  |  |  |  |  |
|                        | INIT equ H'FFFF'; /*INITALIZE ALL OUTPUTS HIGH<br>RHD equ H'DFFF'; /*ACKNOWLEDGE RECEIVING HOST DATA<br>DTR equ H'EFFF'; /*DATA TERMINAL READY<br>DONE equ H'BFFF';<br>ABORT equ H'BFFF'; /*TELL HOST THAT DATA WAS CORRUPTED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | */<br>*/<br>*/<br>D*/                 |  |  |  |  |  |  |
|                        | <pre>/* R21 - H'0060' - MASK REGISTER FOR EVEN PARITY /* R20 - H'00E0' - MASK REGISTER FOR ODD PARITY /* R19 - H'0002' - CONSTANT TO DIVIDE THE 32-BIT VALUE /* IN RX R16 /* R18 - H'0000' - COUNTER OF THE NUMBER OF ONES IN THE DATA /* R17 - H'FFFF' - A CONSTANT TO MASK WITH DATA /* R16 - H'0000' - A CONSTANT TO MASK WITH DATA /* R16 - H'0000' - A CONSTANT TO MASK WITH DATA /* R16 - H'0000' - A CONSTANT TO MASK WITH DATA /* R17 - H'FFFF' - A CONSTANT TO MASK WITH DATA /* R17 - H'FFFF' - A CONSTANT TO MASK WITH DATA /* R17 - H'FFFF' - A CONSTANT TO MASK WITH DATA /* R17 - H'FFFF' - A CONSTANT TO MASK WITH DATA /* R18 - WORKING REGISTER FROM R0 /* R0 - ORIGINAL DATA FROM HOST SYSTEM /* Q - REGISTER TO SHIFT OUT DATA TO THE /* SERIAL PORT</pre> | * * * * * * * * * * * * * * * * * * * |  |  |  |  |  |  |

Programmable UART (Cont.) R21 := H'0060', OUT INIT : /\*SET OC[15:0] HIGH\*/ bean: R20 := H'00E0' : R19 := H'0002' : R18 := H'0000' ; R17 := H'FFFF' 5 R16 := R18 : Q := R18 ; /\* INITIALIZE Q TO ZERO'S \*/ /\* WAIT FOR HOST TELLS PAC1000 \*/ TO START TRANSMITTING DATA /\* \*/ stndby: JMPNC CC1 stndby : JMPC FICD abort : RDFIFO , OUT RHD ; /\* READ FIFO DATA INTO RO \*/ /\*TELL HOST THAT DATA WAS \*/ /\*READ CORRECTLY **\***/ /\* FORMAT OF DATA RECEIVED \*/ /\* FIFODAL15:01 **\***/ /\* 15 14 13 12 11 10 9 8 7 43 6 5 2 1 Ô \*/ /\* \*/ /\* SWAP THE HIGHER AND LOWER BYTES #1 /\* SET OC TO NON-\*/ AOR := RO , OUT INIT ; /\* FUNCTIONING MODE \*/ R8 := SWPV ; /\* MODE SWAP TO SHIFT \*/ RO := SWPV ; /\* LATER SWAP NOW \*/ 1\* SHIFT DATA \*/ FOR 7 ; R8:= R8 << 0 ; IF S : R18 := ++ R18 : /\*INCREMENT COUNTER\*/ ENDIF ; ENDFOR ; /\* CHECK FOR EVEN/ODD PARITY **\*/** DIV R16 R18 R19 ; /\* DIVIDE R18 R16 BY 2 \*/ ORQO; /\* CHECK IF REMAINDER IS ZERO \*/ IF Z ; /\* IF Z=1 THEN JUMP TO PARITY \*/ /\* (EVEN PARITY) \*/ /\* IF Z = O THEN (ODD PARITY) \*/ OR R0 R21 ; /\* MERGE MASK BITS FOR EVEN PARITY \*/ ELSE ; OR RO R20 : /\* MERGE MASK BITS FOR ODD PARITY \*/ ENDIF ; /\* RO IS NOW FORMATTED CORRECTLY FOR\*/ /\* SERIAL SHIFTING \*/ Q := RO :/\* LOAD RO TO Q TO SHIFT OUT TO IO3 \*/ /\* CHECK THAT RECEIVING END IS READY \*/

**Programmable** UART (Cont.) /\*IF RECEIVER READY SET IO3 TO OUTPUT \*/ wait: IF CCO : CONFIGURE SID : /\*AND SET MODE TO SHIFT Q TO IO3 \*/ OUTPUT 103 . OUT DTR : /\*DRIVE DTR TO ZERO THIS ¥/ /\*TELLS THE RECEIVER THAT \*/ /\*THE TRANSMITTER IS READY\*/ /\* SHIFT OUT THE 1 START BIT, 7-BITS OF DATA,1 PARITY AND \*/ /\* 2 STOP BITS . THEREFORE SHIFT 11 TIMES \*/ LDLC 10 : /\*LOAD 10 INTO LOOP COUNTER FOR \*/ /\*A SHIFT OF 11 THEN FILL WITH \*/ /\*ZEROS **\***/ lp: LOOPNZ lo . QR8 := Q << 0 R8 << 0 : ELSE: JMP wait : /\*IF RECEIVER IS NOT READY THEN WAIT\*/ ENDIF : OUT DONE : /\*TELL HOST THAT PAC1000 IS DONE ¥/ JMP begn : /\* START AGAIN FOR NEXT DATA ¥/ /\* ABORT DATA READ AND TELL HOST ABOUT IT \*/ abort: JMP begn . OUT ABORT ; end:

#### Summary

The PAC1000 user programmable high performance microcontroller incorporates many features that enable a high speed design to be quickly realized. Its reprogrammability has enabled many designers to go to printed circuit board lavout early in the design cycle. Moreover, because the system logic is programmable into the on-chip EPROM, modifications can be made at a later time without having to change printed circuit board artwork. In fact over discrete and PAL/EPLD type solutions the printed circuit board artwork is considerably less complex because a greater degree of circuit complexity containing much interconnect has migrated into the instructions encoded in the EPROM section of the chip.

To learn how to use the PAC1000 is a relatively quick process for most systems designers have designed with microprocessors and microcontrollers.

This is because they understand the writing of assembly or high level code. With the support of WSI's user friendly software tools, an engineer can be designing with the PAC1000 in less than a week. This contrasts with the many and diverse schematic capture, net translation, placing and routing, annotation and backannotation packages that support EPLD and PGA devices. These products subject the designer to a multiplicity of software tools that he must become familiar with. This results in generating a long learning curve that can easily be avoided with the PAC1000 and WSI's software support.

The result of using the PAC1000 device and software tools virtually guarantees the fastest route possible from initial conception to the final design of a complex high performance system.



# Programmable System™Device

**Application Note 005** 

PAC1000 as a High-Speed Four-Channel DMA Controller

By Arye Ziklik and Kiran Buch

# **Abstract** The objective of this Application Note is to demonstrate the use of the PAC1000 Userconfigurable Microcontroller in a typical high performance application. The text describes an implementation of a generic four-channel DMA controller that supports transfer rates of up to *20 Mbyte/sec* (10 Mword/sec) in 16-bit data-bus environments.

This Application Note covers the terminology of DMA operations as well as an implementation description. The readers will be able to use this article as a get-started tutorial that shows how to configure the PAC1000 for any specific task.

## Introduction

A DMA (Direct Memory Access) controller coordinates fast data transfers between peripheral devices and the system memory. All possible transfer combinations might occur: device to device, device to memory or memory to memory. By taking care of these high-speed transfers, the host computer (typically a Microprocessor) is off-loaded from these time-consuming tasks and can execute other operations concurrently, on its local bus.

We refer to peripherals such as FIFOs, video, communication, graphics or serial channel controllers, latches, ports, etc., as devices in this text. The distinction between memory and device is that a memory needs an explicit address in order to specify a byte or a word, whereas a device requires only strobes (such as:  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{CS}}$ ) combined sometimes with additional hand-shaking signals for data accessing.

The PAC1000 is a perfect match for most DMA applications. Its unique structure, shown in Figure 1 and Figure 2, allows the user to execute three independent instructions in one cycle. The ability of the PAC1000 to perform three different tasks concurrently (Control, Output and CPU) is fully exploited here, thereby speeding-up DMA transfers.

For example, during DMA operations, the control section checks for the block-count termination, the output control section generates RD and WR strobes, and the CPU calculates and produces the next address. All these activities occur simultaneously during the same clock cycle(!).

Unlike most other available DMA controllers, the PAC1000 is a user-programmable Microcontroller. It may be easily modified by reprogramming to support various DMA schemes.

Figure 3 illustrates a typical system configuration using the PAC1000 as a DMA controller. The host controls the system bus as well as its local bus (not shown here). It can also access the memories, the devices as well as the PAC1000 via the system bus. It does so by driving the Address, Control and Data buses.

Initially the PAC1000 is in the slave mode, waiting for host messages. Once the host begins a channel initialization phase by writing into the PAC1000's FIFO, a DMA operation will start. In that phase, the host instructs the PAC1000 of the required DMA transfer. The PAC1000 then decodes the transfer type and optimizes it internally to perform at the fastest rate the surrounding hardware allows. At this point the PAC1000 requests the system bus from the bus arbiter. When the bus is granted to the PAC1000, it becomes the Bus Master, driving the address, data and control buses.

If the DMA operation is fully completed, or a higher priority transfer is pending, or the host or active devices abort the transfer, a DMA transfer can be successfully terminated or suspended, respectively. In all of these cases, system control is returned to the host and the PAC1000 re-enters to Slave Mode.

# Figure 1. PAC1000 Microcontroller Block Diagram





# Transfer Modes

There are two transfer modes: Fly-by and Dual cycle.

*Fly-by* is the fastest transfer mode (refer to Figure 4). Transfers can be carried out at a rate of up to 10 Mword/sec provided that the PAC1000 uses a 20-MHz clock. In this application note, Fly-by can only be used between memory and device if they share the same data-bus path (either 8 or 16 bits).

The fly-by operation is initiated by a DMARQ from the device. The PAC1000 explicitly addresses the memory, while sending the  $\overline{\text{RD}}$  strobe to the source side and the  $\overline{\text{WR}}$  strobe to the destination side. It also acknowledges the device with the  $\overline{\text{DMACK}}$  signal that serves as the device's  $\overline{\text{CS}}$  signal. Data is then directly transferred from the source to the destination in one bus cycle.

**Double-cycle** is a transfer mode comprised of two bus cycles. It takes place whenever one of the following DMA combinations is specified (refer to Figure 5):

- Memory to/from device that is not connected to the same part of the data-bus.
- Memory to Memory transfers (require the generation of two different explicit addresses).
- Device to Device transfers (with simple additional hardware it might be easily upgraded to support the Fly-by mode, too).

Once the transfer has started, the PAC1000 reads an operand from the source on the first bus-cycle, processes it, and then writes that operand on the second bus cycle into the destination.

The READY signal enables the PAC1000 to synchronize its operations with slow memories or devices (whenever they are explicitly addressed). READY is an activehigh signal, derived from the address decoder. It is driven low as long as the addressed memory or device is not ready to finish the current bus-cycle. 4





#### **Request Modes**

Requests may be externally generated by a device or internally created by the autorequest mechanism of the PAC1000, whenever a memory to memory transfer is performed. Auto-requests are always pending so that the PAC1000 can work at its maximum speed, provided that the memories are always ready. Otherwise, the PAC1000 adapts itself to the READY signal.

External requests may be of either the block-type or of the single-operand transfer mode. Block-type transfers are provided for high-speed devices that are capable of meeting the speed rate of the PAC1000. DMARQ is asserted at the beginning of the block transfer and remains so as long as the transfer is in process. Single-operand transfers are used by slow devices. They toggle on and off the DMARQ. Each individual transfer is indicated by an active high DMARQ level. When the transfer is completed, DMARQ is held low until the device is ready for the next transfer cycle, and so on.

Some important observations:

- Memory to device (or device to memory) transfers will begin only after an external DMARQ is asserted by the device.
- Synchronization with the memory is always achieved via the Ready signal.

Table 1 briefly summarizes the transfer and request options:

#### Table 1. Summary of Transfer and Request Modes

| Transfer Type                           | DMA Mode                    | Transfer Mode              |
|-----------------------------------------|-----------------------------|----------------------------|
| Memory to Memory                        | Two Bus-cycles              | Block                      |
| Memory to Device or<br>Device to Memory | Fly-by or<br>Two Bus-Cycles | Block or<br>Single Operand |
| Device to Device                        | Two Bus-Cycles              | Block or<br>Single Operand |

#### Functional Description

#### General:

Figure 6 contains the circuit diagram. Refer also to Appendix 1 for the Pin Description Table. The PAC1000 is configured in this application as a four-channel DMA controller. This means that it can handle up to four DMA transfers concurrently, on a prioritized basis. Each of the channels can be any one of the above-mentioned DMA transfer types. The maximum transfer rate is accomplished during Fly-by transfers with rates approaching 10 Mword/sec for word transfers or 10 Mbyte/sec for byte transfers. Double-cycle transfer modes achieve a rate of up to 5 Mword/sec (in word transfers) or 5 Mbyte/sec (in byte transfers). The only exception to this is the Memory to Memory transfer mode which is a little bit slower due to the internal creation of two different 24-bit addresses.

The PAC1000 drives 24 address lines and handles a 16-bit data bus, so it is well tuned for most common high-performance buses or Microprocessors. The maximum operand block-size is 64K (in accordance with VMEbus specs, for example).

#### Host-PAC1000 Communication:

DMA specifications are programmed into the PAC1000 by the host, according to the message format of Appendix 2. The host writes eight words into the PAC1000's FIFO. The command message fully specifies one of the four possible channels that can be active at the same time. Word 1 defines the transfer characteristics of the DMA operation: transfer type, data bus width, device numbers (redundant in Memory to Memory operations), channel-priority and transfer mode. Bit 12 in that word serves as a software abort-command bit. When set, it instructs the DMA controller to cease the transfers of the channel specified in that command buffer.

The low-order byte of word 7 is a DMAtransfer identification number. It assigns a serial number to a DMA process. Whenever the PAC1000 sends a status message to the host, that number is also included in order to unambiguously identify the process that has either normally terminated or abnormally aborted (by an external device or due to a PAC1000 exception).

#### Functional Description (Cont.)

Figure 6. PAC1000 Configured as a Generic High-Speed DMA Controller



### Functional Description (Cont.)

Several fields in the command buffer are optional. For instance, in transfers where devices are involved, one can still specify the explicit addresses of the source and the destination even though it has already been defined by the command word's devicenumber field (Appendix 2 — command word format). This feature allows the programmer to define the device interface with either explicit or implicit address.

Whenever the PAC1000 has to inform the host of an important event, it prepares a status word in its DOR (Data Output Register), enters the slave mode and interrupts the host by raising the HOSTINTR line. The possible messages are:

- Reject the Command buffer with the specified identification number because of internal discrepancies or illegal combinations.
- Propagate a Hardware DMA abort, generated by the source or the destination of the current transfer.
- Signal a PAC1000 exception. The host is capable of reading the PAC1000's SR register in order to find out the cause.
- An end-of-count message. This transfer has been normally terminated.

#### Initial State and Slave Mode:

After a reset (either a power-on reset or a reset through the RSPAC line driven from the host side), the PAC1000 enters its initial state, which is the Slave Mode. Table 2 describes the signal states during the Slave Mode. The PAC1000 monitors its internal FIIR flag (FIFO Input Ready) and when it is not set, the FIFO is full with a new command buffer written by the host. The PAC1000 decodes the message and acts accordingly. If it is a memory to memory transfer, then it immediately requests the bus. When one or two devices participate in a transfer operation, the PAC1000 monitors the corresponding DMARQ lines to determine when to issue a bus request to the arbiter. The PAC1000 requests the bus by lowering BR. Then it waits for BG to go low in order to switch to the Master Mode.

#### Master Mode:

Upon gaining mastership, the PAC1000 drives the HOSTINTR signal low and BUSMSTR high. BUSMSTR remains high (active) as long as the PAC1000 remains master of the system bus, thereby enabling  $\overline{\text{RDM}}$  and  $\overline{\text{WRM}}$  to  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$ , respectively.  $\overline{\text{BR}}$  is set high (= not active). According to the required DMA operation, the PAC1000 drives the appropriate address and data lines, and the  $\overline{\text{RDM}}$ ,  $\overline{\text{WRM}}$  and  $\overline{\text{DMACK}}$  signals.

DMA transfers may be successfully ended (when the terminal-count expires) or aborted. Abortion can emanate either from an external DMABT signal that is driven by one of the DMA participants, or from an internal exception recognized by the PAC1000. Whenever one of the above events occur, the PAC1000 changes its mode to the Slave mode, writes a status word into the DOR register (discussed previously) and raises the HOSTINTR line to cause the host to read that information through its own Interrupt routine.

#### Releasing and resuming bus control:

The host is allocated a higher priority than the PAC1000 by the bus arbiter. This is done in order to enable the host to suspend DMA transfers whenever it needs the bus. Each time the host accesses an address that resides within the system bus domain (including the CSPAC address), the bus will be granted. If the PAC1000 is the current master (as reflected by BUSMSTR), the bus arbiter will negate BG (high level). The PAC1000 monitors this line while it is a bus Master and consequently will relinquish the bus and return to the slave mode. The host might use the bus for programming the PAC1000 with a new DMA channel. Upon completion of the host activities over the system bus (BG becomes high), the PAC1000 checks whether DMA transfers are still pending. If this is the case, it will request the bus. When the bus is granted, it will determine whether to continue the suspended transfer or to start a higher priority pending-DMA request. If it starts a higher priority transfer, then the suspended operation will be resumed after the completion of the higher priority transfer.

DMAWORD is set low during word transfers and high during byte transfers. It is used to derive the BHE strobe, as displayed in Figure 6. The most efficient transfer method is the word transfer mode. In order to use it, the specified addresses must be even, otherwise the PAC1000 will perform only in the byte transfer mode regardless of the command word content.

#### Functional Description (Cont.)

#### *Table 2. Signal States During the Slave Mode*

| PAC1000 Signal Names | Function     | Signal States              |
|----------------------|--------------|----------------------------|
| ADD(15:0)            | A(21:6)      | Float                      |
| HAD(5:0)             | A(5:0)       | Input                      |
| IO(5:4)              | A(23:22)     | Float                      |
| OC6, OC5             | FBRW2, FBRW1 | 0, 0 — Normal Operation    |
| OC4, OC3             | RDM, WRM     | Don't Care                 |
| 10(3:0)              | DMACK (3:0)  | 1,1,1,1 — Normal Operation |
| OC2                  | BUSMSTR      | 0 — Non-active             |
| OC1                  | BR           | 1 — Non-active             |
| OC0                  | HOSTINTR     | 0 — Non-active             |
| OC7                  | DMAWORD      | Don't Care                 |
| HD(15:0)             | D(15:0)      | Input                      |

.

#### Hardware Considerations

Figure 6 is the detailed schematic diagram. The host side is beyond the scope of this paper since it is application dependent. In addition to the PAC1000, there are a few standard glue-logic chips used to interface with the memory and the four devices.

Throughout the following description it is assumed that the glue-logic components belong to the HC family. However, since the PAC1000 is a fully TTL compatible device implemented in CMOS technology, the reader can use other glue-logic families like: LSTTL, HCT, etc.

The HC374 latch is gated into the condition code inputs by the PAC1000's clock, thus ensuring that the CC7–CC0 lines will meet the set-up time requirements.

The three-state buffers controlled by BUSMSTR, are part of a HC126 chip. They are used to float the PAC1000's BHE, RDM, WRM control lines during slave operations, because at that time these signals are driven by the host.

The four AND-Gates amount to one HC08 chip. They enable either the host side (during Slave operations) or the PAC1000 (in the Master Mode) to drive the appropriate device  $\overline{CS}$  signals.

The four OR-Gates comprise together one HC32 chip. They are used during Fly-by operations to avoid  $\overline{CE}$ ,  $\overline{RD}$ ,  $\overline{WR}$  from reaching the selected devices and memories concurrently (for functional explanation, refer to the Pin Description Table, Appendix 1).

Prior to the setting of  $\overline{BG}$  in the active position (low), the arbiter floats the data bus D(15:0), address bus A(23:0) and  $\overline{BHE}$ ,  $\overline{RD}$ and  $\overline{WR}$  from the host side. As long as BUSMSTR remains high, these lines are driven by the PAC1000.

The six chip select lines from the host side  $\overline{(CS#3)} - \overline{CS#0}$ ,  $\overline{CSMEM}$  and  $\overline{CSPAC}$ ) are derived from the system address decode block, as illustrated in Figure 6. During the time that the PAC1000 is the bus master, the address decode block (shown in Figure 3) is driven by the PAC1000's address lines. Therefore, the PAC1000 can access memories and devices in the same manner the host does.

The DMACK3-DMACK0 signals provide the PAC1000 with an alternative chip select generation method to the devices. It is considerably faster than the host's method, since there is no need to generate explicit device addresses inside the PAC1000.

|                                       | and the second                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware<br>Considerations<br>(Cont.) | In this application note, it is assumed that<br>the READY signal is produced by the<br>address decoder. However, if a device or<br>memory can generate the READY signal<br>independent of the decoder, the system<br>designer can connect it with a Three-state<br>buffer so that it will drive the READY input<br>whenever it is chip-selected.<br>The host programmer is free to choose<br>whether to synchronize the PAC1000 with<br>slow devices via single operand transfers or<br>through the READY mechanism. READY is                                                                                                                                                                                                                                                        | always considered when the PAC1000<br>generates an explicit address. The selection<br>between single operand transfer and<br>READY is done in the command word<br>(see Appendix 2).<br>As seen in Figure 6 there are several spare<br>pins, such as output controls, I/Os, interrupts<br>and condition codes. These pins can be<br>used to perform other operations in parallel<br>(unrelated to the DMA controller function),<br>without any performance degradation of the<br>DMA task.                                                                                                                                                                                                                                                              |
| PAC1000 Internal<br>Resources Usage   | Using PAC1000 as a 4-channel DMA<br>controller utilizes most of the resources<br>available on the chip, shown in Figure 1.<br>The Host microprocessor uses the FIFO to<br>program the DMA request in to PAC1000.<br>Internal condition codes are used to monitor<br>FIFO status, CPU operation flags and external<br>condition code inputs are used to monitor<br>situations like bus-grant, DMA requests by<br>the devices, etc. The CPU registers are<br>used to store source and destination<br>addresses, device numbers and other<br>relevant information about the DMA<br>transfers in progress.<br>To achieve the fastest transfer rate possible<br>with PAC1000, address generation and<br>block size counting are achieved by<br>different methods depending on the type of | transfer. For example, for the Device-Memory<br>fly-by transfers, a nested loop is set up<br>using the loop counter and the stack for<br>maintaining block count and ACH and ACL<br>are used as independent registers for<br>address generation. On the other hand, for<br>the memory to memory transfers, Block<br>counter is used for counting and address<br>generation is done by using ACH and ACL<br>as 22-bit counter.<br>The IOR is used to output chip selects to<br>the devices. The OUTCTL lines are used to<br>generate Read and Write signals and also<br>used for generating hand-shake signals to<br>the host.<br>The data bus and associated CPU registers<br>are used to read data in and out of PAC1000<br>for non-fly-by transfers. |
| Software<br>Considerations            | All the algorithms described so far are<br>internally realized by Software. Flowcharts<br>and partial code implementation (of all the<br>important transfer procedures referred to in<br>the flowcharts) can be found in Appendix 3<br>and Appendix 4, respectively. Both flowcharts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | and code listings contain sufficient<br>explanations that let the reader understand<br>the subjects they describe. The attached<br>code listings cover all the important DMA<br>transfer procedures (see Appendix 4).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Conclusion                            | PAC1000 is perfectly suitable for any DMA<br>transfers which require an intelligent processor<br>that can adapt its data handling according<br>to the changing requirements of its interface.<br>The PAC1000 does so by properly exploiting<br>its unique structure of a very high speed<br>sequencer combined with a programmable                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ALU and user configurable ports. The<br>PAC1000's programmability enables it to<br>handle complex tasks concurrently in a very<br>efficient manner, unlike all other existing<br>DMA controllers that are restricted to perform<br>in a predefined environment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Appendix 1:** The PAC1000 is configured in this application note as a generic DMA controller. It has a separate 24-bit address (that can be easily expanded) and a 16-bit data bus. It also has a set of control signals to enable operation as a bus master or a bus slave. The

following table defines the individual PAC1000 pins. These brief descriptions are provided for reference only. Each signal is further detailed within the sections that describe the associated DMA function. For pin identifications refer to Figure 6.

#### **Pin Descriptions**

| Symbol         | Туре   | Name and Function                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|----------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| A(23:22)       | 0      | Address Lines A(23:22): Output the two most significant address lines during Master operations. Tied to IO(5:4) on the PAC1000. Float in Slave Mode.                                                                                                                                                               |  |  |  |  |
| A(21:6)        | 0      | Address Lines A(21:6): Output the mentioned address lines only in Master Mode. Connected to ADD(15:0) on the PAC1000. Float in Slave operations.                                                                                                                                                                   |  |  |  |  |
| A(5:0)         | 1/0    | <b>Address Lines A(5:0):</b> Bidirectional address lines. Input during Slave operations, output in Master mode. Tied to HAD(5:0) on the PAC1000.                                                                                                                                                                   |  |  |  |  |
| FBRW2<br>FBRW1 | 0<br>0 | Fly-by Read/Write (2:1): Enable fly-by DMA operations. In fly-by mode, operands are transferred directly from the source to the destination bypassing the DMA controller. FBRW2 and FBRW1 are tied to OC6 and OC5, respectively.                                                                                   |  |  |  |  |
|                |        | FBRW2 FBRW1                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                |        | 0 0 — Normal operation.                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                |        | 0 1 — Enable fly-by from memory to device.                                                                                                                                                                                                                                                                         |  |  |  |  |
|                |        | 1 0 — Enable fly-by from device to memory.                                                                                                                                                                                                                                                                         |  |  |  |  |
|                |        | 1 — Illegal.                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| WR             | 1      | Write: Active as an input, only in Slave Mode. When low,<br>HD(15:0) is written into the PAC1000.                                                                                                                                                                                                                  |  |  |  |  |
| RD             | ł      | <b>Read:</b> Active as an input, only in Slave Mode. When low, HD(15:0) is driven by the PAC1000.                                                                                                                                                                                                                  |  |  |  |  |
| WRM            | 0      | Write-Out: Active as an output, only in Master Mode. Enabled by BUSMSTR signal. Tied to OC4 on the PAC1000.                                                                                                                                                                                                        |  |  |  |  |
| RDM            | 0      | <b>Read-Out:</b> Active as an output, only in Master Mode. Enabled by BUSMSTR signal. Tied to OC3 on the PAC1000.                                                                                                                                                                                                  |  |  |  |  |
| DMACK(3:0)     | 0      | <b>DMA Acknowledge (3:0):</b> 4 active low signals. High in Slave<br>Mode. Correspond to the 4 devices shown in Figure 6<br>respectively. Chip select the active devices during DMA<br>operations. In the PAC1000 they are tied to IO(3:0) lines.                                                                  |  |  |  |  |
| BUSMSTR        | 0      | <b>Bus-Master:</b> An active high signal. Asserted whenever the PAC1000 is the current Bus Master. Informs arbiters or hosts not to access the bus before the PAC1000 relinquishes it. Enables OC4 and OC3 into $\overline{\text{WR}}$ and $\overline{\text{RD}}$ , respectively. Connected to OC2 on the PAC1000. |  |  |  |  |
| CSPAC          | ł      | <b>PAC1000 Chip Select:</b> This pin is driven low whenever the PAC1000 is addressed in a slave bus read or write cycle.                                                                                                                                                                                           |  |  |  |  |
| BR             | 0      | Bus Request: The PAC1000 drives this pin low whenever it requests the bus due to pending DMA requests.                                                                                                                                                                                                             |  |  |  |  |

| Pin Descriptions<br>(Cont.) | Symbol   | Туре | Name and Function                                                                                                                                                                                                                                                                   |
|-----------------------------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | HOSTINTR | 0    | <b>Host Interrupt:</b> The PAC1000 interrupts the host in order to inform him of one of the following events: PAC1000 exception, Terminal-Count or DMA aborted by a device. The OC0 line is assigned to this signal.                                                                |
|                             | CLK      | 1    | <b>Clock:</b> 20 MHz clock input to the PAC1000. It also latches the condition codes to ensure the proper Set-up time.                                                                                                                                                              |
|                             | CC7      | I    | <b>DMA Abort:</b> An active-high input driven by the memories and/or devices currently participating in the DMA process. Whenever it is sensed high, the PAC1000 will generate a HOSTINTR signal towards the host after writing into the DOR register the appropriate status word.  |
|                             | CC6      | I    | <b>Bus Grant:</b> An active-low signal monitored by the PAC1000 to determine when it is in the Master mode or when to relinquish the buses and enter the Slave Mode.                                                                                                                |
|                             | CC4      |      | <b>Ready:</b> An active-high signal (RDY) that enables the PAC1000 to synchronize its DMA cycles with slow memories or devices in the Master Mode.                                                                                                                                  |
|                             | CC(3:0)  | I    | <b>DMA Requests (3:0):</b> External DMA requests monitored by the PAC1000. Active-high signals, driven by the four devices.                                                                                                                                                         |
|                             | DMAWORD  | 0    | <b>DMA Word or Byte Transfers:</b> Determines whether the next<br>DMA cycle will be of word (low) or byte (high) length. Used to<br>derive the BHE (Bus High Enable) signal that enables data lines<br>D15:D8 in the Master Mode. BLE is directly driven by the A0<br>address line. |
|                             | RSPAC    | Ι    | <b>Reset PAC1000:</b> This asynchronous input initializes the state of.<br>PAC1000. RESET must be held low for at least two clock cycles.                                                                                                                                           |
|                             | D(15:0)  | I/O  | <b>Data-Bus (15:0):</b> This is the 16-bit data bus. During Master cycles, it is controlled and sometimes also driven by the PAC1000. In Slave mode the host drives it. Tied to HD(15:0) on the PAC1000.                                                                            |

### Appendix 2: Host-DMA Message Formats

| 1) Host to          |                                                 | HAD(5: | 0) CON | TENT |      |      |      |
|---------------------|-------------------------------------------------|--------|--------|------|------|------|------|
| PAC1000<br>Commands | HD(15:0) CONTENT                                | HAD5   | HAD4   | HAD3 | HAD2 | HAD1 | HAD0 |
| (via the FIFO)      | Word 1: Command word (see paragraph 3).         | 0      | 0      | 0    | 0    | 0    | 0    |
| (112 110 111 0)     | Word 2: 16 low-order source address lines.      | 0      | 0      | 0    | 0    | 0    | 1    |
|                     | Word 3: 8 high-order source address lines.      | 0      | 0      | 0    | 0    | 1    | 0    |
|                     | Word 4: 16 low-order destination address lines. | 0      | 0      | 0    | 0    | 1    | 1    |
|                     | Word 5: 8 high-order destination address lines. | 0      | 0      | 0    | 1    | 0    | 0    |
|                     | Word 6: 16 bit block-count.                     | 0      | 0      | 0    | 1    | 0    | 1    |
|                     | Word 7: 8 bit DMA-transfer identification byte. | 0      | 0      | 0    | 1    | 1    | 0    |
|                     | Word 8: Spare.                                  | 0      | 0      | 0    | 1    | 1    | 1    |

# 2) PAC1000 to Host Status Word (via DOR register)

| b15                                                                                                                         | b14 | b13 | b12     | b11             | b10     | b09    | b08     | b07    | b06    | b05    | b04      | b03    | b02 | b01 | b00 |
|-----------------------------------------------------------------------------------------------------------------------------|-----|-----|---------|-----------------|---------|--------|---------|--------|--------|--------|----------|--------|-----|-----|-----|
|                                                                                                                             |     |     |         |                 |         |        |         |        |        |        |          |        |     |     |     |
|                                                                                                                             |     | p.  | 15,b14, | ,b13,b1         | I2,b11, | b10,b9 | 9,b8: I | DMA-ti | ransfe | r iden | ificatio | on byt | e.  |     |     |
|                                                                                                                             |     | b   | 7,b6,b5 | 5,b4: s         | spare.  |        |         |        |        |        |          |        |     |     |     |
| <ul> <li>b3: Reject or accept the DMA transfer identified by b15 ÷ b8.</li> <li>1 — reject.</li> <li>0 — accept.</li> </ul> |     |     |         |                 |         |        |         |        |        |        |          |        |     |     |     |
| b2: 1 — PAC1000 aborted.<br>0 — Normal operation                                                                            |     |     |         |                 |         |        |         |        |        |        |          |        |     |     |     |
| <ul> <li>b1: 1 — DMA terminal-count completed</li> <li>0 — Normal operation</li> </ul>                                      |     |     |         |                 |         |        |         |        |        |        |          |        |     |     |     |
|                                                                                                                             |     | b   | 0:1-    | – PAC<br>– Nori |         |        |         | curre  | d      |        |          |        |     |     |     |

# 3) Command Word Format

| b15 b14 b13 b12 b11 b1 | b10 b09 b08 b07 | b06 b05 b04 b03 | b02 b01 b00 |
|------------------------|-----------------|-----------------|-------------|
|------------------------|-----------------|-----------------|-------------|

| b15,b14 | : spare.                                                                                                                                                           |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| b13:    | block transfer or single transfer mode.<br>1 — DMA block operation.<br>0 — DMA single operand transfer mode.                                                       |
| b12:    | DMA abort bit. Quits DMA-transfer specified in word 7.<br>1 — abort.<br>0 — nop.                                                                                   |
| b10,b9: | Priority level of this DMA-transfer.<br>00 — level 0 (lowest priority level).<br>01 — level 1 •<br>02 — level 2 •<br>03 — level 3 (highest priority level).        |
| b9,b8:  | Source Device number for DMA transfer or Abort.<br>00 — Device #0<br>01 — Device #1<br>02 — Device #2<br>03 — Device #3                                            |
| b7,b6:  | Dest. Device number for DMA transfer or Abort.<br>00 — Device #0<br>01 — Device #1<br>02 — Device #2<br>03 — Device #3                                             |
| b5,b4:  | Destination data bus definition.<br>00 — Data bus is D7–D0 (bit bits).<br>01 — Data bus is D15–D8 (8 bits).<br>02 — Data bus is D15–D0 (16 bits).<br>03 — Illegal. |
| b3,b2:  | Source data bus definition.<br>00 — Data bus is D7–D0 (8 bits).<br>01 — Data bus is D15–D8 (8 bits).<br>02 — Data bus is D15–D0 (16 bits).<br>03 — Illegal.        |
| b1,b0:  | DMA transfer mode.<br>00 — Memory to memory.<br>01 — Memory to device.<br>02 — Device to device.<br>03 — Device to memory.                                         |

#### Appendix 3 General Note:

Code implementation of labels marked with an asterisk (\*) can be found in Appendix 4.



Legend:

1. **Slot:** The PAC1000 can handle up to 4 DMA channels concurrently. Slot means empty register space inside the PAC1000 that is allocated for a pending channel.

 LCPTR branching: A goto instruction of the command section, enabling multi-way branching of the program according to a value loaded into the LC register by the ALU (executed in two cycles).





#### Legend:

- 1. B\_dm\_byte: block device to/from memory transfer of bytes.
- 2. B\_dm\_word: block device to/from memory transfer of words.
- 3. B\_dm\_sbyte: block device to/from memory transfer of swapped bytes. Occurs whenever the transfer is between even and odd addresses.



#### Legend:

1. B\_dd\_byte: block device to device transfer of bytes.

2. B\_dd\_word: block device to device transfer of words.

3. B\_dd\_sbyte: block device to device transfer of swapped bytes. Happens whenever the transfer is between even and odd addresses.



# Legend:

- 1. B\_mm\_byte: block memory to memory transfer of bytes.
- 2. B\_mm\_word: block memory to memory transfer of words.
- 3. B\_mm\_sbyte: block memory to memory transfer of swapped bytes. Occurs whenever the transfer is between even and odd addresses.





#### Appendix 4

```
/* device to memory byte transfer in the fly-by mode. The start address */
/* of the memory is loaded in R3 and R4 and the device number is loaded*/
/* PAC has control of the bus. For simplicity it is assumed that the*/
/* block size is a multiple of 64 and R5*64 = block size.
                                                */
segment b dm byte ;
   /* define equates */
                                            */
   bgn egu CC7
                       /* bus grant (active low)
                     ;
                       /* ready input
                                            */
   ready equ CC4
                     ;
   b dm byte norm equ h'00de' ; /* dma active w/o read/write
b_dm_byte_read equ h'00d6' ; /* read (active low )
                                            */
                                            */
   b dm byte write equ h'00c6'; /* write (active low )
                                            */
init b dm byte :
   \overrightarrow{ACH} := R3
                     ; /* upper 16 bits address
                                            */
   SET ASEL ADOE HADOE
   ACL := R4
                       /* select counter to output ,
                       enable ADD and HAD output, and
                       load lower address in ACL
                                          */
   IOR := \sim Q,
   OUT b dm_byte_norm
                                        */
                     ; /* select device #
                     ; /* address increment for byte
   Q := 1
                                             */
                     ; /* R5 * 64 -> block count
   LDLCD , MOV R5 R5
                                             * /
/* start of outer transfer loop
                                                 */
x1: PLDLC H'3F'
                       /* push cnt to stack and load 64
                                     */
                       in cnt
*/
/* start inner transfer loop
y1 : JMPNC ready y1 ,
   OUT b dm byte read ; /* wait till ready signal high
                                               */
   LOOPNZ y1
   ACL := ACL + Q ,
   OUT b dm_byte_write
                       /* strobe the write signal and
                     ;
                       set up the next address */
/* end inner loop
                                                 */
POPLC
   ACH := ++ ACH ,
   OUT b dm byte read
                     ; /* pop stack to cnt , increment
                       upper address bits */
   JMPC bgn release bus
                     ; /* check if bus grant has been
                       taken away
                                        */
                      /* loop back if counter not zero*/
   LOOPNZ x1
/*****
                /* end outer loop
                                                 */
done :
   . . . . . . . . . . . . . . . . . . .
   . . . . . . . . . . . . . . . . . . .
release bus :
   . . . . . . . . . . . . . . . . . . .
```

```
/* device to memory word transfer in the fly-by mode. The start address */
/* of the memory is loaded in R3 and R4 and the device number is loaded*/
/* in Q . For simplicity it is assumed that the block size is a multiple*/
                                                 */
/* of 64 and R5*64 = block size.
segment b dm word ;
   /* define equates */
   ban equ CC7
                   ; /* bus grant (active low)
                                         */
                 ; /* ready input
                                         */
   ready equ CC4
   b dm word norm equ h'00de' ; /* dma active w/o read/write */
b dm word read equ h'00d6' ; /* read (active low ) */
   b dm word write equ h'00c6'; /* write (active low )
                                            */
init b dm word :
   \overline{ACH} := R3
                      ; /* upper 16 bits address
                                            */
   SET ASEL ADOE HADOE
                       /* select counter to output ,
   ACL := R4
                        enable ADD and HAD output, and
                        load lower address in ACL
                                           */
   IOR := \sim Q ,
   OUT b dm word norm Q := 2
                      ; /* select device #
                                         */
                      ; /* address increment for word */
                      ; /* R5 * 64 -> block size (words)*/
   LDLCD , MOV R5 R5
/* start of outer transfer loop
                                                 */
x1: PLDLC H'1F'
                      ; /* push cnt to stack and load 32
                        in cnt
                                     */
/* start inner transfer loop
                                                 */
y1 : JMPNC ready y1 ,
   OUT b_dm_word_read ; /* wait till ready signal high
                                                * /
   LOOPNZ y1 ,
ACL := ACL + Q ,
   LOOPNZ yl
                     ; /* strobe the write signal and
   OUT b dm word write
                       set up the next address */
*/
/* end inner loop
POPLC
   ACH := ++ ACH ,
   OUT b dm word read
                      ; /* pop stack to cnt , increment
                       upper address bits */
   JMPC bgn release bus
                      ; /* check if bus grant has been
                                         */
                        taken away
                       /* loop back if counter not zero*/
   LOOPNZ x1
/* end outer loop
                                                 */
done :
   . . . . . . . . . . . . . . . . . . .
   . . . . . . . . . . . . . . . . . . .
release bus :
   . . . . . . . . . . . . .
```

4

/\* device to memory byte transfer in the fly-by mode. The start address \*//\* of the memory is loaded in R3 and R4 and the device number is loaded\*/ /\* in Q . For simplicity it is assumed that the block size is a multiple\*/ /\* of 64. This code illustrates individual transfer mode(non-block mode)\*/ segment s dm byte ; /\* define equates \*/ ; /\* bus grant (active low) \*/ bgn egu CC7 ; /\* ready input \*/ ready equ CC4 s dm byte norm equ h'00de' ; /\* dma active w/o read/write \*/ s dm byte read equ h'00d6' ; /\* read (active low ) \*/ s dm byte write equ h'00c6'; /\* write (active low ) \*/ init s dm byte : ACH := R3 ; /\* upper 16 bits address \*/ SET ASEL ADOE HADOE ACL := R4/\* select counter to output , ; enable ADD and HAD output, and load lower address in ACL BC := R5 ; /\* load block size in to BC IOR :=  $\sim Q$ , ; /\* select device # OUT s dm byte norm \*/ CMP Q H'0001' ; /\* find out if device #0 JMPC Z dev0 ; CMP Q H'0002' /\* if device # 1 \*/ ; JMPC Z dev1 ; CMP O H'0004' /\* if device # 2 \*/ ; JMPC Z dev2 ; /\* else it is device # 3 /\* start transfer loop for dev#3 \*/ dev3 : \*/ JMPC bgn release bus ; /\* monitor bus grant JMPNC CC3 dev3 ; /\* branch to check for dma request OUT s dm byte read \*/ from device3 SET ACEN BCEN , OUT s dm byte write /\* start counter \*/ ; RESET ACEN BCEN , OUT s dm byte norm /\* stop counter ; \*/ JMPNCBCZ dev3; /\* loop back if not done JMP done /\* start transfer loop for dev#2 \*/ dev2 : ; /\* monitor bus grant \*/ JMPC bgn release bus JMPNC CC2 dev2 ; /\* branch to check for dma request OUT s dm byte read from device2 \*/ SET ACEN BCEN , OUT s dm byte write ; /\* start counter \*/

| RESET ACEN BCEN ,                                                   |                                                         |
|---------------------------------------------------------------------|---------------------------------------------------------|
| OUT s_dm_byte_norm                                                  | ; /* stop counter */                                    |
| JMPNCBCZ devZ                                                       | ; /* loop back if not done */                           |
| JMP done                                                            | ;                                                       |
| ,                                                                   | ***************************************                 |
| /* start transfer loop for<br>/************************************ | /* /**********************************                  |
| dev1 :                                                              |                                                         |
| JMPC bgn release_bus<br>JMPNC CC1 dev1 ,                            | ; /* monitor bus grant */                               |
| OUT s_dm_byte_read                                                  | ; /* branch to check for dma request<br>from device1 */ |
| SET ACEN BCEN ,                                                     |                                                         |
| OUT s_dm_byte_write<br>RESET_ACEN_BCEN ,                            | ; /* start counter */                                   |
| OUT s dm byte norm                                                  | ; /* stop counter */                                    |
| $JMPNC \overline{BCZ} \operatorname{dev}\overline{1}$               | ; /* loop back if not done */                           |
| JMP done ;                                                          |                                                         |
| /******                                                             | * * * * * * * * * * * * * * * * * * * *                 |
| <pre>/* start transfer loop for</pre>                               | dev#0 */                                                |
|                                                                     | * * * * * * * * * * * * * * * * * * * *                 |
| dev0 :                                                              |                                                         |
| JMPC bgn release_bus<br>JMPNC CC3 dev0 ,                            | ; /* monitor bus grant */                               |
| OUT s_dm_byte_read                                                  | ; /* branch to check for dma request<br>from device3 */ |
| SET ACEN BCEN ,                                                     |                                                         |
| OUT s_dm_byte_write<br>RESET ACEN BCEN ,                            |                                                         |
| OUT s_dm_byte_norm                                                  | ; /* stop counter */                                    |
| JMPNCBCZ dev0                                                       | ; /* loop back if not done */                           |
|                                                                     |                                                         |
| ,                                                                   | ***************************************                 |
| done :                                                              |                                                         |
| • • • • • • • • • • • • • • • • • • • •                             |                                                         |
| release_bus :                                                       |                                                         |
|                                                                     |                                                         |

4

```
*/
/* code to illustrate device to memory transfer in non fly by mode .
/* This is used when data bus is connected d7-d0 to d15-d8 or the
                                                    */
/* other way around. Use counter to output addresses.Q contains device \ */
/* number and R3 R4 contain destination address.R5 contains block size. */
segment b dm sbyte ;
   /* define equates */
   b dm sbyte norm equ h'009e'
   b_dm_sbyte_read equ h'0096';
   b dm sbyte write equ h'008e';
   rdy equ CC4
                     ;
   bgn egu CC7
                     :
init b dm sbyte :
   \overline{BC} := R5 ,
                       /* load block size in bcnt */
   OUT b dm sbyte norm ;
                      ;/* select counter to output , */
   SET DIREN ASEL HADOE ADOE
                         enable had output
   ACH := R3
                 ;
   ACL := R4
*/
/* start of transfer loop
b dm sbyte :
   JMPC bgn release bus
                        ; /* enable DIR
                                                */
   SET DIREN
srdy :
   JMPNC rdy srdy ,
   OUT b dm sbyte read
                       ; /* wait till source ready
                                               */
   SET HDOE HDSELO ,
   AOR := DIR
                         /* when src is ready read the data
                     ;
                         in , enable HD output , select
                                           */
                         DOR to output
   DOR := SWPV
   OUT b dm sbyte write
                       ; /* put swapped data in DOR
                                                   */
   SET ACEN BCEN ,
                         /* start counter , output swapped
   OUT b dm sbyte norm
                     ;
                         data
                                            */
   RESET ACEN BCEN HDOE
                        ;
   JMPNC BCZ b dm sbyte
*/
/* end of transfer loop
done :
   . . .
release bus :
   . . . . . . . . . . . . . . . . . . .
```

#### Appendix 4 (Cont.) \*/ /\* code to illustrate memory to memory transfer.Use counter to output /\* both addresses.R1,R2 contain source address and R3 R4 contain dest \*/ \*/ /\* address . R5 contains block size. segment b mm byte ; /\* define equates \*/ b mm byte norm equ h'009e' ; b mm byte read equ h'0096'; b mm byte write equ h'008e'; $r\overline{d}y \ \overline{e}qu \ C\overline{C}4$ ; bgn equ CC7 ; init b mm byte : BC := R5 OUT b mm byte norm ; /\* load block size in bcnt \*/ SET ASEL HADOE ADOE ; /\* select counter to output enable had output \*/ /\* start of transfer loop \*/ b mm byte : JMPC bgn release bus , ACH := R1 /\* monitor bus grant , source ; address in R1 SET DIREN , ACL := R2 ; /\* enable dir, r2 <- low 6 bits \*/ srdy : JMPNC rdy srdy , OUT b mm byte read /\* wait till source ready \*/ ; SET ACEN HDOE HDSELO , DOR := DIR /\* when src is ready read the data in , enable HD output , select DOR to output \*/ RESET ACEN DIREN , R1 := ACH, OUT b mm byte norm ; /\* stop counter , store it back in \*/ to registers ADD R2 ACL Q ARDREG ACH R3 ; /\* mov ACL back to r1 and at the same time load r3 to ach ACL := R4/\* ach,acl have dest address \*/ : drdy : JMPNC rdy drdy ; /\* wait for destination ready \*/ SET ACEN BCEN , OUT b mm byte write ; /\* when dest is ready , write the data, increment counter , also enable block counter \*/ RESET ACEN BCEN HDOE , R3 := ACH , OUT b mm byte norm /\* stop counters , set HD to input ; save dest address (upper 16) \*/ JMPNC BCZ b mm byte , R4 := ACL ; /\* loop back if block counter not zero , also save lower 6 bits of dest address \*/ \*\*\*\*\*/ /\* end of transfer loop \*/ done : release\_bus : . . . . . . . . . . . . . . . . . .

/\* code to illustrate memory to memory transfer (word mode).Use counter \*/ /\* to output both addresses.R1,R2 contain source address and R3 R4 \*/ /\* contain destination address . R5 contains block size in words. \*/ segment b mm word ; /\* define equates \*/ b mm word norm equ h'009e' ; b mm word read equ h'0096' ; b mm word write equ h'008e'; rdy equ CC4 ; bgn equ CC7 ; init b mm word :  $\overline{BC} := R5$  , ; /\* load block size in bcnt \*/
; /\* select counter to output, OUT b mm word norm SET ASEL HADOE ADOE enable had output \*/ \*\*\*\*\*\*\*\*\*\* /\* start of transfer loop \*/ b mm word : JMPC bgn release bus , ACH := R1 /\* monitor bus grant , source ; \*/ address in R1 SET DIREN , ACL := R2 /\* enable dir,ACL <- low 6 bits \*/</pre> ; srdy : JMPNC rdy srdy , OUT b mm word read /\* wait till source ready \*/ ; SET ACEN HDOE HDSEL0 , DOR := DIR /\* when src is ready read the data ; in , enable HD output , select DOR to output OUT b mm word norm ; RESET ACEN DIREN , ADD R1 ACH Q ARDREG ACH R3 ; /\* stop counter , store ACH in to R1 and also load ACH with R3 \*/ ADD R2 ACL Q ARDREG ACL R4 ; /\* store ACL in R2 and at the same time put R4 in to ACL \*/ drdy : JMPNC rdy drdy ; /\* wait for destination ready \*/ SET ACEN BCEN , OUT b mm word write /\* when dest is ready , write the ; data, increment counter , also enable block counter \*/ RESET BCEN HDOE , OUT b mm word norm /\* stop block counter, set HD to ; \*/ input RESET ACEN , R3 := ACH ; /\* stop add counter , save dest address (upper 16) \*/ JMPNC BCZ b mm word , R4 := ACL/\* loop back if block counter not : zero , also save lower 6 bits of dest address \*/ \*\*\*/ /\* end of transfer loop done : release bus : . . . . . . /\*\*\*\*\*\*

```
/* code to illustrate memory to memory transfer from D7-D0 to D15-D8 */
/* or vice-versa. Use counter to output both addresses .R1 , R2 contain */
/* source address and R3 R4 contain destination address.R5 contains */
/* block size. Data is read in to AOR and byte-swpped before outputting */
                                                        */
/* through DOR.
****/
segment b mm sbyte ;
   /* define equates */
   b mm sbyte_norm equ h'009e'
   b mm sbyte read equ h'0096' ;
   b mm sbyte write equ h'008e';
   rdy equ CC4
                      ;
   ban eau CC7
                      ;
init b mm sbyte :
   BC := R5,OUT b mm sbyte norm; /* load block size in bcnt */
   SET ASEL HADOE ADOE ;
                            /* select counter to output ,
                               enable had output
                                                      * /
/* start of transfer loop
                                                        */
b mm sbyte :
   JMPC bgn release_bus ,
   ACH := R1
                           /* monitor bus grant , source
                ;
                                          */
                           address in R1
   SET DIREN , ACL := R2
                        ; /* enable dir, r2 <- low 6 bits */
srdy: JMPNC rdy śrdy,
   OUT b mm sbyte read
                         ; /* wait till source ready
                                                  */
   SET ACEN HDOE HDSELO ,
   AOR := DIR
                     :
                           /* when src is ready read the data
                           in , enable HD output , select
                           DOR to output
                                              */
   RESET ACEN DIREN, R1 := ACH ,
                           /* stop counter , store it back in
   OUT b mm sbyte norm
                         ;
                                             */
                           to registers
   ADD R2 ACL Q ARDREG ACH R3 ;
                          /* mov ACL back to r1 and at the
                           same time load r3 to ach */
   ACL := R4
                         ; /* ach,acl have dest address
drdy : JMPNC rdy drdy, DOR := SWPV ; /* wait for destination ready
                           and write swapped value
                                                   */
   SET ACEN BCEN ,
   OUT b mm sbyte write
                         ; /* when dest is ready , write the
                          data, increment counter , also
                           enable block counter
                                              */
   RESET ACEN BCEN HDOE ,
   R3 := ACH ,
   OUT b mm sbyte norm
                         ; /* stop counters , set HD to input
                           save dest address (upper 16) */
   JMPNC BCZ b mm sbyte ,
   R4 := ACL
               ;
                           /* loop back if block counter not
                           zero , also save lower 6 bits
                           of dest address
                                               */
/* end of transfer loop
                                                        */
done :
   . . . . . . . . . . . . . . . . . . . .
release bus :
   . . . . . . . . . . . . . . . . .
```

```
/* code to illustrate device to device transfers in the byte as well as */
/* word mode. source device is in r1 and dest device is in r3. block
                                              */
                                              */
/* size is in r5.
segment b dd bw ;
   /* define equates */
   b dd bw norm equ h'009e'
   b_dd_bw_read equ h'0096'
   b dd bw write equ h'008e';
   rdy equ CC4
                  ;
   bgn egu CC7
                  ;
init b dd bw :
   SET DIREN , IOR := ~ R1 ,
   OUT b dd bw_norm
                       /* enable DIR and output source
                                       */
                       device chip select
/* start of transfer loop
                                              */
b dd byte :
b dd word :
b dd bw :
   JMPC bgn release bus ,
   IOR := \sim R3 ,
   OUT b dd bw read
                  ; /* read source device and output
                    dest device chip select , also
                   monitor bus grant
                                    */
   SET HDOE HDSELO ,
   DOR := DIR ,
   OUT b dd bw norm
                 ; /* enable HD output , select DOR
                                    */
                    to output
   RESET HDOE ,
   DEC R5 .
   OUT b dd bw write
                  ; /* HD to input , decrement count ,
                    output write strobe
                                   */
   JMPNC Z b dd bw ,
   IOR := \sim \overline{R1} ,
                  ; /* loop back if R5 not zero , also
   OUT b dd bw norm
                                      */
                   output src device cs
/* end of transfer loop
                                              */
done :
   release bus :
```

```
/* code to illustrate device to device transfer in non fly by mode .
                                               */
/* This is used when data bus is connected d7-d0 to d15-d8 or the
                                               */
/* other way around. Source device # is in R1 and dest device # in R3
                                               */
segment b dd sbyte :
   /* define equates */
   b dd sbyte norm equ h'009e' ;
   b dd sbyte read equ h'0096'
   b dd sbyte write equ h'008e';
   rdy equ CC4
                   ;
   bgn equ CC7
                   ;
init b dd sbyte :
   SET DIREN , IOR := ~ R1 ,
   OUT b dd sbyte norm
                     ; /* enable DIR and output source
                                       */
                      device chip select
/* start of transfer loop
                                               */
b dd sbyte :
   JMPC bgn release bus ,
   IOR := \sim R3 ,
   OUT b dd sbyte read
                     ; /* read source device and output
                       dest device chip select , also
                                       */
                       monitor bus grant
                                       */
   AOR := DIR
                     /* read in the data
                  ;
   SET HDOE HDSEL0 ,
   DOR := SWPV ,
   OUT b dd sbyte write
                     ; /* enable HD output , select DOR
                      to output, put swapped data in
                                    */
                      DOR
   RESET HDOE ,
   DEC R5 ,
   OUT b dd sbyte_norm
                     ; /* HD to input , decrement count ,
                      output write strobe
                                       */
   JMPNC Z b dd sbyte ,
                     ; /* loop back if R5 not zero , also
   IOR := \sim R1
                                         */
                      output src device cs
/* end of transfer loop
                                               */
done :
   release_bus :
```



# Programmable System<sup>™</sup> Device

Application Brief 006

PAC1000 as a 16 Bi-Directional Serial Channel Controller By Arve Ziklik

|                             | By Arye Zikli                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ik                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                | This Application Brief describes a<br>Communications Controller that utilizes the<br>PAC1000 as the board level control element<br>in a 16 bi-directional serial channel board.<br>The aggregate board throughput is around<br><i>1 Mbyte/sec.</i><br>Serialization and de-serialization of the<br>data is handled by eight Serial<br>Communication Controllers (SCC). Every                                                                                                                                                                                                                                         | SCC has two bi-directional serial channels<br>with individual baud rate generator and<br>digital phase loop mechanism. The SCC<br>can handle all the customary synchronous<br>and asynchronous protocols as well as the<br>popular serial data encoding/decoding<br>schemes. With a 16-MHz clock, the<br>maximum bit rate in every individual<br>channel can be up to 2 Mbps.                                                                                                                                                                                                                             |
| PAC1000 —<br>Host Interface | The PAC1000 performs the low level<br>function of moving the data to and from<br>the serial devices and buffer RAM memory.<br>The host interface is a generic 32-bit<br>system. The host processor communicates<br>with the PAC1000 through two interrupt<br>lines, two status signals and a mail-box<br>area that resides in the buffer memory.<br>Prior to accessing the board, the host<br>drives the "system board access" signal.<br>The PAC1000 is interrupted (INT3) and<br>relinquishes control of the board's data<br>and address buses as long as that signal<br>is active (as reflected by CC0). The host | reads and/or writes into the buffer memory.<br>After completion of this activity, it updates<br>the mail-box region and then lowers the<br>"system board access" signal. The PAC1000<br>continuously monitors that signal. After<br>CC0 is negated, the PAC1000 can raise its<br>"PAC1000-board master" signal and start<br>controlling the data/address buses and<br>control signals. Whenever it needs a fast<br>response from the host, the PAC1000<br>updates the mail-box portion of the shared<br>buffer memory, lowers the "PAC1000-board<br>master" signal and activates the system<br>interrupt. |
| Buffer Memory<br>Structure  | The high speed buffer memory is composed<br>of 64K bytes of static RAM that can be<br>accessed in three ways: by bytes (during<br>SCC transfer operations), by words (when<br>accessed by the PAC1000), or by double<br>words (from the host side). Memory access<br>configuration is determined by the PAC1000<br>output control signals (OC port).<br>The buffer memory is divided into three                                                                                                                                                                                                                      | Whenever instructed to do so, the PAC1000<br>writes the image register content of a<br>channel into the corresponding SCC,<br>thereby initializing that channel for a<br>particular transfer mode. Buffer message<br>sizes are allocated by the host according<br>to the speed of each individual channel.<br>The pointers of the buffers are stored in<br>the mail-box area.                                                                                                                                                                                                                             |
|                             | <ol> <li>SCC control image register space that<br/>includes copies of the SCC registers.</li> <li>Buffer message space where the 32<br/>buffers of the corresponding serial<br/>channels are stored.</li> <li>Mail-box area in which the PAC1000<br/>exchanges command and status<br/>information with the host. This region<br/>also contains the pointers to the 32<br/>channel buffers.</li> </ol>                                                                                                                                                                                                                | Every transfer takes place between the<br>buffer memory and the selected SCC. The<br>PAC1000 is acting in this design as a<br>32-channel DMA controller, capable also of<br>communicating with the host processor<br>through their mail-box region. Once the<br>board is properly configured, the only<br>interface of the host system is the reading<br>of data from the receive and mail-box<br>buffers and the placing of new data into<br>the transmit and mail-box buffers. The<br>PAC1000 off-loads the host processor from<br>maintaining the low level control of each<br>channel.                |

#### PAC1000 — SCC Devices Interface

The high speed data transfers are achieved due to the very fast response of the PAC1000 to the channel service requests. The SCCs are programmed to request DMA transfers whenever they are either ready to transmit or containing new received characters.

The 16 received character DMA requests are priority encoded and latched. The encoder output is connected to the PAC1000's CC3 pin. The 16 transmit DMA requests are priority encoded and latched, too. Their encoder drives the CC2 input pin. The condition code multiplexer presents to the CC7-CC4 the highest priority encoded-channel-number of the pending receiver request, or the transmitter request. or the highest priority SCC number that is currently requesting an interrupt service via the CC1 pin. The receiver requests have higher priority over the transmitter requests. The lowest service priority is assigned to the SCC interrupts. This configuration ensures a very fast response

time of the PAC1000 to DMA requests and SCC interrupts. Condition code latency is 125 ns and multi-way branching according to the CC7–CC4 lines requires additional 125 ns. Therefore, 250 ns after a high priority DMA request, the service routine will be initiated. The condition code lines CC3, CC2 and CC1 are continuously monitored by the PAC1000 during the time that it is the board master. Therefore it responds immediately when either a DMA request or an SCC interrupt is pending.

The regular SCC interrupt lines are also prioritized and latched by an 8 interrupt encoder. These interrupts are requested by erroneous SCC channels or whenever block transfers are completed. The interrupt priority encoder is also connected to the condition code multiplexer. The three encoded lines that denote the number of the serviced SCC route the INTA signal issued by the PAC1000 (via the I/O6 pin) to the corresponding SCC.

# Miscellaneous

In addition to functioning as an SCC controller, the PAC1000 can also generate all the necessary signals for modem control and modem interface through the SCC control signal latch.

The PAC1000 output control (OC) port generates various control strobes such as data path width definition, read/write, multiplexer and decoder select, etc.



WAFERSCALE INTEGRATION, INC. 4-73



# Programmable System<sup>™</sup> Device

Application Note 008

PAC1000 User-Configurable Microcontroller with a Built-In-Self-Test Capability By David Fong

|                          | by David Fully                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Abstract                 | The objective of this Application Note is to demonstrate the Built-In-Self-Test (BIST) capability of the PAC1000 High-Performance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | User-Configurable Microcontroller. This article describes the basic instructions needed to implement BIST.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Introduction             | With increasing device densities on one<br>chip, more devices are needed for BIST to<br>check the functionality of the internal logic.<br>Current serial scan techniques for board<br>level verification would take too much time<br>and resources. The current PAC1000 will                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | only test the ALU and its status flags, the<br>address and block counter, and the<br>sequencer. Future versions in the WS-PAC<br>Family will have even larger sizes of<br>EPROM and may test the control EPROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Usage and<br>Limitations | The program is accessible by calling the<br>BIST program. The program occupies<br>forty-five lines of EPROM code. The<br>program can be reduced in size by<br>specifying extra CPU registers to hold the<br>constants h'FFFF', h'0000', h'AAAA', h'5555'<br>and h'FFF4'.<br>Certain conditions must be met prior to<br>programming the code to ensure that this<br>program will work correctly. The stack<br>should be empty because the program<br>exercises the stack. In addition, location<br>h'3FF' must be reserved because the BIST<br>uses this location to verify the contents of<br>the stack as a '1.' The outputs should be<br>placed in a mode where the existing<br>system is not affected. The 'MAINT'<br>instruction will ensure that the OC is the<br>same throughout the program. However,<br>this example was not implemented in that<br>manner. Instead, it uses set values to<br>assist in debugging the program. Users<br>can do a global substitution of "OUT<br>h'xxxx' " with "MAINT" in their word<br>processor to fully implement this BIST<br>program. | This BIST is not a panacea for system<br>designers. A 'PASS' condition is indicated<br>by a return to the main calling program.<br>The output control will be h'0000'. A 'FAIL'<br>condition will result in some endless loop<br>or jump to some portion of the program. If<br>the event that it does fail after about 170<br>clock cycles, the system must disable the<br>PAC1000 from the rest of the system in<br>some manner. Future versions of the<br>PAC1000 may include a watchdog timer to<br>interrupt and timeout the BIST.<br>The variables that can be altered by the<br>user are listed at the beginning of the<br>BIST.mal file. The current values used will<br>only exercise the counters in a simple<br>manner. The user can modify these<br>variables to increase the confidence level<br>of the program at the expense of a longer<br>test cycle. |

| <i>Usage and<br/>Limitations<br/>(Cont.)</i>                                                                                                                                                                          | A summary of the instructions used and<br>the functional blocks follow below:<br>/************************************                                                                                                                                                                                   |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            | Confidence<br>Level        | The program executes some of the possible<br>internal critical paths of the PAC1000.<br>From tester and simulation measurements,<br>the test of condition codes and branching<br>were consistently the longest. Similarly for<br>the ALU, flag generation such as adding                            | with a carryout is considered a critical<br>path. The counters have a critical path in<br>propagating the carry. Overall, the<br>confidence level of this test is considered<br>to be high.                                                                 |
|                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            | Analysis of the<br>Program | The currently executing program calls the<br>BIST program by using the 'CALL'<br>instruction. The instruction following 'CALL'<br>which is the return address is pushed to<br>the stack and is not destroyed by the BIST<br>program. See Figure 1 for the BIST<br>flowbart. The DIST tests the BIST | are set and reset by instructions. The ALU<br>result of each cycle updates each flag on<br>the next rising edge of the clock. For<br>example, to check the zero flag (Z), some<br>ALU instruction forces the Z flag to zero.<br>See the instructions below: |
|                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            | flowchart. The BIST tests the PAC1000<br>functional blocks in the following order:                                                                                                                                                                                                                  | MOV R2 R2 , OUT h'0138' ;<br>/* force zero flag Z=0 */                                                                                                                                                                                                      |
| 1. Block Counter and flag BCZ.                                                                                                                                                                                        | <ul> <li>zero: JMPNC Z zero, AND AOR R1,<br/>OUT h'0139';</li> <li>Next, loading the loop counter from the<br/>ALU needs special treatment. The data<br/>must be present at the ALU output before<br/>the instruction to load the loop counter<br/>executes. See the instructions below:</li> </ul>      |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
| 2. Address Counter and flag ACO.                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
| <ol><li>ALU with shifter and flags CY, Z, O<br/>and S.</li></ol>                                                                                                                                                      |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
| <ol> <li>Sequencer with stack and loop counter,<br/>and flag STKF.</li> </ol>                                                                                                                                         |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
| Some subtleties of programming the<br>PAC1000 are presented. In the ALU section,<br>certain flags must be forced to zero before<br>being tested upon, unlike the normal<br>microprocessors where the individual flags | MOV R4 short, OUT h'014B' ;<br>/* force ALU output to the<br>value of short = h'0010' */<br>LDLCD , MOV R4 R4, OUT h'014C' ;<br>/* load 0010 to LC */                                                                                                                                                    |                                                                                                                                                                                                                                                            |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |
| Analysis of the<br>Simulation<br>Output                                                                                                                                                                               | Looking at the block counter outputs<br>BC(15:0) from cycle 7 through 18, the<br>counter counts continuously until disabled.<br>The block counter contents wraps around<br>from h'0000' to h'ffff' and down. Note that<br>the BCZ flag remains latched until new<br>data is loaded to the block counter. | Because of the latched flag BCZ, there is<br>a minimum of two cycles before the next<br>instruction is executed after the loop.<br>Figure 2 shows the loop with the minimum<br>number of latency cycles before executing<br>the next line of program code. |                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                             |

# Figure 1. Built-In-Self-Test Flowchart





```
*/'
/* Built-In-Self-Test Program 02/03/89
                                                            */
/* David A. Fong
                            Rev. 1.0
                                                            */
/* bist.mal
*/
/* registers destroyed : R0,R1,R2,R3 and R4
/*
                                                            */
                       AOR, ACH, ACL, BC, LC and stack
/*
                                                            */
/* stack should be empty before calling this program
                                                            */
                                                            */
/*
/* the block counter, address counter, ALU with register file and*/
/* flags, and the sequencer with stack and counter are tested
                                                            */
/*
                                                            */
/* flags checked: BCZ,ACO,CY,Z,O,S,and STKF
                                                            */
/* ALU instructions used: ADC, AND, ADD, MOV, NOP, SHRR, SHRL, SUB
                                                            */
                                                            */
/* CONTROL instructions used: ACSIZE, CONT, JMPNC, JMPC, LDLCD,
/*
                                                            */
             LOOPNZ, PLDLC, POP, RET, RNC, RSTCON and SETCON
/*
                                                            */
/*DATA from EPROM used: 0000, FFFF, FFF4, AAAA, 5555 ,0008 , 0010*/
/*
              03FF, 0019
                                                            */
segment c bist ;
entry bist,jmpf ;
                  /* entry points into this program */
/* define equates for user to substitute */
shorter equ h'0008' ;
short
         equ h'0010'
                    :
medium
         equ h'03ff' ;
         equ h'fff4' ;
long
popper
         equ h'0019';
/*********************************
/* test the counters and
                         */
/* initialize the registers */
bist:
         MOV R1 h'0000', OUT h'0124'; /*the outputs should be placed*/
                                /* in a non-functional mode */
         MOV R0 h'FFFF' , OUT h'0125' ; /* in this program it is not*/
         MOV BC shorter , OUT h'0126' ;/*because it was needed to*/
         SETCON h'002', OUT h'0127' ; /*debug enable block counter */
         MOV R2 h'5555', OUT h'0128';
JMPNC BCZ loop1 , OUT h'0129';
loop1:
RSTCON h'002', OUT h'012A'; /* disable block counter */
/* R0 = FFFF ; R1 = 0000 ; R2 = 5555 */
/* test the 22-bit address counter */
         ACSIZE 22 , MOV ACH R0 , OUT h'012B' ;
         MOV ACL long , OUT h'012C' ;
         SETCON h'001' , OUT h'012D' ; /* enable address counter */
```

MOV R3 h'AAAA' , OUT h'012E' ; loop2: JMPNC ACO loop2 , OUT h'012F' ; RSTCON h'001', OUT h'0130' ; /\* disable address counter \*/ /\* R0 = FFFF ; R1 = 0000 ; R2 = 5555 ; R3 = AAAA \*/ /\* test the 16-bit address counter \*/ ACSIZE 16 , OUT h'0131' ; MOV ACH long, OUT h'0132'; SETCON h'001', OUT h'0133'; /\* enable address counter \*/ MOV R4 h'0000', OUT h'0134'; loop3: JMPNC ACO loop3 , OUT h'0135' ; RSTCON h'001' , MOV R3 R3 , OUT h'0136' ; /\* disable address counter \*/ /\* and do a dummy ALU instruction so that Z=0 and CY=0 \*/ /\* note: a NOP instruction will force Z=1 and CY=1 on the \*/ /\* following cvcle\*/ /\* R0 = FFFF ; R1 = 0000 ; R2 = 5555 ; R3 = AAAA ; R4 = 0000 \*/ /\* R4 is the working register \*/ /\*\*\*\*\*/ /\* test the ALU \*/ /\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*/ JMPNC CY carry , ADC AOR R0 , OUT h'0137' ;/\*test carryout \*/ carry: MOV R2 R2 , OUT h'0138'; /\* force zero flag = 0 \*/ JMPNC Z zero , AND AOR R1 , OUT h'0139' ;/\*test all the alu\*/ zero: /\* outputs are zero \*/ SUB AOR R3 R2 , OUT h'013A' ; /\* test for overflow \*/ over: JMPNC 0 over , OUT h'013B' ; /\* test for overflow \*/ f15: JMPNC S f15 , ADD AOR R1 R0 , OUT h'013C' ;/\*test sign bit\*/ /\* test the alu shifting \*/ shftl: SHLR R2 Z , OUT h'013D' ; AND AOR R3 R2 , OUT h'013E' ; /\*should not loop\*/ /\*but fall-thru \*/ JMPC Z shftl , OUT h'013F' ; shftr: SHRR R2 Z , OUT h'0140' ; AND AOR R3 R2 , OUT h'0141' ; /\* should not loop, but fall-thru \*/ JMPNC Z shftr , OUT h'0142' ; /\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* /\* test the sequencer \*/ /\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*/ MOV BC short , OUT h'0143' ;

SETCON h'002' , OUT h'0144' ; /\* enable block counter \*/ stack: PLDLC medium , OUT h'0145' ; JMPNC STKF stack , OUT h'0146'; /\*exit loop when stack is full \*/ /\* the return address will not be \*/ /\* overwritten , only the top of stack\*/ MOV BC popper , OUT h'0147' ; RNC BCZ, OUT h'0148'; jmpf: /\*should come out of loop when empty+1\*/ /\* which is the return address \*/ POP, NOP, OUT h'0149'; /\* pop one more time but don't pop \*/ /\* the last return address \*/ RSTCON h'002', OUT h'014A'; /\* disable block counter \*/ /\* test the loop counter \*/ MOV R4 short , OUT h'014B' ; LDLCD , MOV R4 R4 , OUT h'014C' ;/\* load 16 into the LC\*/ lp: ADC AOR R4 , OUT h'014D' ; /\* aor = aor + r4 \*/LOOPNZ lp , OUT h'014E';/\*check that loop count is not zero\*/ RET , OUT h'014F' ; /\* return to calling program \*/ end ; /\* bist linker file 02/03/89 \*/ /\* David Fong \*/ Rev. 1.0 \*/ /\* exbist.ml place main , c\_bist , jmp ; /\* place the segments \*/ load main , bist , jmpf ; /\* load the .mal files \*/ locate main , h'000' ; /\* locate main and init file \*/
locate c\_bist , h'011' ; /\* locate bist file after interrupt \*/ locate jmp , h'3ff' ; /\* locate jmp at 3ff to test '1' from stack \*/ end ; .т  $\mathbf{E}$ 3210 543210 5432101111119876543210 т 543210 в TIME 1 2 



# **Programmable System™Device**

Application Note 009

In-Circuit Debugging for the PAC1000 User-Configurable Microcontroller By David Fong

| Abstract                 | This Application Note is used to illustrate the in-circuit debugging capabilities of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PAC1000 user-configurable microcontroller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction             | With the increasing densities and<br>complexities of integrated circuits, the<br>usage of tools such as in-circuit debuggers<br>and emulators is greatly desired by the<br>heroic hardware designer. The PAC1000<br>supports the usage of in-circuit debuggers.<br>A review of BP (breakpoint) and SS (single<br>step) is discussed. SS is the method of<br>stepping through the program code one<br>instruction at a time through manual means.<br>In the case of the PAC1000, there is no<br>manual means with a single-step switch.<br>Instead, an interrupt which is set internally<br>through the program is set. This interrupt<br>can then call upon an ISR (interrupt service<br>routine). This subroutine then dumps out<br>the contents of all the possible registers<br>that can be read out. These registers must<br>then be written into the system memory by                                                                                                                                                                                                                                                                                               | the user to use in his monitor program. SS<br>is useful for checking that every cycle is<br>executing correctly.<br>On the other hand, BP is the method of<br>interrupting the program at a specific<br>program location. This allows the program<br>in the PAC1000 to run in real-time system<br>conditions. This breakpoint is passed to<br>the PAC1000 through the FIFO instead of<br>having a fixed address through the program.<br>BP is useful for intermittently checking the<br>execution of the program.<br>There is no preference on which method is<br>the best. Generally, it is determined by the<br>situation. If the system designer doesn't<br>trust their own system in the beginning of<br>debug, then they will use SS. After the<br>system becomes more debugged,<br>breakpoint is needed occasionally.                                                                                                                                                                                                                                  |
| Usage and<br>Limitations | Either SS or BP interrupts can occur.<br>Because both use the same initial ISR, the<br>ISR will differentiate between the two by<br>testing for a specific data pattern that<br>accompanies the breakpoint/single-step<br>data through the FIFO. One way was to<br>test for a specific external condition code<br>but that was determined to be inflexible<br>since a specific condition code needed to<br>be dedicated for this task. Instead, two<br>words are written into the CPU registers.<br>These two registers must be reserved for<br>breakpoint/single-step operation. In this<br>example, R0 and R1 are reserved.<br>Register R1 is the mask that is 'AND'd<br>with R0 which is written from the FIFO to<br>produce the Z (zero) flag that is tested.<br>See Figure 1 for the data format that is<br>written into the FIFO and CPU register R0.<br>The BP state continues with its program<br>by reading out the contents of some<br>registers to the host interface bus. Note<br>the usage of the FIFO to read out the<br>contents of the register to the ADD bus.<br>BP reads out only the input and output<br>registers that can be read as source to the | HD bus. Whereas, SS reads out the CPU<br>registers as well as the input and output<br>registers to ADD.<br>Not all the registers can be read out or if<br>at all with difficulty. CPU registers as was<br>illustrated by this program was read out<br>using the FIFO. However, the user could<br>have individually read out each register.<br>Unfortunately, there would have been a lot<br>of overhead program space taken. The<br>stack cannot be read out because the<br>contents of the stack would affect the<br>program flow. The interrupt mask register<br>and interrupt pending register cannot be<br>read out or to the CPU. Future PAC1000<br>versions may support extra functions to<br>allow the user to more easily access the<br>internal registers.<br>In summary, the single-step program dumps<br>out the following registers to the ADD bus:<br>CPU registers R31–R0, DIR, AIR, ACH,<br>ACL, IIR, and BC. Whereas, the breakpoint<br>program dumps out the tollowing registers<br>to the HD bus: DIR, AIR, AOR, ACH, ACL,<br>IIR, and BC. |

## Analysis of Program

This single program incorporates essentially two programs. One for breakpoint and one for single-step. To differentiate between the two programs since they use the same interrupt INT6, the data in register R0 is tested upon and the corresponding action is taken. If Z is true, then breakpoint will occur, else single-step will occur. See BREAKPOINT/SINGLE-STEP algorithm Figure 2.

Note that the Interrupt Jump Table is located at h'008' through h'00f'. The PAC1000 interrupt vector from the internal interrupt jumps to these individual locations. In addition, note that neither conditional nor unconditional jumps were allowed to be executed when either the breakpoint or the single-step interrupts occurred. This also applies to other interrupts. The delay interval from the time of interrupt to executing the interrupt is two cycles. See Figure 3 for the timing relationship of interrupt to the beginning of execution of the interrupt service routine (ISR).

The single-step subroutine utilizes the FIFO to externally address the CPU dualport registers. The usage of the FIFO in conjunction with loops reduces the size of the control store. However, the contents of the FIFO must be empty before using it.









```
/* Main program
                       04/03/89 */
/* David Fong
                                */
                  Rev. 1.0
/* main.mal
                                */
segment main ;
entry main1 ;
main1 :
/* BEGIN MAIN PROGRAM
                                             */
/* initialize registers */
R1 := h'1000', OUT h'0050' ;/* the twelveth bit R1.12 tests for BP/SS*/
/* IF Z=1 (which means R1.12 = 0 ) THEN run breakpoint program */
/* ELSE run single-step program */
R2 := h'0002', OUT h'0051';
             , OUT h'0052'
R3 := h'0003'
             , OUT h'0053'
R4 := h'0004'
             , OUT h'0054'
R5 := h'0005'
             , OUT h'0055'
R6 := h'0006'
             , OUT h'0056'
R7 := h'0007'
R8 := h'0008' , OUT h'0057'
R9 := h'0009', OUT h'0058'
R10 := h'000a', OUT h'0059'
R11 := h'000b' , OUT h'005a'
R12 := h'000c', OUT h'005b'
              , OUT h'005c'
R13 := h'000d'
              , OUT h'005d'
R14 := h'000e'
              , OUT h'005e'
R15 := h'000f'
R16 := h'0010', OUT h'005f'
R17 := h'0011', OUT h'0060'

R18 := h'0012', OUT h'0061'

R19 := h'0013', OUT h'0062'
             , OUT h'0063'
R20 := h'0014'
R21 := h'0015'
              , OUT h'0064'
              , OUT h'0065'
R22 := h'0016'
                           ;
              , OUT h'0066'
R23 := h'0017'
              , OUT h'0067'
R24 := h'0018'
R25 := h'0019', OUT h'0068'
R26 := h'001a', OUT h'0069'
R27 := h'001b' , OUT h'006a'
R28 := h'001c'
                OUT h'006b'
              ,
              , OUT h'006c'
R29 := h'001d'
R30 := h'001e'
              , OUT h'006d'
R31 := h'001f' , OUT h'006e' ;
ACH := R31 , OUT h'006f' ;
ACL := R0 , OUT h'0070' ;
AOR := R1 , OUT h'0071'
                      ;
DOR := R15 , OUT h'0072'
                       ;
BC := R7 , OUT h'0073' ;
```

/\* all input registers are initialized to zero from RESET \*/ /\* to integrate two different programs 1. BREAKPOINT 2. SINGLE-STEP\*/ /\* The result of masking R0 with  $\overline{R1}$  is used to differentiate \*/ /\* between BP and SS. \*/ /\* IF Z = 1 Breakpoint; ELSE Z = 0 Single-Step \*/ g0: JMPC FICD g0 , OUT h'0074' ; /\*check that the fifo contents is data LDBPD , RDFIFO , OUT h'0075'; /\* FIFO was loaded with h'0 00 007a' \*/ /\* first 0 is FICD ; 00 is B address ; 0 is the test bit ; \*/ /\* 07a is the EPROM breakpoint address. \*/ /\* Load loop counter with same data read from FIFO : LDLCD; \*/ /\* the data written into the CPU is the same as the CPU output bus \*/ AND R1 R0 , OUT h'0076' ; /\* the Z flag is tested in the next cycle \*/ JMPC Z b0 , OUT h'0077' ; /\* select single-step interrupt \*/ ESS , OUT h'0078' ; JMP c0 , OUT h'0079' ; /\* skip breakpoint routine \*/ /\* perform alu operations till interrupt comes \*/ b0: R2 := R2 + R1 , OUT h'007a' ; /\* breakpoint on this address h'07a' R3 := R3 + R1, OUT h'007b'; R4 := R4 + R1 , OUT h'007c' ; /\* breakpoint interrupt comes here \*/ /\* return from ISR to here \*/ e0 : JMP e0 , OUT h'007d' ; /\* loop forever ; end of breakpoint \*/ c0: R5 := R5 + R1 , OUT h'007e' ; /\* execute till interrupt comes \*/ R6 := R6 + R1 , OUT h'007f' ; /\* interrupt should after here \*/ /\* return from single-step ISR to here \*/ /\* enable single-step interrupt and perform an operation \*/ ENABLE INT6 , R7 := R7 + R1 , OUT h'0080' ; /\* the output for R2 \*/ /\* should be h'1002' \*/ R8 := R8 + R1 , OUT h'0081' ; /\* interrupt should come here \*/ /\* return from single-step ISR to here \*/ f0 : JMP f0 , OUT h'0082' ; /\* loop forever \*/ end ; /\*SINGLE-STEP SUBROUTINE 04/03/89\*/ /\* David Fong Rev. 1.0 \*/ /\* single.mal \*/ segment single ; entry single1 ; single1 : /\* read out the registers from the ALU \*/ /\* use the addressing scheme from the FIFO \*/

```
SETCON h'010' , OUT h'2000' ; /* set ADD bus to output */
    /* to read out AOR to ADD */
    /* loop four times to address the 32 registers */
    FOR 3 , OUT h'2001' ;
    /* FIFO should already be full */
f0 : JMPC FIIR f0 , OUT h'2002' ; /* loop till FIFO is full*/
    /* check that the first value in the FIFO is a data */
f1 : JMPC FICD f1 , OUT h'2003' ;
    /* loop eight times to empty the FIFO */
         FOR 7 , OUT h'2004' ;
    /* use the FIFO as an address pointer */
    /* the data is not needed; write the data back to CPU */
    /* and output the CPU output to AOR */
    /* the default CPU instruction is add which adds zero and */
    /* the address pointed by the FIFO which is the B address */
         RDFIFO , alu src = zb , ybus sel = y aoreq ,
         OUT h'2005';
         ENDFOR , OUT h'2006' ;
    ENDFOR , OUT h'2007' ;
    /* read out the source registers to ADD */
    MOV AOR DIR , OUT h'2008' ; /* 0000 should come out next cyle */
    MOV AOR AIR , OUT h'2009' ; /* 0000 */
    MOV AOR ACH , OUT h'200a' ; /* 001f */
    MOV AOR ACL , OUT h'200b' ; /* 0000 */
    MOV AOR IIR , OUT h'200c' ; /* 0000 */
    MOV AOR BC , OUT h'200d' ; /* 0007 */
    RET , OUT h'200e' ; /* return to ISR 6 */
end ;
/* INTERRUPT JUMP TABLE 04/03/89*/
/* David Fong
                   Rev. 1.0
                                */
/* intserv.mal
                                */
segment intserv ;
entry int serv ;
external int0, int1, int2, int3, int4, int5, int6, int7 ;
int_serv :
     JMP int0 , OUT h'0008' ;
     JMP int1 , OUT h'0009' ;
     JMP int2 , OUT h'000a' ;
     JMP int3 , OUT h'000b' ;
```

```
JMP int4 , OUT h'000c' ;
    JMP int5 , OUT h'000d' ;
    JMP int6 , OUT h'000e' ;
    JMP int7 , OUT h'000f' ;
end ;
/* Interrupt Service Routines 04/03/89
                                                    */
                           Rev. 1.0
/* David Fong
                                                    */
/* int.mal
                                                    */
segment int ;
entry int0 , int1 , int2 , int3 , int4 , int5 , int6 , int7 ;
external single1 ;
int0 :
    /* clear all the external interrupts */
    CLI h'00f' , OUT h'0100' ;
    RET , OUT h'0101' ;
int1 :
    /* clear all the external interrupts */
    CLI h'00f' , OUT h'0102' ;
    RET , OUT h'0103' ;
int2 :
    /* clear all the external interrupts */
    CLI h'00f' , OUT h'0104' ;
    RET , OUT h'0105' ;
int3 :
    /* clear all the external interrupts */
    CLI h'00f' , OUT h'0106' ;
    RET , OUT h'0107' ;
int4 :
    /* mask that interrupt */
    DISABLE INT4 , OUT h'0108' ;
    RET , OUT h'0109' ;
int5 :
    /* mask that interrupt */
    DISABLE INT5 , OUT h'010a' ;
    RET , OUT h'010b' ;
int6 : /* Breakpoint and Single-step ISR */
    /* mask that interrupt */
    DISABLE INT6 , OUT h'010c' ; /* mask interrupt 6 INT6 */
    CLI h'Off' , OUT h'O1Od' ; /* clear all interrupts */
/************* TEST for Breakpoint/Single-Step ***********/
     AND R1 R0 , OUT h'010e' ;
     JMPC Z a0 , OUT h'010f' ; /* if Z=1 then breakpoint,Z=0 SS */
```

- 1

```
CALL single1 , OUT h'0110' ;/* call single step program */
  JMP b0 , OUT h'0111' ; /*finish SS ISR , return to main progr */
  SET HDOE HDSEL0 , OUT h'0112' ; /* set HD to output */
a0:
         /* select DOR to HD output bus*/
  /* move out the source registers to HD */
 MOV DOR DIR , OUT h'0113' ; /* 0000 should come out next cycle*/
 MOV DOR AIR , OUT h'0114' ; /* 0000 */
 MOV DOR AOR , OUT h'0115'
           ; /*
             0001 */
 MOV DOR ACH , OUT h'0116' ; /* 001f */
 MOV DOR ACL , OUT h'0117' ; /* 0000 */
 MOV DOR IIR , OUT h'0118' ; /* 0000 */
 MOV DOR BC
      , OUT h'0119' ; /* 0007 */
b0:
 RET , OUT h'011a' ;
int7 :
  /* mask that interrupt */
 DISABLE INT7 , OUT h'011a' ;
 RET , OUT h'011b' ;
end ;
.т
   Е
         3210
            543210
                  5432101111119876543210
   т
                    543210
   в
TIME
 1
   2
   # bps0.stl file for single-stepping
# write the single-step mode bit hd12=1
 20
   21
   write into FIFO for single-step
   55
 56
   57
   58
   59
   60
   61
   62
   63
   64
   65
   66
   67
   68
   69
   70
   71
```

| 95    | 100000000000000000000100000000000000000              |
|-------|------------------------------------------------------|
| 96    | 100000000000000000011100000000000000000              |
| 97    | 100000000000000000000000000000000000000              |
| 98    | 100000000000000000011100000000000000000              |
| 99    | 100000000000000000000000000000000000000              |
| 100   | 100000000000000000011100000000000000000              |
|       |                                                      |
| 101   | 100000000000000000000000000000000000000              |
| 102   | 10000000000000000001110000000000000000               |
| 103   | 100000000000000000000000000000000000000              |
| 104   | 100000000000000000011100000000000000000              |
| 105   | 100000000000000000000000000000000000000              |
| 106   | 100000000000000000011100000000000000000              |
| 107   | 100000000000000000000010000000000000000              |
| 108   | 100000000000000000011100000000000000000              |
| 109   | 100000000000000000000000000000000000000              |
| 110   | 100000000000000000011100000000000000000              |
| 135   | 100000000000000000000000000000000000000              |
| 136   | 100000000000000000011100000000000000000              |
| 137   | 100000000000000000000000000000000000000              |
|       |                                                      |
| 138   |                                                      |
| 139   | 100000000000000000000000000000000000000              |
| 140   | 10000000000000000001110000000000000000               |
| 141   | 10000000000000000000001000000000000000               |
| 142   | 100000000000000000011100000000000000000              |
| 143   | 100000000000000000000010000000000000000              |
| 144   | 100000000000000000001110000000000000000              |
| 145   | 100000000000000000000010000000000000000              |
| 146   | 100000000000000000011100000000000000000              |
| 147   | 100000000000000000000000000000000000000              |
| 148   | 100000000000000000011100000000000000000              |
| 149   | 100000000000000000000000000000000000000              |
| 150   | 100000000000000000011100000000000000000              |
| 175   | 100000000000000000000000000000000000000              |
| 176   | 10000000000000000001110000000000000000110002ZZZZZZZZ |
| 177   | 100000000000000000000000000000000000000              |
| 178   | 100000000000000000011100000000000000000              |
| 179   |                                                      |
|       |                                                      |
| 180   | 10000000000000000011100000000000000011010            |
| 181   | 10000000000000000000000000000000000000               |
| 182   | 10000000000000000001110000000000000000               |
| 183   | 10000000000000000000000000000000000000               |
| 184   | 100000000000000000011100000000000000000              |
| 185   | 100000000000000000000000000000000000000              |
| 186   | 100000000000000000011100000000000000000              |
| 187   | 100000000000000000000010000000000000000              |
| 188   | 100000000000000000001110000000000000000              |
| 189   | 100000000000000000000000000000000000000              |
| 190   | 100000000000000000011100000000000000001111           |
| write | into FIFO second time around for single-step         |
| 240   | 10000000000000000001110000000000000000               |
| 240   | 100000000000000000000000000000000000000              |
| 241   | 10000000000000000000000000000000000000               |
| 242   | 100000000000000000000000000000000000000              |
|       |                                                      |
| 244   | 100000000000000000111000000000000000000              |
| 245   | 100000000000000000000000000000000000000              |
| 246   | 100000000000000000011100000000000000000              |
| 247   | 10000000000000000000000000000000000000               |
|       |                                                      |

#

| 248 | 100000000000000000011100000000000000000     |
|-----|---------------------------------------------|
| 249 | 10000000000000000000000000000000000000      |
| 250 | 100000000000000000011100000000000000000     |
|     |                                             |
| 255 | 100000000000000000000000000000000000000     |
| 256 | 100000000000000000011100000000000000000     |
| 257 | 100000000000000000000000000000000000000     |
| 258 | 100000000000000000011100000000000000000     |
| 259 | 100000000000000000000000000000000000000     |
| 260 | 100000000000000000011100000000000000000     |
| 285 | 10000000000000000000000000000000000000      |
|     |                                             |
| 286 | 10000000000000000001110000000000000000      |
| 287 | 100000000000000000000000000000000000000     |
| 288 | 100000000000000000011100000000000000000     |
| 289 | 100000000000000000000000000000000000000     |
| 290 | 100000000000000000011100000000000000000     |
| 291 | 100000000000000000000000000000000000000     |
| 292 | 100000000000000000001110000000000000000     |
|     |                                             |
| 293 | 100000000000000000000000000000000000000     |
| 294 | 100000000000000000001110000000000000000     |
| 295 | 100000000000000000000000000000000000000     |
| 296 | 100000000000000000011100000000000000000     |
| 297 | 100000000000000000000000000000000000000     |
| 298 | 100000000000000000011100000000000000000     |
| 299 | 100000000000000000000000000000000000000     |
| 300 | 100000000000000000000000000000000000000     |
|     |                                             |
| 325 | 10000000000000000000000000000000000000      |
| 326 | 10000000000000000001110000000000000000      |
| 327 | 100000000000000000000000000000000000000     |
| 328 | 100000000000000000011100000000000000000     |
| 329 | 100000000000000000000000000000000000000     |
| 330 | 10000000000000000001110000000000000000      |
| 331 | 100000000000000000000000000000000000000     |
| 332 | 100000000000000000011100000000000000000     |
| 333 |                                             |
|     | 100000000000000000000000000000000000000     |
| 334 | 10000000000000000001110000000000000000      |
| 335 | 10000000000000000000000000000000000000      |
| 336 | 100000000000000000011100000000000000000     |
| 337 | 100000000000000000000000000000000000000     |
| 338 | 100000000000000000011100000000000000000     |
| 339 | 100000000000000000000000000000000000000     |
| 340 | 100000000000000000011100000000000000000     |
| 365 | 100000000000000000000000000000000000000     |
| 366 | 100000000000000000000000000000000000000     |
| 367 |                                             |
|     | 10000000000000000000000000000000000000      |
| 368 | 100000000000000000011100000000000000000     |
| 369 | 1000000000000000000001000000000000000011010 |
| 370 | 100000000000000000011100000000000000000     |
| 371 | 100000000000000000000000000000000000000     |
| 372 | 100000000000000000011100000000000000000     |
| 373 | 100000000000000000000000000000000000000     |
| 374 | 100000000000000000000000000000000000000     |
| 374 |                                             |
|     | 100000000000000000000000000000000000000     |
| 376 | 10000000000000000001110000000000000000      |
| 377 | 10000000000000000000000000000000000000      |
| 378 | 10000000000000000000111000000000000000      |
| 379 | 100000000000000000000100000000000000001111  |
| 380 | 100000000000000000001110000000000000000     |
|     |                                             |

| • 1    | -    |                | ~~  |       | *****          | TTTOUT       | ******* |              |        |                                                       |
|--------|------|----------------|-----|-------|----------------|--------------|---------|--------------|--------|-------------------------------------------------------|
|        | Ε    | CCCCC<br>76543 | cc  | 0000  | 0000N<br>3210T | NNNSRD       | DDDD    | DDDD<br>1198 | DDDDD  | IHHHHHHHHHAAAAAAAAAAAAAAAAAAAAAA<br>DDDDAAAAAADDDDDDD |
| TIME   |      |                |     |       |                |              |         |              |        |                                                       |
| 1      |      |                |     |       |                |              |         |              |        | 000000000000000000000000000000000000000               |
| 2      |      | 100000         | 000 | 00000 | 00000          | 000011       | 10000   | 0000         | 00000  | 000000000000000000000000000000000000000               |
| 20     |      | 100000         | 000 | 00000 | 00000          | 000000       | 10000   | 0000         | 00111  | 101000000000000000000000000000000000000               |
| 21     |      | 100000         | 00  | 00000 | 00000          | 000011       | 10000   | 0000         | 00111  | 101000000000000000000000000000000000000               |
| 53     |      | 10000          | 00  | 00000 | 00000          | 000011       | 12222   | ZZZZ         | ZZZZZ  | ZZZZ0000000000000000000000000                         |
| # bps1 | .stl | uses           | ; Z | =1 fc | or bre         | akpoir       | nt IS   | R; H         | ID12=0 | );                                                    |
|        |      |                |     |       |                | -            |         | •            |        |                                                       |
|        |      |                |     | ****  | :***1          | 'he bps      | s0.ou   | t fi         | le **  | ****                                                  |
| *****  | **** | *****          | *** | ***** | *****          | *****        | ****    | ****         | ****   | *******                                               |
|        |      |                |     |       |                |              |         |              |        |                                                       |
|        |      |                |     |       | οτ             | ЈТΡΊ         | JT      | ТА           | A B L  | E                                                     |
|        |      |                |     |       |                |              |         |              |        |                                                       |
|        | сs   |                |     |       | 1.09           |              |         |              |        | Tue Apr 04 15:43:42 1989                              |
| *****  | **** | *****          | *** | ***** | *****          | *****        | ****    | ****         | *****  | *******                                               |
|        |      |                |     |       |                |              |         |              |        |                                                       |
|        |      |                |     |       |                | FFFIB        |         |              |        |                                                       |
|        |      |                |     |       |                | IIINR        |         |              |        |                                                       |
|        |      |                |     |       |                | CIOTP        |         |              |        |                                                       |
|        |      |                | Е   |       |                | DRRRT        |         |              |        |                                                       |
|        |      | ::40           |     | 51::  |                | Е            | :40     | :40          | ::40   |                                                       |
|        | :40  |                |     | ::40  | ::40           | Q            | 8       | 8            | 18     |                                                       |
|        | 8    | 2              |     | 18    | 18             | U            |         |              | 2      |                                                       |
|        |      |                |     | 2     | 2              | $\mathtt{L}$ |         |              |        |                                                       |
| TIME   |      |                | ~   |       |                |              |         |              |        |                                                       |
| 1      |      |                |     |       |                | 00001        |         |              |        |                                                       |
| 2      |      |                |     |       |                | 00001        |         |              |        |                                                       |
| 3      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 4      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 5      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 6      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 7      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 8      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 9      |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 10     | 054  | 0054           | 0   | 0000  | 0000           | 01000        | 055     | 000          | 0000   |                                                       |
| 11     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 12     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 13     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 14     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 15     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 16     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 17     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 18     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 19     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 20     |      |                |     |       |                | 01000        |         |              |        |                                                       |
| 21     | 05f  | 005f           | 0   | 0000  | 0000           | 01000        | 060     | 000          | 0000   |                                                       |
| 22     |      |                |     |       |                | 01100        |         |              |        |                                                       |
| 23     | 061  | 0061           | 0   | 0000  | 0000           | 01100        | 062     | 000          | 0000   |                                                       |
|        |      |                |     |       |                |              |         |              |        |                                                       |

.т

4

| 24<br>25<br>26<br>27<br>28<br>29<br>30<br>31<br>32<br>33<br>***Due                                                            | 062       0062       0       0000       01100       063       0000         063       0063       0       0000       01100       064       0000         064       0064       0       0000       01100       065       0000         065       0065       0       0000       01100       066       0000         066       0066       0       0000       01100       067       0000         066       0066       0       0000       01100       067       0000         067       0067       0       0000       01100       068       0000         068       0068       0       0000       01100       068       0000         069       0069       0       0000       01100       068       0000         064       0060       0000       01100       064       0000       0000         064       0066       0       0000       01100       064       0000       0000         064       0060       0000       01100       066       0000       0000       0000         064       0060       0000       01100       066       0000 | :* |
|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| de de de de de de                                                                                                             | *********The bps1.out file ***********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
| *****                                                                                                                         | ***************************************                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ×  |
|                                                                                                                               | OUTPUT TABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| PAC<br>*****                                                                                                                  | I M Ver. 1.09 Mon Apr 03 13:08:15 1989                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | *  |
| TIME                                                                                                                          | CC       0000       M       CC       DI       BBB       B       HHHH       LLL       BBBB         PP       CCCC       D       CC       ON       RRR       R       DDDD       CCC       CCC         CC       1173       O       73       RT       EEE       P       1173       1173         73       51::       E       ::       R       AAA       T       51::       51::         ::       ::40       40       KKK       E       ::40       :40       ::40         40       18       RRR       Q       18       8       18         2       EEE       U       2       2       2         GGG       L       973       ::::       840                                                                                                                                                                                                                                                                                                                                                                                          |    |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>20<br>21<br>22<br>23 | 00       0000       0       000       1       0000       0000         00       0000       0       000       0000       1       0000       0000         00       0002       0       00       0000       0000       0000       0000         01       0001       0       000       0000       0000       0000       0000         02       0000       0       000       0000       0000       0000       0000         02       0000       0       000       0000       0000       0000       0000         50       0050       0       000       0000       0000       0000       0000         51       0051       0       00       0000       0000       0000       0000         52       0052       0       00       0000       0000       0000       0000         54       0054       0       00       0000       0000       0000       0000         55       0055       0       00       0000       0000       0000       0000         55       0055       0       00       0000       0000       00000       0000          |    |

| 24       | 062 | 0062 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
|----------|-----|------|---|----|----|-----|---|------|-----|------|
| 25       | 063 | 0063 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 26       | 064 | 0064 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 27       | 065 | 0065 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 28       | 066 | 0066 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 29       | 067 | 0067 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 30       | 068 | 0068 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 31       | 069 | 0069 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 32       | 06a | 006a | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 33       | 06b | 006b | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 34       | 06c | 006c | ŏ | 00 | 00 | 000 | ŏ | 007a | 000 | 0000 |
| 35       | 06d | 006d | ŏ | 00 | 00 | 000 | ŏ | 007a | 000 | 0000 |
| 36       | 06e | 006e | ŏ | 00 | 00 | 000 | ŏ | 007a | 000 | 0000 |
| 37       | 06f | 006f | ŏ | 00 | 00 | 000 | õ | 007a | 000 | 0000 |
| 38       | 070 | 0070 | ŏ | 00 | 00 | 000 | ŏ | 007a | 000 | 0000 |
| 39       | 071 | 0071 | ŏ | 00 | 00 | 000 | õ | 007a | 000 | 0000 |
| 40       | 072 | 0072 | ŏ | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 41       | 073 | 0072 | ŏ | 00 | 00 | 000 | õ | 007a | 000 | 0000 |
| 42       | 074 | 0074 | 0 | 00 | 00 | 000 | 0 | 007a | 000 | 0000 |
| 43       | 075 | 0074 | õ | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 43<br>44 | 075 | 0075 | 0 | 00 | 00 | 07a |   | 007a | 000 | 0007 |
| 44       | 070 | 0078 |   |    |    |     | 0 |      |     |      |
|          |     |      | 0 | 00 | 00 | 07a | 1 | 007a | 000 | 0007 |
| 46       | 07a | 007a | 0 | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 47       | 07b | 007b | 0 | 00 | 01 | 07a | 0 | 007a | 000 | 0007 |
| 48       | 00e | 000e | 0 | 00 | 01 | 07a | 0 | 007a | 000 | 0007 |
| 49       | 10c | 010c | 0 | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 50       | 10d | 010d | 0 | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 51       | 10e | 010e | 0 | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 52       | 10f | 010f | 0 | 00 | 00 | 07a | 0 | 007a | 000 | 0007 |
| 53       | 112 | 0112 | 1 | 00 | 00 | 07a | 0 | 000f | 000 | 0007 |
| 54       | 113 | 0113 | 1 | 00 | 00 | 07a | 0 | 000f | 000 | 0007 |
| 55       | 114 | 0114 | 1 | 00 | 00 | 07a | 0 | 0000 | 000 | 0007 |
| 56       | 115 | 0115 | 1 | 00 | 00 | 07a | 0 | 0000 | 000 | 0007 |
| 57       | 116 | 0116 | 1 | 00 | 00 | 07a | 0 | 1000 | 000 | 0007 |
| 58       | 117 | 0117 | 1 | 00 | 00 | 07a | 0 | 001f | 000 | 0007 |
| 59       | 118 | 0118 | 1 | 00 | 00 | 07a | 0 | 0000 | 000 | 0007 |
| 60       | 119 | 0119 | 1 | 00 | 00 | 07a | 0 | 0000 | 000 | 0007 |
| 61       | 11a | 011a | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 62       | 07c | 007c | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 63       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 64       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 65       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 66       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 67       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 68       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 69       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
| 70       | 07d | 007d | 1 | 00 | 00 | 07a | 0 | 0007 | 000 | 0007 |
|          |     |      |   |    |    |     |   |      |     |      |



# Programmable System™Device

Application Brief 007

Hardware Interfacing the PAC1000 as a Micro Channel Bus Controller

By Arye Ziklik

Abstract This application brief describes how to use the PAC1000 High-Performance User-Configurable Microcontroller as a Micro Channel (MCA) bus controller.

> The MCA bus uses asynchronous and synchronous procedures to control and transfer data on the bus. The data is transferred from a master board to a slave

board, or from the PS/2 mother-board (the system) to a slave. This application brief describes the use of the PAC1000 on a master board and on a slave board.

In both applications the PAC1000 is handling the synchronous functions, the asynchronous functions are implemented by external PALs.

### MCA Signal Descriptions

The bus signals described in this chapter are the most important and essential signals to understand the application brief. The buffers needed per each signal are summarized in Table 2. The timing relations between the signals is drawn in Figure 1.

## AO-A23

Address bits generated by the bus master to address memory and IO slaves attached to the bus. The address bits are unlatched and must be latched by the slaves using either the trailing edge of ADL or the leading edge of CMD signals.

## D0-D15

Data bits, valid during the period  $\overline{\text{CMD}}$  signal is low. The data is driven by bidirectional three-state drivers.

# ADL

Address Decode Latch, driven by the bus master. The signal is used by the slaves to latch valid address and status bits.

# CD\_\_DS16

Card Data Size 16, driven by 16 bit slaves to provide an indication to the master about their data bus width. Eight-bit slaves do not drive this line.

## <u>DS\_\_16\_\_RTN</u>

Data Size 16 Return. A signal generated by the PS/2 system by AND-ing all the CD\_DS16 signals received from all the slave connected to the bus. The signal is provided by the PS/2 system to the bus masters.

# M/ĪŌ

Memory/ $\overline{IO}$ , driven by the bus master and indicates a memory or IO cycle. M/ $\overline{IO}$  is latched by the slave at the leading edge of  $\overline{CMD}$  signal.

# <u>50, 51</u>

Status bits, driven by the bus master and indicate the start of read or write cycle. The status bits are latched by the slaves using the leading edge of  $\overline{\text{CMD}}$ .

# CMD

Command signal is driven by the bus master and defines the period data is valid on the data bus. The leading edge of  $\overline{CMD}$  is used to latch the unlatched signals: A0-23,  $M/\overline{IO}$ ,  $\overline{SO}$ , and  $\overline{S1}$ . The trailing edge of  $\overline{CMD}$  indicates the end of the bus cycle.

# CD\_\_SFDBK

Card Select Feedback. When a bus master addresses a memory or an IO slave, the addressed slave drives CD\_\_SFDBK active as a positive acknowledgement of its presence at the specified address.

# CD\_\_CHRDY

Channel Ready. This line is pulled inactive (not ready) by a slave to allow additional time to complete a bus cycle.

## CHRDYRTN

Channel Ready Return. Generated on the PS/2 system board by AND-ing the CD\_CHRDY signals driven by all the slaves. The signal is provided by the system to the mastr driving the bus.

MCA Signal Descriptions (Cont.)

#### ARBO-ARB3

Arbitration Bus priority signals. These four signals represent the priority levels for masters seeking control on the bus. The four signals represent 16 priority levels, level 15 represents the lowest priority, level 0 represents the highest priority and belongs to the PS/2 system.

#### ARB/GNT

Arbitrate/Grant. When high, this signal indicates an arbitration cycle is in process. When low, indicates that a master has been granted. ARB/GNT is driven by the system.

## PREEMPT

Used by the arbitration bus masters to request the bus.

### BURST

Indicates that the master requests the bus for transferring a block of data.

## ĪRQ

Interrupt Request is used to signal the system that a device requires attention.

#### **CHRESET**

Channel Reset, active high reset signal generated by the system and sent to all the boards on the bus.



| Table 1. The<br>States Generated | M/ĪŌ | SO | <u>\$1</u> |               |
|----------------------------------|------|----|------------|---------------|
| M/IO, SO and ST                  | 0    | 0  | 1          | I/O write.    |
| <i>milo, oo ana o i</i>          | 0    | 1  | 0          | I/O read.     |
|                                  | 1    | 0  | 1          | Memory write. |
|                                  | 1    | 1  | 0          | Memory read.  |

MCA Timing Parameters The PAC1000 as a bus master transfers data on the MCA bus with a control sequence based on the following events:

- The addres bus and M/IO signal become valid.
- □ The status signals SO and SI are valid 10 nsec minimum after (1).
- ADL is valid 45 nsec minimum after (1).

□ In response to the unlatched address decode, the selected slave responses with CD\_SFDBK (and CD\_DS16 if it is a 16 bit slave). The maximum allowable response time of the slave is 55 nsec maximum from (1).

| MCA Timing<br>Parameters<br>(Cont.) | <ul> <li>In response to (1), the slave responds with CD_CHRDY. The maximum allowable response time is 60 nsec maximum from (1).</li> <li>Write data appears on the bus for the write cycle. The data has to be valid before the leading edge of CMD.</li> <li>CMD becomes active and ADL inactive typically 85 nsec minimum after (1). The unlatched signals on the bus are latched.</li> <li>The status signals become inactive after they were latched.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <ul> <li>The address bus becomes inactive after the address was latched.</li> <li>In response to the address change, the slave's unlatched responses (CD_CFDBK AND CD_DS16) are invalid.</li> <li>System stays in this state until CD_CHRDY is ready.</li> <li>The slave places data on the bus in response to a read.</li> <li>The address and M/IO are valid for the next cycle.</li> <li>CMD goes inactive, ending the cycle.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operation Modes                     | <ul> <li>The PAC1000 working as a MCA controller can handle the following functions:</li> <li>Bus signal generator.</li> <li>Card setup.</li> <li>The bus arbitration logic and signal decoding are pure asynchronous functions and implemented by two PALs.</li> <li>Bus Slave Board</li> <li>On a bus slave board the PAC1000 may be used to implement the POS registers.</li> <li>The Programmable Option Select (POS) registers main objectives are:</li> <li>Eliminate switches from the board.</li> <li>Positively identify any card connected to the system.</li> <li>The POS registers on a PS/2 board replace the switches by using software writeable registers. There are eight POS registers are addressed by CD_SETUP signal and by address bits A0-2. The POS registers are located at I/O addresses 100H to 107H. The eight POS registers are located at I/O addresses 100H to 107H. The eight POS registers are located in the PAC1000 and control the board's functions.</li> <li>The POS registers' interface to the MCA is a decoder which decodes the system's access to the registers and generates the RD and WR signals to the PAC1000.</li> <li>The address decoder and slave logic are most of the circuitry needed for the slave functions. The decoder has to decode the address on the bus and to respond with CD_SFDBK, CD_CHRDY and CD_DS16 signals. The address decoder might be for memory, I/O or for both. The decoder's</li> </ul> | <ul> <li>size depends on the number of address bits it is decoding. The decoder's CS outputs are latched by the leading edge of CMD and are stable until the end of the bus cycle. The decoder generates the feedbacks to the bus, CD_SFDBK, CD_DS16 and CD_CHRDY. These signals are not latched and are very time critical. The decoder responds with these outputs at 55 nsec maximum after the address is stable.</li> <li><b>Bus Master Board</b> <ul> <li>A master board is a board with a CPU which requests the MCA bus. When granted by the PS/2 system, the master board is driving the bus signals.</li> <li>On a master board the PAC1000 can handle the following functions: <ul> <li>POS registers (similar to the bus slave board).</li> </ul> </li> <li>Generation of the bus signals</li> <li>The other functions of a bus controller are implemented by PALs because the functions are pure asynchronous.</li> <li>The bus signals are generated by the PAC1000 after the CPU is granted to be a bus master. The process of getting the bus is done in the following sequence: <ul> <li>The CPU is requesting the bus through one of the interface lines with the PAC1000.</li> <li>The PAC1000 is setting the bus request line which is buffered by drivers and sent to the MCA system.</li> </ul> </li> </ul></li></ul> |



- The bus arbiter sends the PAC1000 the signal MASTER which tells the board that the bus was granted and the board may drive the bus.
- □ The PAC1000 signals the CPU that it is the bus master.
- □ The PAC1000 is enabling the address and data drivers, and the CPU drives the address and data to the bus.
- □ The PAC1000 generates all the bus signals in the right sequence and the right timing requirements as defined by the MCA bus standard.
- After the CPU is done, it releases the bus request. The PAC1000 translates it to the right signal sequence on the MCA bus and releases the bus buffers.

On the bus master board the PAC1000 may implement a lot of control functions and save glue logic.

#### For example:

The PAC1000 can handle several DMA operations on the board, or be used as a high speed controller for various applications.



| le 2. Driver | Signal Name   | Driver Type                    |
|--------------|---------------|--------------------------------|
| 2 Signals    | A(0–23)       | TS 24 mA (TS = Three-State)    |
|              | D(0–15)       | TS 24 mA                       |
|              | ADL           | TS 24 mA                       |
|              | CDDS16        | TP 6 mA (TP = Totem Pole)      |
|              | DS16RTN       | BD 24 mA (BD = Bus Driver)     |
|              | M/IO          | TS 24 mA                       |
|              | <u>S0, S1</u> | TS 24 mA                       |
|              | CMD           | TS 24 mA                       |
|              | CD_SFDBK      | TP 6 mA                        |
|              | CD_CHRDY      | TP 6 mA                        |
|              | CHRDYRTN      | BD 24 mA                       |
|              | ARB(0–3)      | OC 24 mA (OC = Open Collector) |
|              | PREEMPT       | OC 24 mA                       |
|              | BURST         | OC 24 mA                       |
|              | ARB/GNT       | BD 24 mA                       |



Master





# Programmable System<sup>™</sup> Device

**Application Note 003** 

High-End SAM Applications Using Microassembler Design Entry

| Scope of This<br>Application Note | This Application Note describes the SAM<br>microsequencer design entry process utilizing<br>ASM microassembler input syntax and<br>provides illustrations of all basic concepts<br>needed to execute a SAM microassembler<br>design. Basic microassembler functionality<br>is reviewed, its utilization of SAM internal<br>resources, as well as user convenience<br>features. Cascading of multiple SAM devices<br>to address large design problems is also | covered. To illustrate a practical application<br>of SAM, a graphics controller application is<br>presented in detail along with annotated<br>ASM source code.<br>The reader is referred to WSI's SAM448<br>Data Sheet for details concerning device<br>architecture and performance. A general<br>knowledge of SAM device architecture is<br>assumed as background for this<br>Application Note. |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The SAM<br>Solution               | The SAM (Stand-Alone Microsequencer)<br>User-Configurable device provides a unique<br>solution for high-performance control<br>functions. The combination of a microcoded<br>engine with a branch EPLD front-end gives<br>SAM the ability to handle high-complexity<br>tasks while still achieving high clock rates.<br>The basic SAM architecture is shown in<br>Figure 1.                                                                                  | Programming the SAM device for a particular application involves specifying multi-way branch transition specifications for the branch EPLD, and instruction and output strings for the required number of microcode words in SAM's EPROM control memory. (See the SAM448 Data Sheet for further information). This task is eased by the use of the SAM+PLUS development system.                   |
| SAM+PLUS<br>System Overview       | The SAM+PLUS PC-based design<br>development system provides an efficient<br>mechanism for entry and automatic<br>compilation of SAM designs. Interactive<br>functional simulation is provided in<br>SAM+PLUS to enable rapid verification of<br>design flows and operation. PC-compatible<br>programming hardware is also available to<br>allow device programming right at the                                                                              | designer's desk. Given the fact that control<br>logic is frequently difficult to design, and<br>particularly prone to design alterations, the<br>ability to enter, compile, simulate and test<br>a design in rapid fashion results in an<br>effective design system.<br>SAM+PLUS actually supports two design<br>entry methods, one using ASMILE state<br>machine input language, the other ASM   |



# SAM+PLUS System Overview (Cont.)

microassembler format, as shown in Figure 2. SAM ASMILE input is described in WSI Application Note #4, referenced below. This Application Note will focus on microassembler input.

Microassembler design entry begins with the creation of a design file on the PC using any standard text editor. Next, the SAM Design Processor (SDP) takes the ASM input file, automatically minimizes transition equations and generates the device programming code. A Utilization Report is generated which reports total resources consumed, absolute memory assignments of microassembler instructions and compiler-assigned pinouts. A standard JEDEC file is generated to allow programming of the device right on the PC. For larger designs, multiple SAM devices may be horizontally cascaded to increase the number of available control outputs. The microassembler supports the specification of a single source file for a multiple-SAM application, and automatically generates the separate JEDEC files for the programming of each of the devices at compile time. The JEDEC file, which represents the actual template of the specific application implemented, may be used as input to the SAMSIM (SAM SIMulator) program which provides functional simulation capability. Hard-copy output of simulation results may be obtained, as well as on-line "logic analyzer" viewing capability. Multi-chip applications using horizontal cascading is also supported by the functional simulator.



## Choosing Appropriate Applications for SAM

The SAM architecture supports highperformance synchronous control applications. It is important to realize that all outputs from SAM are asserted synchronously with respect to the device clock, and as such SAM implements a classic Moore machine architecture. Similarly, as can be seen in the SAM Data Sheet, all inputs must obey a required setup time (Tsu) relative to the Clock input.

| Choosing<br>Appropriate<br>Applications for<br>SAM (Cont.) | In order to obtain greater than 16 outputs<br>in a SAM design, the concept of horizontal<br>cascading may be used. Similarly, if greater<br>control store (microcode) depth is required,<br>multiple SAM devices may be vertically<br>cascaded, sharing a common control output<br>bus. Both cascading approaches may be<br>simultaneously used for problems requiring<br>increased capacity in both dimensions.<br>In order to determine whether a given<br>application will be suitable for SAM, the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | following "rules-of-thumb" derived from the<br>device architecture and specifications are<br>useful. These guidelines are for single<br>SAM implementations. Cascaded SAM<br>configurations may expand output count<br>and memory depth substantially. For<br>example, SAM+PLUS supports horizontal<br>cascading of up to 8 SAM448 devices, for<br>a total output count of 128 lines!                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAM Application<br>Guidelines                              | <ul> <li>Operating frequency up to specified SAM's Fmax</li> <li>Synchronous operation</li> <li>Up to eight control inputs (exclusive of Clock and nRESET)</li> <li>Up to sixteen control outputs (single device)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <ul> <li>Up to 256 primary microcode locations</li> <li>Up to 64 of 256 primary microcode locations may be multi-way (external conditional) branches (single device)</li> <li>Transition expressions reducible to four product terms per IF THEN expression</li> <li>Applications which satisfy this list will in all likelihood fit into a single SAM device.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Microassembler<br>Input Overview                           | Shown in Figure 3 is an example of the<br>structure of a SAM ASM input file. This file<br>may be created using any standard text<br>editor. It is important that the text editor is<br>used in non-document mode in order to<br>prevent the insertion of any spurious<br>format control characters which may be<br>detected by the ASM microassembler<br>parser at compile time as input errors.<br>Other than this constraint, input is<br>essentially free-form and may be structured<br>for readability and overall clarity.<br>The case of characters inserted into the<br>ASM file is significant, so be sure that<br>case significance is maintained. For<br>example, the names "RWB" and "rwb"<br>are not the same.<br>Comments may be inserted freely into the<br>source code, delimited by leading and<br>trailing percent signs (%).<br>The basic format of a SAM ASM file<br>consists of the following sections:<br>[HEADER]<br>PART<br>INPUTS<br>OUTPUTS<br>[PINS]<br>[DEFAULT]<br>[MACROS]<br>[EQUATIONS]<br>PROGRAM<br>END\$ | Those sections noted within brackets are optional and may be omitted if not required. <i>Header</i> The HEADER contains user-specified design identifier information. It may include design title, designer's name, date, revision information, etc. <i>Part</i> The PART section of the ASM file specifies the target SAM device or devices the application is intended for. By specifying AUTO, the user permits the SAM+PLUS software to pick the optimal device or set of devices for the application based upon minimal pin count. Multiple devices may be invoked for designs requiring a larger number of total outputs than a single SAM device can supply, i.e., the SAM+PLUS software supports horizontal cascading (see SAM Data Sheet) of devices at a source code level. This cascading capability may be invoked by utilizing AUTO with a design requiring high output count as noted, or may be explicitly defined by supplying a list of devices after PART which the design is to be fitted into. As shown in the example below, two SAM448 devices are going to be used in this application, and have been explicitly entered. Devices may be cascaded horizontally up to a width of 128 outputs in a single source code listing and simulated |

Microassembler Input Overview (Cont.) as one large virtual SAM. Separate JEDEC files are generated for each device to support programming devices when design is complete.

#### Inputs

The single INPUTS section of the ASM file defines all external inputs into the design, as well as any required user pin assignments. Pin assignments are specified by the format input\_name @ pin\_number. Note that since in a horizontally cascaded design all design inputs must be common, there will never be more inputs specified in a source file than are available in a single SAM device.

Only user-defined inputs should appear in the INPUTS section: the CLOCK and nRESET inputs to SAM, being fixedfunction pins, should not be included.

#### **Outputs**

The OUTPUTS section(s) of the ASM file contains a list of all outputs from the design as well as any pin assignments. Pin assignment syntax is similar to input pin assignments. If multiple SAMs are specified in the PART: section of the design file (horizontal cascading), there will be multiple OUTPUTS sections in the ASM file, one for each SAM component. If AUTO parts selection is used for a cascaded design, a single OUTPUTS declaration may be used to specify all required outputs. At compile time, outputs will be assigned to the various devices automatically.

Output names must be unique across all OUTPUTS section declarations.

AUTO parts selection may not be used in conjunction with user-defined pin assignments.

#### Pins

The PINS section allows mapping of external variable names onto internal variable names for convenience. For example, a user may have an active-low signal in his system he has called /WR which enters into his transition specifications in his SAM design. To keep the logical sense of such specifications clear, it is wise to transform all active-low external signals into equivalent active-high names internally, e.g., /WR = WRint.

#### Default

The DEFAULT section allows the specification of a default output combination to be used whenever the output string is not explicitly defined in an instruction. In a single SAM device specification the syntax is simply DEFAULT: [O0 . . . On], where O0 through On represents a binary string corresponding to the n outputs specified for the SAM design. Default output values are matched to output pins in the order they appear in the OUTPUTS declaration. If multiple OUTPUTS sections appear in a cascaded SAM application, the DEFAULT specifier is increased in width to accommodate this change as shown in the example. Only one DEFAULT section may appear per ASM file.

#### Macros

The MACROS section allows the user to define string equivalences to be substituted universally throughout his ASM source code listing. For example, the user may wish to redefine instruction mnemonics for efficiency or clarity, or may wish to redefine binary output strings with alphanumeric labels. For example,

REG1TOALU = "0101111001100000"

The left hand side of this expression is undoubtedly easier to remember and type repeatedly into a listing than the right.

Imbedded strings are not macro substituted. Macro instances must be delimited by white space to be recognized. For example, if a macro substitution is defined as

REG = "0110"

the string 0110 would be substituted into

[REG ALU OP] CONTINUE;

but not into

[BREG4 ALU OP] CONTINUE;

#### Equations

The EQUATIONS section of the ASM file is available for the definition of intermediate equations to be used later in the design. Entry of transition specifications may be eased by defining intermediate variables initially, and then invoking them during the design. For example,

EventClk = 11 \*/14 + 13\*16\*/17might be defined in the EQUATIONS

## SAM448 — Application Note 003

| Microassembler<br>Input Overview<br>(Cont.) | section, and then utilized later in an<br>IF THEN ELSE statement or<br>statements, such as<br>IF EventClk THEN [] JUMP START;<br><b>Program</b><br>The PROGRAM section of the ASM file<br>actually specifies the sequence of<br>instructions to be executed and associated<br>outputs required from the SAM device.<br>The format of a basic instruction<br>specification in the PROGRAM section is<br>label: [output-spec] opcode;<br>label is an optional alphanumeric string<br>which may be used to identify the | [output-spec] represents an actual numeric<br>string of the correct length (in either binary<br>hexadecimal or decimal notation), a Macro<br>substitution with numeric equivalence (as<br>defined above), or the special character Z<br>which signifies tri-state output pins.<br>Hexadecimal and decimal strings are<br>defined by a string of valid digits of correc<br>length, followed by H or D respectively. In<br>horizontally cascaded applications, all<br>outputs are specified in the single output-<br>spec within brackets. The output-spec<br>defined in the DEFAULT statement will be<br>utilized whenever the output-spec has<br>length zero, i.e., [] implies default<br>output-spec. |
|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | instruction in branching expressions, etc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| END\$                                       | Every SAM ASM source file must terminate with the END\$ terminator.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Multi-Way<br>Branch Syntax                  | The syntax for multi-way branching within<br>the SAM ASM source file is by way of a<br>complex expression of the form<br>IF (expression1) THEN (instruction1)<br>ELSEIF (expression2)<br>THEN (instruction2)<br>ELSEIF (expression3)<br>THEN (instruction3)                                                                                                                                                                                                                                                          | another, it is possible to trade-off product<br>term counts for number of multi-way<br>branch destinations. For example, it is<br>perfectly valid to enter<br>IF (expression1) THEN [] JUMP START;<br>ELSEIF (expression2) THEN [] JUMP START<br>ELSEIF (expression3) THEN [] JUMP NEXT1<br>ELSE [] JUMP NEXT2;                                                                                                                                                                                                                                                                                                                                                                                        |
|                                             | ELSE (instruction4)<br>For example, a complex instruction of this<br>type might look like                                                                                                                                                                                                                                                                                                                                                                                                                            | Here, expression1 and expression2 could<br>each be four product term expressions,<br>resulting in eight product terms which can<br>be used to specify the transition to START.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                             | IF I0*11*15*/I7 + I3*14 + I6*/I0 + /I3*/I1 THEN<br>[1111001110010000] CALL<br>label1 RETURNTO label2;<br>ELSEIF I3*/I2 + I5*I6 + /I0*14*11 THEN<br>[1011000011100011] LOADC<br>255 GOTO label3;<br>ELSEIF I4*16*10 THEN [] PUSH 15<br>GOTO label4;<br>ELSE [111111100000001] PUSHI<br>GOTO label5;                                                                                                                                                                                                                   | Note the inherent priority scheme in the<br>above statements. The SAM architecture<br>physically implements such a priority<br>scheme in the Branch Control Block: the<br>first occurrence of a valid expression<br>results in the execution of the corresponding<br>instruction. If the first three expressions<br>are all false, then instruction4 will be<br>subsequently executed.                                                                                                                                                                                                                                                                                                                 |
|                                             | Each expression may be a function of any<br>of the eight SAM external inputs containing<br>up to four product terms.<br>If more than four product terms are needed<br>to define a transition from one state to                                                                                                                                                                                                                                                                                                       | Up to 64 such IF THEN ELSE<br>constructs may be implemented in a single<br>SAM program, along with 192 conventiona<br>instructions without IF THEN ELSE<br>The result is a total microcode memory<br>capacity of $(64 \times 4) + 192 = 448$ words.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Sircle Drawing | This is the Circle Drawing Design                                                                                                                                                                                                                                                                                                                                         |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Routine        |                                                                                                                                                                                                                                                                                                                                                                           |
|                | % Circle Drawing Routine for SAM %                                                                                                                                                                                                                                                                                                                                        |
|                | PART: SAM448 SAM448                                                                                                                                                                                                                                                                                                                                                       |
|                | % SAM Control Output Lines     Inputs     %       % A & B Fields (2901)     - 8     CO-2     - 3     %       % IO-18 (2901)     - 9     CmdAtt     - 1     %       % OE (2901)     - 1     Sign     - 1     %       % Done     - 1     %     %     %       % Cn (2901)     - 1     %     %       % ALE     - 1     %       % Rd     - 1     %       % RegRd     - 1     % |
|                | INPUTS: CO,C1,C2,CmdAtt,SIgn                                                                                                                                                                                                                                                                                                                                              |
|                | OUTPUTS: A0,A1,A2,A3,B0,B1,B2,B3,I2,I1,I0,I5,I4,I3,I8,I7<br>OUTPUTS: I6,Rd,Wr,ALE,RegRd,OE,Cn,Done                                                                                                                                                                                                                                                                        |
|                | DEFAULT: [0000 0000 0000 0000 1110 0100]                                                                                                                                                                                                                                                                                                                                  |
|                | MACROS :                                                                                                                                                                                                                                                                                                                                                                  |
|                | CONT - "CONTINUE"                                                                                                                                                                                                                                                                                                                                                         |
|                | % A & B Fleids %                                                                                                                                                                                                                                                                                                                                                          |
|                | RadiusReg = '0001'<br>Reg1 = '0001'<br>Reg2 = '0010'<br>Reg3 = '0011'<br>Reg4 = '0100'<br>Reg5 = '0101'<br>Reg7 = '0111'<br>Reg8 = '1000'<br>Reg9 = '1001'<br>Reg10 = '1010'<br>Reg11 = '1011'<br>Reg12 = '1100'                                                                                                                                                          |
|                | % Source Control %                                                                                                                                                                                                                                                                                                                                                        |
|                | AQ = "000"<br>AB = "001"<br>ZQ = "010"<br>ZB = "011"<br>ZA = "100"<br>DA = "101"<br>DQ = "110"<br>DZ = "111"                                                                                                                                                                                                                                                              |
|                | % Function %                                                                                                                                                                                                                                                                                                                                                              |
|                | ADD = "000"<br>SUBR = "001"<br>SUBS = "010"<br>OR = "011"<br>AND = "100"<br>NOTRS = "101"<br>EXOR = "110"<br>EXOR = "111"                                                                                                                                                                                                                                                 |

```
Figure 3.
Circle Drawing
                      % Destination Control %
Routine (Cont.)
                      QREG = "000"
                      NOP = "001"
                      RAMA = "010"
                      RAMF = "011"
                      RAMQD = "100"
RAMD = "101"
                      RAMQU = "110"
RAMU = "111"
                      % Bus Cycle %
                      MemWr = "10001"
                      RegWr = "10011"
                      ALEcyc = "11100"
                      NoCyc = "11000"
                      % Misc %
                      Cn = "1"
                      nCn = "0"
                      Done = "1"
                      nDone = "O"
                      EQUATIONS:
                      PROGRAM:
                      % Processor initializes: %
                      OD:[] JUMP WAIT:
                      % o Load Coloreg, Radius, XO, YO %
                      % o issues DrawCirc Command
                                 IF CmdAtt*CO'*C1'*C2' THEN [] JUMP DOIT ;
                     WAIT:
                                  ELSE [] JUMP WAIT ;
                      % Move parameters from buffer to 2901 internal registers %
                      % Radius -> Reg1 (Y) %
                      DOIT:
                                 [ Reg1 Reg1 AQ ADD NOP RegWr nCn nDone ] CONT ;
                               [ Reg1 Reg1 AQ ADD NOP RegWr nCn nDone ] CONT ;
                      % XO -> Reg2 %
                               [ Reg2 Reg2 AQ ADD NOP NoCyc nCn nDone ] CONT ;
                               [ Reg2 Reg2 AQ ADD NOP RegWr nCn nDone ] CONT ;
                               [ Reg2 Reg2 AQ ADD NOP RegWr nCn nDone ] CONT ;
                      % YO -> Reg3 %
                               [ Reg2 Reg2 AQ ADD NOP NoCyc nCn nDone ] CONT ;
                               [ Reg3 Reg3 AQ ADD NOP RegWr nCn nDone ] CONT ;
                               [ Reg3 Reg3 AQ ADD NOP RegWr nCn nDone ] CONT ;
                      % Load constants to 2901 registers %
                      % 0 -> Reg4 (X) (AND 0 & anything gives 0) %
                               [ Reg4 Reg4 ZB AND RAMF NoCyc nCn nDone ] CONT ;
```

```
Figure 3. Circle
Drawing Routine
                      % 3 -> Reg5 (d) %
                      % Put "1" in Reg5 %
(Cont.)
                               [ Reg4 Reg5 ZA ADD RAMF NoCyc Cn nDone ] CONT ;
                      % Shift Reg5 Up one to give 2 %
                               [ Reg5 Reg5 ZB ADD RAMU NoCyc nCn nDone ] CONT ;
                      % While we have it, preload 2 into Reg9 %
                               [ Reg5 Reg9 ZA ADD RAMF NoCyc nCn nDone ] CONT ;
                      % increment Reg5 to get 3 (whew!!) %
                               [ Reg5 Reg5 ZA ADD RAMF NoCyc Cn nDone ] CONT ;
                      % 6 -> Reg8 (const) - just shift 3 up one! %
                      % Load 1 in CREG to set-up for next instruction %
                               [ Reg5 Reg8 ZA ADD RAMU NoCyc nCn nDone ] LOADC 1D ;
                      % 10 -> Reg9 (const) %
                      % Start by shifting Reg9 (now contains 2) up twice to get 8 %
                      % Reg6 (Temp register) %
                      CircPix:
                                 [ Reg4 Reg6 ZA ADD RAMF NoCvc nCn nDone 1 CONT :
                               [ Reg1 Reg11 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                      % Reflect X to -X %
                               [ Reg4 Reg6 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg1 Reg11 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                      % Swap X & Y %
                               [ Reg1 Reg6 ZA ADD RAMF NoCyc nCn nDone ] CONT ;
                               [ Reg4 Reg11 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                      % Swap -X & Y %
                               [ Reg4 Reg11 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg1 Reg6 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                      % Reflect Y %
                               [ Reg1 Reg11 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg4 Reg6 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                     % Swap -Y & X %
                               [ Reg1 Reg6 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg4 Reg11 ZA ADD RAMF NoCyc nCn nDone ] CALL TRANS ;
                      % Reflect -X, -Y %
                               [ Reg4 Reg6 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg1 Reg11 ZA SUBS RAMF NoCyc Cn nDone ] CALL TRANS ;
```

```
Figure 3. Circle
Drawing Routine
                     % Swap -X & -Y
                                      %
(Cont.)
                              [ Reg1 Reg6 ZA SUBS RAMF NoCyc Cn nDone ] CONT ;
                              [ Reg4 Reg11 ZA SUBS RAMF NoCyc Cn nDone ] CALL TRANS ;
                              [] RETURN ;
                     % This routine Translates relative to x0.y0 and runs the memory
                     update cvcle %
                     TRANS
                                [ Reg3 Reg11 AB ADD RAMF NoCyc nCn nDone ] CONT ;
                              [ Reg2 Reg6 AB ADD RAMF NoCyc nCn nDone ] LOADC 10D ;
                              [ Reg11 Reg12 ZA ADD RAMF NoCyc nCn nDone ] CONT ;
                     % Multiply y by 1024 %
                     MULT1024: [ Reg11 Reg11 ZA ADD RAMU NoCyc nCn nDone ]
                                  LOOPNZ MULT1024 :
                     % Subtract y to get effective multiply by 1023 %
                     DONE1024: [ Reg12 Reg11 AB SUBR RAMF NoCyc Cn nDone ] CONT ;
                     % Calculate address %
                               [ Reg6 Reg11 AB ADD RAMF NoCyc nCn nDone ] CONT ;
                     % Write pixel in buffer RAM %
                                 [ Reg11 Reg11 ZA ADD RAMF ALEcyc nCn nDone ] CONT ;
                     RUNBUS
                               [ Reg11 Reg11 ZA ADD RAMF MemWr nCn nDone ] RETURN ;
                      END$
                     SHIFTR9:
                                 [ Reg9 Reg9 ZA ADD RAMU NoCyc nCn nDone ]
                                 LOOPNZ SHIFTR9 :
                     % increment Reg9 twice to get 10 %
                               [ Reg9 Reg9 ZA ADD RAMF NoCyc Cn nDone ] CONT ;
                               [ Reg9 Reg9 ZA ADD RAMF NoCyc Cn nDone ] CONT ;
                     % Initializing done ! - Begin algorithm %
                      % d = 3 - 2*radius initially %
                               [ Reg1 Reg6 ZA ADD RAMU NoCyc nCn nDone ] CONT ;
                               [ Reg5 Reg6 AB SUBS RAMF NoCyc Cn nDone ] CONT ;
                     % if x >= y branch to finish up %
                     OUTERLOOP: [ Reg4 Reg1 AB SUBS RAMF NoCyc Cn nDone ] CONT ;
                               IF Sign THEN [] JUMP DrawEnd ;
                      % Write pixels, translate origin & reflect to all octants %
                                 ELSE [] CALL CIrcPix ;
                     % Test d sign, if >= 0, use POS %
                               [ Reg5 Reg5 ZA ADD RAMF NoCyc nCn nDone ] CONT ;
                               IF Sign THEN [] JUMP POS ;
```

(Cont.)

```
Figure 3. Circle
Drawing Routine
                      % Compute d = d + 4*x + 6 %
                      % First 4*x %
                                   ELSE [ Reg4 Reg6 ZA ADD RAMU NoCyc nCn nDone ] CONT ;
                                [ Reg6 Reg6 ZA ADD RAMU NoCyc nCn nDone ] CONT ;
                      % Add 6 %
                                [ Reg8 Reg6 AB ADD RAMF NoCyc nCn nDone ] CONT ;
                                [ Reg6 Reg5 AB ADD RAMF NoCyc nCn nDone ] JUMP IncX ;
                      % Compute d = d + 4*(x-y) + 10 %
                      % First x-y %
                      POS
                                  [ Reg1 Reg6 ZA ADD RAMF NoCyc nCn nDone ] CONT ;
                                [ Reg4 Reg6 AB SUBS RAMF NoCyc Cn nDone ] LOADC 1D ;
                      % Then 4*(x-y) %
                                  [ Reg6 Reg6 ZA ADD RAMU NoCyc nCn nDone ]
                      SHIFTR6:
                                    LOOPNZ SHIFTRE ;
                      % Add 10 %
                                [ Reg9 Reg6 AB ADD RAMF NoCyc nCn nDone ] CONT ;
                                [ Reg6 Reg5 AB ADD RAMF NoCyc nCn nDone ] CONT ;
                     % Decrement y %
                              [ Reg1 Reg1 ZA SUBR RAMF NoCyc nCn nDone ] CONT ;
                     % increment x and repeat til x = y %
                              [ Reg4 Reg4 ZA ADD RAMF NoCyc Cn nDone ] JUMP OUTERLOOP ;
                     IncX:
                     % Last pixel write / ends octant with x = y (45 degrees) %
                                [] Call CircPix ;
                     DrawEnd:
                              [] LOADC 16D ;
                     % Issue Done to processor for 16 clocks %
                                [ Reg1 Reg1 ZA ADD RAMF NoCyc nCn Done ]
                     DoDone:
                                  LOOPNZ DoDone ONZERO WAIT :
                     % End Main Routine %
                     % This routine reflects the pixel into all octants and calls a
                     routine which translates the pixel relative to x0,y0,
                     calculates the pixel address as addr = x + y*1023 and runs the
                     memory cycle. %
```

## SAM Microassembler Opcodes

The basic SAM device instruction set accessible by the user through the microassembler consists of:

### CONTINUE

Execute next sequential instruction

- JUMP (label1)
- Jump to instruction specified @ label1
- LOOPNZ (label1) ONZERO (label2) If Count Register (CREG) is zero, execute instruction @ label2, else decrement CREG and execute instruction @ label1. Useful for oneinstruction timing and delay loops.
- DECNZ GOTO (label1) Decrement the CREG if non-zero; execute instruction @ label1.
- POPC GOTO (label1) Top-of-Stack is popped into CREG and the instruction @ label1 is executed.
- POPXORC (constant1) GOTO (label1) Top-of-Stack is popped, bitewise XORed with (constant1) and loaded to CREG. Instruction @ label1 is next executed. Useful for comparing Top-of-Stack to a value by subsequently testing CREG zero-flag using a LOOPNZ instruction.
- LOADC (constant1) GOTO (label1) CREG is loaded with the value constant1, and instruction @ label1 is next executed.
- RETURN

Address of the next instruction is popped from Top-of-Stack and subsequently executed. Used to terminate subroutines.

- PUSHLOADC (constant1) GOTO (label1) CREG value is pushed onto the Stack and CREG is reloaded with constant1.
- PUSHI GOTO (label1) The eight input lines are pushed onto the Top-of-Stack and the instruction at label1 is subsequently executed. May be used to implement a "dispatch" function in conjunction with a subsequent RETURN instruction: external inputs provide address of next SAM instruction.
- ANDPUSHI (constant1) GOTO (label1) The eight input lines are bitwise ANDed with constant1, the result is pushed onto the Stack and the instruction @ label1 is subsequently executed. May be used to mask inputs before loading to CREG or next address.
- CALL (label1) RETURNTO (label2) Label2 is pushed onto the Stack, and the instruction @ label1 is executed next. Used for subroutines.
- PUSH (constant1) GOTO (label1) Constant1 is pushed onto the Stack and the instruction @ label1 is next executed.

The Branch Control Block of SAM is invoked automatically by use of IF...THEN...ELSE constructs in conjunction with the above instructions. This allows program flow control based upon external inputs as in conventional state machines and multi-way branching in a single clock.

## An Actual Design Example

Now that the basic syntax and elements of a SAM ASM file have been covered, a detailed example of a SAM application will be presented: a high-performance Graphics Controller. In this particular application, two SAM devices will be horizontally cascaded to generate the control outputs for a graphics subsystem. This subsystem provides graphics primitive drawing capability for a larger microprocessorbased system.

Figure 4 shows a typical 8086 microprocessor-based system. Beneath the Address/Data Buses is the graphics subsystem to be controlled by the SAM devices, the primary elements of which are a 1 Megabyte high-speed static RAM video frame buffer (giving individual pixel addressing capability), five WS5901 bitslice elements used to construct a 20 bit ALU/data path engine, and two SAM devices as previously mentioned to provide overall control within the subsystem.

This basic graphics engine represents a user-microcodeable arrangement which can potentially support many primitive graphic drawing operations such as line drawing, polygon filling, drawing of conic sections and others. For the purposes of this example, a single primitive drawing operation which draws circles of arbitrary radius and origin into the frame buffer will An Actual Design Example (Cont.) be discussed. The basic concept behind this algorithm will be discussed below.

In order to execute its role of controller for this subsystem, the pair of SAM devices must be able to execute the following subfunctions

- Read Commands issued by main microprocessor
- Transfer Parameters associated with commands to Register File in WS5901's
- Initialize Constant Registers in WS5901's to specified values for algorithm
- Compute values for pixels on circle as function of specified Radius for first octant [Assume circle origin = (0,0)]
- Translate x,y coordinates into RAM addresses

- Reflect circle pixel coordinates into remaining seven octants
- Translate pixel coordinates relative to actual origin
- Perform Video Buffer write to all pixel addresses specified
- Issue DONE interrupt to main processor

This activity is done independently of the main microprocessor and frees it up to do other tasks while the operation is performed.

These operations fall into two general categories of controlling bus transfers between various elements (Registers, ALU, RAM, etc.) and sequencing computations performed by the WS5901 ALU in generating the pixel addresses to be set to draw the required circle. The structure of the SAM microassembler code shown above generally follows this flow.





#### *Circle Drawing Algorithm Overview*

The sample algorithm to be implemented in the SAM code to draw the circle is one based upon a methodology developed by Bresenham. In order to speed computation, it exploits the fundamental symmetry of a circle, by calculating the circle points in the first octant (see Figure 5), and then reflecting those coordinates into the other seven octants. For a given pixel location (x,y), reflection involves drawing points



| Circle Drawing<br>Algorithm<br>Overview<br>(Cont.) | (-x,y), (x,-y), (-x,-y), as well as those points<br>with x and y swapped. In drawing the<br>points for a circle in the first octant, one<br>can easily see that, having just calculated<br>one of the pixel locations, there are only<br>two possible choices for the next pixel<br>location: increment x (horizontal move) and<br>increment x and y (diagonal move). The<br>trick is how to decide, based upon current<br>location, which of the two to pick next.<br>The entire derivation of the algorithm will<br>not be presented here. However, a | complete discussion of the algorithm may<br>be found in Foley and Van Dam (1981),<br>referenced below. Suffice it to say, it is<br>obvious that the best match between<br>actual pixel coordinates and the ideal<br>circle points can be obtained by checking<br>an error term equal to the difference in<br>distance from the circle's center to each of<br>the two potential next pixel choices: the<br>sign of the term will indicate which point to<br>pick to obtain the best fit.<br>The basic algorithm implemented is shown<br>in Figure 6. |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing<br>Considerations                           | SAM timing analysis is straightforward, as<br>all times are relative to the synchronous<br>clock input. Tsu specifies minimum set-up<br>time for inputs to gain recognition at the<br>next clock edge, while Tco specifies clock-<br>to-output delays for the user-configured<br>output pins. Output tri-state and enable<br>times are speced as Tcz, but are not<br>relevent in this particular application as<br>outputs are always enabled.<br>For this particular design example, the                                                               | 18 nanosecond set-up time (Tsu) relative to<br>the clock edge.<br>High-speed Static RAM will be used for<br>the video frame buffer for two reasons:<br>one is raw speed. The memory must be<br>fast enough to keep up with SAM's high-<br>speed bus cycles. The second is that<br>SRAM requires no refresh cycles, unlike<br>DRAM. Thus more time is available to<br>perform buffer drawing functions: no time<br>is her for refresh cycles.                                                                                                        |
|                                                    | SAM448-25-controlled graphics subsystem<br>is being driven by a 15 MegaHertz clock.<br>This implies a clock period of 66<br>nanoseconds. SAM control outputs will<br>reflect a Tco of approximately 18<br>nanoseconds, while inputs must obey a                                                                                                                                                                                                                                                                                                         | is lost for refresh cycles.<br>Memory consists of CMOS SRAM<br>components organized 8K × 8 with an<br>access time of 45 nanoseconds, and a<br>minimum Write Pulse width of 30<br>nanoseconds. The CMOS WS5901 bit-                                                                                                                                                                                                                                                                                                                                  |



| Timing<br>Considerations<br>(Cont.) | slices require a 30 nanosecond<br>propagation delay from A and B Register<br>Address inputs to valid Y output, and a 10<br>nanosecond set-up time prior to the Clock<br>high-to-low transition on A and B inputs. A<br>timing diagram is shown in Figure 7.<br>The bus cycle uses a two clock approach.<br>During the first cycle, the WS5901 will<br>generate a pixel address to be set, and<br>during the second cycle, the actual write<br>pulse will be generated by SAM to write<br>the frame buffer.<br>Operations performed entirely within the                                                                                                                                                                                                                            | single clock cycle. Note that Carry<br>Lookahead circuitry is employed with the<br>WS5901 slices to improve arithmetic<br>computation times, but is not explicitly<br>shown in the block diagram.<br>The algorithm below uses many of the<br>WS5901's operations, as well as many of<br>the internal addressing modes. In the<br>following listings, standard mnemonics<br>have been used for the various Source,<br>Destination, and Operation specifiers.<br>These control lines for the WS5901's are<br>all generated by the SAM devices. These<br>mnemonics, and resulting WS5901                                                                                                                                                                                                  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | WS5901 slices (register transfers, ALU operations, etc.) are all executed in a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | functions, may be found in the WSI<br>WS5901 Data Sheet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Example Program<br>Listing          | <ul> <li>Figure 3 is a source listing of the basic circle drawing process. The following comments are worth noting before going further:</li> <li>Two SAM devices are used in a horizontal cascade configuration.</li> <li>Extensive MACRO definitions to ease design entry and allow the use of user-and WS5901-specified mnemonics.</li> <li>Two subroutines, CircPix and Trans, are invoked multiple times to draw the circle pixels. CircPix reflects the pixels into all octants of the circle as mentioned above, while Trans translates the pixels relative to the actual circle origin and runs the memory update cycle. These</li> </ul>                                                                                                                                 | <ul> <li>functions utilize the Stack and subroutining resources on SAM.</li> <li>Since the display is assumed to be 1024 × 1024 pixels, x and y pixel coordinates must be converted to SRAM address locations by multiplying the y coordinate by 1023 and adding the x coordinate.</li> <li>The signal CmdAtt is an input to the SAMs from the main processor, signaling that all parameters are loaded to the Parameter Registers, and that a circle drawing operation should be executed. DoneInt is a signal from SAM to the processor, asserted when the drawing operation is complete.</li> </ul>                                                                                                                                                                                 |
| Compiling the<br>Design             | By convention, microassembler source<br>files are given the extension .ASM. This<br>file is called CIRC.ASM. Compilation of<br>this design involves invoking the<br>SAM+PLUS software and specifying ASM<br>microassembler input format. A variety of<br>runtime options for SAM+PLUS are<br>available, which provide special reporting<br>modes and logging simulation input and<br>output to a special file. For detailed<br>descriptions of the SAM+PLUS user<br>interface and options, see the SAM+PLUS<br>User's Manual. Compilation is an automatic<br>process resulting in the generation of<br>programming "object code" for the EPLD<br>and EPROM blocks on SAM. In this case,<br>two programming files wil be generated,<br>since two devices are required to implement | the design. These two files are given the<br>extensions .JD1 and .JD2 to distinguish<br>them. These JEDEC files are not intended<br>to be user readable (as with any object<br>code). Functional simulation uses these<br>programming files for its modeling of SAM<br>operation. An additional product of the<br>compilation is a single Report file<br>(extensionRPT) which describes the<br>resources which have been used in the<br>SAM devices, pin assignments which have<br>been selected and absolute locations<br>within SAM's microcode assigned to the<br>instructions entered. Figure 8 shows key<br>portions of the CIRC.RPT report file.<br>Notice the assigned pinouts for the two<br>devices, as well as the substitution of<br>absolute addresses for logical labels. |

```
Figure 8. Report
File for Circle
                      SAM Design Processor Utilization Report
Drawing Routine
                      Version 1.01 7/28/87 01:57:09 38.1
                      ***** Design implemented successfully
                        .X:7
                      This is the Circle Drawing Design
                      % Circle Drawing Routine for SAM %
                                    SAM448
                                                                          SAM448
                                    _____.
                                                                           ____.
                     RESERVED : 1
                                          28 : RESERVED
                                                               A0 : 1
Gnd : 2
                                                                                 28 : A1
                          Gnd : 2
                                          27 : RESERVED
                                                                                 27 : A2
                          Gnd : 3
                                          26 : RESERVED
                                                               Gnd : 3
                                                                                26 : A3
                                          25 : 16
24 : Rd
                          Gnd : 4
C0 : 5
                                                            Gnd : 4
C0 : 5
CLOCK : 6
                                                                                25 : BO
                                                                                 24 : B1
                        CLOCK : 6
                                          23 : Wr
                                                                                 23 : B2
                                                               Vcc : 7
                          Vcc : 7
                                          22 : ALE
                                                                                22 : B3
                       nRESET : 8
C1 : 9
                                          21 : GND
20 : RegRd
                                                            nRESET : 8
                                                                                21 : GND
                                                            C1 : 9
C2 : 10
                                                                                 20 : 12
                                          19 : OE
                           C2 : 10
                                                                                 19 : 11
                       CmdAtt : 11
                                          18 : Cn
                                                            CmdAtt : 11
                                                                                 18 : 10
                                          17 : Done
16 : RESERVED
                         Sign : 12
                                                              Sign : 12
                                                                                 17 : 15
                     RESERVED : 13
                                                                Ī7 : 13
                                                                                 16 : 14
                                          15 : RESERVED
                     RESERVED : 14
                                                                18 : 14
                                                                                 15 : 13
                                                                    `_____′
                    ***** DESIGN LISTING
                    PART:
                            SAM448, SAM448
                    INPUTS:
                         CO, C1, C2, CmdAtt, Sign
                    OUTPUTS:
                         AO, A1, A2, A3, BO, B1, B2, B3, 12, 11, 10, 15, 14, 13, 18, 17
                    OUTPUTS:
                         16, Rd, Wr, ALE, RegRd, OE, Cn, Done
                    PINS:
                    DEFAULT:
                    [0000000000000011100100]
                    PROGRAM:
                    OD:
                         [0000000000000011100100] JUMP WAIT:
                    1920+
                    WAIT:
                         IF CmdAtt * CO' * C1' * C2' THEN
                              [0000000000000011100100] JUMP DOIT;
                         ELSE
                              [0000000000000011100100] JUMP WAIT;
                    1D:
                    DOIT:
                          [00010001000000011001100] JUMP 2D;
                    2D:
                          [00010001000000011001100] JUMP 3D;
                    3D:
                          [00100010000000011100000] JUMP 4D;
                    4D:
                          [00100010000000011001100] JUMP 5D;
                    5D:
                          [00100010000000011001100] JUMP 6D;
                    6D:
                          [00100010000000011100000] JUMP 7D;
```

Figure 8. Report File for Circle 7D : [001100110000000011001100] JUMP 8D; **Drawing Routine** 80. (Cont.) [001100110000000011001100] JUMP 9D; ٩n٠ [010001000111000111100000] JUMP 10D; 10D: [010001011000000111100010] JUMP 11D; 11D: [010101010110001111100000] JUMP 12D; 12D: [010110011000000111100000] JUMP 13D; 13D : [010101011000000111100010] JUMP 14D; 14D: [010110001000001111100000] LOADC 1D GOTO SHIFTR9; 15D: SHIFTR9: [100110011000001111100000] LOOPNZ SHIFTR9 ONZERO 16D; 16D · [100110011000000111100010] JUMP 17D; 170. [100110011000000111100010] JUMP 18D; 18D: [000101101000001111100000] JUMP 19D: 190. [010101100010100111100010] JUMP OUTERLOOP; 200. OUTERLOOP: [010000010010100111100010] JUMP 193D; 193D: IF Sign THEN [0000000000000011100100] JUMP DrawEnd: ELSE [00000000000000011100100] CALL CIrcPix RETURNTO 21D: 21D: [010101011000000111100000] JUMP 194D; 194D: IF Sign THEN [0000000000000011100100] JUMP POS; ELSE [010001101000001111100000] JUMP 22D; 22D: [011001101000001111100000] JUMP 23D; 23D: [100001100010000111100000] JUMP 24D; 24D: [011001010010000111100000] JUMP IncX; 25D: POS: [000101101000000111100000] JUMP 26D; 26D: [010001100010100111100010] LOADC 1D GOTO SHIFTR6; 270. SHIFTR6: [011001101000001111100000] LOOPNZ SHIFTR6 ONZERO 28D; 28D: [100101100010000111100000] JUMP 29D; 29D: [011001010010000111100000] JUMP 30D; 30D: [000100011000010111100000] JUMP IncX; 31D: IncX: [010001001000000111100010] JUMP OUTERLOOP; 32D: DrawEnd: [00000000000000011100100] CALL CircPix RETURNTO 33D;

| Figure 8. Report                   |                                                                             |
|------------------------------------|-----------------------------------------------------------------------------|
| File for Circle<br>Drawing Routine | 33D:<br>[00000000000000011100100] LOADC 16D GOTO DoDone;                    |
| (Cont.)                            | 34D:<br>DoDone:                                                             |
| . ,                                | [000100011000000111100001] LOOPNZ DoDone ONZERO WAIT;<br>35D:               |
|                                    | CircPix:<br>[010001101000000111100000] JUMP 36D;                            |
|                                    | 36D:<br>[000110111000000111100000] CALL TRANS RETURNTO 37D;                 |
|                                    | 37D:<br>[010001101000100111100010] JUMP 38D;                                |
|                                    | 38D:<br>[000110111000000111100000] CALL TRANS RETURNTO 39D;                 |
|                                    | 39D:<br>[0001011010000000111100000] JUMP 40D;                               |
|                                    | 40D:<br>[010010111000000111100000] CALL TRANS RETURNTO 41D;                 |
|                                    | 41D:<br>[010010111000100111100010] JUMP 42D;                                |
|                                    | 42D:<br>[000101101000000111100000] CALL TRANS RETURNTO 43D;                 |
|                                    | 43D:<br>[000110111000100111100010] JUMP 44D;<br>14D:                        |
|                                    | 44D:<br>[010001101000000111100000] CALL TRANS RETURNTO 45D;<br>45D:         |
|                                    | [000101101000100111100010] JUMP 46D;<br>46D:                                |
|                                    | [0100101111000000111100000] CALL TRANS RETURNTO 47D;<br>47D:                |
|                                    | [010001101000100111100010] JUMP 48D;<br>48D:                                |
|                                    | [000110111000100111100010] CALL TRANS RETURNTO 49D;<br>49D:                 |
|                                    | [000101101000100111100010] JUMP 50D;<br>50D:                                |
|                                    | [010010111000100111100010] CALL TRANS RETURNTO 51D;<br>51D:                 |
|                                    | [00000000000000011100100] RETURN;<br>52D:                                   |
|                                    | TRANS:<br>[001110110010000111100000] JUMP 53D;                              |
|                                    | 53D:<br>[001001100010000111100000] LOADC 10D GOTO 54D;                      |
|                                    | 54D:<br>[101111001000000111100000] JUMP MULT1024;                           |
|                                    | 55D:<br>MULT1024:                                                           |
|                                    | [101110111000001111100000] LOOPNZ MULT1024 ONZERO DONE1024;<br>56D:         |
|                                    | DONE1024:<br>[1100101100100101111100010] JUMP 57D;                          |
|                                    | 57D:<br>[011010110010000111100000] JUMP RUNBUS;                             |
|                                    | 58D : RUNBUS :                                                              |
|                                    | [101110111000000111110000] JUMP 59D;<br>59D:                                |
|                                    | [101110111000000111000100] RETURN;                                          |
|                                    | END\$                                                                       |
|                                    | ***** PART UTILIZATION                                                      |
|                                    | 60/192 Unconditional Branches (31.25%)<br>3/64 Conditional Branches (4.69%) |
|                                    | 0 Warnings                                                                  |
|                                    | 0 Fatal errors                                                              |

Design Simulation The SAMSIM functional simulator allows simulation of single-, as well as multiple-SAM designs. Once a design has been successfully compiled, the user can specify input stimulus in a variety of formats and observe the device response. SAMSIM supports both hard-copy waveform and tabular output, as well as interactive "virtual logic analyzer" viewing on the PC monitor. Split-window, multiple zoom levels, and delta time display are a few of the capabilities available for analyzing the simulation results in this fashion.

SAMSIM supports both interactive and command file input. Shown in Figure 9 is a sample input stimulus command file for this design. Command files are typically given the design name with extension .CMD. In this example, CIRC.CMD is the name of the command file. The first line specifies the source JEDEC files. Note only the primary file name is given and not the extensions. GROUP CREATE creates a group called CF containing 3 signals (C0-C2). By creating this group, the input pattern for the group can be

#### Figure 9. Command File

JEDEC CIRC GROUP CREATE CF = CO C1 C2 PATTERN CREATE CF = (OH)\*200 PATTERN CREATE CmdAtt = (0)\*5 (1)\*2 (0)\*193 PATTERN CREATE Sign = (0)\*200 TRACE CREATE CIRC.TRC TRACE ON SIMULATE 200 VIEW

specified in the PATTERN CREATE CF statement immediately following, rather than having to enter each signal's stimulus separately. The PATTERN CREATE statement shows the sequential values the given input (or group of inputs) is to take beginning at the start of the simulation and continuing onward. Hex format (as shown) can be used to streamline group pattern entry further. The notation ()\*n indicates repeat the enclosed stimulus pattern n times. TRACE CREATE creates a trace buffer file CIRC.TRC into which the state of SAM wil be dumped after each simulation step. This information includes internal information such as value on Topof-Stack, counter value, etc., as shown in Figure 10. TRACE ON turns the trace process on and may be discontinued with a TRACE OFF command later in the command file. SIMULATE 200 specifies a 200 clock simulation is to be run, and finally VIEW enables interactive viewing of the results of the simulation when complete.

Other useful commands supported by SAMSIM, but not used in our example include (among others):

SET - Modifies values of internal stack, counter, etc.

RADIX - Defines default radix for all SAMSIM input. Options are decimal. binary and hex.

LINK - Logically links device pins for simulation purposes.

Running SAMSIM with the above command file gives the output shown in Figure 11.

In reviewing the simulation output figure, a few words of explanation are required. It is immediately apparent that there are two types of output displayed, two examples of which are CmdAtt and AF. CmdAtt is an example of a single signal waveform, in this case corresponding to a device input. AF corresponds to a group of four signals (note the (4) after the name AF) which includes A0-A3. For AF. the values in the group are displayed in a vertical hex notation each time any signal in the group changes. (If an explicit value is not displayed, it is the same as the previous time step's value). By grouping common signals, much more information can be displayed in a single screen than might otherwise be visible. In our example A (AF = A3-A0), B (BF = B3-B0), and I outputs (IL = I2-I0, IM = I5-I3, IH = I8-I6) are viewing groups which have been formed.

| Figure 10. Trace |                                              |
|------------------|----------------------------------------------|
| File Output      | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
| •                | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | MULT1024: 55D: [12288992D] LOOPNZ MULT1024 ; |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | DONE1024: 56D: [13313506D] CONTINUE ;        |
|                  | Sign=0 CmdAtt=0 c2=0 c1=0 c0=0               |
|                  | 55D: [7021024D] CONTINUE ;                   |

The virtual logic analyzer supports commands which allow the order of waveforms to be changed interactively, arbitrary signal groups to be constructed, among others. An on-line HELP command gives instant explanations for all commands. An extremely flexible interactive analysis tool is the result.

The simulation results shown in Figure 11 correspond to the first 40 or so clocks after the graphics controller receives a

CmdAtt signaling the beginning of a circle drawing operation. The three RegRd pulses correspond to reading the circles' radius and x-y origin from the parameter register. The single OE pulse two-thirds of the way across the display is the point where the CircPix routine is first entered. It is left as an exercise to the reader to verify the intermediate output values by following the CIRC.ASM source file.

#### **Conclusion**

The SAM device provides an efficient solution for sophisticated control problems such as the graphics controller just described. SAM's capability is applicable to a wide range of problems, including industrial control, graphics and disk controllers, programmable sequence generators and the like. The SAM+PLUS tool set makes the design, verification and debug of such designs straightforward. The combination represents a winning approach to control design.



#### Output



#### References

WSI 1990 Data Book SAM448 Data Sheet WSI Application Note #4: SAM Applications Using State Design Entry

J. Foley & A. Van Dam, Fundamentals of Interactive Computer Graphics, Addison Wesley, 1981

4



## Programmable System™ Device

Application Note 004

SAM Applications Using State Machine Design Entry

| n Note.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ery fast state machines of low-to-<br>omplexity which required few<br>d relatively simple state flows or<br>algorithms." Ability to perform<br>control branching in a single<br>e is a plus for this approach.<br>Juch as conventional registered<br>representative of this class.<br>rm count limitations, resulting in<br>y to generate complex output<br>or state transitions, limits the<br>is approach when addressing<br>trol problems. |
| u<br>Pit<br>s                                                                                                                                                                                                                                                                                                                                                                                                                                 |



| The SAM<br>Solution (Cont.)            | functions, requiring high control output<br>counts. Until recently, however, the only<br>mechanism for implementing this approach<br>has been to glue together an assortment<br>of bit-slice component building-blocks. In<br>addition, the approach also did not lend<br>itself to rapid multi-way branching (a<br>strength of Logic Arrays), instead being<br>relegated to a serial test-and-binary-branch<br>mechanism.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | An enhanced vehicle for state machine<br>implementation really requires a marriage<br>of these two architectures, to obtain the<br>high performance, multi-way branching<br>based on real-time inputs characteristics of<br>Logic Array-based sequencers, while having<br>the ability to manage complex algorithms<br>and generate high output counts<br>characteristic of microcoded approaches.<br>WSI's SAM448 does exactly this.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAM+PLUS<br>System Overview            | The versatility of the SAM architecture,<br>and its applicability to both State Machine<br>and complex Controller functions, has<br>necessitated the need for multiple design<br>input formats. WSI's SAM+PLUS PC-based<br>Design Software allows the designer to<br>enter his design in either a high-level state<br>machine description using WSI's ASMILE<br>language, or in an efficient microcode<br>assembler format known as ASM. A block<br>diagram of this system is shown in Figure 2.<br>Given these options, the user can employ<br>the design description most appropriate for<br>his particular problem, or which he is<br>personally most comfortable with.<br>The SAM Design Processor (SDP) takes<br>the input file and automatically minimizes<br>the transition specification logic and fits<br>the resultant resource requests to the SAM                                                                                                                                                     | architecture. A Utilization Report is<br>generated which reports total resources<br>consumed, any unfittable requests, and<br>assigned pinouts. Upon successful fitting,<br>a standard JEDEC file is generated to allow<br>programming of the device using a hardward<br>programming card installed in the PC.<br>In addition, this JEDEC file, which represents<br>the actual template of the specific application<br>implemented, may be used as input to the<br>SAMSIM (SAM SIMulator) program which<br>provides functional simulation capability<br>integrated into the total design environment<br>Hard-copy output of simulation results may<br>be obtained, as well as on-line "logic<br>analyzer" viewing capability. The result is<br>a design entry, compilation and verification<br>system which can be iterated rapidly until<br>the desired functionality is obtained. |
| Sizing-Up a<br>Potential<br>SAM Design | There are two broad categories of state<br>machines. Mealy and Moore machines<br>(see Figure 3). Given the SAM architecture,<br>one can see that Moore machines may<br>be directly implemented into a SAM<br>component: SAM's outputs are a function<br>of the currently addressed microcode<br>location (state). Mealy machines specify<br>outputs as functions of state and inputs.<br>However, Mealy machines can frequently<br>be converted to equivalent Moore machines.<br>The general rule for this conversion is that<br>for each transition into a state in the Mealy<br>machine with a unique set of outputs,<br>insert a state into the Moore machine with<br>that output combination. Figure 4 illustrates<br>this concept.<br>ASMILE supports the resources available<br>on SAM for state machine design. Additional<br>feaures, such as the stack and counter,<br>are supported in the microassembler format<br>which lends itself to their efficient use.<br>In order to determine whether a given | <ul> <li>"rules-of-thumb" derived from the device architecture and specifications can prove helpful:</li> <li>Operating frequency less than or equal to specified SAM device's Fmax</li> <li>Synchronous, Moore machine operation</li> <li>Up to eight state machine inputs (not including CLOCK or RESET)</li> <li>Up to sixteen state machine Outputs</li> <li>Up to 64 Multi-Way (conditional) state branches</li> <li>Transition expressions reducible to four product terms per IF THEN expression</li> <li>192 or fewer unconditional state transitions</li> <li>An application which meets the above list of requirements will probably fit into a SAM device.</li> </ul>                                                                                                                                                                                                    |

application is suitable for SAM, a few brief



4



ASMILE Entry Overview

The basic format of a SAM ASMILE file consists of the following sections:

[Header] PART INPUTS OUTPUTS [EQUATIONS] MACHINE CLOCK STATES Transition Specifications END\$

Those sections surrounded by [] are optional and may be deleted if their use is not required in a given application.

ASMILE files may be constructed utilizing any standard text editor in non-document mode. Using an editor in document mode may inject spurious format control characters which will be detected as syntax error by the ASMILE parser at compile time. Other than this constraint, input is essentially free-form and may be structured for readability and overall clarity.

The case of characters inserted into the ASMILE file is significant, so it is important to insure that character case is maintained as text is entered. For example, the names "RWB" and "rwb" are not the same.

Comments may be inserted freely into the source code, delimited by leading and trailing percent signs, for example,

% This is a comment %

#### Header

The header contains user-specified design identifier information. Typical information includes:

Designer's Name Company Date Design Number Revision SAM Part Number Other Comments

#### Part

The PART section of the ASMILE file specifies the target SAM device the application is intended for.

#### Inputs

The single INPUTS section of the ASMILE file defines all external inputs into the design, as well as any required user pin assignments. Pin assignments are optional and will be assigned by SAM+PLUS if not specified. Pin assignments are specified by the format

input\_name @ pin\_number

#### Outputs

The OUTPUTS section of the ASMILE file contains a list of all outputs from the design as well as any pin assignments. Pin assignment syntax is similar to input pin assignments.

#### Equations

The EQUATIONS section of the ASMILE file is available for the definition of intermediate equations to be used later in the design. Entry of transition specifications may be eased by defining intermediate variables initially, and then invoking them during the design. For example,

EventClk = I1\*/I4 + I3\*I6\*/I7

might be defined in the EQUATIONS section, and then utilized later in an IF . . . THEN statement.

#### Machine

The format for the MACHINE declaration is

MACHINE: machine\_\_name

The MACHINE section of the ASMILE file actually specifies the state machine's state, output, and transition definitions required from the SAM device. There are three subsections which are to be included: CLOCK, STATES, and Transition Specifications.

#### Clock

The CLOCK subsection specifies the clock signal which will act as the synchronous clock source for the state machine and the resulting SAM device.

#### States

The STATES section specifies all states in the target machine, as well as outputs corresponding to these states. The general form of this statement, when used in a SAM design, is

STATES: [output\_\_name\_\_1 . . . output\_\_name\_\_n]

state\_name [output\_value\_list]

In the above, the output\_names are a list of all SAM output names used in the design, separated by whitespace. Following this initial declaration, a list of all ASMILE Entry Overview (Cont.)

state\_\_names appears, each followed by a binary string in brackets which specifies all output values to be provided when the machine is in that state.

For example,

| STATES: |           |
|---------|-----------|
| S0      | [0 0 0 0] |
| S1      | [0 1 1 0] |
| S2      | [1000]    |
| S3      | 0001      |

Specifies a machine with four outputs A through D, State  $S_0$  has all outputs low,  $S_1$  takes B and C to logic one,  $S_2$  has only output A high, etc.

#### **Transition Specification**

The form of the Transition Specifications in a SAM ASMILE design is

state\_\_name: transition\_\_specification

Every state in the machine must have a transition\_specification which will specify successor states, either unconditionally

S0: S2

or conditionally using IF . . . THEN statements.

The first state\_\_name encountered in the Transition Specification section will be defined as the initial state of the machine coming out of Reset. As such, it has special significance. Typically, this might be defined as an "inactive" or passive machine state. Other Transition Specifications have no positional significance.

#### If . . . Then Statements

The SAM architecture implements in silicon the state transition specifications defined by a user in the chip's Branch

Control logic block. This block allows, by its structure, the specification of up to 64 complex branching expressions in a single machine. [As noted above, up to 192 unconditional state transitions may be specified for a single SAM device]. Each IF . . . THEN expression may specify a direct branch from the current state to as many as four other successor states, based upon inputs to the SAM device. This is illustrated in Figure 5. Examples are shown below.

In specifying IF ... THEN expressions, it is valuable to note that the order of the expression is important and can determine the machine flow. Transition specifications need not be mutually exclusive in such expressions. For example, the expression

#### S0: IF I1\*I2 + I5 THEN S1 IF I5\*I6 + I4\*/I3 THEN S2 IF I4 THEN S3 S4

might appear ambiguous under the condition that inputs I5 and I6 to the SAM device become true during S0. Is S1 or S2 the next state? At this point SAM's priority logic comes into play. Since the S1 transition is specified before the S2 in the design definition, it will be the next state entered. Similarly, if I4\*/I3 become valid, S2 will be the next state entered in preference over S3. This precedenceresolving capability is provided in the SAM silicon architecture which employs a hardware priority encoder in selecting the next state transition. This capability resolves conflicts, and may be exploited in the design to prioritize transitions.



|                              | state entered if S1, S2, and S3 are not<br>selected by the appropriate conditions<br>being true. This feature can reduce design<br>effort and resource requirements<br>substantially, since default transitions are<br>frequently defined as the negation of non-<br>default transitions and such inverted<br>expressions have a tendency to consume<br>logic product terms or resources quickly.<br>For example,<br>S0: IF I1*I2 + I5*/I7 + I0 THEN S1<br>IF I3 + /I6*I4 THEN S2<br>IF I2*I3*I4*I5/I7 THEN S3<br>S4<br>is a valid ASMILE SAM transition<br>specification. If the notion of a default<br>transition (S4) was not in the ASMILE<br>syntax, and had to be explicitly defined,<br>we might have to specify the last transition<br>as (unminimized)<br>IF /(I1*I2 + I5*/I7 + I0) * /(I3 + /I6*I4)<br>* /(I2*I3*I4*I5'/I7) THEN S4 | designs, this should<br>A trade-off betweer<br>destinations and pr<br>destination can be<br>IF THEN expression<br>S0: IF (cond1)<br>IF (cond2)<br>IF (cond3)<br>S3<br>provides a three-wa<br>eight product terms<br>specification of trar<br><b>End\$</b><br>Every SAM ASMILE<br>terminate with the I |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SAM ASMILE<br>Design Example | To illustrate SAM ASMILE input syntax in a real example, a 68020 Microprocessor Bus Arbiter state machine will be examined. This machine, while not overly complex, illustrates most of the concepts of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | exchanges betweer<br>Request, Grant, an<br>a bus master which<br>bus, the procedure<br>in Figure 6):                                                                                                                                                                                                  |
|                              | ASMILE entry.<br>Shown in Figure 7 is a state machine<br>diagram for the Bus Arbiter. The 68020-<br>based system runs at 25 MegaHertz, and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | In the above flow c<br>labels S0–S6 desig<br>between the operat<br>state machine diag                                                                                                                                                                                                                 |
|                              | therefore the Bus Arbiter machine must<br>also run with a 40 nanosecond clock<br>period. To understand its operation, a<br>review of the bus exchange protocol used<br>on the 68020 bus is useful.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Relating this seque<br>S0 represents the '<br>the processor, S1 a<br>the Grant phase, S<br>Acknowledge phase                                                                                                                                                                                          |
|                              | Three signal lines on a 68020 bus define the handshake required to arbitrate bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | rearbitration phase<br>at the end of the c                                                                                                                                                                                                                                                            |
| The Design                   | The file shown below in Figure 8 is the actual ASMILE file generated for the machine from the state diagram. It conforms to the general file outline as described above. ASMILE source files are                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | been defined which<br>during a unique sta<br>simulated, these wi<br>which state the ma<br>point in time.                                                                                                                                                                                              |
|                              | given the extension .SMF (for state<br>machine file) when generated. In this case,<br>the file would be 68020ARB.SMF. Note<br>that in the OUTPUTS and STATES<br>sections, output variables OS0–OS6 have                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | To compile this des<br>software is invoked,<br>(and not microasse<br>being used. For a c                                                                                                                                                                                                              |
| <del></del>                  | WA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | FERSCALE INTEGR                                                                                                                                                                                                                                                                                       |

**ASMILE Entry** 

**Overview** 

(Cont.)

**Default Transitions** 

One other benefit of this approach is the

the example above, S4 will be the next

implicit "default" transition to be made. In

Each expression (IF . . . THEN) may be a function of any of the eight SAM external inputs, and may contain up to four product terms after logic minimization. For most designs, this should prove ample.

n number of branch roduct terms per made, as multiple ssions can point to the For example, the

> THEN S1 THEN S1 THEN S2

ay branch, with up to available for the sitions to state S1.

E source file must END\$ terminator.

n multiple bus masters: d Acknowledge. Given h desires access to the is as follows (illustrated

description, the state anate correspondence tions shown and the iram above.

nce to the state diagram, "normal," active state of and S2 correspond to 5 and S6 the e, and S3 and S4 the if requests are pending urrent bus exchange.

h are each valid only ate. As the design is ill give an indication of chine is at any given

sign, the SAM+PLUS , specifying that ASMILE mbler) input format is detailed description of





#### The Design (Cont.)

the SAM+PLUS user interface and options, the SAM+PLUS User's Manual should be consulted. Compilation then proceeds automatically. Transition equations are automatically minimized, and "object code" generated for the EPLD and EPROM blocks. As a result, JEDEC programming file (.JED) is generated, as well as a Utilization Report file (.RPT) reporting the results of the compilation process. Functional simulation of the design can be performed using the .JED file as a design template as described below. The .JED file is not intended to be user-readable. The .RPT file contains valuable information such as design pin assignments and resource utilization. Figure 9 shows key portions of this file. All ASMILE input is transformed into microassembler format before subsequent processing, and the equivalent microassembler code for the design is given in the .RPT file as well. More information on the interpretation of this code can be obtained from the references shown below.

Figure 8. 68020 Bus Arbiter State Machine Input File (68020ARB.SMF)

STEVE MCGRAY WSI, INC. 6/18/88 68020 Bus Arbiter for SAM % This description uses IF...THEN Transition Specifications% PART: SAM448 % Pin Assignments (an option) are made by the designer % INPUTS: REQUEST ACKe2 OUTPUTS: GRANTe23 TRISTATEe22 OSO OS1 OS2 OS3 OS4 OS5 OS6 NETWORK -OUT3 = CONF (OUT3, CK, VCC, VCC, VCC) MACHINE: BUSARBITER CLOCK: CLK % STATES gives the output value mapping % STATES: [GRANT TRISTATE OSO OS1 OS2 OS3 OS4 OS5 OS6] SO [0 0 1 0 0 0 0 0] S1 [1 1 0 1 0 0 0 0 ] S2 [1 1 0 0 1 0 0 0] S3 [1 1 0 0 0 1 0 0 0] S4 [1 1 0 0 0 0 1 0 0] S5 [0 1 0 0 0 0 0 1 0] S6 [0 1 0 0 0 0 0 0 1] % Transition Specifications follow% SO : IF REQUEST\*/ACK THEN S1 IF ACK THEN S5 so S1: **S**2 S2 : IF /REQUEST\*/ACK + ACK THEN S6 **S**2 S3 : IF /REQUEST THEN S6 IF REQUEST\*/ACK THEN S2 **S**3 S4 : **S**3 S5 : IF REQUEST THEN S4 IF /REQUEST\*/ACK THEN SO **S**5 S6: **S**5 END\$

```
Figure 9. 68020
Bus Arbiter
Desian
                         SAM Design Processor Utilization Report
Report File
                         Version 1.01 7/28/87 01:57:09 38.1
                         ***** Design implemented successfully
(68020ARB.RPT)
                         STEVE MCGRAY
                         WSI, INC.
                         3/18/88
                         68020 Bus Arbiter for SAM
                                                       SAM448
                                                . -----.
                                      RESERVED : 1
ACK : 2
Gnd : 3
Gnd : 4
Gnd : 5
CLOCK : 6
                                                            28 : RESERVED
27 : RESERVED
                                                             26 : RESERVED
                                                             25 : RESERVED
                                                             24 : RESERVED
                                                             23 : GRANT
                                        VCC : 7
NRESET : 8
Gnd : 9
                                                             22 : TRISTATE
                                                             21 : GND
                                                              20 : RESERVED
                                            Gnd : 10
                                                              19 : OSO
                                            Gnd : 11
                                                              18 : OS1
                                       REQUEST : 12
                                                              17 : OS2
                                            OS6 : 13
                                                              16 : OS3
                                                              15 : OS4
                                            OS5 : 14
                                                 .
                          ***** DESIGN LISTING
                          PART:
                               SAM448
                          INPUTS:
                               REQUESTe12, ACKe2
                          OUTPUTS:
                               GRANTe23, TRISTATEe22, OSOe19, OS1e18, OS2e17, OS3e16,
                               OS4@15, OS5@14, OS6@13
                          PINS:
                          DEFAULT:
                               [000000000]
                          PROGRAM:
                            OD:
                                  [00100000] JUMP SO;
                            192D:
                            S0 ·
                         68020arb.rpt
                            IF REQUEST * ACK' THEN
                                  [110100000] JUMP S1;
                            ELSEIF ACK THEN
                                  [010000010] JUMP S5;
                            ELSE
                                  [00100000] JUMP SO;
```

Figure 9. 68020 Bus Arbiter Design Report File (68020ARB.RPT) (Cont.)

```
1D ·
  S1:
        [110010000] JUMP S2;
  193D:
  S2 :
       IF REQUEST' +
          ACK THEN
             [01000001] JUMP S6:
       ELSE
             [110010000] JUMP S2;
  194D:
  S3 :
        IF REQUEST' THEN
             [010000001] JUMP S6;
       ELSEIF REQUEST * ACK' THEN
             [110010000] JUMP S2:
       EL SE
             [110001000] JUMP S3:
  2D :
  S4:
       [110001000] JUMP S3;
  195D:
  S5 :
       IF REQUEST THEN
             [110000100] JUMP S4;
       ELSEIF REQUEST' * ACK' THEN
             [00100000] JUMP SO;
       EL SE
             [010000010] JUMP S5;
  3D :
  S6 :
       [010000010] JUMP S5:
END$
***** PART UTILIZATION
  4/192
              Unconditional Branches (
                                          2.08%)
  4/ 64
              Conditional Branches
                                          6.25%)
      0
              Warnings
      o
              Fatal errors
```

#### Design Simulation

Integral to the SAM+PLUS design system is the SAMSIM functional simulator. Once a design has been successfully processed, the user can specify input stimulus in a variety of formats and observe the device response quickly and effectively using this unit-delay simulator. As mentioned above, SAMSIM supports both hard-copy and virtual logic analyzer output formats. Splitwindow, multiple zoom-levels, and delta time display are a few of the capabilities of this interactive display mode.

SAMSIM supports both interactive and command file input. Shown in Figure 11 is a simple input stimulus command file for our design. Typically command files are given the design name with the extension .CMD (for example, 68020ARB.CMD). The first line specifies the source design JEDEC (or .JED) file. The next two lines illustrate logic sequences for the two machine inputs. The PATTERN CREATE command allows the user to specify a sequence of input logic levels to be applied to the indicated node or nodes. The notation ()\*n, where n is an integer, signifies hold the indicated logic value on the associated input for n clocks. SIMULATE 41 instructs SAMSIM to run the simulation for 41 clocks, and finally interactive display is invoked with the VIEW command.

Design Simulation (Cont.)

Some other representative SAMSIM commands, while not used in the example, include:

TRACE — Dumps entire state of machine (inputs, outputs, internal registers, etc.) for each clock executed.

GROUP — Specifies logical grouping of signals for easy observation or input vector specification.

SET — Modifies values of internal counter, stack, etc.

LINK — Logically links device pins for simulation purposes.

RADIX — Defines default radix for all SAMSIM commands.

Options are binary, hex, and decimal.

Running the SAMSIM simulator with this command file produces the results shown in Figure 10. Here, on the PC screen, is displayed the input stimulus to the SAM arbiter design, and the resulting state machine operation. The initial input stimulus applied to the SAM design shows a straightforward bus exchange between the 68020 and another bus master. This corresponds to the first **REQUEST/GRANT/ACK** sequence. Upon detecting a REQUEST, the 68020 asserts its TRI-STATE line, and issues a GRANT pulse, allowing the new bus master to assume control. The alternate bus master asserts ACK when it detects the fact that the bus has been granted. When ACK finally drops, the 68020 knows it can resume control. The second such sequence involves not just a single initial REQUEST (bus master #1), but a second REQUEST from another bus master (#2) during the time bus master #1 has control. As a result, the 68020 must generate a new GRANT pulse (during S4-S2), and handover bus control to bus master #2 when bus master #1 is finished (ACK is dropped). When bus master #2 is finished. and no requests are pending, the 68020 finally retakes control of the bus (TRI-STATE goes low).



#### Figure 10. SAMSIM Interactive Output

| Figure 11.<br>SAMSIM<br>Command File<br>(68020ARB.CMD) | JEDEC 68020AARB<br>PATTERN CREATE REQUEST = (0)*3 1 1 1 (0)*12 1 1 1 1 1 0 0 (1)*7 (0)*5<br>PATTERN CREATE ACK = (0)*5 (1)*8 (0)*10 (1)*6 (0)*2 (1)*6 (0)*4<br>SIMULATE 41<br>VIEW                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Conclusion                                             | State machine design is a straightforward<br>process using the ASMILE input language<br>in conjunction with the SAM device. Design<br>entry and debug, using functional simulation,<br>can be readily accomplished at the user's<br>PC. When the design is debugged and<br>complete, the SAM component may be<br>programmed using PC-based hardware<br>and software in seconds. Should design<br>errors be detected after in-system test, a<br>windowed SAM device may be erased, a<br>design change compiled, and the device<br>reprogrammed in minutes. |
| References                                             | WSI 1990 Data Book<br>SAM448 Data Sheet<br>WSI Application Note #3: High-End SAM<br>Applications Using Microassembler Design<br>Entry                                                                                                                                                                                                                                                                                                                                                                                                                     |





## Section Index

| Article Reprint | Microprogram an Embedded Controller — PAC1000 | 1 |
|-----------------|-----------------------------------------------|---|
|-----------------|-----------------------------------------------|---|

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.

WAFERSCALE INTEGRATION, INC.



## **COVER FEATURE**

## Packing All The Major Blocks Of A Microprogrammable System, A CMOS IC Eases Embedded Controller Designs **CONFIGURABLE CHIP EASES CONTROL-SYSTEM DESIGN**

**DAVE BURSKY** 

nyone who has ever designed a high-performance controller subsyst m using highspeed microprogrammed building blocks, programmable logic devices, gate arrays, or discrete logic

realizes the difficulties in integrating the complete solution. In such a system, the chip count escalates, the operating power rises, and the development schedule lengthens.

By integrating all these functions and resources onto one high-speed CMOS chip—the PAC1000 microcontroller—WaferScale Integration Inc. has drastically reduced the chip count from the typically required 50 or so ICs to just one. At the same time, the PAC1000 slashes the power consumption from tens of watts to less than 1.5 W and cuts development time.

The PAC1000 can solve many highend embedded control applications and is the only available circuit that can tackle system, data, and event control tasks. A C-like language and PC-hosted system-development tools simplify the creation of the control software. Users can configure the circuit as a microprocessor peripheral or as a standalone controller to meet the unique requirements of high-performance system, data, or event controllers. Each of the chip's two bidirectional 16-bit buses, its individual I/O lines, and interrupt inputs can, if necessary, be redefined during each 50-ns instruction cycle.



At the heart of the PAC1000's flexibility lies an internal microprogrammable architecture, including a 16-bit CPU, a fast 10-bit microsequencer, a 32-wordby-16-bit register file, and a 1kword-by-64-bit high-speed EPROM. As product planning manager Yoram Cedar explains, since the circuit executes any of its instructions in one clock cycle, the controller delivers a raw throughput of

Copyright 1988 VNU Business Publications, Inc

Reprinted with permission from ELECTRONIC DESIGN - October 27, 1988

## COVER: USER-CONFIGURABLE CONTROLLER

#### 20 MIPS.

Every instruction of the PAC1000 can perform as many as three simultaneous operations: program control, CPU functions, and output control, with all possible combinations allowed. Cedar claims the more powerful instruction format, combined with the higher clock speed, yields a five- to tenfold performance improvement, compared with other one-chip microcontrollers. The high throughput suits many tasks well. It has already found homes in radar, communications, video-graphics, I/O subsystems, bus and DMA controllers, and disk-drive-controllers.

Besides the CPU, register file, and sequencer, the chip includes an auxiliary Q-register for double-word operations, an 8-input interrupt controller, 16 output control lines, 8 bi-



directional I/O lines, scan-test and CASE program test logic, and a 22bit external address bus (*Fig. 1, top*).

Also, Cedar emphasizes, the circuit deals much more rapidly with interrupts than most controllers do. and that serves embedded control applications well. The chip changes program flow in either of two ways. First, it has four user-definable interrupt input lines plus four dedicated internal interrupts that require just 100 ns, at most, to alter the program flow. Second, another set of input lines-22 condition-code inputs (8 external and 14 internal)-let the processor alter the program flow with condition calls and program jumps in just one 50-ns instruction cycle.

And if on-chip resources don't quite match an application's requirements, chip modifications can be done for large-volume users. The circuit was designed with the company's standard-cell library, and many of the chip's sections are actually cells in WaferScale's library (Fig. 1, left). Noticeable on the chip's left side are the large cells that include the 64-kbit EPROM block on the bottom and the 16-bit CPU on the upper left. On the chip's right side, random logic performs the control and interface functions: small standard cells are used to create those circuits.

For every instruction, a dedicated field specifies the bit pattern on the output lines. Also, designers can individually program eight I/O lines as inputs or outputs or to perform special functions under the control of the chip's mode and I/O registers. The special functions turn the I/O lines into control signals that allow various features and flags to indicate several status conditions. In addition to the eight I/O lines, the circuit has two 16-bit bidirectional buses that go on and off the chip: One links with the host; the other is the upper 16 bits of the address/data bus. Another 16 lines are dedicated, user-programmable latched output lines. These can be changed on a cycle-by-cycle basis.

Thanks to all its buses and control signals, the PAC1000 microcontroller operates as either a memory-

## COVER: USER-CONFIGURABLE CONTROLLER

mapped peripheral to a microprocessor to offload the CPU (Fig. 2a) or as a standalone controller running from its own internally or externally stored program (Fig. 2b). As a peripheral, the chip ties into the host with a straightforward bus interface—a 16-bit data bus and a 6-bit address bus to access the internal resources of the PAC1000-and the standard Chip Select, Read, and Write control lines. In the standalone mode, the chip typically runs the application program from its internal memory and uses its 16-bit output bus and 8-bit I/O port to control the application and communicate to a host system.

To handle multiple operations in parallel, the chip internally takes advantage of a long-64-bit-microcode word so that each word can control multiple sections of the circuitry. The on-chip microcode storage area consists of a fast, reprogrammable UV EPROM, organized as 1 kword by 64 bits. Since the EPROM is read only by the on-chip logic, it doesn't need high-current output buffers, which slow down the memory access. Thus, the EPROM contents can be read very quickly-the chip's 20-MHz version accesses memory in just 30 ns, well within the CPU's 50-ns instruction cycle time. The memory is also secure. Users can program a security bit to prevent an external system from extracting the code from the memory array.

Besides its own program memory, the chip also has a separate address/ data bus that can be programmed for either 16 or 22 address lines (with 64kword or 4-Mword off-chip addressing ranges, respectively). The address generator for the bus is separate from the sequencer that addresses the program memory. The PAC1000 can therefore execute a program while it's using the address bus to move data from memory into the on-chip register file or to an externally controlled device.

The address bus, in fact, can serve as a simple direct-memory-access controller when used with the onchip 22-bit address counter and 16-bit block counter. This DMA controller can transfer data from external memory to the on-chip register file or to an external device.

An eight-word FIFO register lets a host microprocessor asynchronously load commands or data into the controller. The 22-bit word length in the FIFO register is employed, so that if data values are to be loaded into the register file, the lower 16 bits of the 22-bit word sent over the host data bus represent the data, and the next five bits-the lower five bits of the host-interface address bus-represent the register location into which the data will be loaded (R0 to R31). The sixth bit of the host-interface address bus signifies whether the word loaded into the FIFO register is a command or data word. If it's a command, the lower 10 bits of the host-data bus are used as a branch address to one of the 1024 memory locations in the EPROM.

The 10-bit sequencer addresses the 1,024 words of program memory and has a 15-level stack that permits multiple subroutine calls to occur without forcing the program to go back to a higher level before calling the next subroutine. Besides having more levels in the stack than WaferScale's 5910 microsequencer, the enhanced sequencer block has a 10bit loop counter that cuts overhead in programs for loops and nested loops. The application program can load the counter with a constant or a value calculated in the CPU.

Because programming fast, embedded controllers can get complicated, the company includes on-chip programming and test features to ease system development. For starters, a 10-bit breakpoint register simplifies real-time debugging. It can be loaded from either of two sources—a value stored in a CPU register or a constant value specified in the program memory. When the program memory address matches the register contents, the register issues an interrupt, which a service routine in memory could then react to.

Test and CASE logic on the chip also aids program and hardware testing. The condition-code logic responds to 22 different program test conditions that can be tested for true



2. MULTIPLE BUSES, AN ON-CHIP ADDRESS GENERATOR, and sequencer blocks let the microcontroller operate as a memory-mapped peripheral to offload the host microprocessor (a). Or it can be operated as a standalone controller (b).

## COVER: USER-CONFIGURABLE CONTROLLER

#### SAMPLE PROGRAM FOR PAC1000 MICROCONTROLLER

| /* control memory read/write based on CC0 */<br>segment memcon , |                                     |    |
|------------------------------------------------------------------|-------------------------------------|----|
| enmem equ h'0002',                                               | /* output control constants         | */ |
| dismem equ h'0040',                                              |                                     |    |
| wr egu h'0000',                                                  |                                     |    |
| rd equ h'1000',                                                  |                                     |    |
| start                                                            |                                     |    |
| IF CC0 , OUT enmem ,                                             | /* enable memory                    | */ |
| FOR 6, AOR = $R0 + R1$ , OUT wr,                                 | /* store begin addr in AOR and loop | •/ |
| AOR = AOR + 4, OUT rd,                                           | /* inc addr by 4 and do rd/wr       | */ |
| ENDFOR, OUT wr,                                                  | /* end loop body                    | •/ |
| ELSE, OUT dismem,                                                | /* disable mem if CC0 is not true   | •/ |
| ENDIF,                                                           |                                     |    |
| end ,                                                            |                                     |    |



or not-true results. Up to four conditions can be tested simultaneously. Tests can check for the state of various flags or register contents.

The processor handles two types of CASE operations: standard and priority. A CASE group consists of a combination of four test conditions that can be tested in a single cycle. In that same cycle, the PAC1000 branches to any one of 16 locations, depending on the status of the four inputs to the CASE group being tested. The priority CASE instruction operates on internal and external interrupt conditions and treats interrupts as prioritized test conditions. The priority encoder generates a branch to the highest-priority condition.

Thanks to all its on-chip resources, the PAC1000 is a powerful one-chip controller, housed in a windowed, 88lead pin-grid-array package or an 84lead ceramic leaded chip carrier. An 84-lead plastic leaded chip carrier package (the one-time-programmable version) is also available. Because the chip employs an EPROM to hold the program, revisions to the code are no more difficult than reprogramming a standard EPROM. Prototype systems and production products can benefit from the ability to revise the code at the last minute.

To alleviate the complexity of microcode program development, WaferScale has assembled a series of PC-hosted system-development tools (PAC-SDT). These make the PAC1000 as easy to program as any one-chip microcontroller. A simple example of a multiple-command expression in the C-like language lets designers combine operations such as FOR6,AOR=R0+R1,OUT WR (loop for six cycles, add the contents of registers R0 and R1 and store the result in the AOR register, output the value WR) in one word (Fig. 3).

The toolset has a system-entry language, a functional simulator, and a device programmer (MagicPro). The system-entry language software is the most critical part. The high-level language uses a structure similar to C's and practically eliminates writing routines in machine or assembly code. But designers who are more comfortable working on that level can write machine-code routines.

5-5

# WSI Launches The Programmable System Device.<sup>™</sup>

## A new class of user-configurable products; a higher standard in functionality, integration, and performance.

**PSD:**<sup> $^{\text{M}}$ </sup> *n* Programmable System Device.<sup> $^{\text{M}}$ </sup> **1**) A user-configurable system-on-a-chip, integrating high-performance EPROM, SRAM, and Logic; **2**) User configurable with a menu-driven, familiar "C"-like language and IBM-PC<sup>®</sup>-hosted system development tools; **3**) A standard product first launched in 1988 by WSI.





Not just programmable logic, but programmable logic and memory -programmable systems.



47280 Kato Road Fremont, California 94538 800/331-1030, extension 234 In California call: 800/323-3939, extension 234

Programmable System Device, PSD, and MAP168 are indemarks of WaferScale Integration, Inc PAL is a registered indemark of Advanced Micro Devices, Inc. IBM PC is a registered indemark of International Business Machines Corporation Cocypright 1988 by WaferScale Integration, Inc. All Ingless interseved





## Section Index

| Package     |        |
|-------------|--------|
| Information | <br>-1 |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.



**Package Information** 

### Drawing C3

#### 44 Pad Ceramic Leadless Chip Carrier (CLLCC) (Package Type C)





100 Pin Ceramic Quad Flatpack (with Window), Gullwing, Fine Pitch (Package Type F)



# Drawing J2 44 Pin Plastic Leaded Chip Carrier (PLDCC) (Package Type J)



Drawing J3

28 Pin Plastic Leaded Chip Carrier (PLDCC) (Package Type J)



# Drawing L2 28 Pin Ceramic Leaded Chip Carrier (CLDCC) with Window (Package Type L)



Drawing L4 44 Pin Ceramic Leaded Chip Carrier (CLDCC) with Window (Package Type L)









Drawing S2

28 Pin Plastic .300 DIP (Package Type S)



Drawing T2

28 Pin CERDIP









Drawing X2 44 Pin Ceramic PGA (Package Type X)







# Section Index

| Sales            |  |
|------------------|--|
| Representatives  |  |
| and Distributors |  |

For additional information, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.



# Sales Representatives and Distributors

WAFERSCALE INTEGRATION, INC.

# Domestic Representatives

#### ALABAMA

Southern Tech. Sales Huntsville Tel: (205) 539-4789 Fax: (205) 539-7449

# ARIZONA

Summit Sales Scottsdale Tel: (602) 998-4850 Fax: (602) 998-5274

#### CALIFORNIA

Bager Electronics Inc. Fountain Valley Tel: (714) 957-3367 Fax: (714) 546-2654

Bager Elecronics Inc. Woodland Hills Tel: (818) 712-0011 Fax: (818) 712-0160

Earle Assoc. Inc. San Diego Tel: (619) 278-5441 Fax: (619) 278-5443

Criterion Santa Clara Tel: (408) 988-6300 Fax: (408) 986-9039

Technology Sales Kentfield Tel: (415) 459-2661 Fax: (415) 459-3341

#### CANADA

Har-Tech Electronics, Ltd. Toronto Tel: (416) 665-7773 Fax: (416) 665-7290

Har-Tech Electronics, Ltd. Montreal Tel: (514) 694-6110 Telex: 05-822679 Fax: (514) 694-8501

Har-Tech Electronics, Ltd. Ottawa Tel: (613) 726-9410 Fax: (613) 726-8834

#### COLORADO

Waugaman Associates, Inc. Wheat Ridge Tel: (303) 423-1020 Fax: (303) 467-3095

### CONNECTICUT

Advanced Tech Sales Wallingford Tel: (203) 284-0838 Fax: (203) 284-8232

#### FLORIDA

Sales Engineering Concepts, Inc. Fort Lauderdale Tel: (305) 426-4601 Fax: (305) 427-7338

Sales Engineering Concepts, Inc. Altamonte Springs Tel: (407) 682-4800 Fax: (407) 682-6491

Sales Engineering Concepts, Inc. Tampa Tel: (407) 682-4800 Fax: (407) 854-3127

# ILLINOIS

Sieger Associates Schaumburg Tel: (708) 310-8844 Telex: 206248 Fax. (708) 310-9530

INDIANA Giesting & Associates Carmel Tel: (317) 844-5222 Fax: (317) 844-5861

# IOWA

Gassner & Clark Co. Cedar Rapids Tel: (319) 393-5763 Twx: 62950087 Fax: (319) 393-5799

#### KANSAS

C. Logsdon & Assoc. Prairie Village Tel: (913) 381-3833 Fax: (913) 381-9774

### MARYLAND

Logical Technology, Inc. Glen Burnie Tel: (301) 766-7444 Fax: (301) 760-2054

#### MASSACHUSETTS

Advanced Tech Sales, Inc. North Reading Tel. (508) 664-0888 Fax: (508) 664-5503

#### MICHIGAN

Giesting & Associates Livonia Tel: (313) 478-8106 Fax: (313) 477-6908

Giesting & Associates Coloma Tel: (616) 468-4200 Fax: (616) 468-6511

#### MINNESOTA

HMR Minneapolis Tel: (612) 988-2122 Fax: (612) 884-4768

#### MISSOURI

John G. Macke Company St. Louis Tel: (314) 432-2830 Fax: (314) 432-1456

NEW JERSEY Strategic Sales, Inc. Teaneck Tel: (201) 833-0099 Fax: (201) 833-0061

S.J. Associates, Inc. Mt. Laurel, NJ 08084 Tel: (609) 866-1234 Fax: (609) 866-8627

# NEW MEXICO

S & S Technologies Albuquerque Tel: (505) 255-5599 Fax: (505) 255-5944

## NEW YORK

Tri-Tech Electronics, Inc East Rochester Tel: (716) 385-6500 Twx: 62934993 Fax: (716) 385-7655

Tri-Tech Electronics Inc. Endwell Tel: (607) 754-1094 Twx: 5102520891 Fax: (607) 785-4557

Tri-Tech Electronics Inc. Fayetteville Tel: (315) 446-2881 Twx: 7105410604 Fax: (315) 446-3047

Tri-Tech Electronics Inc. Fishkill Tel: (914) 897-5611 Twx: 62906505 Fax: (914) 897-5611

# NORTH CAROLINA

Rep, Inc. Morrisville Tel: (919) 469-9997 Twx: 821765 Fax: (919) 481-3879

Rep, Inc. Charlotte Tel: (704) 563-5554 Twx: 821765 Fax: (704) 535-7507

#### оню

Giesting & Associates Cincinnati Tel: (513) 385-1105 Fax: (513) 385-5069

Giesting & Associates Cleveland Tel: (216) 261-9705 Fax: (216) 261-5624

#### OREGON

Thorson Company Northwest Beaverton Tel: (503) 644-5900 Telex: 294835 Fax: (503) 644-5919

#### PENNSYLVANIA

Giesting & Associates Pittsburgh Tel: (412) 828-3553 Fax: (412) 828-5861

#### PUERTO RICO

G & A Associates Milaville, Rio Piedras Tel: (809) 758-7001 Fax: 809-754-0421

#### TEXAS

Southwestern Technical Sales Dallas Tel: (214) 369-0977 Fax: (214) 369-2903

Southwestern Technical Sales Austin

Tel: (512) 440-0499 Southwestern

Technical Sales Houston Tel: (713) 440-9200

#### UTAH

Butterworth Marketing West Valley Tel: (801) 972-5566 Fax: (801) 972-5573

#### WASHINGTON

Thorson Company Northwest Bellevue Tel: (206) 455-9180 Twx: 9104432300 Fax: (206) 455-9185

# Domestic Distributors

#### ALABAMA

Schweber Electronics Huntsville Tel: (205) 895-0480

#### ARIZONA

Schweber Electronics Tempe Tel: (602) 431-0030

Time Electronics Tempe

Tel: (602) 967-2000

Wyle Laboratories Phoenix Tel: (602) 431-0030

## CALIFORNIA

Schweber Electronics Calabasas Tel: (818) 880-9686

Schweber Electronics Irvine Tel: (714) 863-0200

Schweber Electronics Sacramento Tel: (916) 364-0222

Schweber Electronics San Diego Tel: (619) 495-0015

Schweber Electronics San Jose Tel: (408) 432-7171

Time Electronics Torrance Tel: (213) 320-0880

Time Electronics Sunnyvale Tel: (408) 734-9888

Time Electronics Chatsworth Tel: (818) 998-7200

Time Electronics San Diego Tel: (619) 586-1331

Time Electronics Anaheim Tel: (714) 937-0911

Wyle Laboratories Santa Clara Tel: (408) 727-2500

Wyle Laboratories Rancho Cordova Tel: (916) 638-5282

Wyle Laboratories Irvine Tel: (714) 863-9953

Wyle Laboratories

Irvine Tel: (714) 851-9953

Wyle Laboratories Calabasas Tel: (818) 880-9001

Wyle Laboratories San Diego Tel: (619) 565-9171

# CANADA

Time Electronics 2798 Thamesgate Drive, #5 Mississauga, Ontario L4T 4E8 Tel: (416) 672-5300

#### COLORADO

Schweber Electronics Englewood Tel: (303) 799-0258

Time Electronics Englewood Tel: (303) 799-8851

Wyle Laboratories Thornton Tel: (303) 457-9953

CONNECTICUT

Schweber Electronics Oxford Tel: (203) 264-4700

#### FLORIDA

Schweber Electronics Altamonte Springs Tel: (305) 331-7555

Schweber Electronics Largo Tel: (813) 541-5100

Schweber Electronics North Pompano Beach Tel: (305) 997-7511

Time Electronics Ft. Lauderdale Tel: (305) 974-4800

Time Electronics Orlando Tel: (305) 841-6565

#### GEORGIA

Schweber Electronics Norcross Tel: (404) 449-9170

Time Electronics Norcross Tel: (404) 448-4448

#### KANSAS

Schweber Electronics Overland Park Tel: (913) 492-2922

# ILLINOIS

Schweber Electronics Elk Grove Village Tel: (708) 364-3750

Time Electronics Wooddale Tel: (708) 350-0610

#### INDIANA

Schweber Electronics Indianapolis Tel: (317) 843-1050

## IOWA

Schweber Electronics Cedar Rapids Tel: (319) 373-1417

MARYLAND Schweber Electronics Columbia Tel: (301) 596-7800

Time Laboratories Columbia Tel: (301) 964-3090

Vantage Components Columbia Tel: (301) 720-5100 Tel: (301) 621-8555

## MASSACHUSSETTS

Schweber Electronics Bedford Tel: (617) 275-5100

Time Electronics Peabody Tel: (508) 532-9900

Wyle Laboratories Burlington Tel: (617) 272-7300

## MICHIGAN

Schweber Electronics Livonia Tel: (313) 525-8100

MINNESOTA Schweber Electronics Edina Tel: (612) 941-5280

Time Electronics Edina Tel: (612) 835-1250

# MISSOURI

Schweber Electronics Earth City Tel: (314) 739-0526

Time Electronics St. Louis Tel: (314) 391-6444

NEW HAMPSHIRE Schweber Electronics Manchester Tel: (603) 625-2250

NEW JERSEY Schweber Electronics Pinebrook Tel: (201) 227-7880

Time Electronics Pinebrook Tel: (201) 882-4611

Vantage Components Clifton Tel: (201) 777-4100

NEW YORK Schweber Electronics Rochester Tel: (716) 424-2222

#### Schweber Electronics Hauppauge Tel: (516) 231-2500

Schweber Electronics Westbury Tel: (516) 334-7555

Time Electronics Hauppauge Tel: (516) 273-0100

Time Electronics Fairport Tel: (716) 383-8853 Fax: (716) 383-8863

Time Electronics East Syracuse Tel: (315) 432-0355

Vantage Components Smithtown Tel: (516) 543-2000

NORTH CAROLINA Schweber Electronics Raleigh Tel: (919) 876-0000

Time Electronics Charlotte Tel: (704) 522-7600

OHIO Schweber Electronics Beachwood Tel: (216) 464-2970

Schweber Electronics Dayton Tel: (513) 439-1800

Time Electronics Dublin Tel: (614) 761-1100

#### OKLAHOMA

Schweber Electronics Tulsa Tel: (918) 622-8000

## OREGON

Time Electronics Portland Tel: (503) 684-3780

#### PENNSYLVANIA

Schweber Electronics Horsham Tel: (215) 441-0600

Schweber Electronics Pittsburgh Tel: (412) 963-6804

Time Electronics King of Prussia Tel: (215) 337-0900

## TEXAS

Schweber Electronics Austin Tel: (512) 339-0088

Schweber Electronics Dallas Tel: (214) 247-6300

# Domestic Distributors (Cont.)

International

Distributors

# TEXAS Schweber Electronics

Houston Tel: (713) 784-3600

Time Electronics Carrollton Tel: (214) 241-7441

Wyle Laboratories Richardson Tel: (214) 235-9953

# AUSTRALIA

Energy Control Brisbane Tel: 61-7-376-2955 Fax: 61-7-376-3286 Tlx: 43778

#### BELGIUM

Inelco Brussels Tel: 32 2 216 0160 Tix: 84-22090 Fax: 32 2 2164606

#### DENMARK

Distributoren Intereiko, A/S DK-2690 Karlslunde Tel: 45-53-140700 Tlx: 85543507 Fax: 45-53-146805

## ENGLAND

Micro Call Ltd. Thame, Oxon 0X9 3XD Tel: 44 84 426 1939 Fax: 44 84 426 1678

## FINLAND

OY Comdax AB SF-00210 Helsingfors Tel: 358 067 02 77 Tlx: 857125876 Fax: 358 06922326

#### FRANCE

MICROEL Imeuble MICRO Cedex Tel: 33 (1) 69.07.08.24 Tix: 692493F Fax: 33 (1) 69.07.17.23 Wyle Laboratories Houston Tel: (713) 879-9953

Wyle Laboratories Austin

Tel: (512) 834-9957

UTAH Time Electronics West Valley Tel: (801) 973-8181

#### GERMANY

Topas Electronic GmbH 3000 Hannover 1 Tel: (0511) 13 12 17 Tlx: 9218176 Fax: (0511) 13 12 16

Scantec GmbH D-33 Planegg Tel: (089) 859-8021 Tlx: 5213219 Fax: (089) 857-6574

#### HOLLAND

Maxtronix Savannahweg 60 3542 AW UTRECHT Tel: (31) 30-420340 Fax: (31) 30-422440

#### HONG KONG

Components Agent Ltd. New Territories Tel: 0-499-2688 Tlx: 78030398 Fax: 852 0-4136080

#### INDIA

Pamir Electronics Corp. 400 West Lancaster Suite 202 Devon, PA 19333 USA Tel: 215-688-5299 Fax: 215-688-5382 Tlx: 210656 Pamir UR Wyle Laboratories West Valley Tel: (801) 974-9953

# WASHINGTON

ISRAEL

ITALY

Silverstar

JAPAN

20146 Milano

Tel: 39 2 661251

Fax: 39-2-66101359

Setagaya-ku, Tokyo

Fax: 81 3 325 0021

Kyocera Corporation

Setagava-ku, Tokyo

Tel: 321 4415

Tlx: 781 23444

Tel: 3-708-3111

KORFA

Tix: 7812466091

Fax: 81-3-708-3864

Eastern Electronics, Inc.

Sungdong-Ku, Seoul

Tel: 82 2 463-2266

Fax: 82 2 465-2607

Tix: 78727381

Nippon Imex Corporation

Tix: 843332189

Vectronics

P.O. Box 2024

Tix: 922342579

60 Medinat Havehudim St.

Herzlia B 46120. Israel

Tel: 972 52 556070

Fax: 972 52 556508

Time Electronics Redmond Tel: (206) 882-1600 Wyle Laboratories Redmond Tel: (206) 881-1150

# WISCONSIN

Schweber Electronics New Berlin Tel: (414) 784-9020

## NORWAY

OTE A/S N-0617 Oslo 6 Tel: 47 2 306600 TIx: 85678955 Fax: 47 2 321360

#### SPAIN

Unitronics, S.A. 28008 Madrid Tel: 34 1 542 5204 Tlx: 83122596 Fax: 34 1 248 4228

#### SWEDEN

Traco AB S-123 22 Farsta Tel: 468 930011 Tlx: 85410689 Fax: 468 947732

# SWITZERLAND

Laser & Electronic Equipment 8053 Zürich Tel: 41 (1) 55 3330 Tlx: 816801 Fax: 41 (1) 55 3458

#### TAIWAN

Sertek International, Inc. Taipei, 10479, Taiwan Tel: 2-501-0019 Tlx: 78523756

# REGIONAL SALES

North Andover, MA Tel: (508) 685-6101 Fax: 508/685-6105

#### Midwest

Hoffman Estates, IL Tel: (708) 490-5318 Fax: 708/882-1881 Southwest Huntington Beach, CA Tel: (714) 848-6968 Fax: 714/848-5648

Mid-Atlantic Trevose, PA Tel: (215) 638-9617 Fax: 215/638-7326 Southeast Huntsville, AL Tel: (205) 539-7406 Fax: 205/539-7449

Northwest Fremont, CA Tel: (415) 656-5400 Telex: 289255 Fax: 415/657-5916

## EUROPE SALES

Excelsiorlaan 53 1930 Zaventem Belgium Tel: 32-2-725-0546 Fax: 32-2-725-1146

For additional information or assistance, call 800-TEAM-WSI (800-832-6974). In California, call 800-562-6363.

WSI Direct

Sales Offices

7-3

#### LIFE SUPPORT POLICY:

WaferScale Integration, Inc. (WSI) products are not authorized for use as critical components in life support systems or devices without the express written approval of the President of WSI. As used herein:

A) Life support devices or systems are devices or systems which 1) are intended for surgical implant into the body, or 2) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury or death to the user,

B) A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness.

Information furnished herein by WaferScale Integration, Inc. (WSI) is believed to be accurate and reliable. However, no responsibility is assumed for its use. WSI makes no representation that the use of its products or the interconnection of its circuits, as described herein, will not infringe on existing patent rights. No patent liability shall be incurred by WSI for use of the circuits or devices described herein. WSI does not assume any responsibility for use of any circuitry described, no circuit patent rights or licenses are granted or implied, and WSI reserves the right without commitment, at any time without notice, to change said circuitry or specifications. The performance characteristics listed in this book result from specific tests, correlated testing, guard banding, design and other practices common to the industry. Information contained herein supersedes previously published specifications. Contact your WSI sales representative for specific testing details or latest information.

Products in this book may be covered by one or more of the following patents. Additional patents are pending. USA: 4,328,565; 4,361,847; 4,409,723; 4,639,893; 4,649,520; 4,795,719; 4,763,184; 4,758,869 West Germany: 3,103,160 Japan: 1,279,100 England: 2,073,484; 2,073,487

PAL is a registered trademark of Monolithic Memories, Inc. SAM and SAM+PLUS are trademarks of Altera Corporation. MagicPro<sup>™</sup> and Programmable System<sup>™</sup> Devices are trademarks of WaferScale Integration, Inc. ASMILE, SAMSIM and SAMPLUS are trademarks of WaferScale Integration, Inc. and Altera Corporation. MS-DOS is a trademark of Microsoft Corporation. IBM and IBM Personal Computer is a registered trademark of International Business Machines Corporation. Copyright © 1989 WaferScale Integration, Inc. All Rights Reserved.

Patents Pending

Rev. 1.3



WAFERSCALE INTEGRATION, INC.

47280 Kato Road, Fremont, CA 94538-7333 415-656-5400 FAX: 415-657-5916 TELEX: 289255 800-TEAM-WSI (800-832-6974) IN CALIFORNIA 800-562-6363 Printed in U.S.A.